Update mastodon frontend
[akkoma] / priv / static / packs / modals / onboarding_modal.js.map
index 49ccebe4d986a172546e50325d11563e8705f26f..5e70e5e5b70e7f1fcbcedf489070442d06a5e232 100644 (file)
@@ -1 +1 @@
-{"version":3,"sources":["webpack:///modals/onboarding_modal.js","webpack:///./app/javascript/mastodon/features/ui/components/column_header.js","webpack:///./app/javascript/mastodon/features/compose/components/compose_form.js","webpack:///./app/javascript/mastodon/features/compose/components/character_counter.js","webpack:///./app/javascript/mastodon/features/compose/containers/reply_indicator_container.js","webpack:///./app/javascript/mastodon/features/compose/components/reply_indicator.js","webpack:///./app/javascript/mastodon/components/autosuggest_textarea.js","webpack:///./app/javascript/mastodon/features/compose/containers/autosuggest_account_container.js","webpack:///./app/javascript/mastodon/features/compose/components/autosuggest_account.js","webpack:///./app/javascript/mastodon/components/autosuggest_emoji.js","webpack:///./node_modules/react-textarea-autosize/es/index.js","webpack:///./app/javascript/mastodon/features/compose/containers/upload_button_container.js","webpack:///./app/javascript/mastodon/features/compose/components/upload_button.js","webpack:///./app/javascript/mastodon/components/collapsable.js","webpack:///./app/javascript/mastodon/features/compose/containers/spoiler_button_container.js","webpack:///./app/javascript/mastodon/features/compose/components/text_icon_button.js","webpack:///./app/javascript/mastodon/features/compose/containers/privacy_dropdown_container.js","webpack:///./app/javascript/mastodon/features/compose/components/privacy_dropdown.js","webpack:///./app/javascript/mastodon/features/compose/containers/sensitive_button_container.js","webpack:///./app/javascript/mastodon/features/compose/containers/emoji_picker_dropdown_container.js","webpack:///./app/javascript/mastodon/features/compose/components/emoji_picker_dropdown.js","webpack:///./app/javascript/mastodon/features/compose/containers/upload_form_container.js","webpack:///./app/javascript/mastodon/features/compose/components/upload_form.js","webpack:///./app/javascript/mastodon/features/compose/containers/upload_progress_container.js","webpack:///./app/javascript/mastodon/features/compose/components/upload_progress.js","webpack:///./app/javascript/mastodon/features/compose/containers/upload_container.js","webpack:///./app/javascript/mastodon/features/compose/components/upload.js","webpack:///./app/javascript/mastodon/features/compose/containers/warning_container.js","webpack:///./app/javascript/mastodon/features/compose/components/warning.js","webpack:///./app/javascript/mastodon/features/compose/util/counter.js","webpack:///./app/javascript/mastodon/features/compose/util/url_regex.js","webpack:///./app/javascript/mastodon/features/ui/components/onboarding_modal.js","webpack:///./app/javascript/mastodon/features/compose/components/navigation_bar.js","webpack:///./app/javascript/mastodon/features/compose/components/search.js"],"names":["webpackJsonp","150","module","__webpack_exports__","__webpack_require__","d","ColumnHeader","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__","__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default","n","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default","__WEBPACK_IMPORTED_MODULE_4_react__","__WEBPACK_IMPORTED_MODULE_4_react___default","__WEBPACK_IMPORTED_MODULE_5_classnames__","__WEBPACK_IMPORTED_MODULE_5_classnames___default","_React$PureComponent","_temp","_this","_ret","this","_len","arguments","length","args","Array","_key","call","apply","concat","handleClick","props","onClick","prototype","render","_props","icon","type","active","columnHeaderId","iconElement","className","id","a","PureComponent","302","ComposeForm","_class","_class2","_temp2","__WEBPACK_IMPORTED_MODULE_5__character_counter__","__WEBPACK_IMPORTED_MODULE_6__components_button__","__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_reply_indicator_container__","__WEBPACK_IMPORTED_MODULE_10__components_autosuggest_textarea__","__WEBPACK_IMPORTED_MODULE_11__containers_upload_button_container__","__WEBPACK_IMPORTED_MODULE_12_react_intl__","__WEBPACK_IMPORTED_MODULE_13__components_collapsable__","__WEBPACK_IMPORTED_MODULE_14__containers_spoiler_button_container__","__WEBPACK_IMPORTED_MODULE_15__containers_privacy_dropdown_container__","__WEBPACK_IMPORTED_MODULE_16__containers_sensitive_button_container__","__WEBPACK_IMPORTED_MODULE_17__containers_emoji_picker_dropdown_container__","__WEBPACK_IMPORTED_MODULE_18__containers_upload_form_container__","__WEBPACK_IMPORTED_MODULE_19__containers_warning_container__","__WEBPACK_IMPORTED_MODULE_20__is_mobile__","__WEBPACK_IMPORTED_MODULE_21_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_21_react_immutable_pure_component___default","__WEBPACK_IMPORTED_MODULE_22_stringz__","__WEBPACK_IMPORTED_MODULE_23__util_counter__","__WEBPACK_IMPORTED_MODULE_24__initial_state__","messages","Object","placeholder","defaultMessage","spoiler_placeholder","publish","publishLoud","_ImmutablePureCompone","handleChange","e","onChange","target","value","handleKeyDown","keyCode","ctrlKey","metaKey","handleSubmit","text","autosuggestTextarea","textarea","onSubmit","onSuggestionsClearRequested","onClearSuggestions","onSuggestionsFetchRequested","token","onFetchSuggestions","onSuggestionSelected","tokenStart","_restoreCaret","handleChangeSpoilerText","onChangeSpoilerText","setAutosuggestTextarea","c","handleEmojiPick","data","position","selectionStart","emojiChar","native","onPickEmoji","componentWillReceiveProps","nextProps","is_uploading","componentDidUpdate","prevProps","focusDate","selectionEnd","preselectDate","search","setSelectionRange","focus","is_submitting","intl","onPaste","showSearch","anyMedia","disabled","spoiler_text","join","disabledButton","trim","publishText","privacy","formatMessage","isVisible","spoiler","fullHeight","style","display","onKeyDown","createElement","ref","suggestions","autoFocus","window","innerWidth","max","block","propTypes","object","isRequired","string","suggestion_token","list","bool","instanceOf","Date","func","defaultProps","303","CharacterCounter","__WEBPACK_IMPORTED_MODULE_5_stringz__","checkRemainingText","diff","304","__WEBPACK_IMPORTED_MODULE_0_react_redux__","__WEBPACK_IMPORTED_MODULE_1__actions_compose__","__WEBPACK_IMPORTED_MODULE_2__selectors__","__WEBPACK_IMPORTED_MODULE_3__components_reply_indicator__","makeMapStateToProps","getStatus","state","status","getIn","mapDispatchToProps","dispatch","onCancel","305","ReplyIndicator","__WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes__","__WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default","__WEBPACK_IMPORTED_MODULE_6_prop_types__","__WEBPACK_IMPORTED_MODULE_6_prop_types___default","__WEBPACK_IMPORTED_MODULE_7__components_avatar__","__WEBPACK_IMPORTED_MODULE_8__components_icon_button__","__WEBPACK_IMPORTED_MODULE_9__components_display_name__","__WEBPACK_IMPORTED_MODULE_10_react_intl__","__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default","__WEBPACK_IMPORTED_MODULE_12__rtl__","cancel","handleAccountClick","button","preventDefault","context","router","history","push","content","__html","get","direction","title","href","account","size","dangerouslySetInnerHTML","contextTypes","map","306","AutosuggestTextarea","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_typeof__","__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_typeof___default","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_classCallCheck__","__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_classCallCheck___default","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_possibleConstructorReturn__","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_possibleConstructorReturn___default","__WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_inherits__","__WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_inherits___default","__WEBPACK_IMPORTED_MODULE_5_react__","__WEBPACK_IMPORTED_MODULE_6__features_compose_containers_autosuggest_account_container__","__WEBPACK_IMPORTED_MODULE_7__autosuggest_emoji__","__WEBPACK_IMPORTED_MODULE_8_react_immutable_proptypes__","__WEBPACK_IMPORTED_MODULE_8_react_immutable_proptypes___default","__WEBPACK_IMPORTED_MODULE_9_prop_types__","__WEBPACK_IMPORTED_MODULE_9_prop_types___default","__WEBPACK_IMPORTED_MODULE_10__rtl__","__WEBPACK_IMPORTED_MODULE_12_react_textarea_autosize__","__WEBPACK_IMPORTED_MODULE_13_classnames__","__WEBPACK_IMPORTED_MODULE_13_classnames___default","textAtCursorMatchesToken","str","caretPosition","word","left","slice","right","indexOf","toLowerCase","suggestionsHidden","selectedSuggestion","lastToken","_textAtCursorMatchesT","setState","_this$props","_this$state","key","Math","min","stopPropagation","defaultPrevented","onKeyUp","document","querySelector","parentElement","onBlur","onSuggestionClick","suggestion","currentTarget","getAttribute","setTextarea","clipboardData","files","renderSuggestion","i","inner","emoji","role","tabIndex","data-index","selected","onMouseDown","inputRef","aria-autocomplete","isEmpty","307","__WEBPACK_IMPORTED_MODULE_1__components_autosuggest_account__","getAccount","_ref","308","AutosuggestAccount","__WEBPACK_IMPORTED_MODULE_5__components_avatar__","__WEBPACK_IMPORTED_MODULE_6__components_display_name__","__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component___default","309","process","AutosuggestEmoji","__WEBPACK_IMPORTED_MODULE_5__features_emoji_emoji_unicode_mapping_light__","__WEBPACK_IMPORTED_MODULE_5__features_emoji_emoji_unicode_mapping_light___default","assetHost","env","CDN_HOST","url","custom","imageUrl","mapping","replace","filename","src","alt","colons","310","_extends","assign","source","hasOwnProperty","_inheritsLoose","subClass","superClass","create","constructor","__proto__","_objectWithoutProperties","excluded","sourceKeys","keys","getOwnPropertySymbols","sourceSymbolKeys","propertyIsEnumerable","calculateNodeHeight","uiTextNode","uid","useCache","minRows","maxRows","hiddenTextarea","parentNode","body","appendChild","nodeStyling","calculateNodeStyling","paddingSize","borderSize","boxSizing","sizingStyle","forEach","HIDDEN_TEXTAREA_STYLE","setProperty","minHeight","Infinity","maxHeight","height","scrollHeight","singleRowHeight","rowCount","floor","node","computedStyleCache","getComputedStyle","SIZING_STYLE","reduce","obj","name","getPropertyValue","isIE","width","parseFloat","nodeInfo","__WEBPACK_IMPORTED_MODULE_0_react__","__WEBPACK_IMPORTED_MODULE_0_react___default","__WEBPACK_IMPORTED_MODULE_1_prop_types__","isBrowser","documentElement","currentStyle","min-height","max-height","visibility","overflow","z-index","top","purgeCache","seed","noop","requestAnimationFrame","cancelAnimationFrame","setTimeout","clearTimeout","onNextFrame","clearNextFrameAction","TextareaAutosize","_React$Component","_resizeLock","_onRootDOMNode","_rootDOMNode","_onChange","event","_controlled","_resizeComponent","callback","nodeHeight","_uid","useCacheForDOMMeasurements","_proto","onHeightChange","componentDidMount","_this2","_resizeListener","addEventListener","_this3","_clearNextFrame","_onNextFrameActionId","prevState","componentWillUnmount","removeEventListener","Component","311","__WEBPACK_IMPORTED_MODULE_1__components_upload_button__","__WEBPACK_IMPORTED_MODULE_2__actions_compose__","mapStateToProps","some","m","resetFileKey","onSelectFile","312","UploadButton","_dec","__WEBPACK_IMPORTED_MODULE_5__components_icon_button__","__WEBPACK_IMPORTED_MODULE_7_react_intl__","__WEBPACK_IMPORTED_MODULE_8_react_redux__","__WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component___default","__WEBPACK_IMPORTED_MODULE_10_react_immutable_proptypes__","__WEBPACK_IMPORTED_MODULE_10_react_immutable_proptypes___default","upload","acceptContentTypes","iconStyle","lineHeight","fileElement","click","setRef","inverted","multiple","accept","toArray","number","listOf","313","__WEBPACK_IMPORTED_MODULE_1_react__","__WEBPACK_IMPORTED_MODULE_2__features_ui_util_optional_motion__","__WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring__","__WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring___default","Collapsable","children","defaultStyle","opacity","_ref2","314","__WEBPACK_IMPORTED_MODULE_1__components_text_icon_button__","__WEBPACK_IMPORTED_MODULE_3_react_intl__","marked","unmarked","label","ariaControls","315","TextIconButton","aria-label","aria-expanded","aria-controls","316","__WEBPACK_IMPORTED_MODULE_1__components_privacy_dropdown__","__WEBPACK_IMPORTED_MODULE_3__actions_modal__","__WEBPACK_IMPORTED_MODULE_4__is_mobile__","isModalOpen","modalType","isUserTouching","onModalOpen","onModalClose","317","PrivacyDropdown","__WEBPACK_IMPORTED_MODULE_5_react_intl__","__WEBPACK_IMPORTED_MODULE_6__components_icon_button__","__WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay__","__WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay___default","__WEBPACK_IMPORTED_MODULE_8__ui_util_optional_motion__","__WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring__","__WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring___default","__WEBPACK_IMPORTED_MODULE_10_detect_passive_events__","__WEBPACK_IMPORTED_MODULE_10_detect_passive_events___default","__WEBPACK_IMPORTED_MODULE_11_classnames__","__WEBPACK_IMPORTED_MODULE_11_classnames___default","public_short","public_long","unlisted_short","unlisted_long","private_short","private_long","direct_short","direct_long","change_privacy","listenerOptions","hasSupport","passive","PrivacyDropdownMenu","handleDocumentClick","contains","onClose","items","scaleX","scaleY","damping","stiffness","transform","item","meta","_React$PureComponent2","_ret2","_len2","_key2","open","handleToggle","actions","options","option","handleModalActionClick","handleClose","componentWillMount","_props2","valueOption","find","expanded","show","placement","318","__WEBPACK_IMPORTED_MODULE_5_react_redux__","__WEBPACK_IMPORTED_MODULE_6_classnames__","__WEBPACK_IMPORTED_MODULE_6_classnames___default","__WEBPACK_IMPORTED_MODULE_7__components_icon_button__","__WEBPACK_IMPORTED_MODULE_8__actions_compose__","__WEBPACK_IMPORTED_MODULE_9__ui_util_optional_motion__","__WEBPACK_IMPORTED_MODULE_10_react_motion_lib_spring__","__WEBPACK_IMPORTED_MODULE_10_react_motion_lib_spring___default","__WEBPACK_IMPORTED_MODULE_11_react_intl__","visible","SensitiveButton","scale","compose-form__sensitive-button--visible","319","__WEBPACK_IMPORTED_MODULE_1__components_emoji_picker_dropdown__","__WEBPACK_IMPORTED_MODULE_2__actions_settings__","__WEBPACK_IMPORTED_MODULE_3_reselect__","__WEBPACK_IMPORTED_MODULE_4_immutable__","__WEBPACK_IMPORTED_MODULE_5__actions_emojis__","DEFAULTS","getFrequentlyUsedEmojis","emojiCounters","emojis","keySeq","sort","b","reverse","perLine","getCustomEmojis","filter","aShort","bShort","custom_emojis","skinTone","frequentlyUsedEmojis","onSkinTone","320","EmojiPickerDropdown","_class3","_class4","_temp4","_class5","__WEBPACK_IMPORTED_MODULE_6__ui_util_async_components__","__WEBPACK_IMPORTED_MODULE_8_classnames__","__WEBPACK_IMPORTED_MODULE_8_classnames___default","__WEBPACK_IMPORTED_MODULE_9_detect_passive_events__","__WEBPACK_IMPORTED_MODULE_9_detect_passive_events___default","__WEBPACK_IMPORTED_MODULE_10__emoji_emoji__","emoji_search","emoji_not_found","recent","search_results","people","nature","food","activity","travel","objects","symbols","flags","EmojiPicker","Emoji","backgroundImageFn","categoriesSort","ModifierPickerMenu","onSelect","attachListeners","removeListeners","set","sheetSize","skin","ModifierPicker","onOpen","handleSelect","modifier","EmojiPickerMenu","_React$PureComponent3","_temp3","_ret3","_len3","_key3","modifierOpen","getI18n","notfound","categories","foods","places","onPick","handleModifierOpen","handleModifierClose","handleModifierChange","loading","selecting","emojiSize","color","i18n","include","showPreview","emojiTooltip","_React$PureComponent4","_temp5","_this4","_ret4","_len4","_key4","dropdown","onShowDropdown","then","EmojiMart","Picker","catch","onHideDropdown","onToggle","setTargetRef","findTarget","_props3","_state","pulse-loading","321","__WEBPACK_IMPORTED_MODULE_1__components_upload_form__","mediaIds","322","UploadForm","__WEBPACK_IMPORTED_MODULE_6__containers_upload_progress_container__","__WEBPACK_IMPORTED_MODULE_7_react_immutable_pure_component__","__WEBPACK_IMPORTED_MODULE_7_react_immutable_pure_component___default","__WEBPACK_IMPORTED_MODULE_8__containers_upload_container__","323","__WEBPACK_IMPORTED_MODULE_1__components_upload_progress__","progress","324","UploadProgress","__WEBPACK_IMPORTED_MODULE_5__ui_util_optional_motion__","__WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring__","__WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default","325","__WEBPACK_IMPORTED_MODULE_1__components_upload__","media","onUndo","onDescriptionChange","description","onOpenFocalPoint","326","Upload","__WEBPACK_IMPORTED_MODULE_7__ui_util_optional_motion__","__WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring__","__WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default","hovered","focused","dirtyDescription","handleUndoClick","handleFocalPointClick","handleInputChange","handleMouseEnter","handleMouseLeave","handleInputFocus","handleInputBlur","focusX","focusY","x","y","onMouseEnter","onMouseLeave","backgroundImage","backgroundPosition","maxLength","onFocus","327","__WEBPACK_IMPORTED_MODULE_2_react_redux__","__WEBPACK_IMPORTED_MODULE_3__components_warning__","__WEBPACK_IMPORTED_MODULE_4_react_intl__","__WEBPACK_IMPORTED_MODULE_5__initial_state__","APPROX_HASHTAG_RE","needsLockWarning","hashtagWarning","test","directMessageWarning","WarningWrapper","message","values","locked","328","Warning","329","countableText","inputText","__WEBPACK_IMPORTED_MODULE_0__url_regex__","urlPlaceholder","330","urlRegex","regexen","regexSupplant","regex","global","ignoreCase","multiline","RegExp","match","newRegex","stringSupplant","spaces_group","invalid_chars_group","punct","validUrlPrecedingChars","invalidDomainChars","validDomainChars","validSubdomain","validDomainName","validGTLD","validCCTLD","validPunycode","validSpecialCCTLD","validDomain","validPortNumber","pd","validGeneralUrlPathChars","validUrlBalancedParens","validUrlPathEndingChars","validUrlPath","validUrlQueryChars","validUrlQueryEndingChars","validUrl","823","defineProperty","OnboardingModal","__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_babel_runtime_helpers_jsx__","__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default","__WEBPACK_IMPORTED_MODULE_6_react_intl__","__WEBPACK_IMPORTED_MODULE_7_react_swipeable_views__","__WEBPACK_IMPORTED_MODULE_7_react_swipeable_views___default","__WEBPACK_IMPORTED_MODULE_9__components_permalink__","__WEBPACK_IMPORTED_MODULE_10__compose_components_compose_form__","__WEBPACK_IMPORTED_MODULE_11__compose_components_search__","__WEBPACK_IMPORTED_MODULE_12__compose_components_navigation_bar__","__WEBPACK_IMPORTED_MODULE_13__column_header__","__WEBPACK_IMPORTED_MODULE_14_immutable__","__WEBPACK_IMPORTED_MODULE_15__initial_state__","home_title","notifications_title","local_title","federated_title","PageOne","acct","domain","PageTwo","myAccount","mentionedDomains","PageThree","_ref3","onClear","onShow","illustration","to","introductions","PageFour","_ref4","marginBottom","PageSix","_ref5","admin","adminSection","guidelines","github","rel","apps","currentIndex","handleSkip","handleDot","Number","handlePrev","_ref6","handleNext","pages","_ref7","handleSwipe","index","handleKeyUp","_ref8","hasMore","nextOrDoneBtn","onChangeIndex","page","onboarding-modal__page__wrapper--active","_","863","NavigationBar","__WEBPACK_IMPORTED_MODULE_5_prop_types__","__WEBPACK_IMPORTED_MODULE_5_prop_types___default","__WEBPACK_IMPORTED_MODULE_6_react_immutable_proptypes__","__WEBPACK_IMPORTED_MODULE_6_react_immutable_proptypes___default","864","Search","__WEBPACK_IMPORTED_MODULE_6_react_overlays_lib_Overlay__","__WEBPACK_IMPORTED_MODULE_6_react_overlays_lib_Overlay___default","__WEBPACK_IMPORTED_MODULE_9__initial_state__","SearchPopout","extraInformation","handleClear","submitted","handleFocus","handleBlur","hasValue"],"mappings":"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","file":"modals/onboarding_modal.js","sourcesContent":["webpackJsonp([3],{\n\n/***/ 150:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ColumnHeader; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_classnames__);\n\n\n\n\n\n\n\n\nvar ColumnHeader = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ColumnHeader, _React$PureComponent);\n\n  function ColumnHeader() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ColumnHeader);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.handleClick = function () {\n      _this.props.onClick();\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ColumnHeader.prototype.render = function render() {\n    var _props = this.props,\n        icon = _props.icon,\n        type = _props.type,\n        active = _props.active,\n        columnHeaderId = _props.columnHeaderId;\n\n    var iconElement = '';\n\n    if (icon) {\n      iconElement = __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n        className: 'fa fa-fw fa-' + icon + ' column-header__icon'\n      });\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('h1', {\n      className: __WEBPACK_IMPORTED_MODULE_5_classnames___default()('column-header', { active: active }),\n      id: columnHeaderId || null\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n      onClick: this.handleClick\n    }, void 0, iconElement, type));\n  };\n\n  return ColumnHeader;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 302:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ComposeForm; });\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__character_counter__ = __webpack_require__(303);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__components_button__ = __webpack_require__(101);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__ = __webpack_require__(13);\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_reply_indicator_container__ = __webpack_require__(304);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__components_autosuggest_textarea__ = __webpack_require__(306);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11__containers_upload_button_container__ = __webpack_require__(311);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13__components_collapsable__ = __webpack_require__(313);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14__containers_spoiler_button_container__ = __webpack_require__(314);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_15__containers_privacy_dropdown_container__ = __webpack_require__(316);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_16__containers_sensitive_button_container__ = __webpack_require__(318);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_17__containers_emoji_picker_dropdown_container__ = __webpack_require__(319);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_18__containers_upload_form_container__ = __webpack_require__(321);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_19__containers_warning_container__ = __webpack_require__(327);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_20__is_mobile__ = __webpack_require__(35);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_21_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_21_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_21_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_22_stringz__ = __webpack_require__(98);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_22_stringz___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_22_stringz__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_23__util_counter__ = __webpack_require__(329);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_24__initial_state__ = __webpack_require__(11);\n\n\n\n\n\nvar _class, _class2, _temp2;\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_12_react_intl__[\"f\" /* defineMessages */])({\n  placeholder: {\n    'id': 'compose_form.placeholder',\n    'defaultMessage': 'What is on your mind?'\n  },\n  spoiler_placeholder: {\n    'id': 'compose_form.spoiler_placeholder',\n    'defaultMessage': 'Write your warning here'\n  },\n  publish: {\n    'id': 'compose_form.publish',\n    'defaultMessage': 'Toot'\n  },\n  publishLoud: {\n    'id': 'compose_form.publish_loud',\n    'defaultMessage': '{publish}!'\n  }\n});\n\nvar ComposeForm = Object(__WEBPACK_IMPORTED_MODULE_12_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ComposeForm, _ImmutablePureCompone);\n\n  function ComposeForm() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ComposeForm);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.handleChange = function (e) {\n      _this.props.onChange(e.target.value);\n    }, _this.handleKeyDown = function (e) {\n      if (e.keyCode === 13 && (e.ctrlKey || e.metaKey)) {\n        _this.handleSubmit();\n      }\n    }, _this.handleSubmit = function () {\n      if (_this.props.text !== _this.autosuggestTextarea.textarea.value) {\n        // Something changed the text inside the textarea (e.g. browser extensions like Grammarly)\n        // Update the state to match the current text\n        _this.props.onChange(_this.autosuggestTextarea.textarea.value);\n      }\n\n      _this.props.onSubmit();\n    }, _this.onSuggestionsClearRequested = function () {\n      _this.props.onClearSuggestions();\n    }, _this.onSuggestionsFetchRequested = function (token) {\n      _this.props.onFetchSuggestions(token);\n    }, _this.onSuggestionSelected = function (tokenStart, token, value) {\n      _this._restoreCaret = null;\n      _this.props.onSuggestionSelected(tokenStart, token, value);\n    }, _this.handleChangeSpoilerText = function (e) {\n      _this.props.onChangeSpoilerText(e.target.value);\n    }, _this.setAutosuggestTextarea = function (c) {\n      _this.autosuggestTextarea = c;\n    }, _this.handleEmojiPick = function (data) {\n      var position = _this.autosuggestTextarea.textarea.selectionStart;\n      var emojiChar = data.native;\n      _this._restoreCaret = position + emojiChar.length + 1;\n      _this.props.onPickEmoji(position, data);\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ComposeForm.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n    // If this is the update where we've finished uploading,\n    // save the last caret position so we can restore it below!\n    if (!nextProps.is_uploading && this.props.is_uploading) {\n      this._restoreCaret = this.autosuggestTextarea.textarea.selectionStart;\n    }\n  };\n\n  ComposeForm.prototype.componentDidUpdate = function componentDidUpdate(prevProps) {\n    // This statement does several things:\n    // - If we're beginning a reply, and,\n    //     - Replying to zero or one users, places the cursor at the end of the textbox.\n    //     - Replying to more than one user, selects any usernames past the first;\n    //       this provides a convenient shortcut to drop everyone else from the conversation.\n    // - If we've just finished uploading an image, and have a saved caret position,\n    //   restores the cursor to that position after the text changes!\n    if (this.props.focusDate !== prevProps.focusDate || prevProps.is_uploading && !this.props.is_uploading && typeof this._restoreCaret === 'number') {\n      var selectionEnd = void 0,\n          selectionStart = void 0;\n\n      if (this.props.preselectDate !== prevProps.preselectDate) {\n        selectionEnd = this.props.text.length;\n        selectionStart = this.props.text.search(/\\s/) + 1;\n      } else if (typeof this._restoreCaret === 'number') {\n        selectionStart = this._restoreCaret;\n        selectionEnd = this._restoreCaret;\n      } else {\n        selectionEnd = this.props.text.length;\n        selectionStart = selectionEnd;\n      }\n\n      this.autosuggestTextarea.textarea.setSelectionRange(selectionStart, selectionEnd);\n      this.autosuggestTextarea.textarea.focus();\n    } else if (prevProps.is_submitting && !this.props.is_submitting) {\n      this.autosuggestTextarea.textarea.focus();\n    }\n  };\n\n  ComposeForm.prototype.render = function render() {\n    var _props = this.props,\n        intl = _props.intl,\n        onPaste = _props.onPaste,\n        showSearch = _props.showSearch,\n        anyMedia = _props.anyMedia;\n\n    var disabled = this.props.is_submitting;\n    var text = [this.props.spoiler_text, Object(__WEBPACK_IMPORTED_MODULE_23__util_counter__[\"a\" /* countableText */])(this.props.text)].join('');\n    var disabledButton = disabled || this.props.is_uploading || Object(__WEBPACK_IMPORTED_MODULE_22_stringz__[\"length\"])(text) > __WEBPACK_IMPORTED_MODULE_24__initial_state__[\"c\" /* charLimit */] || text.length !== 0 && text.trim().length === 0 && !anyMedia;\n    var publishText = '';\n\n    if (this.props.privacy === 'private' || this.props.privacy === 'direct') {\n      publishText = __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n        className: 'compose-form__publish-private'\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n        className: 'fa fa-lock'\n      }), ' ', intl.formatMessage(messages.publish));\n    } else {\n      publishText = this.props.privacy !== 'unlisted' ? intl.formatMessage(messages.publishLoud, { publish: intl.formatMessage(messages.publish) }) : intl.formatMessage(messages.publish);\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_19__containers_warning_container__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_13__components_collapsable__[\"a\" /* default */], {\n      isVisible: this.props.spoiler,\n      fullHeight: 50\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'spoiler-input'\n    }, void 0, __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, intl.formatMessage(messages.spoiler_placeholder)), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('input', {\n      placeholder: intl.formatMessage(messages.spoiler_placeholder),\n      value: this.props.spoiler_text,\n      onChange: this.handleChangeSpoilerText,\n      onKeyDown: this.handleKeyDown,\n      type: 'text',\n      className: 'spoiler-input__input',\n      id: 'cw-spoiler-input'\n    })))), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__containers_reply_indicator_container__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__autosuggest-wrapper'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_10__components_autosuggest_textarea__[\"a\" /* default */], {\n      ref: this.setAutosuggestTextarea,\n      placeholder: intl.formatMessage(messages.placeholder),\n      disabled: disabled,\n      value: this.props.text,\n      onChange: this.handleChange,\n      suggestions: this.props.suggestions,\n      onKeyDown: this.handleKeyDown,\n      onSuggestionsFetchRequested: this.onSuggestionsFetchRequested,\n      onSuggestionsClearRequested: this.onSuggestionsClearRequested,\n      onSuggestionSelected: this.onSuggestionSelected,\n      onPaste: onPaste,\n      autoFocus: !showSearch && !Object(__WEBPACK_IMPORTED_MODULE_20__is_mobile__[\"b\" /* isMobile */])(window.innerWidth)\n    }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_17__containers_emoji_picker_dropdown_container__[\"a\" /* default */], {\n      onPickEmoji: this.handleEmojiPick\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__modifiers'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_18__containers_upload_form_container__[\"a\" /* default */], {})), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__buttons-wrapper'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__buttons'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11__containers_upload_button_container__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_15__containers_privacy_dropdown_container__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_16__containers_sensitive_button_container__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_14__containers_spoiler_button_container__[\"a\" /* default */], {})), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'character-counter__wrapper'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5__character_counter__[\"a\" /* default */], {\n      max: __WEBPACK_IMPORTED_MODULE_24__initial_state__[\"c\" /* charLimit */],\n      text: text\n    }))), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__publish'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__publish-button-wrapper'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__components_button__[\"a\" /* default */], {\n      text: publishText,\n      onClick: this.handleSubmit,\n      disabled: disabledButton,\n      block: true\n    }))));\n  };\n\n  return ComposeForm;\n}(__WEBPACK_IMPORTED_MODULE_21_react_immutable_pure_component___default.a), _class2.propTypes = {\n  intl: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.object.isRequired,\n  text: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.string.isRequired,\n  suggestion_token: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.string,\n  suggestions: __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default.a.list,\n  spoiler: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  privacy: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.string,\n  spoiler_text: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.string,\n  focusDate: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.instanceOf(Date),\n  preselectDate: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.instanceOf(Date),\n  is_submitting: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  is_uploading: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  onChange: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onSubmit: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onClearSuggestions: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onFetchSuggestions: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onSuggestionSelected: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onChangeSpoilerText: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onPaste: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  onPickEmoji: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.func.isRequired,\n  showSearch: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool,\n  anyMedia: __WEBPACK_IMPORTED_MODULE_8_prop_types___default.a.bool\n}, _class2.defaultProps = {\n  showSearch: false\n}, _temp2)) || _class;\n\n\n\n/***/ }),\n\n/***/ 303:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return CharacterCounter; });\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_stringz__ = __webpack_require__(98);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_stringz___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_stringz__);\n\n\n\n\n\n\n\n\nvar CharacterCounter = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(CharacterCounter, _React$PureComponent);\n\n  function CharacterCounter() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, CharacterCounter);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  CharacterCounter.prototype.checkRemainingText = function checkRemainingText(diff) {\n    if (diff < 0) {\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n        className: 'character-counter character-counter--over'\n      }, void 0, diff);\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n      className: 'character-counter'\n    }, void 0, diff);\n  };\n\n  CharacterCounter.prototype.render = function render() {\n    var diff = this.props.max - Object(__WEBPACK_IMPORTED_MODULE_5_stringz__[\"length\"])(this.props.text);\n    return this.checkRemainingText(diff);\n  };\n\n  return CharacterCounter;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 304:\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__actions_compose__ = __webpack_require__(18);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__selectors__ = __webpack_require__(66);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_reply_indicator__ = __webpack_require__(305);\n\n\n\n\n\nvar makeMapStateToProps = function makeMapStateToProps() {\n  var getStatus = Object(__WEBPACK_IMPORTED_MODULE_2__selectors__[\"e\" /* makeGetStatus */])();\n\n  var mapStateToProps = function mapStateToProps(state) {\n    return {\n      status: getStatus(state, state.getIn(['compose', 'in_reply_to']))\n    };\n  };\n\n  return mapStateToProps;\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n    onCancel: function onCancel() {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_1__actions_compose__[\"E\" /* cancelReplyCompose */])());\n    }\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(makeMapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_3__components_reply_indicator__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 305:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return ReplyIndicator; });\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_immutable_proptypes__ = __webpack_require__(13);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__components_avatar__ = __webpack_require__(56);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__components_icon_button__ = __webpack_require__(23);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__components_display_name__ = __webpack_require__(55);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__rtl__ = __webpack_require__(97);\n\n\n\n\n\nvar _class, _class2, _temp2;\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"f\" /* defineMessages */])({\n  cancel: {\n    'id': 'reply_indicator.cancel',\n    'defaultMessage': 'Cancel'\n  }\n});\n\nvar ReplyIndicator = Object(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ReplyIndicator, _ImmutablePureCompone);\n\n  function ReplyIndicator() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ReplyIndicator);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.handleClick = function () {\n      _this.props.onCancel();\n    }, _this.handleAccountClick = function (e) {\n      if (e.button === 0) {\n        e.preventDefault();\n        _this.context.router.history.push('/accounts/' + _this.props.status.getIn(['account', 'id']));\n      }\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ReplyIndicator.prototype.render = function render() {\n    var _props = this.props,\n        status = _props.status,\n        intl = _props.intl;\n\n\n    if (!status) {\n      return null;\n    }\n\n    var content = { __html: status.get('contentHtml') };\n    var style = {\n      direction: Object(__WEBPACK_IMPORTED_MODULE_12__rtl__[\"a\" /* isRtl */])(status.get('search_index')) ? 'rtl' : 'ltr'\n    };\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'reply-indicator'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'reply-indicator__header'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'reply-indicator__cancel'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_8__components_icon_button__[\"a\" /* default */], {\n      title: intl.formatMessage(messages.cancel),\n      icon: 'times',\n      onClick: this.handleClick\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('a', {\n      href: status.getIn(['account', 'url']),\n      onClick: this.handleAccountClick,\n      className: 'reply-indicator__display-name'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'reply-indicator__display-avatar'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__components_avatar__[\"a\" /* default */], {\n      account: status.get('account'),\n      size: 24\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_display_name__[\"a\" /* default */], {\n      account: status.get('account')\n    }))), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'reply-indicator__content',\n      style: style,\n      dangerouslySetInnerHTML: content\n    }));\n  };\n\n  return ReplyIndicator;\n}(__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default.a), _class2.contextTypes = {\n  router: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object\n}, _class2.propTypes = {\n  status: __WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default.a.map,\n  onCancel: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.func.isRequired,\n  intl: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object.isRequired\n}, _temp2)) || _class;\n\n\n\n/***/ }),\n\n/***/ 306:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return AutosuggestTextarea; });\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_typeof__ = __webpack_require__(32);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_typeof___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_typeof__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_inherits__);\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__features_compose_containers_autosuggest_account_container__ = __webpack_require__(307);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__autosuggest_emoji__ = __webpack_require__(309);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_immutable_proptypes__ = __webpack_require__(13);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_react_immutable_proptypes__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_9_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__rtl__ = __webpack_require__(97);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12_react_textarea_autosize__ = __webpack_require__(310);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_13_classnames__);\n\n\n\n\n\n\nvar _class, _temp2;\n\n\n\n\n\n\n\n\n\n\n\nvar textAtCursorMatchesToken = function textAtCursorMatchesToken(str, caretPosition) {\n  var word = void 0;\n\n  var left = str.slice(0, caretPosition).search(/\\S+$/);\n  var right = str.slice(caretPosition).search(/\\s/);\n\n  if (right < 0) {\n    word = str.slice(left);\n  } else {\n    word = str.slice(left, right + caretPosition);\n  }\n\n  if (!word || word.trim().length < 3 || ['@', ':', '#'].indexOf(word[0]) === -1) {\n    return [null, null];\n  }\n\n  word = word.trim().toLowerCase();\n\n  if (word.length > 0) {\n    return [left + 1, word];\n  } else {\n    return [null, null];\n  }\n};\n\nvar AutosuggestTextarea = (_temp2 = _class = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_4_babel_runtime_helpers_inherits___default()(AutosuggestTextarea, _ImmutablePureCompone);\n\n  function AutosuggestTextarea() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_classCallCheck___default()(this, AutosuggestTextarea);\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_3_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.state = {\n      suggestionsHidden: false,\n      selectedSuggestion: 0,\n      lastToken: null,\n      tokenStart: 0\n    }, _this.onChange = function (e) {\n      var _textAtCursorMatchesT = textAtCursorMatchesToken(e.target.value, e.target.selectionStart),\n          tokenStart = _textAtCursorMatchesT[0],\n          token = _textAtCursorMatchesT[1];\n\n      if (token !== null && _this.state.lastToken !== token) {\n        _this.setState({ lastToken: token, selectedSuggestion: 0, tokenStart: tokenStart });\n        _this.props.onSuggestionsFetchRequested(token);\n      } else if (token === null) {\n        _this.setState({ lastToken: null });\n        _this.props.onSuggestionsClearRequested();\n      }\n\n      _this.props.onChange(e);\n    }, _this.onKeyDown = function (e) {\n      var _this$props = _this.props,\n          suggestions = _this$props.suggestions,\n          disabled = _this$props.disabled;\n      var _this$state = _this.state,\n          selectedSuggestion = _this$state.selectedSuggestion,\n          suggestionsHidden = _this$state.suggestionsHidden;\n\n\n      if (disabled) {\n        e.preventDefault();\n        return;\n      }\n\n      switch (e.key) {\n        case 'Escape':\n          if (!suggestionsHidden) {\n            e.preventDefault();\n            _this.setState({ suggestionsHidden: true });\n          }\n\n          break;\n        case 'ArrowDown':\n          if (suggestions.size > 0 && !suggestionsHidden) {\n            e.preventDefault();\n            _this.setState({ selectedSuggestion: Math.min(selectedSuggestion + 1, suggestions.size - 1) });\n          }\n\n          break;\n        case 'ArrowUp':\n          if (suggestions.size > 0 && !suggestionsHidden) {\n            e.preventDefault();\n            _this.setState({ selectedSuggestion: Math.max(selectedSuggestion - 1, 0) });\n          }\n\n          break;\n        case 'Enter':\n        case 'Tab':\n          // Select suggestion\n          if (_this.state.lastToken !== null && suggestions.size > 0 && !suggestionsHidden) {\n            e.preventDefault();\n            e.stopPropagation();\n            _this.props.onSuggestionSelected(_this.state.tokenStart, _this.state.lastToken, suggestions.get(selectedSuggestion));\n          }\n\n          break;\n      }\n\n      if (e.defaultPrevented || !_this.props.onKeyDown) {\n        return;\n      }\n\n      _this.props.onKeyDown(e);\n    }, _this.onKeyUp = function (e) {\n      if (e.key === 'Escape' && _this.state.suggestionsHidden) {\n        document.querySelector('.ui').parentElement.focus();\n      }\n\n      if (_this.props.onKeyUp) {\n        _this.props.onKeyUp(e);\n      }\n    }, _this.onBlur = function () {\n      _this.setState({ suggestionsHidden: true });\n    }, _this.onSuggestionClick = function (e) {\n      var suggestion = _this.props.suggestions.get(e.currentTarget.getAttribute('data-index'));\n      e.preventDefault();\n      _this.props.onSuggestionSelected(_this.state.tokenStart, _this.state.lastToken, suggestion);\n      _this.textarea.focus();\n    }, _this.setTextarea = function (c) {\n      _this.textarea = c;\n    }, _this.onPaste = function (e) {\n      if (e.clipboardData && e.clipboardData.files.length === 1) {\n        _this.props.onPaste(e.clipboardData.files);\n        e.preventDefault();\n      }\n    }, _this.renderSuggestion = function (suggestion, i) {\n      var selectedSuggestion = _this.state.selectedSuggestion;\n\n      var inner = void 0,\n          key = void 0;\n\n      if ((typeof suggestion === 'undefined' ? 'undefined' : __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_typeof___default()(suggestion)) === 'object') {\n        inner = __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__autosuggest_emoji__[\"a\" /* default */], {\n          emoji: suggestion\n        });\n        key = suggestion.id;\n      } else if (suggestion[0] === '#') {\n        inner = suggestion;\n        key = suggestion;\n      } else {\n        inner = __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__features_compose_containers_autosuggest_account_container__[\"a\" /* default */], {\n          id: suggestion\n        });\n        key = suggestion;\n      }\n\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        role: 'button',\n        tabIndex: '0',\n        'data-index': i,\n        className: __WEBPACK_IMPORTED_MODULE_13_classnames___default()('autosuggest-textarea__suggestions__item', { selected: i === selectedSuggestion }),\n        onMouseDown: _this.onSuggestionClick\n      }, key, inner);\n    }, _temp), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  AutosuggestTextarea.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n    if (nextProps.suggestions !== this.props.suggestions && nextProps.suggestions.size > 0 && this.state.suggestionsHidden) {\n      this.setState({ suggestionsHidden: false });\n    }\n  };\n\n  AutosuggestTextarea.prototype.render = function render() {\n    var _props = this.props,\n        value = _props.value,\n        suggestions = _props.suggestions,\n        disabled = _props.disabled,\n        placeholder = _props.placeholder,\n        autoFocus = _props.autoFocus;\n    var suggestionsHidden = this.state.suggestionsHidden;\n\n    var style = { direction: 'ltr' };\n\n    if (Object(__WEBPACK_IMPORTED_MODULE_10__rtl__[\"a\" /* isRtl */])(value)) {\n      style.direction = 'rtl';\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'autosuggest-textarea'\n    }, void 0, __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, placeholder), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_12_react_textarea_autosize__[\"a\" /* default */], {\n      inputRef: this.setTextarea,\n      className: 'autosuggest-textarea__textarea',\n      disabled: disabled,\n      placeholder: placeholder,\n      autoFocus: autoFocus,\n      value: value,\n      onChange: this.onChange,\n      onKeyDown: this.onKeyDown,\n      onKeyUp: this.onKeyUp,\n      onBlur: this.onBlur,\n      onPaste: this.onPaste,\n      style: style,\n      'aria-autocomplete': 'list'\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'autosuggest-textarea__suggestions ' + (suggestionsHidden || suggestions.isEmpty() ? '' : 'autosuggest-textarea__suggestions--visible')\n    }, void 0, suggestions.map(this.renderSuggestion)));\n  };\n\n  return AutosuggestTextarea;\n}(__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default.a), _class.propTypes = {\n  value: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.string,\n  suggestions: __WEBPACK_IMPORTED_MODULE_8_react_immutable_proptypes___default.a.list,\n  disabled: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.bool,\n  placeholder: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.string,\n  onSuggestionSelected: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func.isRequired,\n  onSuggestionsClearRequested: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func.isRequired,\n  onSuggestionsFetchRequested: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func.isRequired,\n  onChange: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func.isRequired,\n  onKeyUp: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func,\n  onKeyDown: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func,\n  onPaste: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.func.isRequired,\n  autoFocus: __WEBPACK_IMPORTED_MODULE_9_prop_types___default.a.bool\n}, _class.defaultProps = {\n  autoFocus: true\n}, _temp2);\n\n\n/***/ }),\n\n/***/ 307:\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_autosuggest_account__ = __webpack_require__(308);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__selectors__ = __webpack_require__(66);\n\n\n\n\nvar makeMapStateToProps = function makeMapStateToProps() {\n  var getAccount = Object(__WEBPACK_IMPORTED_MODULE_2__selectors__[\"c\" /* makeGetAccount */])();\n\n  var mapStateToProps = function mapStateToProps(state, _ref) {\n    var id = _ref.id;\n    return {\n      account: getAccount(state, id)\n    };\n  };\n\n  return mapStateToProps;\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(makeMapStateToProps)(__WEBPACK_IMPORTED_MODULE_1__components_autosuggest_account__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 308:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return AutosuggestAccount; });\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__components_avatar__ = __webpack_require__(56);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__components_display_name__ = __webpack_require__(55);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes__ = __webpack_require__(13);\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_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component__);\n\n\n\n\n\nvar _class, _temp;\n\n\n\n\n\n\n\nvar AutosuggestAccount = (_temp = _class = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(AutosuggestAccount, _ImmutablePureCompone);\n\n  function AutosuggestAccount() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, AutosuggestAccount);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.apply(this, arguments));\n  }\n\n  AutosuggestAccount.prototype.render = function render() {\n    var account = this.props.account;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'autosuggest-account'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'autosuggest-account-icon'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5__components_avatar__[\"a\" /* default */], {\n      account: account,\n      size: 18\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__components_display_name__[\"a\" /* default */], {\n      account: account\n    }));\n  };\n\n  return AutosuggestAccount;\n}(__WEBPACK_IMPORTED_MODULE_8_react_immutable_pure_component___default.a), _class.propTypes = {\n  account: __WEBPACK_IMPORTED_MODULE_7_react_immutable_proptypes___default.a.map.isRequired\n}, _temp);\n\n\n/***/ }),\n\n/***/ 309:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* WEBPACK VAR INJECTION */(function(process) {/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return AutosuggestEmoji; });\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__features_emoji_emoji_unicode_mapping_light__ = __webpack_require__(155);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__features_emoji_emoji_unicode_mapping_light___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__features_emoji_emoji_unicode_mapping_light__);\n\n\n\n\n\n\n\n\nvar assetHost = process.env.CDN_HOST || '';\n\nvar AutosuggestEmoji = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(AutosuggestEmoji, _React$PureComponent);\n\n  function AutosuggestEmoji() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, AutosuggestEmoji);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  AutosuggestEmoji.prototype.render = function render() {\n    var emoji = this.props.emoji;\n\n    var url = void 0;\n\n    if (emoji.custom) {\n      url = emoji.imageUrl;\n    } else {\n      var mapping = __WEBPACK_IMPORTED_MODULE_5__features_emoji_emoji_unicode_mapping_light___default.a[emoji.native] || __WEBPACK_IMPORTED_MODULE_5__features_emoji_emoji_unicode_mapping_light___default.a[emoji.native.replace(/\\uFE0F$/, '')];\n\n      if (!mapping) {\n        return null;\n      }\n\n      url = assetHost + '/emoji/' + mapping.filename + '.svg';\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'autosuggest-emoji'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('img', {\n      className: 'emojione',\n      src: url,\n      alt: emoji.native || emoji.colons\n    }), emoji.colons);\n  };\n\n  return AutosuggestEmoji;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n/* WEBPACK VAR INJECTION */}.call(__webpack_exports__, __webpack_require__(36)))\n\n/***/ }),\n\n/***/ 310:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_prop_types__);\n\n\n\nfunction _extends() {\n  _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n  subClass.prototype = Object.create(superClass.prototype);\n  subClass.prototype.constructor = subClass;\n  subClass.__proto__ = superClass;\n}\n\nfunction _objectWithoutProperties(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  if (Object.getOwnPropertySymbols) {\n    var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n    for (i = 0; i < sourceSymbolKeys.length; i++) {\n      key = sourceSymbolKeys[i];\n      if (excluded.indexOf(key) >= 0) continue;\n      if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n      target[key] = source[key];\n    }\n  }\n\n  return target;\n}\n\nvar isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined';\n\nvar isIE = isBrowser ? !!document.documentElement.currentStyle : false;\nvar hiddenTextarea = isBrowser && document.createElement('textarea');\nvar HIDDEN_TEXTAREA_STYLE = {\n  'min-height': '0',\n  'max-height': 'none',\n  height: '0',\n  visibility: 'hidden',\n  overflow: 'hidden',\n  position: 'absolute',\n  'z-index': '-1000',\n  top: '0',\n  right: '0'\n};\nvar SIZING_STYLE = ['letter-spacing', 'line-height', 'font-family', 'font-weight', 'font-size', 'font-style', 'tab-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-top', 'padding-right', 'padding-bottom', 'padding-left', 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width', 'box-sizing'];\nvar computedStyleCache = {};\nfunction calculateNodeHeight(uiTextNode, uid, useCache, minRows, maxRows) {\n  if (useCache === void 0) {\n    useCache = false;\n  }\n\n  if (minRows === void 0) {\n    minRows = null;\n  }\n\n  if (maxRows === void 0) {\n    maxRows = null;\n  }\n\n  if (hiddenTextarea.parentNode === null) {\n    document.body.appendChild(hiddenTextarea);\n  } // Copy all CSS properties that have an impact on the height of the content in\n  // the textbox\n\n\n  var nodeStyling = calculateNodeStyling(uiTextNode, uid, useCache);\n\n  if (nodeStyling === null) {\n    return null;\n  }\n\n  var paddingSize = nodeStyling.paddingSize,\n      borderSize = nodeStyling.borderSize,\n      boxSizing = nodeStyling.boxSizing,\n      sizingStyle = nodeStyling.sizingStyle; // Need to have the overflow attribute to hide the scrollbar otherwise\n  // text-lines will not calculated properly as the shadow will technically be\n  // narrower for content\n\n  Object.keys(sizingStyle).forEach(function (key) {\n    hiddenTextarea.style[key] = sizingStyle[key];\n  });\n  Object.keys(HIDDEN_TEXTAREA_STYLE).forEach(function (key) {\n    hiddenTextarea.style.setProperty(key, HIDDEN_TEXTAREA_STYLE[key], 'important');\n  });\n  hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || 'x';\n  var minHeight = -Infinity;\n  var maxHeight = Infinity;\n  var height = hiddenTextarea.scrollHeight;\n\n  if (boxSizing === 'border-box') {\n    // border-box: add border, since height = content + padding + border\n    height = height + borderSize;\n  } else if (boxSizing === 'content-box') {\n    // remove padding, since height = content\n    height = height - paddingSize;\n  } // measure height of a textarea with a single row\n\n\n  hiddenTextarea.value = 'x';\n  var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;\n\n  if (minRows !== null || maxRows !== null) {\n    if (minRows !== null) {\n      minHeight = singleRowHeight * minRows;\n\n      if (boxSizing === 'border-box') {\n        minHeight = minHeight + paddingSize + borderSize;\n      }\n\n      height = Math.max(minHeight, height);\n    }\n\n    if (maxRows !== null) {\n      maxHeight = singleRowHeight * maxRows;\n\n      if (boxSizing === 'border-box') {\n        maxHeight = maxHeight + paddingSize + borderSize;\n      }\n\n      height = Math.min(maxHeight, height);\n    }\n  }\n\n  var rowCount = Math.floor(height / singleRowHeight);\n  return {\n    height: height,\n    minHeight: minHeight,\n    maxHeight: maxHeight,\n    rowCount: rowCount\n  };\n}\n\nfunction calculateNodeStyling(node, uid, useCache) {\n  if (useCache === void 0) {\n    useCache = false;\n  }\n\n  if (useCache && computedStyleCache[uid]) {\n    return computedStyleCache[uid];\n  }\n\n  var style = window.getComputedStyle(node);\n\n  if (style === null) {\n    return null;\n  }\n\n  var sizingStyle = SIZING_STYLE.reduce(function (obj, name) {\n    obj[name] = style.getPropertyValue(name);\n    return obj;\n  }, {});\n  var boxSizing = sizingStyle['box-sizing']; // IE (Edge has already correct behaviour) returns content width as computed width\n  // so we need to add manually padding and border widths\n\n  if (isIE && boxSizing === 'border-box') {\n    sizingStyle.width = parseFloat(sizingStyle.width) + parseFloat(style['border-right-width']) + parseFloat(style['border-left-width']) + parseFloat(style['padding-right']) + parseFloat(style['padding-left']) + 'px';\n  }\n\n  var paddingSize = parseFloat(sizingStyle['padding-bottom']) + parseFloat(sizingStyle['padding-top']);\n  var borderSize = parseFloat(sizingStyle['border-bottom-width']) + parseFloat(sizingStyle['border-top-width']);\n  var nodeInfo = {\n    sizingStyle: sizingStyle,\n    paddingSize: paddingSize,\n    borderSize: borderSize,\n    boxSizing: boxSizing\n  };\n\n  if (useCache) {\n    computedStyleCache[uid] = nodeInfo;\n  }\n\n  return nodeInfo;\n}\n\nvar purgeCache = function purgeCache(uid) {\n  return delete computedStyleCache[uid];\n};\n\nfunction autoInc(seed) {\n  if (seed === void 0) {\n    seed = 0;\n  }\n\n  return function () {\n    return ++seed;\n  };\n}\n\nvar uid = autoInc();\n\n/**\n * <TextareaAutosize />\n */\nvar noop = function noop() {}; // IE11 has a problem with eval source maps, can be reproduced with:\n// eval('\"use strict\"; var onNextFrame = window.cancelAnimationFrame; onNextFrame(4);')\n// so we bind window as context in dev modes\n\n\nvar _ref = isBrowser && window.requestAnimationFrame ?  true ? [window.requestAnimationFrame, window.cancelAnimationFrame] : [window.requestAnimationFrame.bind(window), window.cancelAnimationFrame.bind(window)] : [setTimeout, clearTimeout];\nvar onNextFrame = _ref[0];\nvar clearNextFrameAction = _ref[1];\n\nvar TextareaAutosize =\n/*#__PURE__*/\nfunction (_React$Component) {\n  _inheritsLoose(TextareaAutosize, _React$Component);\n\n  function TextareaAutosize(props) {\n    var _this;\n\n    _this = _React$Component.call(this, props) || this;\n    _this._resizeLock = false;\n\n    _this._onRootDOMNode = function (node) {\n      _this._rootDOMNode = node;\n\n      if (_this.props.inputRef) {\n        _this.props.inputRef(node);\n      }\n    };\n\n    _this._onChange = function (event) {\n      if (!_this._controlled) {\n        _this._resizeComponent();\n      }\n\n      _this.props.onChange(event);\n    };\n\n    _this._resizeComponent = function (callback) {\n      if (callback === void 0) {\n        callback = noop;\n      }\n\n      if (typeof _this._rootDOMNode === 'undefined') {\n        callback();\n        return;\n      }\n\n      var nodeHeight = calculateNodeHeight(_this._rootDOMNode, _this._uid, _this.props.useCacheForDOMMeasurements, _this.props.minRows, _this.props.maxRows);\n\n      if (nodeHeight === null) {\n        callback();\n        return;\n      }\n\n      var height = nodeHeight.height,\n          minHeight = nodeHeight.minHeight,\n          maxHeight = nodeHeight.maxHeight,\n          rowCount = nodeHeight.rowCount;\n      _this.rowCount = rowCount;\n\n      if (_this.state.height !== height || _this.state.minHeight !== minHeight || _this.state.maxHeight !== maxHeight) {\n        _this.setState({\n          height: height,\n          minHeight: minHeight,\n          maxHeight: maxHeight\n        }, callback);\n\n        return;\n      }\n\n      callback();\n    };\n\n    _this.state = {\n      height: props.style && props.style.height || 0,\n      minHeight: -Infinity,\n      maxHeight: Infinity\n    };\n    _this._uid = uid();\n    _this._controlled = typeof props.value === 'string';\n    return _this;\n  }\n\n  var _proto = TextareaAutosize.prototype;\n\n  _proto.render = function render() {\n    var _props = this.props,\n        _minRows = _props.minRows,\n        _maxRows = _props.maxRows,\n        _onHeightChange = _props.onHeightChange,\n        _useCacheForDOMMeasurements = _props.useCacheForDOMMeasurements,\n        _inputRef = _props.inputRef,\n        props = _objectWithoutProperties(_props, [\"minRows\", \"maxRows\", \"onHeightChange\", \"useCacheForDOMMeasurements\", \"inputRef\"]);\n    props.style = _extends({}, props.style, {\n      height: this.state.height\n    });\n    var maxHeight = Math.max(props.style.maxHeight || Infinity, this.state.maxHeight);\n\n    if (maxHeight < this.state.height) {\n      props.style.overflow = 'hidden';\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\"textarea\", _extends({}, props, {\n      onChange: this._onChange,\n      ref: this._onRootDOMNode\n    }));\n  };\n\n  _proto.componentDidMount = function componentDidMount() {\n    var _this2 = this;\n\n    this._resizeComponent(); // Working around Firefox bug which runs resize listeners even when other JS is running at the same moment\n    // causing competing rerenders (due to setState in the listener) in React.\n    // More can be found here - facebook/react#6324\n\n\n    this._resizeListener = function () {\n      if (_this2._resizeLock) {\n        return;\n      }\n\n      _this2._resizeLock = true;\n\n      _this2._resizeComponent(function () {\n        return _this2._resizeLock = false;\n      });\n    };\n\n    window.addEventListener('resize', this._resizeListener);\n  };\n\n  _proto.componentWillReceiveProps = function componentWillReceiveProps() {\n    var _this3 = this;\n\n    this._clearNextFrame();\n\n    this._onNextFrameActionId = onNextFrame(function () {\n      return _this3._resizeComponent();\n    });\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n    if (this.state.height !== prevState.height) {\n      this.props.onHeightChange(this.state.height, this);\n    }\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this._clearNextFrame();\n\n    window.removeEventListener('resize', this._resizeListener);\n    purgeCache(this._uid);\n  };\n\n  _proto._clearNextFrame = function _clearNextFrame() {\n    clearNextFrameAction(this._onNextFrameActionId);\n  };\n\n  return TextareaAutosize;\n}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.Component);\n\nTextareaAutosize.defaultProps = {\n  onChange: noop,\n  onHeightChange: noop,\n  useCacheForDOMMeasurements: false\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (TextareaAutosize);\n\n/***/ }),\n\n/***/ 311:\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_upload_button__ = __webpack_require__(312);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_compose__ = __webpack_require__(18);\n\n\n\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    disabled: state.getIn(['compose', 'is_uploading']) || state.getIn(['compose', 'media_attachments']).size > 3 || state.getIn(['compose', 'media_attachments']).some(function (m) {\n      return m.get('type') === 'video';\n    }),\n    resetFileKey: state.getIn(['compose', 'resetFileKey'])\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n    onSelectFile: function onSelectFile(files) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_compose__[\"Z\" /* uploadCompose */])(files));\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_upload_button__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 312:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return UploadButton; });\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__components_icon_button__ = __webpack_require__(23);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_redux__ = __webpack_require__(9);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_immutable_proptypes__ = __webpack_require__(13);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_10_react_immutable_proptypes__);\n\n\n\n\n\nvar _dec, _class, _class2, _temp2;\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_7_react_intl__[\"f\" /* defineMessages */])({\n  upload: {\n    'id': 'upload_button.label',\n    'defaultMessage': 'Add media'\n  }\n});\n\nvar makeMapStateToProps = function makeMapStateToProps() {\n  var mapStateToProps = function mapStateToProps(state) {\n    return {\n      acceptContentTypes: state.getIn(['media_attachments', 'accept_content_types'])\n    };\n  };\n\n  return mapStateToProps;\n};\n\nvar iconStyle = {\n  height: null,\n  lineHeight: '27px'\n};\n\nvar UploadButton = (_dec = Object(__WEBPACK_IMPORTED_MODULE_8_react_redux__[\"connect\"])(makeMapStateToProps), _dec(_class = Object(__WEBPACK_IMPORTED_MODULE_7_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(UploadButton, _ImmutablePureCompone);\n\n  function UploadButton() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, UploadButton);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.handleChange = function (e) {\n      if (e.target.files.length > 0) {\n        _this.props.onSelectFile(e.target.files);\n      }\n    }, _this.handleClick = function () {\n      _this.fileElement.click();\n    }, _this.setRef = function (c) {\n      _this.fileElement = c;\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  UploadButton.prototype.render = function render() {\n    var _props = this.props,\n        intl = _props.intl,\n        resetFileKey = _props.resetFileKey,\n        disabled = _props.disabled,\n        acceptContentTypes = _props.acceptContentTypes;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__upload-button'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5__components_icon_button__[\"a\" /* default */], {\n      icon: 'camera',\n      title: intl.formatMessage(messages.upload),\n      disabled: disabled,\n      onClick: this.handleClick,\n      className: 'compose-form__upload-button-icon',\n      size: 18,\n      inverted: true,\n      style: iconStyle\n    }), __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, intl.formatMessage(messages.upload)), __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement('input', {\n      key: resetFileKey,\n      ref: this.setRef,\n      type: 'file',\n      multiple: false,\n      accept: acceptContentTypes.toArray().join(','),\n      onChange: this.handleChange,\n      disabled: disabled,\n      style: { display: 'none' }\n    })));\n  };\n\n  return UploadButton;\n}(__WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component___default.a), _class2.propTypes = {\n  disabled: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.bool,\n  onSelectFile: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.func.isRequired,\n  style: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object,\n  resetFileKey: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.number,\n  acceptContentTypes: __WEBPACK_IMPORTED_MODULE_10_react_immutable_proptypes___default.a.listOf(__WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.string).isRequired,\n  intl: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object.isRequired\n}, _temp2)) || _class) || _class);\n\n\n/***/ }),\n\n/***/ 313:\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__features_ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring__);\n\n\n\n\n\n\nvar Collapsable = function Collapsable(_ref) {\n  var fullHeight = _ref.fullHeight,\n      isVisible = _ref.isVisible,\n      children = _ref.children;\n  return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_2__features_ui_util_optional_motion__[\"a\" /* default */], {\n    defaultStyle: { opacity: !isVisible ? 0 : 100, height: isVisible ? fullHeight : 0 },\n    style: { opacity: __WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring___default()(!isVisible ? 0 : 100), height: __WEBPACK_IMPORTED_MODULE_3_react_motion_lib_spring___default()(!isVisible ? 0 : fullHeight) }\n  }, void 0, function (_ref2) {\n    var opacity = _ref2.opacity,\n        height = _ref2.height;\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      style: { height: height + 'px', overflow: 'hidden', opacity: opacity / 100, display: Math.floor(opacity) === 0 ? 'none' : 'block' }\n    }, void 0, children);\n  });\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Collapsable);\n\n/***/ }),\n\n/***/ 314:\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_text_icon_button__ = __webpack_require__(315);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_compose__ = __webpack_require__(18);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_react_intl__ = __webpack_require__(6);\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_3_react_intl__[\"f\" /* defineMessages */])({\n  marked: {\n    'id': 'compose_form.spoiler.marked',\n    'defaultMessage': 'Text is hidden behind warning'\n  },\n  unmarked: {\n    'id': 'compose_form.spoiler.unmarked',\n    'defaultMessage': 'Text is not hidden'\n  }\n});\n\nvar mapStateToProps = function mapStateToProps(state, _ref) {\n  var intl = _ref.intl;\n  return {\n    label: 'CW',\n    title: intl.formatMessage(state.getIn(['compose', 'spoiler']) ? messages.marked : messages.unmarked),\n    active: state.getIn(['compose', 'spoiler']),\n    ariaControls: 'cw-spoiler-input'\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n    onClick: function onClick() {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_compose__[\"I\" /* changeComposeSpoilerness */])());\n    }\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_3_react_intl__[\"g\" /* injectIntl */])(Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(mapStateToProps, mapDispatchToProps)(__WEBPACK_IMPORTED_MODULE_1__components_text_icon_button__[\"a\" /* default */])));\n\n/***/ }),\n\n/***/ 315:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return TextIconButton; });\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 TextIconButton = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(TextIconButton, _React$PureComponent);\n\n  function TextIconButton() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, TextIconButton);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.handleClick = function (e) {\n      e.preventDefault();\n      _this.props.onClick();\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  TextIconButton.prototype.render = function render() {\n    var _props = this.props,\n        label = _props.label,\n        title = _props.title,\n        active = _props.active,\n        ariaControls = _props.ariaControls;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n      title: title,\n      'aria-label': title,\n      className: 'text-icon-button ' + (active ? 'active' : ''),\n      'aria-expanded': active,\n      onClick: this.handleClick,\n      'aria-controls': ariaControls\n    }, void 0, label);\n  };\n\n  return TextIconButton;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 316:\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_privacy_dropdown__ = __webpack_require__(317);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_compose__ = __webpack_require__(18);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__actions_modal__ = __webpack_require__(26);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__is_mobile__ = __webpack_require__(35);\n\n\n\n\n\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    isModalOpen: state.get('modal').modalType === 'ACTIONS',\n    value: state.getIn(['compose', 'privacy'])\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n    onChange: function onChange(value) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_compose__[\"J\" /* changeComposeVisibility */])(value));\n    },\n\n\n    isUserTouching: __WEBPACK_IMPORTED_MODULE_4__is_mobile__[\"c\" /* isUserTouching */],\n    onModalOpen: function onModalOpen(props) {\n      return dispatch(Object(__WEBPACK_IMPORTED_MODULE_3__actions_modal__[\"d\" /* openModal */])('ACTIONS', props));\n    },\n    onModalClose: function onModalClose() {\n      return dispatch(Object(__WEBPACK_IMPORTED_MODULE_3__actions_modal__[\"c\" /* closeModal */])());\n    }\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_privacy_dropdown__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 317:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return PrivacyDropdown; });\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__components_icon_button__ = __webpack_require__(23);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay__ = __webpack_require__(96);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_detect_passive_events__ = __webpack_require__(46);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_detect_passive_events___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_10_detect_passive_events__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_11_classnames__);\n\n\n\n\n\nvar _class2;\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"f\" /* defineMessages */])({\n  public_short: {\n    'id': 'privacy.public.short',\n    'defaultMessage': 'Public'\n  },\n  public_long: {\n    'id': 'privacy.public.long',\n    'defaultMessage': 'Post to public timelines'\n  },\n  unlisted_short: {\n    'id': 'privacy.unlisted.short',\n    'defaultMessage': 'Unlisted'\n  },\n  unlisted_long: {\n    'id': 'privacy.unlisted.long',\n    'defaultMessage': 'Do not show in public timelines'\n  },\n  private_short: {\n    'id': 'privacy.private.short',\n    'defaultMessage': 'Followers-only'\n  },\n  private_long: {\n    'id': 'privacy.private.long',\n    'defaultMessage': 'Post to followers only'\n  },\n  direct_short: {\n    'id': 'privacy.direct.short',\n    'defaultMessage': 'Direct'\n  },\n  direct_long: {\n    'id': 'privacy.direct.long',\n    'defaultMessage': 'Post to mentioned users only'\n  },\n  change_privacy: {\n    'id': 'privacy.change',\n    'defaultMessage': 'Adjust status privacy'\n  }\n});\n\nvar listenerOptions = __WEBPACK_IMPORTED_MODULE_10_detect_passive_events___default.a.hasSupport ? { passive: true } : false;\n\nvar PrivacyDropdownMenu = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(PrivacyDropdownMenu, _React$PureComponent);\n\n  function PrivacyDropdownMenu() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, PrivacyDropdownMenu);\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.handleDocumentClick = function (e) {\n      if (_this.node && !_this.node.contains(e.target)) {\n        _this.props.onClose();\n      }\n    }, _this.handleClick = function (e) {\n      if (e.key === 'Escape') {\n        _this.props.onClose();\n      } else if (!e.key || e.key === 'Enter') {\n        var value = e.currentTarget.getAttribute('data-index');\n\n        e.preventDefault();\n\n        _this.props.onClose();\n        _this.props.onChange(value);\n      }\n    }, _this.setRef = function (c) {\n      _this.node = c;\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  PrivacyDropdownMenu.prototype.componentDidMount = function componentDidMount() {\n    document.addEventListener('click', this.handleDocumentClick, false);\n    document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  };\n\n  PrivacyDropdownMenu.prototype.componentWillUnmount = function componentWillUnmount() {\n    document.removeEventListener('click', this.handleDocumentClick, false);\n    document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  };\n\n  PrivacyDropdownMenu.prototype.render = function render() {\n    var _this2 = this;\n\n    var _props = this.props,\n        style = _props.style,\n        items = _props.items,\n        value = _props.value;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_8__ui_util_optional_motion__[\"a\" /* default */], {\n      defaultStyle: { opacity: 0, scaleX: 0.85, scaleY: 0.75 },\n      style: { opacity: __WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }), scaleX: __WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }), scaleY: __WEBPACK_IMPORTED_MODULE_9_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }) }\n    }, void 0, function (_ref) {\n      var opacity = _ref.opacity,\n          scaleX = _ref.scaleX,\n          scaleY = _ref.scaleY;\n      return __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(\n        'div',\n        { className: 'privacy-dropdown__dropdown', style: Object.assign({}, style, { opacity: opacity, transform: 'scale(' + scaleX + ', ' + scaleY + ')' }), ref: _this2.setRef },\n        items.map(function (item) {\n          return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n            role: 'button',\n            tabIndex: '0',\n            'data-index': item.value,\n            onKeyDown: _this2.handleClick,\n            onClick: _this2.handleClick,\n            className: __WEBPACK_IMPORTED_MODULE_11_classnames___default()('privacy-dropdown__option', { active: item.value === value })\n          }, item.value, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n            className: 'privacy-dropdown__option__icon'\n          }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n            className: 'fa fa-fw fa-' + item.icon\n          })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n            className: 'privacy-dropdown__option__content'\n          }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('strong', {}, void 0, item.text), item.meta));\n        })\n      );\n    });\n  };\n\n  return PrivacyDropdownMenu;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\nvar PrivacyDropdown = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"g\" /* injectIntl */])(_class2 = function (_React$PureComponent2) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(PrivacyDropdown, _React$PureComponent2);\n\n  function PrivacyDropdown() {\n    var _temp2, _this3, _ret2;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, PrivacyDropdown);\n\n    for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n      args[_key2] = arguments[_key2];\n    }\n\n    return _ret2 = (_temp2 = (_this3 = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent2.call.apply(_React$PureComponent2, [this].concat(args))), _this3), _this3.state = {\n      open: false\n    }, _this3.handleToggle = function () {\n      if (_this3.props.isUserTouching()) {\n        if (_this3.state.open) {\n          _this3.props.onModalClose();\n        } else {\n          _this3.props.onModalOpen({\n            actions: _this3.options.map(function (option) {\n              return Object.assign({}, option, { active: option.value === _this3.props.value });\n            }),\n            onClick: _this3.handleModalActionClick\n          });\n        }\n      } else {\n        _this3.setState({ open: !_this3.state.open });\n      }\n    }, _this3.handleModalActionClick = function (e) {\n      e.preventDefault();\n\n      var value = _this3.options[e.currentTarget.getAttribute('data-index')].value;\n\n      _this3.props.onModalClose();\n      _this3.props.onChange(value);\n    }, _this3.handleKeyDown = function (e) {\n      switch (e.key) {\n        case 'Enter':\n          _this3.handleToggle();\n          break;\n        case 'Escape':\n          _this3.handleClose();\n          break;\n      }\n    }, _this3.handleClose = function () {\n      _this3.setState({ open: false });\n    }, _this3.handleChange = function (value) {\n      _this3.props.onChange(value);\n    }, _temp2), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this3, _ret2);\n  }\n\n  PrivacyDropdown.prototype.componentWillMount = function componentWillMount() {\n    var formatMessage = this.props.intl.formatMessage;\n\n\n    this.options = [{ icon: 'globe', value: 'public', text: formatMessage(messages.public_short), meta: formatMessage(messages.public_long) }, { icon: 'unlock-alt', value: 'unlisted', text: formatMessage(messages.unlisted_short), meta: formatMessage(messages.unlisted_long) }, { icon: 'lock', value: 'private', text: formatMessage(messages.private_short), meta: formatMessage(messages.private_long) }, { icon: 'envelope', value: 'direct', text: formatMessage(messages.direct_short), meta: formatMessage(messages.direct_long) }];\n  };\n\n  PrivacyDropdown.prototype.render = function render() {\n    var _props2 = this.props,\n        value = _props2.value,\n        intl = _props2.intl;\n    var open = this.state.open;\n\n\n    var valueOption = this.options.find(function (item) {\n      return item.value === value;\n    });\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: __WEBPACK_IMPORTED_MODULE_11_classnames___default()('privacy-dropdown', { active: open }),\n      onKeyDown: this.handleKeyDown\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: __WEBPACK_IMPORTED_MODULE_11_classnames___default()('privacy-dropdown__value', { active: this.options.indexOf(valueOption) === 0 })\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__components_icon_button__[\"a\" /* default */], {\n      className: 'privacy-dropdown__value-icon',\n      icon: valueOption.icon,\n      title: intl.formatMessage(messages.change_privacy),\n      size: 18,\n      expanded: open,\n      active: open,\n      inverted: true,\n      onClick: this.handleToggle,\n      style: { height: null, lineHeight: '27px' }\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay___default.a, {\n      show: open,\n      placement: 'bottom',\n      target: this\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(PrivacyDropdownMenu, {\n      items: this.options,\n      value: value,\n      onClose: this.handleClose,\n      onChange: this.handleChange\n    })));\n  };\n\n  return PrivacyDropdown;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent)) || _class2;\n\n\n\n/***/ }),\n\n/***/ 318:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_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_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__components_icon_button__ = __webpack_require__(23);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__actions_compose__ = __webpack_require__(18);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_10_react_motion_lib_spring__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_intl__ = __webpack_require__(6);\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  marked: {\n    'id': 'compose_form.sensitive.marked',\n    'defaultMessage': 'Media is marked as sensitive'\n  },\n  unmarked: {\n    'id': 'compose_form.sensitive.unmarked',\n    'defaultMessage': 'Media is not marked as sensitive'\n  }\n});\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    visible: state.getIn(['compose', 'media_attachments']).size > 0,\n    active: state.getIn(['compose', 'sensitive']),\n    disabled: state.getIn(['compose', 'spoiler'])\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n    onClick: function onClick() {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_8__actions_compose__[\"G\" /* changeComposeSensitivity */])());\n    }\n  };\n};\n\nvar SensitiveButton = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(SensitiveButton, _React$PureComponent);\n\n  function SensitiveButton() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, SensitiveButton);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  SensitiveButton.prototype.render = function render() {\n    var _props = this.props,\n        visible = _props.visible,\n        active = _props.active,\n        disabled = _props.disabled,\n        onClick = _props.onClick,\n        intl = _props.intl;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__ui_util_optional_motion__[\"a\" /* default */], {\n      defaultStyle: { scale: 0.87 },\n      style: { scale: __WEBPACK_IMPORTED_MODULE_10_react_motion_lib_spring___default()(visible ? 1 : 0.87, { stiffness: 200, damping: 3 }) }\n    }, void 0, function (_ref) {\n      var scale = _ref.scale;\n\n      var icon = active ? 'eye-slash' : 'eye';\n      var className = __WEBPACK_IMPORTED_MODULE_6_classnames___default()('compose-form__sensitive-button', {\n        'compose-form__sensitive-button--visible': visible\n      });\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: className,\n        style: { transform: 'scale(' + scale + ')' }\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__components_icon_button__[\"a\" /* default */], {\n        className: 'compose-form__sensitive-button__icon',\n        title: intl.formatMessage(active ? messages.marked : messages.unmarked),\n        icon: icon,\n        onClick: onClick,\n        size: 18,\n        active: active,\n        disabled: disabled,\n        style: { lineHeight: null, height: null },\n        inverted: true\n      }));\n    });\n  };\n\n  return SensitiveButton;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_5_react_redux__[\"connect\"])(mapStateToProps, mapDispatchToProps)(Object(__WEBPACK_IMPORTED_MODULE_11_react_intl__[\"g\" /* injectIntl */])(SensitiveButton)));\n\n/***/ }),\n\n/***/ 319:\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_emoji_picker_dropdown__ = __webpack_require__(320);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_settings__ = __webpack_require__(57);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_reselect__ = __webpack_require__(95);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_reselect___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_reselect__);\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__actions_emojis__ = __webpack_require__(99);\n\n\n\n\n\n\n\nvar perLine = 8;\nvar lines = 2;\n\nvar DEFAULTS = ['+1', 'grinning', 'kissing_heart', 'heart_eyes', 'laughing', 'stuck_out_tongue_winking_eye', 'sweat_smile', 'joy', 'yum', 'disappointed', 'thinking_face', 'weary', 'sob', 'sunglasses', 'heart', 'ok_hand'];\n\nvar getFrequentlyUsedEmojis = Object(__WEBPACK_IMPORTED_MODULE_3_reselect__[\"createSelector\"])([function (state) {\n  return state.getIn(['settings', 'frequentlyUsedEmojis'], Object(__WEBPACK_IMPORTED_MODULE_4_immutable__[\"Map\"])());\n}], function (emojiCounters) {\n  var emojis = emojiCounters.keySeq().sort(function (a, b) {\n    return emojiCounters.get(a) - emojiCounters.get(b);\n  }).reverse().slice(0, perLine * lines).toArray();\n\n  if (emojis.length < DEFAULTS.length) {\n    emojis = emojis.concat(DEFAULTS.slice(0, DEFAULTS.length - emojis.length));\n  }\n\n  return emojis;\n});\n\nvar getCustomEmojis = Object(__WEBPACK_IMPORTED_MODULE_3_reselect__[\"createSelector\"])([function (state) {\n  return state.get('custom_emojis');\n}], function (emojis) {\n  return emojis.filter(function (e) {\n    return e.get('visible_in_picker');\n  }).sort(function (a, b) {\n    var aShort = a.get('shortcode').toLowerCase();\n    var bShort = b.get('shortcode').toLowerCase();\n\n    if (aShort < bShort) {\n      return -1;\n    } else if (aShort > bShort) {\n      return 1;\n    } else {\n      return 0;\n    }\n  });\n});\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    custom_emojis: getCustomEmojis(state),\n    skinTone: state.getIn(['settings', 'skinTone']),\n    frequentlyUsedEmojis: getFrequentlyUsedEmojis(state)\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch, _ref) {\n  var _onPickEmoji = _ref.onPickEmoji;\n  return {\n    onSkinTone: function onSkinTone(skinTone) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_settings__[\"c\" /* changeSetting */])(['skinTone'], skinTone));\n    },\n\n    onPickEmoji: function onPickEmoji(emoji) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_5__actions_emojis__[\"b\" /* useEmoji */])(emoji));\n\n      if (_onPickEmoji) {\n        _onPickEmoji(emoji);\n      }\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_emoji_picker_dropdown__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 320:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* WEBPACK VAR INJECTION */(function(process) {/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return EmojiPickerDropdown; });\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__ui_util_async_components__ = __webpack_require__(58);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay__ = __webpack_require__(96);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_detect_passive_events__ = __webpack_require__(46);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_detect_passive_events___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_9_detect_passive_events__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__emoji_emoji__ = __webpack_require__(71);\n\n\n\n\n\nvar _class3, _class4, _temp4, _class5;\n\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"f\" /* defineMessages */])({\n  emoji: {\n    'id': 'emoji_button.label',\n    'defaultMessage': 'Insert emoji'\n  },\n  emoji_search: {\n    'id': 'emoji_button.search',\n    'defaultMessage': 'Search...'\n  },\n  emoji_not_found: {\n    'id': 'emoji_button.not_found',\n    'defaultMessage': 'No emojos!! (\\u256F\\xB0\\u25A1\\xB0\\uFF09\\u256F\\uFE35 \\u253B\\u2501\\u253B'\n  },\n  custom: {\n    'id': 'emoji_button.custom',\n    'defaultMessage': 'Custom'\n  },\n  recent: {\n    'id': 'emoji_button.recent',\n    'defaultMessage': 'Frequently used'\n  },\n  search_results: {\n    'id': 'emoji_button.search_results',\n    'defaultMessage': 'Search results'\n  },\n  people: {\n    'id': 'emoji_button.people',\n    'defaultMessage': 'People'\n  },\n  nature: {\n    'id': 'emoji_button.nature',\n    'defaultMessage': 'Nature'\n  },\n  food: {\n    'id': 'emoji_button.food',\n    'defaultMessage': 'Food & Drink'\n  },\n  activity: {\n    'id': 'emoji_button.activity',\n    'defaultMessage': 'Activity'\n  },\n  travel: {\n    'id': 'emoji_button.travel',\n    'defaultMessage': 'Travel & Places'\n  },\n  objects: {\n    'id': 'emoji_button.objects',\n    'defaultMessage': 'Objects'\n  },\n  symbols: {\n    'id': 'emoji_button.symbols',\n    'defaultMessage': 'Symbols'\n  },\n  flags: {\n    'id': 'emoji_button.flags',\n    'defaultMessage': 'Flags'\n  }\n});\n\nvar assetHost = process.env.CDN_HOST || '';\nvar EmojiPicker = void 0,\n    Emoji = void 0; // load asynchronously\n\nvar backgroundImageFn = function backgroundImageFn() {\n  return assetHost + '/emoji/sheet.png';\n};\nvar listenerOptions = __WEBPACK_IMPORTED_MODULE_9_detect_passive_events___default.a.hasSupport ? { passive: true } : false;\n\nvar categoriesSort = ['recent', 'custom', 'people', 'nature', 'foods', 'activity', 'places', 'objects', 'symbols', 'flags'];\n\nvar ModifierPickerMenu = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ModifierPickerMenu, _React$PureComponent);\n\n  function ModifierPickerMenu() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ModifierPickerMenu);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.handleClick = function (e) {\n      _this.props.onSelect(e.currentTarget.getAttribute('data-index') * 1);\n    }, _this.handleDocumentClick = function (e) {\n      if (_this.node && !_this.node.contains(e.target)) {\n        _this.props.onClose();\n      }\n    }, _this.setRef = function (c) {\n      _this.node = c;\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  ModifierPickerMenu.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n    if (nextProps.active) {\n      this.attachListeners();\n    } else {\n      this.removeListeners();\n    }\n  };\n\n  ModifierPickerMenu.prototype.componentWillUnmount = function componentWillUnmount() {\n    this.removeListeners();\n  };\n\n  ModifierPickerMenu.prototype.attachListeners = function attachListeners() {\n    document.addEventListener('click', this.handleDocumentClick, false);\n    document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  };\n\n  ModifierPickerMenu.prototype.removeListeners = function removeListeners() {\n    document.removeEventListener('click', this.handleDocumentClick, false);\n    document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  };\n\n  ModifierPickerMenu.prototype.render = function render() {\n    var active = this.props.active;\n\n\n    return __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(\n      'div',\n      { className: 'emoji-picker-dropdown__modifiers__menu', style: { display: active ? 'block' : 'none' }, ref: this.setRef },\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        onClick: this.handleClick,\n        'data-index': 1\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n        emoji: 'fist',\n        set: 'twitter',\n        size: 22,\n        sheetSize: 32,\n        skin: 1,\n        backgroundImageFn: backgroundImageFn\n      })),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        onClick: this.handleClick,\n        'data-index': 2\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n        emoji: 'fist',\n        set: 'twitter',\n        size: 22,\n        sheetSize: 32,\n        skin: 2,\n        backgroundImageFn: backgroundImageFn\n      })),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        onClick: this.handleClick,\n        'data-index': 3\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n        emoji: 'fist',\n        set: 'twitter',\n        size: 22,\n        sheetSize: 32,\n        skin: 3,\n        backgroundImageFn: backgroundImageFn\n      })),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        onClick: this.handleClick,\n        'data-index': 4\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n        emoji: 'fist',\n        set: 'twitter',\n        size: 22,\n        sheetSize: 32,\n        skin: 4,\n        backgroundImageFn: backgroundImageFn\n      })),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        onClick: this.handleClick,\n        'data-index': 5\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n        emoji: 'fist',\n        set: 'twitter',\n        size: 22,\n        sheetSize: 32,\n        skin: 5,\n        backgroundImageFn: backgroundImageFn\n      })),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        onClick: this.handleClick,\n        'data-index': 6\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n        emoji: 'fist',\n        set: 'twitter',\n        size: 22,\n        sheetSize: 32,\n        skin: 6,\n        backgroundImageFn: backgroundImageFn\n      }))\n    );\n  };\n\n  return ModifierPickerMenu;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\nvar ModifierPicker = function (_React$PureComponent2) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(ModifierPicker, _React$PureComponent2);\n\n  function ModifierPicker() {\n    var _temp2, _this2, _ret2;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, ModifierPicker);\n\n    for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n      args[_key2] = arguments[_key2];\n    }\n\n    return _ret2 = (_temp2 = (_this2 = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent2.call.apply(_React$PureComponent2, [this].concat(args))), _this2), _this2.handleClick = function () {\n      if (_this2.props.active) {\n        _this2.props.onClose();\n      } else {\n        _this2.props.onOpen();\n      }\n    }, _this2.handleSelect = function (modifier) {\n      _this2.props.onChange(modifier);\n      _this2.props.onClose();\n    }, _temp2), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this2, _ret2);\n  }\n\n  ModifierPicker.prototype.render = function render() {\n    var _props = this.props,\n        active = _props.active,\n        modifier = _props.modifier;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'emoji-picker-dropdown__modifiers'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(Emoji, {\n      emoji: 'fist',\n      set: 'twitter',\n      size: 22,\n      sheetSize: 32,\n      skin: modifier,\n      onClick: this.handleClick,\n      backgroundImageFn: backgroundImageFn\n    }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(ModifierPickerMenu, {\n      active: active,\n      onSelect: this.handleSelect,\n      onClose: this.props.onClose\n    }));\n  };\n\n  return ModifierPicker;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\nvar EmojiPickerMenu = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"g\" /* injectIntl */])(_class3 = (_temp4 = _class4 = function (_React$PureComponent3) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(EmojiPickerMenu, _React$PureComponent3);\n\n  function EmojiPickerMenu() {\n    var _temp3, _this3, _ret3;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, EmojiPickerMenu);\n\n    for (var _len3 = arguments.length, args = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n      args[_key3] = arguments[_key3];\n    }\n\n    return _ret3 = (_temp3 = (_this3 = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent3.call.apply(_React$PureComponent3, [this].concat(args))), _this3), _this3.state = {\n      modifierOpen: false\n    }, _this3.handleDocumentClick = function (e) {\n      if (_this3.node && !_this3.node.contains(e.target)) {\n        _this3.props.onClose();\n      }\n    }, _this3.setRef = function (c) {\n      _this3.node = c;\n    }, _this3.getI18n = function () {\n      var intl = _this3.props.intl;\n\n\n      return {\n        search: intl.formatMessage(messages.emoji_search),\n        notfound: intl.formatMessage(messages.emoji_not_found),\n        categories: {\n          search: intl.formatMessage(messages.search_results),\n          recent: intl.formatMessage(messages.recent),\n          people: intl.formatMessage(messages.people),\n          nature: intl.formatMessage(messages.nature),\n          foods: intl.formatMessage(messages.food),\n          activity: intl.formatMessage(messages.activity),\n          places: intl.formatMessage(messages.travel),\n          objects: intl.formatMessage(messages.objects),\n          symbols: intl.formatMessage(messages.symbols),\n          flags: intl.formatMessage(messages.flags),\n          custom: intl.formatMessage(messages.custom)\n        }\n      };\n    }, _this3.handleClick = function (emoji) {\n      if (!emoji.native) {\n        emoji.native = emoji.colons;\n      }\n\n      _this3.props.onClose();\n      _this3.props.onPick(emoji);\n    }, _this3.handleModifierOpen = function () {\n      _this3.setState({ modifierOpen: true });\n    }, _this3.handleModifierClose = function () {\n      _this3.setState({ modifierOpen: false });\n    }, _this3.handleModifierChange = function (modifier) {\n      _this3.props.onSkinTone(modifier);\n    }, _temp3), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this3, _ret3);\n  }\n\n  EmojiPickerMenu.prototype.componentDidMount = function componentDidMount() {\n    document.addEventListener('click', this.handleDocumentClick, false);\n    document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  };\n\n  EmojiPickerMenu.prototype.componentWillUnmount = function componentWillUnmount() {\n    document.removeEventListener('click', this.handleDocumentClick, false);\n    document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  };\n\n  EmojiPickerMenu.prototype.render = function render() {\n    var _props2 = this.props,\n        loading = _props2.loading,\n        style = _props2.style,\n        intl = _props2.intl,\n        custom_emojis = _props2.custom_emojis,\n        skinTone = _props2.skinTone,\n        frequentlyUsedEmojis = _props2.frequentlyUsedEmojis;\n\n\n    if (loading) {\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        style: { width: 299 }\n      });\n    }\n\n    var title = intl.formatMessage(messages.emoji);\n    var modifierOpen = this.state.modifierOpen;\n\n\n    return __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(\n      'div',\n      { className: __WEBPACK_IMPORTED_MODULE_8_classnames___default()('emoji-picker-dropdown__menu', { selecting: modifierOpen }), style: style, ref: this.setRef },\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(EmojiPicker, {\n        perLine: 8,\n        emojiSize: 22,\n        sheetSize: 32,\n        custom: Object(__WEBPACK_IMPORTED_MODULE_10__emoji_emoji__[\"buildCustomEmojis\"])(custom_emojis),\n        color: '',\n        emoji: '',\n        set: 'twitter',\n        title: title,\n        i18n: this.getI18n(),\n        onClick: this.handleClick,\n        include: categoriesSort,\n        recent: frequentlyUsedEmojis,\n        skin: skinTone,\n        showPreview: false,\n        backgroundImageFn: backgroundImageFn,\n        emojiTooltip: true\n      }),\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(ModifierPicker, {\n        active: modifierOpen,\n        modifier: skinTone,\n        onOpen: this.handleModifierOpen,\n        onClose: this.handleModifierClose,\n        onChange: this.handleModifierChange\n      })\n    );\n  };\n\n  return EmojiPickerMenu;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent), _class4.defaultProps = {\n  style: {},\n  loading: true,\n  placement: 'bottom',\n  frequentlyUsedEmojis: []\n}, _temp4)) || _class3;\n\nvar EmojiPickerDropdown = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"g\" /* injectIntl */])(_class5 = function (_React$PureComponent4) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(EmojiPickerDropdown, _React$PureComponent4);\n\n  function EmojiPickerDropdown() {\n    var _temp5, _this4, _ret4;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, EmojiPickerDropdown);\n\n    for (var _len4 = arguments.length, args = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n      args[_key4] = arguments[_key4];\n    }\n\n    return _ret4 = (_temp5 = (_this4 = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent4.call.apply(_React$PureComponent4, [this].concat(args))), _this4), _this4.state = {\n      active: false,\n      loading: false\n    }, _this4.setRef = function (c) {\n      _this4.dropdown = c;\n    }, _this4.onShowDropdown = function () {\n      _this4.setState({ active: true });\n\n      if (!EmojiPicker) {\n        _this4.setState({ loading: true });\n\n        Object(__WEBPACK_IMPORTED_MODULE_6__ui_util_async_components__[\"f\" /* EmojiPicker */])().then(function (EmojiMart) {\n          EmojiPicker = EmojiMart.Picker;\n          Emoji = EmojiMart.Emoji;\n\n          _this4.setState({ loading: false });\n        }).catch(function () {\n          _this4.setState({ loading: false });\n        });\n      }\n    }, _this4.onHideDropdown = function () {\n      _this4.setState({ active: false });\n    }, _this4.onToggle = function (e) {\n      if (!_this4.state.loading && (!e.key || e.key === 'Enter')) {\n        if (_this4.state.active) {\n          _this4.onHideDropdown();\n        } else {\n          _this4.onShowDropdown();\n        }\n      }\n    }, _this4.handleKeyDown = function (e) {\n      if (e.key === 'Escape') {\n        _this4.onHideDropdown();\n      }\n    }, _this4.setTargetRef = function (c) {\n      _this4.target = c;\n    }, _this4.findTarget = function () {\n      return _this4.target;\n    }, _temp5), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this4, _ret4);\n  }\n\n  EmojiPickerDropdown.prototype.render = function render() {\n    var _props3 = this.props,\n        intl = _props3.intl,\n        onPickEmoji = _props3.onPickEmoji,\n        onSkinTone = _props3.onSkinTone,\n        skinTone = _props3.skinTone,\n        frequentlyUsedEmojis = _props3.frequentlyUsedEmojis;\n\n    var title = intl.formatMessage(messages.emoji);\n    var _state = this.state,\n        active = _state.active,\n        loading = _state.loading;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'emoji-picker-dropdown',\n      onKeyDown: this.handleKeyDown\n    }, void 0, __WEBPACK_IMPORTED_MODULE_4_react___default.a.createElement(\n      'div',\n      { ref: this.setTargetRef, className: 'emoji-button', title: title, 'aria-label': title, 'aria-expanded': active, role: 'button', onClick: this.onToggle, onKeyDown: this.onToggle, tabIndex: 0 },\n      __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('img', {\n        className: __WEBPACK_IMPORTED_MODULE_8_classnames___default()('emojione', { 'pulse-loading': active && loading }),\n        alt: '\\uD83D\\uDE42',\n        src: assetHost + '/emoji/1f602.svg'\n      })\n    ), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7_react_overlays_lib_Overlay___default.a, {\n      show: active,\n      placement: 'bottom',\n      target: this.findTarget\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(EmojiPickerMenu, {\n      custom_emojis: this.props.custom_emojis,\n      loading: loading,\n      onClose: this.onHideDropdown,\n      onPick: onPickEmoji,\n      onSkinTone: onSkinTone,\n      skinTone: skinTone,\n      frequentlyUsedEmojis: frequentlyUsedEmojis\n    })));\n  };\n\n  return EmojiPickerDropdown;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent)) || _class5;\n\n\n/* WEBPACK VAR INJECTION */}.call(__webpack_exports__, __webpack_require__(36)))\n\n/***/ }),\n\n/***/ 321:\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_upload_form__ = __webpack_require__(322);\n\n\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    mediaIds: state.getIn(['compose', 'media_attachments']).map(function (item) {\n      return item.get('id');\n    })\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(mapStateToProps)(__WEBPACK_IMPORTED_MODULE_1__components_upload_form__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 322:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return UploadForm; });\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_immutable_proptypes__ = __webpack_require__(13);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__containers_upload_progress_container__ = __webpack_require__(323);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__containers_upload_container__ = __webpack_require__(325);\n\n\n\n\n\nvar _class, _temp;\n\n\n\n\n\n\n\nvar UploadForm = (_temp = _class = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(UploadForm, _ImmutablePureCompone);\n\n  function UploadForm() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, UploadForm);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.apply(this, arguments));\n  }\n\n  UploadForm.prototype.render = function render() {\n    var mediaIds = this.props.mediaIds;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__upload-wrapper'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6__containers_upload_progress_container__[\"a\" /* default */], {}), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__uploads-wrapper'\n    }, void 0, mediaIds.map(function (id) {\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_8__containers_upload_container__[\"a\" /* default */], {\n        id: id\n      }, id);\n    })));\n  };\n\n  return UploadForm;\n}(__WEBPACK_IMPORTED_MODULE_7_react_immutable_pure_component___default.a), _class.propTypes = {\n  mediaIds: __WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default.a.list.isRequired\n}, _temp);\n\n\n/***/ }),\n\n/***/ 323:\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_upload_progress__ = __webpack_require__(324);\n\n\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    active: state.getIn(['compose', 'is_uploading']),\n    progress: state.getIn(['compose', 'progress'])\n  };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_0_react_redux__[\"connect\"])(mapStateToProps)(__WEBPACK_IMPORTED_MODULE_1__components_upload_progress__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 324:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return UploadProgress; });\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__ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_intl__ = __webpack_require__(6);\n\n\n\n\n\n\n\n\n\n\nvar UploadProgress = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(UploadProgress, _React$PureComponent);\n\n  function UploadProgress() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, UploadProgress);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  UploadProgress.prototype.render = function render() {\n    var _props = this.props,\n        active = _props.active,\n        progress = _props.progress;\n\n\n    if (!active) {\n      return null;\n    }\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'upload-progress'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'upload-progress__icon'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n      className: 'fa fa-upload'\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'upload-progress__message'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'upload_progress.label',\n      defaultMessage: 'Uploading...'\n    }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'upload-progress__backdrop'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5__ui_util_optional_motion__[\"a\" /* default */], {\n      defaultStyle: { width: 0 },\n      style: { width: __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default()(progress) }\n    }, void 0, function (_ref) {\n      var width = _ref.width;\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: 'upload-progress__tracker',\n        style: { width: width + '%' }\n      });\n    }))));\n  };\n\n  return UploadProgress;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 325:\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_upload__ = __webpack_require__(326);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions_compose__ = __webpack_require__(18);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__actions_modal__ = __webpack_require__(26);\n\n\n\n\n\nvar mapStateToProps = function mapStateToProps(state, _ref) {\n  var id = _ref.id;\n  return {\n    media: state.getIn(['compose', 'media_attachments']).find(function (item) {\n      return item.get('id') === id;\n    })\n  };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n  return {\n\n    onUndo: function onUndo(id) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_compose__[\"X\" /* undoUploadCompose */])(id));\n    },\n\n    onDescriptionChange: function onDescriptionChange(id, description) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_2__actions_compose__[\"L\" /* changeUploadCompose */])(id, { description: description }));\n    },\n\n    onOpenFocalPoint: function onOpenFocalPoint(id) {\n      dispatch(Object(__WEBPACK_IMPORTED_MODULE_3__actions_modal__[\"d\" /* openModal */])('FOCAL_POINT', { id: id }));\n    }\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_upload__[\"a\" /* default */]));\n\n/***/ }),\n\n/***/ 326:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return Upload; });\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_immutable_proptypes__ = __webpack_require__(13);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_11_classnames__);\n\n\n\n\n\nvar _class, _class2, _temp2;\n\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"f\" /* defineMessages */])({\n  description: {\n    'id': 'upload_form.description',\n    'defaultMessage': 'Describe for the visually impaired'\n  }\n});\n\nvar Upload = Object(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"g\" /* injectIntl */])(_class = (_temp2 = _class2 = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Upload, _ImmutablePureCompone);\n\n  function Upload() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Upload);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.call.apply(_ImmutablePureCompone, [this].concat(args))), _this), _this.state = {\n      hovered: false,\n      focused: false,\n      dirtyDescription: null\n    }, _this.handleUndoClick = function () {\n      _this.props.onUndo(_this.props.media.get('id'));\n    }, _this.handleFocalPointClick = function () {\n      _this.props.onOpenFocalPoint(_this.props.media.get('id'));\n    }, _this.handleInputChange = function (e) {\n      _this.setState({ dirtyDescription: e.target.value });\n    }, _this.handleMouseEnter = function () {\n      _this.setState({ hovered: true });\n    }, _this.handleMouseLeave = function () {\n      _this.setState({ hovered: false });\n    }, _this.handleInputFocus = function () {\n      _this.setState({ focused: true });\n    }, _this.handleInputBlur = function () {\n      var dirtyDescription = _this.state.dirtyDescription;\n\n\n      _this.setState({ focused: false, dirtyDescription: null });\n\n      if (dirtyDescription !== null) {\n        _this.props.onDescriptionChange(_this.props.media.get('id'), dirtyDescription);\n      }\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  Upload.prototype.render = function render() {\n    var _this2 = this;\n\n    var _props = this.props,\n        intl = _props.intl,\n        media = _props.media;\n\n    var active = this.state.hovered || this.state.focused;\n    var description = this.state.dirtyDescription || this.state.dirtyDescription !== '' && media.get('description') || '';\n    var focusX = media.getIn(['meta', 'focus', 'x']);\n    var focusY = media.getIn(['meta', 'focus', 'y']);\n    var x = (focusX / 2 + .5) * 100;\n    var y = (focusY / -2 + .5) * 100;\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'compose-form__upload',\n      onMouseEnter: this.handleMouseEnter,\n      onMouseLeave: this.handleMouseLeave\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__ui_util_optional_motion__[\"a\" /* default */], {\n      defaultStyle: { scale: 0.8 },\n      style: { scale: __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default()(1, { stiffness: 180, damping: 12 }) }\n    }, void 0, function (_ref) {\n      var scale = _ref.scale;\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: 'compose-form__upload-thumbnail',\n        style: { transform: 'scale(' + scale + ')', backgroundImage: 'url(' + media.get('preview_url') + ')', backgroundPosition: x + '% ' + y + '%' }\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: __WEBPACK_IMPORTED_MODULE_11_classnames___default()('compose-form__upload__actions', { active: active })\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        className: 'icon-button',\n        onClick: _this2.handleUndoClick\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n        className: 'fa fa-times'\n      }), ' ', __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'upload_form.undo',\n        defaultMessage: 'Undo'\n      })), media.get('type') === 'image' && __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('button', {\n        className: 'icon-button',\n        onClick: _this2.handleFocalPointClick\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n        className: 'fa fa-crosshairs'\n      }), ' ', __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'upload_form.focus',\n        defaultMessage: 'Crop'\n      }))), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: __WEBPACK_IMPORTED_MODULE_11_classnames___default()('compose-form__upload-description', { active: active })\n      }, void 0, __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, intl.formatMessage(messages.description)), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('input', {\n        placeholder: intl.formatMessage(messages.description),\n        type: 'text',\n        value: description,\n        maxLength: 420,\n        onFocus: _this2.handleInputFocus,\n        onChange: _this2.handleInputChange,\n        onBlur: _this2.handleInputBlur\n      }))));\n    }));\n  };\n\n  return Upload;\n}(__WEBPACK_IMPORTED_MODULE_9_react_immutable_pure_component___default.a), _class2.propTypes = {\n  media: __WEBPACK_IMPORTED_MODULE_5_react_immutable_proptypes___default.a.map.isRequired,\n  intl: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.object.isRequired,\n  onUndo: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.func.isRequired,\n  onDescriptionChange: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.func.isRequired,\n  onOpenFocalPoint: __WEBPACK_IMPORTED_MODULE_6_prop_types___default.a.func.isRequired\n}, _temp2)) || _class;\n\n\n\n/***/ }),\n\n/***/ 327:\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_warning__ = __webpack_require__(328);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__initial_state__ = __webpack_require__(11);\n\n\n\n\n\n\n\n\nvar APPROX_HASHTAG_RE = /(?:^|[^\\/\\)\\w])#(\\w*[a-zA-Z·]\\w*)/i;\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    needsLockWarning: state.getIn(['compose', 'privacy']) === 'private' && !state.getIn(['accounts', __WEBPACK_IMPORTED_MODULE_5__initial_state__[\"g\" /* me */], 'locked']),\n    hashtagWarning: state.getIn(['compose', 'privacy']) !== 'public' && APPROX_HASHTAG_RE.test(state.getIn(['compose', 'text'])),\n    directMessageWarning: state.getIn(['compose', 'privacy']) === 'direct'\n  };\n};\n\nvar WarningWrapper = function WarningWrapper(_ref) {\n  var needsLockWarning = _ref.needsLockWarning,\n      hashtagWarning = _ref.hashtagWarning,\n      directMessageWarning = _ref.directMessageWarning;\n\n  if (needsLockWarning) {\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_3__components_warning__[\"a\" /* default */], {\n      message: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_4_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'compose_form.lock_disclaimer',\n        defaultMessage: 'Your account is not {locked}. Anyone can follow you to view your follower-only posts.',\n        values: { locked: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('a', {\n            href: '/settings/profile'\n          }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_4_react_intl__[\"b\" /* FormattedMessage */], {\n            id: 'compose_form.lock_disclaimer.lock',\n            defaultMessage: 'locked'\n          })) }\n      })\n    });\n  }\n  if (hashtagWarning) {\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_3__components_warning__[\"a\" /* default */], {\n      message: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_4_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'compose_form.hashtag_warning',\n        defaultMessage: 'This toot won\\'t be listed under any hashtag as it is unlisted. Only public toots can be searched by hashtag.'\n      })\n    });\n  }\n  if (directMessageWarning) {\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_3__components_warning__[\"a\" /* default */], {\n      message: __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_4_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'compose_form.direct_message_warning',\n        defaultMessage: 'This toot will only be visible to all the mentioned users.'\n      })\n    });\n  }\n\n  return null;\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_2_react_redux__[\"connect\"])(mapStateToProps)(WarningWrapper));\n\n/***/ }),\n\n/***/ 328:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return Warning; });\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__ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring__);\n\n\n\n\n\n\n\n\n\nvar Warning = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Warning, _React$PureComponent);\n\n  function Warning() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Warning);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  Warning.prototype.render = function render() {\n    var message = this.props.message;\n\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5__ui_util_optional_motion__[\"a\" /* default */], {\n      defaultStyle: { opacity: 0, scaleX: 0.85, scaleY: 0.75 },\n      style: { opacity: __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }), scaleX: __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }), scaleY: __WEBPACK_IMPORTED_MODULE_6_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }) }\n    }, void 0, function (_ref) {\n      var opacity = _ref.opacity,\n          scaleX = _ref.scaleX,\n          scaleY = _ref.scaleY;\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: 'compose-form__warning',\n        style: { opacity: opacity, transform: 'scale(' + scaleX + ', ' + scaleY + ')' }\n      }, void 0, message);\n    });\n  };\n\n  return Warning;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\n\n\n/***/ }),\n\n/***/ 329:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = countableText;\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__url_regex__ = __webpack_require__(330);\n\n\nvar urlPlaceholder = 'xxxxxxxxxxxxxxxxxxxxxxx';\n\nfunction countableText(inputText) {\n  return inputText.replace(__WEBPACK_IMPORTED_MODULE_0__url_regex__[\"a\" /* urlRegex */], urlPlaceholder).replace(/(^|[^\\/\\w])@(([a-z0-9_]+)@[a-z0-9\\.\\-]+[a-z0-9]+)/ig, '$1@$3');\n};\n\n/***/ }),\n\n/***/ 330:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return urlRegex; });\nvar regexen = {};\n\nvar regexSupplant = function regexSupplant(regex, flags) {\n  flags = flags || '';\n  if (typeof regex !== 'string') {\n    if (regex.global && flags.indexOf('g') < 0) {\n      flags += 'g';\n    }\n    if (regex.ignoreCase && flags.indexOf('i') < 0) {\n      flags += 'i';\n    }\n    if (regex.multiline && flags.indexOf('m') < 0) {\n      flags += 'm';\n    }\n\n    regex = regex.source;\n  }\n  return new RegExp(regex.replace(/#\\{(\\w+)\\}/g, function (match, name) {\n    var newRegex = regexen[name] || '';\n    if (typeof newRegex !== 'string') {\n      newRegex = newRegex.source;\n    }\n    return newRegex;\n  }), flags);\n};\n\nvar stringSupplant = function stringSupplant(str, values) {\n  return str.replace(/#\\{(\\w+)\\}/g, function (match, name) {\n    return values[name] || '';\n  });\n};\n\nvar urlRegex = function () {\n  regexen.spaces_group = /\\x09-\\x0D\\x20\\x85\\xA0\\u1680\\u180E\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000/;\n  regexen.invalid_chars_group = /\\uFFFE\\uFEFF\\uFFFF\\u202A-\\u202E/;\n  regexen.punct = /\\!'#%&'\\(\\)*\\+,\\\\\\-\\.\\/:;<=>\\?@\\[\\]\\^_{|}~\\$/;\n  regexen.validUrlPrecedingChars = regexSupplant(/(?:[^A-Za-z0-9@@$###{invalid_chars_group}]|^)/);\n  regexen.invalidDomainChars = stringSupplant('#{punct}#{spaces_group}#{invalid_chars_group}', regexen);\n  regexen.validDomainChars = regexSupplant(/[^#{invalidDomainChars}]/);\n  regexen.validSubdomain = regexSupplant(/(?:(?:#{validDomainChars}(?:[_-]|#{validDomainChars})*)?#{validDomainChars}\\.)/);\n  regexen.validDomainName = regexSupplant(/(?:(?:#{validDomainChars}(?:-|#{validDomainChars})*)?#{validDomainChars}\\.)/);\n  regexen.validGTLD = regexSupplant(RegExp('(?:(?:' + '삼성|닷컴|닷넷|香格里拉|餐厅|食品|飞利浦|電訊盈科|集团|通販|购物|谷歌|诺基亚|联通|网络|网站|网店|网址|组织机构|移动|珠宝|点看|游戏|淡马锡|机构|書籍|时尚|新闻|政府|' + '政务|手表|手机|我爱你|慈善|微博|广东|工行|家電|娱乐|天主教|大拿|大众汽车|在线|嘉里大酒店|嘉里|商标|商店|商城|公益|公司|八卦|健康|信息|佛山|企业|中文网|中信|世界|' + 'ポイント|ファッション|セール|ストア|コム|グーグル|クラウド|みんな|คอม|संगठन|नेट|कॉम|همراه|موقع|موبايلي|كوم|كاثوليك|عرب|شبكة|' + 'بيتك|بازار|العليان|ارامكو|اتصالات|ابوظبي|קום|сайт|рус|орг|онлайн|москва|ком|католик|дети|' + 'zuerich|zone|zippo|zip|zero|zara|zappos|yun|youtube|you|yokohama|yoga|yodobashi|yandex|yamaxun|' + 'yahoo|yachts|xyz|xxx|xperia|xin|xihuan|xfinity|xerox|xbox|wtf|wtc|wow|world|works|work|woodside|' + 'wolterskluwer|wme|winners|wine|windows|win|williamhill|wiki|wien|whoswho|weir|weibo|wedding|wed|' + 'website|weber|webcam|weatherchannel|weather|watches|watch|warman|wanggou|wang|walter|walmart|' + 'wales|vuelos|voyage|voto|voting|vote|volvo|volkswagen|vodka|vlaanderen|vivo|viva|vistaprint|' + 'vista|vision|visa|virgin|vip|vin|villas|viking|vig|video|viajes|vet|versicherung|' + 'vermögensberatung|vermögensberater|verisign|ventures|vegas|vanguard|vana|vacations|ups|uol|uno|' + 'university|unicom|uconnect|ubs|ubank|tvs|tushu|tunes|tui|tube|trv|trust|travelersinsurance|' + 'travelers|travelchannel|travel|training|trading|trade|toys|toyota|town|tours|total|toshiba|' + 'toray|top|tools|tokyo|today|tmall|tkmaxx|tjx|tjmaxx|tirol|tires|tips|tiffany|tienda|tickets|' + 'tiaa|theatre|theater|thd|teva|tennis|temasek|telefonica|telecity|tel|technology|tech|team|tdk|' + 'tci|taxi|tax|tattoo|tatar|tatamotors|target|taobao|talk|taipei|tab|systems|symantec|sydney|' + 'swiss|swiftcover|swatch|suzuki|surgery|surf|support|supply|supplies|sucks|style|study|studio|' + 'stream|store|storage|stockholm|stcgroup|stc|statoil|statefarm|statebank|starhub|star|staples|' + 'stada|srt|srl|spreadbetting|spot|spiegel|space|soy|sony|song|solutions|solar|sohu|software|' + 'softbank|social|soccer|sncf|smile|smart|sling|skype|sky|skin|ski|site|singles|sina|silk|shriram|' + 'showtime|show|shouji|shopping|shop|shoes|shiksha|shia|shell|shaw|sharp|shangrila|sfr|sexy|sex|' + 'sew|seven|ses|services|sener|select|seek|security|secure|seat|search|scot|scor|scjohnson|' + 'science|schwarz|schule|school|scholarships|schmidt|schaeffler|scb|sca|sbs|sbi|saxo|save|sas|' + 'sarl|sapo|sap|sanofi|sandvikcoromant|sandvik|samsung|samsclub|salon|sale|sakura|safety|safe|' + 'saarland|ryukyu|rwe|run|ruhr|rugby|rsvp|room|rogers|rodeo|rocks|rocher|rmit|rip|rio|ril|' + 'rightathome|ricoh|richardli|rich|rexroth|reviews|review|restaurant|rest|republican|report|' + 'repair|rentals|rent|ren|reliance|reit|reisen|reise|rehab|redumbrella|redstone|red|recipes|' + 'realty|realtor|realestate|read|raid|radio|racing|qvc|quest|quebec|qpon|pwc|pub|prudential|pru|' + 'protection|property|properties|promo|progressive|prof|productions|prod|pro|prime|press|praxi|' + 'pramerica|post|porn|politie|poker|pohl|pnc|plus|plumbing|playstation|play|place|pizza|pioneer|' + 'pink|ping|pin|pid|pictures|pictet|pics|piaget|physio|photos|photography|photo|phone|philips|phd|' + 'pharmacy|pfizer|pet|pccw|pay|passagens|party|parts|partners|pars|paris|panerai|panasonic|' + 'pamperedchef|page|ovh|ott|otsuka|osaka|origins|orientexpress|organic|org|orange|oracle|open|ooo|' + 'onyourside|online|onl|ong|one|omega|ollo|oldnavy|olayangroup|olayan|okinawa|office|off|observer|' + 'obi|nyc|ntt|nrw|nra|nowtv|nowruz|now|norton|northwesternmutual|nokia|nissay|nissan|ninja|nikon|' + 'nike|nico|nhk|ngo|nfl|nexus|nextdirect|next|news|newholland|new|neustar|network|netflix|netbank|' + 'net|nec|nba|navy|natura|nationwide|name|nagoya|nadex|nab|mutuelle|mutual|museum|mtr|mtpc|mtn|' + 'msd|movistar|movie|mov|motorcycles|moto|moscow|mortgage|mormon|mopar|montblanc|monster|money|' + 'monash|mom|moi|moe|moda|mobily|mobile|mobi|mma|mls|mlb|mitsubishi|mit|mint|mini|mil|microsoft|' + 'miami|metlife|merckmsd|meo|menu|men|memorial|meme|melbourne|meet|media|med|mckinsey|mcdonalds|' + 'mcd|mba|mattel|maserati|marshalls|marriott|markets|marketing|market|map|mango|management|man|' + 'makeup|maison|maif|madrid|macys|luxury|luxe|lupin|lundbeck|ltda|ltd|lplfinancial|lpl|love|lotto|' + 'lotte|london|lol|loft|locus|locker|loans|loan|lixil|living|live|lipsy|link|linde|lincoln|limo|' + 'limited|lilly|like|lighting|lifestyle|lifeinsurance|life|lidl|liaison|lgbt|lexus|lego|legal|' + 'lefrak|leclerc|lease|lds|lawyer|law|latrobe|latino|lat|lasalle|lanxess|landrover|land|lancome|' + 'lancia|lancaster|lamer|lamborghini|ladbrokes|lacaixa|kyoto|kuokgroup|kred|krd|kpn|kpmg|kosher|' + 'komatsu|koeln|kiwi|kitchen|kindle|kinder|kim|kia|kfh|kerryproperties|kerrylogistics|kerryhotels|' + 'kddi|kaufen|juniper|juegos|jprs|jpmorgan|joy|jot|joburg|jobs|jnj|jmp|jll|jlc|jio|jewelry|jetzt|' + 'jeep|jcp|jcb|java|jaguar|iwc|iveco|itv|itau|istanbul|ist|ismaili|iselect|irish|ipiranga|' + 'investments|intuit|international|intel|int|insure|insurance|institute|ink|ing|info|infiniti|' + 'industries|immobilien|immo|imdb|imamat|ikano|iinet|ifm|ieee|icu|ice|icbc|ibm|hyundai|hyatt|' + 'hughes|htc|hsbc|how|house|hotmail|hotels|hoteles|hot|hosting|host|hospital|horse|honeywell|' + 'honda|homesense|homes|homegoods|homedepot|holiday|holdings|hockey|hkt|hiv|hitachi|hisamitsu|' + 'hiphop|hgtv|hermes|here|helsinki|help|healthcare|health|hdfcbank|hdfc|hbo|haus|hangout|hamburg|' + 'hair|guru|guitars|guide|guge|gucci|guardian|group|grocery|gripe|green|gratis|graphics|grainger|' + 'gov|got|gop|google|goog|goodyear|goodhands|goo|golf|goldpoint|gold|godaddy|gmx|gmo|gmbh|gmail|' + 'globo|global|gle|glass|glade|giving|gives|gifts|gift|ggee|george|genting|gent|gea|gdn|gbiz|' + 'garden|gap|games|game|gallup|gallo|gallery|gal|fyi|futbol|furniture|fund|fun|fujixerox|fujitsu|' + 'ftr|frontier|frontdoor|frogans|frl|fresenius|free|fox|foundation|forum|forsale|forex|ford|' + 'football|foodnetwork|food|foo|fly|flsmidth|flowers|florist|flir|flights|flickr|fitness|fit|' + 'fishing|fish|firmdale|firestone|fire|financial|finance|final|film|fido|fidelity|fiat|ferrero|' + 'ferrari|feedback|fedex|fast|fashion|farmers|farm|fans|fan|family|faith|fairwinds|fail|fage|' + 'extraspace|express|exposed|expert|exchange|everbank|events|eus|eurovision|etisalat|esurance|' + 'estate|esq|erni|ericsson|equipment|epson|epost|enterprises|engineering|engineer|energy|emerck|' + 'email|education|edu|edeka|eco|eat|earth|dvr|dvag|durban|dupont|duns|dunlop|duck|dubai|dtv|drive|' + 'download|dot|doosan|domains|doha|dog|dodge|doctor|docs|dnp|diy|dish|discover|discount|directory|' + 'direct|digital|diet|diamonds|dhl|dev|design|desi|dentist|dental|democrat|delta|deloitte|dell|' + 'delivery|degree|deals|dealer|deal|dds|dclk|day|datsun|dating|date|data|dance|dad|dabur|cyou|' + 'cymru|cuisinella|csc|cruises|cruise|crs|crown|cricket|creditunion|creditcard|credit|courses|' + 'coupons|coupon|country|corsica|coop|cool|cookingchannel|cooking|contractors|contact|consulting|' + 'construction|condos|comsec|computer|compare|company|community|commbank|comcast|com|cologne|' + 'college|coffee|codes|coach|clubmed|club|cloud|clothing|clinique|clinic|click|cleaning|claims|' + 'cityeats|city|citic|citi|citadel|cisco|circle|cipriani|church|chrysler|chrome|christmas|chloe|' + 'chintai|cheap|chat|chase|channel|chanel|cfd|cfa|cern|ceo|center|ceb|cbs|cbre|cbn|cba|catholic|' + 'catering|cat|casino|cash|caseih|case|casa|cartier|cars|careers|career|care|cards|caravan|car|' + 'capitalone|capital|capetown|canon|cancerresearch|camp|camera|cam|calvinklein|call|cal|cafe|cab|' + 'bzh|buzz|buy|business|builders|build|bugatti|budapest|brussels|brother|broker|broadway|' + 'bridgestone|bradesco|box|boutique|bot|boston|bostik|bosch|boots|booking|book|boo|bond|bom|bofa|' + 'boehringer|boats|bnpparibas|bnl|bmw|bms|blue|bloomberg|blog|blockbuster|blanco|blackfriday|' + 'black|biz|bio|bingo|bing|bike|bid|bible|bharti|bet|bestbuy|best|berlin|bentley|beer|beauty|' + 'beats|bcn|bcg|bbva|bbt|bbc|bayern|bauhaus|basketball|baseball|bargains|barefoot|barclays|' + 'barclaycard|barcelona|bar|bank|band|bananarepublic|banamex|baidu|baby|azure|axa|aws|avianca|' + 'autos|auto|author|auspost|audio|audible|audi|auction|attorney|athleta|associates|asia|asda|arte|' + 'art|arpa|army|archi|aramco|arab|aquarelle|apple|app|apartments|aol|anz|anquan|android|analytics|' + 'amsterdam|amica|amfam|amex|americanfamily|americanexpress|alstom|alsace|ally|allstate|allfinanz|' + 'alipay|alibaba|alfaromeo|akdn|airtel|airforce|airbus|aigo|aig|agency|agakhan|africa|afl|' + 'afamilycompany|aetna|aero|aeg|adult|ads|adac|actor|active|aco|accountants|accountant|accenture|' + 'academy|abudhabi|abogado|able|abc|abbvie|abbott|abb|abarth|aarp|aaa|onion' + ')(?=[^0-9a-zA-Z@]|$))'));\n  regexen.validCCTLD = regexSupplant(RegExp('(?:(?:' + '한국|香港|澳門|新加坡|台灣|台湾|中國|中国|გე|ไทย|ලංකා|ഭാരതം|ಭಾರತ|భారత్|சிங்கப்பூர்|இலங்கை|இந்தியா|ଭାରତ|ભારત|ਭਾਰਤ|' + 'ভাৰত|ভারত|বাংলা|भारोत|भारतम्|भारत|ڀارت|پاکستان|مليسيا|مصر|قطر|فلسطين|عمان|عراق|سورية|سودان|تونس|' + 'بھارت|بارت|ایران|امارات|المغرب|السعودية|الجزائر|الاردن|հայ|қаз|укр|срб|рф|мон|мкд|ею|бел|бг|ελ|' + 'zw|zm|za|yt|ye|ws|wf|vu|vn|vi|vg|ve|vc|va|uz|uy|us|um|uk|ug|ua|tz|tw|tv|tt|tr|tp|to|tn|tm|tl|tk|' + 'tj|th|tg|tf|td|tc|sz|sy|sx|sv|su|st|ss|sr|so|sn|sm|sl|sk|sj|si|sh|sg|se|sd|sc|sb|sa|rw|ru|rs|ro|' + 're|qa|py|pw|pt|ps|pr|pn|pm|pl|pk|ph|pg|pf|pe|pa|om|nz|nu|nr|np|no|nl|ni|ng|nf|ne|nc|na|mz|my|mx|' + 'mw|mv|mu|mt|ms|mr|mq|mp|mo|mn|mm|ml|mk|mh|mg|mf|me|md|mc|ma|ly|lv|lu|lt|ls|lr|lk|li|lc|lb|la|kz|' + 'ky|kw|kr|kp|kn|km|ki|kh|kg|ke|jp|jo|jm|je|it|is|ir|iq|io|in|im|il|ie|id|hu|ht|hr|hn|hm|hk|gy|gw|' + 'gu|gt|gs|gr|gq|gp|gn|gm|gl|gi|gh|gg|gf|ge|gd|gb|ga|fr|fo|fm|fk|fj|fi|eu|et|es|er|eh|eg|ee|ec|dz|' + 'do|dm|dk|dj|de|cz|cy|cx|cw|cv|cu|cr|co|cn|cm|cl|ck|ci|ch|cg|cf|cd|cc|ca|bz|by|bw|bv|bt|bs|br|bq|' + 'bo|bn|bm|bl|bj|bi|bh|bg|bf|be|bd|bb|ba|az|ax|aw|au|at|as|ar|aq|ao|an|am|al|ai|ag|af|ae|ad|ac' + ')(?=[^0-9a-zA-Z@]|$))'));\n  regexen.validPunycode = /(?:xn--[0-9a-z]+)/;\n  regexen.validSpecialCCTLD = /(?:(?:co|tv)(?=[^0-9a-zA-Z@]|$))/;\n  regexen.validDomain = regexSupplant(/(?:#{validSubdomain}*#{validDomainName}(?:#{validGTLD}|#{validCCTLD}|#{validPunycode}))/);\n  regexen.validPortNumber = /[0-9]+/;\n  regexen.pd = /\\u002d\\u058a\\u05be\\u1400\\u1806\\u2010-\\u2015\\u2e17\\u2e1a\\u2e3a\\u2e40\\u301c\\u3030\\u30a0\\ufe31\\ufe58\\ufe63\\uff0d/;\n  regexen.validGeneralUrlPathChars = regexSupplant(/[^#{spaces_group}\\(\\)\\?]/i);\n  // Allow URL paths to contain up to two nested levels of balanced parens\n  //  1. Used in Wikipedia URLs like /Primer_(film)\n  //  2. Used in IIS sessions like /S(dfd346)/\n  //  3. Used in Rdio URLs like /track/We_Up_(Album_Version_(Edited))/\n  regexen.validUrlBalancedParens = regexSupplant('\\\\(' + '(?:' + '#{validGeneralUrlPathChars}+' + '|' +\n  // allow one nested level of balanced parentheses\n  '(?:' + '#{validGeneralUrlPathChars}*' + '\\\\(' + '#{validGeneralUrlPathChars}+' + '\\\\)' + '#{validGeneralUrlPathChars}*' + ')' + ')' + '\\\\)', 'i');\n  // Valid end-of-path chracters (so /foo. does not gobble the period).\n  // 1. Allow =&# for empty URL parameters and other URL-join artifacts\n  regexen.validUrlPathEndingChars = regexSupplant(/[^#{spaces_group}\\(\\)\\?!\\*';:=\\,\\.\\$%\\[\\]#{pd}~&\\|@]|(?:#{validUrlBalancedParens})/i);\n  // Allow @ in a url, but only in the middle. Catch things like http://example.com/@user/\n  regexen.validUrlPath = regexSupplant('(?:' + '(?:' + '#{validGeneralUrlPathChars}*' + '(?:#{validUrlBalancedParens}#{validGeneralUrlPathChars}*)*' + '#{validUrlPathEndingChars}' + ')|(?:@#{validGeneralUrlPathChars}+\\/)' + ')', 'i');\n  regexen.validUrlQueryChars = /[a-z0-9!?\\*'@\\(\\);:&=\\+\\$\\/%#\\[\\]\\-_\\.,~|]/i;\n  regexen.validUrlQueryEndingChars = /[a-z0-9_&=#\\/]/i;\n  regexen.validUrl = regexSupplant('(' + // $1 URL\n  '(https?:\\\\/\\\\/)' + // $2 Protocol\n  '(#{validDomain})' + // $3 Domain(s)\n  '(?::(#{validPortNumber}))?' + // $4 Port number (optional)\n  '(\\\\/#{validUrlPath}*)?' + // $5 URL Path\n  '(\\\\?#{validUrlQueryChars}*#{validUrlQueryEndingChars})?' + // $6 Query String\n  ')', 'gi');\n  return regexen.validUrl;\n}();\n\n/***/ }),\n\n/***/ 823:\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 OnboardingModal; });\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_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx__);\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_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_swipeable_views__ = __webpack_require__(158);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7_react_swipeable_views___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7_react_swipeable_views__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_classnames__ = __webpack_require__(10);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__components_permalink__ = __webpack_require__(295);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__compose_components_compose_form__ = __webpack_require__(302);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11__compose_components_search__ = __webpack_require__(864);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__compose_components_navigation_bar__ = __webpack_require__(863);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13__column_header__ = __webpack_require__(150);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14_immutable__ = __webpack_require__(8);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14_immutable___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_14_immutable__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_15__initial_state__ = __webpack_require__(11);\n\n\n\n\n\nvar _dec, _class;\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar noop = function noop() {};\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"f\" /* defineMessages */])({\n  home_title: {\n    'id': 'column.home',\n    'defaultMessage': 'Home'\n  },\n  notifications_title: {\n    'id': 'column.notifications',\n    'defaultMessage': 'Notifications'\n  },\n  local_title: {\n    'id': 'column.community',\n    'defaultMessage': 'Local timeline'\n  },\n  federated_title: {\n    'id': 'column.public',\n    'defaultMessage': 'Federated timeline'\n  }\n});\n\nvar PageOne = function PageOne(_ref) {\n  var acct = _ref.acct,\n      domain = _ref.domain;\n  return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page onboarding-modal__page-one'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page-one__lead'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('h1', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_one.welcome',\n    defaultMessage: 'Welcome to Mastodon!'\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_one.federation',\n    defaultMessage: 'Mastodon is a network of independent servers joining up to make one larger social network. We call these servers instances.'\n  }))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page-one__extra'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'display-case'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'display-case__label'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_one.full_handle',\n    defaultMessage: 'Your full handle'\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'display-case__case'\n  }, void 0, '@', acct, '@', domain)), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_one.handle_hint',\n    defaultMessage: 'This is what you would tell your friends to search for.'\n  }))));\n};\n\nvar PageTwo = function PageTwo(_ref2) {\n  var myAccount = _ref2.myAccount;\n  return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page onboarding-modal__page-two'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'figure non-interactive'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'pseudo-drawer'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_12__compose_components_navigation_bar__[\"a\" /* default */], {\n    account: myAccount\n  }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10__compose_components_compose_form__[\"a\" /* default */], {\n    text: 'Awoo! #introductions',\n    suggestions: Object(__WEBPACK_IMPORTED_MODULE_14_immutable__[\"List\"])(),\n    mentionedDomains: [],\n    spoiler: false,\n    onChange: noop,\n    onSubmit: noop,\n    onPaste: noop,\n    onPickEmoji: noop,\n    onChangeSpoilerText: noop,\n    onClearSuggestions: noop,\n    onFetchSuggestions: noop,\n    onSuggestionSelected: noop,\n    showSearch: true\n  }))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_two.compose',\n    defaultMessage: 'Write posts from the compose column. You can upload images, change privacy settings, and add content warnings with the icons below.'\n  })));\n};\n\nvar PageThree = function PageThree(_ref3) {\n  var myAccount = _ref3.myAccount;\n  return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page onboarding-modal__page-three'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'figure non-interactive'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_11__compose_components_search__[\"a\" /* default */], {\n    value: '',\n    onChange: noop,\n    onSubmit: noop,\n    onClear: noop,\n    onShow: noop\n  }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'pseudo-drawer'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_12__compose_components_navigation_bar__[\"a\" /* default */], {\n    account: myAccount\n  }))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_three.search',\n    defaultMessage: 'Use the search bar to find people and look at hashtags, such as {illustration} and {introductions}. To look for a person who is not on this instance, use their full handle.',\n    values: { illustration: __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_permalink__[\"a\" /* default */], {\n        to: '/timelines/tag/illustration',\n        href: '/tags/illustration'\n      }, void 0, '#illustration'), introductions: __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_permalink__[\"a\" /* default */], {\n        to: '/timelines/tag/introductions',\n        href: '/tags/introductions'\n      }, void 0, '#introductions') }\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_three.profile',\n    defaultMessage: 'Edit your profile to change your avatar, bio, and display name. There, you will also find other preferences.'\n  })));\n};\n\nvar PageFour = function PageFour(_ref4) {\n  var domain = _ref4.domain,\n      intl = _ref4.intl;\n  return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page onboarding-modal__page-four'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page-four__columns'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'row'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'figure non-interactive'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_13__column_header__[\"a\" /* default */], {\n    icon: 'home',\n    type: intl.formatMessage(messages.home_title)\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_four.home',\n    defaultMessage: 'The home timeline shows posts from people you follow.'\n  }))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'figure non-interactive'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_13__column_header__[\"a\" /* default */], {\n    icon: 'bell',\n    type: intl.formatMessage(messages.notifications_title)\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_four.notifications',\n    defaultMessage: 'The notifications column shows when someone interacts with you.'\n  })))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'row'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'figure non-interactive',\n    style: { marginBottom: 0 }\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_13__column_header__[\"a\" /* default */], {\n    icon: 'users',\n    type: intl.formatMessage(messages.local_title)\n  }))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'figure non-interactive',\n    style: { marginBottom: 0 }\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_13__column_header__[\"a\" /* default */], {\n    icon: 'globe',\n    type: intl.formatMessage(messages.federated_title)\n  })))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_five.public_timelines',\n    defaultMessage: 'The local timeline shows public posts from everyone on {domain}. The federated timeline shows public posts from everyone who people on {domain} follow. These are the Public Timelines, a great way to discover new people.',\n    values: { domain: domain }\n  }))));\n};\n\nvar PageSix = function PageSix(_ref5) {\n  var admin = _ref5.admin,\n      domain = _ref5.domain;\n\n  var adminSection = '';\n\n  if (admin) {\n    adminSection = __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'onboarding.page_six.admin',\n      defaultMessage: 'Your instance\\'s admin is {admin}.',\n      values: { admin: __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_permalink__[\"a\" /* default */], {\n          href: admin.get('url'),\n          to: '/accounts/' + admin.get('id')\n        }, void 0, '@', admin.get('acct')) }\n    }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('br', {}), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'onboarding.page_six.read_guidelines',\n      defaultMessage: 'Please read {domain}\\'s {guidelines}!',\n      values: { domain: domain, guidelines: __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('a', {\n          href: '/about/more',\n          target: '_blank'\n        }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n          id: 'onboarding.page_six.guidelines',\n          defaultMessage: 'community guidelines'\n        })) }\n    }));\n  }\n\n  return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n    className: 'onboarding-modal__page onboarding-modal__page-six'\n  }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('h1', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_six.almost_done',\n    defaultMessage: 'Almost done...'\n  })), adminSection, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_six.github',\n    defaultMessage: 'Mastodon is free open-source software. You can report bugs, request features, or contribute to the code on {github}.',\n    values: { github: __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('a', {\n        href: 'https://github.com/tootsuite/mastodon',\n        target: '_blank',\n        rel: 'noopener'\n      }, void 0, 'GitHub') }\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_six.apps_available',\n    defaultMessage: 'There are {apps} available for iOS, Android and other platforms.',\n    values: { apps: __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('a', {\n        href: 'https://github.com/tootsuite/documentation/blob/master/Using-Mastodon/Apps.md',\n        target: '_blank',\n        rel: 'noopener'\n      }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'onboarding.page_six.various_app',\n        defaultMessage: 'mobile apps'\n      })) }\n  })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('p', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('em', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n    id: 'onboarding.page_six.appetoot',\n    defaultMessage: 'Bon Appetoot!'\n  }))));\n};\n\nvar mapStateToProps = function mapStateToProps(state) {\n  return {\n    myAccount: state.getIn(['accounts', __WEBPACK_IMPORTED_MODULE_15__initial_state__[\"g\" /* me */]]),\n    admin: state.getIn(['accounts', state.getIn(['meta', 'admin'])]),\n    domain: state.getIn(['meta', 'domain'])\n  };\n};\n\nvar OnboardingModal = (_dec = Object(__WEBPACK_IMPORTED_MODULE_5_react_redux__[\"connect\"])(mapStateToProps), _dec(_class = Object(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"g\" /* injectIntl */])(_class = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_inherits___default()(OnboardingModal, _React$PureComponent);\n\n  function OnboardingModal() {\n    var _temp, _this, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_classCallCheck___default()(this, OnboardingModal);\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$PureComponent.call.apply(_React$PureComponent, [this].concat(args))), _this), _this.state = {\n      currentIndex: 0\n    }, _this.handleSkip = function (e) {\n      e.preventDefault();\n      _this.props.onClose();\n    }, _this.handleDot = function (e) {\n      var i = Number(e.currentTarget.getAttribute('data-index'));\n      e.preventDefault();\n      _this.setState({ currentIndex: i });\n    }, _this.handlePrev = function () {\n      _this.setState(function (_ref6) {\n        var currentIndex = _ref6.currentIndex;\n        return {\n          currentIndex: Math.max(0, currentIndex - 1)\n        };\n      });\n    }, _this.handleNext = function () {\n      var _this2 = _this,\n          pages = _this2.pages;\n\n      _this.setState(function (_ref7) {\n        var currentIndex = _ref7.currentIndex;\n        return {\n          currentIndex: Math.min(currentIndex + 1, pages.length - 1)\n        };\n      });\n    }, _this.handleSwipe = function (index) {\n      _this.setState({ currentIndex: index });\n    }, _this.handleKeyUp = function (_ref8) {\n      var key = _ref8.key;\n\n      switch (key) {\n        case 'ArrowLeft':\n          _this.handlePrev();\n          break;\n        case 'ArrowRight':\n          _this.handleNext();\n          break;\n      }\n    }, _this.handleClose = function () {\n      _this.props.onClose();\n    }, _temp), __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_possibleConstructorReturn___default()(_this, _ret);\n  }\n\n  OnboardingModal.prototype.componentWillMount = function componentWillMount() {\n    var _props = this.props,\n        myAccount = _props.myAccount,\n        admin = _props.admin,\n        domain = _props.domain,\n        intl = _props.intl;\n\n    this.pages = [__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(PageOne, {\n      acct: myAccount.get('acct'),\n      domain: domain\n    }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(PageTwo, {\n      myAccount: myAccount\n    }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(PageThree, {\n      myAccount: myAccount\n    }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(PageFour, {\n      domain: domain,\n      intl: intl\n    }), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(PageSix, {\n      admin: admin,\n      domain: domain\n    })];\n  };\n\n  OnboardingModal.prototype.componentDidMount = function componentDidMount() {\n    window.addEventListener('keyup', this.handleKeyUp);\n  };\n\n  OnboardingModal.prototype.componentWillUnmount = function componentWillUnmount() {\n    window.addEventListener('keyup', this.handleKeyUp);\n  };\n\n  OnboardingModal.prototype.render = function render() {\n    var _this3 = this;\n\n    var pages = this.pages;\n    var currentIndex = this.state.currentIndex;\n\n    var hasMore = currentIndex < pages.length - 1;\n\n    var nextOrDoneBtn = hasMore ? __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('button', {\n      onClick: this.handleNext,\n      className: 'onboarding-modal__nav onboarding-modal__next shake-bottom'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'onboarding.next',\n      defaultMessage: 'Next'\n    }), ' ', __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('i', {\n      className: 'fa fa-fw fa-chevron-right'\n    })) : __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('button', {\n      onClick: this.handleClose,\n      className: 'onboarding-modal__nav onboarding-modal__done shake-bottom'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'onboarding.done',\n      defaultMessage: 'Done'\n    }), ' ', __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('i', {\n      className: 'fa fa-fw fa-check'\n    }));\n\n    return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n      className: 'modal-root__modal onboarding-modal'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7_react_swipeable_views___default.a, {\n      index: currentIndex,\n      onChangeIndex: this.handleSwipe,\n      className: 'onboarding-modal__pager'\n    }, void 0, pages.map(function (page, i) {\n      var className = __WEBPACK_IMPORTED_MODULE_8_classnames___default()('onboarding-modal__page__wrapper', 'onboarding-modal__page__wrapper-' + i, {\n        'onboarding-modal__page__wrapper--active': i === currentIndex\n      });\n\n      return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n        className: className\n      }, i, page);\n    })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n      className: 'onboarding-modal__paginator'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {}, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('button', {\n      onClick: this.handleSkip,\n      className: 'onboarding-modal__nav onboarding-modal__skip'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'onboarding.skip',\n      defaultMessage: 'Skip'\n    }))), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n      className: 'onboarding-modal__dots'\n    }, void 0, pages.map(function (_, i) {\n      var className = __WEBPACK_IMPORTED_MODULE_8_classnames___default()('onboarding-modal__dot', {\n        active: i === currentIndex\n      });\n\n      return __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {\n        role: 'button',\n        tabIndex: '0',\n        'data-index': i,\n        onClick: _this3.handleDot,\n        className: className\n      }, 'dot-' + i);\n    })), __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_jsx___default()('div', {}, void 0, nextOrDoneBtn)));\n  };\n\n  return OnboardingModal;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent)) || _class) || _class);\n\n\n/***/ }),\n\n/***/ 863:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return NavigationBar; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_prop_types__ = __webpack_require__(5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_immutable_proptypes__ = __webpack_require__(13);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_immutable_proptypes___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_react_immutable_proptypes__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__components_avatar__ = __webpack_require__(56);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__components_icon_button__ = __webpack_require__(23);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__components_permalink__ = __webpack_require__(295);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10_react_intl__ = __webpack_require__(6);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__ = __webpack_require__(12);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component__);\n\n\n\n\n\nvar _class, _temp;\n\n\n\n\n\n\n\n\n\n\nvar NavigationBar = (_temp = _class = function (_ImmutablePureCompone) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(NavigationBar, _ImmutablePureCompone);\n\n  function NavigationBar() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, NavigationBar);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _ImmutablePureCompone.apply(this, arguments));\n  }\n\n  NavigationBar.prototype.render = function render() {\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'navigation-bar'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_permalink__[\"a\" /* default */], {\n      href: this.props.account.get('url'),\n      to: '/accounts/' + this.props.account.get('id')\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('span', {\n      style: { display: 'none' }\n    }, void 0, this.props.account.get('acct')), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__components_avatar__[\"a\" /* default */], {\n      account: this.props.account,\n      size: 40\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'navigation-bar__profile'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_9__components_permalink__[\"a\" /* default */], {\n      href: this.props.account.get('url'),\n      to: '/accounts/' + this.props.account.get('id')\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('strong', {\n      className: 'navigation-bar__profile-account'\n    }, void 0, '@', this.props.account.get('acct'))), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('a', {\n      href: '/settings/profile',\n      className: 'navigation-bar__profile-edit'\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_10_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'navigation_bar.edit_profile',\n      defaultMessage: 'Edit profile'\n    }))), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_8__components_icon_button__[\"a\" /* default */], {\n      title: '',\n      icon: 'close',\n      onClick: this.props.onClose\n    }));\n  };\n\n  return NavigationBar;\n}(__WEBPACK_IMPORTED_MODULE_11_react_immutable_pure_component___default.a), _class.propTypes = {\n  account: __WEBPACK_IMPORTED_MODULE_6_react_immutable_proptypes___default.a.map.isRequired,\n  onClose: __WEBPACK_IMPORTED_MODULE_5_prop_types___default.a.func\n}, _temp);\n\n\n/***/ }),\n\n/***/ 864:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return Search; });\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_react_overlays_lib_Overlay__ = __webpack_require__(96);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6_react_overlays_lib_Overlay___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6_react_overlays_lib_Overlay__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__ui_util_optional_motion__ = __webpack_require__(28);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring__ = __webpack_require__(27);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__initial_state__ = __webpack_require__(11);\n\n\n\n\n\nvar _class;\n\n\n\n\n\n\n\n\n\nvar messages = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"f\" /* defineMessages */])({\n  placeholder: {\n    'id': 'search.placeholder',\n    'defaultMessage': 'Search'\n  }\n});\n\nvar SearchPopout = function (_React$PureComponent) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(SearchPopout, _React$PureComponent);\n\n  function SearchPopout() {\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, SearchPopout);\n\n    return __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent.apply(this, arguments));\n  }\n\n  SearchPopout.prototype.render = function render() {\n    var style = this.props.style;\n\n    var extraInformation = __WEBPACK_IMPORTED_MODULE_9__initial_state__[\"i\" /* searchEnabled */] ? __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'search_popout.tips.full_text',\n      defaultMessage: 'Simple text returns statuses you have written, favourited, boosted, or have been mentioned in, as well as matching usernames, display names, and hashtags.'\n    }) : __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n      id: 'search_popout.tips.text',\n      defaultMessage: 'Simple text returns matching display names, usernames and hashtags'\n    });\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      style: Object.assign({}, style, { position: 'absolute', width: 315 })\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_7__ui_util_optional_motion__[\"a\" /* default */], {\n      defaultStyle: { opacity: 0, scaleX: 0.85, scaleY: 0.75 },\n      style: { opacity: __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }), scaleX: __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }), scaleY: __WEBPACK_IMPORTED_MODULE_8_react_motion_lib_spring___default()(1, { damping: 35, stiffness: 400 }) }\n    }, void 0, function (_ref) {\n      var opacity = _ref.opacity,\n          scaleX = _ref.scaleX,\n          scaleY = _ref.scaleY;\n      return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n        className: 'search-popout',\n        style: { opacity: opacity, transform: 'scale(' + scaleX + ', ' + scaleY + ')' }\n      }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('h4', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'search_popout.search_format',\n        defaultMessage: 'Advanced search format'\n      })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('ul', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('li', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('em', {}, void 0, '#example'), ' ', __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'search_popout.tips.hashtag',\n        defaultMessage: 'hashtag'\n      })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('li', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('em', {}, void 0, '@username@domain'), ' ', __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'search_popout.tips.user',\n        defaultMessage: 'user'\n      })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('li', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('em', {}, void 0, 'URL'), ' ', __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'search_popout.tips.user',\n        defaultMessage: 'user'\n      })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('li', {}, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('em', {}, void 0, 'URL'), ' ', __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"b\" /* FormattedMessage */], {\n        id: 'search_popout.tips.status',\n        defaultMessage: 'status'\n      }))), extraInformation);\n    }));\n  };\n\n  return SearchPopout;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent);\n\nvar Search = Object(__WEBPACK_IMPORTED_MODULE_5_react_intl__[\"g\" /* injectIntl */])(_class = function (_React$PureComponent2) {\n  __WEBPACK_IMPORTED_MODULE_3_babel_runtime_helpers_inherits___default()(Search, _React$PureComponent2);\n\n  function Search() {\n    var _temp, _this2, _ret;\n\n    __WEBPACK_IMPORTED_MODULE_1_babel_runtime_helpers_classCallCheck___default()(this, Search);\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 = (_this2 = __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(this, _React$PureComponent2.call.apply(_React$PureComponent2, [this].concat(args))), _this2), _this2.state = {\n      expanded: false\n    }, _this2.handleChange = function (e) {\n      _this2.props.onChange(e.target.value);\n    }, _this2.handleClear = function (e) {\n      e.preventDefault();\n\n      if (_this2.props.value.length > 0 || _this2.props.submitted) {\n        _this2.props.onClear();\n      }\n    }, _this2.handleKeyDown = function (e) {\n      if (e.key === 'Enter') {\n        e.preventDefault();\n        _this2.props.onSubmit();\n      } else if (e.key === 'Escape') {\n        document.querySelector('.ui').parentElement.focus();\n      }\n    }, _this2.handleFocus = function () {\n      _this2.setState({ expanded: true });\n      _this2.props.onShow();\n    }, _this2.handleBlur = function () {\n      _this2.setState({ expanded: false });\n    }, _temp), __WEBPACK_IMPORTED_MODULE_2_babel_runtime_helpers_possibleConstructorReturn___default()(_this2, _ret);\n  }\n\n  Search.prototype.noop = function noop() {};\n\n  Search.prototype.render = function render() {\n    var _props = this.props,\n        intl = _props.intl,\n        value = _props.value,\n        submitted = _props.submitted;\n    var expanded = this.state.expanded;\n\n    var hasValue = value.length > 0 || submitted;\n\n    return __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      className: 'search'\n    }, void 0, __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, intl.formatMessage(messages.placeholder)), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('input', {\n      className: 'search__input',\n      type: 'text',\n      placeholder: intl.formatMessage(messages.placeholder),\n      value: value,\n      onChange: this.handleChange,\n      onKeyUp: this.handleKeyDown,\n      onFocus: this.handleFocus,\n      onBlur: this.handleBlur\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('div', {\n      role: 'button',\n      tabIndex: '0',\n      className: 'search__icon',\n      onClick: this.handleClear\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n      className: 'fa fa-search ' + (hasValue ? '' : 'active')\n    }), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()('i', {\n      'aria-label': intl.formatMessage(messages.placeholder),\n      className: 'fa fa-times-circle ' + (hasValue ? 'active' : '')\n    })), __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(__WEBPACK_IMPORTED_MODULE_6_react_overlays_lib_Overlay___default.a, {\n      show: expanded && !hasValue,\n      placement: 'bottom',\n      target: this\n    }, void 0, __WEBPACK_IMPORTED_MODULE_0_babel_runtime_helpers_jsx___default()(SearchPopout, {})));\n  };\n\n  return Search;\n}(__WEBPACK_IMPORTED_MODULE_4_react___default.a.PureComponent)) || _class;\n\n\n\n/***/ })\n\n});\n\n\n// WEBPACK FOOTER //\n// modals/onboarding_modal.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\n\nexport default class ColumnHeader extends React.PureComponent {\n\n  static propTypes = {\n    icon: PropTypes.string,\n    type: PropTypes.string,\n    active: PropTypes.bool,\n    onClick: PropTypes.func,\n    columnHeaderId: PropTypes.string,\n  };\n\n  handleClick = () => {\n    this.props.onClick();\n  }\n\n  render () {\n    const { icon, type, active, columnHeaderId } = this.props;\n    let iconElement = '';\n\n    if (icon) {\n      iconElement = <i className={`fa fa-fw fa-${icon} column-header__icon`} />;\n    }\n\n    return (\n      <h1 className={classNames('column-header', { active })} id={columnHeaderId || null}>\n        <button onClick={this.handleClick}>\n          {iconElement}\n          {type}\n        </button>\n      </h1>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/components/column_header.js","import React from 'react';\nimport CharacterCounter from './character_counter';\nimport Button from '../../../components/button';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport ReplyIndicatorContainer from '../containers/reply_indicator_container';\nimport AutosuggestTextarea from '../../../components/autosuggest_textarea';\nimport UploadButtonContainer from '../containers/upload_button_container';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport Collapsable from '../../../components/collapsable';\nimport SpoilerButtonContainer from '../containers/spoiler_button_container';\nimport PrivacyDropdownContainer from '../containers/privacy_dropdown_container';\nimport SensitiveButtonContainer from '../containers/sensitive_button_container';\nimport EmojiPickerDropdown from '../containers/emoji_picker_dropdown_container';\nimport UploadFormContainer from '../containers/upload_form_container';\nimport WarningContainer from '../containers/warning_container';\nimport { isMobile } from '../../../is_mobile';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport { length } from 'stringz';\nimport { countableText } from '../util/counter';\nimport { charLimit } from \"../../../initial_state\"\n\nconst messages = defineMessages({\n  placeholder: { id: 'compose_form.placeholder', defaultMessage: 'What is on your mind?' },\n  spoiler_placeholder: { id: 'compose_form.spoiler_placeholder', defaultMessage: 'Write your warning here' },\n  publish: { id: 'compose_form.publish', defaultMessage: 'Toot' },\n  publishLoud: { id: 'compose_form.publish_loud', defaultMessage: '{publish}!' },\n});\n\n@injectIntl\nexport default class ComposeForm extends ImmutablePureComponent {\n\n  static propTypes = {\n    intl: PropTypes.object.isRequired,\n    text: PropTypes.string.isRequired,\n    suggestion_token: PropTypes.string,\n    suggestions: ImmutablePropTypes.list,\n    spoiler: PropTypes.bool,\n    privacy: PropTypes.string,\n    spoiler_text: PropTypes.string,\n    focusDate: PropTypes.instanceOf(Date),\n    preselectDate: PropTypes.instanceOf(Date),\n    is_submitting: PropTypes.bool,\n    is_uploading: PropTypes.bool,\n    onChange: PropTypes.func.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    onClearSuggestions: PropTypes.func.isRequired,\n    onFetchSuggestions: PropTypes.func.isRequired,\n    onSuggestionSelected: PropTypes.func.isRequired,\n    onChangeSpoilerText: PropTypes.func.isRequired,\n    onPaste: PropTypes.func.isRequired,\n    onPickEmoji: PropTypes.func.isRequired,\n    showSearch: PropTypes.bool,\n    anyMedia: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    showSearch: false,\n  };\n\n  handleChange = (e) => {\n    this.props.onChange(e.target.value);\n  }\n\n  handleKeyDown = (e) => {\n    if (e.keyCode === 13 && (e.ctrlKey || e.metaKey)) {\n      this.handleSubmit();\n    }\n  }\n\n  handleSubmit = () => {\n    if (this.props.text !== this.autosuggestTextarea.textarea.value) {\n      // Something changed the text inside the textarea (e.g. browser extensions like Grammarly)\n      // Update the state to match the current text\n      this.props.onChange(this.autosuggestTextarea.textarea.value);\n    }\n\n    this.props.onSubmit();\n  }\n\n  onSuggestionsClearRequested = () => {\n    this.props.onClearSuggestions();\n  }\n\n  onSuggestionsFetchRequested = (token) => {\n    this.props.onFetchSuggestions(token);\n  }\n\n  onSuggestionSelected = (tokenStart, token, value) => {\n    this._restoreCaret = null;\n    this.props.onSuggestionSelected(tokenStart, token, value);\n  }\n\n  handleChangeSpoilerText = (e) => {\n    this.props.onChangeSpoilerText(e.target.value);\n  }\n\n  componentWillReceiveProps (nextProps) {\n    // If this is the update where we've finished uploading,\n    // save the last caret position so we can restore it below!\n    if (!nextProps.is_uploading && this.props.is_uploading) {\n      this._restoreCaret = this.autosuggestTextarea.textarea.selectionStart;\n    }\n  }\n\n  componentDidUpdate (prevProps) {\n    // This statement does several things:\n    // - If we're beginning a reply, and,\n    //     - Replying to zero or one users, places the cursor at the end of the textbox.\n    //     - Replying to more than one user, selects any usernames past the first;\n    //       this provides a convenient shortcut to drop everyone else from the conversation.\n    // - If we've just finished uploading an image, and have a saved caret position,\n    //   restores the cursor to that position after the text changes!\n    if (this.props.focusDate !== prevProps.focusDate || (prevProps.is_uploading && !this.props.is_uploading && typeof this._restoreCaret === 'number')) {\n      let selectionEnd, selectionStart;\n\n      if (this.props.preselectDate !== prevProps.preselectDate) {\n        selectionEnd   = this.props.text.length;\n        selectionStart = this.props.text.search(/\\s/) + 1;\n      } else if (typeof this._restoreCaret === 'number') {\n        selectionStart = this._restoreCaret;\n        selectionEnd   = this._restoreCaret;\n      } else {\n        selectionEnd   = this.props.text.length;\n        selectionStart = selectionEnd;\n      }\n\n      this.autosuggestTextarea.textarea.setSelectionRange(selectionStart, selectionEnd);\n      this.autosuggestTextarea.textarea.focus();\n    } else if(prevProps.is_submitting && !this.props.is_submitting) {\n      this.autosuggestTextarea.textarea.focus();\n    }\n  }\n\n  setAutosuggestTextarea = (c) => {\n    this.autosuggestTextarea = c;\n  }\n\n  handleEmojiPick = (data) => {\n    const position     = this.autosuggestTextarea.textarea.selectionStart;\n    const emojiChar    = data.native;\n    this._restoreCaret = position + emojiChar.length + 1;\n    this.props.onPickEmoji(position, data);\n  }\n\n  render () {\n    const { intl, onPaste, showSearch, anyMedia } = this.props;\n    const disabled = this.props.is_submitting;\n    const text     = [this.props.spoiler_text, countableText(this.props.text)].join('');\n    const disabledButton = disabled || this.props.is_uploading || length(text) > charLimit || (text.length !== 0 && text.trim().length === 0 && !anyMedia);\n    let publishText = '';\n\n    if (this.props.privacy === 'private' || this.props.privacy === 'direct') {\n      publishText = <span className='compose-form__publish-private'><i className='fa fa-lock' /> {intl.formatMessage(messages.publish)}</span>;\n    } else {\n      publishText = this.props.privacy !== 'unlisted' ? intl.formatMessage(messages.publishLoud, { publish: intl.formatMessage(messages.publish) }) : intl.formatMessage(messages.publish);\n    }\n\n    return (\n      <div className='compose-form'>\n        <WarningContainer />\n\n        <Collapsable isVisible={this.props.spoiler} fullHeight={50}>\n          <div className='spoiler-input'>\n            <label>\n              <span style={{ display: 'none' }}>{intl.formatMessage(messages.spoiler_placeholder)}</span>\n              <input placeholder={intl.formatMessage(messages.spoiler_placeholder)} value={this.props.spoiler_text} onChange={this.handleChangeSpoilerText} onKeyDown={this.handleKeyDown} type='text' className='spoiler-input__input'  id='cw-spoiler-input' />\n            </label>\n          </div>\n        </Collapsable>\n\n        <ReplyIndicatorContainer />\n\n        <div className='compose-form__autosuggest-wrapper'>\n          <AutosuggestTextarea\n            ref={this.setAutosuggestTextarea}\n            placeholder={intl.formatMessage(messages.placeholder)}\n            disabled={disabled}\n            value={this.props.text}\n            onChange={this.handleChange}\n            suggestions={this.props.suggestions}\n            onKeyDown={this.handleKeyDown}\n            onSuggestionsFetchRequested={this.onSuggestionsFetchRequested}\n            onSuggestionsClearRequested={this.onSuggestionsClearRequested}\n            onSuggestionSelected={this.onSuggestionSelected}\n            onPaste={onPaste}\n            autoFocus={!showSearch && !isMobile(window.innerWidth)}\n          />\n\n          <EmojiPickerDropdown onPickEmoji={this.handleEmojiPick} />\n        </div>\n\n        <div className='compose-form__modifiers'>\n          <UploadFormContainer />\n        </div>\n\n        <div className='compose-form__buttons-wrapper'>\n          <div className='compose-form__buttons'>\n            <UploadButtonContainer />\n            <PrivacyDropdownContainer />\n            <SensitiveButtonContainer />\n            <SpoilerButtonContainer />\n          </div>\n          <div className='character-counter__wrapper'><CharacterCounter max={charLimit} text={text} /></div>\n        </div>\n\n        <div className='compose-form__publish'>\n          <div className='compose-form__publish-button-wrapper'><Button text={publishText} onClick={this.handleSubmit} disabled={disabledButton} block /></div>\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/compose_form.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { length } from 'stringz';\n\nexport default class CharacterCounter extends React.PureComponent {\n\n  static propTypes = {\n    text: PropTypes.string.isRequired,\n    max: PropTypes.number.isRequired,\n  };\n\n  checkRemainingText (diff) {\n    if (diff < 0) {\n      return <span className='character-counter character-counter--over'>{diff}</span>;\n    }\n\n    return <span className='character-counter'>{diff}</span>;\n  }\n\n  render () {\n    const diff = this.props.max - length(this.props.text);\n    return this.checkRemainingText(diff);\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/character_counter.js","import { connect } from 'react-redux';\nimport { cancelReplyCompose } from '../../../actions/compose';\nimport { makeGetStatus } from '../../../selectors';\nimport ReplyIndicator from '../components/reply_indicator';\n\nconst makeMapStateToProps = () => {\n  const getStatus = makeGetStatus();\n\n  const mapStateToProps = state => ({\n    status: getStatus(state, state.getIn(['compose', 'in_reply_to'])),\n  });\n\n  return mapStateToProps;\n};\n\nconst mapDispatchToProps = dispatch => ({\n\n  onCancel () {\n    dispatch(cancelReplyCompose());\n  },\n\n});\n\nexport default connect(makeMapStateToProps, mapDispatchToProps)(ReplyIndicator);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/reply_indicator_container.js","import React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport Avatar from '../../../components/avatar';\nimport IconButton from '../../../components/icon_button';\nimport DisplayName from '../../../components/display_name';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport { isRtl } from '../../../rtl';\n\nconst messages = defineMessages({\n  cancel: { id: 'reply_indicator.cancel', defaultMessage: 'Cancel' },\n});\n\n@injectIntl\nexport default class ReplyIndicator extends ImmutablePureComponent {\n\n  static contextTypes = {\n    router: PropTypes.object,\n  };\n\n  static propTypes = {\n    status: ImmutablePropTypes.map,\n    onCancel: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  handleClick = () => {\n    this.props.onCancel();\n  }\n\n  handleAccountClick = (e) => {\n    if (e.button === 0) {\n      e.preventDefault();\n      this.context.router.history.push(`/accounts/${this.props.status.getIn(['account', 'id'])}`);\n    }\n  }\n\n  render () {\n    const { status, intl } = this.props;\n\n    if (!status) {\n      return null;\n    }\n\n    const content = { __html: status.get('contentHtml') };\n    const style   = {\n      direction: isRtl(status.get('search_index')) ? 'rtl' : 'ltr',\n    };\n\n    return (\n      <div className='reply-indicator'>\n        <div className='reply-indicator__header'>\n          <div className='reply-indicator__cancel'><IconButton title={intl.formatMessage(messages.cancel)} icon='times' onClick={this.handleClick} /></div>\n\n          <a href={status.getIn(['account', 'url'])} onClick={this.handleAccountClick} className='reply-indicator__display-name'>\n            <div className='reply-indicator__display-avatar'><Avatar account={status.get('account')} size={24} /></div>\n            <DisplayName account={status.get('account')} />\n          </a>\n        </div>\n\n        <div className='reply-indicator__content' style={style} dangerouslySetInnerHTML={content} />\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/reply_indicator.js","import React from 'react';\nimport AutosuggestAccountContainer from '../features/compose/containers/autosuggest_account_container';\nimport AutosuggestEmoji from './autosuggest_emoji';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport { isRtl } from '../rtl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport Textarea from 'react-textarea-autosize';\nimport classNames from 'classnames';\n\nconst textAtCursorMatchesToken = (str, caretPosition) => {\n  let word;\n\n  let left  = str.slice(0, caretPosition).search(/\\S+$/);\n  let right = str.slice(caretPosition).search(/\\s/);\n\n  if (right < 0) {\n    word = str.slice(left);\n  } else {\n    word = str.slice(left, right + caretPosition);\n  }\n\n  if (!word || word.trim().length < 3 || ['@', ':', '#'].indexOf(word[0]) === -1) {\n    return [null, null];\n  }\n\n  word = word.trim().toLowerCase();\n\n  if (word.length > 0) {\n    return [left + 1, word];\n  } else {\n    return [null, null];\n  }\n};\n\nexport default class AutosuggestTextarea extends ImmutablePureComponent {\n\n  static propTypes = {\n    value: PropTypes.string,\n    suggestions: ImmutablePropTypes.list,\n    disabled: PropTypes.bool,\n    placeholder: PropTypes.string,\n    onSuggestionSelected: PropTypes.func.isRequired,\n    onSuggestionsClearRequested: PropTypes.func.isRequired,\n    onSuggestionsFetchRequested: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    onKeyUp: PropTypes.func,\n    onKeyDown: PropTypes.func,\n    onPaste: PropTypes.func.isRequired,\n    autoFocus: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    autoFocus: true,\n  };\n\n  state = {\n    suggestionsHidden: false,\n    selectedSuggestion: 0,\n    lastToken: null,\n    tokenStart: 0,\n  };\n\n  onChange = (e) => {\n    const [ tokenStart, token ] = textAtCursorMatchesToken(e.target.value, e.target.selectionStart);\n\n    if (token !== null && this.state.lastToken !== token) {\n      this.setState({ lastToken: token, selectedSuggestion: 0, tokenStart });\n      this.props.onSuggestionsFetchRequested(token);\n    } else if (token === null) {\n      this.setState({ lastToken: null });\n      this.props.onSuggestionsClearRequested();\n    }\n\n    this.props.onChange(e);\n  }\n\n  onKeyDown = (e) => {\n    const { suggestions, disabled } = this.props;\n    const { selectedSuggestion, suggestionsHidden } = this.state;\n\n    if (disabled) {\n      e.preventDefault();\n      return;\n    }\n\n    switch(e.key) {\n    case 'Escape':\n      if (!suggestionsHidden) {\n        e.preventDefault();\n        this.setState({ suggestionsHidden: true });\n      }\n\n      break;\n    case 'ArrowDown':\n      if (suggestions.size > 0 && !suggestionsHidden) {\n        e.preventDefault();\n        this.setState({ selectedSuggestion: Math.min(selectedSuggestion + 1, suggestions.size - 1) });\n      }\n\n      break;\n    case 'ArrowUp':\n      if (suggestions.size > 0 && !suggestionsHidden) {\n        e.preventDefault();\n        this.setState({ selectedSuggestion: Math.max(selectedSuggestion - 1, 0) });\n      }\n\n      break;\n    case 'Enter':\n    case 'Tab':\n      // Select suggestion\n      if (this.state.lastToken !== null && suggestions.size > 0 && !suggestionsHidden) {\n        e.preventDefault();\n        e.stopPropagation();\n        this.props.onSuggestionSelected(this.state.tokenStart, this.state.lastToken, suggestions.get(selectedSuggestion));\n      }\n\n      break;\n    }\n\n    if (e.defaultPrevented || !this.props.onKeyDown) {\n      return;\n    }\n\n    this.props.onKeyDown(e);\n  }\n\n  onKeyUp = e => {\n    if (e.key === 'Escape' && this.state.suggestionsHidden) {\n      document.querySelector('.ui').parentElement.focus();\n    }\n\n    if (this.props.onKeyUp) {\n      this.props.onKeyUp(e);\n    }\n  }\n\n  onBlur = () => {\n    this.setState({ suggestionsHidden: true });\n  }\n\n  onSuggestionClick = (e) => {\n    const suggestion = this.props.suggestions.get(e.currentTarget.getAttribute('data-index'));\n    e.preventDefault();\n    this.props.onSuggestionSelected(this.state.tokenStart, this.state.lastToken, suggestion);\n    this.textarea.focus();\n  }\n\n  componentWillReceiveProps (nextProps) {\n    if (nextProps.suggestions !== this.props.suggestions && nextProps.suggestions.size > 0 && this.state.suggestionsHidden) {\n      this.setState({ suggestionsHidden: false });\n    }\n  }\n\n  setTextarea = (c) => {\n    this.textarea = c;\n  }\n\n  onPaste = (e) => {\n    if (e.clipboardData && e.clipboardData.files.length === 1) {\n      this.props.onPaste(e.clipboardData.files);\n      e.preventDefault();\n    }\n  }\n\n  renderSuggestion = (suggestion, i) => {\n    const { selectedSuggestion } = this.state;\n    let inner, key;\n\n    if (typeof suggestion === 'object') {\n      inner = <AutosuggestEmoji emoji={suggestion} />;\n      key   = suggestion.id;\n    } else if (suggestion[0] === '#') {\n      inner = suggestion;\n      key   = suggestion;\n    } else {\n      inner = <AutosuggestAccountContainer id={suggestion} />;\n      key   = suggestion;\n    }\n\n    return (\n      <div role='button' tabIndex='0' key={key} data-index={i} className={classNames('autosuggest-textarea__suggestions__item', { selected: i === selectedSuggestion })} onMouseDown={this.onSuggestionClick}>\n        {inner}\n      </div>\n    );\n  }\n\n  render () {\n    const { value, suggestions, disabled, placeholder, autoFocus } = this.props;\n    const { suggestionsHidden } = this.state;\n    const style = { direction: 'ltr' };\n\n    if (isRtl(value)) {\n      style.direction = 'rtl';\n    }\n\n    return (\n      <div className='autosuggest-textarea'>\n        <label>\n          <span style={{ display: 'none' }}>{placeholder}</span>\n\n          <Textarea\n            inputRef={this.setTextarea}\n            className='autosuggest-textarea__textarea'\n            disabled={disabled}\n            placeholder={placeholder}\n            autoFocus={autoFocus}\n            value={value}\n            onChange={this.onChange}\n            onKeyDown={this.onKeyDown}\n            onKeyUp={this.onKeyUp}\n            onBlur={this.onBlur}\n            onPaste={this.onPaste}\n            style={style}\n            aria-autocomplete='list'\n          />\n        </label>\n\n        <div className={`autosuggest-textarea__suggestions ${suggestionsHidden || suggestions.isEmpty() ? '' : 'autosuggest-textarea__suggestions--visible'}`}>\n          {suggestions.map(this.renderSuggestion)}\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/autosuggest_textarea.js","import { connect } from 'react-redux';\nimport AutosuggestAccount from '../components/autosuggest_account';\nimport { makeGetAccount } from '../../../selectors';\n\nconst makeMapStateToProps = () => {\n  const getAccount = makeGetAccount();\n\n  const mapStateToProps = (state, { id }) => ({\n    account: getAccount(state, id),\n  });\n\n  return mapStateToProps;\n};\n\nexport default connect(makeMapStateToProps)(AutosuggestAccount);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/autosuggest_account_container.js","import React from 'react';\nimport Avatar from '../../../components/avatar';\nimport DisplayName from '../../../components/display_name';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\n\nexport default class AutosuggestAccount extends ImmutablePureComponent {\n\n  static propTypes = {\n    account: ImmutablePropTypes.map.isRequired,\n  };\n\n  render () {\n    const { account } = this.props;\n\n    return (\n      <div className='autosuggest-account'>\n        <div className='autosuggest-account-icon'><Avatar account={account} size={18} /></div>\n        <DisplayName account={account} />\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/autosuggest_account.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport unicodeMapping from '../features/emoji/emoji_unicode_mapping_light';\n\nconst assetHost = process.env.CDN_HOST || '';\n\nexport default class AutosuggestEmoji extends React.PureComponent {\n\n  static propTypes = {\n    emoji: PropTypes.object.isRequired,\n  };\n\n  render () {\n    const { emoji } = this.props;\n    let url;\n\n    if (emoji.custom) {\n      url = emoji.imageUrl;\n    } else {\n      const mapping = unicodeMapping[emoji.native] || unicodeMapping[emoji.native.replace(/\\uFE0F$/, '')];\n\n      if (!mapping) {\n        return null;\n      }\n\n      url = `${assetHost}/emoji/${mapping.filename}.svg`;\n    }\n\n    return (\n      <div className='autosuggest-emoji'>\n        <img\n          className='emojione'\n          src={url}\n          alt={emoji.native || emoji.colons}\n        />\n\n        {emoji.colons}\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/autosuggest_emoji.js","import React from 'react';\nimport PropTypes from 'prop-types';\n\nfunction _extends() {\n  _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n  subClass.prototype = Object.create(superClass.prototype);\n  subClass.prototype.constructor = subClass;\n  subClass.__proto__ = superClass;\n}\n\nfunction _objectWithoutProperties(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  if (Object.getOwnPropertySymbols) {\n    var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n    for (i = 0; i < sourceSymbolKeys.length; i++) {\n      key = sourceSymbolKeys[i];\n      if (excluded.indexOf(key) >= 0) continue;\n      if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n      target[key] = source[key];\n    }\n  }\n\n  return target;\n}\n\nvar isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined';\n\nvar isIE = isBrowser ? !!document.documentElement.currentStyle : false;\nvar hiddenTextarea = isBrowser && document.createElement('textarea');\nvar HIDDEN_TEXTAREA_STYLE = {\n  'min-height': '0',\n  'max-height': 'none',\n  height: '0',\n  visibility: 'hidden',\n  overflow: 'hidden',\n  position: 'absolute',\n  'z-index': '-1000',\n  top: '0',\n  right: '0'\n};\nvar SIZING_STYLE = ['letter-spacing', 'line-height', 'font-family', 'font-weight', 'font-size', 'font-style', 'tab-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-top', 'padding-right', 'padding-bottom', 'padding-left', 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width', 'box-sizing'];\nvar computedStyleCache = {};\nfunction calculateNodeHeight(uiTextNode, uid, useCache, minRows, maxRows) {\n  if (useCache === void 0) {\n    useCache = false;\n  }\n\n  if (minRows === void 0) {\n    minRows = null;\n  }\n\n  if (maxRows === void 0) {\n    maxRows = null;\n  }\n\n  if (hiddenTextarea.parentNode === null) {\n    document.body.appendChild(hiddenTextarea);\n  } // Copy all CSS properties that have an impact on the height of the content in\n  // the textbox\n\n\n  var nodeStyling = calculateNodeStyling(uiTextNode, uid, useCache);\n\n  if (nodeStyling === null) {\n    return null;\n  }\n\n  var paddingSize = nodeStyling.paddingSize,\n      borderSize = nodeStyling.borderSize,\n      boxSizing = nodeStyling.boxSizing,\n      sizingStyle = nodeStyling.sizingStyle; // Need to have the overflow attribute to hide the scrollbar otherwise\n  // text-lines will not calculated properly as the shadow will technically be\n  // narrower for content\n\n  Object.keys(sizingStyle).forEach(function (key) {\n    hiddenTextarea.style[key] = sizingStyle[key];\n  });\n  Object.keys(HIDDEN_TEXTAREA_STYLE).forEach(function (key) {\n    hiddenTextarea.style.setProperty(key, HIDDEN_TEXTAREA_STYLE[key], 'important');\n  });\n  hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || 'x';\n  var minHeight = -Infinity;\n  var maxHeight = Infinity;\n  var height = hiddenTextarea.scrollHeight;\n\n  if (boxSizing === 'border-box') {\n    // border-box: add border, since height = content + padding + border\n    height = height + borderSize;\n  } else if (boxSizing === 'content-box') {\n    // remove padding, since height = content\n    height = height - paddingSize;\n  } // measure height of a textarea with a single row\n\n\n  hiddenTextarea.value = 'x';\n  var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;\n\n  if (minRows !== null || maxRows !== null) {\n    if (minRows !== null) {\n      minHeight = singleRowHeight * minRows;\n\n      if (boxSizing === 'border-box') {\n        minHeight = minHeight + paddingSize + borderSize;\n      }\n\n      height = Math.max(minHeight, height);\n    }\n\n    if (maxRows !== null) {\n      maxHeight = singleRowHeight * maxRows;\n\n      if (boxSizing === 'border-box') {\n        maxHeight = maxHeight + paddingSize + borderSize;\n      }\n\n      height = Math.min(maxHeight, height);\n    }\n  }\n\n  var rowCount = Math.floor(height / singleRowHeight);\n  return {\n    height: height,\n    minHeight: minHeight,\n    maxHeight: maxHeight,\n    rowCount: rowCount\n  };\n}\n\nfunction calculateNodeStyling(node, uid, useCache) {\n  if (useCache === void 0) {\n    useCache = false;\n  }\n\n  if (useCache && computedStyleCache[uid]) {\n    return computedStyleCache[uid];\n  }\n\n  var style = window.getComputedStyle(node);\n\n  if (style === null) {\n    return null;\n  }\n\n  var sizingStyle = SIZING_STYLE.reduce(function (obj, name) {\n    obj[name] = style.getPropertyValue(name);\n    return obj;\n  }, {});\n  var boxSizing = sizingStyle['box-sizing']; // IE (Edge has already correct behaviour) returns content width as computed width\n  // so we need to add manually padding and border widths\n\n  if (isIE && boxSizing === 'border-box') {\n    sizingStyle.width = parseFloat(sizingStyle.width) + parseFloat(style['border-right-width']) + parseFloat(style['border-left-width']) + parseFloat(style['padding-right']) + parseFloat(style['padding-left']) + 'px';\n  }\n\n  var paddingSize = parseFloat(sizingStyle['padding-bottom']) + parseFloat(sizingStyle['padding-top']);\n  var borderSize = parseFloat(sizingStyle['border-bottom-width']) + parseFloat(sizingStyle['border-top-width']);\n  var nodeInfo = {\n    sizingStyle: sizingStyle,\n    paddingSize: paddingSize,\n    borderSize: borderSize,\n    boxSizing: boxSizing\n  };\n\n  if (useCache) {\n    computedStyleCache[uid] = nodeInfo;\n  }\n\n  return nodeInfo;\n}\n\nvar purgeCache = function purgeCache(uid) {\n  return delete computedStyleCache[uid];\n};\n\nfunction autoInc(seed) {\n  if (seed === void 0) {\n    seed = 0;\n  }\n\n  return function () {\n    return ++seed;\n  };\n}\n\nvar uid = autoInc();\n\n/**\n * <TextareaAutosize />\n */\nvar noop = function noop() {}; // IE11 has a problem with eval source maps, can be reproduced with:\n// eval('\"use strict\"; var onNextFrame = window.cancelAnimationFrame; onNextFrame(4);')\n// so we bind window as context in dev modes\n\n\nvar _ref = isBrowser && window.requestAnimationFrame ? process.env.NODE_ENV !== 'development' ? [window.requestAnimationFrame, window.cancelAnimationFrame] : [window.requestAnimationFrame.bind(window), window.cancelAnimationFrame.bind(window)] : [setTimeout, clearTimeout];\nvar onNextFrame = _ref[0];\nvar clearNextFrameAction = _ref[1];\n\nvar TextareaAutosize =\n/*#__PURE__*/\nfunction (_React$Component) {\n  _inheritsLoose(TextareaAutosize, _React$Component);\n\n  function TextareaAutosize(props) {\n    var _this;\n\n    _this = _React$Component.call(this, props) || this;\n    _this._resizeLock = false;\n\n    _this._onRootDOMNode = function (node) {\n      _this._rootDOMNode = node;\n\n      if (_this.props.inputRef) {\n        _this.props.inputRef(node);\n      }\n    };\n\n    _this._onChange = function (event) {\n      if (!_this._controlled) {\n        _this._resizeComponent();\n      }\n\n      _this.props.onChange(event);\n    };\n\n    _this._resizeComponent = function (callback) {\n      if (callback === void 0) {\n        callback = noop;\n      }\n\n      if (typeof _this._rootDOMNode === 'undefined') {\n        callback();\n        return;\n      }\n\n      var nodeHeight = calculateNodeHeight(_this._rootDOMNode, _this._uid, _this.props.useCacheForDOMMeasurements, _this.props.minRows, _this.props.maxRows);\n\n      if (nodeHeight === null) {\n        callback();\n        return;\n      }\n\n      var height = nodeHeight.height,\n          minHeight = nodeHeight.minHeight,\n          maxHeight = nodeHeight.maxHeight,\n          rowCount = nodeHeight.rowCount;\n      _this.rowCount = rowCount;\n\n      if (_this.state.height !== height || _this.state.minHeight !== minHeight || _this.state.maxHeight !== maxHeight) {\n        _this.setState({\n          height: height,\n          minHeight: minHeight,\n          maxHeight: maxHeight\n        }, callback);\n\n        return;\n      }\n\n      callback();\n    };\n\n    _this.state = {\n      height: props.style && props.style.height || 0,\n      minHeight: -Infinity,\n      maxHeight: Infinity\n    };\n    _this._uid = uid();\n    _this._controlled = typeof props.value === 'string';\n    return _this;\n  }\n\n  var _proto = TextareaAutosize.prototype;\n\n  _proto.render = function render() {\n    var _props = this.props,\n        _minRows = _props.minRows,\n        _maxRows = _props.maxRows,\n        _onHeightChange = _props.onHeightChange,\n        _useCacheForDOMMeasurements = _props.useCacheForDOMMeasurements,\n        _inputRef = _props.inputRef,\n        props = _objectWithoutProperties(_props, [\"minRows\", \"maxRows\", \"onHeightChange\", \"useCacheForDOMMeasurements\", \"inputRef\"]);\n    props.style = _extends({}, props.style, {\n      height: this.state.height\n    });\n    var maxHeight = Math.max(props.style.maxHeight || Infinity, this.state.maxHeight);\n\n    if (maxHeight < this.state.height) {\n      props.style.overflow = 'hidden';\n    }\n\n    return React.createElement(\"textarea\", _extends({}, props, {\n      onChange: this._onChange,\n      ref: this._onRootDOMNode\n    }));\n  };\n\n  _proto.componentDidMount = function componentDidMount() {\n    var _this2 = this;\n\n    this._resizeComponent(); // Working around Firefox bug which runs resize listeners even when other JS is running at the same moment\n    // causing competing rerenders (due to setState in the listener) in React.\n    // More can be found here - facebook/react#6324\n\n\n    this._resizeListener = function () {\n      if (_this2._resizeLock) {\n        return;\n      }\n\n      _this2._resizeLock = true;\n\n      _this2._resizeComponent(function () {\n        return _this2._resizeLock = false;\n      });\n    };\n\n    window.addEventListener('resize', this._resizeListener);\n  };\n\n  _proto.componentWillReceiveProps = function componentWillReceiveProps() {\n    var _this3 = this;\n\n    this._clearNextFrame();\n\n    this._onNextFrameActionId = onNextFrame(function () {\n      return _this3._resizeComponent();\n    });\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n    if (this.state.height !== prevState.height) {\n      this.props.onHeightChange(this.state.height, this);\n    }\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this._clearNextFrame();\n\n    window.removeEventListener('resize', this._resizeListener);\n    purgeCache(this._uid);\n  };\n\n  _proto._clearNextFrame = function _clearNextFrame() {\n    clearNextFrameAction(this._onNextFrameActionId);\n  };\n\n  return TextareaAutosize;\n}(React.Component);\n\nTextareaAutosize.propTypes = {\n  value: PropTypes.string,\n  onChange: PropTypes.func,\n  onHeightChange: PropTypes.func,\n  useCacheForDOMMeasurements: PropTypes.bool,\n  minRows: PropTypes.number,\n  maxRows: PropTypes.number,\n  inputRef: PropTypes.func\n};\nTextareaAutosize.defaultProps = {\n  onChange: noop,\n  onHeightChange: noop,\n  useCacheForDOMMeasurements: false\n};\n\nexport default TextareaAutosize;\n\n\n\n// WEBPACK FOOTER //\n// ./node_modules/react-textarea-autosize/es/index.js","import { connect } from 'react-redux';\nimport UploadButton from '../components/upload_button';\nimport { uploadCompose } from '../../../actions/compose';\n\nconst mapStateToProps = state => ({\n  disabled: state.getIn(['compose', 'is_uploading']) || (state.getIn(['compose', 'media_attachments']).size > 3 || state.getIn(['compose', 'media_attachments']).some(m => m.get('type') === 'video')),\n  resetFileKey: state.getIn(['compose', 'resetFileKey']),\n});\n\nconst mapDispatchToProps = dispatch => ({\n\n  onSelectFile (files) {\n    dispatch(uploadCompose(files));\n  },\n\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(UploadButton);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/upload_button_container.js","import React from 'react';\nimport IconButton from '../../../components/icon_button';\nimport PropTypes from 'prop-types';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport { connect } from 'react-redux';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst messages = defineMessages({\n  upload: { id: 'upload_button.label', defaultMessage: 'Add media' },\n});\n\nconst makeMapStateToProps = () => {\n  const mapStateToProps = state => ({\n    acceptContentTypes: state.getIn(['media_attachments', 'accept_content_types']),\n  });\n\n  return mapStateToProps;\n};\n\nconst iconStyle = {\n  height: null,\n  lineHeight: '27px',\n};\n\n@connect(makeMapStateToProps)\n@injectIntl\nexport default class UploadButton extends ImmutablePureComponent {\n\n  static propTypes = {\n    disabled: PropTypes.bool,\n    onSelectFile: PropTypes.func.isRequired,\n    style: PropTypes.object,\n    resetFileKey: PropTypes.number,\n    acceptContentTypes: ImmutablePropTypes.listOf(PropTypes.string).isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  handleChange = (e) => {\n    if (e.target.files.length > 0) {\n      this.props.onSelectFile(e.target.files);\n    }\n  }\n\n  handleClick = () => {\n    this.fileElement.click();\n  }\n\n  setRef = (c) => {\n    this.fileElement = c;\n  }\n\n  render () {\n\n    const { intl, resetFileKey, disabled, acceptContentTypes } = this.props;\n\n    return (\n      <div className='compose-form__upload-button'>\n        <IconButton icon='camera' title={intl.formatMessage(messages.upload)} disabled={disabled} onClick={this.handleClick} className='compose-form__upload-button-icon' size={18} inverted style={iconStyle} />\n        <label>\n          <span style={{ display: 'none' }}>{intl.formatMessage(messages.upload)}</span>\n          <input\n            key={resetFileKey}\n            ref={this.setRef}\n            type='file'\n            multiple={false}\n            accept={acceptContentTypes.toArray().join(',')}\n            onChange={this.handleChange}\n            disabled={disabled}\n            style={{ display: 'none' }}\n          />\n        </label>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/upload_button.js","import React from 'react';\nimport Motion from '../features/ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\nimport PropTypes from 'prop-types';\n\nconst Collapsable = ({ fullHeight, isVisible, children }) => (\n  <Motion defaultStyle={{ opacity: !isVisible ? 0 : 100, height: isVisible ? fullHeight : 0 }} style={{ opacity: spring(!isVisible ? 0 : 100), height: spring(!isVisible ? 0 : fullHeight) }}>\n    {({ opacity, height }) => (\n      <div style={{ height: `${height}px`, overflow: 'hidden', opacity: opacity / 100, display: Math.floor(opacity) === 0 ? 'none' : 'block' }}>\n        {children}\n      </div>\n    )}\n  </Motion>\n);\n\nCollapsable.propTypes = {\n  fullHeight: PropTypes.number.isRequired,\n  isVisible: PropTypes.bool.isRequired,\n  children: PropTypes.node.isRequired,\n};\n\nexport default Collapsable;\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/components/collapsable.js","import { connect } from 'react-redux';\nimport TextIconButton from '../components/text_icon_button';\nimport { changeComposeSpoilerness } from '../../../actions/compose';\nimport { injectIntl, defineMessages } from 'react-intl';\n\nconst messages = defineMessages({\n  marked: { id: 'compose_form.spoiler.marked', defaultMessage: 'Text is hidden behind warning' },\n  unmarked: { id: 'compose_form.spoiler.unmarked', defaultMessage: 'Text is not hidden' },\n});\n\nconst mapStateToProps = (state, { intl }) => ({\n  label: 'CW',\n  title: intl.formatMessage(state.getIn(['compose', 'spoiler']) ? messages.marked : messages.unmarked),\n  active: state.getIn(['compose', 'spoiler']),\n  ariaControls: 'cw-spoiler-input',\n});\n\nconst mapDispatchToProps = dispatch => ({\n\n  onClick () {\n    dispatch(changeComposeSpoilerness());\n  },\n\n});\n\nexport default injectIntl(connect(mapStateToProps, mapDispatchToProps)(TextIconButton));\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/spoiler_button_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\n\nexport default class TextIconButton extends React.PureComponent {\n\n  static propTypes = {\n    label: PropTypes.string.isRequired,\n    title: PropTypes.string,\n    active: PropTypes.bool,\n    onClick: PropTypes.func.isRequired,\n    ariaControls: PropTypes.string,\n  };\n\n  handleClick = (e) => {\n    e.preventDefault();\n    this.props.onClick();\n  }\n\n  render () {\n    const { label, title, active, ariaControls } = this.props;\n\n    return (\n      <button title={title} aria-label={title} className={`text-icon-button ${active ? 'active' : ''}`} aria-expanded={active} onClick={this.handleClick} aria-controls={ariaControls}>\n        {label}\n      </button>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/text_icon_button.js","import { connect } from 'react-redux';\nimport PrivacyDropdown from '../components/privacy_dropdown';\nimport { changeComposeVisibility } from '../../../actions/compose';\nimport { openModal, closeModal } from '../../../actions/modal';\nimport { isUserTouching } from '../../../is_mobile';\n\nconst mapStateToProps = state => ({\n  isModalOpen: state.get('modal').modalType === 'ACTIONS',\n  value: state.getIn(['compose', 'privacy']),\n});\n\nconst mapDispatchToProps = dispatch => ({\n\n  onChange (value) {\n    dispatch(changeComposeVisibility(value));\n  },\n\n  isUserTouching,\n  onModalOpen: props => dispatch(openModal('ACTIONS', props)),\n  onModalClose: () => dispatch(closeModal()),\n\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(PrivacyDropdown);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/privacy_dropdown_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { injectIntl, defineMessages } from 'react-intl';\nimport IconButton from '../../../components/icon_button';\nimport Overlay from 'react-overlays/lib/Overlay';\nimport Motion from '../../ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\nimport detectPassiveEvents from 'detect-passive-events';\nimport classNames from 'classnames';\n\nconst messages = defineMessages({\n  public_short: { id: 'privacy.public.short', defaultMessage: 'Public' },\n  public_long: { id: 'privacy.public.long', defaultMessage: 'Post to public timelines' },\n  unlisted_short: { id: 'privacy.unlisted.short', defaultMessage: 'Unlisted' },\n  unlisted_long: { id: 'privacy.unlisted.long', defaultMessage: 'Do not show in public timelines' },\n  private_short: { id: 'privacy.private.short', defaultMessage: 'Followers-only' },\n  private_long: { id: 'privacy.private.long', defaultMessage: 'Post to followers only' },\n  direct_short: { id: 'privacy.direct.short', defaultMessage: 'Direct' },\n  direct_long: { id: 'privacy.direct.long', defaultMessage: 'Post to mentioned users only' },\n  change_privacy: { id: 'privacy.change', defaultMessage: 'Adjust status privacy' },\n});\n\nconst listenerOptions = detectPassiveEvents.hasSupport ? { passive: true } : false;\n\nclass PrivacyDropdownMenu extends React.PureComponent {\n\n  static propTypes = {\n    style: PropTypes.object,\n    items: PropTypes.array.isRequired,\n    value: PropTypes.string.isRequired,\n    onClose: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n  };\n\n  handleDocumentClick = e => {\n    if (this.node && !this.node.contains(e.target)) {\n      this.props.onClose();\n    }\n  }\n\n  handleClick = e => {\n    if (e.key === 'Escape') {\n      this.props.onClose();\n    } else if (!e.key || e.key === 'Enter') {\n      const value = e.currentTarget.getAttribute('data-index');\n\n      e.preventDefault();\n\n      this.props.onClose();\n      this.props.onChange(value);\n    }\n  }\n\n  componentDidMount () {\n    document.addEventListener('click', this.handleDocumentClick, false);\n    document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  }\n\n  componentWillUnmount () {\n    document.removeEventListener('click', this.handleDocumentClick, false);\n    document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  }\n\n  setRef = c => {\n    this.node = c;\n  }\n\n  render () {\n    const { style, items, value } = this.props;\n\n    return (\n      <Motion defaultStyle={{ opacity: 0, scaleX: 0.85, scaleY: 0.75 }} style={{ opacity: spring(1, { damping: 35, stiffness: 400 }), scaleX: spring(1, { damping: 35, stiffness: 400 }), scaleY: spring(1, { damping: 35, stiffness: 400 }) }}>\n        {({ opacity, scaleX, scaleY }) => (\n          <div className='privacy-dropdown__dropdown' style={{ ...style, opacity: opacity, transform: `scale(${scaleX}, ${scaleY})` }} ref={this.setRef}>\n            {items.map(item => (\n              <div role='button' tabIndex='0' key={item.value} data-index={item.value} onKeyDown={this.handleClick} onClick={this.handleClick} className={classNames('privacy-dropdown__option', { active: item.value === value })}>\n                <div className='privacy-dropdown__option__icon'>\n                  <i className={`fa fa-fw fa-${item.icon}`} />\n                </div>\n\n                <div className='privacy-dropdown__option__content'>\n                  <strong>{item.text}</strong>\n                  {item.meta}\n                </div>\n              </div>\n            ))}\n          </div>\n        )}\n      </Motion>\n    );\n  }\n\n}\n\n@injectIntl\nexport default class PrivacyDropdown extends React.PureComponent {\n\n  static propTypes = {\n    isUserTouching: PropTypes.func,\n    isModalOpen: PropTypes.bool.isRequired,\n    onModalOpen: PropTypes.func,\n    onModalClose: PropTypes.func,\n    value: PropTypes.string.isRequired,\n    onChange: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  state = {\n    open: false,\n  };\n\n  handleToggle = () => {\n    if (this.props.isUserTouching()) {\n      if (this.state.open) {\n        this.props.onModalClose();\n      } else {\n        this.props.onModalOpen({\n          actions: this.options.map(option => ({ ...option, active: option.value === this.props.value })),\n          onClick: this.handleModalActionClick,\n        });\n      }\n    } else {\n      this.setState({ open: !this.state.open });\n    }\n  }\n\n  handleModalActionClick = (e) => {\n    e.preventDefault();\n\n    const { value } = this.options[e.currentTarget.getAttribute('data-index')];\n\n    this.props.onModalClose();\n    this.props.onChange(value);\n  }\n\n  handleKeyDown = e => {\n    switch(e.key) {\n    case 'Enter':\n      this.handleToggle();\n      break;\n    case 'Escape':\n      this.handleClose();\n      break;\n    }\n  }\n\n  handleClose = () => {\n    this.setState({ open: false });\n  }\n\n  handleChange = value => {\n    this.props.onChange(value);\n  }\n\n  componentWillMount () {\n    const { intl: { formatMessage } } = this.props;\n\n    this.options = [\n      { icon: 'globe', value: 'public', text: formatMessage(messages.public_short), meta: formatMessage(messages.public_long) },\n      { icon: 'unlock-alt', value: 'unlisted', text: formatMessage(messages.unlisted_short), meta: formatMessage(messages.unlisted_long) },\n      { icon: 'lock', value: 'private', text: formatMessage(messages.private_short), meta: formatMessage(messages.private_long) },\n      { icon: 'envelope', value: 'direct', text: formatMessage(messages.direct_short), meta: formatMessage(messages.direct_long) },\n    ];\n  }\n\n  render () {\n    const { value, intl } = this.props;\n    const { open } = this.state;\n\n    const valueOption = this.options.find(item => item.value === value);\n\n    return (\n      <div className={classNames('privacy-dropdown', { active: open })} onKeyDown={this.handleKeyDown}>\n        <div className={classNames('privacy-dropdown__value', { active: this.options.indexOf(valueOption) === 0 })}>\n          <IconButton\n            className='privacy-dropdown__value-icon'\n            icon={valueOption.icon}\n            title={intl.formatMessage(messages.change_privacy)}\n            size={18}\n            expanded={open}\n            active={open}\n            inverted\n            onClick={this.handleToggle}\n            style={{ height: null, lineHeight: '27px' }}\n          />\n        </div>\n\n        <Overlay show={open} placement='bottom' target={this}>\n          <PrivacyDropdownMenu\n            items={this.options}\n            value={value}\n            onClose={this.handleClose}\n            onChange={this.handleChange}\n          />\n        </Overlay>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/privacy_dropdown.js","import React from 'react';\nimport { connect } from 'react-redux';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport IconButton from '../../../components/icon_button';\nimport { changeComposeSensitivity } from '../../../actions/compose';\nimport Motion from '../../ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\nimport { injectIntl, defineMessages } from 'react-intl';\n\nconst messages = defineMessages({\n  marked: { id: 'compose_form.sensitive.marked', defaultMessage: 'Media is marked as sensitive' },\n  unmarked: { id: 'compose_form.sensitive.unmarked', defaultMessage: 'Media is not marked as sensitive' },\n});\n\nconst mapStateToProps = state => ({\n  visible: state.getIn(['compose', 'media_attachments']).size > 0,\n  active: state.getIn(['compose', 'sensitive']),\n  disabled: state.getIn(['compose', 'spoiler']),\n});\n\nconst mapDispatchToProps = dispatch => ({\n\n  onClick () {\n    dispatch(changeComposeSensitivity());\n  },\n\n});\n\nclass SensitiveButton extends React.PureComponent {\n\n  static propTypes = {\n    visible: PropTypes.bool,\n    active: PropTypes.bool,\n    disabled: PropTypes.bool,\n    onClick: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  render () {\n    const { visible, active, disabled, onClick, intl } = this.props;\n\n    return (\n      <Motion defaultStyle={{ scale: 0.87 }} style={{ scale: spring(visible ? 1 : 0.87, { stiffness: 200, damping: 3 }) }}>\n        {({ scale }) => {\n          const icon = active ? 'eye-slash' : 'eye';\n          const className = classNames('compose-form__sensitive-button', {\n            'compose-form__sensitive-button--visible': visible,\n          });\n          return (\n            <div className={className} style={{ transform: `scale(${scale})` }}>\n              <IconButton\n                className='compose-form__sensitive-button__icon'\n                title={intl.formatMessage(active ? messages.marked : messages.unmarked)}\n                icon={icon}\n                onClick={onClick}\n                size={18}\n                active={active}\n                disabled={disabled}\n                style={{ lineHeight: null, height: null }}\n                inverted\n              />\n            </div>\n          );\n        }}\n      </Motion>\n    );\n  }\n\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(injectIntl(SensitiveButton));\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/sensitive_button_container.js","import { connect } from 'react-redux';\nimport EmojiPickerDropdown from '../components/emoji_picker_dropdown';\nimport { changeSetting } from '../../../actions/settings';\nimport { createSelector } from 'reselect';\nimport { Map as ImmutableMap } from 'immutable';\nimport { useEmoji } from '../../../actions/emojis';\n\nconst perLine = 8;\nconst lines   = 2;\n\nconst DEFAULTS = [\n  '+1',\n  'grinning',\n  'kissing_heart',\n  'heart_eyes',\n  'laughing',\n  'stuck_out_tongue_winking_eye',\n  'sweat_smile',\n  'joy',\n  'yum',\n  'disappointed',\n  'thinking_face',\n  'weary',\n  'sob',\n  'sunglasses',\n  'heart',\n  'ok_hand',\n];\n\nconst getFrequentlyUsedEmojis = createSelector([\n  state => state.getIn(['settings', 'frequentlyUsedEmojis'], ImmutableMap()),\n], emojiCounters => {\n  let emojis = emojiCounters\n    .keySeq()\n    .sort((a, b) => emojiCounters.get(a) - emojiCounters.get(b))\n    .reverse()\n    .slice(0, perLine * lines)\n    .toArray();\n\n  if (emojis.length < DEFAULTS.length) {\n    emojis = emojis.concat(DEFAULTS.slice(0, DEFAULTS.length - emojis.length));\n  }\n\n  return emojis;\n});\n\nconst getCustomEmojis = createSelector([\n  state => state.get('custom_emojis'),\n], emojis => emojis.filter(e => e.get('visible_in_picker')).sort((a, b) => {\n  const aShort = a.get('shortcode').toLowerCase();\n  const bShort = b.get('shortcode').toLowerCase();\n\n  if (aShort < bShort) {\n    return -1;\n  } else if (aShort > bShort ) {\n    return 1;\n  } else {\n    return 0;\n  }\n}));\n\nconst mapStateToProps = state => ({\n  custom_emojis: getCustomEmojis(state),\n  skinTone: state.getIn(['settings', 'skinTone']),\n  frequentlyUsedEmojis: getFrequentlyUsedEmojis(state),\n});\n\nconst mapDispatchToProps = (dispatch, { onPickEmoji }) => ({\n  onSkinTone: skinTone => {\n    dispatch(changeSetting(['skinTone'], skinTone));\n  },\n\n  onPickEmoji: emoji => {\n    dispatch(useEmoji(emoji));\n\n    if (onPickEmoji) {\n      onPickEmoji(emoji);\n    }\n  },\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(EmojiPickerDropdown);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/emoji_picker_dropdown_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { defineMessages, injectIntl } from 'react-intl';\nimport { EmojiPicker as EmojiPickerAsync } from '../../ui/util/async-components';\nimport Overlay from 'react-overlays/lib/Overlay';\nimport classNames from 'classnames';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport detectPassiveEvents from 'detect-passive-events';\nimport { buildCustomEmojis } from '../../emoji/emoji';\n\nconst messages = defineMessages({\n  emoji: { id: 'emoji_button.label', defaultMessage: 'Insert emoji' },\n  emoji_search: { id: 'emoji_button.search', defaultMessage: 'Search...' },\n  emoji_not_found: { id: 'emoji_button.not_found', defaultMessage: 'No emojos!! (╯°□°)╯︵ ┻━┻' },\n  custom: { id: 'emoji_button.custom', defaultMessage: 'Custom' },\n  recent: { id: 'emoji_button.recent', defaultMessage: 'Frequently used' },\n  search_results: { id: 'emoji_button.search_results', defaultMessage: 'Search results' },\n  people: { id: 'emoji_button.people', defaultMessage: 'People' },\n  nature: { id: 'emoji_button.nature', defaultMessage: 'Nature' },\n  food: { id: 'emoji_button.food', defaultMessage: 'Food & Drink' },\n  activity: { id: 'emoji_button.activity', defaultMessage: 'Activity' },\n  travel: { id: 'emoji_button.travel', defaultMessage: 'Travel & Places' },\n  objects: { id: 'emoji_button.objects', defaultMessage: 'Objects' },\n  symbols: { id: 'emoji_button.symbols', defaultMessage: 'Symbols' },\n  flags: { id: 'emoji_button.flags', defaultMessage: 'Flags' },\n});\n\nconst assetHost = process.env.CDN_HOST || '';\nlet EmojiPicker, Emoji; // load asynchronously\n\nconst backgroundImageFn = () => `${assetHost}/emoji/sheet.png`;\nconst listenerOptions = detectPassiveEvents.hasSupport ? { passive: true } : false;\n\nconst categoriesSort = [\n  'recent',\n  'custom',\n  'people',\n  'nature',\n  'foods',\n  'activity',\n  'places',\n  'objects',\n  'symbols',\n  'flags',\n];\n\nclass ModifierPickerMenu extends React.PureComponent {\n\n  static propTypes = {\n    active: PropTypes.bool,\n    onSelect: PropTypes.func.isRequired,\n    onClose: PropTypes.func.isRequired,\n  };\n\n  handleClick = e => {\n    this.props.onSelect(e.currentTarget.getAttribute('data-index') * 1);\n  }\n\n  componentWillReceiveProps (nextProps) {\n    if (nextProps.active) {\n      this.attachListeners();\n    } else {\n      this.removeListeners();\n    }\n  }\n\n  componentWillUnmount () {\n    this.removeListeners();\n  }\n\n  handleDocumentClick = e => {\n    if (this.node && !this.node.contains(e.target)) {\n      this.props.onClose();\n    }\n  }\n\n  attachListeners () {\n    document.addEventListener('click', this.handleDocumentClick, false);\n    document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  }\n\n  removeListeners () {\n    document.removeEventListener('click', this.handleDocumentClick, false);\n    document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  }\n\n  setRef = c => {\n    this.node = c;\n  }\n\n  render () {\n    const { active } = this.props;\n\n    return (\n      <div className='emoji-picker-dropdown__modifiers__menu' style={{ display: active ? 'block' : 'none' }} ref={this.setRef}>\n        <button onClick={this.handleClick} data-index={1}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={1} backgroundImageFn={backgroundImageFn} /></button>\n        <button onClick={this.handleClick} data-index={2}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={2} backgroundImageFn={backgroundImageFn} /></button>\n        <button onClick={this.handleClick} data-index={3}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={3} backgroundImageFn={backgroundImageFn} /></button>\n        <button onClick={this.handleClick} data-index={4}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={4} backgroundImageFn={backgroundImageFn} /></button>\n        <button onClick={this.handleClick} data-index={5}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={5} backgroundImageFn={backgroundImageFn} /></button>\n        <button onClick={this.handleClick} data-index={6}><Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={6} backgroundImageFn={backgroundImageFn} /></button>\n      </div>\n    );\n  }\n\n}\n\nclass ModifierPicker extends React.PureComponent {\n\n  static propTypes = {\n    active: PropTypes.bool,\n    modifier: PropTypes.number,\n    onChange: PropTypes.func,\n    onClose: PropTypes.func,\n    onOpen: PropTypes.func,\n  };\n\n  handleClick = () => {\n    if (this.props.active) {\n      this.props.onClose();\n    } else {\n      this.props.onOpen();\n    }\n  }\n\n  handleSelect = modifier => {\n    this.props.onChange(modifier);\n    this.props.onClose();\n  }\n\n  render () {\n    const { active, modifier } = this.props;\n\n    return (\n      <div className='emoji-picker-dropdown__modifiers'>\n        <Emoji emoji='fist' set='twitter' size={22} sheetSize={32} skin={modifier} onClick={this.handleClick} backgroundImageFn={backgroundImageFn} />\n        <ModifierPickerMenu active={active} onSelect={this.handleSelect} onClose={this.props.onClose} />\n      </div>\n    );\n  }\n\n}\n\n@injectIntl\nclass EmojiPickerMenu extends React.PureComponent {\n\n  static propTypes = {\n    custom_emojis: ImmutablePropTypes.list,\n    frequentlyUsedEmojis: PropTypes.arrayOf(PropTypes.string),\n    loading: PropTypes.bool,\n    onClose: PropTypes.func.isRequired,\n    onPick: PropTypes.func.isRequired,\n    style: PropTypes.object,\n    placement: PropTypes.string,\n    arrowOffsetLeft: PropTypes.string,\n    arrowOffsetTop: PropTypes.string,\n    intl: PropTypes.object.isRequired,\n    skinTone: PropTypes.number.isRequired,\n    onSkinTone: PropTypes.func.isRequired,\n  };\n\n  static defaultProps = {\n    style: {},\n    loading: true,\n    placement: 'bottom',\n    frequentlyUsedEmojis: [],\n  };\n\n  state = {\n    modifierOpen: false,\n  };\n\n  handleDocumentClick = e => {\n    if (this.node && !this.node.contains(e.target)) {\n      this.props.onClose();\n    }\n  }\n\n  componentDidMount () {\n    document.addEventListener('click', this.handleDocumentClick, false);\n    document.addEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  }\n\n  componentWillUnmount () {\n    document.removeEventListener('click', this.handleDocumentClick, false);\n    document.removeEventListener('touchend', this.handleDocumentClick, listenerOptions);\n  }\n\n  setRef = c => {\n    this.node = c;\n  }\n\n  getI18n = () => {\n    const { intl } = this.props;\n\n    return {\n      search: intl.formatMessage(messages.emoji_search),\n      notfound: intl.formatMessage(messages.emoji_not_found),\n      categories: {\n        search: intl.formatMessage(messages.search_results),\n        recent: intl.formatMessage(messages.recent),\n        people: intl.formatMessage(messages.people),\n        nature: intl.formatMessage(messages.nature),\n        foods: intl.formatMessage(messages.food),\n        activity: intl.formatMessage(messages.activity),\n        places: intl.formatMessage(messages.travel),\n        objects: intl.formatMessage(messages.objects),\n        symbols: intl.formatMessage(messages.symbols),\n        flags: intl.formatMessage(messages.flags),\n        custom: intl.formatMessage(messages.custom),\n      },\n    };\n  }\n\n  handleClick = emoji => {\n    if (!emoji.native) {\n      emoji.native = emoji.colons;\n    }\n\n    this.props.onClose();\n    this.props.onPick(emoji);\n  }\n\n  handleModifierOpen = () => {\n    this.setState({ modifierOpen: true });\n  }\n\n  handleModifierClose = () => {\n    this.setState({ modifierOpen: false });\n  }\n\n  handleModifierChange = modifier => {\n    this.props.onSkinTone(modifier);\n  }\n\n  render () {\n    const { loading, style, intl, custom_emojis, skinTone, frequentlyUsedEmojis } = this.props;\n\n    if (loading) {\n      return <div style={{ width: 299 }} />;\n    }\n\n    const title = intl.formatMessage(messages.emoji);\n    const { modifierOpen } = this.state;\n\n    return (\n      <div className={classNames('emoji-picker-dropdown__menu', { selecting: modifierOpen })} style={style} ref={this.setRef}>\n        <EmojiPicker\n          perLine={8}\n          emojiSize={22}\n          sheetSize={32}\n          custom={buildCustomEmojis(custom_emojis)}\n          color=''\n          emoji=''\n          set='twitter'\n          title={title}\n          i18n={this.getI18n()}\n          onClick={this.handleClick}\n          include={categoriesSort}\n          recent={frequentlyUsedEmojis}\n          skin={skinTone}\n          showPreview={false}\n          backgroundImageFn={backgroundImageFn}\n          emojiTooltip\n        />\n\n        <ModifierPicker\n          active={modifierOpen}\n          modifier={skinTone}\n          onOpen={this.handleModifierOpen}\n          onClose={this.handleModifierClose}\n          onChange={this.handleModifierChange}\n        />\n      </div>\n    );\n  }\n\n}\n\n@injectIntl\nexport default class EmojiPickerDropdown extends React.PureComponent {\n\n  static propTypes = {\n    custom_emojis: ImmutablePropTypes.list,\n    frequentlyUsedEmojis: PropTypes.arrayOf(PropTypes.string),\n    intl: PropTypes.object.isRequired,\n    onPickEmoji: PropTypes.func.isRequired,\n    onSkinTone: PropTypes.func.isRequired,\n    skinTone: PropTypes.number.isRequired,\n  };\n\n  state = {\n    active: false,\n    loading: false,\n  };\n\n  setRef = (c) => {\n    this.dropdown = c;\n  }\n\n  onShowDropdown = () => {\n    this.setState({ active: true });\n\n    if (!EmojiPicker) {\n      this.setState({ loading: true });\n\n      EmojiPickerAsync().then(EmojiMart => {\n        EmojiPicker = EmojiMart.Picker;\n        Emoji       = EmojiMart.Emoji;\n\n        this.setState({ loading: false });\n      }).catch(() => {\n        this.setState({ loading: false });\n      });\n    }\n  }\n\n  onHideDropdown = () => {\n    this.setState({ active: false });\n  }\n\n  onToggle = (e) => {\n    if (!this.state.loading && (!e.key || e.key === 'Enter')) {\n      if (this.state.active) {\n        this.onHideDropdown();\n      } else {\n        this.onShowDropdown();\n      }\n    }\n  }\n\n  handleKeyDown = e => {\n    if (e.key === 'Escape') {\n      this.onHideDropdown();\n    }\n  }\n\n  setTargetRef = c => {\n    this.target = c;\n  }\n\n  findTarget = () => {\n    return this.target;\n  }\n\n  render () {\n    const { intl, onPickEmoji, onSkinTone, skinTone, frequentlyUsedEmojis } = this.props;\n    const title = intl.formatMessage(messages.emoji);\n    const { active, loading } = this.state;\n\n    return (\n      <div className='emoji-picker-dropdown' onKeyDown={this.handleKeyDown}>\n        <div ref={this.setTargetRef} className='emoji-button' title={title} aria-label={title} aria-expanded={active} role='button' onClick={this.onToggle} onKeyDown={this.onToggle} tabIndex={0}>\n          <img\n            className={classNames('emojione', { 'pulse-loading': active && loading })}\n            alt='🙂'\n            src={`${assetHost}/emoji/1f602.svg`}\n          />\n        </div>\n\n        <Overlay show={active} placement='bottom' target={this.findTarget}>\n          <EmojiPickerMenu\n            custom_emojis={this.props.custom_emojis}\n            loading={loading}\n            onClose={this.onHideDropdown}\n            onPick={onPickEmoji}\n            onSkinTone={onSkinTone}\n            skinTone={skinTone}\n            frequentlyUsedEmojis={frequentlyUsedEmojis}\n          />\n        </Overlay>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/emoji_picker_dropdown.js","import { connect } from 'react-redux';\nimport UploadForm from '../components/upload_form';\n\nconst mapStateToProps = state => ({\n  mediaIds: state.getIn(['compose', 'media_attachments']).map(item => item.get('id')),\n});\n\nexport default connect(mapStateToProps)(UploadForm);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/upload_form_container.js","import React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport UploadProgressContainer from '../containers/upload_progress_container';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport UploadContainer from '../containers/upload_container';\n\nexport default class UploadForm extends ImmutablePureComponent {\n\n  static propTypes = {\n    mediaIds: ImmutablePropTypes.list.isRequired,\n  };\n\n  render () {\n    const { mediaIds } = this.props;\n\n    return (\n      <div className='compose-form__upload-wrapper'>\n        <UploadProgressContainer />\n\n        <div className='compose-form__uploads-wrapper'>\n          {mediaIds.map(id => (\n            <UploadContainer id={id} key={id} />\n          ))}\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/upload_form.js","import { connect } from 'react-redux';\nimport UploadProgress from '../components/upload_progress';\n\nconst mapStateToProps = state => ({\n  active: state.getIn(['compose', 'is_uploading']),\n  progress: state.getIn(['compose', 'progress']),\n});\n\nexport default connect(mapStateToProps)(UploadProgress);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/upload_progress_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport Motion from '../../ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\nimport { FormattedMessage } from 'react-intl';\n\nexport default class UploadProgress extends React.PureComponent {\n\n  static propTypes = {\n    active: PropTypes.bool,\n    progress: PropTypes.number,\n  };\n\n  render () {\n    const { active, progress } = this.props;\n\n    if (!active) {\n      return null;\n    }\n\n    return (\n      <div className='upload-progress'>\n        <div className='upload-progress__icon'>\n          <i className='fa fa-upload' />\n        </div>\n\n        <div className='upload-progress__message'>\n          <FormattedMessage id='upload_progress.label' defaultMessage='Uploading...' />\n\n          <div className='upload-progress__backdrop'>\n            <Motion defaultStyle={{ width: 0 }} style={{ width: spring(progress) }}>\n              {({ width }) =>\n                <div className='upload-progress__tracker' style={{ width: `${width}%` }} />\n              }\n            </Motion>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/upload_progress.js","import { connect } from 'react-redux';\nimport Upload from '../components/upload';\nimport { undoUploadCompose, changeUploadCompose } from '../../../actions/compose';\nimport { openModal } from '../../../actions/modal';\n\nconst mapStateToProps = (state, { id }) => ({\n  media: state.getIn(['compose', 'media_attachments']).find(item => item.get('id') === id),\n});\n\nconst mapDispatchToProps = dispatch => ({\n\n  onUndo: id => {\n    dispatch(undoUploadCompose(id));\n  },\n\n  onDescriptionChange: (id, description) => {\n    dispatch(changeUploadCompose(id, { description }));\n  },\n\n  onOpenFocalPoint: id => {\n    dispatch(openModal('FOCAL_POINT', { id }));\n  },\n\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Upload);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/upload_container.js","import React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport PropTypes from 'prop-types';\nimport Motion from '../../ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport classNames from 'classnames';\n\nconst messages = defineMessages({\n  description: { id: 'upload_form.description', defaultMessage: 'Describe for the visually impaired' },\n});\n\n@injectIntl\nexport default class Upload extends ImmutablePureComponent {\n\n  static propTypes = {\n    media: ImmutablePropTypes.map.isRequired,\n    intl: PropTypes.object.isRequired,\n    onUndo: PropTypes.func.isRequired,\n    onDescriptionChange: PropTypes.func.isRequired,\n    onOpenFocalPoint: PropTypes.func.isRequired,\n  };\n\n  state = {\n    hovered: false,\n    focused: false,\n    dirtyDescription: null,\n  };\n\n  handleUndoClick = () => {\n    this.props.onUndo(this.props.media.get('id'));\n  }\n\n  handleFocalPointClick = () => {\n    this.props.onOpenFocalPoint(this.props.media.get('id'));\n  }\n\n  handleInputChange = e => {\n    this.setState({ dirtyDescription: e.target.value });\n  }\n\n  handleMouseEnter = () => {\n    this.setState({ hovered: true });\n  }\n\n  handleMouseLeave = () => {\n    this.setState({ hovered: false });\n  }\n\n  handleInputFocus = () => {\n    this.setState({ focused: true });\n  }\n\n  handleInputBlur = () => {\n    const { dirtyDescription } = this.state;\n\n    this.setState({ focused: false, dirtyDescription: null });\n\n    if (dirtyDescription !== null) {\n      this.props.onDescriptionChange(this.props.media.get('id'), dirtyDescription);\n    }\n  }\n\n  render () {\n    const { intl, media } = this.props;\n    const active          = this.state.hovered || this.state.focused;\n    const description     = this.state.dirtyDescription || (this.state.dirtyDescription !== '' && media.get('description')) || '';\n    const focusX = media.getIn(['meta', 'focus', 'x']);\n    const focusY = media.getIn(['meta', 'focus', 'y']);\n    const x = ((focusX /  2) + .5) * 100;\n    const y = ((focusY / -2) + .5) * 100;\n\n    return (\n      <div className='compose-form__upload' onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave}>\n        <Motion defaultStyle={{ scale: 0.8 }} style={{ scale: spring(1, { stiffness: 180, damping: 12 }) }}>\n          {({ scale }) => (\n            <div className='compose-form__upload-thumbnail' style={{ transform: `scale(${scale})`, backgroundImage: `url(${media.get('preview_url')})`, backgroundPosition: `${x}% ${y}%` }}>\n              <div className={classNames('compose-form__upload__actions', { active })}>\n                <button className='icon-button' onClick={this.handleUndoClick}><i className='fa fa-times' /> <FormattedMessage id='upload_form.undo' defaultMessage='Undo' /></button>\n                {media.get('type') === 'image' && <button className='icon-button' onClick={this.handleFocalPointClick}><i className='fa fa-crosshairs' /> <FormattedMessage id='upload_form.focus' defaultMessage='Crop' /></button>}\n              </div>\n\n              <div className={classNames('compose-form__upload-description', { active })}>\n                <label>\n                  <span style={{ display: 'none' }}>{intl.formatMessage(messages.description)}</span>\n\n                  <input\n                    placeholder={intl.formatMessage(messages.description)}\n                    type='text'\n                    value={description}\n                    maxLength={420}\n                    onFocus={this.handleInputFocus}\n                    onChange={this.handleInputChange}\n                    onBlur={this.handleInputBlur}\n                  />\n                </label>\n              </div>\n            </div>\n          )}\n        </Motion>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/upload.js","import React from 'react';\nimport { connect } from 'react-redux';\nimport Warning from '../components/warning';\nimport PropTypes from 'prop-types';\nimport { FormattedMessage } from 'react-intl';\nimport { me } from '../../../initial_state';\n\nconst APPROX_HASHTAG_RE = /(?:^|[^\\/\\)\\w])#(\\w*[a-zA-Z·]\\w*)/i;\n\nconst mapStateToProps = state => ({\n  needsLockWarning: state.getIn(['compose', 'privacy']) === 'private' && !state.getIn(['accounts', me, 'locked']),\n  hashtagWarning: state.getIn(['compose', 'privacy']) !== 'public' && APPROX_HASHTAG_RE.test(state.getIn(['compose', 'text'])),\n  directMessageWarning: state.getIn(['compose', 'privacy']) === 'direct',\n});\n\nconst WarningWrapper = ({ needsLockWarning, hashtagWarning, directMessageWarning }) => {\n  if (needsLockWarning) {\n    return <Warning message={<FormattedMessage id='compose_form.lock_disclaimer' defaultMessage='Your account is not {locked}. Anyone can follow you to view your follower-only posts.' values={{ locked: <a href='/settings/profile'><FormattedMessage id='compose_form.lock_disclaimer.lock' defaultMessage='locked' /></a> }} />} />;\n  }\n  if (hashtagWarning) {\n    return <Warning message={<FormattedMessage id='compose_form.hashtag_warning' defaultMessage=\"This toot won't be listed under any hashtag as it is unlisted. Only public toots can be searched by hashtag.\" />} />;\n  }\n  if (directMessageWarning) {\n    return <Warning message={<FormattedMessage id='compose_form.direct_message_warning' defaultMessage='This toot will only be visible to all the mentioned users.' />} />;\n  }\n\n  return null;\n};\n\nWarningWrapper.propTypes = {\n  needsLockWarning: PropTypes.bool,\n  hashtagWarning: PropTypes.bool,\n  directMessageWarning: PropTypes.bool,\n};\n\nexport default connect(mapStateToProps)(WarningWrapper);\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/containers/warning_container.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport Motion from '../../ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\n\nexport default class Warning extends React.PureComponent {\n\n  static propTypes = {\n    message: PropTypes.node.isRequired,\n  };\n\n  render () {\n    const { message } = this.props;\n\n    return (\n      <Motion defaultStyle={{ opacity: 0, scaleX: 0.85, scaleY: 0.75 }} style={{ opacity: spring(1, { damping: 35, stiffness: 400 }), scaleX: spring(1, { damping: 35, stiffness: 400 }), scaleY: spring(1, { damping: 35, stiffness: 400 }) }}>\n        {({ opacity, scaleX, scaleY }) => (\n          <div className='compose-form__warning' style={{ opacity: opacity, transform: `scale(${scaleX}, ${scaleY})` }}>\n            {message}\n          </div>\n        )}\n      </Motion>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/warning.js","import { urlRegex } from './url_regex';\n\nconst urlPlaceholder = 'xxxxxxxxxxxxxxxxxxxxxxx';\n\nexport function countableText(inputText) {\n  return inputText\n    .replace(urlRegex, urlPlaceholder)\n    .replace(/(^|[^\\/\\w])@(([a-z0-9_]+)@[a-z0-9\\.\\-]+[a-z0-9]+)/ig, '$1@$3');\n};\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/util/counter.js","const regexen = {};\n\nconst regexSupplant = function(regex, flags) {\n  flags = flags || '';\n  if (typeof regex !== 'string') {\n    if (regex.global && flags.indexOf('g') < 0) {\n      flags += 'g';\n    }\n    if (regex.ignoreCase && flags.indexOf('i') < 0) {\n      flags += 'i';\n    }\n    if (regex.multiline && flags.indexOf('m') < 0) {\n      flags += 'm';\n    }\n\n    regex = regex.source;\n  }\n  return new RegExp(regex.replace(/#\\{(\\w+)\\}/g, function(match, name) {\n    var newRegex = regexen[name] || '';\n    if (typeof newRegex !== 'string') {\n      newRegex = newRegex.source;\n    }\n    return newRegex;\n  }), flags);\n};\n\nconst stringSupplant = function(str, values) {\n  return str.replace(/#\\{(\\w+)\\}/g, function(match, name) {\n    return values[name] || '';\n  });\n};\n\nexport const urlRegex = (function() {\n  regexen.spaces_group = /\\x09-\\x0D\\x20\\x85\\xA0\\u1680\\u180E\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000/;\n  regexen.invalid_chars_group = /\\uFFFE\\uFEFF\\uFFFF\\u202A-\\u202E/;\n  regexen.punct = /\\!'#%&'\\(\\)*\\+,\\\\\\-\\.\\/:;<=>\\?@\\[\\]\\^_{|}~\\$/;\n  regexen.validUrlPrecedingChars = regexSupplant(/(?:[^A-Za-z0-9@@$###{invalid_chars_group}]|^)/);\n  regexen.invalidDomainChars = stringSupplant('#{punct}#{spaces_group}#{invalid_chars_group}', regexen);\n  regexen.validDomainChars = regexSupplant(/[^#{invalidDomainChars}]/);\n  regexen.validSubdomain = regexSupplant(/(?:(?:#{validDomainChars}(?:[_-]|#{validDomainChars})*)?#{validDomainChars}\\.)/);\n  regexen.validDomainName = regexSupplant(/(?:(?:#{validDomainChars}(?:-|#{validDomainChars})*)?#{validDomainChars}\\.)/);\n  regexen.validGTLD = regexSupplant(RegExp(\n    '(?:(?:' +\n      '삼성|닷컴|닷넷|香格里拉|餐厅|食品|飞利浦|電訊盈科|集团|通販|购物|谷歌|诺基亚|联通|网络|网站|网店|网址|组织机构|移动|珠宝|点看|游戏|淡马锡|机构|書籍|时尚|新闻|政府|' +\n      '政务|手表|手机|我爱你|慈善|微博|广东|工行|家電|娱乐|天主教|大拿|大众汽车|在线|嘉里大酒店|嘉里|商标|商店|商城|公益|公司|八卦|健康|信息|佛山|企业|中文网|中信|世界|' +\n      'ポイント|ファッション|セール|ストア|コム|グーグル|クラウド|みんな|คอม|संगठन|नेट|कॉम|همراه|موقع|موبايلي|كوم|كاثوليك|عرب|شبكة|' +\n      'بيتك|بازار|العليان|ارامكو|اتصالات|ابوظبي|קום|сайт|рус|орг|онлайн|москва|ком|католик|дети|' +\n      'zuerich|zone|zippo|zip|zero|zara|zappos|yun|youtube|you|yokohama|yoga|yodobashi|yandex|yamaxun|' +\n      'yahoo|yachts|xyz|xxx|xperia|xin|xihuan|xfinity|xerox|xbox|wtf|wtc|wow|world|works|work|woodside|' +\n      'wolterskluwer|wme|winners|wine|windows|win|williamhill|wiki|wien|whoswho|weir|weibo|wedding|wed|' +\n      'website|weber|webcam|weatherchannel|weather|watches|watch|warman|wanggou|wang|walter|walmart|' +\n      'wales|vuelos|voyage|voto|voting|vote|volvo|volkswagen|vodka|vlaanderen|vivo|viva|vistaprint|' +\n      'vista|vision|visa|virgin|vip|vin|villas|viking|vig|video|viajes|vet|versicherung|' +\n      'vermögensberatung|vermögensberater|verisign|ventures|vegas|vanguard|vana|vacations|ups|uol|uno|' +\n      'university|unicom|uconnect|ubs|ubank|tvs|tushu|tunes|tui|tube|trv|trust|travelersinsurance|' +\n      'travelers|travelchannel|travel|training|trading|trade|toys|toyota|town|tours|total|toshiba|' +\n      'toray|top|tools|tokyo|today|tmall|tkmaxx|tjx|tjmaxx|tirol|tires|tips|tiffany|tienda|tickets|' +\n      'tiaa|theatre|theater|thd|teva|tennis|temasek|telefonica|telecity|tel|technology|tech|team|tdk|' +\n      'tci|taxi|tax|tattoo|tatar|tatamotors|target|taobao|talk|taipei|tab|systems|symantec|sydney|' +\n      'swiss|swiftcover|swatch|suzuki|surgery|surf|support|supply|supplies|sucks|style|study|studio|' +\n      'stream|store|storage|stockholm|stcgroup|stc|statoil|statefarm|statebank|starhub|star|staples|' +\n      'stada|srt|srl|spreadbetting|spot|spiegel|space|soy|sony|song|solutions|solar|sohu|software|' +\n      'softbank|social|soccer|sncf|smile|smart|sling|skype|sky|skin|ski|site|singles|sina|silk|shriram|' +\n      'showtime|show|shouji|shopping|shop|shoes|shiksha|shia|shell|shaw|sharp|shangrila|sfr|sexy|sex|' +\n      'sew|seven|ses|services|sener|select|seek|security|secure|seat|search|scot|scor|scjohnson|' +\n      'science|schwarz|schule|school|scholarships|schmidt|schaeffler|scb|sca|sbs|sbi|saxo|save|sas|' +\n      'sarl|sapo|sap|sanofi|sandvikcoromant|sandvik|samsung|samsclub|salon|sale|sakura|safety|safe|' +\n      'saarland|ryukyu|rwe|run|ruhr|rugby|rsvp|room|rogers|rodeo|rocks|rocher|rmit|rip|rio|ril|' +\n      'rightathome|ricoh|richardli|rich|rexroth|reviews|review|restaurant|rest|republican|report|' +\n      'repair|rentals|rent|ren|reliance|reit|reisen|reise|rehab|redumbrella|redstone|red|recipes|' +\n      'realty|realtor|realestate|read|raid|radio|racing|qvc|quest|quebec|qpon|pwc|pub|prudential|pru|' +\n      'protection|property|properties|promo|progressive|prof|productions|prod|pro|prime|press|praxi|' +\n      'pramerica|post|porn|politie|poker|pohl|pnc|plus|plumbing|playstation|play|place|pizza|pioneer|' +\n      'pink|ping|pin|pid|pictures|pictet|pics|piaget|physio|photos|photography|photo|phone|philips|phd|' +\n      'pharmacy|pfizer|pet|pccw|pay|passagens|party|parts|partners|pars|paris|panerai|panasonic|' +\n      'pamperedchef|page|ovh|ott|otsuka|osaka|origins|orientexpress|organic|org|orange|oracle|open|ooo|' +\n      'onyourside|online|onl|ong|one|omega|ollo|oldnavy|olayangroup|olayan|okinawa|office|off|observer|' +\n      'obi|nyc|ntt|nrw|nra|nowtv|nowruz|now|norton|northwesternmutual|nokia|nissay|nissan|ninja|nikon|' +\n      'nike|nico|nhk|ngo|nfl|nexus|nextdirect|next|news|newholland|new|neustar|network|netflix|netbank|' +\n      'net|nec|nba|navy|natura|nationwide|name|nagoya|nadex|nab|mutuelle|mutual|museum|mtr|mtpc|mtn|' +\n      'msd|movistar|movie|mov|motorcycles|moto|moscow|mortgage|mormon|mopar|montblanc|monster|money|' +\n      'monash|mom|moi|moe|moda|mobily|mobile|mobi|mma|mls|mlb|mitsubishi|mit|mint|mini|mil|microsoft|' +\n      'miami|metlife|merckmsd|meo|menu|men|memorial|meme|melbourne|meet|media|med|mckinsey|mcdonalds|' +\n      'mcd|mba|mattel|maserati|marshalls|marriott|markets|marketing|market|map|mango|management|man|' +\n      'makeup|maison|maif|madrid|macys|luxury|luxe|lupin|lundbeck|ltda|ltd|lplfinancial|lpl|love|lotto|' +\n      'lotte|london|lol|loft|locus|locker|loans|loan|lixil|living|live|lipsy|link|linde|lincoln|limo|' +\n      'limited|lilly|like|lighting|lifestyle|lifeinsurance|life|lidl|liaison|lgbt|lexus|lego|legal|' +\n      'lefrak|leclerc|lease|lds|lawyer|law|latrobe|latino|lat|lasalle|lanxess|landrover|land|lancome|' +\n      'lancia|lancaster|lamer|lamborghini|ladbrokes|lacaixa|kyoto|kuokgroup|kred|krd|kpn|kpmg|kosher|' +\n      'komatsu|koeln|kiwi|kitchen|kindle|kinder|kim|kia|kfh|kerryproperties|kerrylogistics|kerryhotels|' +\n      'kddi|kaufen|juniper|juegos|jprs|jpmorgan|joy|jot|joburg|jobs|jnj|jmp|jll|jlc|jio|jewelry|jetzt|' +\n      'jeep|jcp|jcb|java|jaguar|iwc|iveco|itv|itau|istanbul|ist|ismaili|iselect|irish|ipiranga|' +\n      'investments|intuit|international|intel|int|insure|insurance|institute|ink|ing|info|infiniti|' +\n      'industries|immobilien|immo|imdb|imamat|ikano|iinet|ifm|ieee|icu|ice|icbc|ibm|hyundai|hyatt|' +\n      'hughes|htc|hsbc|how|house|hotmail|hotels|hoteles|hot|hosting|host|hospital|horse|honeywell|' +\n      'honda|homesense|homes|homegoods|homedepot|holiday|holdings|hockey|hkt|hiv|hitachi|hisamitsu|' +\n      'hiphop|hgtv|hermes|here|helsinki|help|healthcare|health|hdfcbank|hdfc|hbo|haus|hangout|hamburg|' +\n      'hair|guru|guitars|guide|guge|gucci|guardian|group|grocery|gripe|green|gratis|graphics|grainger|' +\n      'gov|got|gop|google|goog|goodyear|goodhands|goo|golf|goldpoint|gold|godaddy|gmx|gmo|gmbh|gmail|' +\n      'globo|global|gle|glass|glade|giving|gives|gifts|gift|ggee|george|genting|gent|gea|gdn|gbiz|' +\n      'garden|gap|games|game|gallup|gallo|gallery|gal|fyi|futbol|furniture|fund|fun|fujixerox|fujitsu|' +\n      'ftr|frontier|frontdoor|frogans|frl|fresenius|free|fox|foundation|forum|forsale|forex|ford|' +\n      'football|foodnetwork|food|foo|fly|flsmidth|flowers|florist|flir|flights|flickr|fitness|fit|' +\n      'fishing|fish|firmdale|firestone|fire|financial|finance|final|film|fido|fidelity|fiat|ferrero|' +\n      'ferrari|feedback|fedex|fast|fashion|farmers|farm|fans|fan|family|faith|fairwinds|fail|fage|' +\n      'extraspace|express|exposed|expert|exchange|everbank|events|eus|eurovision|etisalat|esurance|' +\n      'estate|esq|erni|ericsson|equipment|epson|epost|enterprises|engineering|engineer|energy|emerck|' +\n      'email|education|edu|edeka|eco|eat|earth|dvr|dvag|durban|dupont|duns|dunlop|duck|dubai|dtv|drive|' +\n      'download|dot|doosan|domains|doha|dog|dodge|doctor|docs|dnp|diy|dish|discover|discount|directory|' +\n      'direct|digital|diet|diamonds|dhl|dev|design|desi|dentist|dental|democrat|delta|deloitte|dell|' +\n      'delivery|degree|deals|dealer|deal|dds|dclk|day|datsun|dating|date|data|dance|dad|dabur|cyou|' +\n      'cymru|cuisinella|csc|cruises|cruise|crs|crown|cricket|creditunion|creditcard|credit|courses|' +\n      'coupons|coupon|country|corsica|coop|cool|cookingchannel|cooking|contractors|contact|consulting|' +\n      'construction|condos|comsec|computer|compare|company|community|commbank|comcast|com|cologne|' +\n      'college|coffee|codes|coach|clubmed|club|cloud|clothing|clinique|clinic|click|cleaning|claims|' +\n      'cityeats|city|citic|citi|citadel|cisco|circle|cipriani|church|chrysler|chrome|christmas|chloe|' +\n      'chintai|cheap|chat|chase|channel|chanel|cfd|cfa|cern|ceo|center|ceb|cbs|cbre|cbn|cba|catholic|' +\n      'catering|cat|casino|cash|caseih|case|casa|cartier|cars|careers|career|care|cards|caravan|car|' +\n      'capitalone|capital|capetown|canon|cancerresearch|camp|camera|cam|calvinklein|call|cal|cafe|cab|' +\n      'bzh|buzz|buy|business|builders|build|bugatti|budapest|brussels|brother|broker|broadway|' +\n      'bridgestone|bradesco|box|boutique|bot|boston|bostik|bosch|boots|booking|book|boo|bond|bom|bofa|' +\n      'boehringer|boats|bnpparibas|bnl|bmw|bms|blue|bloomberg|blog|blockbuster|blanco|blackfriday|' +\n      'black|biz|bio|bingo|bing|bike|bid|bible|bharti|bet|bestbuy|best|berlin|bentley|beer|beauty|' +\n      'beats|bcn|bcg|bbva|bbt|bbc|bayern|bauhaus|basketball|baseball|bargains|barefoot|barclays|' +\n      'barclaycard|barcelona|bar|bank|band|bananarepublic|banamex|baidu|baby|azure|axa|aws|avianca|' +\n      'autos|auto|author|auspost|audio|audible|audi|auction|attorney|athleta|associates|asia|asda|arte|' +\n      'art|arpa|army|archi|aramco|arab|aquarelle|apple|app|apartments|aol|anz|anquan|android|analytics|' +\n      'amsterdam|amica|amfam|amex|americanfamily|americanexpress|alstom|alsace|ally|allstate|allfinanz|' +\n      'alipay|alibaba|alfaromeo|akdn|airtel|airforce|airbus|aigo|aig|agency|agakhan|africa|afl|' +\n      'afamilycompany|aetna|aero|aeg|adult|ads|adac|actor|active|aco|accountants|accountant|accenture|' +\n      'academy|abudhabi|abogado|able|abc|abbvie|abbott|abb|abarth|aarp|aaa|onion' +\n    ')(?=[^0-9a-zA-Z@]|$))'));\n  regexen.validCCTLD = regexSupplant(RegExp(\n    '(?:(?:' +\n      '한국|香港|澳門|新加坡|台灣|台湾|中國|中国|გე|ไทย|ලංකා|ഭാരതം|ಭಾರತ|భారత్|சிங்கப்பூர்|இலங்கை|இந்தியா|ଭାରତ|ભારત|ਭਾਰਤ|' +\n      'ভাৰত|ভারত|বাংলা|भारोत|भारतम्|भारत|ڀارت|پاکستان|مليسيا|مصر|قطر|فلسطين|عمان|عراق|سورية|سودان|تونس|' +\n      'بھارت|بارت|ایران|امارات|المغرب|السعودية|الجزائر|الاردن|հայ|қаз|укр|срб|рф|мон|мкд|ею|бел|бг|ελ|' +\n      'zw|zm|za|yt|ye|ws|wf|vu|vn|vi|vg|ve|vc|va|uz|uy|us|um|uk|ug|ua|tz|tw|tv|tt|tr|tp|to|tn|tm|tl|tk|' +\n      'tj|th|tg|tf|td|tc|sz|sy|sx|sv|su|st|ss|sr|so|sn|sm|sl|sk|sj|si|sh|sg|se|sd|sc|sb|sa|rw|ru|rs|ro|' +\n      're|qa|py|pw|pt|ps|pr|pn|pm|pl|pk|ph|pg|pf|pe|pa|om|nz|nu|nr|np|no|nl|ni|ng|nf|ne|nc|na|mz|my|mx|' +\n      'mw|mv|mu|mt|ms|mr|mq|mp|mo|mn|mm|ml|mk|mh|mg|mf|me|md|mc|ma|ly|lv|lu|lt|ls|lr|lk|li|lc|lb|la|kz|' +\n      'ky|kw|kr|kp|kn|km|ki|kh|kg|ke|jp|jo|jm|je|it|is|ir|iq|io|in|im|il|ie|id|hu|ht|hr|hn|hm|hk|gy|gw|' +\n      'gu|gt|gs|gr|gq|gp|gn|gm|gl|gi|gh|gg|gf|ge|gd|gb|ga|fr|fo|fm|fk|fj|fi|eu|et|es|er|eh|eg|ee|ec|dz|' +\n      'do|dm|dk|dj|de|cz|cy|cx|cw|cv|cu|cr|co|cn|cm|cl|ck|ci|ch|cg|cf|cd|cc|ca|bz|by|bw|bv|bt|bs|br|bq|' +\n      'bo|bn|bm|bl|bj|bi|bh|bg|bf|be|bd|bb|ba|az|ax|aw|au|at|as|ar|aq|ao|an|am|al|ai|ag|af|ae|ad|ac' +\n    ')(?=[^0-9a-zA-Z@]|$))'));\n  regexen.validPunycode = /(?:xn--[0-9a-z]+)/;\n  regexen.validSpecialCCTLD = /(?:(?:co|tv)(?=[^0-9a-zA-Z@]|$))/;\n  regexen.validDomain = regexSupplant(/(?:#{validSubdomain}*#{validDomainName}(?:#{validGTLD}|#{validCCTLD}|#{validPunycode}))/);\n  regexen.validPortNumber = /[0-9]+/;\n  regexen.pd = /\\u002d\\u058a\\u05be\\u1400\\u1806\\u2010-\\u2015\\u2e17\\u2e1a\\u2e3a\\u2e40\\u301c\\u3030\\u30a0\\ufe31\\ufe58\\ufe63\\uff0d/;\n  regexen.validGeneralUrlPathChars = regexSupplant(/[^#{spaces_group}\\(\\)\\?]/i);\n  // Allow URL paths to contain up to two nested levels of balanced parens\n  //  1. Used in Wikipedia URLs like /Primer_(film)\n  //  2. Used in IIS sessions like /S(dfd346)/\n  //  3. Used in Rdio URLs like /track/We_Up_(Album_Version_(Edited))/\n  regexen.validUrlBalancedParens = regexSupplant(\n    '\\\\('                                   +\n      '(?:'                                 +\n        '#{validGeneralUrlPathChars}+'      +\n        '|'                                 +\n        // allow one nested level of balanced parentheses\n        '(?:'                               +\n          '#{validGeneralUrlPathChars}*'    +\n          '\\\\('                             +\n            '#{validGeneralUrlPathChars}+'  +\n          '\\\\)'                             +\n          '#{validGeneralUrlPathChars}*'    +\n        ')'                                 +\n      ')'                                   +\n    '\\\\)',\n    'i');\n  // Valid end-of-path chracters (so /foo. does not gobble the period).\n  // 1. Allow =&# for empty URL parameters and other URL-join artifacts\n  regexen.validUrlPathEndingChars = regexSupplant(/[^#{spaces_group}\\(\\)\\?!\\*';:=\\,\\.\\$%\\[\\]#{pd}~&\\|@]|(?:#{validUrlBalancedParens})/i);\n  // Allow @ in a url, but only in the middle. Catch things like http://example.com/@user/\n  regexen.validUrlPath = regexSupplant('(?:' +\n    '(?:' +\n      '#{validGeneralUrlPathChars}*' +\n        '(?:#{validUrlBalancedParens}#{validGeneralUrlPathChars}*)*' +\n        '#{validUrlPathEndingChars}'+\n      ')|(?:@#{validGeneralUrlPathChars}+\\/)'+\n    ')', 'i');\n  regexen.validUrlQueryChars = /[a-z0-9!?\\*'@\\(\\);:&=\\+\\$\\/%#\\[\\]\\-_\\.,~|]/i;\n  regexen.validUrlQueryEndingChars = /[a-z0-9_&=#\\/]/i;\n  regexen.validUrl = regexSupplant(\n    '('                                                          + // $1 URL\n      '(https?:\\\\/\\\\/)'                                          + // $2 Protocol\n      '(#{validDomain})'                                         + // $3 Domain(s)\n      '(?::(#{validPortNumber}))?'                               + // $4 Port number (optional)\n      '(\\\\/#{validUrlPath}*)?'                                   + // $5 URL Path\n      '(\\\\?#{validUrlQueryChars}*#{validUrlQueryEndingChars})?'  + // $6 Query String\n    ')',\n    'gi');\n  return regexen.validUrl;\n}());\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/util/url_regex.js","import React from 'react';\nimport { connect } from 'react-redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport ReactSwipeableViews from 'react-swipeable-views';\nimport classNames from 'classnames';\nimport Permalink from '../../../components/permalink';\nimport ComposeForm from '../../compose/components/compose_form';\nimport Search from '../../compose/components/search';\nimport NavigationBar from '../../compose/components/navigation_bar';\nimport ColumnHeader from './column_header';\nimport { List as ImmutableList } from 'immutable';\nimport { me } from '../../../initial_state';\n\nconst noop = () => { };\n\nconst messages = defineMessages({\n  home_title: { id: 'column.home', defaultMessage: 'Home' },\n  notifications_title: { id: 'column.notifications', defaultMessage: 'Notifications' },\n  local_title: { id: 'column.community', defaultMessage: 'Local timeline' },\n  federated_title: { id: 'column.public', defaultMessage: 'Federated timeline' },\n});\n\nconst PageOne = ({ acct, domain }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-one'>\n    <div className='onboarding-modal__page-one__lead'>\n      <h1><FormattedMessage id='onboarding.page_one.welcome' defaultMessage='Welcome to Mastodon!' /></h1>\n      <p><FormattedMessage id='onboarding.page_one.federation' defaultMessage='Mastodon is a network of independent servers joining up to make one larger social network. We call these servers instances.' /></p>\n    </div>\n\n    <div className='onboarding-modal__page-one__extra'>\n      <div className='display-case'>\n        <div className='display-case__label'>\n          <FormattedMessage id='onboarding.page_one.full_handle' defaultMessage='Your full handle' />\n        </div>\n\n        <div className='display-case__case'>\n          @{acct}@{domain}\n        </div>\n      </div>\n\n      <p><FormattedMessage id='onboarding.page_one.handle_hint' defaultMessage='This is what you would tell your friends to search for.' /></p>\n    </div>\n  </div>\n);\n\nPageOne.propTypes = {\n  acct: PropTypes.string.isRequired,\n  domain: PropTypes.string.isRequired,\n};\n\nconst PageTwo = ({ myAccount }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-two'>\n    <div className='figure non-interactive'>\n      <div className='pseudo-drawer'>\n        <NavigationBar account={myAccount} />\n\n        <ComposeForm\n          text='Awoo! #introductions'\n          suggestions={ImmutableList()}\n          mentionedDomains={[]}\n          spoiler={false}\n          onChange={noop}\n          onSubmit={noop}\n          onPaste={noop}\n          onPickEmoji={noop}\n          onChangeSpoilerText={noop}\n          onClearSuggestions={noop}\n          onFetchSuggestions={noop}\n          onSuggestionSelected={noop}\n          showSearch\n        />\n      </div>\n    </div>\n\n    <p><FormattedMessage id='onboarding.page_two.compose' defaultMessage='Write posts from the compose column. You can upload images, change privacy settings, and add content warnings with the icons below.' /></p>\n  </div>\n);\n\nPageTwo.propTypes = {\n  myAccount: ImmutablePropTypes.map.isRequired,\n};\n\nconst PageThree = ({ myAccount }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-three'>\n    <div className='figure non-interactive'>\n      <Search\n        value=''\n        onChange={noop}\n        onSubmit={noop}\n        onClear={noop}\n        onShow={noop}\n      />\n\n      <div className='pseudo-drawer'>\n        <NavigationBar account={myAccount} />\n      </div>\n    </div>\n\n    <p><FormattedMessage id='onboarding.page_three.search' defaultMessage='Use the search bar to find people and look at hashtags, such as {illustration} and {introductions}. To look for a person who is not on this instance, use their full handle.' values={{ illustration: <Permalink to='/timelines/tag/illustration' href='/tags/illustration'>#illustration</Permalink>, introductions: <Permalink to='/timelines/tag/introductions' href='/tags/introductions'>#introductions</Permalink> }} /></p>\n    <p><FormattedMessage id='onboarding.page_three.profile' defaultMessage='Edit your profile to change your avatar, bio, and display name. There, you will also find other preferences.' /></p>\n  </div>\n);\n\nPageThree.propTypes = {\n  myAccount: ImmutablePropTypes.map.isRequired,\n};\n\nconst PageFour = ({ domain, intl }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-four'>\n    <div className='onboarding-modal__page-four__columns'>\n      <div className='row'>\n        <div>\n          <div className='figure non-interactive'><ColumnHeader icon='home' type={intl.formatMessage(messages.home_title)} /></div>\n          <p><FormattedMessage id='onboarding.page_four.home' defaultMessage='The home timeline shows posts from people you follow.' /></p>\n        </div>\n\n        <div>\n          <div className='figure non-interactive'><ColumnHeader icon='bell' type={intl.formatMessage(messages.notifications_title)} /></div>\n          <p><FormattedMessage id='onboarding.page_four.notifications' defaultMessage='The notifications column shows when someone interacts with you.' /></p>\n        </div>\n      </div>\n\n      <div className='row'>\n        <div>\n          <div className='figure non-interactive' style={{ marginBottom: 0 }}><ColumnHeader icon='users' type={intl.formatMessage(messages.local_title)} /></div>\n        </div>\n\n        <div>\n          <div className='figure non-interactive' style={{ marginBottom: 0 }}><ColumnHeader icon='globe' type={intl.formatMessage(messages.federated_title)} /></div>\n        </div>\n      </div>\n\n      <p><FormattedMessage id='onboarding.page_five.public_timelines' defaultMessage='The local timeline shows public posts from everyone on {domain}. The federated timeline shows public posts from everyone who people on {domain} follow. These are the Public Timelines, a great way to discover new people.' values={{ domain }} /></p>\n    </div>\n  </div>\n);\n\nPageFour.propTypes = {\n  domain: PropTypes.string.isRequired,\n  intl: PropTypes.object.isRequired,\n};\n\nconst PageSix = ({ admin, domain }) => {\n  let adminSection = '';\n\n  if (admin) {\n    adminSection = (\n      <p>\n        <FormattedMessage id='onboarding.page_six.admin' defaultMessage=\"Your instance's admin is {admin}.\" values={{ admin: <Permalink href={admin.get('url')} to={`/accounts/${admin.get('id')}`}>@{admin.get('acct')}</Permalink> }} />\n        <br />\n        <FormattedMessage id='onboarding.page_six.read_guidelines' defaultMessage=\"Please read {domain}'s {guidelines}!\" values={{ domain, guidelines: <a href='/about/more' target='_blank'><FormattedMessage id='onboarding.page_six.guidelines' defaultMessage='community guidelines' /></a> }} />\n      </p>\n    );\n  }\n\n  return (\n    <div className='onboarding-modal__page onboarding-modal__page-six'>\n      <h1><FormattedMessage id='onboarding.page_six.almost_done' defaultMessage='Almost done...' /></h1>\n      {adminSection}\n      <p><FormattedMessage id='onboarding.page_six.github' defaultMessage='Mastodon is free open-source software. You can report bugs, request features, or contribute to the code on {github}.' values={{ github: <a href='https://github.com/tootsuite/mastodon' target='_blank' rel='noopener'>GitHub</a> }} /></p>\n      <p><FormattedMessage id='onboarding.page_six.apps_available' defaultMessage='There are {apps} available for iOS, Android and other platforms.' values={{ apps: <a href='https://github.com/tootsuite/documentation/blob/master/Using-Mastodon/Apps.md' target='_blank' rel='noopener'><FormattedMessage id='onboarding.page_six.various_app' defaultMessage='mobile apps' /></a> }} /></p>\n      <p><em><FormattedMessage id='onboarding.page_six.appetoot' defaultMessage='Bon Appetoot!' /></em></p>\n    </div>\n  );\n};\n\nPageSix.propTypes = {\n  admin: ImmutablePropTypes.map,\n  domain: PropTypes.string.isRequired,\n};\n\nconst mapStateToProps = state => ({\n  myAccount: state.getIn(['accounts', me]),\n  admin: state.getIn(['accounts', state.getIn(['meta', 'admin'])]),\n  domain: state.getIn(['meta', 'domain']),\n});\n\n@connect(mapStateToProps)\n@injectIntl\nexport default class OnboardingModal extends React.PureComponent {\n\n  static propTypes = {\n    onClose: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n    myAccount: ImmutablePropTypes.map.isRequired,\n    domain: PropTypes.string.isRequired,\n    admin: ImmutablePropTypes.map,\n  };\n\n  state = {\n    currentIndex: 0,\n  };\n\n  componentWillMount() {\n    const { myAccount, admin, domain, intl } = this.props;\n    this.pages = [\n      <PageOne acct={myAccount.get('acct')} domain={domain} />,\n      <PageTwo myAccount={myAccount} />,\n      <PageThree myAccount={myAccount} />,\n      <PageFour domain={domain} intl={intl} />,\n      <PageSix admin={admin} domain={domain} />,\n    ];\n  };\n\n  componentDidMount() {\n    window.addEventListener('keyup', this.handleKeyUp);\n  }\n\n  componentWillUnmount() {\n    window.addEventListener('keyup', this.handleKeyUp);\n  }\n\n  handleSkip = (e) => {\n    e.preventDefault();\n    this.props.onClose();\n  }\n\n  handleDot = (e) => {\n    const i = Number(e.currentTarget.getAttribute('data-index'));\n    e.preventDefault();\n    this.setState({ currentIndex: i });\n  }\n\n  handlePrev = () => {\n    this.setState(({ currentIndex }) => ({\n      currentIndex: Math.max(0, currentIndex - 1),\n    }));\n  }\n\n  handleNext = () => {\n    const { pages } = this;\n    this.setState(({ currentIndex }) => ({\n      currentIndex: Math.min(currentIndex + 1, pages.length - 1),\n    }));\n  }\n\n  handleSwipe = (index) => {\n    this.setState({ currentIndex: index });\n  }\n\n  handleKeyUp = ({ key }) => {\n    switch (key) {\n    case 'ArrowLeft':\n      this.handlePrev();\n      break;\n    case 'ArrowRight':\n      this.handleNext();\n      break;\n    }\n  }\n\n  handleClose = () => {\n    this.props.onClose();\n  }\n\n  render () {\n    const { pages } = this;\n    const { currentIndex } = this.state;\n    const hasMore = currentIndex < pages.length - 1;\n\n    const nextOrDoneBtn = hasMore ? (\n      <button onClick={this.handleNext} className='onboarding-modal__nav onboarding-modal__next shake-bottom'>\n        <FormattedMessage id='onboarding.next' defaultMessage='Next' /> <i className='fa fa-fw fa-chevron-right' />\n      </button>\n    ) : (\n      <button onClick={this.handleClose} className='onboarding-modal__nav onboarding-modal__done shake-bottom'>\n        <FormattedMessage id='onboarding.done' defaultMessage='Done' /> <i className='fa fa-fw fa-check' />\n      </button>\n    );\n\n    return (\n      <div className='modal-root__modal onboarding-modal'>\n        <ReactSwipeableViews index={currentIndex} onChangeIndex={this.handleSwipe} className='onboarding-modal__pager'>\n          {pages.map((page, i) => {\n            const className = classNames('onboarding-modal__page__wrapper', `onboarding-modal__page__wrapper-${i}`, {\n              'onboarding-modal__page__wrapper--active': i === currentIndex,\n            });\n\n            return (\n              <div key={i} className={className}>{page}</div>\n            );\n          })}\n        </ReactSwipeableViews>\n\n        <div className='onboarding-modal__paginator'>\n          <div>\n            <button\n              onClick={this.handleSkip}\n              className='onboarding-modal__nav onboarding-modal__skip'\n            >\n              <FormattedMessage id='onboarding.skip' defaultMessage='Skip' />\n            </button>\n          </div>\n\n          <div className='onboarding-modal__dots'>\n            {pages.map((_, i) => {\n              const className = classNames('onboarding-modal__dot', {\n                active: i === currentIndex,\n              });\n\n              return (\n                <div\n                  key={`dot-${i}`}\n                  role='button'\n                  tabIndex='0'\n                  data-index={i}\n                  onClick={this.handleDot}\n                  className={className}\n                />\n              );\n            })}\n          </div>\n\n          <div>\n            {nextOrDoneBtn}\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/ui/components/onboarding_modal.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport Avatar from '../../../components/avatar';\nimport IconButton from '../../../components/icon_button';\nimport Permalink from '../../../components/permalink';\nimport { FormattedMessage } from 'react-intl';\nimport ImmutablePureComponent from 'react-immutable-pure-component';\n\nexport default class NavigationBar extends ImmutablePureComponent {\n\n  static propTypes = {\n    account: ImmutablePropTypes.map.isRequired,\n    onClose: PropTypes.func,\n  };\n\n  render () {\n    return (\n      <div className='navigation-bar'>\n        <Permalink href={this.props.account.get('url')} to={`/accounts/${this.props.account.get('id')}`}>\n          <span style={{ display: 'none' }}>{this.props.account.get('acct')}</span>\n          <Avatar account={this.props.account} size={40} />\n        </Permalink>\n\n        <div className='navigation-bar__profile'>\n          <Permalink href={this.props.account.get('url')} to={`/accounts/${this.props.account.get('id')}`}>\n            <strong className='navigation-bar__profile-account'>@{this.props.account.get('acct')}</strong>\n          </Permalink>\n\n          <a href='/settings/profile' className='navigation-bar__profile-edit'><FormattedMessage id='navigation_bar.edit_profile' defaultMessage='Edit profile' /></a>\n        </div>\n\n        <IconButton title='' icon='close' onClick={this.props.onClose} />\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/navigation_bar.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport Overlay from 'react-overlays/lib/Overlay';\nimport Motion from '../../ui/util/optional_motion';\nimport spring from 'react-motion/lib/spring';\nimport { searchEnabled } from '../../../initial_state';\n\nconst messages = defineMessages({\n  placeholder: { id: 'search.placeholder', defaultMessage: 'Search' },\n});\n\nclass SearchPopout extends React.PureComponent {\n\n  static propTypes = {\n    style: PropTypes.object,\n  };\n\n  render () {\n    const { style } = this.props;\n    const extraInformation = searchEnabled ? <FormattedMessage id='search_popout.tips.full_text' defaultMessage='Simple text returns statuses you have written, favourited, boosted, or have been mentioned in, as well as matching usernames, display names, and hashtags.' /> : <FormattedMessage id='search_popout.tips.text' defaultMessage='Simple text returns matching display names, usernames and hashtags' />;\n    return (\n      <div style={{ ...style, position: 'absolute', width: 315 }}>\n        <Motion defaultStyle={{ opacity: 0, scaleX: 0.85, scaleY: 0.75 }} style={{ opacity: spring(1, { damping: 35, stiffness: 400 }), scaleX: spring(1, { damping: 35, stiffness: 400 }), scaleY: spring(1, { damping: 35, stiffness: 400 }) }}>\n          {({ opacity, scaleX, scaleY }) => (\n            <div className='search-popout' style={{ opacity: opacity, transform: `scale(${scaleX}, ${scaleY})` }}>\n              <h4><FormattedMessage id='search_popout.search_format' defaultMessage='Advanced search format' /></h4>\n\n              <ul>\n                <li><em>#example</em> <FormattedMessage id='search_popout.tips.hashtag' defaultMessage='hashtag' /></li>\n                <li><em>@username@domain</em> <FormattedMessage id='search_popout.tips.user' defaultMessage='user' /></li>\n                <li><em>URL</em> <FormattedMessage id='search_popout.tips.user' defaultMessage='user' /></li>\n                <li><em>URL</em> <FormattedMessage id='search_popout.tips.status' defaultMessage='status' /></li>\n              </ul>\n\n              {extraInformation}\n            </div>\n          )}\n        </Motion>\n      </div>\n    );\n  }\n\n}\n\n@injectIntl\nexport default class Search extends React.PureComponent {\n\n  static propTypes = {\n    value: PropTypes.string.isRequired,\n    submitted: PropTypes.bool,\n    onChange: PropTypes.func.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    onClear: PropTypes.func.isRequired,\n    onShow: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n  };\n\n  state = {\n    expanded: false,\n  };\n\n  handleChange = (e) => {\n    this.props.onChange(e.target.value);\n  }\n\n  handleClear = (e) => {\n    e.preventDefault();\n\n    if (this.props.value.length > 0 || this.props.submitted) {\n      this.props.onClear();\n    }\n  }\n\n  handleKeyDown = (e) => {\n    if (e.key === 'Enter') {\n      e.preventDefault();\n      this.props.onSubmit();\n    } else if (e.key === 'Escape') {\n      document.querySelector('.ui').parentElement.focus();\n    }\n  }\n\n  noop () {\n\n  }\n\n  handleFocus = () => {\n    this.setState({ expanded: true });\n    this.props.onShow();\n  }\n\n  handleBlur = () => {\n    this.setState({ expanded: false });\n  }\n\n  render () {\n    const { intl, value, submitted } = this.props;\n    const { expanded } = this.state;\n    const hasValue = value.length > 0 || submitted;\n\n    return (\n      <div className='search'>\n        <label>\n          <span style={{ display: 'none' }}>{intl.formatMessage(messages.placeholder)}</span>\n          <input\n            className='search__input'\n            type='text'\n            placeholder={intl.formatMessage(messages.placeholder)}\n            value={value}\n            onChange={this.handleChange}\n            onKeyUp={this.handleKeyDown}\n            onFocus={this.handleFocus}\n            onBlur={this.handleBlur}\n          />\n        </label>\n\n        <div role='button' tabIndex='0' className='search__icon' onClick={this.handleClear}>\n          <i className={`fa fa-search ${hasValue ? '' : 'active'}`} />\n          <i aria-label={intl.formatMessage(messages.placeholder)} className={`fa fa-times-circle ${hasValue ? 'active' : ''}`} />\n        </div>\n\n        <Overlay show={expanded && !hasValue} placement='bottom' target={this}>\n          <SearchPopout />\n        </Overlay>\n      </div>\n    );\n  }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ./app/javascript/mastodon/features/compose/components/search.js"],"sourceRoot":""}
\ No newline at end of file
+{"version":3,"sources":["webpack:///./app/javascript/mastodon/features/ui/components/onboarding_modal.js"],"names":["noop","messages","Object","react_intl__WEBPACK_IMPORTED_MODULE_6__","home_title","id","defaultMessage","notifications_title","local_title","federated_title","PageOne","_ref","acct","domain","babel_runtime_helpers_jsx__WEBPACK_IMPORTED_MODULE_3___default","className","PageTwo","_ref2","myAccount","_compose_components_navigation_bar__WEBPACK_IMPORTED_MODULE_12__","account","_compose_components_compose_form__WEBPACK_IMPORTED_MODULE_10__","text","suggestions","immutable__WEBPACK_IMPORTED_MODULE_14__","mentionedDomains","spoiler","onChange","onSubmit","onPaste","onPickEmoji","onChangeSpoilerText","onClearSuggestions","onFetchSuggestions","onSuggestionSelected","showSearch","PageThree","_ref3","_compose_components_search__WEBPACK_IMPORTED_MODULE_11__","value","onClear","onShow","values","illustration","_components_permalink__WEBPACK_IMPORTED_MODULE_9__","to","href","introductions","PageFour","_ref4","intl","_column_header__WEBPACK_IMPORTED_MODULE_13__","icon","type","formatMessage","style","marginBottom","PageSix","_ref5","admin","adminSection","get","guidelines","target","github","rel","apps","OnboardingModal","react_redux__WEBPACK_IMPORTED_MODULE_5__","state","getIn","_initial_state__WEBPACK_IMPORTED_MODULE_15__","currentIndex","handleSkip","e","preventDefault","_this","props","onClose","handleDot","i","Number","currentTarget","getAttribute","setState","handlePrev","_ref6","Math","max","handleNext","pages","_ref7","min","length","handleSwipe","index","handleKeyUp","_ref8","key","handleClose","componentWillMount","_props","this","componentDidMount","window","addEventListener","componentWillUnmount","render","_this3","nextOrDoneBtn","hasMore","onClick","react_swipeable_views__WEBPACK_IMPORTED_MODULE_7___default","a","onChangeIndex","map","page","classnames__WEBPACK_IMPORTED_MODULE_8___default","onboarding-modal__page__wrapper--active","_","active","role","tabIndex","data-index","react__WEBPACK_IMPORTED_MODULE_4___default","PureComponent"],"mappings":"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","file":"modals/onboarding_modal.js","sourcesContent":["import React from 'react';\nimport { connect } from 'react-redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { defineMessages, injectIntl, FormattedMessage } from 'react-intl';\nimport ReactSwipeableViews from 'react-swipeable-views';\nimport classNames from 'classnames';\nimport Permalink from '../../../components/permalink';\nimport ComposeForm from '../../compose/components/compose_form';\nimport Search from '../../compose/components/search';\nimport NavigationBar from '../../compose/components/navigation_bar';\nimport ColumnHeader from './column_header';\nimport { List as ImmutableList } from 'immutable';\nimport { me } from '../../../initial_state';\n\nconst noop = () => { };\n\nconst messages = defineMessages({\n  home_title: { id: 'column.home', defaultMessage: 'Home' },\n  notifications_title: { id: 'column.notifications', defaultMessage: 'Notifications' },\n  local_title: { id: 'column.community', defaultMessage: 'Local timeline' },\n  federated_title: { id: 'column.public', defaultMessage: 'Federated timeline' },\n});\n\nconst PageOne = ({ acct, domain }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-one'>\n    <div className='onboarding-modal__page-one__lead'>\n      <h1><FormattedMessage id='onboarding.page_one.welcome' defaultMessage='Welcome to Mastodon!' /></h1>\n      <p><FormattedMessage id='onboarding.page_one.federation' defaultMessage='Mastodon is a network of independent servers joining up to make one larger social network. We call these servers instances.' /></p>\n    </div>\n\n    <div className='onboarding-modal__page-one__extra'>\n      <div className='display-case'>\n        <div className='display-case__label'>\n          <FormattedMessage id='onboarding.page_one.full_handle' defaultMessage='Your full handle' />\n        </div>\n\n        <div className='display-case__case'>\n          @{acct}@{domain}\n        </div>\n      </div>\n\n      <p><FormattedMessage id='onboarding.page_one.handle_hint' defaultMessage='This is what you would tell your friends to search for.' /></p>\n    </div>\n  </div>\n);\n\nPageOne.propTypes = {\n  acct: PropTypes.string.isRequired,\n  domain: PropTypes.string.isRequired,\n};\n\nconst PageTwo = ({ myAccount }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-two'>\n    <div className='figure non-interactive'>\n      <div className='pseudo-drawer'>\n        <NavigationBar account={myAccount} />\n\n        <ComposeForm\n          text='Awoo! #introductions'\n          suggestions={ImmutableList()}\n          mentionedDomains={[]}\n          spoiler={false}\n          onChange={noop}\n          onSubmit={noop}\n          onPaste={noop}\n          onPickEmoji={noop}\n          onChangeSpoilerText={noop}\n          onClearSuggestions={noop}\n          onFetchSuggestions={noop}\n          onSuggestionSelected={noop}\n          showSearch\n        />\n      </div>\n    </div>\n\n    <p><FormattedMessage id='onboarding.page_two.compose' defaultMessage='Write posts from the compose column. You can upload images, change privacy settings, and add content warnings with the icons below.' /></p>\n  </div>\n);\n\nPageTwo.propTypes = {\n  myAccount: ImmutablePropTypes.map.isRequired,\n};\n\nconst PageThree = ({ myAccount }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-three'>\n    <div className='figure non-interactive'>\n      <Search\n        value=''\n        onChange={noop}\n        onSubmit={noop}\n        onClear={noop}\n        onShow={noop}\n      />\n\n      <div className='pseudo-drawer'>\n        <NavigationBar account={myAccount} />\n      </div>\n    </div>\n\n    <p><FormattedMessage id='onboarding.page_three.search' defaultMessage='Use the search bar to find people and look at hashtags, such as {illustration} and {introductions}. To look for a person who is not on this instance, use their full handle.' values={{ illustration: <Permalink to='/timelines/tag/illustration' href='/tags/illustration'>#illustration</Permalink>, introductions: <Permalink to='/timelines/tag/introductions' href='/tags/introductions'>#introductions</Permalink> }} /></p>\n    <p><FormattedMessage id='onboarding.page_three.profile' defaultMessage='Edit your profile to change your avatar, bio, and display name. There, you will also find other preferences.' /></p>\n  </div>\n);\n\nPageThree.propTypes = {\n  myAccount: ImmutablePropTypes.map.isRequired,\n};\n\nconst PageFour = ({ domain, intl }) => (\n  <div className='onboarding-modal__page onboarding-modal__page-four'>\n    <div className='onboarding-modal__page-four__columns'>\n      <div className='row'>\n        <div>\n          <div className='figure non-interactive'><ColumnHeader icon='home' type={intl.formatMessage(messages.home_title)} /></div>\n          <p><FormattedMessage id='onboarding.page_four.home' defaultMessage='The home timeline shows posts from people you follow.' /></p>\n        </div>\n\n        <div>\n          <div className='figure non-interactive'><ColumnHeader icon='bell' type={intl.formatMessage(messages.notifications_title)} /></div>\n          <p><FormattedMessage id='onboarding.page_four.notifications' defaultMessage='The notifications column shows when someone interacts with you.' /></p>\n        </div>\n      </div>\n\n      <div className='row'>\n        <div>\n          <div className='figure non-interactive' style={{ marginBottom: 0 }}><ColumnHeader icon='users' type={intl.formatMessage(messages.local_title)} /></div>\n        </div>\n\n        <div>\n          <div className='figure non-interactive' style={{ marginBottom: 0 }}><ColumnHeader icon='globe' type={intl.formatMessage(messages.federated_title)} /></div>\n        </div>\n      </div>\n\n      <p><FormattedMessage id='onboarding.page_five.public_timelines' defaultMessage='The local timeline shows public posts from everyone on {domain}. The federated timeline shows public posts from everyone who people on {domain} follow. These are the Public Timelines, a great way to discover new people.' values={{ domain }} /></p>\n    </div>\n  </div>\n);\n\nPageFour.propTypes = {\n  domain: PropTypes.string.isRequired,\n  intl: PropTypes.object.isRequired,\n};\n\nconst PageSix = ({ admin, domain }) => {\n  let adminSection = '';\n\n  if (admin) {\n    adminSection = (\n      <p>\n        <FormattedMessage id='onboarding.page_six.admin' defaultMessage=\"Your instance's admin is {admin}.\" values={{ admin: <Permalink href={admin.get('url')} to={`/accounts/${admin.get('id')}`}>@{admin.get('acct')}</Permalink> }} />\n        <br />\n        <FormattedMessage id='onboarding.page_six.read_guidelines' defaultMessage=\"Please read {domain}'s {guidelines}!\" values={{ domain, guidelines: <a href='/about/more' target='_blank'><FormattedMessage id='onboarding.page_six.guidelines' defaultMessage='community guidelines' /></a> }} />\n      </p>\n    );\n  }\n\n  return (\n    <div className='onboarding-modal__page onboarding-modal__page-six'>\n      <h1><FormattedMessage id='onboarding.page_six.almost_done' defaultMessage='Almost done...' /></h1>\n      {adminSection}\n      <p><FormattedMessage id='onboarding.page_six.github' defaultMessage='Mastodon is free open-source software. You can report bugs, request features, or contribute to the code on {github}.' values={{ github: <a href='https://github.com/tootsuite/mastodon' target='_blank' rel='noopener'>GitHub</a> }} /></p>\n      <p><FormattedMessage id='onboarding.page_six.apps_available' defaultMessage='There are {apps} available for iOS, Android and other platforms.' values={{ apps: <a href='https://github.com/tootsuite/documentation/blob/master/Using-Mastodon/Apps.md' target='_blank' rel='noopener'><FormattedMessage id='onboarding.page_six.various_app' defaultMessage='mobile apps' /></a> }} /></p>\n      <p><em><FormattedMessage id='onboarding.page_six.appetoot' defaultMessage='Bon Appetoot!' /></em></p>\n    </div>\n  );\n};\n\nPageSix.propTypes = {\n  admin: ImmutablePropTypes.map,\n  domain: PropTypes.string.isRequired,\n};\n\nconst mapStateToProps = state => ({\n  myAccount: state.getIn(['accounts', me]),\n  admin: state.getIn(['accounts', state.getIn(['meta', 'admin'])]),\n  domain: state.getIn(['meta', 'domain']),\n});\n\n@connect(mapStateToProps)\n@injectIntl\nexport default class OnboardingModal extends React.PureComponent {\n\n  static propTypes = {\n    onClose: PropTypes.func.isRequired,\n    intl: PropTypes.object.isRequired,\n    myAccount: ImmutablePropTypes.map.isRequired,\n    domain: PropTypes.string.isRequired,\n    admin: ImmutablePropTypes.map,\n  };\n\n  state = {\n    currentIndex: 0,\n  };\n\n  componentWillMount() {\n    const { myAccount, admin, domain, intl } = this.props;\n    this.pages = [\n      <PageOne acct={myAccount.get('acct')} domain={domain} />,\n      <PageTwo myAccount={myAccount} />,\n      <PageThree myAccount={myAccount} />,\n      <PageFour domain={domain} intl={intl} />,\n      <PageSix admin={admin} domain={domain} />,\n    ];\n  };\n\n  componentDidMount() {\n    window.addEventListener('keyup', this.handleKeyUp);\n  }\n\n  componentWillUnmount() {\n    window.addEventListener('keyup', this.handleKeyUp);\n  }\n\n  handleSkip = (e) => {\n    e.preventDefault();\n    this.props.onClose();\n  }\n\n  handleDot = (e) => {\n    const i = Number(e.currentTarget.getAttribute('data-index'));\n    e.preventDefault();\n    this.setState({ currentIndex: i });\n  }\n\n  handlePrev = () => {\n    this.setState(({ currentIndex }) => ({\n      currentIndex: Math.max(0, currentIndex - 1),\n    }));\n  }\n\n  handleNext = () => {\n    const { pages } = this;\n    this.setState(({ currentIndex }) => ({\n      currentIndex: Math.min(currentIndex + 1, pages.length - 1),\n    }));\n  }\n\n  handleSwipe = (index) => {\n    this.setState({ currentIndex: index });\n  }\n\n  handleKeyUp = ({ key }) => {\n    switch (key) {\n    case 'ArrowLeft':\n      this.handlePrev();\n      break;\n    case 'ArrowRight':\n      this.handleNext();\n      break;\n    }\n  }\n\n  handleClose = () => {\n    this.props.onClose();\n  }\n\n  render () {\n    const { pages } = this;\n    const { currentIndex } = this.state;\n    const hasMore = currentIndex < pages.length - 1;\n\n    const nextOrDoneBtn = hasMore ? (\n      <button onClick={this.handleNext} className='onboarding-modal__nav onboarding-modal__next shake-bottom'>\n        <FormattedMessage id='onboarding.next' defaultMessage='Next' /> <i className='fa fa-fw fa-chevron-right' />\n      </button>\n    ) : (\n      <button onClick={this.handleClose} className='onboarding-modal__nav onboarding-modal__done shake-bottom'>\n        <FormattedMessage id='onboarding.done' defaultMessage='Done' /> <i className='fa fa-fw fa-check' />\n      </button>\n    );\n\n    return (\n      <div className='modal-root__modal onboarding-modal'>\n        <ReactSwipeableViews index={currentIndex} onChangeIndex={this.handleSwipe} className='onboarding-modal__pager'>\n          {pages.map((page, i) => {\n            const className = classNames('onboarding-modal__page__wrapper', `onboarding-modal__page__wrapper-${i}`, {\n              'onboarding-modal__page__wrapper--active': i === currentIndex,\n            });\n\n            return (\n              <div key={i} className={className}>{page}</div>\n            );\n          })}\n        </ReactSwipeableViews>\n\n        <div className='onboarding-modal__paginator'>\n          <div>\n            <button\n              onClick={this.handleSkip}\n              className='onboarding-modal__nav onboarding-modal__skip'\n            >\n              <FormattedMessage id='onboarding.skip' defaultMessage='Skip' />\n            </button>\n          </div>\n\n          <div className='onboarding-modal__dots'>\n            {pages.map((_, i) => {\n              const className = classNames('onboarding-modal__dot', {\n                active: i === currentIndex,\n              });\n\n              return (\n                <div\n                  key={`dot-${i}`}\n                  role='button'\n                  tabIndex='0'\n                  data-index={i}\n                  onClick={this.handleDot}\n                  className={className}\n                />\n              );\n            })}\n          </div>\n\n          <div>\n            {nextOrDoneBtn}\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n}\n"],"sourceRoot":""}
\ No newline at end of file