{"version":3,"sources":["webpack:///wagtail/admin/static/wagtailadmin/js/wagtailadmin.js","webpack:///./node_modules/react-redux/es/utils/warning.js","webpack:///./node_modules/react-redux/es/utils/PropTypes.js","webpack:///./node_modules/react-redux/es/components/connectAdvanced.js","webpack:///./node_modules/redux/es/redux.js","webpack:///./node_modules/react-redux/es/connect/wrapMapToProps.js","webpack:///./node_modules/lodash-es/_Symbol.js","webpack:///./client/src/components/Explorer/actions.js","webpack:///./client/src/components/LoadingSpinner/LoadingSpinner.js","webpack:///./client/src/components/Transition/Transition.js","webpack:///./node_modules/dom-helpers/util/inDOM.js","webpack:///./node_modules/react-transition-group/utils/PropTypes.js","webpack:///./client/src/components/PublicationStatus/PublicationStatus.js","webpack:///./wagtail/admin/static_src/wagtailadmin/app/wagtailadmin.entry.js","webpack:///./client/src/index.js","webpack:///./client/src/components/Explorer/index.js","webpack:///./node_modules/react-redux/es/components/Provider.js","webpack:///./node_modules/hoist-non-react-statics/index.js","webpack:///./node_modules/invariant/browser.js","webpack:///./node_modules/react-redux/es/utils/Subscription.js","webpack:///./node_modules/react-redux/es/connect/connect.js","webpack:///./node_modules/react-redux/es/utils/shallowEqual.js","webpack:///./node_modules/react-redux/es/connect/mapDispatchToProps.js","webpack:///./node_modules/symbol-observable/es/index.js","webpack:///(webpack)/buildin/harmony-module.js","webpack:///./node_modules/symbol-observable/es/ponyfill.js","webpack:///./node_modules/lodash-es/isPlainObject.js","webpack:///./node_modules/lodash-es/_baseGetTag.js","webpack:///./node_modules/lodash-es/_root.js","webpack:///./node_modules/lodash-es/_freeGlobal.js","webpack:///./node_modules/lodash-es/_getRawTag.js","webpack:///./node_modules/lodash-es/_objectToString.js","webpack:///./node_modules/lodash-es/_getPrototype.js","webpack:///./node_modules/lodash-es/_overArg.js","webpack:///./node_modules/lodash-es/isObjectLike.js","webpack:///./node_modules/react-redux/es/connect/mapStateToProps.js","webpack:///./node_modules/react-redux/es/connect/mergeProps.js","webpack:///./node_modules/react-redux/es/connect/selectorFactory.js","webpack:///./node_modules/redux-thunk/es/index.js","webpack:///./client/src/components/Explorer/Explorer.js","webpack:///./client/src/api/admin.js","webpack:///./client/src/api/client.js","webpack:///./client/src/utils/actions.js","webpack:///./client/src/components/Explorer/ExplorerPanel.js","webpack:///./node_modules/focus-trap-react/dist/focus-trap-react.js-exposed","webpack:///./node_modules/focus-trap-react/dist/focus-trap-react.js","webpack:///./node_modules/focus-trap/index.js","webpack:///./node_modules/tabbable/index.js","webpack:///./node_modules/react-transition-group/CSSTransitionGroup.js-exposed","webpack:///./node_modules/react-transition-group/CSSTransitionGroup.js","webpack:///./node_modules/react-transition-group/TransitionGroup.js","webpack:///./node_modules/chain-function/index.js","webpack:///./node_modules/warning/browser.js","webpack:///./node_modules/react-transition-group/utils/ChildMapping.js","webpack:///./node_modules/react-transition-group/CSSTransitionGroupChild.js","webpack:///./node_modules/dom-helpers/class/addClass.js","webpack:///./node_modules/dom-helpers/class/hasClass.js","webpack:///./node_modules/dom-helpers/class/removeClass.js","webpack:///./node_modules/dom-helpers/util/requestAnimationFrame.js","webpack:///./node_modules/dom-helpers/transition/properties.js","webpack:///./client/src/components/Explorer/ExplorerHeader.js","webpack:///./client/src/components/Explorer/ExplorerItem.js","webpack:///./client/src/components/Explorer/PageCount.js","webpack:///./client/src/components/Explorer/ExplorerToggle.js","webpack:///./client/src/components/Explorer/reducers/explorer.js","webpack:///./client/src/components/Explorer/reducers/nodes.js","webpack:///./client/src/utils/focus.js","webpack:///./client/src/includes/initSubmenus.js","webpack:///./client/src/components/UpgradeNotification/index.js","webpack:///./client/src/utils/version.js","webpack:///./client/src/components/Button/Button.js"],"names":["webpackJsonp","122","module","__webpack_exports__","__webpack_require__","__WEBPACK_IMPORTED_MODULE_0__components_Provider__","__WEBPACK_IMPORTED_MODULE_2__connect_connect__","d","123","warning","message","console","error","Error","e","174","subscriptionShape","storeShape","__WEBPACK_IMPORTED_MODULE_0_prop_types__","__WEBPACK_IMPORTED_MODULE_0_prop_types___default","n","a","shape","trySubscribe","func","isRequired","tryUnsubscribe","notifyNestedSubs","isSubscribed","subscribe","dispatch","getState","175","_classCallCheck","instance","Constructor","TypeError","_possibleConstructorReturn","self","call","ReferenceError","_inherits","subClass","superClass","prototype","Object","create","constructor","value","enumerable","writable","configurable","setPrototypeOf","__proto__","_objectWithoutProperties","obj","keys","target","i","indexOf","hasOwnProperty","noop","makeSelectorStateful","sourceSelector","store","selector","run","props","nextProps","shouldComponentUpdate","connectAdvanced","selectorFactory","_contextTypes","_childContextTypes","_ref","arguments","length","undefined","_ref$getDisplayName","getDisplayName","name","_ref$methodName","methodName","_ref$renderCountProp","renderCountProp","_ref$shouldHandleStat","shouldHandleStateChanges","_ref$storeKey","storeKey","_ref$withRef","withRef","connectOptions","subscriptionKey","version","hotReloadingVersion","contextTypes","__WEBPACK_IMPORTED_MODULE_4__utils_PropTypes__","childContextTypes","WrappedComponent","__WEBPACK_IMPORTED_MODULE_1_invariant___default","JSON","stringify","wrappedComponentName","displayName","selectorFactoryOptions","_extends","Connect","_Component","context","this","_this","state","renderCount","propsMode","Boolean","setWrappedInstance","bind","initSelector","initSubscription","getChildContext","_ref2","subscription","componentDidMount","forceUpdate","componentWillReceiveProps","componentWillUnmount","getWrappedInstance","wrappedInstance","ref","parentSub","__WEBPACK_IMPORTED_MODULE_3__utils_Subscription__","onStateChange","componentDidUpdate","notifyNestedSubsOnComponentDidUpdate","setState","dummyState","addExtraProps","withExtras","render","__WEBPACK_IMPORTED_MODULE_2_react__","propTypes","__WEBPACK_IMPORTED_MODULE_0_hoist_non_react_statics___default","__WEBPACK_IMPORTED_MODULE_0_hoist_non_react_statics__","__WEBPACK_IMPORTED_MODULE_1_invariant__","assign","source","key","176","isPlainObject","proto","getPrototypeOf","createStore","reducer","preloadedState","enhancer","ensureCanMutateNextListeners","nextListeners","currentListeners","slice","isDispatching","currentState","listener","push","index","splice","action","type","currentReducer","listeners","replaceReducer","nextReducer","ActionTypes","REPLACE","observable","outerSubscribe","observer","observeState","next","unsubscribe","__WEBPACK_IMPORTED_MODULE_0_symbol_observable__","INIT","getUndefinedStateErrorMessage","actionType","String","assertReducerShape","reducers","forEach","PROBE_UNKNOWN_ACTION","combineReducers","reducerKeys","finalReducers","shapeAssertionError","finalReducerKeys","hasChanged","nextState","_i","_key","previousStateForKey","nextStateForKey","errorMessage","bindActionCreator","actionCreator","apply","bindActionCreators","actionCreators","boundActionCreators","_defineProperty","defineProperty","_objectSpread","ownKeys","getOwnPropertySymbols","concat","filter","sym","getOwnPropertyDescriptor","compose","_len","funcs","Array","arg","reduce","b","applyMiddleware","middlewares","_dispatch","middlewareAPI","chain","map","middleware","randomString","Math","random","toString","substring","split","join","177","wrapMapToPropsConstant","getConstant","options","constantSelector","constant","dependsOnOwnProps","getDependsOnOwnProps","mapToProps","wrapMapToPropsFunc","proxy","stateOrDispatch","ownProps","178","179","__WEBPACK_IMPORTED_MODULE_0__root_js__","Symbol","180","getPage","id","getPageStart","__WEBPACK_IMPORTED_MODULE_0__api_admin__","then","data","getPageSuccess","getPageFailure","getChildren","offset","getChildrenStart","items","meta","nbPages","getChildrenSuccess","total_count","__WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__","getChildrenFailure","toggleExplorer","_getState","explorer","nodes","isVisible","closeExplorer","page","openExplorer","pushPage","_getState2","pushPagePrivate","isFetching","children","count","popPage","__WEBPACK_IMPORTED_MODULE_1__utils_actions__","181","__WEBPACK_IMPORTED_MODULE_0_react__","__WEBPACK_IMPORTED_MODULE_0_react___default","__WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__","__WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__","LoadingSpinner","createElement","className","LOADING","182","PUSH","POP","__WEBPACK_IMPORTED_MODULE_1_react_transition_group_CSSTransitionGroup__","__WEBPACK_IMPORTED_MODULE_1_react_transition_group_CSSTransitionGroup___default","Transition","component","duration","label","transitionEnterTimeout","transitionLeaveTimeout","transitionName","aria-label","defaultProps","183","exports","default","window","document","184","_interopRequireDefault","__esModule","transitionTimeout","transitionType","timeoutPropName","enabledPropName","nameShape","_react","_propTypes","_propTypes2","oneOfType","string","enter","leave","active","enterActive","leaveActive","appear","appearActive","185","PublicationStatus","status","live","414","__WEBPACK_IMPORTED_MODULE_1_react_dom__","__WEBPACK_IMPORTED_MODULE_2_wagtail_client__","wagtail","components","Icon","Portal","addEventListener","explorerNode","querySelector","toggleNode","421","__WEBPACK_IMPORTED_MODULE_1__components_Explorer__","__WEBPACK_IMPORTED_MODULE_4__components_Portal_Portal__","__WEBPACK_IMPORTED_MODULE_7__utils_focus__","__WEBPACK_IMPORTED_MODULE_8__includes_initSubmenus__","__WEBPACK_IMPORTED_MODULE_9__components_UpgradeNotification__","422","initExplorer","__WEBPACK_IMPORTED_MODULE_1_react_dom___default","__WEBPACK_IMPORTED_MODULE_2_react_redux__","__WEBPACK_IMPORTED_MODULE_3_redux__","__WEBPACK_IMPORTED_MODULE_4_redux_thunk__","__WEBPACK_IMPORTED_MODULE_5__Explorer__","__WEBPACK_IMPORTED_MODULE_6__ExplorerToggle__","__WEBPACK_IMPORTED_MODULE_7__reducers_explorer__","__WEBPACK_IMPORTED_MODULE_8__reducers_nodes__","rootReducer","__REDUX_DEVTOOLS_EXTENSION__","startPage","parseInt","getAttribute","textContent","parentNode","423","__WEBPACK_IMPORTED_MODULE_1_prop_types__","__WEBPACK_IMPORTED_MODULE_1_prop_types___default","__WEBPACK_IMPORTED_MODULE_2__utils_PropTypes__","_Provider$childContex","subKey","Provider","only","element","426","REACT_STATICS","getDefaultProps","mixins","KNOWN_STATICS","caller","callee","arity","getOwnPropertyNames","objectPrototype","hoistNonReactStatics","targetComponent","sourceComponent","blacklist","inheritedComponent","descriptor","427","invariant","condition","format","c","f","args","argIndex","replace","framesToPop","428","createListenerCollection","current","clear","CLEARED","notify","get","Subscription","nullListeners","addNestedSub","429","match","factories","result","strictEqual","__WEBPACK_IMPORTED_MODULE_0__components_connectAdvanced__","__WEBPACK_IMPORTED_MODULE_1__utils_shallowEqual__","__WEBPACK_IMPORTED_MODULE_2__mapDispatchToProps__","__WEBPACK_IMPORTED_MODULE_3__mapStateToProps__","__WEBPACK_IMPORTED_MODULE_4__mergeProps__","__WEBPACK_IMPORTED_MODULE_5__selectorFactory__","_ref$connectHOC","connectHOC","_ref$mapStateToPropsF","mapStateToPropsFactories","_ref$mapDispatchToPro","mapDispatchToPropsFactories","_ref$mergePropsFactor","mergePropsFactories","_ref$selectorFactory","mapStateToProps","mapDispatchToProps","mergeProps","_ref2$pure","pure","_ref2$areStatesEqual","areStatesEqual","_ref2$areOwnPropsEqua","areOwnPropsEqual","_ref2$areStatePropsEq","areStatePropsEqual","_ref2$areMergedPropsE","areMergedPropsEqual","extraOptions","initMapStateToProps","initMapDispatchToProps","initMergeProps","430","is","x","y","shallowEqual","objA","objB","keysA","keysB","hasOwn","431","whenMapDispatchToPropsIsFunction","__WEBPACK_IMPORTED_MODULE_1__wrapMapToProps__","whenMapDispatchToPropsIsMissing","whenMapDispatchToPropsIsObject","__WEBPACK_IMPORTED_MODULE_0_redux__","432","global","root","__WEBPACK_IMPORTED_MODULE_0__ponyfill_js__","433","originalModule","webpackPolyfill","l","434","symbolObservablePonyfill","435","__WEBPACK_IMPORTED_MODULE_2__isObjectLike_js__","__WEBPACK_IMPORTED_MODULE_0__baseGetTag_js__","objectTag","__WEBPACK_IMPORTED_MODULE_1__getPrototype_js__","Ctor","funcToString","objectCtorString","funcProto","Function","objectProto","436","baseGetTag","undefinedTag","nullTag","symToStringTag","__WEBPACK_IMPORTED_MODULE_1__getRawTag_js__","__WEBPACK_IMPORTED_MODULE_2__objectToString_js__","__WEBPACK_IMPORTED_MODULE_0__Symbol_js__","toStringTag","437","__WEBPACK_IMPORTED_MODULE_0__freeGlobal_js__","freeSelf","438","freeGlobal","439","getRawTag","isOwn","tag","unmasked","nativeObjectToString","440","objectToString","441","__WEBPACK_IMPORTED_MODULE_0__overArg_js__","getPrototype","442","overArg","transform","443","isObjectLike","444","whenMapStateToPropsIsFunction","__WEBPACK_IMPORTED_MODULE_0__wrapMapToProps__","whenMapStateToPropsIsMissing","445","defaultMergeProps","stateProps","dispatchProps","wrapMergePropsFunc","hasRunOnce","mergedProps","nextMergedProps","whenMergePropsIsFunction","whenMergePropsIsOmitted","446","impureFinalPropsSelectorFactory","pureFinalPropsSelectorFactory","handleFirstCall","firstState","firstOwnProps","hasRunAtLeastOnce","handleNewPropsAndNewState","handleNewProps","handleNewState","nextStateProps","statePropsChanged","handleSubsequentCalls","nextOwnProps","propsChanged","stateChanged","finalPropsSelectorFactory","447","448","createThunkMiddleware","extraArgument","thunk","withExtraArgument","449","__WEBPACK_IMPORTED_MODULE_1_react_redux__","__WEBPACK_IMPORTED_MODULE_2__actions__","__WEBPACK_IMPORTED_MODULE_3__ExplorerPanel__","Explorer","path","onClose","450","getPageChildren","__WEBPACK_IMPORTED_MODULE_0__api_client__","url","PAGES","fields","encodeURIComponent","onlyWithChildren","EXTRA_CHILDREN_PARAMETERS","451","fetch","Headers","checkStatus","response","statusText","parseJSON","json","timeout","ms","promise","Promise","resolve","reject","timeoutId","setTimeout","res","clearTimeout","err","request","method","credentials","headers","Accept","Content-Type","452","createAction","metaCreator","finalActionCreator","identity","payload","453","__WEBPACK_IMPORTED_MODULE_1_focus_trap_react__","__WEBPACK_IMPORTED_MODULE_1_focus_trap_react___default","__WEBPACK_IMPORTED_MODULE_3__Button_Button__","__WEBPACK_IMPORTED_MODULE_4__LoadingSpinner_LoadingSpinner__","__WEBPACK_IMPORTED_MODULE_5__Transition_Transition__","__WEBPACK_IMPORTED_MODULE_6__ExplorerHeader__","__WEBPACK_IMPORTED_MODULE_7__ExplorerItem__","__WEBPACK_IMPORTED_MODULE_8__PageCount__","_createClass","defineProperties","protoProps","staticProps","ExplorerPanel","_React$Component","transition","paused","onItemClick","onHeaderClick","clickOutside","newProps","isPush","classList","add","body","remove","removeEventListener","toggle","contains","preventDefault","stopPropagation","_props","_this2","_props2","item","onClick","NO_RESULTS","isError","SERVER_ERROR","_props3","_state","role","focusTrapOptions","initialFocus","onDeactivate","CLOSE_EXPLORER","PAGE_EXPLORER","depth","renderChildren","Component","454","455","React","createFocusTrap","checkedProps","FocusTrap","_temp","_ret","setNode","el","node","previouslyFocusedElement","activeElement","specifiedFocusTrapOptions","tailoredFocusTrapOptions","returnFocusOnDeactivate","optionName","focusTrap","_createFocusTrap","activate","pause","prevProps","deactivate","unpause","focus","elementProps","prop","456","userOptions","activateOptions","defaultedActivateOptions","onActivate","config","nodeFocusedBeforeActivation","addListeners","trap","deactivateOptions","defaultedDeactivateOptions","returnFocus","removeListeners","tryFocus","listeningFocusTrap","updateTabbableNodes","firstFocusNode","checkFocus","checkClick","checkPointerDown","checkKey","getNodeForOption","optionValue","container","tabbableNodes","clickOutsideDeactivates","stopImmediatePropagation","blur","tabEvent","readjustFocus","keyCode","handleTab","escapeDeactivates","isEscapeEvent","hasAttribute","Number","currentFocusIndex","shiftKey","firstTabbableNode","lastTabbableNode","tabbable","tagName","toLowerCase","select","457","createIsUnavailable","elementDocument","isOff","nodeComputedStyle","documentElement","isOffCache","defaultView","getComputedStyle","display","computedStyle","visibility","ownerDocument","basicTabbables","orderedTabbables","isUnavailable","candidateSelectors","candidates","querySelectorAll","includeContainer","matches","Element","msMatchesSelector","webkitMatchesSelector","some","candidateSelector","unshift","candidate","candidateIndex","tabIndex","disabled","sort","458","459","_react2","_TransitionGroup","_TransitionGroup2","_CSSTransitionGroupChild","_CSSTransitionGroupChild2","_PropTypes","bool","transitionAppear","transitionEnter","transitionLeave","CSSTransitionGroup","_wrapChild","child","appearTimeout","transitionAppearTimeout","enterTimeout","leaveTimeout","childFactory","460","_chainFunction","_chainFunction2","_warning","_ChildMapping","any","TransitionGroup","performAppear","currentlyTransitioningKeys","componentWillAppear","_handleDoneAppearing","componentDidAppear","currentChildMapping","getChildMapping","performLeave","performEnter","componentWillEnter","_handleDoneEntering","componentDidEnter","componentWillLeave","_handleDoneLeaving","componentDidLeave","keysToEnter","newChildren","childRefs","componentWillMount","keysToLeave","initialChildMapping","nextChildMapping","prevChildMapping","mergeChildMappings","hasPrev","hasNext","_this3","childrenToRender","isCallbackRef","factoryChild","r","cloneElement","461","len","fn","462","463","Children","prev","getValueForKey","nextKeysPending","pendingKeys","prevKey","childMapping","nextKey","pendingNextKey","464","addEndListener","events","_addClass","_addClass2","_removeClass","_removeClass2","_requestAnimationFrame","_requestAnimationFrame2","_properties","_reactDom","transitionEnd","animationEnd","CSSTransitionGroupChild","number","done","classNameAndNodeQueue","transitionTimeouts","unmounted","animationType","finishCallback","findDOMNode","activeClassName","timer","queueClassAndNode","finish","rafHandle","flushClassNameAndNodeQueue","scrollTop","465","addClass","_hasClass2","_hasClass","466","hasClass","467","RegExp","468","fallback","curr","Date","getTime","max","req","_inDOM","_inDOM2","vendors","cancel","raf","compatRaf","getKey","vendor","k","toUpperCase","substr","rafKey","cb","469","animationDelay","animationTiming","animationDuration","animationName","transitionDuration","transitionDelay","transitionTiming","transitionProperty","prefix","_getTransitionPropert","style","vendorMap","O","Moz","Webkit","end","property","timing","delay","470","__WEBPACK_IMPORTED_MODULE_2__components_Button_Button__","__WEBPACK_IMPORTED_MODULE_3__components_Icon_Icon__","ExplorerHeader","isRoot","href","admin_display_title","471","__WEBPACK_IMPORTED_MODULE_3__components_Button_Button__","__WEBPACK_IMPORTED_MODULE_4__components_PublicationStatus_PublicationStatus__","childrenIcon","ExplorerItem","title","hasChildren","isPublished","has_unpublished_changes","EDIT_PAGE","VIEW_CHILD_PAGES_OF_PAGE","472","__WEBPACK_IMPORTED_MODULE_2__Icon_Icon__","PageCount","SEE_ALL","PAGE","473","ExplorerToggle","onToggle","icon","dialogTrigger","474","prevState","defaultState","475","newState","defaultPageState","476","initFocusOutline","toggleFocusOutline","isOn","removeFocusOutline","addFocusOutline","477","_toConsumableArray","arr","isArray","arr2","from","initSubmenus","primaryNavContainer","subMenuTriggers","activeClass","subMenuTrigger","clickEvent","submenuContainer","sm","478","initUpgradeNotification","__WEBPACK_IMPORTED_MODULE_0__utils_version__","releasesUrl","currentVersion","dataset","wagtailVersion","log","innerText","setAttribute","catch","479","compareVersion","versionA","versionB","re","va","vb","min","cmp","versionOutOfDate","latestVersion","72","getClassName","hasIcon","iconName","val","handleClick","Button","accessibleLabel","isLoading","hasText","accessibleElt","rel","aria-haspopup"],"mappings":"AAAAA,cAAc,IAERC,IACA,SAAUC,EAAQC,EAAqBC,GAE7C,YACqB,IAAIC,GAAqDD,EAAoB,KAEzEE,GAD4DF,EAAoB,KAC/BA,EAAoB,KAC7DA,GAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOE,GAAsD,IAG1HD,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOG,GAAkD,KASjJE,IACA,SAAUN,EAAQC,EAAqBC,GAE7C,YClBA,SAAAK,GAAAC,GAEA,mBAAAC,UAAA,kBAAAA,SAAAC,OACAD,QAAAC,MAAAF,EAGA,KAIA,SAAAG,OAAAH,GAEG,MAAAI,KAlBHX,EAAA,EAAAM,GDkDMM,IACA,SAAUb,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOa,KACpEZ,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOc,IAC9E,IAAIC,GAA2Cd,EAAoB,IAC/De,EAAmDf,EAAoBgB,EAAEF,GEvDlGF,EAAAG,EAAAE,EAAAC,OACAC,aAAAJ,EAAAE,EAAAG,KAAAC,WACAC,eAAAP,EAAAE,EAAAG,KAAAC,WACAE,iBAAAR,EAAAE,EAAAG,KAAAC,WACAG,aAAAT,EAAAE,EAAAG,KAAAC,aAGAR,EAAAE,EAAAE,EAAAC,OACAO,UAAAV,EAAAE,EAAAG,KAAAC,WACAK,SAAAX,EAAAE,EAAAG,KAAAC,WACAM,SAAAZ,EAAAE,EAAAG,KAAAC,cF+DMO,IACA,SAAU9B,EAAQC,EAAqBC,GAE7C,YG5EA,SAAA6B,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAE3F,QAAAC,GAAAC,EAAAC,GAAiD,IAAAD,EAAa,SAAAE,gBAAA,4DAAyF,QAAAD,GAAA,gBAAAA,IAAA,kBAAAA,GAAAD,EAAAC,EAEvJ,QAAAE,GAAAC,EAAAC,GAA0C,qBAAAA,IAAA,OAAAA,EAA+D,SAAAP,WAAA,iEAAAO,GAAuGD,GAAAE,UAAAC,OAAAC,OAAAH,KAAAC,WAAyEG,aAAeC,MAAAN,EAAAO,YAAA,EAAAC,UAAA,EAAAC,cAAA,KAA6ER,IAAAE,OAAAO,eAAAP,OAAAO,eAAAV,EAAAC,GAAAD,EAAAW,UAAAV,GAErX,QAAAW,GAAAC,EAAAC,GAA8C,GAAAC,KAAiB,QAAAC,KAAAH,GAAqBC,EAAAG,QAAAD,IAAA,GAAoCb,OAAAD,UAAAgB,eAAArB,KAAAgB,EAAAG,KAA6DD,EAAAC,GAAAH,EAAAG,GAAsB,OAAAD,GAW3M,QAAAI,MACA,QAAAC,GAAAC,EAAAC,GAEA,GAAAC,IACAC,IAAA,SAAAC,GACA,IACA,GAAAC,GAAAL,EAAAC,EAAAjC,WAAAoC,IACAC,IAAAH,EAAAE,OAAAF,EAAArD,SACAqD,EAAAI,uBAAA,EACAJ,EAAAE,MAAAC,EACAH,EAAArD,MAAA,MAEO,MAAAA,GACPqD,EAAAI,uBAAA,EACAJ,EAAArD,UAKA,OAAAqD,GAGA,QAAAK,GAeAC,GACA,GAAAC,GAAAC,EAEAC,EAAAC,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,MACAG,EAAAJ,EAAAK,eACAA,MAAAF,KAAAC,EAAA,SAAAE,GACA,yBAAAA,EAAA,KACGF,EACHG,EAAAP,EAAAQ,WACAA,MAAAL,KAAAI,EAAA,kBAAAA,EACAE,EAAAT,EAAAU,gBACAA,MAAAP,KAAAM,MAAAN,GAAAM,EACAE,EAAAX,EAAAY,yBACAA,MAAAT,KAAAQ,KACAE,EAAAb,EAAAc,SACAA,MAAAX,KAAAU,EAAA,QAAAA,EACAE,EAAAf,EAAAgB,QACAA,MAAAb,KAAAY,KACAE,EAAArC,EAAAoB,GAAA,kGAEAkB,EAAAJ,EAAA,eACAK,EAAAC,IAEAC,GAAAvB,KAAwCA,EAAAgB,GAAAQ,EAAA,EAAAxB,EAAAoB,GAAAI,EAAA,EAAAxB,GACxCyB,GAAAxB,KAAkDA,EAAAmB,GAAAI,EAAA,EAAAvB,EAElD,iBAAAyB,GACAC,IAAA,kBAAAD,GAAA,mFAAAE,KAAAC,UAAAH,GAEA,IAAAI,GAAAJ,EAAAK,aAAAL,EAAAlB,MAAA,YAEAuB,EAAAxB,EAAAuB,GAEAE,EAAAC,KAA4Cd,GAC5CZ,iBACAG,aACAE,kBACAE,2BACAE,WACAE,UACAa,cACAD,uBACAJ,qBAGAQ,EAAA,SAAAC,GAGA,QAAAD,GAAAvC,EAAAyC,GACA3E,EAAA4E,KAAAH,EAEA,IAAAI,GAAAzE,EAAAwE,KAAAF,EAAApE,KAAAsE,KAAA1C,EAAAyC,GAaA,OAXAE,GAAAjB,UACAiB,EAAAC,SACAD,EAAAE,YAAA,EACAF,EAAA9C,MAAAG,EAAAqB,IAAAoB,EAAApB,GACAsB,EAAAG,UAAAC,QAAA/C,EAAAqB,IACAsB,EAAAK,mBAAAL,EAAAK,mBAAAC,KAAAN,GAEAX,IAAAW,EAAA9C,MAAA,mBAAAwB,EAAA,wCAAAe,EAAA,0EAAAf,EAAA,mBAAAe,EAAA,MAEAO,EAAAO,eACAP,EAAAQ,mBACAR,EA8HA,MAhJArE,GAAAiE,EAAAC,GAqBAD,EAAA9D,UAAA2E,gBAAA,WACA,GAAAC,GAMAC,EAAAZ,KAAAI,UAAA,KAAAJ,KAAAY,YACA,OAAAD,MAAyBA,EAAA5B,GAAA6B,GAAAZ,KAAAD,QAAAhB,GAAA4B,GAGzBd,EAAA9D,UAAA8E,kBAAA,WACApC,IAQAuB,KAAAY,aAAAlG,eACAsF,KAAA5C,SAAAC,IAAA2C,KAAA1C,OACA0C,KAAA5C,SAAAI,uBAAAwC,KAAAc,gBAGAjB,EAAA9D,UAAAgF,0BAAA,SAAAxD,GACAyC,KAAA5C,SAAAC,IAAAE,IAGAsC,EAAA9D,UAAAyB,sBAAA,WACA,MAAAwC,MAAA5C,SAAAI,uBAGAqC,EAAA9D,UAAAiF,qBAAA,WACAhB,KAAAY,cAAAZ,KAAAY,aAAA/F,iBACAmF,KAAAY,aAAA,KACAZ,KAAAlF,iBAAAkC,EACAgD,KAAA7C,MAAA,KACA6C,KAAA5C,SAAAC,IAAAL,EACAgD,KAAA5C,SAAAI,uBAAA,GAGAqC,EAAA9D,UAAAkF,mBAAA,WAEA,MADA3B,KAAAT,EAAA,wGAAuGR,EAAA,YACvG2B,KAAAkB,iBAGArB,EAAA9D,UAAAuE,mBAAA,SAAAa,GACAnB,KAAAkB,gBAAAC,GAGAtB,EAAA9D,UAAAyE,aAAA,WACA,GAAAtD,GAAAQ,EAAAsC,KAAA7C,MAAAlC,SAAA0E,EACAK,MAAA5C,SAAAH,EAAAC,EAAA8C,KAAA7C,OACA6C,KAAA5C,SAAAC,IAAA2C,KAAA1C,QAGAuC,EAAA9D,UAAA0E,iBAAA,WACA,GAAAhC,EAAA,CAIA,GAAA2C,IAAApB,KAAAI,UAAAJ,KAAA1C,MAAA0C,KAAAD,SAAAhB,EACAiB,MAAAY,aAAA,GAAAS,GAAA,EAAArB,KAAA7C,MAAAiE,EAAApB,KAAAsB,cAAAf,KAAAP,OAQAA,KAAAlF,iBAAAkF,KAAAY,aAAA9F,iBAAAyF,KAAAP,KAAAY,gBAGAf,EAAA9D,UAAAuF,cAAA,WACAtB,KAAA5C,SAAAC,IAAA2C,KAAA1C,OAEA0C,KAAA5C,SAAAI,uBAGAwC,KAAAuB,mBAAAvB,KAAAwB,qCACAxB,KAAAyB,SAAAC,IAHA1B,KAAAlF,oBAOA+E,EAAA9D,UAAAyF,qCAAA,WAMAxB,KAAAuB,uBAAAvD,GACAgC,KAAAlF,oBAGA+E,EAAA9D,UAAAhB,aAAA,WACA,MAAAsF,SAAAL,KAAAY,eAAAZ,KAAAY,aAAA7F,gBAGA8E,EAAA9D,UAAA4F,cAAA,SAAArE,GACA,KAAAuB,GAAAN,GAAAyB,KAAAI,WAAAJ,KAAAY,cAAA,MAAAtD,EAKA,IAAAsE,GAAAhC,KAAoCtC,EAIpC,OAHAuB,KAAA+C,EAAAT,IAAAnB,KAAAM,oBACA/B,IAAAqD,EAAArD,GAAAyB,KAAAG,eACAH,KAAAI,WAAAJ,KAAAY,eAAAgB,EAAA7C,GAAAiB,KAAAY,cACAgB,GAGA/B,EAAA9D,UAAA8F,OAAA,WACA,GAAAzE,GAAA4C,KAAA5C,QAGA,IAFAA,EAAAI,uBAAA,EAEAJ,EAAArD,MACA,KAAAqD,GAAArD,KAEA,OAAAiC,QAAA8F,EAAA,eAAAzC,EAAAW,KAAA2B,cAAAvE,EAAAE,SAIAuC,GACKiC,EAAA,UAuCL,OArCAjC,GAAAR,mBACAQ,EAAAH,cACAG,EAAAT,oBACAS,EAAAX,eACAW,EAAAkC,UAAA7C,EAiCA8C,IAAAnC,EAAAR,IH/MiC/F,EAAuB,EAAImE,CACvC,IAAIwE,GAAwD1I,EAAoB,KAC5EyI,EAAgEzI,EAAoBgB,EAAE0H,GACtFC,EAA0C3I,EAAoB,KAC9D+F,EAAkD/F,EAAoBgB,EAAE2H,GACxEJ,EAAsCvI,EAAoB,GAE1D8H,GAD8C9H,EAAoBgB,EAAEuH,GAChBvI,EAAoB,MGtFjG4F,EAAA5F,EAAA,KAAAqG,EAAA5D,OAAAmG,QAAA,SAAAvF,GAAmD,OAAAC,GAAA,EAAgBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CAAO,GAAAuF,GAAAtE,UAAAjB,EAA2B,QAAAwF,KAAAD,GAA0BpG,OAAAD,UAAAgB,eAAArB,KAAA0G,EAAAC,KAAyDzF,EAAAyF,GAAAD,EAAAC,IAAiC,MAAAzF,IAiB/OqC,EAAA,EACAyC,MH0WMY,IACA,SAAUjJ,EAAQC,EAAqBC,GAE7C,YIvWA,SAAAgJ,GAAA7F,GACA,mBAAAA,IAAA,OAAAA,EAAA,QAGA,KAFA,GAAA8F,GAAA9F,EAEA,OAAAV,OAAAyG,eAAAD,IACAA,EAAAxG,OAAAyG,eAAAD,EAGA,OAAAxG,QAAAyG,eAAA/F,KAAA8F,EA6BA,QAAAE,GAAAC,EAAAC,EAAAC,GA8BA,QAAAC,KACAC,IAAAC,IACAD,EAAAC,EAAAC,SAUA,QAAA/H,KACA,GAAAgI,EACA,SAAAlJ,OAAA,uMAGA,OAAAmJ,GA2BA,QAAAnI,GAAAoI,GACA,qBAAAA,GACA,SAAApJ,OAAA,0CAGA,IAAAkJ,EACA,SAAAlJ,OAAA,8TAGA,IAAAe,IAAA,CAGA,OAFA+H,KACAC,EAAAM,KAAAD,GACA,WACA,GAAArI,EAAA,CAIA,GAAAmI,EACA,SAAAlJ,OAAA,mKAGAe,IAAA,EACA+H,GACA,IAAAQ,GAAAP,EAAAjG,QAAAsG,EACAL,GAAAQ,OAAAD,EAAA,KA8BA,QAAArI,GAAAuI,GACA,IAAAjB,EAAAiB,GACA,SAAAxJ,OAAA,0EAGA,aAAAwJ,EAAAC,KACA,SAAAzJ,OAAA,qFAGA,IAAAkJ,EACA,SAAAlJ,OAAA,qCAGA,KACAkJ,GAAA,EACAC,EAAAO,EAAAP,EAAAK,GACK,QACLN,GAAA,EAKA,OAFAS,GAAAX,EAAAD,EAEAlG,EAAA,EAAmBA,EAAA8G,EAAA5F,OAAsBlB,IAAA,EAEzCuG,EADAO,EAAA9G,MAIA,MAAA2G,GAcA,QAAAI,GAAAC,GACA,qBAAAA,GACA,SAAA7J,OAAA,6CAGA0J,GAAAG,EACA5I,GACAwI,KAAAK,EAAAC,UAWA,QAAAC,KACA,GAAAnG,GAEAoG,EAAAjJ,CACA,OAAA6C,IASA7C,UAAA,SAAAkJ,GAKA,QAAAC,KACAD,EAAAE,MACAF,EAAAE,KAAAlJ,KANA,mBAAAgJ,IAAA,OAAAA,EACA,SAAA3I,WAAA,yCAWA,OAFA4I,MAGAE,YAFAJ,EAAAE,MAKKtG,EAAAyG,EAAA,cACL,MAAAtE,OACKnC,EA1NL,GAAA8C,EAEA,sBAAAiC,IAAA,kBAAAC,IAAA,kBAAAA,IAAA,kBAAA/E,WAAA,GACA,SAAA9D,OAAA,qJAQA,IALA,kBAAA4I,QAAA,KAAAC,IACAA,EAAAD,EACAA,MAAA5E,QAGA,KAAA6E,EAAA,CACA,qBAAAA,GACA,SAAA7I,OAAA,0CAGA,OAAA6I,GAAAH,GAAAC,EAAAC,GAGA,qBAAAD,GACA,SAAA3I,OAAA,yCAGA,IAAA0J,GAAAf,EACAQ,EAAAP,EACAI,KACAD,EAAAC,EACAE,GAAA,CAwMA,OAHAjI,IACAwI,KAAAK,EAAAS,OAEA5D,GACA1F,WACAD,YACAE,WACA0I,kBACGjD,EAAA2D,EAAA,GAAAN,EAAArD,EA0BH,QAAA6D,GAAAnC,EAAAmB,GACA,GAAAiB,GAAAjB,KAAAC,IAEA,iBADAgB,GAAA,WAAAC,OAAAD,GAAA,kBACA,cAAApC,EAAA,iLA4BA,QAAAsC,GAAAC,GACA5I,OAAAW,KAAAiI,GAAAC,QAAA,SAAAxC,GACA,GAAAM,GAAAiC,EAAAvC,EAKA,aAJAM,MAAA3E,IACAyF,KAAAK,EAAAS,OAIA,SAAAvK,OAAA,YAAAqI,EAAA,gRAGA,QAEK,KAFLM,MAAA3E,IACAyF,KAAAK,EAAAgB,yBAEA,SAAA9K,OAAA,YAAAqI,EAAA,6EAAAyB,EAAAS,KAAA,iTAsBA,QAAAQ,GAAAH,GAIA,OAHAI,GAAAhJ,OAAAW,KAAAiI,GACAK,KAEApI,EAAA,EAAiBA,EAAAmI,EAAAjH,OAAwBlB,IAAA,CACzC,GAAAwF,GAAA2C,EAAAnI,EAQA,mBAAA+H,GAAAvC,KACA4C,EAAA5C,GAAAuC,EAAAvC,IAIA,GAOA6C,GAPAC,EAAAnJ,OAAAW,KAAAsI,EASA,KACAN,EAAAM,GACG,MAAAhL,GACHiL,EAAAjL,EAGA,gBAAAiG,EAAAsD,GAKA,OAJA,KAAAtD,IACAA,MAGAgF,EACA,KAAAA,EAcA,QAHAE,IAAA,EACAC,KAEAC,EAAA,EAAoBA,EAAAH,EAAApH,OAA8BuH,IAAA,CAClD,GAAAC,GAAAJ,EAAAG,GACA3C,EAAAsC,EAAAM,GACAC,EAAAtF,EAAAqF,GACAE,EAAA9C,EAAA6C,EAAAhC,EAEA,aAAAiC,EAAA,CACA,GAAAC,GAAAlB,EAAAe,EAAA/B,EACA,UAAAxJ,OAAA0L,GAGAL,EAAAE,GAAAE,EACAL,KAAAK,IAAAD,EAGA,MAAAJ,GAAAC,EAAAnF,GAIA,QAAAyF,GAAAC,EAAA3K,GACA,kBACA,MAAAA,GAAA2K,EAAAC,MAAA7F,KAAAlC,aA0BA,QAAAgI,GAAAC,EAAA9K,GACA,qBAAA8K,GACA,MAAAJ,GAAAI,EAAA9K,EAGA,oBAAA8K,IAAA,OAAAA,EACA,SAAA/L,OAAA,iFAAA+L,EAAA,aAAAA,IAAA,6FAMA,QAHApJ,GAAAX,OAAAW,KAAAoJ,GACAC,KAEAnJ,EAAA,EAAiBA,EAAAF,EAAAoB,OAAiBlB,IAAA,CAClC,GAAAwF,GAAA1F,EAAAE,GACA+I,EAAAG,EAAA1D,EAEA,mBAAAuD,KACAI,EAAA3D,GAAAsD,EAAAC,EAAA3K,IAIA,MAAA+K,GAGA,QAAAC,GAAAvJ,EAAA2F,EAAAlG,GAYA,MAXAkG,KAAA3F,GACAV,OAAAkK,eAAAxJ,EAAA2F,GACAlG,QACAC,YAAA,EACAE,cAAA,EACAD,UAAA,IAGAK,EAAA2F,GAAAlG,EAGAO,EAGA,QAAAyJ,GAAAvJ,GACA,OAAAC,GAAA,EAAiBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CACvC,GAAAuF,GAAA,MAAAtE,UAAAjB,GAAAiB,UAAAjB,MACAuJ,EAAApK,OAAAW,KAAAyF,EAEA,mBAAApG,QAAAqK,wBACAD,IAAAE,OAAAtK,OAAAqK,sBAAAjE,GAAAmE,OAAA,SAAAC,GACA,MAAAxK,QAAAyK,yBAAArE,EAAAoE,GAAApK,eAIAgK,EAAAvB,QAAA,SAAAxC,GACA4D,EAAArJ,EAAAyF,EAAAD,EAAAC,MAIA,MAAAzF,GAaA,QAAA8J,KACA,OAAAC,GAAA7I,UAAAC,OAAA6I,EAAA,GAAAC,OAAAF,GAAApB,EAAA,EAAsEA,EAAAoB,EAAapB,IACnFqB,EAAArB,GAAAzH,UAAAyH,EAGA,YAAAqB,EAAA7I,OACA,SAAA+I,GACA,MAAAA,IAIA,IAAAF,EAAA7I,OACA6I,EAAA,GAGAA,EAAAG,OAAA,SAAAvM,EAAAwM,GACA,kBACA,MAAAxM,GAAAwM,EAAAnB,UAAA,GAAA/H,eAsBA,QAAAmJ,KACA,OAAAN,GAAA7I,UAAAC,OAAAmJ,EAAA,GAAAL,OAAAF,GAAApB,EAAA,EAA4EA,EAAAoB,EAAapB,IACzF2B,EAAA3B,GAAAzH,UAAAyH,EAGA,iBAAA7C,GACA,kBACA,GAAAvF,GAAAuF,EAAAmD,UAAA,GAAA/H,WAEAqJ,EAAA,WACA,SAAAnN,OAAA,2HAGAoN,GACAlM,SAAAiC,EAAAjC,SACAD,SAAA,WACA,MAAAkM,GAAAtB,UAAA,GAAA/H,aAGAuJ,EAAAH,EAAAI,IAAA,SAAAC,GACA,MAAAA,GAAAH,IAGA,OADAD,GAAAT,EAAAb,UAAA,GAAAwB,GAAAlK,EAAAlC,UACAkL,KAA6BhJ,GAC7BlC,SAAAkM,MJ1O+B5N,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOoJ,KACpEnJ,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOyL,KACpExL,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOwM,KACpEvM,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAO2N,KACpE1N,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOoN,IAE9E,IAAIpC,GAAkD/K,EAAoB,KI9X/FiO,EAAA,WACA,MAAAC,MAAAC,SAAAC,SAAA,IAAAC,UAAA,GAAAC,MAAA,IAAAC,KAAA,MAGAhE,GACAS,KAAA,eAAAiD,IACAzD,QAAA,kBAAAyD,IACA1C,qBAAA,WACA,qCAAA0C,OJu/BMO,IACA,SAAU1O,EAAQC,EAAqBC,GAE7C,YKxgCA,SAAAyO,GAAAC,GACA,gBAAAhN,EAAAiN,GAGA,QAAAC,KACA,MAAAC,GAHA,GAAAA,GAAAH,EAAAhN,EAAAiN,EAMA,OADAC,GAAAE,mBAAA,EACAF,GAWA,QAAAG,GAAAC,GACA,cAAAA,EAAAF,uBAAArK,KAAAuK,EAAAF,kBAAAhI,QAAAkI,EAAAF,mBAAA,IAAAE,EAAAxK,OAeA,QAAAyK,GAAAD,EAAAlK,GACA,gBAAApD,EAAA4C,GACA,GAEA4K,IAFA5K,EAAA6B,YAEA,SAAAgJ,EAAAC,GACA,MAAAF,GAAAJ,kBAAAI,EAAAF,WAAAG,EAAAC,GAAAF,EAAAF,WAAAG,IAsBA,OAlBAD,GAAAJ,mBAAA,EAEAI,EAAAF,WAAA,SAAAG,EAAAC,GACAF,EAAAF,aACAE,EAAAJ,kBAAAC,EAAAC,EACA,IAAAjL,GAAAmL,EAAAC,EAAAC,EAUA,OARA,kBAAArL,KACAmL,EAAAF,WAAAjL,EACAmL,EAAAJ,kBAAAC,EAAAhL,GACAA,EAAAmL,EAAAC,EAAAC,IAKArL,GAGAmL,GL28BiCnP,EAAuB,EAAI0O,EAE3B1O,EAAuB,EAAIkP,CACsBjP,GAAoB,MAuEhGqP,IACA,SAAUvP,EAAQC,EAAqBC,GAE7C,YAEiFA,GAAoB,KACnCA,EAAoB,MAYhFsP,IACA,SAAUxP,EAAQC,EAAqBC,GAE7C,YACqB,IAAIuP,GAAyCvP,EAAoB,KMxmCtFwP,EAAAD,EAAA,EAAAC,MAEAzP,GAAA,KNinCM0P,IACA,SAAU3P,EAAQC,EAAqBC,GAE7C,YO9mCA,SAAS0P,GAAQC,GACf,MAAO,UAACjO,GAGN,MAFAA,GAASkO,EAAaD,IAEfE,EAAA,EAAcF,GAAIG,KAAK,SAACC,GAC7BrO,EAASsO,EAAeL,EAAII,KAC3B,SAACvP,GACFkB,EAASuO,EAAeN,EAAInP,OAYlC,QAAS0P,GAAYP,GAAgB,GAAZQ,GAAY5L,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,GAAH,CAChC,OAAO,UAAC7C,GAGN,MAFAA,GAAS0O,EAAiBT,IAEnBE,EAAA,EAAsBF,GAC3BQ,OAAQA,IACPL,KAAK,SAAAxL,GAAqB,GAAlB+L,GAAkB/L,EAAlB+L,MAAOC,EAAWhM,EAAXgM,KACVC,EAAUJ,EAASE,EAAM7L,MAC/B9C,GAAS8O,EAAmBb,EAAIU,EAAOC,IAInCC,EAAUD,EAAKG,aAAeF,EAAUG,EAAA,GAC1ChP,EAASwO,EAAYP,EAAIY,KAE1B,SAAC/P,GACFkB,EAASiP,EAAmBhB,EAAInP,OAQ/B,QAASoQ,GAAejB,GAC7B,MAAO,UAACjO,EAAUC,GAAa,GAAAkP,GACDlP,IAApBmP,EADqBD,EACrBC,SAAUC,EADWF,EACXE,KAElB,IAAID,EAASE,UACXtP,EAASuP,SACJ,CACL,GAAMC,GAAOH,EAAMpB,EAEnBjO,GAASyP,EAAaxB,IAEjBuB,GACHxP,EAASwO,EAAYP,GAIE,KAAPA,GAEhBjO,EAASgO,EAAQC,MASlB,QAASyB,GAASzB,GACvB,MAAO,UAACjO,EAAUC,GAAa,GAAA0P,GACX1P,IAAVoP,EADqBM,EACrBN,MACFG,EAAOH,EAAMpB,EAEnBjO,GAAS4P,EAAgB3B,KAErBuB,GAASA,EAAKK,YAAgBL,EAAKM,SAASC,MAAQ,GACtD/P,EAASwO,EAAYP,KPiiCI3P,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOkR,KAClElR,EAAuB,EAAI6Q,EAC7B5Q,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAO2R,KAClE3R,EAAuB,EAAIqR,CACvC,IAAIvB,GAA2C7P,EAAoB,KAC/D2R,EAA+C3R,EAAoB,KACnE0Q,EAAsD1Q,EAAoB,IO5nC7F4P,EAAenN,OAAAkP,EAAA,GAAa,kBAC5B3B,EAAiBvN,OAAAkP,EAAA,GAAa,mBAAoB,SAAChC,EAAII,GAAL,OAAiBJ,KAAII,UACvEE,EAAiBxN,OAAAkP,EAAA,GAAa,mBAAoB,SAAChC,EAAInP,GAAL,OAAkBmP,KAAInP,WAiBxE4P,EAAmB3N,OAAAkP,EAAA,GAAa,qBAAsB,SAAAhC,GAAA,OAASA,QAC/Da,EAAqB/N,OAAAkP,EAAA,GAAa,uBAAwB,SAAChC,EAAIU,EAAOC,GAAZ,OAAwBX,KAAIU,QAAOC,UAC7FK,EAAqBlO,OAAAkP,EAAA,GAAa,uBAAwB,SAAChC,EAAInP,GAAL,OAAkBmP,KAAInP,WA0BhF2Q,EAAe1O,OAAAkP,EAAA,GAAa,gBAAiB,SAAAhC,GAAA,OAASA,QAC/CsB,EAAgBxO,OAAAkP,EAAA,GAAa,kBA0B7BD,EAAUjP,OAAAkP,EAAA,GAAa,YAC9BL,EAAkB7O,OAAAkP,EAAA,GAAa,YAAa,SAAAhC,GAAA,OAASA,SPyqCrDiC,IACA,SAAU9R,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEE,EAAsD/R,EAAoB,IAC1EgS,EAAsDhS,EAAoB,IQxvC7FiS,EAAiB,iBACrBH,GAAA7Q,EAAAiR,cAAA,YACEJ,EAAA7Q,EAAAiR,cAACF,EAAA,GAAKpN,KAAK,UAAUuN,UAAU,cADjC,IACoDJ,EAAA,EAAQK,SAI9DrS,GAAA,KRuwCMsS,IACA,SAAUvS,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOuS,KACpEtS,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOwS,IAC9E,IAAIV,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEW,EAA0ExS,EAAoB,KAC9FyS,EAAkFzS,EAAoBgB,EAAEwR,GSrxCpHF,EAAO,OACPC,EAAM,MAKbG,EAAa,SAAApO,GAAA,GACjBM,GADiBN,EACjBM,KACA+N,EAFiBrO,EAEjBqO,UACAR,EAHiB7N,EAGjB6N,UACAS,EAJiBtO,EAIjBsO,SACApB,EALiBlN,EAKjBkN,SACAqB,EANiBvO,EAMjBuO,KANiB,OAQjBf,GAAA7Q,EAAAiR,cAACO,EAAAxR,GACC0R,UAAWA,EACXG,uBAAwBF,EACxBG,uBAAwBH,EACxBI,eAAA,gBAAgCpO,EAChCuN,UAAWA,EACXc,aAAYJ,GAEXrB,GAaLkB,GAAWQ,cACTP,UAAW,MACXnB,SAAU,KACVW,UAAW,KACXS,SA1C0B,IA2C1BC,MAAO,MAGT9S,EAAA,KT0xCMoT,IACA,SAAUrT,EAAQsT,EAASpT,GAEjC,YU90CAyC,QAAAkK,eAAAyG,EAAA,cACAxQ,OAAA,IAEAwQ,EAAAC,UAAA,mBAAAC,iBAAAC,WAAAD,OAAAC,SAAArB,eACApS,EAAAsT,UAAA,SVq1CMI,IACA,SAAU1T,EAAQsT,EAASpT,GAEjC,YWh1CA,SAAAyT,GAAAtQ,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,GAE7E,QAAAwQ,GAAAC,GACA,GAAAC,GAAA,aAAAD,EAAA,UACAE,EAAA,aAAAF,CAEA,iBAAA7P,GAEA,GAAAA,EAAA+P,GAAA,CAEA,SAAA/P,EAAA8P,GACA,UAAApT,OAAAoT,EAAA,qNAGO,oBAAA9P,GAAA8P,GACP,UAAApT,OAAAoT,EAAA,uCAIA,aA/BAT,EAAAM,YAAA,EACAN,EAAAW,cAAAtP,GACA2O,EAAAO,mBAEA,IAAAK,GAAAhU,EAAA,GAIAiU,GAFAR,EAAAO,GAEAhU,EAAA,KAEAkU,EAAAT,EAAAQ,EAyBAb,GAAAW,UAAAG,EAAAb,QAAAc,WAAAD,EAAAb,QAAAe,OAAAF,EAAAb,QAAAnS,OACAmT,MAAAH,EAAAb,QAAAe,OACAE,MAAAJ,EAAAb,QAAAe,OACAG,OAAAL,EAAAb,QAAAe,SACCF,EAAAb,QAAAnS,OACDmT,MAAAH,EAAAb,QAAAe,OACAI,YAAAN,EAAAb,QAAAe,OACAE,MAAAJ,EAAAb,QAAAe,OACAK,YAAAP,EAAAb,QAAAe,OACAM,OAAAR,EAAAb,QAAAe,OACAO,aAAAT,EAAAb,QAAAe,YXo2CMQ,IACA,SAAU9U,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GYl5CvFgD,EAAoB,SAAAvQ,GAAA,GAAGwQ,GAAHxQ,EAAGwQ,MAAH,OACxBhD,GAAA7Q,EAAAiR,cAAA,QAAMC,UAAA,mBAA6B2C,EAAOC,KAAO,kBAAoB,KAClED,EAAOA,QAWZ/U,GAAA,KZy5CMiV,IACA,SAAUlV,EAAQC,EAAqBC,GAE7C,YACAyC,QAAOkK,eAAe5M,EAAqB,cAAgB6C,OAAO,GAC7C,IAAIiP,GAAsC7R,EAAoB,GAE1DiV,GAD8CjV,EAAoBgB,EAAE6Q,GAC1B7R,EAAoB,KAE9DkV,GADkDlV,EAAoBgB,EAAEiU,GACzBjV,EAAoB,Kaj6C5FsT,QAAO6B,QAAQC,YACbC,KAAAH,EAAA,EACAI,OAAAJ,EAAA,GAMF3B,SAASgC,iBAAiB,mBAAoB,WAC5C,GAAMC,GAAejC,SAASkC,cAAc,wBACtCC,EAAanC,SAASkC,cAAc,6BAEtCD,IAAgBE,GAClBjT,OAAAyS,EAAA,GAAaM,EAAcE,GAG7BjT,OAAAyS,EAAA,KACAzS,OAAAyS,EAAA,KACAzS,OAAAyS,EAAA,Qbo7CIS,IACA,SAAU7V,EAAQC,EAAqBC,GAE7C,YACqB,IACI4V,IAD0D5V,EAAoB,IACzBA,EAAoB,MACzEgS,EAAsDhS,EAAoB,IAE1E6V,GAD0E7V,EAAoB,KACpCA,EAAoB,MAG9E8V,GAFgF9V,EAAoB,KAClCA,EAAoB,KACzCA,EAAoB,MACjE+V,EAAuD/V,EAAoB,KAC3EgW,EAAgEhW,EAAoB,IAI5EA,GAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOiS,GAAuD,IAE3HhS,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAO8V,GAA2D,IAG/H7V,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAO6V,GAAsD,IAC1H5V,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAO+V,GAA8C,IAClH9V,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOgW,GAAwD,Icl/C7J/V,EAAAG,EAAAJ,EAAA,qBAAAiW,GAAA,KdwgDMC,IACA,SAAUnW,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOmW,IAC9E,IAAIrE,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEoD,EAA0CjV,EAAoB,IAC9DmW,EAAkDnW,EAAoBgB,EAAEiU,GACxEmB,EAA4CpW,EAAoB,KAChEqW,EAAsCrW,EAAoB,KAC1DsW,EAA4CtW,EAAoB,KAChEuW,EAA0CvW,EAAoB,KAC9DwW,EAAgDxW,EAAoB,KACpEyW,EAAmDzW,EAAoB,KACvE0W,EAAgD1W,EAAoB,KexgDvFkW,EAAe,SAACV,EAAcE,GAClC,GAAMiB,GAAclU,OAAA4T,EAAA,IAClBvF,SAAA2F,EAAA,EACA1F,MAAA2F,EAAA,IAGI1I,GACJsI,EAAA,GAQI1S,EAAQnB,OAAA4T,EAAA,GAAYM,KAAiBlU,OAAA4T,EAAA,GACzCA,EAAA,EAAA3I,aAAmBM,GAEnBsF,OAAOsD,6BAA+BtD,OAAOsD,+BAAiC,SAAAxV,GAAA,MAAQA,MAGlFyV,EAAYC,SAASpB,EAAWqB,aAAa,4BAA6B,GAEhFZ,GAAAlV,EAASqH,OACPwJ,EAAA7Q,EAAAiR,cAACkE,EAAA,GAASxS,MAAOA,GACfkO,EAAA7Q,EAAAiR,cAACsE,EAAA,GAAeK,UAAWA,GAAYnB,EAAWsB,cAEnDtB,EAAWuB,YAEdd,EAAAlV,EAASqH,OACPwJ,EAAA7Q,EAAAiR,cAACkE,EAAA,GAASxS,MAAOA,GACfkO,EAAA7Q,EAAAiR,cAACqE,EAAA,EAAD,OAEDf,GAGUe,GAAf,GfiiDMW,IACA,SAAUpX,EAAQC,EAAqBC,GAE7C,YgBvlDA,SAAA6B,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAE3F,QAAAC,GAAAC,EAAAC,GAAiD,IAAAD,EAAa,SAAAE,gBAAA,4DAAyF,QAAAD,GAAA,gBAAAA,IAAA,kBAAAA,GAAAD,EAAAC,EAEvJ,QAAAE,GAAAC,EAAAC,GAA0C,qBAAAA,IAAA,OAAAA,EAA+D,SAAAP,WAAA,iEAAAO,GAAuGD,GAAAE,UAAAC,OAAAC,OAAAH,KAAAC,WAAyEG,aAAeC,MAAAN,EAAAO,YAAA,EAAAC,UAAA,EAAAC,cAAA,KAA6ER,IAAAE,OAAAO,eAAAP,OAAAO,eAAAV,EAAAC,GAAAD,EAAAW,UAAAV,GhBqlDhW,GAAIsP,GAAsC7R,EAAoB,GAE1DmX,GAD8CnX,EAAoBgB,EAAE6Q,GACzB7R,EAAoB,KAC/DoX,EAAmDpX,EAAoBgB,EAAEmW,GACzEE,EAAiDrX,EAAoB,IgB7lD9FA,GAAA,IAuEAD,GAAA,EAlDA,WACA,GAAAuX,GAEAlS,EAAAb,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,WACAgT,EAAAhT,UAAA,GAEAiB,EAAA+R,GAAAnS,EAAA,eAEAoS,EAAA,SAAAjR,GASA,QAAAiR,GAAAzT,EAAAyC,GACA3E,EAAA4E,KAAA+Q,EAEA,IAAA9Q,GAAAzE,EAAAwE,KAAAF,EAAApE,KAAAsE,KAAA1C,EAAAyC,GAGA,OADAE,GAAAtB,GAAArB,EAAAH,MACA8C,EAOA,MArBArE,GAAAmV,EAAAjR,GAEAiR,EAAAhV,UAAA2E,gBAAA,WACA,GAAA7C,EAEA,OAAAA,MAAsBA,EAAAc,GAAAqB,KAAArB,GAAAd,EAAAkB,GAAA,KAAAlB,GAYtBkT,EAAAhV,UAAA8F,OAAA,WACA,MAAAuJ,GAAA,SAAA4F,KAAAhR,KAAA1C,MAAAyN,WAGAgG,GACG3F,EAAA,UAgBH,OANA2F,GAAAhP,WACA5E,MAAAyT,EAAA,EAAAhW,WACAmQ,SAAA4F,EAAAnW,EAAAyW,QAAArW,YAEAmW,EAAA3R,mBAAAyR,KAA0DA,EAAAlS,GAAAiS,EAAA,EAAAhW,WAAAiW,EAAA9R,GAAA6R,EAAA,EAAAC,GAE1DE,MhBsmDMG,IACA,SAAU7X,EAAQsT,EAASpT,GAEjC,YiBvqDA,IAAA4X,IACA/R,mBAAA,EACAF,cAAA,EACAuN,cAAA,EACA/M,aAAA,EACA0R,iBAAA,EACAC,QAAA,EACAtP,WAAA,EACA0B,MAAA,GAGA6N,GACAnT,MAAA,EACAJ,QAAA,EACAhC,WAAA,EACAwV,QAAA,EACAC,QAAA,EACA1T,WAAA,EACA2T,OAAA,GAGAvL,EAAAlK,OAAAkK,eACAwL,EAAA1V,OAAA0V,oBACArL,EAAArK,OAAAqK,sBACAI,EAAAzK,OAAAyK,yBACAhE,EAAAzG,OAAAyG,eACAkP,EAAAlP,KAAAzG,OAEA3C,GAAAsT,QAAA,QAAAiF,GAAAC,EAAAC,EAAAC,GACA,mBAAAD,GAAA,CAEA,GAAAH,EAAA,CACA,GAAAK,GAAAvP,EAAAqP,EACAE,QAAAL,GACAC,EAAAC,EAAAG,EAAAD,GAIA,GAAApV,GAAA+U,EAAAI,EAEAzL,KACA1J,IAAA2J,OAAAD,EAAAyL,IAGA,QAAAjV,GAAA,EAAuBA,EAAAF,EAAAoB,SAAiBlB,EAAA,CACxC,GAAAwF,GAAA1F,EAAAE,EACA,MAAAsU,EAAA9O,IAAAiP,EAAAjP,IAAA0P,KAAA1P,IAAA,CACA,GAAA4P,GAAAxL,EAAAqL,EAAAzP,EACA,KACA6D,EAAA2L,EAAAxP,EAAA4P,GACiB,MAAAhY,MAIjB,MAAA4X,GAGA,MAAAA,KjBorDMK,IACA,SAAU7Y,EAAQsT,EAASpT,GAEjC,YkBhuDA,IAAA4Y,GAAA,SAAAC,EAAAC,EAAA7X,EAAAwM,EAAAsL,EAAA5Y,EAAAO,EAAAsY,GAOA,IAAAH,EAAA,CACA,GAAArY,EACA,QAAAiE,KAAAqU,EACAtY,EAAA,GAAAC,OACA,qIAGK,CACL,GAAAwY,IAAAhY,EAAAwM,EAAAsL,EAAA5Y,EAAAO,EAAAsY,GACAE,EAAA,CACA1Y,GAAA,GAAAC,OACAqY,EAAAK,QAAA,iBAA0C,MAAAF,GAAAC,QAE1C1Y,EAAAoE,KAAA,sBAIA,KADApE,GAAA4Y,YAAA,EACA5Y,GAIAV,GAAAsT,QAAAwF,GlB4vDMS,IACA,SAAUvZ,EAAQC,EAAqBC,GAE7C,YmBjzDA,SAAA6B,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAW3F,QAAAsX,KAGA,GAAAC,MACA1O,IAEA,QACA2O,MAAA,WACA3O,EAAA4O,EACAF,EAAAE,GAEAC,OAAA,WAEA,OADAtP,GAAAmP,EAAA1O,EACAvH,EAAA,EAAqBA,EAAA8G,EAAA5F,OAAsBlB,IAC3C8G,EAAA9G,MAGAqW,IAAA,WACA,MAAA9O,IAEApJ,UAAA,SAAAoI,GACA,GAAArI,IAAA,CAIA,OAHAqJ,KAAA0O,IAAA1O,EAAA0O,EAAA7P,SACAmB,EAAAf,KAAAD,GAEA,WACArI,GAAA+X,IAAAE,IACAjY,GAAA,EAEAqJ,IAAA0O,IAAA1O,EAAA0O,EAAA7P,SACAmB,EAAAb,OAAAa,EAAAtH,QAAAsG,GAAA,OAzCA7J,EAAAG,EAAAJ,EAAA,qBAAA6Z,IAMA,IAAAH,GAAA,KACAI,GACAH,OAAA,cAuCAE,EAAA,WACA,QAAAA,GAAAhW,EAAAiE,EAAAE,GACAlG,EAAA4E,KAAAmT,GAEAnT,KAAA7C,QACA6C,KAAAoB,YACApB,KAAAsB,gBACAtB,KAAAqE,YAAA,KACArE,KAAA2D,UAAAyP,EAiCA,MA9BAD,GAAApX,UAAAsX,aAAA,SAAAjQ,GAEA,MADApD,MAAAtF,eACAsF,KAAA2D,UAAA3I,UAAAoI,IAGA+P,EAAApX,UAAAjB,iBAAA,WACAkF,KAAA2D,UAAAsP,UAGAE,EAAApX,UAAAhB,aAAA,WACA,MAAAsF,SAAAL,KAAAqE,cAGA8O,EAAApX,UAAArB,aAAA,WACAsF,KAAAqE,cACArE,KAAAqE,YAAArE,KAAAoB,UAAApB,KAAAoB,UAAAiS,aAAArT,KAAAsB,eAAAtB,KAAA7C,MAAAnC,UAAAgF,KAAAsB,eAEAtB,KAAA2D,UAAAkP,MAIAM,EAAApX,UAAAlB,eAAA,WACAmF,KAAAqE,cACArE,KAAAqE,cACArE,KAAAqE,YAAA,KACArE,KAAA2D,UAAAoP,QACA/S,KAAA2D,UAAAyP,IAIAD,MnB0zDMG,IACA,SAAUja,EAAQC,EAAqBC,GAE7C,YoBn5DA,SAAAkD,GAAAC,EAAAC,GAA8C,GAAAC,KAAiB,QAAAC,KAAAH,GAAqBC,EAAAG,QAAAD,IAAA,GAAoCb,OAAAD,UAAAgB,eAAArB,KAAAgB,EAAAG,KAA6DD,EAAAC,GAAAH,EAAAG,GAAsB,OAAAD,GA0B3M,QAAA2W,GAAAzM,EAAA0M,EAAArV,GACA,OAAAtB,GAAA2W,EAAAzV,OAAA,EAAoClB,GAAA,EAAQA,IAAA,CAC5C,GAAA4W,GAAAD,EAAA3W,GAAAiK,EACA,IAAA2M,EAAA,MAAAA,GAGA,gBAAAxY,EAAAiN,GACA,SAAAlO,OAAA,+BAAA8M,GAAA,QAAA3I,EAAA,uCAAA+J,EAAAzI,qBAAA,MAIA,QAAAiU,GAAAlZ,EAAAwM,GACA,MAAAxM,KAAAwM,EpB+2DqB,GAAI2M,GAA4Dpa,EAAoB,KAChFqa,EAAoDra,EAAoB,KACxEsa,EAAoDta,EAAoB,KACxEua,EAAiDva,EAAoB,KACrEwa,EAA4Cxa,EAAoB,KoB35DzFya,EAAAza,EAAA,KAAAqG,EAAA5D,OAAAmG,QAAA,SAAAvF,GAAmD,OAAAC,GAAA,EAAgBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CAAO,GAAAuF,GAAAtE,UAAAjB,EAA2B,QAAAwF,KAAAD,GAA0BpG,OAAAD,UAAAgB,eAAArB,KAAA0G,EAAAC,KAAyDzF,EAAAyF,GAAAD,EAAAC,IAAiC,MAAAzF,GAsG/OtD,GAAA,EAzDA,WACA,GAAAuE,GAAAC,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,MACAmW,EAAApW,EAAAqW,WACAA,MAAAlW,KAAAiW,EAAAN,EAAA,EAAAM,EACAE,EAAAtW,EAAAuW,yBACAA,MAAApW,KAAAmW,EAAAL,EAAA,EAAAK,EACAE,EAAAxW,EAAAyW,4BACAA,MAAAtW,KAAAqW,EAAAR,EAAA,EAAAQ,EACAE,EAAA1W,EAAA2W,oBACAA,MAAAxW,KAAAuW,EAAAR,EAAA,EAAAQ,EACAE,EAAA5W,EAAAH,gBACAA,MAAAM,KAAAyW,EAAAT,EAAA,EAAAS,CAEA,iBAAAC,EAAAC,EAAAC,GACA,GAAAjU,GAAA7C,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,MACA+W,EAAAlU,EAAAmU,KACAA,MAAA9W,KAAA6W,KACAE,EAAApU,EAAAqU,eACAA,MAAAhX,KAAA+W,EAAArB,EAAAqB,EACAE,EAAAtU,EAAAuU,iBACAA,MAAAlX,KAAAiX,EAAArB,EAAA,EAAAqB,EACAE,EAAAxU,EAAAyU,mBACAA,MAAApX,KAAAmX,EAAAvB,EAAA,EAAAuB,EACAE,EAAA1U,EAAA2U,oBACAA,MAAAtX,KAAAqX,EAAAzB,EAAA,EAAAyB,EACAE,EAAA9Y,EAAAkE,GAAA,wFAEA6U,EAAAjC,EAAAmB,EAAAN,EAAA,mBACAqB,EAAAlC,EAAAoB,EAAAL,EAAA,sBACAoB,EAAAnC,EAAAqB,EAAAJ,EAAA,aAEA,OAAAN,GAAAxW,EAAAkC,GAEAvB,WAAA,UAGAH,eAAA,SAAAC,GACA,iBAAAA,EAAA,KAIAM,yBAAA4B,QAAAqU,GAGAc,sBACAC,yBACAC,iBACAZ,OACAE,iBACAE,mBACAE,qBACAE,uBAEKC,SpBq6DCI,IACA,SAAUtc,EAAQC,EAAqBC,GAE7C,YqBxgEA,SAAAqc,GAAAC,EAAAC,GACA,MAAAD,KAAAC,EACA,IAAAD,GAAA,IAAAC,GAAA,EAAAD,GAAA,EAAAC,EAEAD,OAAAC,MAIA,QAAAC,GAAAC,EAAAC,GACA,GAAAL,EAAAI,EAAAC,GAAA,QAEA,oBAAAD,IAAA,OAAAA,GAAA,gBAAAC,IAAA,OAAAA,EACA,QAGA,IAAAC,GAAAla,OAAAW,KAAAqZ,GACAG,EAAAna,OAAAW,KAAAsZ,EAEA,IAAAC,EAAAnY,SAAAoY,EAAApY,OAAA,QAEA,QAAAlB,GAAA,EAAiBA,EAAAqZ,EAAAnY,OAAkBlB,IACnC,IAAAuZ,EAAA1a,KAAAua,EAAAC,EAAArZ,MAAA+Y,EAAAI,EAAAE,EAAArZ,IAAAoZ,EAAAC,EAAArZ,KACA,QAIA,UA5BAvD,EAAA,EAAAyc,CAAA,IAAAK,GAAApa,OAAAD,UAAAgB,gBrB6iEMsZ,IACA,SAAUhd,EAAQC,EAAqBC,GAE7C,YsB7iEA,SAAA+c,GAAA3B,GACA,wBAAAA,GAAA3Y,OAAAua,EAAA,GAAA5B,EAAA,0BAAA3W,GAGA,QAAAwY,GAAA7B,GACA,MAAAA,OAEG3W,GAFHhC,OAAAua,EAAA,YAAAtb,GACA,OAAYA,cAIZ,QAAAwb,GAAA9B,GACA,MAAAA,IAAA,gBAAAA,GAAA3Y,OAAAua,EAAA,YAAAtb,GACA,MAAAe,QAAA0a,EAAA,GAAA/B,EAAA1Z,SACG+C,GtBoiEkB,GAAI0Y,GAAsCnd,EAAoB,KAC1Dgd,EAAgDhd,EAAoB,IsBliE7FD,GAAA,GAAAgd,EAAAE,EAAAC,ItB0jEME,IACA,SAAUtd,EAAQC,EAAqBC,GAE7C,cAC4B,SAASqd,EAAQvd,GuBjlE7C,GAGAwd,GAHAC,EAAAvd,EAAA,IAMAsd,GADA,mBAAApb,MACAA,KACC,mBAAAoR,QACDA,WACC,KAAA+J,EACDA,EAEAvd,CAKA,IAAAoa,GAAAzX,OAAA8a,EAAA,GAAAD,EACAvd,GAAA,MvBolE6BoC,KAAKpC,EAAqBC,EAAoB,IAAKA,EAAoB,KAAKF,KAInG0d,IACA,SAAU1d,EAAQsT,GwB3mExBtT,EAAAsT,QAAA,SAAAqK,GACA,IAAAA,EAAAC,gBAAA,CACA,GAAA5d,GAAA2C,OAAAC,OAAA+a,EAEA3d,GAAA0R,WAAA1R,EAAA0R,aACA/O,OAAAkK,eAAA7M,EAAA,UACA+C,YAAA,EACA8W,IAAA,WACA,MAAA7Z,GAAA6d,KAGAlb,OAAAkK,eAAA7M,EAAA,MACA+C,YAAA,EACA8W,IAAA,WACA,MAAA7Z,GAAAwD,KAGAb,OAAAkK,eAAA7M,EAAA,WACA+C,YAAA,IAEA/C,EAAA4d,gBAAA,EAEA,MAAA5d,KxBmnEM8d,IACA,SAAU9d,EAAQC,EAAqBC,GAE7C,YyB5oEA,SAAA6d,GAAAP,GACA,GAAApD,GACA1K,EAAA8N,EAAA9N,MAaA,OAXA,kBAAAA,GACAA,EAAA/E,WACAyP,EAAA1K,EAAA/E,YAEAyP,EAAA1K,EAAA,cACAA,EAAA/E,WAAAyP,GAGAA,EAAA,eAGAA,EzB8nEiCna,EAAuB,EAAI8d,GAsBtDC,IACA,SAAUhe,EAAQC,EAAqBC,GAE7C,Y0BtnEA,SAAAgJ,GAAApG,GACA,IAAAH,OAAAsb,EAAA,GAAAnb,IAAAH,OAAAub,EAAA,GAAApb,IAAAqb,EACA,QAEA,IAAAhV,GAAAxG,OAAAyb,EAAA,GAAAtb,EACA,WAAAqG,EACA,QAEA,IAAAkV,GAAA3a,EAAArB,KAAA8G,EAAA,gBAAAA,EAAAtG,WACA,yBAAAwb,oBACAC,EAAAjc,KAAAgc,IAAAE,E1B6mEqB,GAAIL,GAA+Che,EAAoB,KACnEke,EAAiDle,EAAoB,KACrE+d,EAAiD/d,EAAoB,K0BpqE9Fie,EAAA,kBAGAK,EAAAC,SAAA/b,UACAgc,EAAA/b,OAAAD,UAGA4b,EAAAE,EAAAlQ,SAGA5K,EAAAgb,EAAAhb,eAGA6a,EAAAD,EAAAjc,KAAAM,OA2CA1C,GAAA,K1B+qEM0e,IACA,SAAU3e,EAAQC,EAAqBC,GAE7C,Y2B7tEA,SAAA0e,GAAA9b,GACA,aAAAA,MACA6B,KAAA7B,EAAA+b,EAAAC,EAEAC,OAAApc,QAAAG,GACAH,OAAAqc,EAAA,GAAAlc,GACAH,OAAAsc,EAAA,GAAAnc,G3BwtEqB,GAAIoc,GAA2Chf,EAAoB,KAC/D8e,EAA8C9e,EAAoB,KAClE+e,EAAmD/e,EAAoB,K2B7uEhG4e,EAAA,gBACAD,EAAA,qBAGAE,EAAAG,EAAA,EAAAA,EAAA,EAAAC,gBAAAxa,EAkBA1E,GAAA,K3BwvEMmf,IACA,SAAUpf,EAAQC,EAAqBC,GAE7C,YACqB,IAAImf,GAA+Cnf,EAAoB,K4BpxE5Fof,EAAA,gBAAAld,kBAAAO,iBAAAP,KAGAob,EAAA6B,EAAA,GAAAC,GAAAb,SAAA,gBAEAxe,GAAA,K5B6xEMsf,IACA,SAAUvf,EAAQC,EAAqBC,GAE7C,c6BxyEA,SAAAqd,GACA,GAAAiC,GAAA,gBAAAjC,SAAA5a,iBAAA4a,CAEAtd,GAAA,M7B2yE6BoC,KAAKpC,EAAqBC,EAAoB,MAIrEuf,IACA,SAAUzf,EAAQC,EAAqBC,GAE7C,Y8B5xEA,SAAAwf,GAAA5c,GACA,GAAA6c,GAAAjc,EAAArB,KAAAS,EAAAic,GACAa,EAAA9c,EAAAic,EAEA,KACAjc,EAAAic,OAAApa,EACA,IAAAkb,IAAA,EACG,MAAAjf,IAEH,GAAAwZ,GAAA0F,EAAAzd,KAAAS,EAQA,OAPA+c,KACAF,EACA7c,EAAAic,GAAAa,QAEA9c,GAAAic,IAGA3E,E9B4wEqB,GAAI8E,GAA2Chf,EAAoB,K8BnzExFwe,EAAA/b,OAAAD,UAGAgB,EAAAgb,EAAAhb,eAOAoc,EAAApB,EAAApQ,SAGAyQ,EAAAG,EAAA,EAAAA,EAAA,EAAAC,gBAAAxa,EA6BA1E,GAAA,K9B4zEM8f,IACA,SAAU/f,EAAQC,EAAqBC,GAE7C,Y+B31EA,SAAA8f,GAAAld,GACA,MAAAgd,GAAAzd,KAAAS,GAjBA,GAAA4b,GAAA/b,OAAAD,UAOAod,EAAApB,EAAApQ,QAaArO,GAAA,K/Bk3EMggB,IACA,SAAUjgB,EAAQC,EAAqBC,GAE7C,YACqB,IAAIggB,GAA4ChgB,EAAoB,KgCx4EzFigB,EAAAxd,OAAAud,EAAA,GAAAvd,OAAAyG,eAAAzG,OAEA1C,GAAA,KhCi5EMmgB,IACA,SAAUpgB,EAAQC,EAAqBC,GAE7C,YiCj5EA,SAAAmgB,GAAA/e,EAAAgf,GACA,gBAAA7S,GACA,MAAAnM,GAAAgf,EAAA7S,KAIAxN,EAAA,KjC+5EMsgB,IACA,SAAUvgB,EAAQC,EAAqBC,GAE7C,YkCx5EA,SAAAsgB,GAAA1d,GACA,aAAAA,GAAA,gBAAAA,GAGA7C,EAAA,KlCs7EMwgB,IACA,SAAUzgB,EAAQC,EAAqBC,GAE7C,YmCn9EA,SAAAwgB,GAAArF,GACA,wBAAAA,GAAA1Y,OAAAge,EAAA,GAAAtF,EAAA,uBAAA1W,GAGA,QAAAic,GAAAvF,GACA,MAAAA,OAEG1W,GAFHhC,OAAAge,EAAA,cACA,WnCg9EqB,GAAIA,GAAgDzgB,EAAoB,ImC58E7FD,GAAA,GAAAygB,EAAAE,InC69EMC,IACA,SAAU7gB,EAAQC,EAAqBC,GAE7C,YoCx+EA,SAAA4gB,GAAAC,EAAAC,EAAA1R,GACA,MAAA/I,MAAoB+I,EAAAyR,EAAAC,GAGpB,QAAAC,GAAA1F,GACA,gBAAA3Z,EAAA4C,GACA,GACAiX,IADAjX,EAAA6B,YACA7B,EAAAiX,MACAQ,EAAAzX,EAAAyX,oBAEAiF,GAAA,EACAC,MAAA,EAEA,iBAAAJ,EAAAC,EAAA1R,GACA,GAAA8R,GAAA7F,EAAAwF,EAAAC,EAAA1R,EAWA,OATA4R,GACAzF,GAAAQ,EAAAmF,EAAAD,OAAAC,IAEAF,GAAA,EACAC,EAAAC,GAKAD,IAKA,QAAAE,GAAA9F,GACA,wBAAAA,GAAA0F,EAAA1F,OAAA5W,GAGA,QAAA2c,GAAA/F,GACA,MAAAA,OAEG5W,GAFH,WACA,MAAAmc,IAxCA,GAAAva,IAAArG,EAAA,KAAAyC,OAAAmG,QAAA,SAAAvF,GAAmD,OAAAC,GAAA,EAAgBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CAAO,GAAAuF,GAAAtE,UAAAjB,EAA2B,QAAAwF,KAAAD,GAA0BpG,OAAAD,UAAAgB,eAAArB,KAAA0G,EAAAC,KAAyDzF,EAAAyF,GAAAD,EAAAC,IAAiC,MAAAzF,IA4C/OtD,GAAA,GAAAohB,EAAAC,IpCs/EMC,IACA,SAAUvhB,EAAQC,EAAqBC,GAE7C,YqCriFA,SAAAkD,GAAAC,EAAAC,GAA8C,GAAAC,KAAiB,QAAAC,KAAAH,GAAqBC,EAAAG,QAAAD,IAAA,GAAoCb,OAAAD,UAAAgB,eAAArB,KAAAgB,EAAAG,KAA6DD,EAAAC,GAAAH,EAAAG,GAAsB,OAAAD,GAI3M,QAAAie,GAAAnG,EAAAC,EAAAC,EAAA3Z,GACA,gBAAAiF,EAAAyI,GACA,MAAAiM,GAAAF,EAAAxU,EAAAyI,GAAAgM,EAAA1Z,EAAA0N,OAIA,QAAAmS,GAAApG,EAAAC,EAAAC,EAAA3Z,EAAA4C,GAYA,QAAAkd,GAAAC,EAAAC,GAOA,MANA/a,GAAA8a,EACArS,EAAAsS,EACAb,EAAA1F,EAAAxU,EAAAyI,GACA0R,EAAA1F,EAAA1Z,EAAA0N,GACA6R,EAAA5F,EAAAwF,EAAAC,EAAA1R,GACAuS,GAAA,EACAV,EAGA,QAAAW,KAMA,MALAf,GAAA1F,EAAAxU,EAAAyI,GAEAgM,EAAAtM,oBAAAgS,EAAA1F,EAAA1Z,EAAA0N,IAEA6R,EAAA5F,EAAAwF,EAAAC,EAAA1R,GAIA,QAAAyS,KAMA,MALA1G,GAAArM,oBAAA+R,EAAA1F,EAAAxU,EAAAyI,IAEAgM,EAAAtM,oBAAAgS,EAAA1F,EAAA1Z,EAAA0N,IAEA6R,EAAA5F,EAAAwF,EAAAC,EAAA1R,GAIA,QAAA0S,KACA,GAAAC,GAAA5G,EAAAxU,EAAAyI,GACA4S,GAAAnG,EAAAkG,EAAAlB,EAKA,OAJAA,GAAAkB,EAEAC,IAAAf,EAAA5F,EAAAwF,EAAAC,EAAA1R,IAEA6R,EAGA,QAAAgB,GAAAnW,EAAAoW,GACA,GAAAC,IAAAxG,EAAAuG,EAAA9S,GACAgT,GAAA3G,EAAA3P,EAAAnF,EAIA,OAHAA,GAAAmF,EACAsD,EAAA8S,EAEAC,GAAAC,EAAAR,IACAO,EAAAN,IACAO,EAAAN,IACAb,EA1DA,GAAAxF,GAAAnX,EAAAmX,eACAE,EAAArX,EAAAqX,iBACAE,EAAAvX,EAAAuX,mBAEA8F,GAAA,EACAhb,MAAA,GACAyI,MAAA,GACAyR,MAAA,GACAC,MAAA,GACAG,MAAA,EAoDA,iBAAAnV,EAAAoW,GACA,MAAAP,GAAAM,EAAAnW,EAAAoW,GAAAV,EAAA1V,EAAAoW,IAWA,QAAAG,GAAA3gB,EAAA0F,GACA,GAAA6U,GAAA7U,EAAA6U,oBACAC,EAAA9U,EAAA8U,uBACAC,EAAA/U,EAAA+U,eACAxN,EAAAzL,EAAAkE,GAAA,kEAEA+T,EAAAc,EAAAva,EAAAiN,GACAyM,EAAAc,EAAAxa,EAAAiN,GACA0M,EAAAc,EAAAza,EAAAiN,EAQA,QAFAA,EAAA4M,KAAAgG,EAAAD,GAEAnG,EAAAC,EAAAC,EAAA3Z,EAAAiN,GrCo8EiC5O,EAAuB,EAAIsiB,CqCxiF5DriB,GAAA,MrCmpFMsiB,IACA,SAAUxiB,EAAQC,EAAqBC,GAE7C,YAEwEA,GAAoB,MAqBtFuiB,IACA,SAAUziB,EAAQC,EAAqBC,GAE7C,YsChrFA,SAAAwiB,GAAAC,GACA,gBAAAne,GACA,GAAA5C,GAAA4C,EAAA5C,SACAC,EAAA2C,EAAA3C,QACA,iBAAAkJ,GACA,gBAAAZ,GACA,wBAAAA,GACAA,EAAAvI,EAAAC,EAAA8gB,GAGA5X,EAAAZ,MAMA,GAAAyY,GAAAF,GACAE,GAAAC,kBAAAH,EAEAziB,EAAA,KtCqrFM6iB,IACA,SAAU9iB,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEgR,EAA4C7iB,EAAoB,KAChE8iB,EAAyC9iB,EAAoB,KAC7D+iB,EAA+C/iB,EAAoB,KuCxsFtFgjB,EAAW,SAAA1e,GAOX,GANJ0M,GAMI1M,EANJ0M,UACAD,EAKIzM,EALJyM,MACAkS,EAII3e,EAJJ2e,KACA7R,EAGI9M,EAHJ8M,SACAM,EAEIpN,EAFJoN,QACAwR,EACI5e,EADJ4e,QAEMhS,EAAOH,EAAMkS,EAAKA,EAAKze,OAAS,GAEtC,OAAOwM,GACLc,EAAA7Q,EAAAiR,cAAC6Q,EAAA,GACCE,KAAMA,EACN/R,KAAMA,EACNH,MAAOA,EACPmS,QAASA,EACTxR,QAASA,EACTN,SAAUA,IAEV,MAaA+J,EAAkB,SAACxU,GAAD,OACtBqK,UAAWrK,EAAMmK,SAASE,UAC1BiS,KAAMtc,EAAMmK,SAASmS,KACrBlS,MAAOpK,EAAMoK,QAGTqK,EAAqB,SAAC1Z,GAAD,OACzB0P,SAAU,SAACzB,GAAD,MAAQjO,GAASohB,EAAA,EAAiBnT,KAC5C+B,QAAS,iBAAMhQ,GAASohB,EAAA,MACxBI,QAAS,iBAAMxhB,GAASohB,EAAA,OAG1B/iB,GAAA,EAAe0C,OAAAogB,EAAA,GAAQ1H,EAAiBC,GAAoB4H,IvCmtFtDG,IACA,SAAUrjB,EAAQC,EAAqBC,GAE7C,cAC4B,SAASqd,GAAwCrd,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAO2P,KAClH1P,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOqjB,IAC9E,IAAIC,GAA4CrjB,EAAoB,KAChE+R,EAAsD/R,EAAoB,IwCzwFtF0P,EAAU,SAACC,GACtB,GAAM2T,MAASvR,EAAA,EAAUwR,MAAQ5T,EAA3B,GAEN,OAAOlN,QAAA4gB,EAAA,GAAIC,IAGAF,EAAkB,SAACzT,GAAqB,GAAjBhB,GAAiBpK,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,MAC/C+e,EAASvR,EAAA,EAAUwR,MAAnB,aAAqC5T,EAArC,iBAgBJ,OAdIhB,GAAQ6U,SACVF,cAAkBjG,EAAOoG,mBAAmB9U,EAAQ6U,OAAOjV,KAAK,OAG9DI,EAAQ+U,mBACVJ,GAAO,mBAGL3U,EAAQwB,SACVmT,cAAkB3U,EAAQwB,QAG5BmT,GAAOvR,EAAA,EAAU4R,0BAEVlhB,OAAA4gB,EAAA,GAAIC,MxCkxFgBnhB,KAAKpC,EAAqBC,EAAoB,MAIrE4jB,IACA,SAAU9jB,EAAQC,EAAqBC,GAE7C,cAC4B,SAASqd,GyCtzFrCrd,EAAAG,EAAAJ,EAAA,qBAAA4Z,IAAA,IAAMkK,GAAQxG,EAAOwG,MACfC,EAAUzG,EAAOyG,QAIjBC,EAAc,SAACC,GACnB,GAAIA,EAASlP,QAAU,KAAOkP,EAASlP,OAAS,IAC9C,MAAOkP,EAKT,MAFc,IAAIvjB,OAAMujB,EAASC,aAK7BC,EAAY,SAAAF,GAAA,MAAYA,GAASG,QAIjCC,EAAU,SAACC,EAAIC,GAenB,MAda,IAAIC,SAAQ,SAACC,EAASC,GACjC,GAAMC,GAAYC,WAAW,WAC3BF,EAAO,GAAIhkB,OAAM,sBAChB4jB,EAEHC,GAAQxU,KAAK,SAAC8U,GACZC,aAAaH,GACbF,EAAQI,IACP,SAACE,GACFD,aAAaH,GACbD,EAAOK,QAWPC,EAAU,SAACC,EAAQ1B,GACvB,GAAM3U,IACJsW,YAAa,cACbC,QAAS,GAAIpB,IACXqB,OAAU,mBACVC,eAAgB,qBAElBJ,OAAQA,EAGV,OAAOZ,GAhDe,KAgDUP,EAAMP,EAAK3U,IACxCmB,KAAKiU,GACLjU,KAAKoU,IAGGvK,EAAM,SAAA2J,GAAA,MAAOyB,GAAQ,MAAOzB,MzC0zFZnhB,KAAKpC,EAAqBC,EAAoB,MAIrEqlB,IACA,SAAUvlB,EAAQC,EAAqBC,GAE7C,Y0Cr3FO,SAASslB,GAAapb,EAAMmC,EAAekZ,GAChD,GAAMC,GAA8C,kBAAlBnZ,GAA+BA,EAAgBoZ,CAEjF,OAAO,YACL,GAAMxb,IACJC,OACAwb,QAASF,0BAYX,OATIvb,GAAOyb,kBAAmBjlB,SAE5BwJ,EAAOzJ,OAAQ,GAGU,kBAAhB+kB,KACTtb,EAAOqG,KAAOiV,2BAGTtb,GAtBXlK,EAAA,EAAAulB,CAAA,IAAMG,GAAW,SAAArkB,GAAA,MAAQA,K1Cy5FnBukB,IACA,SAAU7lB,EAAQC,EAAqBC,GAE7C,YAcA,SAAS6B,GAAgBC,EAAUC,GAAe,KAAMD,YAAoBC,IAAgB,KAAM,IAAIC,WAAU,qCAEhH,QAASC,GAA2BC,EAAMC,GAAQ,IAAKD,EAAQ,KAAM,IAAIE,gBAAe,4DAAgE,QAAOD,GAAyB,gBAATA,IAAqC,kBAATA,GAA8BD,EAAPC,EAElO,QAASE,GAAUC,EAAUC,GAAc,GAA0B,kBAAfA,IAA4C,OAAfA,EAAuB,KAAM,IAAIP,WAAU,iEAAoEO,GAAeD,GAASE,UAAYC,OAAOC,OAAOH,GAAcA,EAAWC,WAAaG,aAAeC,MAAON,EAAUO,YAAY,EAAOC,UAAU,EAAMC,cAAc,KAAeR,IAAYE,OAAOO,eAAiBP,OAAOO,eAAeV,EAAUC,GAAcD,EAASW,UAAYV,GAjB5c,GAAIsP,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpE+T,EAAiD5lB,EAAoB,KACrE6lB,EAAyD7lB,EAAoBgB,EAAE4kB,GAC/ElV,EAAsD1Q,EAAoB,IAC1E8lB,EAA+C9lB,EAAoB,IACnE+lB,EAA+D/lB,EAAoB,KACnFgmB,EAAuDhmB,EAAoB,KAC3EimB,EAAgDjmB,EAAoB,KACpEkmB,EAA8ClmB,EAAoB,KAClEmmB,EAA2CnmB,EAAoB,KACpFomB,EAAe,WAAc,QAASC,GAAiBhjB,EAAQU,GAAS,IAAK,GAAIT,GAAI,EAAGA,EAAIS,EAAMS,OAAQlB,IAAK,CAAE,GAAIoV,GAAa3U,EAAMT,EAAIoV,GAAW7V,WAAa6V,EAAW7V,aAAc,EAAO6V,EAAW3V,cAAe,EAAU,SAAW2V,KAAYA,EAAW5V,UAAW,GAAML,OAAOkK,eAAetJ,EAAQqV,EAAW5P,IAAK4P,IAAiB,MAAO,UAAU3W,EAAaukB,EAAYC,GAAiJ,MAA9HD,IAAYD,EAAiBtkB,EAAYS,UAAW8jB,GAAiBC,GAAaF,EAAiBtkB,EAAawkB,GAAqBxkB,M2Cv5F1hBykB,E3Cg7Fc,SAAUC,G2C/6F5B,QAAAD,GAAYziB,GAAOlC,EAAA4E,KAAA+f,EAAA,IAAA9f,GAAAzE,EAAAwE,MAAA+f,EAAAvjB,WAAAR,OAAAyG,eAAAsd,IAAArkB,KAAAsE,KACX1C,GADW,OAGjB2C,GAAKC,OACH+f,WAAYV,EAAA,EACZW,QAAQ,GAGVjgB,EAAKkgB,YAAclgB,EAAKkgB,YAAY5f,KAAjBN,GACnBA,EAAKmgB,cAAgBngB,EAAKmgB,cAAc7f,KAAnBN,GACrBA,EAAKogB,aAAepgB,EAAKogB,aAAa9f,KAAlBN,GAVHA,E3C0mGnB,MA1LArE,GAAUmkB,EAAeC,GAkBzBL,EAAaI,IACX1d,IAAK,4BACLlG,MAAO,S2Cv7FiBmkB,GAAU,GAC1B9D,GAASxc,KAAK1C,MAAdkf,KACF+D,EAASD,EAAS9D,KAAKze,OAASye,EAAKze,MAE3CiC,MAAKyB,UACHwe,WAAYM,EAAShB,EAAA,EAAOA,EAAA,O3C47F9Bld,IAAK,oBACLlG,MAAO,W2Cx7FP2Q,SAASkC,cAAc,6BAA6BwR,UAAUC,IAAI,kBAClE3T,SAAS4T,KAAKF,UAAUC,IAAI,iBAC5B3T,SAASgC,iBAAiB,YAAa9O,KAAKqgB,cAC5CvT,SAASgC,iBAAiB,WAAY9O,KAAKqgB,iB3C47F3Che,IAAK,uBACLlG,MAAO,W2Cz7FP2Q,SAASkC,cAAc,6BAA6BwR,UAAUG,OAAO,kBACrE7T,SAAS4T,KAAKF,UAAUG,OAAO,iBAC/B7T,SAAS8T,oBAAoB,YAAa5gB,KAAKqgB,cAC/CvT,SAAS8T,oBAAoB,WAAY5gB,KAAKqgB,iB3C67F9Che,IAAK,eACLlG,MAAO,S2C37FIlC,GAAG,GACNwiB,GAAYzc,KAAK1C,MAAjBmf,QACFpS,EAAWyC,SAASkC,cAAc,wBAClC6R,EAAS/T,SAASkC,cAAc,4BAErB3E,GAASyW,SAAS7mB,EAAE2C,SAAWikB,EAAOC,SAAS7mB,EAAE2C,SAEhE6f,IAGEoE,EAAOC,SAAS7mB,EAAE2C,SACpBoD,KAAKyB,UACHye,QAAQ,O3Ci8FZ7d,IAAK,cACLlG,MAAO,S2C77FG+M,EAAIjP,GAAG,GACT0Q,GAAa3K,KAAK1C,MAAlBqN,QAER1Q,GAAE8mB,iBACF9mB,EAAE+mB,kBAEFrW,EAASzB,M3Ci8FT7G,IAAK,gBACLlG,MAAO,S2C/7FKlC,GAAG,GAAAgnB,GACWjhB,KAAK1C,MAAvBkf,EADOyE,EACPzE,KAAMvR,EADCgW,EACDhW,OACEuR,GAAKze,OAAS,IAG5B9D,EAAE8mB,iBACF9mB,EAAE+mB,kBAEF/V,Q3Cs8FF5I,IAAK,iBACLlG,MAAO,W2Cn8FQ,GAAA+kB,GAAAlhB,KAAAmhB,EACSnhB,KAAK1C,MAArBmN,EADO0W,EACP1W,KAAMH,EADC6W,EACD7W,MACVS,QAsBJ,OAbEA,GAPGN,EAAKK,YAAeL,EAAKM,SAASnB,MAQnCyB,EAAA7Q,EAAAiR,cAAA,OAAKpJ,IAAI,YACNoI,EAAKM,SAASnB,MAAMtC,IAAI,SAAC4B,GAAD,MACvBmC,GAAA7Q,EAAAiR,cAACgU,EAAA,GACCpd,IAAK6G,EACLkY,KAAM9W,EAAMpB,GACZmY,QAASH,EAAKf,YAAY5f,KAAK,KAAM2I,QAX3CmC,EAAA7Q,EAAAiR,cAAA,OAAKpJ,IAAI,QAAQqJ,UAAU,2BACxBzB,EAAA,EAAQqX,YAkBbjW,EAAA7Q,EAAAiR,cAAA,OAAKC,UAAU,sBACZX,EACAN,EAAKK,WACJO,EAAA7Q,EAAAiR,cAAA,OAAKpJ,IAAI,WAAWqJ,UAAU,2BAC5BL,EAAA7Q,EAAAiR,cAAC6T,EAAA,EAAD,OAEA,KACH7U,EAAK8W,QACJlW,EAAA7Q,EAAAiR,cAAA,OAAKpJ,IAAI,QAAQqJ,UAAU,2BACxBzB,EAAA,EAAQuX,cAET,S3C68FRnf,IAAK,SACLlG,MAAO,W2Cz8FA,GAAAslB,GACyBzhB,KAAK1C,MAA7BmN,EADDgX,EACChX,KAAMgS,EADPgF,EACOhF,QAASD,EADhBiF,EACgBjF,KADhBkF,EAEwB1hB,KAAKE,MAA5B+f,EAFDyB,EAECzB,WAAYC,EAFbwB,EAEaxB,MAEpB,OACE7U,GAAA7Q,EAAAiR,cAAC2T,EAAA5kB,GACCye,IAAI,MACJ0I,KAAK,SACLjW,UAAU,WACVwU,OAAQA,IAAWzV,GAAQA,EAAKK,WAChC8W,kBACEC,aAAc,sBACdC,aAAcrF,IAGhBpR,EAAA7Q,EAAAiR,cAAC4T,EAAA,GAAO3T,UAAU,oBAAoB2V,QAAS5E,GAC5CxS,EAAA,EAAQ8X,gBAEX1W,EAAA7Q,EAAAiR,cAAC8T,EAAA,GAAWphB,KAAM8hB,EAAYvU,UAAU,aAAaQ,UAAU,MAAME,MAAOnC,EAAA,EAAQ+X,eAClF3W,EAAA7Q,EAAAiR,cAAA,OAAKpJ,IAAKma,EAAKze,OAAQ2N,UAAU,sBAC/BL,EAAA7Q,EAAAiR,cAAC+T,EAAA,GACCyC,MAAOzF,EAAKze,OACZ0M,KAAMA,EACN4W,QAASrhB,KAAKogB,gBAGfpgB,KAAKkiB,iBAELzX,EAAK8W,SAAW9W,EAAKM,SAASnB,OAASa,EAAKM,SAASC,MAAQf,EAAA,EAC5DoB,EAAA7Q,EAAAiR,cAACiU,EAAA,GAAUjV,KAAMA,IACf,Y3Cy9FPsV,G2C3mGmB1U,EAAA7Q,EAAM2nB,UAyKlC7oB,GAAA,K3Cy8FM8oB,IACA,SAAU/oB,EAAQsT,EAASpT,I4CpoGjC,SAAAqd,GAAAvd,EAAAsT,QAAAiK,EAAA,eAAArd,EAAA,O5CuoG6BmC,KAAKiR,EAASpT,EAAoB,MAIzD8oB,IACA,SAAUhpB,EAAQsT,EAASpT,GAEjC,Y6C1oGA,SAAA6B,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAE3F,QAAAC,GAAAC,EAAAC,GAAiD,IAAAD,EAAa,SAAAE,gBAAA,4DAAyF,QAAAD,GAAA,gBAAAA,IAAA,kBAAAA,GAAAD,EAAAC,EAEvJ,QAAAE,GAAAC,EAAAC,GAA0C,qBAAAA,IAAA,OAAAA,EAA+D,SAAAP,WAAA,iEAAAO,GAAuGD,GAAAE,UAAAC,OAAAC,OAAAH,KAAAC,WAAyEG,aAAeC,MAAAN,EAAAO,YAAA,EAAAC,UAAA,EAAAC,cAAA,KAA6ER,IAAAE,OAAAO,eAAAP,OAAAO,eAAAV,EAAAC,GAAAD,EAAAW,UAAAV,GANrX,GAAA6jB,GAAA,WAAgC,QAAAC,GAAAhjB,EAAAU,GAA2C,OAAAT,GAAA,EAAgBA,EAAAS,EAAAS,OAAkBlB,IAAA,CAAO,GAAAoV,GAAA3U,EAAAT,EAA2BoV,GAAA7V,WAAA6V,EAAA7V,aAAA,EAAwD6V,EAAA3V,cAAA,EAAgC,SAAA2V,OAAA5V,UAAA,GAAuDL,OAAAkK,eAAAtJ,EAAAqV,EAAA5P,IAAA4P,IAA+D,gBAAA3W,EAAAukB,EAAAC,GAA2L,MAAlID,IAAAD,EAAAtkB,EAAAS,UAAA8jB,GAAqEC,GAAAF,EAAAtkB,EAAAwkB,GAA6DxkB,MAQxhBgnB,EAAA/oB,EAAA,GACAgpB,EAAAhpB,EAAA,KAEAipB,GAAA,+DAEAC,EAAA,SAAAzC,GAGA,QAAAyC,KACA,GAAA5kB,GAEA6kB,EAAAziB,EAAA0iB,CAEAvnB,GAAA4E,KAAAyiB,EAEA,QAAA9b,GAAA7I,UAAAC,OAAAyU,EAAA3L,MAAAF,GAAApB,EAAA,EAAmEA,EAAAoB,EAAapB,IAChFiN,EAAAjN,GAAAzH,UAAAyH,EAGA,OAAAmd,GAAAziB,EAAAzE,EAAAwE,MAAAnC,EAAA4kB,EAAAjmB,WAAAR,OAAAyG,eAAAggB,IAAA/mB,KAAAmK,MAAAhI,GAAAmC,MAAAsG,OAAAkM,KAAAvS,EAAA2iB,QAAA,SAAAC,GACA5iB,EAAA6iB,KAAAD,GADAF,EAEKD,EAAAlnB,EAAAyE,EAAA0iB,GA6EL,MA5FA/mB,GAAA6mB,EAAAzC,GAkBAL,EAAA8C,IACApgB,IAAA,qBACAlG,MAAA,WACA,mBAAA2Q,YACA9M,KAAA+iB,yBAAAjW,SAAAkW,kBAIA3gB,IAAA,oBACAlG,MAAA,WAMA,GAAA8mB,GAAAjjB,KAAA1C,MAAAskB,iBACAsB,GACAC,yBAAA,EAEA,QAAAC,KAAAH,GACAA,EAAAlmB,eAAAqmB,IACA,4BAAAA,IACAF,EAAAE,GAAAH,EAAAG,GAGApjB,MAAAqjB,UAAArjB,KAAA1C,MAAAgmB,iBAAAtjB,KAAA8iB,KAAAI,GACAljB,KAAA1C,MAAAwQ,QACA9N,KAAAqjB,UAAAE,WAEAvjB,KAAA1C,MAAA4iB,QACAlgB,KAAAqjB,UAAAG,WAIAnhB,IAAA,qBACAlG,MAAA,SAAAsnB,GACAA,EAAA3V,SAAA9N,KAAA1C,MAAAwQ,OACA9N,KAAAqjB,UAAAK,cACOD,EAAA3V,QAAA9N,KAAA1C,MAAAwQ,QACP9N,KAAAqjB,UAAAE,WAGAE,EAAAvD,SAAAlgB,KAAA1C,MAAA4iB,OACAlgB,KAAAqjB,UAAAM,WACOF,EAAAvD,QAAAlgB,KAAA1C,MAAA4iB,QACPlgB,KAAAqjB,UAAAG,WAIAnhB,IAAA,uBACAlG,MAAA,WACA6D,KAAAqjB,UAAAK,cACA,IAAA1jB,KAAA1C,MAAAskB,iBAAAuB,yBAAAnjB,KAAA+iB,0BAAA/iB,KAAA+iB,yBAAAa,OACA5jB,KAAA+iB,yBAAAa,WAIAvhB,IAAA,SACAlG,MAAA,WACA,GAAA0nB,IACA1iB,IAAAnB,KAAA4iB,QAIA,QAAAkB,KAAA9jB,MAAA1C,MACA0C,KAAA1C,MAAAP,eAAA+mB,KACA,IAAAtB,EAAA1lB,QAAAgnB,KACAD,EAAAC,GAAA9jB,KAAA1C,MAAAwmB,GAGA,OAAAxB,GAAA7W,cAAAzL,KAAA1C,MAAA2b,IAAA4K,EAAA7jB,KAAA1C,MAAAyN,cAIA0X,GACCH,EAAAH,UAEDM,GAAAhW,cACAqB,QAAA,EACAmL,IAAA,MACAiH,QAAA,EACA0B,oBACA0B,iBAAAf,GAGAlpB,EAAAsT,QAAA8V,G7CmpGMsB,IACA,SAAU1qB,EAAQsT,EAASpT,G8CvwGjC,QAAA8pB,GAAApS,EAAA+S,GA8BA,QAAAT,GAAAU,GACA,IAAAnW,EAAA,CAEA,GAAAoW,IACAC,WAAAF,OAAAjmB,KAAAimB,EAAAE,WACAF,EAAAE,WACAC,EAAAD,WAYA,OATArW,IAAA,EACAoS,GAAA,EACAmE,EAAAvX,SAAAkW,cAEAkB,EAAAC,YACAD,EAAAC,aAGAG,IACAC,GAGA,QAAAb,GAAAc,GACA,GAAA1W,EAAA,CAEA,GAAA2W,IACAC,YAAAF,OAAAxmB,KAAAwmB,EAAAE,YACAF,EAAAE,YACAN,EAAAjB,wBACArB,aAAA0C,OAAAxmB,KAAAwmB,EAAA1C,aACA0C,EAAA1C,aACAsC,EAAAtC,aAiBA,OAdA6C,KAEAF,EAAA3C,cACA2C,EAAA3C,eAGA2C,EAAAC,aACAxG,WAAA,WACA0G,EAAAP,IACO,GAGPvW,GAAA,EACAoS,GAAA,EACAlgB,MAGA,QAAAwjB,MACAtD,GAAApS,IACAoS,GAAA,EACAyE,KAGA,QAAAhB,KACAzD,GAAApS,IACAoS,GAAA,EACAoE,KAGA,QAAAA,KACA,GAAAxW,EAgBA,MAbA+W,IACAA,EAAArB,QAEAqB,EAAAN,EAEAO,IACAF,EAAAG,KACAjY,SAAAgC,iBAAA,QAAAkW,GAAA,GACAlY,SAAAgC,iBAAA,QAAAmW,GAAA,GACAnY,SAAAgC,iBAAA,YAAAoW,GAAA,GACApY,SAAAgC,iBAAA,aAAAoW,GAAA,GACApY,SAAAgC,iBAAA,UAAAqW,GAAA,GAEAZ,EAGA,QAAAI,KACA,GAAA7W,GAAA+W,IAAAN,EAUA,MARAzX,UAAA8T,oBAAA,QAAAoE,GAAA,GACAlY,SAAA8T,oBAAA,QAAAqE,GAAA,GACAnY,SAAA8T,oBAAA,YAAAsE,GAAA,GACApY,SAAA8T,oBAAA,aAAAsE,GAAA,GACApY,SAAA8T,oBAAA,UAAAuE,GAAA,GAEAN,EAAA,KAEAN,EAGA,QAAAa,GAAAhC,GACA,GAAAiC,GAAAjB,EAAAhB,GACAN,EAAAuC,CACA,KAAAA,EACA,WAEA,oBAAAA,MACAvC,EAAAhW,SAAAkC,cAAAqW,IAEA,SAAArrB,OAAA,IAAAopB,EAAA,4BAGA,sBAAAiC,MACAvC,EAAAuC,KAEA,SAAArrB,OAAA,IAAAopB,EAAA,0BAGA,OAAAN,GAGA,QAAAiC,KACA,GAAAjC,EASA,MAPAA,EADA,OAAAsC,EAAA,gBACAA,EAAA,gBACKE,EAAAxE,SAAAhU,SAAAkW,eACLlW,SAAAkW,cAEAuC,EAAA,IAAAH,EAAA,kBAIA,SAAAprB,OAAA,qEAGA,OAAA8oB,GAKA,QAAAoC,GAAAjrB,GACAmqB,EAAAoB,0BAAAF,EAAAxE,SAAA7mB,EAAA2C,SACA8mB,GAAkBgB,aAAA,IAIlB,QAAAO,GAAAhrB,GACAmqB,EAAAoB,yBACAF,EAAAxE,SAAA7mB,EAAA2C,UACA3C,EAAA8mB,iBACA9mB,EAAAwrB,4BAGA,QAAAT,GAAA/qB,GACAqrB,EAAAxE,SAAA7mB,EAAA2C,UACA3C,EAAA8mB,iBACA9mB,EAAAwrB,2BAEA,kBAAAxrB,GAAA2C,OAAA8oB,MAAAzrB,EAAA2C,OAAA8oB,OAEAC,GACAC,EAAAD,IAIA,QAAAR,GAAAlrB,GACA,QAAAA,EAAAoI,KAAA,IAAApI,EAAA4rB,SACAC,EAAA7rB,IAGA,IAAAmqB,EAAA2B,mBAAAC,EAAA/rB,IACAypB,IAIA,QAAAoC,GAAA7rB,GAGA,GAFA6qB,IAEA7qB,EAAA2C,OAAAqpB,aAAA,aAAAC,OAAAjsB,EAAA2C,OAAA0T,aAAA,eACA,MAAAqV,GAAA1rB,CAGAA,GAAA8mB,gBACA,IAAAoF,GAAAZ,EAAAzoB,QAAA7C,EAAA2C,OAEA,OAAA3C,GAAAmsB,SAEAxB,EADA3qB,EAAA2C,SAAAypB,IAAA,IAAAd,EAAAzoB,QAAA7C,EAAA2C,QACA0pB,EAEAf,EAAAY,EAAA,IAGAlsB,EAAA2C,SAAA0pB,EAAA1B,EAAAyB,OAEAzB,GAAAW,EAAAY,EAAA,IAGA,QAAArB,KACAS,EAAAgB,EAAAjB,GACAe,EAAAd,EAAA,GACAe,EAAAf,IAAAxnB,OAAA,GAGA,QAAA6nB,GAAA3rB,GACA,GAAAA,EAAAmsB,SAAA,MAAAxB,GAAA0B,EAEA1B,GAAAyB,GAvOA,GAAAd,MACAc,EAAA,KACAC,EAAA,KACAjC,EAAA,KACAvW,GAAA,EACAoS,GAAA,EACAyF,EAAA,KAEAL,EAAA,gBAAArU,GACAnE,SAAAkC,cAAAiC,GACAA,EAEAmT,EAAAJ,KACAI,GAAAjB,yBAAAa,OAAAhmB,KAAAgmB,EAAAb,yBACAa,EAAAb,wBAEAiB,EAAA2B,mBAAA/B,OAAAhmB,KAAAgmB,EAAA+B,mBACA/B,EAAA+B,iBAGA,IAAAxB,IACAhB,WACAG,aACAF,QACAG,UAGA,OAAAY,GAgNA,QAAAyB,GAAA/rB,GACA,iBAAAA,EAAAoI,KAAA,QAAApI,EAAAoI,KAAA,KAAApI,EAAA4rB,QAGA,QAAAjB,GAAA9B,GACAA,KAAAc,OACAd,IAAAhW,SAAAkW,gBAEAF,EAAAc,QACA,UAAAd,EAAA0D,QAAAC,eACA3D,EAAA4D,UA1PA,GAAAH,GAAAhtB,EAAA,KAEAsrB,EAAA,IA4PAxrB,GAAAsT,QAAA0W,G9CkxGMsD,IACA,SAAUttB,EAAQsT,G+Cx8GxB,QAAAia,GAAAC,GAUA,QAAAC,GAAAhE,EAAAiE,GACA,GAAAjE,IAAA+D,EAAAG,gBAAA,QAGA,QAAAnqB,GAAA,EAAAkB,EAAAkpB,EAAAlpB,OAA+ClB,EAAAkB,EAAYlB,IAC3D,GAAAoqB,EAAApqB,GAAA,KAAAimB,EAAA,MAAAmE,GAAApqB,GAAA,EAGAkqB,MAAAF,EAAAK,YAAAC,iBAAArE,EAEA,IAAArP,IAAA,CAUA,OARA,SAAAsT,EAAAK,QACA3T,GAAA,EACKqP,EAAAtS,aACLiD,EAAAqT,EAAAhE,EAAAtS,aAGAyW,EAAA5jB,MAAAyf,EAAArP,IAEAA,EA3BA,GAAAwT,KA8BA,iBAAAnE,GACA,GAAAA,IAAA+D,EAAAG,gBAAA,QAEA,IAAAK,GAAAR,EAAAK,YAAAC,iBAAArE,EAEA,SAAAgE,EAAAhE,EAAAuE,IAEA,WAAAA,EAAAC,YAjHAjuB,EAAAsT,QAAA,SAAAkW,EAAA3a,GACAA,OAEA,IAAA2e,GAAAhE,EAAA0E,eAAA1E,EACA2E,KACAC,KAIAC,EAAAd,EAAAC,GAEAc,GACA,QACA,SACA,UACA,WACA,SACA,cAGAC,EAAA/E,EAAAgF,iBAAAF,EAAA7f,KAAA,KAEA,IAAAI,EAAA4f,iBAAA,CACA,GAAAC,GAAAC,QAAAjsB,UAAAgsB,SAAAC,QAAAjsB,UAAAksB,mBAAAD,QAAAjsB,UAAAmsB,qBAGAP,GAAAQ,KAAA,SAAAC,GACA,MAAAL,GAAArsB,KAAAmnB,EAAAuF,OAGAR,EAAA/gB,MAAA9K,UAAAkH,MAAA4C,MAAA+hB,GACAA,EAAAS,QAAAxF,IAKA,OADAyF,GAAAC,EACA1rB,EAAA,EAAAqa,EAAA0Q,EAAA7pB,OAAwClB,EAAAqa,EAAOra,IAC/CyrB,EAAAV,EAAA/qB,IACA0rB,EAAAlY,SAAAiY,EAAAhY,aAAA,iBAAAgY,EAAAE,UAGA,GACA,UAAAF,EAAA9B,SAAA,WAAA8B,EAAA7kB,MACA6kB,EAAAG,UACAf,EAAAY,EAAAzB,KAKA,IAAA0B,EACAf,EAAAnkB,KAAAilB,GAEAb,EAAApkB,MACAC,MAAAzG,EACA2rB,SAAAD,EACAzF,KAAAwF,IAKA,IAAA/C,GAAAkC,EACAiB,KAAA,SAAAluB,EAAAwM,GACA,MAAAxM,GAAAguB,WAAAxhB,EAAAwhB,SAAAhuB,EAAA8I,MAAA0D,EAAA1D,MAAA9I,EAAAguB,SAAAxhB,EAAAwhB,WAEAlhB,IAAA,SAAA9M,GACA,MAAAA,GAAAsoB,MAKA,OAFAjc,OAAA9K,UAAAsH,KAAAwC,MAAA0f,EAAAiC,GAEAjC,I/CqkHMoD,IACA,SAAUtvB,EAAQsT,EAASpT,IgD5oHjC,SAAAqd,GAAAvd,EAAAsT,QAAAiK,EAAA,mBAAArd,EAAA,OhD+oH6BmC,KAAKiR,EAASpT,EAAoB,MAIzDqvB,IACA,SAAUvvB,EAAQsT,EAASpT,GAEjC,YiD9nHA,SAAAyT,GAAAtQ,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,GAE7E,QAAAtB,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAE3F,QAAAC,GAAAC,EAAAC,GAAiD,IAAAD,EAAa,SAAAE,gBAAA,4DAAyF,QAAAD,GAAA,gBAAAA,IAAA,kBAAAA,GAAAD,EAAAC,EAEvJ,QAAAE,GAAAC,EAAAC,GAA0C,qBAAAA,IAAA,OAAAA,EAA+D,SAAAP,WAAA,iEAAAO,GAAuGD,GAAAE,UAAAC,OAAAC,OAAAH,KAAAC,WAAyEG,aAAeC,MAAAN,EAAAO,YAAA,EAAAC,UAAA,EAAAC,cAAA,KAA6ER,IAAAE,OAAAO,eAAAP,OAAAO,eAAAV,EAAAC,GAAAD,EAAAW,UAAAV,GA5BrX6Q,EAAAM,YAAA,CAEA,IAAArN,GAAA5D,OAAAmG,QAAA,SAAAvF,GAAmD,OAAAC,GAAA,EAAgBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CAAO,GAAAuF,GAAAtE,UAAAjB,EAA2B,QAAAwF,KAAAD,GAA0BpG,OAAAD,UAAAgB,eAAArB,KAAA0G,EAAAC,KAAyDzF,EAAAyF,GAAAD,EAAAC,IAAiC,MAAAzF,IAE/O2Q,EAAAhU,EAAA,GAEAsvB,EAAA7b,EAAAO,GAEAC,EAAAjU,EAAA,IAEAkU,EAAAT,EAAAQ,GAEAsb,EAAAvvB,EAAA,KAEAwvB,EAAA/b,EAAA8b,GAEAE,EAAAzvB,EAAA,KAEA0vB,EAAAjc,EAAAgc,GAEAE,EAAA3vB,EAAA,KAqBAkT,GAVAyc,EAAA5b,UAAA1S,WAEA6S,EAAAb,QAAAuc,KACA1b,EAAAb,QAAAuc,KACA1b,EAAAb,QAAAuc,MACA,EAAAD,EAAAhc,mBAAA,WACA,EAAAgc,EAAAhc,mBAAA,UACA,EAAAgc,EAAAhc,mBAAA,UAIAkc,kBAAA,EACAC,iBAAA,EACAC,iBAAA,IAGAC,EAAA,SAAAvJ,GAGA,QAAAuJ,KACA,GAAA7G,GAAAziB,EAAA0iB,CAEAvnB,GAAA4E,KAAAupB,EAEA,QAAA5iB,GAAA7I,UAAAC,OAAAyU,EAAA3L,MAAAF,GAAApB,EAAA,EAAmEA,EAAAoB,EAAapB,IAChFiN,EAAAjN,GAAAzH,UAAAyH,EAGA,OAAAmd,GAAAziB,EAAAzE,EAAAwE,KAAAggB,EAAAtkB,KAAAmK,MAAAma,GAAAhgB,MAAAsG,OAAAkM,KAAAvS,EAAAupB,WAAA,SAAAC,GACA,MAAAZ,GAAAjc,QAAAnB,cAAAwd,EAAArc,SACAzO,KAAA8B,EAAA3C,MAAAiP,eACA0B,OAAAhO,EAAA3C,MAAA8rB,iBACAxb,MAAA3N,EAAA3C,MAAA+rB,gBACAxb,MAAA5N,EAAA3C,MAAAgsB,gBACAI,cAAAzpB,EAAA3C,MAAAqsB,wBACAC,aAAA3pB,EAAA3C,MAAA+O,uBACAwd,aAAA5pB,EAAA3C,MAAAgP,wBACOmd,IATP9G,EAUKD,EAAAlnB,EAAAyE,EAAA0iB,GAYL,MAjCA/mB,GAAA2tB,EAAAvJ,GA6BAuJ,EAAAxtB,UAAA8F,OAAA,WACA,MAAAgnB,GAAAjc,QAAAnB,cAAAsd,EAAAnc,QAAAhN,KAA+EI,KAAA1C,OAAewsB,aAAA9pB,KAAAwpB,eAG9FD,GACCV,EAAAjc,QAAAuV,UAEDoH,GAAA7pB,YAAA,qBAGA6pB,EAAAxnB,aACAwnB,EAAA9c,eAEAE,EAAAC,QAAA2c,EACAlwB,EAAAsT,UAAA,SjD2pHMod,IACA,SAAU1wB,EAAQsT,EAASpT,GAEjC,YkDnuHA,SAAAyT,GAAAtQ,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,GAE7E,QAAAtB,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAE3F,QAAAC,GAAAC,EAAAC,GAAiD,IAAAD,EAAa,SAAAE,gBAAA,4DAAyF,QAAAD,GAAA,gBAAAA,IAAA,kBAAAA,GAAAD,EAAAC,EAEvJ,QAAAE,GAAAC,EAAAC,GAA0C,qBAAAA,IAAA,OAAAA,EAA+D,SAAAP,WAAA,iEAAAO,GAAuGD,GAAAE,UAAAC,OAAAC,OAAAH,KAAAC,WAAyEG,aAAeC,MAAAN,EAAAO,YAAA,EAAAC,UAAA,EAAAC,cAAA,KAA6ER,IAAAE,OAAAO,eAAAP,OAAAO,eAAAV,EAAAC,GAAAD,EAAAW,UAAAV,GA5BrX6Q,EAAAM,YAAA,CAEA,IAAArN,GAAA5D,OAAAmG,QAAA,SAAAvF,GAAmD,OAAAC,GAAA,EAAgBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CAAO,GAAAuF,GAAAtE,UAAAjB,EAA2B,QAAAwF,KAAAD,GAA0BpG,OAAAD,UAAAgB,eAAArB,KAAA0G,EAAAC,KAAyDzF,EAAAyF,GAAAD,EAAAC,IAAiC,MAAAzF,IAE/OotB,EAAAzwB,EAAA,KAEA0wB,EAAAjd,EAAAgd,GAEAzc,EAAAhU,EAAA,GAEAsvB,EAAA7b,EAAAO,GAEAC,EAAAjU,EAAA,IAEAkU,EAAAT,EAAAQ,GAEA0c,EAAA3wB,EAAA,KAIA4wB,GAFAnd,EAAAkd,GAEA3wB,EAAA,MAgBAkT,GALAgB,EAAAb,QAAAwd,IACA3c,EAAAb,QAAAjS,KACA8S,EAAAb,QAAAkW,MAIA5W,UAAA,OACA4d,aAAA,SAAAL,GACA,MAAAA,MAIAY,EAAA,SAAArK,GAGA,QAAAqK,GAAA/sB,EAAAyC,GACA3E,EAAA4E,KAAAqqB,EAEA,IAAApqB,GAAAzE,EAAAwE,KAAAggB,EAAAtkB,KAAAsE,KAAA1C,EAAAyC,GA2FA,OAzFAE,GAAAqqB,cAAA,SAAAjoB,EAAA6J,GACAjM,EAAAsqB,2BAAAloB,IAAA,EAEA6J,EAAAse,oBACAte,EAAAse,oBAAAvqB,EAAAwqB,qBAAAlqB,KAAAN,EAAAoC,EAAA6J,IAEAjM,EAAAwqB,qBAAApoB,EAAA6J,IAIAjM,EAAAwqB,qBAAA,SAAApoB,EAAA6J,GACAA,EAAAwe,oBACAxe,EAAAwe,2BAGAzqB,GAAAsqB,2BAAAloB,EAEA,IAAAsoB,IAAA,EAAAR,EAAAS,iBAAA3qB,EAAA3C,MAAAyN,SAEA4f,MAAA5tB,eAAAsF,IAEApC,EAAA4qB,aAAAxoB,EAAA6J,IAIAjM,EAAA6qB,aAAA,SAAAzoB,EAAA6J,GACAjM,EAAAsqB,2BAAAloB,IAAA,EAEA6J,EAAA6e,mBACA7e,EAAA6e,mBAAA9qB,EAAA+qB,oBAAAzqB,KAAAN,EAAAoC,EAAA6J,IAEAjM,EAAA+qB,oBAAA3oB,EAAA6J,IAIAjM,EAAA+qB,oBAAA,SAAA3oB,EAAA6J,GACAA,EAAA+e,mBACA/e,EAAA+e,0BAGAhrB,GAAAsqB,2BAAAloB,EAEA,IAAAsoB,IAAA,EAAAR,EAAAS,iBAAA3qB,EAAA3C,MAAAyN,SAEA4f,MAAA5tB,eAAAsF,IAEApC,EAAA4qB,aAAAxoB,EAAA6J,IAIAjM,EAAA4qB,aAAA,SAAAxoB,EAAA6J,GACAjM,EAAAsqB,2BAAAloB,IAAA,EAEA6J,EAAAgf,mBACAhf,EAAAgf,mBAAAjrB,EAAAkrB,mBAAA5qB,KAAAN,EAAAoC,EAAA6J,IAKAjM,EAAAkrB,mBAAA9oB,EAAA6J,IAIAjM,EAAAkrB,mBAAA,SAAA9oB,EAAA6J,GACAA,EAAAkf,mBACAlf,EAAAkf,0BAGAnrB,GAAAsqB,2BAAAloB,EAEA,IAAAsoB,IAAA,EAAAR,EAAAS,iBAAA3qB,EAAA3C,MAAAyN,SAEA4f,MAAA5tB,eAAAsF,GAEApC,EAAAorB,YAAAhoB,KAAAhB,GAEApC,EAAAwB,SAAA,SAAAvB,GACA,GAAAorB,GAAA1rB,KAAuCM,EAAA6K,SAEvC,cADAugB,GAAAjpB,IACkB0I,SAAAugB,MAKlBrrB,EAAAsrB,UAAAvvB,OAAAC,OAAA,MAEAgE,EAAAC,OACA6K,UAAA,EAAAof,EAAAS,iBAAAttB,EAAAyN,WAEA9K,EAoHA,MApNArE,GAAAyuB,EAAArK,GAmGAqK,EAAAtuB,UAAAyvB,mBAAA,WACAxrB,KAAAuqB,8BACAvqB,KAAAqrB,eACArrB,KAAAyrB,gBAGApB,EAAAtuB,UAAA8E,kBAAA,WACA,GAAA6qB,GAAA1rB,KAAAE,MAAA6K,QACA,QAAA1I,KAAAqpB,GACAA,EAAArpB,IACArC,KAAAsqB,cAAAjoB,EAAArC,KAAAurB,UAAAlpB,KAKAgoB,EAAAtuB,UAAAgF,0BAAA,SAAAxD,GACA,GAAAouB,IAAA,EAAAxB,EAAAS,iBAAArtB,EAAAwN,UACA6gB,EAAA5rB,KAAAE,MAAA6K,QAEA/K,MAAAyB,UACAsJ,UAAA,EAAAof,EAAA0B,oBAAAD,EAAAD,IAGA,QAAAtpB,KAAAspB,GAAA,CACA,GAAAG,GAAAF,KAAA7uB,eAAAsF,IACAspB,EAAAtpB,IAAAypB,GAAA9rB,KAAAuqB,2BAAAloB,IACArC,KAAAqrB,YAAAhoB,KAAAhB,GAIA,OAAAkD,KAAAqmB,GAAA,CACA,GAAAG,GAAAJ,KAAA5uB,eAAAwI,IACAqmB,EAAArmB,IAAAwmB,GAAA/rB,KAAAuqB,2BAAAhlB,IACAvF,KAAAyrB,YAAApoB,KAAAkC,KAOA8kB,EAAAtuB,UAAAwF,mBAAA,WACA,GAAA2f,GAAAlhB,KAEAqrB,EAAArrB,KAAAqrB,WACArrB,MAAAqrB,eACAA,EAAAxmB,QAAA,SAAAxC,GACA,MAAA6e,GAAA4J,aAAAzoB,EAAA6e,EAAAqK,UAAAlpB,KAGA,IAAAopB,GAAAzrB,KAAAyrB,WACAzrB,MAAAyrB,eACAA,EAAA5mB,QAAA,SAAAxC,GACA,MAAA6e,GAAA2J,aAAAxoB,EAAA6e,EAAAqK,UAAAlpB,OAIAgoB,EAAAtuB,UAAA8F,OAAA,WACA,GAAAmqB,GAAAhsB,KAIAisB,IAiCA,QAAA5pB,KAAArC,MAAAE,MAAA6K,UA/BA,SAAA1I,GACA,GAAAonB,GAAAuC,EAAA9rB,MAAA6K,SAAA1I,EACA,IAAAonB,EAAA,CACA,GAAAyC,GAAA,gBAAAzC,GAAAtoB,IACAgrB,EAAAH,EAAA1uB,MAAAwsB,aAAAL,GACAtoB,EAAA,SAAAirB,GACAJ,EAAAT,UAAAlpB,GAAA+pB,EASAD,KAAA1C,GAAAyC,IACA/qB,GAAA,EAAA8oB,EAAArd,SAAA6c,EAAAtoB,QAQA8qB,EAAA5oB,KAAAwlB,EAAAjc,QAAAyf,aAAAF,GACA9pB,MACAlB,WAMAkB,EAIA,IAAA/E,GAAAsC,KAA2BI,KAAA1C,MAW3B,cAVAA,GAAAgsB,sBACAhsB,GAAAiP,qBACAjP,GAAA8rB,uBACA9rB,GAAA+rB,sBACA/rB,GAAAwsB,mBACAxsB,GAAAgP,6BACAhP,GAAA+O,6BACA/O,GAAAqsB,8BACArsB,GAAA4O,UAEA2c,EAAAjc,QAAAnB,cAAAzL,KAAA1C,MAAA4O,UAAA5O,EAAA2uB,IAGA5B,GACCxB,EAAAjc,QAAAuV,UAEDkI,GAAA3qB,YAAA,kBAGA2qB,EAAAtoB,aACAsoB,EAAA5d,eAEAE,EAAAC,QAAAyd,EACAhxB,EAAAsT,UAAA,SlDgwHM2f,IACA,SAAUjzB,EAAQsT,GmD5gIxBtT,EAAAsT,QAAA,WAIA,OAHA4f,GAAAzuB,UAAAC,OACAyU,KAEA3V,EAAA,EAAiBA,EAAA0vB,EAAS1vB,IAC1B2V,EAAA3V,GAAAiB,UAAAjB,EAIA,IAFA2V,IAAAjM,OAAA,SAAAimB,GAAkC,aAAAA,IAElC,IAAAha,EAAAzU,OACA,WAAAyU,EAAAzU,OAAAyU,EAAA,GAEAA,EAAAzL,OAAA,SAAA+L,EAAA1O,GACA,kBACA0O,EAAAjN,MAAA7F,KAAAlC,WACAsG,EAAAyB,MAAA7F,KAAAlC,gBnDuhIM2uB,IACA,SAAUpzB,EAAQsT,EAASpT,GAEjC,YoDxhIA,IAAAK,GAAA,YAyCAP,GAAAsT,QAAA/S,GpDgjIM8yB,IACA,SAAUrzB,EAAQsT,EAASpT,GAEjC,YqDhmIA,SAAAqxB,GAAA7f,GACA,IAAAA,EACA,MAAAA,EAEA,IAAA0I,KAMA,OALAlG,GAAAof,SAAArlB,IAAAyD,EAAA,SAAA0e,GACA,MAAAA,KACG5kB,QAAA,SAAA4kB,GACHhW,EAAAgW,EAAApnB,KAAAonB,IAEAhW,EAoBA,QAAAoY,GAAAe,EAAAxoB,GAIA,QAAAyoB,GAAAxqB,GACA,MAAA+B,GAAArH,eAAAsF,GACA+B,EAAA/B,GAGAuqB,EAAAvqB,GARAuqB,QACAxoB,OAYA,IAAA0oB,MAEAC,IACA,QAAAC,KAAAJ,GACAxoB,EAAArH,eAAAiwB,GACAD,EAAAhvB,SACA+uB,EAAAE,GAAAD,EACAA,MAGAA,EAAA1pB,KAAA2pB,EAIA,IAAAnwB,OAAA,GACAowB,IACA,QAAAC,KAAA9oB,GAAA,CACA,GAAA0oB,EAAA/vB,eAAAmwB,GACA,IAAArwB,EAAA,EAAiBA,EAAAiwB,EAAAI,GAAAnvB,OAAqClB,IAAA,CACtD,GAAAswB,GAAAL,EAAAI,GAAArwB,EACAowB,GAAAH,EAAAI,GAAArwB,IAAAgwB,EAAAM,GAGAF,EAAAC,GAAAL,EAAAK,GAIA,IAAArwB,EAAA,EAAaA,EAAAkwB,EAAAhvB,OAAwBlB,IACrCowB,EAAAF,EAAAlwB,IAAAgwB,EAAAE,EAAAlwB,GAGA,OAAAowB,GAvFAtgB,EAAAM,YAAA,EACAN,EAAAie,kBACAje,EAAAkf,oBAEA,IAAAte,GAAAhU,EAAA,IrDusIM6zB,IACA,SAAU/zB,EAAQsT,EAASpT,GAEjC,YsDhrIA,SAAAyT,GAAAtQ,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,GAE7E,QAAAtB,GAAAC,EAAAC,GAAiD,KAAAD,YAAAC,IAA0C,SAAAC,WAAA,qCAE3F,QAAAC,GAAAC,EAAAC,GAAiD,IAAAD,EAAa,SAAAE,gBAAA,4DAAyF,QAAAD,GAAA,gBAAAA,IAAA,kBAAAA,GAAAD,EAAAC,EAEvJ,QAAAE,GAAAC,EAAAC,GAA0C,qBAAAA,IAAA,OAAAA,EAA+D,SAAAP,WAAA,iEAAAO,GAAuGD,GAAAE,UAAAC,OAAAC,OAAAH,KAAAC,WAAyEG,aAAeC,MAAAN,EAAAO,YAAA,EAAAC,UAAA,EAAAC,cAAA,KAA6ER,IAAAE,OAAAO,eAAAP,OAAAO,eAAAV,EAAAC,GAAAD,EAAAW,UAAAV,GAMrX,QAAAuxB,GAAAvK,EAAA1f,GASA,MARAkqB,GAAAvvB,OACAuvB,EAAAzoB,QAAA,SAAA5K,GACA,MAAA6oB,GAAAhU,iBAAA7U,EAAAmJ,GAAA,KAGA8a,WAAA9a,EAAA,GAGA,WACAkqB,EAAAvvB,QACAuvB,EAAAzoB,QAAA,SAAA5K,GACA,MAAA6oB,GAAAlC,oBAAA3mB,EAAAmJ,GAAA,MAtDAuJ,EAAAM,YAAA,CAEA,IAAArN,GAAA5D,OAAAmG,QAAA,SAAAvF,GAAmD,OAAAC,GAAA,EAAgBA,EAAAiB,UAAAC,OAAsBlB,IAAA,CAAO,GAAAuF,GAAAtE,UAAAjB,EAA2B,QAAAwF,KAAAD,GAA0BpG,OAAAD,UAAAgB,eAAArB,KAAA0G,EAAAC,KAAyDzF,EAAAyF,GAAAD,EAAAC,IAAiC,MAAAzF,IAE/O2wB,EAAAh0B,EAAA,KAEAi0B,EAAAxgB,EAAAugB,GAEAE,EAAAl0B,EAAA,KAEAm0B,EAAA1gB,EAAAygB,GAEAE,EAAAp0B,EAAA,KAEAq0B,EAAA5gB,EAAA2gB,GAEAE,EAAAt0B,EAAA,KAEAgU,EAAAhU,EAAA,GAEAsvB,EAAA7b,EAAAO,GAEAC,EAAAjU,EAAA,IAEAkU,EAAAT,EAAAQ,GAEAsgB,EAAAv0B,EAAA,IAEA2vB,EAAA3vB,EAAA,KAUA+zB,IACAO,GAAAE,eAAAT,EAAAjqB,KAAAwqB,EAAAE,eACAF,EAAAG,cAAAV,EAAAjqB,KAAAwqB,EAAAG,aAmBA,IAeAC,IAdAxgB,EAAAb,QAAAkW,KACAoG,EAAA5b,UAAA1S,WAKA6S,EAAAb,QAAAuc,KACA1b,EAAAb,QAAAuc,KACA1b,EAAAb,QAAAuc,KACA1b,EAAAb,QAAAshB,OACAzgB,EAAAb,QAAAshB,OACAzgB,EAAAb,QAAAshB,OAGA,SAAAlO,GAGA,QAAAiO,KACA,GAAAvL,GAAAziB,EAAA0iB,CAEAvnB,GAAA4E,KAAAiuB,EAEA,QAAAtnB,GAAA7I,UAAAC,OAAAyU,EAAA3L,MAAAF,GAAApB,EAAA,EAAmEA,EAAAoB,EAAapB,IAChFiN,EAAAjN,GAAAzH,UAAAyH,EAGA,OAAAmd,GAAAziB,EAAAzE,EAAAwE,KAAAggB,EAAAtkB,KAAAmK,MAAAma,GAAAhgB,MAAAsG,OAAAkM,KAAAvS,EAAAuqB,oBAAA,SAAA2D,GACAluB,EAAA3C,MAAA2Q,OACAhO,EAAAggB,WAAA,SAAAkO,EAAAluB,EAAA3C,MAAAosB,eAEAyE,KAEKluB,EAAA8qB,mBAAA,SAAAoD,GACLluB,EAAA3C,MAAAsQ,MACA3N,EAAAggB,WAAA,QAAAkO,EAAAluB,EAAA3C,MAAAssB,cAEAuE,KAEKluB,EAAAirB,mBAAA,SAAAiD,GACLluB,EAAA3C,MAAAuQ,MACA5N,EAAAggB,WAAA,QAAAkO,EAAAluB,EAAA3C,MAAAusB,cAEAsE,KAhBAxL,EAkBKD,EAAAlnB,EAAAyE,EAAA0iB,GAiHL,MA9IA/mB,GAAAqyB,EAAAjO,GAgCAiO,EAAAlyB,UAAAyvB,mBAAA,WACAxrB,KAAAouB,yBACApuB,KAAAquB,uBAGAJ,EAAAlyB,UAAAiF,qBAAA,WACAhB,KAAAsuB,WAAA,EAEAtuB,KAAA2d,SACAS,aAAApe,KAAA2d,SAEA3d,KAAAquB,mBAAAxpB,QAAA,SAAA8Y,GACAS,aAAAT,KAGA3d,KAAAouB,sBAAArwB,OAAA,GAGAkwB,EAAAlyB,UAAAkkB,WAAA,SAAAsO,EAAAC,EAAA7Q,GACA,GAAAmF,IAAA,EAAAgL,EAAAW,aAAAzuB,KAEA,KAAA8iB,EAIA,YAHA0L,GACAA,IAKA,IAAA9iB,GAAA1L,KAAA1C,MAAAa,KAAAowB,IAAAvuB,KAAA1C,MAAAa,KAAA,IAAAowB,EACAG,EAAA1uB,KAAA1C,MAAAa,KAAAowB,EAAA,WAAA7iB,EAAA,UACAijB,EAAA,KACAhK,MAAA,IAEA,EAAA6I,EAAA5gB,SAAAkW,EAAApX,GAGA1L,KAAA4uB,kBAAAF,EAAA5L,EAGA,IAAA+L,GAAA,SAAA50B,GACAA,KAAA2C,SAAAkmB,IAIA1E,aAAAuQ,GACAhK,QAEA,EAAA+I,EAAA9gB,SAAAkW,EAAApX,IACA,EAAAgiB,EAAA9gB,SAAAkW,EAAA4L,GAEA/J,OAIA6J,GACAA,KAIA7Q,IACAgR,EAAAzQ,WAAA2Q,EAAAlR,GACA3d,KAAAquB,mBAAAhrB,KAAAsrB,IACKd,EAAAE,gBACLpJ,EAAA0I,EAAAvK,EAAA+L,KAIAZ,EAAAlyB,UAAA6yB,kBAAA,SAAAljB,EAAAoX,GACA,GAAA5B,GAAAlhB,IAEAA,MAAAouB,sBAAA/qB,MACAqI,YACAoX,SAGA9iB,KAAA8uB,YACA9uB,KAAA8uB,WAAA,EAAAlB,EAAAhhB,SAAA,WACA,MAAAsU,GAAA6N,iCAKAd,EAAAlyB,UAAAgzB,2BAAA,WACA/uB,KAAAsuB,WACAtuB,KAAAouB,sBAAAvpB,QAAA,SAAAnI,GAIAA,EAAAomB,KAAAkM,WAEA,EAAAxB,EAAA5gB,SAAAlQ,EAAAomB,KAAApmB,EAAAgP,aAGA1L,KAAAouB,sBAAArwB,OAAA,EACAiC,KAAA8uB,UAAA,MAGAb,EAAAlyB,UAAA8F,OAAA,WACA,GAAAvE,GAAAsC,KAA2BI,KAAA1C,MAS3B,cARAA,GAAAa,WACAb,GAAA2Q,aACA3Q,GAAAsQ,YACAtQ,GAAAuQ,YACAvQ,GAAAosB,oBACApsB,GAAAssB,mBACAtsB,GAAAusB,mBACAvsB,GAAAyN,SACA8d,EAAAjc,QAAAyf,aAAAxD,EAAAjc,QAAA+f,SAAA3b,KAAAhR,KAAA1C,MAAAyN,UAAAzN,IAGA2wB,GACCpF,EAAAjc,QAAAuV,WAED8L,GAAAvuB,YAAA,0BAGAuuB,EAAAlsB,aAEA4K,EAAAC,QAAAqhB,EACA50B,EAAAsT,UAAA,StDqtIMsiB,IACA,SAAU51B,EAAQsT,EAASpT,GAEjC,YuD/6IA,SAAA21B,GAAAje,EAAAvF,GACAuF,EAAAuP,UAAAvP,EAAAuP,UAAAC,IAAA/U,IAA0D,EAAAyjB,EAAAviB,SAAAqE,OAAAvF,UAAAuF,EAAAvF,UAAA,IAAAA,GAZ1D1P,OAAAkK,eAAAyG,EAAA,cACAxQ,OAAA,IAEAwQ,EAAAC,QAAAsiB,CAEA,IAAAE,GAAA71B,EAAA,KAEA41B,EAEA,SAAAzyB,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,IAF7E0yB,EAOA/1B,GAAAsT,UAAA,SvDi8IM0iB,IACA,SAAUh2B,EAAQsT,EAASpT,GAEjC,YwD98IA,SAAA+1B,GAAAre,EAAAvF,GACA,MAAAuF,GAAAuP,YAAA9U,GAAAuF,EAAAuP,UAAAM,SAAApV,IAAqF,SAAAuF,EAAAvF,UAAA,KAAA5O,QAAA,IAAA4O,EAAA,KALrF1P,OAAAkK,eAAAyG,EAAA,cACAxQ,OAAA,IAEAwQ,EAAAC,QAAA0iB,EAIAj2B,EAAAsT,UAAA,SxDy9IM4iB,IACA,SAAUl2B,EAAQsT,EAASpT,GAEjC,YyDn+IAF,GAAAsT,QAAA,SAAAsE,EAAAvF,GACAuF,EAAAuP,UAAAvP,EAAAuP,UAAAG,OAAAjV,GAA6DuF,EAAAvF,UAAAuF,EAAAvF,UAAAgH,QAAA,GAAA8c,QAAA,UAAA9jB,EAAA,uBAAAgH,QAAA,YAAAA,QAAA,mBzD2+IvD+c,IACA,SAAUp2B,EAAQsT,EAASpT,GAEjC,Y0D78IA,SAAAm2B,GAAAlD,GACA,GAAAmD,IAAA,GAAAC,OAAAC,UACAjS,EAAAnW,KAAAqoB,IAAA,MAAAH,EAAA/C,IACAmD,EAAA7R,WAAAsO,EAAA5O,EAGA,OADAgP,GAAA+C,EACAI,EAxCA/zB,OAAAkK,eAAAyG,EAAA,cACAxQ,OAAA,GAGA,IAAA6zB,GAAAz2B,EAAA,KAEA02B,EAEA,SAAAvzB,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,IAF7EszB,GAIAE,GAAA,4BACAC,EAAA,eACAC,EAAAV,EACAW,MAAA,GAEAC,EAAA,SAAAC,EAAAC,GACA,MAAAD,MAAAC,EAAA,GAAAC,cAAAD,EAAAE,OAAA,GAAAF,GAAA,iBAGAP,GAAArjB,SACAsjB,EAAA/H,KAAA,SAAAoI,GACA,GAAAI,GAAAL,EAAAC,EAAA,UAEA,IAAAI,IAAA9jB,QAEA,MADAsjB,GAAAG,EAAAC,EAAA,UACAH,EAAA,SAAAQ,GACA,MAAA/jB,QAAA8jB,GAAAC,KAOA,IAAAhE,IAAA,GAAAgD,OAAAC,SAUAQ,GAAA,SAAAO,GACA,MAAAR,GAAAQ,IAEAP,EAAAF,OAAA,SAAAjnB,GACA2D,OAAAsjB,IAAA,kBAAAtjB,QAAAsjB,IAAAtjB,OAAAsjB,GAAAjnB,IAEAyD,EAAAC,QAAAyjB,EACAh3B,EAAAsT,UAAA,S1Ds/IMkkB,IACA,SAAUx3B,EAAQsT,EAASpT,GAEjC,Y2D3iJAyC,QAAAkK,eAAAyG,EAAA,cACAxQ,OAAA,IAEAwQ,EAAAqhB,aAAArhB,EAAAmkB,eAAAnkB,EAAAokB,gBAAApkB,EAAAqkB,kBAAArkB,EAAAskB,cAAAtkB,EAAAohB,cAAAphB,EAAAukB,mBAAAvkB,EAAAwkB,gBAAAxkB,EAAAykB,iBAAAzkB,EAAA0kB,mBAAA1kB,EAAAgN,cAAA3b,EAEA,IAAAgyB,GAAAz2B,EAAA,KAEA02B,EAEA,SAAAvzB,GAAsC,MAAAA,MAAAuQ,WAAAvQ,GAAuCkQ,QAAAlQ,IAF7EszB,GAIArW,EAAA,YACA2X,MAAA,GACAvD,MAAA,GACAC,MAAA,GACAqD,MAAA,GACAH,MAAA,GACAE,MAAA,GACAD,MAAA,GACAF,MAAA,GACAD,MAAA,GACAD,MAAA,GACAD,MAAA,EAEA,IAAAb,EAAArjB,QAAA,CACA,GAAA2kB,GAwCA,WAwBA,OAvBAC,GAAA1kB,SAAArB,cAAA,OAAA+lB,MAEAC,GACAC,EAAA,SAAAz3B,GACA,UAAAA,EAAAwsB,eAEAkL,IAAA,SAAA13B,GACA,MAAAA,GAAAwsB,eAEAmL,OAAA,SAAA33B,GACA,eAAAA,GAEA2jB,GAAA,SAAA3jB,GACA,WAAAA,IAIAi2B,EAAAl0B,OAAAW,KAAA80B,GAEA1D,MAAA,GACAC,MAAA,GACAsD,EAAA,GAEAz0B,EAAA,EAAiBA,EAAAqzB,EAAAnyB,OAAoBlB,IAAA,CACrC,GAAA0zB,GAAAL,EAAArzB,EAEA,IAAA0zB,EAAA,sBAAAiB,GAAA,CACAF,EAAA,IAAAf,EAAA9J,cACAsH,EAAA0D,EAAAlB,GAAA,iBACAvC,EAAAyD,EAAAlB,GAAA,eACA,QAUA,OANAxC,GAAA,sBAAAyD,KAAAzD,EAAA,kBAEAC,GAAA,iBAAAwD,KAAAxD,EAAA,gBAEAwD,EAAA,MAEUxD,eAAAD,gBAAAuD,YA/EVA,GAAAC,EAAAD,OACA3kB,EAAAohB,gBAAAwD,EAAAxD,cACAphB,EAAAqhB,eAAAuD,EAAAvD,aAGArhB,EAAAgN,YAAA2X,EAAA,IAAA3X,EACAhN,EAAA0kB,qBAAAC,EAAA,uBACA3kB,EAAAukB,qBAAAI,EAAA,uBACA3kB,EAAAwkB,kBAAAG,EAAA,oBACA3kB,EAAAykB,mBAAAE,EAAA,8BAEA3kB,EAAAskB,gBAAAK,EAAA,kBACA3kB,EAAAqkB,oBAAAM,EAAA,sBACA3kB,EAAAokB,kBAAAO,EAAA,mBACA3kB,EAAAmkB,iBAAAQ,EAAA,6BAGA3kB,EAAAgN,YACAhN,EAAA0kB,qBACA1kB,EAAAykB,mBACAzkB,EAAAwkB,kBACAxkB,EAAAukB,qBACAvkB,EAAAohB,gBACAphB,EAAAskB,gBACAtkB,EAAAqkB,oBACArkB,EAAAokB,kBACApkB,EAAAmkB,iBACAnkB,EAAAqhB,eACArhB,EAAAC,SACA+M,YACAkY,IAAA9D,EACA+D,SAAAT,EACAU,OAAAX,EACAY,MAAAb,EACAhlB,SAAA+kB,I3DgmJMe,IACA,SAAU54B,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEE,EAAsD/R,EAAoB,IAC1E24B,EAA0D34B,EAAoB,IAC9E44B,EAAsD54B,EAAoB,I4D5pJ7F64B,EAAiB,SAAAv0B,GAA8B,GAA3B4M,GAA2B5M,EAA3B4M,KAAMwX,EAAqBpkB,EAArBokB,MAAOZ,EAAcxjB,EAAdwjB,QAC/BgR,EAAmB,IAAVpQ,CAEf,OACE5W,GAAA7Q,EAAAiR,cAACymB,EAAA,GACCI,KAAM7nB,EAAKvB,GAAL,GAAaoC,EAAA,EAAWwR,MAAQrS,EAAKvB,GAArC,IAA6CoC,EAAA,EAAWwR,MAC9DpR,UAAU,qBACV2V,QAASA,GAEThW,EAAA7Q,EAAAiR,cAAA,OAAKC,UAAU,6BACbL,EAAA7Q,EAAAiR,cAAC0mB,EAAA,GAAKh0B,KAAMk0B,EAAS,OAAS,eAC9BhnB,EAAA7Q,EAAAiR,cAAA,YAAOhB,EAAK8nB,qBAAuBjnB,EAAA,EAAQwR,SAenDxjB,GAAA,K5D6qJMk5B,IACA,SAAUn5B,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEE,EAAsD/R,EAAoB,IAC1EgS,EAAsDhS,EAAoB,IAC1Ek5B,EAA0Dl5B,EAAoB,IAC9Em5B,EAAgFn5B,EAAoB,K6DltJvHo5B,EACJtnB,EAAA7Q,EAAAiR,cAACF,EAAA,GAAKpN,KAAK,mBAOPy0B,EAAe,SAAA/0B,GAAuB,GAApBujB,GAAoBvjB,EAApBujB,KAAMC,EAAcxjB,EAAdwjB,QACpBnY,EAAyCkY,EAAzClY,GAAyB2pB,EAAgBzR,EAArCmR,oBAA4B1oB,EAASuX,EAATvX,KAClCipB,EAAcjpB,EAAKkB,SAASC,MAAQ,EACpC+nB,EAAclpB,EAAKwE,OAAOC,OAASzE,EAAKwE,OAAO2kB,uBAErD,OACE3nB,GAAA7Q,EAAAiR,cAAA,OAAKC,UAAU,oBACbL,EAAA7Q,EAAAiR,cAACgnB,EAAA,GAAOH,KAAA,GAAShnB,EAAA,EAAWwR,MAAQ5T,EAA5B,IAAmCwC,UAAU,0BAClDonB,EAAcH,EAAe,KAE9BtnB,EAAA7Q,EAAAiR,cAAA,MAAIC,UAAU,2BACXmnB,GAGDE,EAIE,KAHF1nB,EAAA7Q,EAAAiR,cAAA,QAAMC,UAAU,oBACdL,EAAA7Q,EAAAiR,cAACinB,EAAA,GAAkBrkB,OAAQxE,EAAKwE,WAItChD,EAAA7Q,EAAAiR,cAACgnB,EAAA,GACCH,KAAA,GAAShnB,EAAA,EAAWwR,MAAQ5T,EAA5B,SACAwC,UAAU,4DAEVL,EAAA7Q,EAAAiR,cAACF,EAAA,GAAKpN,KAAK,OAAO00B,MAAOvnB,EAAA,EAAQ2nB,UAAUvgB,QAAQ,UAAWmgB,MAE/DC,EACCznB,EAAA7Q,EAAAiR,cAACgnB,EAAA,GACC/mB,UAAU,2BACV2V,QAASA,EACTiR,KAAA,GAAShnB,EAAA,EAAWwR,MAAQ5T,EAA5B,KAEAmC,EAAA7Q,EAAAiR,cAACF,EAAA,GAAKpN,KAAK,cAAc00B,MAAOvnB,EAAA,EAAQ4nB,yBAAyBxgB,QAAQ,UAAWmgB,MAEpF,MAgBVv5B,GAAA,K7D4tJM65B,IACA,SAAU95B,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEE,EAAsD/R,EAAoB,IAC1E65B,EAA2C75B,EAAoB,I8DhyJlF85B,EAAY,SAAAx1B,GAAc,GAAX4M,GAAW5M,EAAX4M,KACbO,EAAQP,EAAKM,SAASC,KAE5B,OACEK,GAAA7Q,EAAAiR,cAAA,KACE6mB,KAAA,GAAShnB,EAAA,EAAWwR,MAAQrS,EAAKvB,GAAjC,IACAwC,UAAU,wBAETJ,EAAA,EAAQgoB,QACTjoB,EAAA7Q,EAAAiR,cAAA,gBAAWT,EAAX,KAA8B,IAAVA,EAAcM,EAAA,EAAQioB,KAAK9M,cAAgBnb,EAAA,EAAQwR,MAAM2J,gBAC7Epb,EAAA7Q,EAAAiR,cAAC2nB,EAAA,GAAKj1B,KAAK,iBASjB7E,GAAA,K9D6yJMk6B,IACA,SAAUn6B,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GACpEgR,EAA4C7iB,EAAoB,KAChE8iB,EAAyC9iB,EAAoB,KAC7Dk5B,EAA0Dl5B,EAAoB,I+Dn0JjGk6B,EAAiB,SAAA51B,GAAA,GAAGkN,GAAHlN,EAAGkN,SAAU2oB,EAAb71B,EAAa61B,QAAb,OACrBroB,GAAA7Q,EAAAiR,cAACgnB,EAAA,GACC/mB,UAAU,kBACVioB,KAAK,sBACLC,eAAe,EACfvS,QAASqS,GAER3oB,IASC2J,EAAkB,qBAElBC,EAAqB,SAAC1Z,GAAD,OACzBy4B,SAAU,SAACjpB,GAAD,MAAUxP,GAASohB,EAAA,EAAuB5R,OAGhDmK,EAAa,SAACwF,EAAYC,EAAe1R,GAA5B,OACjBoC,SAAUpC,EAASoC,SACnB2oB,SAAUrZ,EAAcqZ,SAASnzB,KAAK,KAAMoI,EAASyH,YAGvD9W,GAAA,EAAe0C,OAAAogB,EAAA,GAAQ1H,EAAiBC,EAAoBC,GAAY6e,I/D01JlEI,IACA,SAAUx6B,EAAQC,EAAqBC,GAE7C,YgEz3Je,SAAS8Q,KAAsD,GAA7CypB,GAA6Ch2B,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,GAAjCi2B,EAAiCl2B,EAAAC,UAAA,GAAjB2F,EAAiB5F,EAAjB4F,KAAMwb,EAAWphB,EAAXohB,OACjE,QAAQxb,GACR,IAAK,gBAEH,OACE8G,WAAW,EACXiS,MAAOyC,EAAQ/V,IAGnB,KAAK,iBACH,MAAO6qB,EAET,KAAK,YACH,OACExpB,UAAWupB,EAAUvpB,UACrBiS,KAAMsX,EAAUtX,KAAKlW,QAAQ2Y,EAAQ/V,KAGzC,KAAK,WACH,OACEqB,UAAWupB,EAAUvpB,UACrBiS,KAAMsX,EAAUtX,KAAKvZ,MAAM,GAAI,GAGnC,SACE,MAAO6wB,IAnCXx6B,EAAA,EAAA+Q,CAAA,IAAM0pB,IACJxpB,WAAW,EACXiS,UhEi7JIwX,IACA,SAAU36B,EAAQC,EAAqBC,GAE7C,YAEA,SAAS0M,GAAgBvJ,EAAK2F,EAAKlG,GAAiK,MAApJkG,KAAO3F,GAAOV,OAAOkK,eAAexJ,EAAK2F,GAAOlG,MAAOA,EAAOC,YAAY,EAAME,cAAc,EAAMD,UAAU,IAAkBK,EAAI2F,GAAOlG,EAAgBO,EiE/3J5L,QAAS4N,KAA+C,GAAzCpK,GAAyCpC,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,GAAjCi2B,EAAiCpzB,EAAA7C,UAAA,GAAjB2F,EAAiB9C,EAAjB8C,KAAMwb,EAAWte,EAAXse,OAC1D,QAAQxb,GACR,IAAK,gBACL,IAAK,mBACL,IAAK,qBACL,IAAK,mBACL,IAAK,uBACH,MAAOzH,QAAOmG,UAAWjC,EAAlB+F,KAEJgZ,EAAQ/V,GAAK4Z,EAAK5iB,EAAM+e,EAAQ/V,KAAOzF,OAAMwb,aAIlD,KAAK,uBACH,GAAMgV,GAAWj4B,OAAOmG,UAAWjC,EAAlB+F,KACdgZ,EAAQ/V,GAAK4Z,EAAK5iB,EAAM+e,EAAQ/V,KAAOzF,OAAMwb,aAOhD,OAJAA,GAAQrV,MAAM/E,QAAQ,SAACuc,GACrB6S,EAAS7S,EAAKlY,IAAMlN,OAAOmG,UAAW+xB,EAAkB9S,KAGnD6S,CAET,SACE,MAAO/zB,IjEq2JsB5G,EAAuB,EAAIgR,CiEv7J5D,IAAM4pB,IACJppB,YAAY,EACZyW,SAAS,EACTxW,UACEnB,SACAoB,MAAO,GAETnB,MACEkB,cAOE+X,EAAO,WAAiD,GAAhD5iB,GAAgDpC,UAAAC,OAAA,OAAAC,KAAAF,UAAA,GAAAA,UAAA,GAAxCo2B,EAAwCr2B,EAAAC,UAAA,GAApB2F,EAAoB5F,EAApB4F,KAAMwb,EAAcphB,EAAdohB,OAC9C,QAAQxb,GACR,IAAK,gBACH,MAAOvD,IAASg0B,CAElB,KAAK,mBACH,MAAOl4B,QAAOmG,UAAWjC,EAAO+e,EAAQ3V,MACtCiY,SAAS,GAGb,KAAK,qBACH,MAAOvlB,QAAOmG,UAAWjC,GACvB4K,YAAY,GAGhB,KAAK,uBACH,MAAO9O,QAAOmG,UAAWjC,GACvB4K,YAAY,EACZyW,SAAS,EACTxW,UACEnB,MAAO1J,EAAM6K,SAASnB,MAAM3G,QAAQqD,OAAO2Y,EAAQrV,MAAMtC,IAAI,SAAA8Z,GAAA,MAAQA,GAAKlY,MAC1E8B,MAAOiU,EAAQpV,KAAKG,cAI1B,KAAK,mBACL,IAAK,uBACH,MAAOhO,QAAOmG,UAAWjC,GACvB4K,YAAY,EACZyW,SAAS,GAGb,SACE,MAAOrhB,KAIL6zB,MjEq+JAI,IACA,SAAU96B,EAAQC,EAAqBC,GAE7C,YkE5hKAA,GAAAG,EAAAJ,EAAA,qBAAA86B,IAAA,IAGMC,GAAqB,SAACC,GAC1BxnB,SAAS4T,KAAKF,UAAUK,OAHN,qBAG2ByT,GAC7CxnB,SAAS4T,KAAKF,UAAUK,OALP,mBAK0ByT,IAGvCC,EAAqBF,EAAmB9zB,KAAK,MAAM,GACnDi0B,EAAkBH,EAAmB9zB,KAAK,MAAM,GAMzC6zB,EAAmB,WAE9BG,IAEA1nB,OAAOiC,iBAAiB,YAAaylB,GACrC1nB,OAAOiC,iBAAiB,aAAcylB,GAEtC1nB,OAAOiC,iBAAiB,UAAW,SAAA7U,GACF,IAAdA,EAAE4rB,SAGjB2O,QlEqiKAC,IACA,SAAUp7B,EAAQC,EAAqBC,GAE7C,YAEA,SAASm7B,GAAmBC,GAAO,GAAI9tB,MAAM+tB,QAAQD,GAAM,CAAE,IAAK,GAAI93B,GAAI,EAAGg4B,EAAOhuB,MAAM8tB,EAAI52B,QAASlB,EAAI83B,EAAI52B,OAAQlB,IAAOg4B,EAAKh4B,GAAK83B,EAAI93B,EAAM,OAAOg4B,GAAe,MAAOhuB,OAAMiuB,KAAKH,GAD3Jp7B,EAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOy7B,ImE/jKnG,IAAMA,GAAe,WACnB,GAAMC,GAAsBloB,SAASkC,cAAc,qBAEnD,IAAKgmB,EAAL,CAIA,GAAMC,GAAkBnoB,SAAS+a,iBAC/B,sCAEIqN,EAAc,oBAEpB5uB,OAAAouB,EAAIO,IAAiBpwB,QAAQ,SAAAswB,GAC3BA,EAAermB,iBAAiB,QAAS,SAAAsmB,GACvC,GAAMC,GAAmBF,EAAe3kB,UAExCwkB,GAAoBxU,UAAUG,OAAOuU,MACrC5uB,OAAAouB,EAAIO,IAAiBpwB,QAAQ,SAAAywB,GAAA,MAAMA,GAAG9U,UAAUG,OAAOuU,KAEvDF,EAAoBxU,UAAUK,OAAOqU,GACrCG,EAAiB7U,UAAUK,OAAOqU,GAElCpoB,SAASgC,iBAAiB,YAAa,SAAA7U,GAElCo7B,EAAiBvU,SAAS7mB,EAAE2C,SAC7Bu4B,IAAmBl7B,EAAE2C,SAErBo4B,EAAoBxU,UAAUG,OAAOuU,GACrCG,EAAiB7U,UAAUG,OAAOuU,MAItCpoB,SAASgC,iBAAiB,UAAW,SAAA7U,GAErB,WAAVA,EAAEoI,KAA8B,QAAVpI,EAAEoI,MAC1B2yB,EAAoBxU,UAAUG,OAAOuU,GACrCG,EAAiB7U,UAAUG,OAAOuU,MAItCE,EAAWrU,wBnE4kKXwU,IACA,SAAUl8B,EAAQC,EAAqBC,GAE7C,YAC+BA,GAAoBG,EAAEJ,EAAqB,IAAK,WAAa,MAAOk8B,IAC9E,IAAIC,GAA+Cl8B,EAAoB,KoE3nKtFi8B,EAA0B,WAC9B,GAAMlQ,GAAYxY,SAASkC,cAAc,iBAEzC,IAAKsW,EAAL,CAWA,GAAMoQ,GAAc,yCACdC,EAAiBrQ,EAAUsQ,QAAQC,cAEzCzY,OAAMsY,GAAarsB,KAAK,SAAAkU,GACtB,MAAwB,OAApBA,EAASlP,QAEXvU,QAAQg8B,IAAR,4BAAwCJ,EAAxC,aAAgEnY,EAASlP,SAClE,GAEFkP,EAASG,SACfrU,KAAK,SAAAC,GACFA,GAAQA,EAAKtK,SAAWhD,OAAAy5B,EAAA,GAAiBnsB,EAAKtK,QAAS22B,KACzDrQ,EAAUtW,cAAc,0BAA0B+mB,UAAYzsB,EAAKtK,QACnEsmB,EAAUtW,cAAc,uBAAuBgnB,aAAa,OAAQ1sB,EAAKuT,KACzEyI,EAAUkM,MAAMpK,QAAU,MAG3B6O,MAAM,SAAA5X,GAELvkB,QAAQg8B,IAAR,kBAA8BJ,EAA9B,YAAqDrX,QpEqoKrD6X,IACA,SAAU78B,EAAQC,EAAqBC,GAE7C,YqE3qKA,SAAS48B,GAAeC,EAAUC,GAKhC,IAAK,GAJCC,GAAK,eACLC,GAAMH,EAAW,IAAI1jB,QAAQ4jB,EAAI,IAAIzuB,MAAM,KAC3C2uB,GAAMH,EAAW,IAAI3jB,QAAQ4jB,EAAI,IAAIzuB,MAAM,KAC3C0kB,EAAM9kB,KAAKgvB,IAAIF,EAAGx4B,OAAQy4B,EAAGz4B,QAC1BlB,EAAI,EAAGA,EAAI0vB,EAAK1vB,IAAK,CAC5B,GAAM65B,GAAMrmB,SAASkmB,EAAG15B,GAAI,IAAMwT,SAASmmB,EAAG35B,GAAI,GAClD,IAAY,IAAR65B,EACF,MAAOA,GAIX,MAAOH,GAAGx4B,OAASy4B,EAAGz4B,OAGxB,QAAS44B,GAAiBC,EAAejB,GACvC,MAAOQ,GAAeS,EAAejB,GAAkB,EAhBzDp8B,EAAAG,EAAAJ,EAAA,qBAAAq9B,MrEqsKME,GACA,SAAUx9B,EAAQC,EAAqBC,GAE7C,YACqB,IAAI6R,GAAsC7R,EAAoB,GAC1D8R,EAA8C9R,EAAoBgB,EAAE6Q,GsEvsKvF0rB,EAAe,SAACprB,EAAWioB,GAC/B,GAAMoD,GAAmB,KAATpD,EACZqD,EAAW,EAQf,OAPID,KAEAC,EADkB,gBAATrD,GACTqD,SAAoBrD,EAETA,EAAKrsB,IAAI,SAAA2vB,GAAA,eAAgBA,IAAOnvB,KAAK,KAG1C4D,EAAV,KAAuBqrB,EAAU,OAAS,IAAKC,GAG3CE,EAAc,SAAC5E,EAAMjR,EAASN,EAAgB9mB,GAC9C8mB,GAA2B,MAATuR,IACpBr4B,EAAE8mB,iBACF9mB,EAAE+mB,mBAGAK,GACFA,EAAQpnB,IAONk9B,EAAS,SAAAt5B,GAWT,GAVJ6N,GAUI7N,EAVJ6N,UACAioB,EASI91B,EATJ81B,KACA5oB,EAQIlN,EARJkN,SACAqsB,EAOIv5B,EAPJu5B,gBACAC,EAMIx5B,EANJw5B,UACA/E,EAKIz0B,EALJy0B,KACA11B,EAIIiB,EAJJjB,OACAmkB,EAGIljB,EAHJkjB,eACAM,EAEIxjB,EAFJwjB,QACAuS,EACI/1B,EADJ+1B,cAEM0D,EAAuB,OAAbvsB,EACVisB,EAAWK,EAAY,UAAY1D,EACnC4D,EAAgBH,EACpB/rB,EAAA7Q,EAAAiR,cAAA,QAAMC,UAAU,kBACb0rB,GAED,IAEJ,OACE/rB,GAAA7Q,EAAAiR,cAAA,KACEC,UAAWorB,EAAaprB,EAAWsrB,GACnC3V,QAAS6V,EAAY32B,KAAK,KAAM+xB,EAAMjR,EAASN,GAC/CyW,IAAgB,WAAX56B,EAAsB,sBAAwB,KACnD01B,KAAMA,EACN11B,OAAQA,EACR66B,gBAAe7D,EAAgB,SAAW,MAEzC0D,EAAUvsB,EAAWwsB,GAqB5BJ,GAAO1qB,cACL6lB,KAAM,IACN5mB,UAAW,GACXioB,KAAM,GACN/2B,OAAQ,KACRmO,SAAU,KACVqsB,gBAAiB,KACjB/V,QAAS,KACTgW,WAAW,EACXtW,gBAAgB,EAChB6S,eAAe,GAGjBt6B,EAAA,OtEisKG","file":"wagtail/admin/static/wagtailadmin/js/wagtailadmin.js","sourcesContent":["webpackJsonp([1],{\n\n/***/ 122:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__components_Provider__ = __webpack_require__(423);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_connectAdvanced__ = __webpack_require__(175);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__connect_connect__ = __webpack_require__(429);\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return __WEBPACK_IMPORTED_MODULE_0__components_Provider__[\"a\"]; });\n/* unused harmony reexport createProvider */\n/* unused harmony reexport connectAdvanced */\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return __WEBPACK_IMPORTED_MODULE_2__connect_connect__[\"a\"]; });\n\n\n\n\n\n\n/***/ }),\n\n/***/ 123:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = warning;\n/**\n * Prints a warning in the console if it exists.\n *\n * @param {String} message The warning message.\n * @returns {void}\n */\nfunction warning(message) {\n /* eslint-disable no-console */\n if (typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error(message);\n }\n /* eslint-enable no-console */\n try {\n // This error was thrown as a convenience so that if you enable\n // \"break on all exceptions\" in your console,\n // it would pause the execution at this line.\n throw new Error(message);\n /* eslint-disable no-empty */\n } catch (e) {}\n /* eslint-enable no-empty */\n}\n\n/***/ }),\n\n/***/ 174:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return subscriptionShape; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return storeShape; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_prop_types__ = __webpack_require__(59);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_prop_types__);\n\n\nvar subscriptionShape = __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.shape({\n trySubscribe: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired,\n tryUnsubscribe: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired,\n notifyNestedSubs: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired,\n isSubscribed: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired\n});\n\nvar storeShape = __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.shape({\n subscribe: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired,\n dispatch: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired,\n getState: __WEBPACK_IMPORTED_MODULE_0_prop_types___default.a.func.isRequired\n});\n\n/***/ }),\n\n/***/ 175:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = connectAdvanced;\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_hoist_non_react_statics__ = __webpack_require__(426);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_hoist_non_react_statics___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_hoist_non_react_statics__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_invariant__ = __webpack_require__(427);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_invariant___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_invariant__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_react__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__utils_Subscription__ = __webpack_require__(428);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__utils_PropTypes__ = __webpack_require__(174);\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\n\n\n\n\n\n\n\nvar hotReloadingVersion = 0;\nvar dummyState = {};\nfunction noop() {}\nfunction makeSelectorStateful(sourceSelector, store) {\n // wrap the selector in an object that tracks its results between runs.\n var selector = {\n run: function runComponentSelector(props) {\n try {\n var nextProps = sourceSelector(store.getState(), props);\n if (nextProps !== selector.props || selector.error) {\n selector.shouldComponentUpdate = true;\n selector.props = nextProps;\n selector.error = null;\n }\n } catch (error) {\n selector.shouldComponentUpdate = true;\n selector.error = error;\n }\n }\n };\n\n return selector;\n}\n\nfunction connectAdvanced(\n/*\n selectorFactory is a func that is responsible for returning the selector function used to\n compute new props from state, props, and dispatch. For example:\n export default connectAdvanced((dispatch, options) => (state, props) => ({\n thing: state.things[props.thingId],\n saveThing: fields => dispatch(actionCreators.saveThing(props.thingId, fields)),\n }))(YourComponent)\n Access to dispatch is provided to the factory so selectorFactories can bind actionCreators\n outside of their selector as an optimization. Options passed to connectAdvanced are passed to\n the selectorFactory, along with displayName and WrappedComponent, as the second argument.\n Note that selectorFactory is responsible for all caching/memoization of inbound and outbound\n props. Do not use connectAdvanced directly without memoizing results between calls to your\n selector, otherwise the Connect component will re-render on every state or props change.\n*/\nselectorFactory) {\n var _contextTypes, _childContextTypes;\n\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$getDisplayName = _ref.getDisplayName,\n getDisplayName = _ref$getDisplayName === undefined ? function (name) {\n return 'ConnectAdvanced(' + name + ')';\n } : _ref$getDisplayName,\n _ref$methodName = _ref.methodName,\n methodName = _ref$methodName === undefined ? 'connectAdvanced' : _ref$methodName,\n _ref$renderCountProp = _ref.renderCountProp,\n renderCountProp = _ref$renderCountProp === undefined ? undefined : _ref$renderCountProp,\n _ref$shouldHandleStat = _ref.shouldHandleStateChanges,\n shouldHandleStateChanges = _ref$shouldHandleStat === undefined ? true : _ref$shouldHandleStat,\n _ref$storeKey = _ref.storeKey,\n storeKey = _ref$storeKey === undefined ? 'store' : _ref$storeKey,\n _ref$withRef = _ref.withRef,\n withRef = _ref$withRef === undefined ? false : _ref$withRef,\n connectOptions = _objectWithoutProperties(_ref, ['getDisplayName', 'methodName', 'renderCountProp', 'shouldHandleStateChanges', 'storeKey', 'withRef']);\n\n var subscriptionKey = storeKey + 'Subscription';\n var version = hotReloadingVersion++;\n\n var contextTypes = (_contextTypes = {}, _contextTypes[storeKey] = __WEBPACK_IMPORTED_MODULE_4__utils_PropTypes__[\"a\" /* storeShape */], _contextTypes[subscriptionKey] = __WEBPACK_IMPORTED_MODULE_4__utils_PropTypes__[\"b\" /* subscriptionShape */], _contextTypes);\n var childContextTypes = (_childContextTypes = {}, _childContextTypes[subscriptionKey] = __WEBPACK_IMPORTED_MODULE_4__utils_PropTypes__[\"b\" /* subscriptionShape */], _childContextTypes);\n\n return function wrapWithConnect(WrappedComponent) {\n __WEBPACK_IMPORTED_MODULE_1_invariant___default()(typeof WrappedComponent == 'function', 'You must pass a component to the function returned by ' + ('connect. Instead received ' + JSON.stringify(WrappedComponent)));\n\n var wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n\n var displayName = getDisplayName(wrappedComponentName);\n\n var selectorFactoryOptions = _extends({}, connectOptions, {\n getDisplayName: getDisplayName,\n methodName: methodName,\n renderCountProp: renderCountProp,\n shouldHandleStateChanges: shouldHandleStateChanges,\n storeKey: storeKey,\n withRef: withRef,\n displayName: displayName,\n wrappedComponentName: wrappedComponentName,\n WrappedComponent: WrappedComponent\n });\n\n var Connect = function (_Component) {\n _inherits(Connect, _Component);\n\n function Connect(props, context) {\n _classCallCheck(this, Connect);\n\n var _this = _possibleConstructorReturn(this, _Component.call(this, props, context));\n\n _this.version = version;\n _this.state = {};\n _this.renderCount = 0;\n _this.store = props[storeKey] || context[storeKey];\n _this.propsMode = Boolean(props[storeKey]);\n _this.setWrappedInstance = _this.setWrappedInstance.bind(_this);\n\n __WEBPACK_IMPORTED_MODULE_1_invariant___default()(_this.store, 'Could not find \"' + storeKey + '\" in either the context or props of ' + ('\"' + displayName + '\". Either wrap the root component in a , ') + ('or explicitly pass \"' + storeKey + '\" as a prop to \"' + displayName + '\".'));\n\n _this.initSelector();\n _this.initSubscription();\n return _this;\n }\n\n Connect.prototype.getChildContext = function getChildContext() {\n var _ref2;\n\n // If this component received store from props, its subscription should be transparent\n // to any descendants receiving store+subscription from context; it passes along\n // subscription passed to it. Otherwise, it shadows the parent subscription, which allows\n // Connect to control ordering of notifications to flow top-down.\n var subscription = this.propsMode ? null : this.subscription;\n return _ref2 = {}, _ref2[subscriptionKey] = subscription || this.context[subscriptionKey], _ref2;\n };\n\n Connect.prototype.componentDidMount = function componentDidMount() {\n if (!shouldHandleStateChanges) return;\n\n // componentWillMount fires during server side rendering, but componentDidMount and\n // componentWillUnmount do not. Because of this, trySubscribe happens during ...didMount.\n // Otherwise, unsubscription would never take place during SSR, causing a memory leak.\n // To handle the case where a child component may have triggered a state change by\n // dispatching an action in its componentWillMount, we have to re-run the select and maybe\n // re-render.\n this.subscription.trySubscribe();\n this.selector.run(this.props);\n if (this.selector.shouldComponentUpdate) this.forceUpdate();\n };\n\n Connect.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n this.selector.run(nextProps);\n };\n\n Connect.prototype.shouldComponentUpdate = function shouldComponentUpdate() {\n return this.selector.shouldComponentUpdate;\n };\n\n Connect.prototype.componentWillUnmount = function componentWillUnmount() {\n if (this.subscription) this.subscription.tryUnsubscribe();\n this.subscription = null;\n this.notifyNestedSubs = noop;\n this.store = null;\n this.selector.run = noop;\n this.selector.shouldComponentUpdate = false;\n };\n\n Connect.prototype.getWrappedInstance = function getWrappedInstance() {\n __WEBPACK_IMPORTED_MODULE_1_invariant___default()(withRef, 'To access the wrapped instance, you need to specify ' + ('{ withRef: true } in the options argument of the ' + methodName + '() call.'));\n return this.wrappedInstance;\n };\n\n Connect.prototype.setWrappedInstance = function setWrappedInstance(ref) {\n this.wrappedInstance = ref;\n };\n\n Connect.prototype.initSelector = function initSelector() {\n var sourceSelector = selectorFactory(this.store.dispatch, selectorFactoryOptions);\n this.selector = makeSelectorStateful(sourceSelector, this.store);\n this.selector.run(this.props);\n };\n\n Connect.prototype.initSubscription = function initSubscription() {\n if (!shouldHandleStateChanges) return;\n\n // parentSub's source should match where store came from: props vs. context. A component\n // connected to the store via props shouldn't use subscription from context, or vice versa.\n var parentSub = (this.propsMode ? this.props : this.context)[subscriptionKey];\n this.subscription = new __WEBPACK_IMPORTED_MODULE_3__utils_Subscription__[\"a\" /* default */](this.store, parentSub, this.onStateChange.bind(this));\n\n // `notifyNestedSubs` is duplicated to handle the case where the component is unmounted in\n // the middle of the notification loop, where `this.subscription` will then be null. An\n // extra null check every change can be avoided by copying the method onto `this` and then\n // replacing it with a no-op on unmount. This can probably be avoided if Subscription's\n // listeners logic is changed to not call listeners that have been unsubscribed in the\n // middle of the notification loop.\n this.notifyNestedSubs = this.subscription.notifyNestedSubs.bind(this.subscription);\n };\n\n Connect.prototype.onStateChange = function onStateChange() {\n this.selector.run(this.props);\n\n if (!this.selector.shouldComponentUpdate) {\n this.notifyNestedSubs();\n } else {\n this.componentDidUpdate = this.notifyNestedSubsOnComponentDidUpdate;\n this.setState(dummyState);\n }\n };\n\n Connect.prototype.notifyNestedSubsOnComponentDidUpdate = function notifyNestedSubsOnComponentDidUpdate() {\n // `componentDidUpdate` is conditionally implemented when `onStateChange` determines it\n // needs to notify nested subs. Once called, it unimplements itself until further state\n // changes occur. Doing it this way vs having a permanent `componentDidUpdate` that does\n // a boolean check every time avoids an extra method call most of the time, resulting\n // in some perf boost.\n this.componentDidUpdate = undefined;\n this.notifyNestedSubs();\n };\n\n Connect.prototype.isSubscribed = function isSubscribed() {\n return Boolean(this.subscription) && this.subscription.isSubscribed();\n };\n\n Connect.prototype.addExtraProps = function addExtraProps(props) {\n if (!withRef && !renderCountProp && !(this.propsMode && this.subscription)) return props;\n // make a shallow copy so that fields added don't leak to the original selector.\n // this is especially important for 'ref' since that's a reference back to the component\n // instance. a singleton memoized selector would then be holding a reference to the\n // instance, preventing the instance from being garbage collected, and that would be bad\n var withExtras = _extends({}, props);\n if (withRef) withExtras.ref = this.setWrappedInstance;\n if (renderCountProp) withExtras[renderCountProp] = this.renderCount++;\n if (this.propsMode && this.subscription) withExtras[subscriptionKey] = this.subscription;\n return withExtras;\n };\n\n Connect.prototype.render = function render() {\n var selector = this.selector;\n selector.shouldComponentUpdate = false;\n\n if (selector.error) {\n throw selector.error;\n } else {\n return Object(__WEBPACK_IMPORTED_MODULE_2_react__[\"createElement\"])(WrappedComponent, this.addExtraProps(selector.props));\n }\n };\n\n return Connect;\n }(__WEBPACK_IMPORTED_MODULE_2_react__[\"Component\"]);\n\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = displayName;\n Connect.childContextTypes = childContextTypes;\n Connect.contextTypes = contextTypes;\n Connect.propTypes = contextTypes;\n\n if (false) {\n Connect.prototype.componentWillUpdate = function componentWillUpdate() {\n var _this2 = this;\n\n // We are hot reloading!\n if (this.version !== version) {\n this.version = version;\n this.initSelector();\n\n // If any connected descendants don't hot reload (and resubscribe in the process), their\n // listeners will be lost when we unsubscribe. Unfortunately, by copying over all\n // listeners, this does mean that the old versions of connected descendants will still be\n // notified of state changes; however, their onStateChange function is a no-op so this\n // isn't a huge deal.\n var oldListeners = [];\n\n if (this.subscription) {\n oldListeners = this.subscription.listeners.get();\n this.subscription.tryUnsubscribe();\n }\n this.initSubscription();\n if (shouldHandleStateChanges) {\n this.subscription.trySubscribe();\n oldListeners.forEach(function (listener) {\n return _this2.subscription.listeners.subscribe(listener);\n });\n }\n }\n };\n }\n\n return __WEBPACK_IMPORTED_MODULE_0_hoist_non_react_statics___default()(Connect, WrappedComponent);\n };\n}\n\n/***/ }),\n\n/***/ 176:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"e\", function() { return createStore; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"c\", function() { return combineReducers; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return bindActionCreators; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return applyMiddleware; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"d\", function() { return compose; });\n/* unused harmony export __DO_NOT_USE__ActionTypes */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_symbol_observable__ = __webpack_require__(432);\n\n\n/**\n * These are private action types reserved by Redux.\n * For any unknown actions, you must return the current state.\n * If the current state is undefined, you must return the initial state.\n * Do not reference these action types directly in your code.\n */\nvar randomString = function randomString() {\n return Math.random().toString(36).substring(7).split('').join('.');\n};\n\nvar ActionTypes = {\n INIT: \"@@redux/INIT\" + randomString(),\n REPLACE: \"@@redux/REPLACE\" + randomString(),\n PROBE_UNKNOWN_ACTION: function PROBE_UNKNOWN_ACTION() {\n return \"@@redux/PROBE_UNKNOWN_ACTION\" + randomString();\n }\n};\n\n/**\n * @param {any} obj The object to inspect.\n * @returns {boolean} True if the argument appears to be a plain object.\n */\nfunction isPlainObject(obj) {\n if (typeof obj !== 'object' || obj === null) return false;\n var proto = obj;\n\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n\n return Object.getPrototypeOf(obj) === proto;\n}\n\n/**\n * Creates a Redux store that holds the state tree.\n * The only way to change the data in the store is to call `dispatch()` on it.\n *\n * There should only be a single store in your app. To specify how different\n * parts of the state tree respond to actions, you may combine several reducers\n * into a single reducer function by using `combineReducers`.\n *\n * @param {Function} reducer A function that returns the next state tree, given\n * the current state tree and the action to handle.\n *\n * @param {any} [preloadedState] The initial state. You may optionally specify it\n * to hydrate the state from the server in universal apps, or to restore a\n * previously serialized user session.\n * If you use `combineReducers` to produce the root reducer function, this must be\n * an object with the same shape as `combineReducers` keys.\n *\n * @param {Function} [enhancer] The store enhancer. You may optionally specify it\n * to enhance the store with third-party capabilities such as middleware,\n * time travel, persistence, etc. The only store enhancer that ships with Redux\n * is `applyMiddleware()`.\n *\n * @returns {Store} A Redux store that lets you read the state, dispatch actions\n * and subscribe to changes.\n */\n\nfunction createStore(reducer, preloadedState, enhancer) {\n var _ref2;\n\n if (typeof preloadedState === 'function' && typeof enhancer === 'function' || typeof enhancer === 'function' && typeof arguments[3] === 'function') {\n throw new Error('It looks like you are passing several store enhancers to ' + 'createStore(). This is not supported. Instead, compose them ' + 'together to a single function');\n }\n\n if (typeof preloadedState === 'function' && typeof enhancer === 'undefined') {\n enhancer = preloadedState;\n preloadedState = undefined;\n }\n\n if (typeof enhancer !== 'undefined') {\n if (typeof enhancer !== 'function') {\n throw new Error('Expected the enhancer to be a function.');\n }\n\n return enhancer(createStore)(reducer, preloadedState);\n }\n\n if (typeof reducer !== 'function') {\n throw new Error('Expected the reducer to be a function.');\n }\n\n var currentReducer = reducer;\n var currentState = preloadedState;\n var currentListeners = [];\n var nextListeners = currentListeners;\n var isDispatching = false;\n\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = currentListeners.slice();\n }\n }\n /**\n * Reads the state tree managed by the store.\n *\n * @returns {any} The current state tree of your application.\n */\n\n\n function getState() {\n if (isDispatching) {\n throw new Error('You may not call store.getState() while the reducer is executing. ' + 'The reducer has already received the state as an argument. ' + 'Pass it down from the top reducer instead of reading it from the store.');\n }\n\n return currentState;\n }\n /**\n * Adds a change listener. It will be called any time an action is dispatched,\n * and some part of the state tree may potentially have changed. You may then\n * call `getState()` to read the current state tree inside the callback.\n *\n * You may call `dispatch()` from a change listener, with the following\n * caveats:\n *\n * 1. The subscriptions are snapshotted just before every `dispatch()` call.\n * If you subscribe or unsubscribe while the listeners are being invoked, this\n * will not have any effect on the `dispatch()` that is currently in progress.\n * However, the next `dispatch()` call, whether nested or not, will use a more\n * recent snapshot of the subscription list.\n *\n * 2. The listener should not expect to see all state changes, as the state\n * might have been updated multiple times during a nested `dispatch()` before\n * the listener is called. It is, however, guaranteed that all subscribers\n * registered before the `dispatch()` started will be called with the latest\n * state by the time it exits.\n *\n * @param {Function} listener A callback to be invoked on every dispatch.\n * @returns {Function} A function to remove this change listener.\n */\n\n\n function subscribe(listener) {\n if (typeof listener !== 'function') {\n throw new Error('Expected the listener to be a function.');\n }\n\n if (isDispatching) {\n throw new Error('You may not call store.subscribe() while the reducer is executing. ' + 'If you would like to be notified after the store has been updated, subscribe from a ' + 'component and invoke store.getState() in the callback to access the latest state. ' + 'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');\n }\n\n var isSubscribed = true;\n ensureCanMutateNextListeners();\n nextListeners.push(listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n\n if (isDispatching) {\n throw new Error('You may not unsubscribe from a store listener while the reducer is executing. ' + 'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');\n }\n\n isSubscribed = false;\n ensureCanMutateNextListeners();\n var index = nextListeners.indexOf(listener);\n nextListeners.splice(index, 1);\n };\n }\n /**\n * Dispatches an action. It is the only way to trigger a state change.\n *\n * The `reducer` function, used to create the store, will be called with the\n * current state tree and the given `action`. Its return value will\n * be considered the **next** state of the tree, and the change listeners\n * will be notified.\n *\n * The base implementation only supports plain object actions. If you want to\n * dispatch a Promise, an Observable, a thunk, or something else, you need to\n * wrap your store creating function into the corresponding middleware. For\n * example, see the documentation for the `redux-thunk` package. Even the\n * middleware will eventually dispatch plain object actions using this method.\n *\n * @param {Object} action A plain object representing “what changed”. It is\n * a good idea to keep actions serializable so you can record and replay user\n * sessions, or use the time travelling `redux-devtools`. An action must have\n * a `type` property which may not be `undefined`. It is a good idea to use\n * string constants for action types.\n *\n * @returns {Object} For convenience, the same action object you dispatched.\n *\n * Note that, if you use a custom middleware, it may wrap `dispatch()` to\n * return something else (for example, a Promise you can await).\n */\n\n\n function dispatch(action) {\n if (!isPlainObject(action)) {\n throw new Error('Actions must be plain objects. ' + 'Use custom middleware for async actions.');\n }\n\n if (typeof action.type === 'undefined') {\n throw new Error('Actions may not have an undefined \"type\" property. ' + 'Have you misspelled a constant?');\n }\n\n if (isDispatching) {\n throw new Error('Reducers may not dispatch actions.');\n }\n\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n\n var listeners = currentListeners = nextListeners;\n\n for (var i = 0; i < listeners.length; i++) {\n var listener = listeners[i];\n listener();\n }\n\n return action;\n }\n /**\n * Replaces the reducer currently used by the store to calculate the state.\n *\n * You might need this if your app implements code splitting and you want to\n * load some of the reducers dynamically. You might also need this if you\n * implement a hot reloading mechanism for Redux.\n *\n * @param {Function} nextReducer The reducer for the store to use instead.\n * @returns {void}\n */\n\n\n function replaceReducer(nextReducer) {\n if (typeof nextReducer !== 'function') {\n throw new Error('Expected the nextReducer to be a function.');\n }\n\n currentReducer = nextReducer;\n dispatch({\n type: ActionTypes.REPLACE\n });\n }\n /**\n * Interoperability point for observable/reactive libraries.\n * @returns {observable} A minimal observable of state changes.\n * For more information, see the observable proposal:\n * https://github.com/tc39/proposal-observable\n */\n\n\n function observable() {\n var _ref;\n\n var outerSubscribe = subscribe;\n return _ref = {\n /**\n * The minimal observable subscription method.\n * @param {Object} observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns {subscription} An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe: function subscribe(observer) {\n if (typeof observer !== 'object' || observer === null) {\n throw new TypeError('Expected the observer to be an object.');\n }\n\n function observeState() {\n if (observer.next) {\n observer.next(getState());\n }\n }\n\n observeState();\n var unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe: unsubscribe\n };\n }\n }, _ref[__WEBPACK_IMPORTED_MODULE_0_symbol_observable__[\"a\" /* default */]] = function () {\n return this;\n }, _ref;\n } // When a store is created, an \"INIT\" action is dispatched so that every\n // reducer returns their initial state. This effectively populates\n // the initial state tree.\n\n\n dispatch({\n type: ActionTypes.INIT\n });\n return _ref2 = {\n dispatch: dispatch,\n subscribe: subscribe,\n getState: getState,\n replaceReducer: replaceReducer\n }, _ref2[__WEBPACK_IMPORTED_MODULE_0_symbol_observable__[\"a\" /* default */]] = observable, _ref2;\n}\n\n/**\n * Prints a warning in the console if it exists.\n *\n * @param {String} message The warning message.\n * @returns {void}\n */\nfunction warning(message) {\n /* eslint-disable no-console */\n if (typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error(message);\n }\n /* eslint-enable no-console */\n\n\n try {\n // This error was thrown as a convenience so that if you enable\n // \"break on all exceptions\" in your console,\n // it would pause the execution at this line.\n throw new Error(message);\n } catch (e) {} // eslint-disable-line no-empty\n\n}\n\nfunction getUndefinedStateErrorMessage(key, action) {\n var actionType = action && action.type;\n var actionDescription = actionType && \"action \\\"\" + String(actionType) + \"\\\"\" || 'an action';\n return \"Given \" + actionDescription + \", reducer \\\"\" + key + \"\\\" returned undefined. \" + \"To ignore an action, you must explicitly return the previous state. \" + \"If you want this reducer to hold no value, you can return null instead of undefined.\";\n}\n\nfunction getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) {\n var reducerKeys = Object.keys(reducers);\n var argumentName = action && action.type === ActionTypes.INIT ? 'preloadedState argument passed to createStore' : 'previous state received by the reducer';\n\n if (reducerKeys.length === 0) {\n return 'Store does not have a valid reducer. Make sure the argument passed ' + 'to combineReducers is an object whose values are reducers.';\n }\n\n if (!isPlainObject(inputState)) {\n return \"The \" + argumentName + \" has unexpected type of \\\"\" + {}.toString.call(inputState).match(/\\s([a-z|A-Z]+)/)[1] + \"\\\". Expected argument to be an object with the following \" + (\"keys: \\\"\" + reducerKeys.join('\", \"') + \"\\\"\");\n }\n\n var unexpectedKeys = Object.keys(inputState).filter(function (key) {\n return !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key];\n });\n unexpectedKeys.forEach(function (key) {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === ActionTypes.REPLACE) return;\n\n if (unexpectedKeys.length > 0) {\n return \"Unexpected \" + (unexpectedKeys.length > 1 ? 'keys' : 'key') + \" \" + (\"\\\"\" + unexpectedKeys.join('\", \"') + \"\\\" found in \" + argumentName + \". \") + \"Expected to find one of the known reducer keys instead: \" + (\"\\\"\" + reducerKeys.join('\", \"') + \"\\\". Unexpected keys will be ignored.\");\n }\n}\n\nfunction assertReducerShape(reducers) {\n Object.keys(reducers).forEach(function (key) {\n var reducer = reducers[key];\n var initialState = reducer(undefined, {\n type: ActionTypes.INIT\n });\n\n if (typeof initialState === 'undefined') {\n throw new Error(\"Reducer \\\"\" + key + \"\\\" returned undefined during initialization. \" + \"If the state passed to the reducer is undefined, you must \" + \"explicitly return the initial state. The initial state may \" + \"not be undefined. If you don't want to set a value for this reducer, \" + \"you can use null instead of undefined.\");\n }\n\n if (typeof reducer(undefined, {\n type: ActionTypes.PROBE_UNKNOWN_ACTION()\n }) === 'undefined') {\n throw new Error(\"Reducer \\\"\" + key + \"\\\" returned undefined when probed with a random type. \" + (\"Don't try to handle \" + ActionTypes.INIT + \" or other actions in \\\"redux/*\\\" \") + \"namespace. They are considered private. Instead, you must return the \" + \"current state for any unknown actions, unless it is undefined, \" + \"in which case you must return the initial state, regardless of the \" + \"action type. The initial state may not be undefined, but can be null.\");\n }\n });\n}\n/**\n * Turns an object whose values are different reducer functions, into a single\n * reducer function. It will call every child reducer, and gather their results\n * into a single state object, whose keys correspond to the keys of the passed\n * reducer functions.\n *\n * @param {Object} reducers An object whose values correspond to different\n * reducer functions that need to be combined into one. One handy way to obtain\n * it is to use ES6 `import * as reducers` syntax. The reducers may never return\n * undefined for any action. Instead, they should return their initial state\n * if the state passed to them was undefined, and the current state for any\n * unrecognized action.\n *\n * @returns {Function} A reducer function that invokes every reducer inside the\n * passed object, and builds a state object with the same shape.\n */\n\n\nfunction combineReducers(reducers) {\n var reducerKeys = Object.keys(reducers);\n var finalReducers = {};\n\n for (var i = 0; i < reducerKeys.length; i++) {\n var key = reducerKeys[i];\n\n if (false) {\n if (typeof reducers[key] === 'undefined') {\n warning(\"No reducer provided for key \\\"\" + key + \"\\\"\");\n }\n }\n\n if (typeof reducers[key] === 'function') {\n finalReducers[key] = reducers[key];\n }\n }\n\n var finalReducerKeys = Object.keys(finalReducers);\n var unexpectedKeyCache;\n\n if (false) {\n unexpectedKeyCache = {};\n }\n\n var shapeAssertionError;\n\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n\n return function combination(state, action) {\n if (state === void 0) {\n state = {};\n }\n\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n\n if (false) {\n var warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n\n var hasChanged = false;\n var nextState = {};\n\n for (var _i = 0; _i < finalReducerKeys.length; _i++) {\n var _key = finalReducerKeys[_i];\n var reducer = finalReducers[_key];\n var previousStateForKey = state[_key];\n var nextStateForKey = reducer(previousStateForKey, action);\n\n if (typeof nextStateForKey === 'undefined') {\n var errorMessage = getUndefinedStateErrorMessage(_key, action);\n throw new Error(errorMessage);\n }\n\n nextState[_key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n\n return hasChanged ? nextState : state;\n };\n}\n\nfunction bindActionCreator(actionCreator, dispatch) {\n return function () {\n return dispatch(actionCreator.apply(this, arguments));\n };\n}\n/**\n * Turns an object whose values are action creators, into an object with the\n * same keys, but with every function wrapped into a `dispatch` call so they\n * may be invoked directly. This is just a convenience method, as you can call\n * `store.dispatch(MyActionCreators.doSomething())` yourself just fine.\n *\n * For convenience, you can also pass a single function as the first argument,\n * and get a function in return.\n *\n * @param {Function|Object} actionCreators An object whose values are action\n * creator functions. One handy way to obtain it is to use ES6 `import * as`\n * syntax. You may also pass a single function.\n *\n * @param {Function} dispatch The `dispatch` function available on your Redux\n * store.\n *\n * @returns {Function|Object} The object mimicking the original object, but with\n * every action creator wrapped into the `dispatch` call. If you passed a\n * function as `actionCreators`, the return value will also be a single\n * function.\n */\n\n\nfunction bindActionCreators(actionCreators, dispatch) {\n if (typeof actionCreators === 'function') {\n return bindActionCreator(actionCreators, dispatch);\n }\n\n if (typeof actionCreators !== 'object' || actionCreators === null) {\n throw new Error(\"bindActionCreators expected an object or a function, instead received \" + (actionCreators === null ? 'null' : typeof actionCreators) + \". \" + \"Did you write \\\"import ActionCreators from\\\" instead of \\\"import * as ActionCreators from\\\"?\");\n }\n\n var keys = Object.keys(actionCreators);\n var boundActionCreators = {};\n\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n var actionCreator = actionCreators[key];\n\n if (typeof actionCreator === 'function') {\n boundActionCreators[key] = bindActionCreator(actionCreator, dispatch);\n }\n }\n\n return boundActionCreators;\n}\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nfunction _objectSpread(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n\n if (typeof Object.getOwnPropertySymbols === 'function') {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n\n ownKeys.forEach(function (key) {\n _defineProperty(target, key, source[key]);\n });\n }\n\n return target;\n}\n\n/**\n * Composes single-argument functions from right to left. The rightmost\n * function can take multiple arguments as it provides the signature for\n * the resulting composite function.\n *\n * @param {...Function} funcs The functions to compose.\n * @returns {Function} A function obtained by composing the argument functions\n * from right to left. For example, compose(f, g, h) is identical to doing\n * (...args) => f(g(h(...args))).\n */\nfunction compose() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n if (funcs.length === 0) {\n return function (arg) {\n return arg;\n };\n }\n\n if (funcs.length === 1) {\n return funcs[0];\n }\n\n return funcs.reduce(function (a, b) {\n return function () {\n return a(b.apply(void 0, arguments));\n };\n });\n}\n\n/**\n * Creates a store enhancer that applies middleware to the dispatch method\n * of the Redux store. This is handy for a variety of tasks, such as expressing\n * asynchronous actions in a concise manner, or logging every action payload.\n *\n * See `redux-thunk` package as an example of the Redux middleware.\n *\n * Because middleware is potentially asynchronous, this should be the first\n * store enhancer in the composition chain.\n *\n * Note that each middleware will be given the `dispatch` and `getState` functions\n * as named arguments.\n *\n * @param {...Function} middlewares The middleware chain to be applied.\n * @returns {Function} A store enhancer applying the middleware.\n */\n\nfunction applyMiddleware() {\n for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) {\n middlewares[_key] = arguments[_key];\n }\n\n return function (createStore) {\n return function () {\n var store = createStore.apply(void 0, arguments);\n\n var _dispatch = function dispatch() {\n throw new Error(\"Dispatching while constructing your middleware is not allowed. \" + \"Other middleware would not be applied to this dispatch.\");\n };\n\n var middlewareAPI = {\n getState: store.getState,\n dispatch: function dispatch() {\n return _dispatch.apply(void 0, arguments);\n }\n };\n var chain = middlewares.map(function (middleware) {\n return middleware(middlewareAPI);\n });\n _dispatch = compose.apply(void 0, chain)(store.dispatch);\n return _objectSpread({}, store, {\n dispatch: _dispatch\n });\n };\n };\n}\n\n/*\n * This is a dummy function to check if the function name has been altered by minification.\n * If the function has been minified and NODE_ENV !== 'production', warn the user.\n */\n\nfunction isCrushed() {}\n\nif (false) {\n warning('You are currently using minified code outside of NODE_ENV === \"production\". ' + 'This means that you are running a slower development build of Redux. ' + 'You can use loose-envify (https://github.com/zertosh/loose-envify) for browserify ' + 'or setting mode to production in webpack (https://webpack.js.org/concepts/mode/) ' + 'to ensure you have the correct code for your production build.');\n}\n\n\n\n\n/***/ }),\n\n/***/ 177:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = wrapMapToPropsConstant;\n/* unused harmony export getDependsOnOwnProps */\n/* harmony export (immutable) */ __webpack_exports__[\"b\"] = wrapMapToPropsFunc;\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils_verifyPlainObject__ = __webpack_require__(178);\n\n\nfunction wrapMapToPropsConstant(getConstant) {\n return function initConstantSelector(dispatch, options) {\n var constant = getConstant(dispatch, options);\n\n function constantSelector() {\n return constant;\n }\n constantSelector.dependsOnOwnProps = false;\n return constantSelector;\n };\n}\n\n// dependsOnOwnProps is used by createMapToPropsProxy to determine whether to pass props as args\n// to the mapToProps function being wrapped. It is also used by makePurePropsSelector to determine\n// whether mapToProps needs to be invoked when props have changed.\n// \n// A length of one signals that mapToProps does not depend on props from the parent component.\n// A length of zero is assumed to mean mapToProps is getting args via arguments or ...args and\n// therefore not reporting its length accurately..\nfunction getDependsOnOwnProps(mapToProps) {\n return mapToProps.dependsOnOwnProps !== null && mapToProps.dependsOnOwnProps !== undefined ? Boolean(mapToProps.dependsOnOwnProps) : mapToProps.length !== 1;\n}\n\n// Used by whenMapStateToPropsIsFunction and whenMapDispatchToPropsIsFunction,\n// this function wraps mapToProps in a proxy function which does several things:\n// \n// * Detects whether the mapToProps function being called depends on props, which\n// is used by selectorFactory to decide if it should reinvoke on props changes.\n// \n// * On first call, handles mapToProps if returns another function, and treats that\n// new function as the true mapToProps for subsequent calls.\n// \n// * On first call, verifies the first result is a plain object, in order to warn\n// the developer that their mapToProps function is not returning a valid result.\n// \nfunction wrapMapToPropsFunc(mapToProps, methodName) {\n return function initProxySelector(dispatch, _ref) {\n var displayName = _ref.displayName;\n\n var proxy = function mapToPropsProxy(stateOrDispatch, ownProps) {\n return proxy.dependsOnOwnProps ? proxy.mapToProps(stateOrDispatch, ownProps) : proxy.mapToProps(stateOrDispatch);\n };\n\n // allow detectFactoryAndVerify to get ownProps\n proxy.dependsOnOwnProps = true;\n\n proxy.mapToProps = function detectFactoryAndVerify(stateOrDispatch, ownProps) {\n proxy.mapToProps = mapToProps;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(mapToProps);\n var props = proxy(stateOrDispatch, ownProps);\n\n if (typeof props === 'function') {\n proxy.mapToProps = props;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(props);\n props = proxy(stateOrDispatch, ownProps);\n }\n\n if (false) verifyPlainObject(props, displayName, methodName);\n\n return props;\n };\n\n return proxy;\n };\n}\n\n/***/ }),\n\n/***/ 178:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export default */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_es_isPlainObject__ = __webpack_require__(435);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__warning__ = __webpack_require__(123);\n\n\n\nfunction verifyPlainObject(value, displayName, methodName) {\n if (!Object(__WEBPACK_IMPORTED_MODULE_0_lodash_es_isPlainObject__[\"a\" /* default */])(value)) {\n Object(__WEBPACK_IMPORTED_MODULE_1__warning__[\"a\" /* default */])(methodName + '() in ' + displayName + ' must return a plain object. Instead received ' + value + '.');\n }\n}\n\n/***/ }),\n\n/***/ 179:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__root_js__ = __webpack_require__(437);\n\n\n/** Built-in value references. */\nvar Symbol = __WEBPACK_IMPORTED_MODULE_0__root_js__[\"a\" /* default */].Symbol;\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Symbol);\n\n\n/***/ }),\n\n/***/ 180:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return closeExplorer; });\n/* harmony export (immutable) */ __webpack_exports__[\"d\"] = toggleExplorer;\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return popPage; });\n/* harmony export (immutable) */ __webpack_exports__[\"c\"] = pushPage;\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__api_admin__ = __webpack_require__(450);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__utils_actions__ = __webpack_require__(452);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__ = __webpack_require__(17);\n\n\n\n\nvar getPageStart = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('GET_PAGE_START');\nvar getPageSuccess = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('GET_PAGE_SUCCESS', function (id, data) {\n return { id: id, data: data };\n});\nvar getPageFailure = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('GET_PAGE_FAILURE', function (id, error) {\n return { id: id, error: error };\n});\n\n/**\n * Gets a page from the API.\n */\nfunction getPage(id) {\n return function (dispatch) {\n dispatch(getPageStart(id));\n\n return __WEBPACK_IMPORTED_MODULE_0__api_admin__[\"a\" /* getPage */](id).then(function (data) {\n dispatch(getPageSuccess(id, data));\n }, function (error) {\n dispatch(getPageFailure(id, error));\n });\n };\n}\n\nvar getChildrenStart = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('GET_CHILDREN_START', function (id) {\n return { id: id };\n});\nvar getChildrenSuccess = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('GET_CHILDREN_SUCCESS', function (id, items, meta) {\n return { id: id, items: items, meta: meta };\n});\nvar getChildrenFailure = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('GET_CHILDREN_FAILURE', function (id, error) {\n return { id: id, error: error };\n});\n\n/**\n * Gets the children of a node from the API.\n */\nfunction getChildren(id) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n\n return function (dispatch) {\n dispatch(getChildrenStart(id));\n\n return __WEBPACK_IMPORTED_MODULE_0__api_admin__[\"b\" /* getPageChildren */](id, {\n offset: offset\n }).then(function (_ref) {\n var items = _ref.items,\n meta = _ref.meta;\n\n var nbPages = offset + items.length;\n dispatch(getChildrenSuccess(id, items, meta));\n\n // Load more pages if necessary. Only one request is created even though\n // more might be needed, thus naturally throttling the loading.\n if (nbPages < meta.total_count && nbPages < __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__[\"d\" /* MAX_EXPLORER_PAGES */]) {\n dispatch(getChildren(id, nbPages));\n }\n }, function (error) {\n dispatch(getChildrenFailure(id, error));\n });\n };\n}\n\nvar openExplorer = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('OPEN_EXPLORER', function (id) {\n return { id: id };\n});\nvar closeExplorer = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('CLOSE_EXPLORER');\n\nfunction toggleExplorer(id) {\n return function (dispatch, getState) {\n var _getState = getState(),\n explorer = _getState.explorer,\n nodes = _getState.nodes;\n\n if (explorer.isVisible) {\n dispatch(closeExplorer());\n } else {\n var page = nodes[id];\n\n dispatch(openExplorer(id));\n\n if (!page) {\n dispatch(getChildren(id));\n }\n\n // We need to get the title of the starting page, only if it is not the site's root.\n var isNotRoot = id !== 1;\n if (isNotRoot) {\n dispatch(getPage(id));\n }\n }\n };\n}\n\nvar popPage = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('POP_PAGE');\nvar pushPagePrivate = Object(__WEBPACK_IMPORTED_MODULE_1__utils_actions__[\"a\" /* createAction */])('PUSH_PAGE', function (id) {\n return { id: id };\n});\n\nfunction pushPage(id) {\n return function (dispatch, getState) {\n var _getState2 = getState(),\n nodes = _getState2.nodes;\n\n var page = nodes[id];\n\n dispatch(pushPagePrivate(id));\n\n if (page && !page.isFetching && !(page.children.count > 0)) {\n dispatch(getChildren(id));\n }\n };\n}\n\n/***/ }),\n\n/***/ 181:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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__config_wagtailConfig__ = __webpack_require__(17);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__ = __webpack_require__(46);\n\n\n\n\n/**\n * A loading indicator with a text label next to it.\n */\nvar LoadingSpinner = function LoadingSpinner() {\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'span',\n null,\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__[\"a\" /* default */], { name: 'spinner', className: 'c-spinner' }),\n ' ' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].LOADING\n );\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (LoadingSpinner);\n\n/***/ }),\n\n/***/ 182:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return PUSH; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return POP; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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_react_transition_group_CSSTransitionGroup__ = __webpack_require__(458);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react_transition_group_CSSTransitionGroup___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_react_transition_group_CSSTransitionGroup__);\n\n\n\n\n\nvar TRANSITION_DURATION = 210;\n\n// The available transitions. Must match the class names in CSS.\nvar PUSH = 'push';\nvar POP = 'pop';\n\n/**\n * Wrapper arround react-transition-group with default values.\n */\nvar Transition = function Transition(_ref) {\n var name = _ref.name,\n component = _ref.component,\n className = _ref.className,\n duration = _ref.duration,\n children = _ref.children,\n label = _ref.label;\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_1_react_transition_group_CSSTransitionGroup___default.a,\n {\n component: component,\n transitionEnterTimeout: duration,\n transitionLeaveTimeout: duration,\n transitionName: 'c-transition-' + name,\n className: className,\n 'aria-label': label\n },\n children\n );\n};\n\nTransition.defaultProps = {\n component: 'div',\n children: null,\n className: null,\n duration: TRANSITION_DURATION,\n label: null\n};\n\n/* harmony default export */ __webpack_exports__[\"c\"] = (Transition);\n\n/***/ }),\n\n/***/ 183:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nmodule.exports = exports['default'];\n\n/***/ }),\n\n/***/ 184:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nexports.__esModule = true;\nexports.nameShape = undefined;\nexports.transitionTimeout = transitionTimeout;\n\nvar _react = __webpack_require__(1);\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(59);\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction transitionTimeout(transitionType) {\n var timeoutPropName = 'transition' + transitionType + 'Timeout';\n var enabledPropName = 'transition' + transitionType;\n\n return function (props) {\n // If the transition is enabled\n if (props[enabledPropName]) {\n // If no timeout duration is provided\n if (props[timeoutPropName] == null) {\n return new Error(timeoutPropName + ' wasn\\'t supplied to CSSTransitionGroup: ' + 'this can cause unreliable animations and won\\'t be supported in ' + 'a future version of React. See ' + 'https://fb.me/react-animation-transition-group-timeout for more ' + 'information.');\n\n // If the duration isn't a number\n } else if (typeof props[timeoutPropName] !== 'number') {\n return new Error(timeoutPropName + ' must be a number (in milliseconds)');\n }\n }\n\n return null;\n };\n}\n\nvar nameShape = exports.nameShape = _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.shape({\n enter: _propTypes2.default.string,\n leave: _propTypes2.default.string,\n active: _propTypes2.default.string\n}), _propTypes2.default.shape({\n enter: _propTypes2.default.string,\n enterActive: _propTypes2.default.string,\n leave: _propTypes2.default.string,\n leaveActive: _propTypes2.default.string,\n appear: _propTypes2.default.string,\n appearActive: _propTypes2.default.string\n})]);\n\n/***/ }),\n\n/***/ 185:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n\n\n\n/**\n * Displays the publication status of a page in a pill.\n */\nvar PublicationStatus = function PublicationStatus(_ref) {\n var status = _ref.status;\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'span',\n { className: 'o-pill c-status' + (status.live ? ' c-status--live' : '') },\n status.status\n );\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (PublicationStatus);\n\n/***/ }),\n\n/***/ 414:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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_react_dom__ = __webpack_require__(38);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react_dom___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_react_dom__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_wagtail_client__ = __webpack_require__(421);\n\n\n\n\nif (false) {\n // Run react-axe in development only, so it does not affect performance\n // in production, and does not break unit tests either.\n // eslint-disable-next-line global-require\n var axe = require('react-axe');\n axe(React, ReactDOM, 1000);\n}\n\n// Expose components as globals for third-party reuse.\nwindow.wagtail.components = {\n Icon: __WEBPACK_IMPORTED_MODULE_2_wagtail_client__[\"a\" /* Icon */],\n Portal: __WEBPACK_IMPORTED_MODULE_2_wagtail_client__[\"b\" /* Portal */]\n};\n\n/**\n * Add in here code to run once the page is loaded.\n */\ndocument.addEventListener('DOMContentLoaded', function () {\n var explorerNode = document.querySelector('[data-explorer-menu]');\n var toggleNode = document.querySelector('[data-explorer-start-page]');\n\n if (explorerNode && toggleNode) {\n Object(__WEBPACK_IMPORTED_MODULE_2_wagtail_client__[\"c\" /* initExplorer */])(explorerNode, toggleNode);\n }\n\n Object(__WEBPACK_IMPORTED_MODULE_2_wagtail_client__[\"d\" /* initFocusOutline */])();\n Object(__WEBPACK_IMPORTED_MODULE_2_wagtail_client__[\"e\" /* initSubmenus */])();\n Object(__WEBPACK_IMPORTED_MODULE_2_wagtail_client__[\"f\" /* initUpgradeNotification */])();\n});\n\n/***/ }),\n\n/***/ 421:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__components_Button_Button__ = __webpack_require__(72);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_Explorer__ = __webpack_require__(422);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__ = __webpack_require__(46);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_LoadingSpinner_LoadingSpinner__ = __webpack_require__(181);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__components_Portal_Portal__ = __webpack_require__(124);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__components_PublicationStatus_PublicationStatus__ = __webpack_require__(185);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__components_Transition_Transition__ = __webpack_require__(182);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__utils_focus__ = __webpack_require__(476);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__includes_initSubmenus__ = __webpack_require__(477);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__components_UpgradeNotification__ = __webpack_require__(478);\n/* unused harmony reexport Button */\n/* unused harmony reexport Explorer */\n/* unused harmony reexport ExplorerToggle */\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return __WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__[\"a\"]; });\n/* unused harmony reexport LoadingSpinner */\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return __WEBPACK_IMPORTED_MODULE_4__components_Portal_Portal__[\"a\"]; });\n/* unused harmony reexport PublicationStatus */\n/* unused harmony reexport Transition */\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"c\", function() { return __WEBPACK_IMPORTED_MODULE_1__components_Explorer__[\"a\"]; });\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"d\", function() { return __WEBPACK_IMPORTED_MODULE_7__utils_focus__[\"a\"]; });\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"e\", function() { return __WEBPACK_IMPORTED_MODULE_8__includes_initSubmenus__[\"a\"]; });\n/* harmony reexport (binding) */ __webpack_require__.d(__webpack_exports__, \"f\", function() { return __WEBPACK_IMPORTED_MODULE_9__components_UpgradeNotification__[\"a\"]; });\n/**\n * Entry point for the wagtail package.\n * Re-exports components and other modules via a cleaner API.\n */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/***/ }),\n\n/***/ 422:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return initExplorer; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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_react_dom__ = __webpack_require__(38);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react_dom___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_react_dom__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_react_redux__ = __webpack_require__(122);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_redux__ = __webpack_require__(176);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_redux_thunk__ = __webpack_require__(448);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__Explorer__ = __webpack_require__(449);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__ExplorerToggle__ = __webpack_require__(473);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__reducers_explorer__ = __webpack_require__(474);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__reducers_nodes__ = __webpack_require__(475);\n/* unused harmony reexport ExplorerToggle */\n\n\n\n\n\n\n// import { perfMiddleware } from '../../utils/performance';\n\n\n\n\n\n/**\n * Initialises the explorer component on the given nodes.\n */\nvar initExplorer = function initExplorer(explorerNode, toggleNode) {\n var rootReducer = Object(__WEBPACK_IMPORTED_MODULE_3_redux__[\"c\" /* combineReducers */])({\n explorer: __WEBPACK_IMPORTED_MODULE_7__reducers_explorer__[\"a\" /* default */],\n nodes: __WEBPACK_IMPORTED_MODULE_8__reducers_nodes__[\"a\" /* default */]\n });\n\n var middleware = [__WEBPACK_IMPORTED_MODULE_4_redux_thunk__[\"a\" /* default */]];\n\n // Uncomment this to use performance measurements.\n // if (process.env.NODE_ENV !== 'production') {\n // middleware.push(perfMiddleware);\n // }\n\n var store = Object(__WEBPACK_IMPORTED_MODULE_3_redux__[\"e\" /* createStore */])(rootReducer, {}, Object(__WEBPACK_IMPORTED_MODULE_3_redux__[\"d\" /* compose */])(__WEBPACK_IMPORTED_MODULE_3_redux__[\"a\" /* applyMiddleware */].apply(undefined, middleware),\n // Expose store to Redux DevTools extension.\n window.__REDUX_DEVTOOLS_EXTENSION__ ? window.__REDUX_DEVTOOLS_EXTENSION__() : function (func) {\n return func;\n }));\n\n var startPage = parseInt(toggleNode.getAttribute('data-explorer-start-page'), 10);\n\n __WEBPACK_IMPORTED_MODULE_1_react_dom___default.a.render(__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_2_react_redux__[\"a\" /* Provider */],\n { store: store },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_6__ExplorerToggle__[\"a\" /* default */],\n { startPage: startPage },\n toggleNode.textContent\n )\n ), toggleNode.parentNode);\n\n __WEBPACK_IMPORTED_MODULE_1_react_dom___default.a.render(__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_2_react_redux__[\"a\" /* Provider */],\n { store: store },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_5__Explorer__[\"a\" /* default */], null)\n ), explorerNode);\n};\n\n/* unused harmony default export */ var _unused_webpack_default_export = (__WEBPACK_IMPORTED_MODULE_5__Explorer__[\"a\" /* default */]);\n\n\n\n/***/ }),\n\n/***/ 423:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export createProvider */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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__(59);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_prop_types___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_prop_types__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__utils_PropTypes__ = __webpack_require__(174);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__utils_warning__ = __webpack_require__(123);\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n\n\n\n\n\nvar didWarnAboutReceivingStore = false;\nfunction warnAboutReceivingStore() {\n if (didWarnAboutReceivingStore) {\n return;\n }\n didWarnAboutReceivingStore = true;\n\n Object(__WEBPACK_IMPORTED_MODULE_3__utils_warning__[\"a\" /* default */])(' does not support changing `store` on the fly. ' + 'It is most likely that you see this error because you updated to ' + 'Redux 2.x and React Redux 2.x which no longer hot reload reducers ' + 'automatically. See https://github.com/reactjs/react-redux/releases/' + 'tag/v2.0.0 for the migration instructions.');\n}\n\nfunction createProvider() {\n var _Provider$childContex;\n\n var storeKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'store';\n var subKey = arguments[1];\n\n var subscriptionKey = subKey || storeKey + 'Subscription';\n\n var Provider = function (_Component) {\n _inherits(Provider, _Component);\n\n Provider.prototype.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[storeKey] = this[storeKey], _ref[subscriptionKey] = null, _ref;\n };\n\n function Provider(props, context) {\n _classCallCheck(this, Provider);\n\n var _this = _possibleConstructorReturn(this, _Component.call(this, props, context));\n\n _this[storeKey] = props.store;\n return _this;\n }\n\n Provider.prototype.render = function render() {\n return __WEBPACK_IMPORTED_MODULE_0_react__[\"Children\"].only(this.props.children);\n };\n\n return Provider;\n }(__WEBPACK_IMPORTED_MODULE_0_react__[\"Component\"]);\n\n if (false) {\n Provider.prototype.componentWillReceiveProps = function (nextProps) {\n if (this[storeKey] !== nextProps.store) {\n warnAboutReceivingStore();\n }\n };\n }\n\n Provider.propTypes = {\n store: __WEBPACK_IMPORTED_MODULE_2__utils_PropTypes__[\"a\" /* storeShape */].isRequired,\n children: __WEBPACK_IMPORTED_MODULE_1_prop_types___default.a.element.isRequired\n };\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[storeKey] = __WEBPACK_IMPORTED_MODULE_2__utils_PropTypes__[\"a\" /* storeShape */].isRequired, _Provider$childContex[subscriptionKey] = __WEBPACK_IMPORTED_MODULE_2__utils_PropTypes__[\"b\" /* subscriptionShape */], _Provider$childContex);\n\n return Provider;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (createProvider());\n\n/***/ }),\n\n/***/ 426:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\n\n\nvar REACT_STATICS = {\n childContextTypes: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\n\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = getPrototypeOf && getPrototypeOf(Object);\n\nmodule.exports = function hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') { // don't hoist over string (html) components\n\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n if (!REACT_STATICS[key] && !KNOWN_STATICS[key] && (!blacklist || !blacklist[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n try { // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n\n return targetComponent;\n }\n\n return targetComponent;\n};\n\n\n/***/ }),\n\n/***/ 427:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n/**\n * Copyright 2013-2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n */\n\n\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (false) {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\n\n\n/***/ }),\n\n/***/ 428:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return Subscription; });\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n// encapsulates the subscription logic for connecting a component to the redux store, as\n// well as nesting subscriptions of descendant components, so that we can ensure the\n// ancestor components re-render before descendants\n\nvar CLEARED = null;\nvar nullListeners = {\n notify: function notify() {}\n};\n\nfunction createListenerCollection() {\n // the current/next pattern is copied from redux's createStore code.\n // TODO: refactor+expose that code to be reusable here?\n var current = [];\n var next = [];\n\n return {\n clear: function clear() {\n next = CLEARED;\n current = CLEARED;\n },\n notify: function notify() {\n var listeners = current = next;\n for (var i = 0; i < listeners.length; i++) {\n listeners[i]();\n }\n },\n get: function get() {\n return next;\n },\n subscribe: function subscribe(listener) {\n var isSubscribed = true;\n if (next === current) next = current.slice();\n next.push(listener);\n\n return function unsubscribe() {\n if (!isSubscribed || current === CLEARED) return;\n isSubscribed = false;\n\n if (next === current) next = current.slice();\n next.splice(next.indexOf(listener), 1);\n };\n }\n };\n}\n\nvar Subscription = function () {\n function Subscription(store, parentSub, onStateChange) {\n _classCallCheck(this, Subscription);\n\n this.store = store;\n this.parentSub = parentSub;\n this.onStateChange = onStateChange;\n this.unsubscribe = null;\n this.listeners = nullListeners;\n }\n\n Subscription.prototype.addNestedSub = function addNestedSub(listener) {\n this.trySubscribe();\n return this.listeners.subscribe(listener);\n };\n\n Subscription.prototype.notifyNestedSubs = function notifyNestedSubs() {\n this.listeners.notify();\n };\n\n Subscription.prototype.isSubscribed = function isSubscribed() {\n return Boolean(this.unsubscribe);\n };\n\n Subscription.prototype.trySubscribe = function trySubscribe() {\n if (!this.unsubscribe) {\n this.unsubscribe = this.parentSub ? this.parentSub.addNestedSub(this.onStateChange) : this.store.subscribe(this.onStateChange);\n\n this.listeners = createListenerCollection();\n }\n };\n\n Subscription.prototype.tryUnsubscribe = function tryUnsubscribe() {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n this.listeners.clear();\n this.listeners = nullListeners;\n }\n };\n\n return Subscription;\n}();\n\n\n\n/***/ }),\n\n/***/ 429:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export createConnect */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__components_connectAdvanced__ = __webpack_require__(175);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__utils_shallowEqual__ = __webpack_require__(430);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__mapDispatchToProps__ = __webpack_require__(431);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__mapStateToProps__ = __webpack_require__(444);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__mergeProps__ = __webpack_require__(445);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__selectorFactory__ = __webpack_require__(446);\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\n\n\n\n\n\n\n\n/*\n connect is a facade over connectAdvanced. It turns its args into a compatible\n selectorFactory, which has the signature:\n\n (dispatch, options) => (nextState, nextOwnProps) => nextFinalProps\n \n connect passes its args to connectAdvanced as options, which will in turn pass them to\n selectorFactory each time a Connect component instance is instantiated or hot reloaded.\n\n selectorFactory returns a final props selector from its mapStateToProps,\n mapStateToPropsFactories, mapDispatchToProps, mapDispatchToPropsFactories, mergeProps,\n mergePropsFactories, and pure args.\n\n The resulting final props selector is called by the Connect component instance whenever\n it receives new props or store state.\n */\n\nfunction match(arg, factories, name) {\n for (var i = factories.length - 1; i >= 0; i--) {\n var result = factories[i](arg);\n if (result) return result;\n }\n\n return function (dispatch, options) {\n throw new Error('Invalid value of type ' + typeof arg + ' for ' + name + ' argument when connecting component ' + options.wrappedComponentName + '.');\n };\n}\n\nfunction strictEqual(a, b) {\n return a === b;\n}\n\n// createConnect with default args builds the 'official' connect behavior. Calling it with\n// different options opens up some testing and extensibility scenarios\nfunction createConnect() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n _ref$connectHOC = _ref.connectHOC,\n connectHOC = _ref$connectHOC === undefined ? __WEBPACK_IMPORTED_MODULE_0__components_connectAdvanced__[\"a\" /* default */] : _ref$connectHOC,\n _ref$mapStateToPropsF = _ref.mapStateToPropsFactories,\n mapStateToPropsFactories = _ref$mapStateToPropsF === undefined ? __WEBPACK_IMPORTED_MODULE_3__mapStateToProps__[\"a\" /* default */] : _ref$mapStateToPropsF,\n _ref$mapDispatchToPro = _ref.mapDispatchToPropsFactories,\n mapDispatchToPropsFactories = _ref$mapDispatchToPro === undefined ? __WEBPACK_IMPORTED_MODULE_2__mapDispatchToProps__[\"a\" /* default */] : _ref$mapDispatchToPro,\n _ref$mergePropsFactor = _ref.mergePropsFactories,\n mergePropsFactories = _ref$mergePropsFactor === undefined ? __WEBPACK_IMPORTED_MODULE_4__mergeProps__[\"a\" /* default */] : _ref$mergePropsFactor,\n _ref$selectorFactory = _ref.selectorFactory,\n selectorFactory = _ref$selectorFactory === undefined ? __WEBPACK_IMPORTED_MODULE_5__selectorFactory__[\"a\" /* default */] : _ref$selectorFactory;\n\n return function connect(mapStateToProps, mapDispatchToProps, mergeProps) {\n var _ref2 = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {},\n _ref2$pure = _ref2.pure,\n pure = _ref2$pure === undefined ? true : _ref2$pure,\n _ref2$areStatesEqual = _ref2.areStatesEqual,\n areStatesEqual = _ref2$areStatesEqual === undefined ? strictEqual : _ref2$areStatesEqual,\n _ref2$areOwnPropsEqua = _ref2.areOwnPropsEqual,\n areOwnPropsEqual = _ref2$areOwnPropsEqua === undefined ? __WEBPACK_IMPORTED_MODULE_1__utils_shallowEqual__[\"a\" /* default */] : _ref2$areOwnPropsEqua,\n _ref2$areStatePropsEq = _ref2.areStatePropsEqual,\n areStatePropsEqual = _ref2$areStatePropsEq === undefined ? __WEBPACK_IMPORTED_MODULE_1__utils_shallowEqual__[\"a\" /* default */] : _ref2$areStatePropsEq,\n _ref2$areMergedPropsE = _ref2.areMergedPropsEqual,\n areMergedPropsEqual = _ref2$areMergedPropsE === undefined ? __WEBPACK_IMPORTED_MODULE_1__utils_shallowEqual__[\"a\" /* default */] : _ref2$areMergedPropsE,\n extraOptions = _objectWithoutProperties(_ref2, ['pure', 'areStatesEqual', 'areOwnPropsEqual', 'areStatePropsEqual', 'areMergedPropsEqual']);\n\n var initMapStateToProps = match(mapStateToProps, mapStateToPropsFactories, 'mapStateToProps');\n var initMapDispatchToProps = match(mapDispatchToProps, mapDispatchToPropsFactories, 'mapDispatchToProps');\n var initMergeProps = match(mergeProps, mergePropsFactories, 'mergeProps');\n\n return connectHOC(selectorFactory, _extends({\n // used in error messages\n methodName: 'connect',\n\n // used to compute Connect's displayName from the wrapped component's displayName.\n getDisplayName: function getDisplayName(name) {\n return 'Connect(' + name + ')';\n },\n\n // if mapStateToProps is falsy, the Connect component doesn't subscribe to store state changes\n shouldHandleStateChanges: Boolean(mapStateToProps),\n\n // passed through to selectorFactory\n initMapStateToProps: initMapStateToProps,\n initMapDispatchToProps: initMapDispatchToProps,\n initMergeProps: initMergeProps,\n pure: pure,\n areStatesEqual: areStatesEqual,\n areOwnPropsEqual: areOwnPropsEqual,\n areStatePropsEqual: areStatePropsEqual,\n areMergedPropsEqual: areMergedPropsEqual\n\n }, extraOptions));\n };\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (createConnect());\n\n/***/ }),\n\n/***/ 430:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = shallowEqual;\nvar hasOwn = Object.prototype.hasOwnProperty;\n\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nfunction shallowEqual(objA, objB) {\n if (is(objA, objB)) return true;\n\n if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {\n return false;\n }\n\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n\n if (keysA.length !== keysB.length) return false;\n\n for (var i = 0; i < keysA.length; i++) {\n if (!hasOwn.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n\n return true;\n}\n\n/***/ }),\n\n/***/ 431:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export whenMapDispatchToPropsIsFunction */\n/* unused harmony export whenMapDispatchToPropsIsMissing */\n/* unused harmony export whenMapDispatchToPropsIsObject */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_redux__ = __webpack_require__(176);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__wrapMapToProps__ = __webpack_require__(177);\n\n\n\nfunction whenMapDispatchToPropsIsFunction(mapDispatchToProps) {\n return typeof mapDispatchToProps === 'function' ? Object(__WEBPACK_IMPORTED_MODULE_1__wrapMapToProps__[\"b\" /* wrapMapToPropsFunc */])(mapDispatchToProps, 'mapDispatchToProps') : undefined;\n}\n\nfunction whenMapDispatchToPropsIsMissing(mapDispatchToProps) {\n return !mapDispatchToProps ? Object(__WEBPACK_IMPORTED_MODULE_1__wrapMapToProps__[\"a\" /* wrapMapToPropsConstant */])(function (dispatch) {\n return { dispatch: dispatch };\n }) : undefined;\n}\n\nfunction whenMapDispatchToPropsIsObject(mapDispatchToProps) {\n return mapDispatchToProps && typeof mapDispatchToProps === 'object' ? Object(__WEBPACK_IMPORTED_MODULE_1__wrapMapToProps__[\"a\" /* wrapMapToPropsConstant */])(function (dispatch) {\n return Object(__WEBPACK_IMPORTED_MODULE_0_redux__[\"b\" /* bindActionCreators */])(mapDispatchToProps, dispatch);\n }) : undefined;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = ([whenMapDispatchToPropsIsFunction, whenMapDispatchToPropsIsMissing, whenMapDispatchToPropsIsObject]);\n\n/***/ }),\n\n/***/ 432:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* WEBPACK VAR INJECTION */(function(global, module) {/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__ponyfill_js__ = __webpack_require__(434);\n/* global window */\n\n\nvar root;\n\nif (typeof self !== 'undefined') {\n root = self;\n} else if (typeof window !== 'undefined') {\n root = window;\n} else if (typeof global !== 'undefined') {\n root = global;\n} else if (true) {\n root = module;\n} else {\n root = Function('return this')();\n}\n\nvar result = Object(__WEBPACK_IMPORTED_MODULE_0__ponyfill_js__[\"a\" /* default */])(root);\n/* harmony default export */ __webpack_exports__[\"a\"] = (result);\n\n/* WEBPACK VAR INJECTION */}.call(__webpack_exports__, __webpack_require__(13), __webpack_require__(433)(module)))\n\n/***/ }),\n\n/***/ 433:\n/***/ (function(module, exports) {\n\nmodule.exports = function(originalModule) {\r\n\tif(!originalModule.webpackPolyfill) {\r\n\t\tvar module = Object.create(originalModule);\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"exports\", {\r\n\t\t\tenumerable: true,\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n\n\n/***/ }),\n\n/***/ 434:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = symbolObservablePonyfill;\nfunction symbolObservablePonyfill(root) {\n\tvar result;\n\tvar Symbol = root.Symbol;\n\n\tif (typeof Symbol === 'function') {\n\t\tif (Symbol.observable) {\n\t\t\tresult = Symbol.observable;\n\t\t} else {\n\t\t\tresult = Symbol('observable');\n\t\t\tSymbol.observable = result;\n\t\t}\n\t} else {\n\t\tresult = '@@observable';\n\t}\n\n\treturn result;\n};\n\n\n/***/ }),\n\n/***/ 435:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__baseGetTag_js__ = __webpack_require__(436);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__getPrototype_js__ = __webpack_require__(441);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__isObjectLike_js__ = __webpack_require__(443);\n\n\n\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n if (!Object(__WEBPACK_IMPORTED_MODULE_2__isObjectLike_js__[\"a\" /* default */])(value) || Object(__WEBPACK_IMPORTED_MODULE_0__baseGetTag_js__[\"a\" /* default */])(value) != objectTag) {\n return false;\n }\n var proto = Object(__WEBPACK_IMPORTED_MODULE_1__getPrototype_js__[\"a\" /* default */])(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (isPlainObject);\n\n\n/***/ }),\n\n/***/ 436:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__Symbol_js__ = __webpack_require__(179);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__getRawTag_js__ = __webpack_require__(439);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__objectToString_js__ = __webpack_require__(440);\n\n\n\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = __WEBPACK_IMPORTED_MODULE_0__Symbol_js__[\"a\" /* default */] ? __WEBPACK_IMPORTED_MODULE_0__Symbol_js__[\"a\" /* default */].toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? Object(__WEBPACK_IMPORTED_MODULE_1__getRawTag_js__[\"a\" /* default */])(value)\n : Object(__WEBPACK_IMPORTED_MODULE_2__objectToString_js__[\"a\" /* default */])(value);\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (baseGetTag);\n\n\n/***/ }),\n\n/***/ 437:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__freeGlobal_js__ = __webpack_require__(438);\n\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = __WEBPACK_IMPORTED_MODULE_0__freeGlobal_js__[\"a\" /* default */] || freeSelf || Function('return this')();\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (root);\n\n\n/***/ }),\n\n/***/ 438:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* WEBPACK VAR INJECTION */(function(global) {/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (freeGlobal);\n\n/* WEBPACK VAR INJECTION */}.call(__webpack_exports__, __webpack_require__(13)))\n\n/***/ }),\n\n/***/ 439:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__Symbol_js__ = __webpack_require__(179);\n\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = __WEBPACK_IMPORTED_MODULE_0__Symbol_js__[\"a\" /* default */] ? __WEBPACK_IMPORTED_MODULE_0__Symbol_js__[\"a\" /* default */].toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (getRawTag);\n\n\n/***/ }),\n\n/***/ 440:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (objectToString);\n\n\n/***/ }),\n\n/***/ 441:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__overArg_js__ = __webpack_require__(442);\n\n\n/** Built-in value references. */\nvar getPrototype = Object(__WEBPACK_IMPORTED_MODULE_0__overArg_js__[\"a\" /* default */])(Object.getPrototypeOf, Object);\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (getPrototype);\n\n\n/***/ }),\n\n/***/ 442:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (overArg);\n\n\n/***/ }),\n\n/***/ 443:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (isObjectLike);\n\n\n/***/ }),\n\n/***/ 444:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export whenMapStateToPropsIsFunction */\n/* unused harmony export whenMapStateToPropsIsMissing */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__wrapMapToProps__ = __webpack_require__(177);\n\n\nfunction whenMapStateToPropsIsFunction(mapStateToProps) {\n return typeof mapStateToProps === 'function' ? Object(__WEBPACK_IMPORTED_MODULE_0__wrapMapToProps__[\"b\" /* wrapMapToPropsFunc */])(mapStateToProps, 'mapStateToProps') : undefined;\n}\n\nfunction whenMapStateToPropsIsMissing(mapStateToProps) {\n return !mapStateToProps ? Object(__WEBPACK_IMPORTED_MODULE_0__wrapMapToProps__[\"a\" /* wrapMapToPropsConstant */])(function () {\n return {};\n }) : undefined;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = ([whenMapStateToPropsIsFunction, whenMapStateToPropsIsMissing]);\n\n/***/ }),\n\n/***/ 445:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export defaultMergeProps */\n/* unused harmony export wrapMergePropsFunc */\n/* unused harmony export whenMergePropsIsFunction */\n/* unused harmony export whenMergePropsIsOmitted */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils_verifyPlainObject__ = __webpack_require__(178);\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\n\n\nfunction defaultMergeProps(stateProps, dispatchProps, ownProps) {\n return _extends({}, ownProps, stateProps, dispatchProps);\n}\n\nfunction wrapMergePropsFunc(mergeProps) {\n return function initMergePropsProxy(dispatch, _ref) {\n var displayName = _ref.displayName,\n pure = _ref.pure,\n areMergedPropsEqual = _ref.areMergedPropsEqual;\n\n var hasRunOnce = false;\n var mergedProps = void 0;\n\n return function mergePropsProxy(stateProps, dispatchProps, ownProps) {\n var nextMergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n\n if (hasRunOnce) {\n if (!pure || !areMergedPropsEqual(nextMergedProps, mergedProps)) mergedProps = nextMergedProps;\n } else {\n hasRunOnce = true;\n mergedProps = nextMergedProps;\n\n if (false) verifyPlainObject(mergedProps, displayName, 'mergeProps');\n }\n\n return mergedProps;\n };\n };\n}\n\nfunction whenMergePropsIsFunction(mergeProps) {\n return typeof mergeProps === 'function' ? wrapMergePropsFunc(mergeProps) : undefined;\n}\n\nfunction whenMergePropsIsOmitted(mergeProps) {\n return !mergeProps ? function () {\n return defaultMergeProps;\n } : undefined;\n}\n\n/* harmony default export */ __webpack_exports__[\"a\"] = ([whenMergePropsIsFunction, whenMergePropsIsOmitted]);\n\n/***/ }),\n\n/***/ 446:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export impureFinalPropsSelectorFactory */\n/* unused harmony export pureFinalPropsSelectorFactory */\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = finalPropsSelectorFactory;\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__verifySubselectors__ = __webpack_require__(447);\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\n\n\nfunction impureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch) {\n return function impureFinalPropsSelector(state, ownProps) {\n return mergeProps(mapStateToProps(state, ownProps), mapDispatchToProps(dispatch, ownProps), ownProps);\n };\n}\n\nfunction pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, _ref) {\n var areStatesEqual = _ref.areStatesEqual,\n areOwnPropsEqual = _ref.areOwnPropsEqual,\n areStatePropsEqual = _ref.areStatePropsEqual;\n\n var hasRunAtLeastOnce = false;\n var state = void 0;\n var ownProps = void 0;\n var stateProps = void 0;\n var dispatchProps = void 0;\n var mergedProps = void 0;\n\n function handleFirstCall(firstState, firstOwnProps) {\n state = firstState;\n ownProps = firstOwnProps;\n stateProps = mapStateToProps(state, ownProps);\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n hasRunAtLeastOnce = true;\n return mergedProps;\n }\n\n function handleNewPropsAndNewState() {\n stateProps = mapStateToProps(state, ownProps);\n\n if (mapDispatchToProps.dependsOnOwnProps) dispatchProps = mapDispatchToProps(dispatch, ownProps);\n\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleNewProps() {\n if (mapStateToProps.dependsOnOwnProps) stateProps = mapStateToProps(state, ownProps);\n\n if (mapDispatchToProps.dependsOnOwnProps) dispatchProps = mapDispatchToProps(dispatch, ownProps);\n\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleNewState() {\n var nextStateProps = mapStateToProps(state, ownProps);\n var statePropsChanged = !areStatePropsEqual(nextStateProps, stateProps);\n stateProps = nextStateProps;\n\n if (statePropsChanged) mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n\n return mergedProps;\n }\n\n function handleSubsequentCalls(nextState, nextOwnProps) {\n var propsChanged = !areOwnPropsEqual(nextOwnProps, ownProps);\n var stateChanged = !areStatesEqual(nextState, state);\n state = nextState;\n ownProps = nextOwnProps;\n\n if (propsChanged && stateChanged) return handleNewPropsAndNewState();\n if (propsChanged) return handleNewProps();\n if (stateChanged) return handleNewState();\n return mergedProps;\n }\n\n return function pureFinalPropsSelector(nextState, nextOwnProps) {\n return hasRunAtLeastOnce ? handleSubsequentCalls(nextState, nextOwnProps) : handleFirstCall(nextState, nextOwnProps);\n };\n}\n\n// TODO: Add more comments\n\n// If pure is true, the selector returned by selectorFactory will memoize its results,\n// allowing connectAdvanced's shouldComponentUpdate to return false if final\n// props have not changed. If false, the selector will always return a new\n// object and shouldComponentUpdate will always return true.\n\nfunction finalPropsSelectorFactory(dispatch, _ref2) {\n var initMapStateToProps = _ref2.initMapStateToProps,\n initMapDispatchToProps = _ref2.initMapDispatchToProps,\n initMergeProps = _ref2.initMergeProps,\n options = _objectWithoutProperties(_ref2, ['initMapStateToProps', 'initMapDispatchToProps', 'initMergeProps']);\n\n var mapStateToProps = initMapStateToProps(dispatch, options);\n var mapDispatchToProps = initMapDispatchToProps(dispatch, options);\n var mergeProps = initMergeProps(dispatch, options);\n\n if (false) {\n verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps, options.displayName);\n }\n\n var selectorFactory = options.pure ? pureFinalPropsSelectorFactory : impureFinalPropsSelectorFactory;\n\n return selectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, options);\n}\n\n/***/ }),\n\n/***/ 447:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export default */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils_warning__ = __webpack_require__(123);\n\n\nfunction verify(selector, methodName, displayName) {\n if (!selector) {\n throw new Error('Unexpected value for ' + methodName + ' in ' + displayName + '.');\n } else if (methodName === 'mapStateToProps' || methodName === 'mapDispatchToProps') {\n if (!selector.hasOwnProperty('dependsOnOwnProps')) {\n Object(__WEBPACK_IMPORTED_MODULE_0__utils_warning__[\"a\" /* default */])('The selector for ' + methodName + ' of ' + displayName + ' did not specify a value for dependsOnOwnProps.');\n }\n }\n}\n\nfunction verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps, displayName) {\n verify(mapStateToProps, 'mapStateToProps', displayName);\n verify(mapDispatchToProps, 'mapDispatchToProps', displayName);\n verify(mergeProps, 'mergeProps', displayName);\n}\n\n/***/ }),\n\n/***/ 448:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nfunction createThunkMiddleware(extraArgument) {\n return function (_ref) {\n var dispatch = _ref.dispatch,\n getState = _ref.getState;\n return function (next) {\n return function (action) {\n if (typeof action === 'function') {\n return action(dispatch, getState, extraArgument);\n }\n\n return next(action);\n };\n };\n };\n}\n\nvar thunk = createThunkMiddleware();\nthunk.withExtraArgument = createThunkMiddleware;\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (thunk);\n\n/***/ }),\n\n/***/ 449:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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_react_redux__ = __webpack_require__(122);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions__ = __webpack_require__(180);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__ExplorerPanel__ = __webpack_require__(453);\n\n\n\n\n\n\n\n\nvar Explorer = function Explorer(_ref) {\n var isVisible = _ref.isVisible,\n nodes = _ref.nodes,\n path = _ref.path,\n pushPage = _ref.pushPage,\n popPage = _ref.popPage,\n onClose = _ref.onClose;\n\n var page = nodes[path[path.length - 1]];\n\n return isVisible ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_3__ExplorerPanel__[\"a\" /* default */], {\n path: path,\n page: page,\n nodes: nodes,\n onClose: onClose,\n popPage: popPage,\n pushPage: pushPage\n }) : null;\n};\n\nvar mapStateToProps = function mapStateToProps(state) {\n return {\n isVisible: state.explorer.isVisible,\n path: state.explorer.path,\n nodes: state.nodes\n };\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n return {\n pushPage: function pushPage(id) {\n return dispatch(__WEBPACK_IMPORTED_MODULE_2__actions__[\"c\" /* pushPage */](id));\n },\n popPage: function popPage() {\n return dispatch(__WEBPACK_IMPORTED_MODULE_2__actions__[\"b\" /* popPage */]());\n },\n onClose: function onClose() {\n return dispatch(__WEBPACK_IMPORTED_MODULE_2__actions__[\"a\" /* closeExplorer */]());\n }\n };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_1_react_redux__[\"b\" /* connect */])(mapStateToProps, mapDispatchToProps)(Explorer));\n\n/***/ }),\n\n/***/ 450:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* WEBPACK VAR INJECTION */(function(global) {/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return getPage; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"b\", function() { return getPageChildren; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__api_client__ = __webpack_require__(451);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__ = __webpack_require__(17);\n\n\n\n\nvar getPage = function getPage(id) {\n var url = '' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"a\" /* ADMIN_API */].PAGES + id + '/';\n\n return Object(__WEBPACK_IMPORTED_MODULE_0__api_client__[\"a\" /* get */])(url);\n};\n\nvar getPageChildren = function getPageChildren(id) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var url = __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"a\" /* ADMIN_API */].PAGES + '?child_of=' + id + '&for_explorer=1';\n\n if (options.fields) {\n url += '&fields=' + global.encodeURIComponent(options.fields.join(','));\n }\n\n if (options.onlyWithChildren) {\n url += '&has_children=1';\n }\n\n if (options.offset) {\n url += '&offset=' + options.offset;\n }\n\n url += __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"a\" /* ADMIN_API */].EXTRA_CHILDREN_PARAMETERS;\n\n return Object(__WEBPACK_IMPORTED_MODULE_0__api_client__[\"a\" /* get */])(url);\n};\n/* WEBPACK VAR INJECTION */}.call(__webpack_exports__, __webpack_require__(13)))\n\n/***/ }),\n\n/***/ 451:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* WEBPACK VAR INJECTION */(function(global) {/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return get; });\nvar fetch = global.fetch;\nvar Headers = global.Headers;\n\nvar REQUEST_TIMEOUT = 15000;\n\nvar checkStatus = function checkStatus(response) {\n if (response.status >= 200 && response.status < 300) {\n return response;\n }\n\n var error = new Error(response.statusText);\n\n throw error;\n};\n\nvar parseJSON = function parseJSON(response) {\n return response.json();\n};\n\n// Response timeout cancelling the promise (not the request).\n// See https://github.com/github/fetch/issues/175#issuecomment-216791333.\nvar timeout = function timeout(ms, promise) {\n var race = new Promise(function (resolve, reject) {\n var timeoutId = setTimeout(function () {\n reject(new Error('Response timeout'));\n }, ms);\n\n promise.then(function (res) {\n clearTimeout(timeoutId);\n resolve(res);\n }, function (err) {\n clearTimeout(timeoutId);\n reject(err);\n });\n });\n\n return race;\n};\n\n/**\n * Wrapper around fetch with sane defaults for behavior in the face of\n * errors.\n */\nvar request = function request(method, url) {\n var options = {\n credentials: 'same-origin',\n headers: new Headers({\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n }),\n method: method\n };\n\n return timeout(REQUEST_TIMEOUT, fetch(url, options)).then(checkStatus).then(parseJSON);\n};\n\nvar get = function get(url) {\n return request('GET', url);\n};\n/* WEBPACK VAR INJECTION */}.call(__webpack_exports__, __webpack_require__(13)))\n\n/***/ }),\n\n/***/ 452:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = createAction;\nvar identity = function identity(func) {\n return func;\n};\n\n// Stolen from the following project (had a 18kb footprint at the time).\n// https://github.com/acdlite/redux-actions/blob/79c68635fb1524c1b1cf8e2398d4b099b53ca8de/src/createAction.js\nfunction createAction(type, actionCreator, metaCreator) {\n var finalActionCreator = typeof actionCreator === 'function' ? actionCreator : identity;\n\n return function () {\n var action = {\n type: type,\n payload: finalActionCreator.apply(undefined, arguments)\n };\n\n if (action.payload instanceof Error) {\n // Handle FSA errors where the payload is an Error object. Set error.\n action.error = true;\n }\n\n if (typeof metaCreator === 'function') {\n action.meta = metaCreator.apply(undefined, arguments);\n }\n\n return action;\n };\n}\n\n/***/ }),\n\n/***/ 453:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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_focus_trap_react__ = __webpack_require__(454);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_focus_trap_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_focus_trap_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__ = __webpack_require__(17);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__Button_Button__ = __webpack_require__(72);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__LoadingSpinner_LoadingSpinner__ = __webpack_require__(181);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__Transition_Transition__ = __webpack_require__(182);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__ExplorerHeader__ = __webpack_require__(470);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__ExplorerItem__ = __webpack_require__(471);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__PageCount__ = __webpack_require__(472);\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n\n\n\n\n\n\n\n\n\n\n\n\n/**\n * The main panel of the page explorer menu, with heading,\n * menu items, and special states.\n */\n\nvar ExplorerPanel = function (_React$Component) {\n _inherits(ExplorerPanel, _React$Component);\n\n function ExplorerPanel(props) {\n _classCallCheck(this, ExplorerPanel);\n\n var _this = _possibleConstructorReturn(this, (ExplorerPanel.__proto__ || Object.getPrototypeOf(ExplorerPanel)).call(this, props));\n\n _this.state = {\n transition: __WEBPACK_IMPORTED_MODULE_5__Transition_Transition__[\"b\" /* PUSH */],\n paused: false\n };\n\n _this.onItemClick = _this.onItemClick.bind(_this);\n _this.onHeaderClick = _this.onHeaderClick.bind(_this);\n _this.clickOutside = _this.clickOutside.bind(_this);\n return _this;\n }\n\n _createClass(ExplorerPanel, [{\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(newProps) {\n var path = this.props.path;\n\n var isPush = newProps.path.length > path.length;\n\n this.setState({\n transition: isPush ? __WEBPACK_IMPORTED_MODULE_5__Transition_Transition__[\"b\" /* PUSH */] : __WEBPACK_IMPORTED_MODULE_5__Transition_Transition__[\"a\" /* POP */]\n });\n }\n }, {\n key: 'componentDidMount',\n value: function componentDidMount() {\n document.querySelector('[data-explorer-menu-item]').classList.add('submenu-active');\n document.body.classList.add('explorer-open');\n document.addEventListener('mousedown', this.clickOutside);\n document.addEventListener('touchend', this.clickOutside);\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n document.querySelector('[data-explorer-menu-item]').classList.remove('submenu-active');\n document.body.classList.remove('explorer-open');\n document.removeEventListener('mousedown', this.clickOutside);\n document.removeEventListener('touchend', this.clickOutside);\n }\n }, {\n key: 'clickOutside',\n value: function clickOutside(e) {\n var onClose = this.props.onClose;\n\n var explorer = document.querySelector('[data-explorer-menu]');\n var toggle = document.querySelector('[data-explorer-menu-item]');\n\n var isInside = explorer.contains(e.target) || toggle.contains(e.target);\n if (!isInside) {\n onClose();\n }\n\n if (toggle.contains(e.target)) {\n this.setState({\n paused: true\n });\n }\n }\n }, {\n key: 'onItemClick',\n value: function onItemClick(id, e) {\n var pushPage = this.props.pushPage;\n\n\n e.preventDefault();\n e.stopPropagation();\n\n pushPage(id);\n }\n }, {\n key: 'onHeaderClick',\n value: function onHeaderClick(e) {\n var _props = this.props,\n path = _props.path,\n popPage = _props.popPage;\n\n var hasBack = path.length > 1;\n\n if (hasBack) {\n e.preventDefault();\n e.stopPropagation();\n\n popPage();\n }\n }\n }, {\n key: 'renderChildren',\n value: function renderChildren() {\n var _this2 = this;\n\n var _props2 = this.props,\n page = _props2.page,\n nodes = _props2.nodes;\n\n var children = void 0;\n\n if (!page.isFetching && !page.children.items) {\n children = __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { key: 'empty', className: 'c-explorer__placeholder' },\n __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__[\"e\" /* STRINGS */].NO_RESULTS\n );\n } else {\n children = __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { key: 'children' },\n page.children.items.map(function (id) {\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_7__ExplorerItem__[\"a\" /* default */], {\n key: id,\n item: nodes[id],\n onClick: _this2.onItemClick.bind(null, id)\n });\n })\n );\n }\n\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { className: 'c-explorer__drawer' },\n children,\n page.isFetching ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { key: 'fetching', className: 'c-explorer__placeholder' },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_4__LoadingSpinner_LoadingSpinner__[\"a\" /* default */], null)\n ) : null,\n page.isError ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { key: 'error', className: 'c-explorer__placeholder' },\n __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__[\"e\" /* STRINGS */].SERVER_ERROR\n ) : null\n );\n }\n }, {\n key: 'render',\n value: function render() {\n var _props3 = this.props,\n page = _props3.page,\n onClose = _props3.onClose,\n path = _props3.path;\n var _state = this.state,\n transition = _state.transition,\n paused = _state.paused;\n\n\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_1_focus_trap_react___default.a,\n {\n tag: 'div',\n role: 'dialog',\n className: 'explorer',\n paused: paused || !page || page.isFetching,\n focusTrapOptions: {\n initialFocus: '.c-explorer__header',\n onDeactivate: onClose\n }\n },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_3__Button_Button__[\"a\" /* default */],\n { className: 'c-explorer__close', onClick: onClose },\n __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__[\"e\" /* STRINGS */].CLOSE_EXPLORER\n ),\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_5__Transition_Transition__[\"c\" /* default */],\n { name: transition, className: 'c-explorer', component: 'nav', label: __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__[\"e\" /* STRINGS */].PAGE_EXPLORER },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { key: path.length, className: 'c-transition-group' },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_6__ExplorerHeader__[\"a\" /* default */], {\n depth: path.length,\n page: page,\n onClick: this.onHeaderClick\n }),\n this.renderChildren(),\n page.isError || page.children.items && page.children.count > __WEBPACK_IMPORTED_MODULE_2__config_wagtailConfig__[\"d\" /* MAX_EXPLORER_PAGES */] ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_8__PageCount__[\"a\" /* default */], { page: page }) : null\n )\n )\n );\n }\n }]);\n\n return ExplorerPanel;\n}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.Component);\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (ExplorerPanel);\n\n/***/ }),\n\n/***/ 454:\n/***/ (function(module, exports, __webpack_require__) {\n\n/* WEBPACK VAR INJECTION */(function(global) {module.exports = global[\"FocusTrapReact\"] = __webpack_require__(455);\n/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(13)))\n\n/***/ }),\n\n/***/ 455:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar React = __webpack_require__(1);\nvar createFocusTrap = __webpack_require__(456);\n\nvar checkedProps = ['active', 'paused', 'tag', 'focusTrapOptions', '_createFocusTrap'];\n\nvar FocusTrap = function (_React$Component) {\n _inherits(FocusTrap, _React$Component);\n\n function FocusTrap() {\n var _ref;\n\n var _temp, _this, _ret;\n\n _classCallCheck(this, FocusTrap);\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 = _possibleConstructorReturn(this, (_ref = FocusTrap.__proto__ || Object.getPrototypeOf(FocusTrap)).call.apply(_ref, [this].concat(args))), _this), _this.setNode = function (el) {\n _this.node = el;\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n _createClass(FocusTrap, [{\n key: 'componentWillMount',\n value: function componentWillMount() {\n if (typeof document !== 'undefined') {\n this.previouslyFocusedElement = document.activeElement;\n }\n }\n }, {\n key: 'componentDidMount',\n value: function componentDidMount() {\n // We need to hijack the returnFocusOnDeactivate option,\n // because React can move focus into the element before we arrived at\n // this lifecycle hook (e.g. with autoFocus inputs). So the component\n // captures the previouslyFocusedElement in componentWillMount,\n // then (optionally) returns focus to it in componentWillUnmount.\n var specifiedFocusTrapOptions = this.props.focusTrapOptions;\n var tailoredFocusTrapOptions = {\n returnFocusOnDeactivate: false\n };\n for (var optionName in specifiedFocusTrapOptions) {\n if (!specifiedFocusTrapOptions.hasOwnProperty(optionName)) continue;\n if (optionName === 'returnFocusOnDeactivate') continue;\n tailoredFocusTrapOptions[optionName] = specifiedFocusTrapOptions[optionName];\n }\n\n this.focusTrap = this.props._createFocusTrap(this.node, tailoredFocusTrapOptions);\n if (this.props.active) {\n this.focusTrap.activate();\n }\n if (this.props.paused) {\n this.focusTrap.pause();\n }\n }\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(prevProps) {\n if (prevProps.active && !this.props.active) {\n this.focusTrap.deactivate();\n } else if (!prevProps.active && this.props.active) {\n this.focusTrap.activate();\n }\n\n if (prevProps.paused && !this.props.paused) {\n this.focusTrap.unpause();\n } else if (!prevProps.paused && this.props.paused) {\n this.focusTrap.pause();\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n this.focusTrap.deactivate();\n if (this.props.focusTrapOptions.returnFocusOnDeactivate !== false && this.previouslyFocusedElement && this.previouslyFocusedElement.focus) {\n this.previouslyFocusedElement.focus();\n }\n }\n }, {\n key: 'render',\n value: function render() {\n var elementProps = {\n ref: this.setNode\n };\n\n // This will get id, className, style, etc. -- arbitrary element props\n for (var prop in this.props) {\n if (!this.props.hasOwnProperty(prop)) continue;\n if (checkedProps.indexOf(prop) !== -1) continue;\n elementProps[prop] = this.props[prop];\n }\n\n return React.createElement(this.props.tag, elementProps, this.props.children);\n }\n }]);\n\n return FocusTrap;\n}(React.Component);\n\nFocusTrap.defaultProps = {\n active: true,\n tag: 'div',\n paused: false,\n focusTrapOptions: {},\n _createFocusTrap: createFocusTrap\n};\n\nmodule.exports = FocusTrap;\n\n/***/ }),\n\n/***/ 456:\n/***/ (function(module, exports, __webpack_require__) {\n\nvar tabbable = __webpack_require__(457);\n\nvar listeningFocusTrap = null;\n\nfunction focusTrap(element, userOptions) {\n var tabbableNodes = [];\n var firstTabbableNode = null;\n var lastTabbableNode = null;\n var nodeFocusedBeforeActivation = null;\n var active = false;\n var paused = false;\n var tabEvent = null;\n\n var container = (typeof element === 'string')\n ? document.querySelector(element)\n : element;\n\n var config = userOptions || {};\n config.returnFocusOnDeactivate = (userOptions && userOptions.returnFocusOnDeactivate !== undefined)\n ? userOptions.returnFocusOnDeactivate\n : true;\n config.escapeDeactivates = (userOptions && userOptions.escapeDeactivates !== undefined)\n ? userOptions.escapeDeactivates\n : true;\n\n var trap = {\n activate: activate,\n deactivate: deactivate,\n pause: pause,\n unpause: unpause,\n };\n\n return trap;\n\n function activate(activateOptions) {\n if (active) return;\n\n var defaultedActivateOptions = {\n onActivate: (activateOptions && activateOptions.onActivate !== undefined)\n ? activateOptions.onActivate\n : config.onActivate,\n };\n\n active = true;\n paused = false;\n nodeFocusedBeforeActivation = document.activeElement;\n\n if (defaultedActivateOptions.onActivate) {\n defaultedActivateOptions.onActivate();\n }\n\n addListeners();\n return trap;\n }\n\n function deactivate(deactivateOptions) {\n if (!active) return;\n\n var defaultedDeactivateOptions = {\n returnFocus: (deactivateOptions && deactivateOptions.returnFocus !== undefined)\n ? deactivateOptions.returnFocus\n : config.returnFocusOnDeactivate,\n onDeactivate: (deactivateOptions && deactivateOptions.onDeactivate !== undefined)\n ? deactivateOptions.onDeactivate\n : config.onDeactivate,\n };\n\n removeListeners();\n\n if (defaultedDeactivateOptions.onDeactivate) {\n defaultedDeactivateOptions.onDeactivate();\n }\n\n if (defaultedDeactivateOptions.returnFocus) {\n setTimeout(function () {\n tryFocus(nodeFocusedBeforeActivation);\n }, 0);\n }\n\n active = false;\n paused = false;\n return this;\n }\n\n function pause() {\n if (paused || !active) return;\n paused = true;\n removeListeners();\n }\n\n function unpause() {\n if (!paused || !active) return;\n paused = false;\n addListeners();\n }\n\n function addListeners() {\n if (!active) return;\n\n // There can be only one listening focus trap at a time\n if (listeningFocusTrap) {\n listeningFocusTrap.pause();\n }\n listeningFocusTrap = trap;\n\n updateTabbableNodes();\n tryFocus(firstFocusNode());\n document.addEventListener('focus', checkFocus, true);\n document.addEventListener('click', checkClick, true);\n document.addEventListener('mousedown', checkPointerDown, true);\n document.addEventListener('touchstart', checkPointerDown, true);\n document.addEventListener('keydown', checkKey, true);\n\n return trap;\n }\n\n function removeListeners() {\n if (!active || listeningFocusTrap !== trap) return;\n\n document.removeEventListener('focus', checkFocus, true);\n document.removeEventListener('click', checkClick, true);\n document.removeEventListener('mousedown', checkPointerDown, true);\n document.removeEventListener('touchstart', checkPointerDown, true);\n document.removeEventListener('keydown', checkKey, true);\n\n listeningFocusTrap = null;\n\n return trap;\n }\n\n function getNodeForOption(optionName) {\n var optionValue = config[optionName];\n var node = optionValue;\n if (!optionValue) {\n return null;\n }\n if (typeof optionValue === 'string') {\n node = document.querySelector(optionValue);\n if (!node) {\n throw new Error('`' + optionName + '` refers to no known node');\n }\n }\n if (typeof optionValue === 'function') {\n node = optionValue();\n if (!node) {\n throw new Error('`' + optionName + '` did not return a node');\n }\n }\n return node;\n }\n\n function firstFocusNode() {\n var node;\n if (getNodeForOption('initialFocus') !== null) {\n node = getNodeForOption('initialFocus');\n } else if (container.contains(document.activeElement)) {\n node = document.activeElement;\n } else {\n node = tabbableNodes[0] || getNodeForOption('fallbackFocus');\n }\n\n if (!node) {\n throw new Error('You can\\'t have a focus-trap without at least one focusable element');\n }\n\n return node;\n }\n\n // This needs to be done on mousedown and touchstart instead of click\n // so that it precedes the focus event\n function checkPointerDown(e) {\n if (config.clickOutsideDeactivates && !container.contains(e.target)) {\n deactivate({ returnFocus: false });\n }\n }\n\n function checkClick(e) {\n if (config.clickOutsideDeactivates) return;\n if (container.contains(e.target)) return;\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n\n function checkFocus(e) {\n if (container.contains(e.target)) return;\n e.preventDefault();\n e.stopImmediatePropagation();\n // Checking for a blur method here resolves a Firefox issue (#15)\n if (typeof e.target.blur === 'function') e.target.blur();\n\n if (tabEvent) {\n readjustFocus(tabEvent);\n }\n }\n\n function checkKey(e) {\n if (e.key === 'Tab' || e.keyCode === 9) {\n handleTab(e);\n }\n\n if (config.escapeDeactivates !== false && isEscapeEvent(e)) {\n deactivate();\n }\n }\n\n function handleTab(e) {\n updateTabbableNodes();\n\n if (e.target.hasAttribute('tabindex') && Number(e.target.getAttribute('tabindex')) < 0) {\n return tabEvent = e;\n }\n\n e.preventDefault();\n var currentFocusIndex = tabbableNodes.indexOf(e.target);\n\n if (e.shiftKey) {\n if (e.target === firstTabbableNode || tabbableNodes.indexOf(e.target) === -1) {\n return tryFocus(lastTabbableNode);\n }\n return tryFocus(tabbableNodes[currentFocusIndex - 1]);\n }\n\n if (e.target === lastTabbableNode) return tryFocus(firstTabbableNode);\n\n tryFocus(tabbableNodes[currentFocusIndex + 1]);\n }\n\n function updateTabbableNodes() {\n tabbableNodes = tabbable(container);\n firstTabbableNode = tabbableNodes[0];\n lastTabbableNode = tabbableNodes[tabbableNodes.length - 1];\n }\n\n function readjustFocus(e) {\n if (e.shiftKey) return tryFocus(lastTabbableNode);\n\n tryFocus(firstTabbableNode);\n }\n}\n\nfunction isEscapeEvent(e) {\n return e.key === 'Escape' || e.key === 'Esc' || e.keyCode === 27;\n}\n\nfunction tryFocus(node) {\n if (!node || !node.focus) return;\n if (node === document.activeElement) return;\n\n node.focus();\n if (node.tagName.toLowerCase() === 'input') {\n node.select();\n }\n}\n\nmodule.exports = focusTrap;\n\n\n/***/ }),\n\n/***/ 457:\n/***/ (function(module, exports) {\n\nmodule.exports = function(el, options) {\n options = options || {};\n\n var elementDocument = el.ownerDocument || el;\n var basicTabbables = [];\n var orderedTabbables = [];\n\n // A node is \"available\" if\n // - it's computed style\n var isUnavailable = createIsUnavailable(elementDocument);\n\n var candidateSelectors = [\n 'input',\n 'select',\n 'a[href]',\n 'textarea',\n 'button',\n '[tabindex]',\n ];\n\n var candidates = el.querySelectorAll(candidateSelectors.join(','));\n\n if (options.includeContainer) {\n var matches = Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\n\n if (\n candidateSelectors.some(function(candidateSelector) {\n return matches.call(el, candidateSelector);\n })\n ) {\n candidates = Array.prototype.slice.apply(candidates);\n candidates.unshift(el);\n }\n }\n\n var candidate, candidateIndex;\n for (var i = 0, l = candidates.length; i < l; i++) {\n candidate = candidates[i];\n candidateIndex = parseInt(candidate.getAttribute('tabindex'), 10) || candidate.tabIndex;\n\n if (\n candidateIndex < 0\n || (candidate.tagName === 'INPUT' && candidate.type === 'hidden')\n || candidate.disabled\n || isUnavailable(candidate, elementDocument)\n ) {\n continue;\n }\n\n if (candidateIndex === 0) {\n basicTabbables.push(candidate);\n } else {\n orderedTabbables.push({\n index: i,\n tabIndex: candidateIndex,\n node: candidate,\n });\n }\n }\n\n var tabbableNodes = orderedTabbables\n .sort(function(a, b) {\n return a.tabIndex === b.tabIndex ? a.index - b.index : a.tabIndex - b.tabIndex;\n })\n .map(function(a) {\n return a.node\n });\n\n Array.prototype.push.apply(tabbableNodes, basicTabbables);\n\n return tabbableNodes;\n}\n\nfunction createIsUnavailable(elementDocument) {\n // Node cache must be refreshed on every check, in case\n // the content of the element has changed\n var isOffCache = [];\n\n // \"off\" means `display: none;`, as opposed to \"hidden\",\n // which means `visibility: hidden;`. getComputedStyle\n // accurately reflects visiblity in context but not\n // \"off\" state, so we need to recursively check parents.\n\n function isOff(node, nodeComputedStyle) {\n if (node === elementDocument.documentElement) return false;\n\n // Find the cached node (Array.prototype.find not available in IE9)\n for (var i = 0, length = isOffCache.length; i < length; i++) {\n if (isOffCache[i][0] === node) return isOffCache[i][1];\n }\n\n nodeComputedStyle = nodeComputedStyle || elementDocument.defaultView.getComputedStyle(node);\n\n var result = false;\n\n if (nodeComputedStyle.display === 'none') {\n result = true;\n } else if (node.parentNode) {\n result = isOff(node.parentNode);\n }\n\n isOffCache.push([node, result]);\n\n return result;\n }\n\n return function isUnavailable(node) {\n if (node === elementDocument.documentElement) return false;\n\n var computedStyle = elementDocument.defaultView.getComputedStyle(node);\n\n if (isOff(node, computedStyle)) return true;\n\n return computedStyle.visibility === 'hidden';\n }\n}\n\n\n/***/ }),\n\n/***/ 458:\n/***/ (function(module, exports, __webpack_require__) {\n\n/* WEBPACK VAR INJECTION */(function(global) {module.exports = global[\"CSSTransitionGroup\"] = __webpack_require__(459);\n/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(13)))\n\n/***/ }),\n\n/***/ 459:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nexports.__esModule = true;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _react = __webpack_require__(1);\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(59);\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _TransitionGroup = __webpack_require__(460);\n\nvar _TransitionGroup2 = _interopRequireDefault(_TransitionGroup);\n\nvar _CSSTransitionGroupChild = __webpack_require__(464);\n\nvar _CSSTransitionGroupChild2 = _interopRequireDefault(_CSSTransitionGroupChild);\n\nvar _PropTypes = __webpack_require__(184);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar propTypes = {\n transitionName: _PropTypes.nameShape.isRequired,\n\n transitionAppear: _propTypes2.default.bool,\n transitionEnter: _propTypes2.default.bool,\n transitionLeave: _propTypes2.default.bool,\n transitionAppearTimeout: (0, _PropTypes.transitionTimeout)('Appear'),\n transitionEnterTimeout: (0, _PropTypes.transitionTimeout)('Enter'),\n transitionLeaveTimeout: (0, _PropTypes.transitionTimeout)('Leave')\n};\n\nvar defaultProps = {\n transitionAppear: false,\n transitionEnter: true,\n transitionLeave: true\n};\n\nvar CSSTransitionGroup = function (_React$Component) {\n _inherits(CSSTransitionGroup, _React$Component);\n\n function CSSTransitionGroup() {\n var _temp, _this, _ret;\n\n _classCallCheck(this, CSSTransitionGroup);\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 = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this._wrapChild = function (child) {\n return _react2.default.createElement(_CSSTransitionGroupChild2.default, {\n name: _this.props.transitionName,\n appear: _this.props.transitionAppear,\n enter: _this.props.transitionEnter,\n leave: _this.props.transitionLeave,\n appearTimeout: _this.props.transitionAppearTimeout,\n enterTimeout: _this.props.transitionEnterTimeout,\n leaveTimeout: _this.props.transitionLeaveTimeout\n }, child);\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n // We need to provide this childFactory so that\n // ReactCSSTransitionGroupChild can receive updates to name, enter, and\n // leave while it is leaving.\n\n\n CSSTransitionGroup.prototype.render = function render() {\n return _react2.default.createElement(_TransitionGroup2.default, _extends({}, this.props, { childFactory: this._wrapChild }));\n };\n\n return CSSTransitionGroup;\n}(_react2.default.Component);\n\nCSSTransitionGroup.displayName = 'CSSTransitionGroup';\n\n\nCSSTransitionGroup.propTypes = false ? propTypes : {};\nCSSTransitionGroup.defaultProps = defaultProps;\n\nexports.default = CSSTransitionGroup;\nmodule.exports = exports['default'];\n\n/***/ }),\n\n/***/ 460:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nexports.__esModule = true;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _chainFunction = __webpack_require__(461);\n\nvar _chainFunction2 = _interopRequireDefault(_chainFunction);\n\nvar _react = __webpack_require__(1);\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(59);\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _warning = __webpack_require__(462);\n\nvar _warning2 = _interopRequireDefault(_warning);\n\nvar _ChildMapping = __webpack_require__(463);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar propTypes = {\n component: _propTypes2.default.any,\n childFactory: _propTypes2.default.func,\n children: _propTypes2.default.node\n};\n\nvar defaultProps = {\n component: 'span',\n childFactory: function childFactory(child) {\n return child;\n }\n};\n\nvar TransitionGroup = function (_React$Component) {\n _inherits(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n _classCallCheck(this, TransitionGroup);\n\n var _this = _possibleConstructorReturn(this, _React$Component.call(this, props, context));\n\n _this.performAppear = function (key, component) {\n _this.currentlyTransitioningKeys[key] = true;\n\n if (component.componentWillAppear) {\n component.componentWillAppear(_this._handleDoneAppearing.bind(_this, key, component));\n } else {\n _this._handleDoneAppearing(key, component);\n }\n };\n\n _this._handleDoneAppearing = function (key, component) {\n if (component.componentDidAppear) {\n component.componentDidAppear();\n }\n\n delete _this.currentlyTransitioningKeys[key];\n\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(_this.props.children);\n\n if (!currentChildMapping || !currentChildMapping.hasOwnProperty(key)) {\n // This was removed before it had fully appeared. Remove it.\n _this.performLeave(key, component);\n }\n };\n\n _this.performEnter = function (key, component) {\n _this.currentlyTransitioningKeys[key] = true;\n\n if (component.componentWillEnter) {\n component.componentWillEnter(_this._handleDoneEntering.bind(_this, key, component));\n } else {\n _this._handleDoneEntering(key, component);\n }\n };\n\n _this._handleDoneEntering = function (key, component) {\n if (component.componentDidEnter) {\n component.componentDidEnter();\n }\n\n delete _this.currentlyTransitioningKeys[key];\n\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(_this.props.children);\n\n if (!currentChildMapping || !currentChildMapping.hasOwnProperty(key)) {\n // This was removed before it had fully entered. Remove it.\n _this.performLeave(key, component);\n }\n };\n\n _this.performLeave = function (key, component) {\n _this.currentlyTransitioningKeys[key] = true;\n\n if (component.componentWillLeave) {\n component.componentWillLeave(_this._handleDoneLeaving.bind(_this, key, component));\n } else {\n // Note that this is somewhat dangerous b/c it calls setState()\n // again, effectively mutating the component before all the work\n // is done.\n _this._handleDoneLeaving(key, component);\n }\n };\n\n _this._handleDoneLeaving = function (key, component) {\n if (component.componentDidLeave) {\n component.componentDidLeave();\n }\n\n delete _this.currentlyTransitioningKeys[key];\n\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(_this.props.children);\n\n if (currentChildMapping && currentChildMapping.hasOwnProperty(key)) {\n // This entered again before it fully left. Add it again.\n _this.keysToEnter.push(key);\n } else {\n _this.setState(function (state) {\n var newChildren = _extends({}, state.children);\n delete newChildren[key];\n return { children: newChildren };\n });\n }\n };\n\n _this.childRefs = Object.create(null);\n\n _this.state = {\n children: (0, _ChildMapping.getChildMapping)(props.children)\n };\n return _this;\n }\n\n TransitionGroup.prototype.componentWillMount = function componentWillMount() {\n this.currentlyTransitioningKeys = {};\n this.keysToEnter = [];\n this.keysToLeave = [];\n };\n\n TransitionGroup.prototype.componentDidMount = function componentDidMount() {\n var initialChildMapping = this.state.children;\n for (var key in initialChildMapping) {\n if (initialChildMapping[key]) {\n this.performAppear(key, this.childRefs[key]);\n }\n }\n };\n\n TransitionGroup.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var nextChildMapping = (0, _ChildMapping.getChildMapping)(nextProps.children);\n var prevChildMapping = this.state.children;\n\n this.setState({\n children: (0, _ChildMapping.mergeChildMappings)(prevChildMapping, nextChildMapping)\n });\n\n for (var key in nextChildMapping) {\n var hasPrev = prevChildMapping && prevChildMapping.hasOwnProperty(key);\n if (nextChildMapping[key] && !hasPrev && !this.currentlyTransitioningKeys[key]) {\n this.keysToEnter.push(key);\n }\n }\n\n for (var _key in prevChildMapping) {\n var hasNext = nextChildMapping && nextChildMapping.hasOwnProperty(_key);\n if (prevChildMapping[_key] && !hasNext && !this.currentlyTransitioningKeys[_key]) {\n this.keysToLeave.push(_key);\n }\n }\n\n // If we want to someday check for reordering, we could do it here.\n };\n\n TransitionGroup.prototype.componentDidUpdate = function componentDidUpdate() {\n var _this2 = this;\n\n var keysToEnter = this.keysToEnter;\n this.keysToEnter = [];\n keysToEnter.forEach(function (key) {\n return _this2.performEnter(key, _this2.childRefs[key]);\n });\n\n var keysToLeave = this.keysToLeave;\n this.keysToLeave = [];\n keysToLeave.forEach(function (key) {\n return _this2.performLeave(key, _this2.childRefs[key]);\n });\n };\n\n TransitionGroup.prototype.render = function render() {\n var _this3 = this;\n\n // TODO: we could get rid of the need for the wrapper node\n // by cloning a single child\n var childrenToRender = [];\n\n var _loop = function _loop(key) {\n var child = _this3.state.children[key];\n if (child) {\n var isCallbackRef = typeof child.ref !== 'string';\n var factoryChild = _this3.props.childFactory(child);\n var ref = function ref(r) {\n _this3.childRefs[key] = r;\n };\n\n false ? (0, _warning2.default)(isCallbackRef, 'string refs are not supported on children of TransitionGroup and will be ignored. ' + 'Please use a callback ref instead: https://facebook.github.io/react/docs/refs-and-the-dom.html#the-ref-callback-attribute') : void 0;\n\n // Always chaining the refs leads to problems when the childFactory\n // wraps the child. The child ref callback gets called twice with the\n // wrapper and the child. So we only need to chain the ref if the\n // factoryChild is not different from child.\n if (factoryChild === child && isCallbackRef) {\n ref = (0, _chainFunction2.default)(child.ref, ref);\n }\n\n // You may need to apply reactive updates to a child as it is leaving.\n // The normal React way to do it won't work since the child will have\n // already been removed. In case you need this behavior you can provide\n // a childFactory function to wrap every child, even the ones that are\n // leaving.\n childrenToRender.push(_react2.default.cloneElement(factoryChild, {\n key: key,\n ref: ref\n }));\n }\n };\n\n for (var key in this.state.children) {\n _loop(key);\n }\n\n // Do not forward TransitionGroup props to primitive DOM nodes\n var props = _extends({}, this.props);\n delete props.transitionLeave;\n delete props.transitionName;\n delete props.transitionAppear;\n delete props.transitionEnter;\n delete props.childFactory;\n delete props.transitionLeaveTimeout;\n delete props.transitionEnterTimeout;\n delete props.transitionAppearTimeout;\n delete props.component;\n\n return _react2.default.createElement(this.props.component, props, childrenToRender);\n };\n\n return TransitionGroup;\n}(_react2.default.Component);\n\nTransitionGroup.displayName = 'TransitionGroup';\n\n\nTransitionGroup.propTypes = false ? propTypes : {};\nTransitionGroup.defaultProps = defaultProps;\n\nexports.default = TransitionGroup;\nmodule.exports = exports['default'];\n\n/***/ }),\n\n/***/ 461:\n/***/ (function(module, exports) {\n\n\r\nmodule.exports = function chain(){\r\n var len = arguments.length\r\n var args = [];\r\n\r\n for (var i = 0; i < len; i++)\r\n args[i] = arguments[i]\r\n\r\n args = args.filter(function(fn){ return fn != null })\r\n\r\n if (args.length === 0) return undefined\r\n if (args.length === 1) return args[0]\r\n\r\n return args.reduce(function(current, next){\r\n return function chainedFunction() {\r\n current.apply(this, arguments);\r\n next.apply(this, arguments);\r\n };\r\n })\r\n}\r\n\n\n/***/ }),\n\n/***/ 462:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n/**\n * Copyright 2014-2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n */\n\n\n\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar warning = function() {};\n\nif (false) {\n warning = function(condition, format, args) {\n var len = arguments.length;\n args = new Array(len > 2 ? len - 2 : 0);\n for (var key = 2; key < len; key++) {\n args[key - 2] = arguments[key];\n }\n if (format === undefined) {\n throw new Error(\n '`warning(condition, format, ...args)` requires a warning ' +\n 'message argument'\n );\n }\n\n if (format.length < 10 || (/^[s\\W]*$/).test(format)) {\n throw new Error(\n 'The warning format should be able to uniquely identify this ' +\n 'warning. Please, use a more descriptive format than: ' + format\n );\n }\n\n if (!condition) {\n var argIndex = 0;\n var message = 'Warning: ' +\n format.replace(/%s/g, function() {\n return args[argIndex++];\n });\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch(x) {}\n }\n };\n}\n\nmodule.exports = warning;\n\n\n/***/ }),\n\n/***/ 463:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nexports.__esModule = true;\nexports.getChildMapping = getChildMapping;\nexports.mergeChildMappings = mergeChildMappings;\n\nvar _react = __webpack_require__(1);\n\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\nfunction getChildMapping(children) {\n if (!children) {\n return children;\n }\n var result = {};\n _react.Children.map(children, function (child) {\n return child;\n }).forEach(function (child) {\n result[child.key] = child;\n });\n return result;\n}\n\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\nfunction mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n if (next.hasOwnProperty(key)) {\n return next[key];\n }\n\n return prev[key];\n }\n\n // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n var nextKeysPending = {};\n\n var pendingKeys = [];\n for (var prevKey in prev) {\n if (next.hasOwnProperty(prevKey)) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i = void 0;\n var childMapping = {};\n for (var nextKey in next) {\n if (nextKeysPending.hasOwnProperty(nextKey)) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n childMapping[nextKey] = getValueForKey(nextKey);\n }\n\n // Finally, add the keys which didn't appear before any key in `next`\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\n/***/ }),\n\n/***/ 464:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nexports.__esModule = true;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _addClass = __webpack_require__(465);\n\nvar _addClass2 = _interopRequireDefault(_addClass);\n\nvar _removeClass = __webpack_require__(467);\n\nvar _removeClass2 = _interopRequireDefault(_removeClass);\n\nvar _requestAnimationFrame = __webpack_require__(468);\n\nvar _requestAnimationFrame2 = _interopRequireDefault(_requestAnimationFrame);\n\nvar _properties = __webpack_require__(469);\n\nvar _react = __webpack_require__(1);\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(59);\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _reactDom = __webpack_require__(38);\n\nvar _PropTypes = __webpack_require__(184);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar events = [];\nif (_properties.transitionEnd) events.push(_properties.transitionEnd);\nif (_properties.animationEnd) events.push(_properties.animationEnd);\n\nfunction addEndListener(node, listener) {\n if (events.length) {\n events.forEach(function (e) {\n return node.addEventListener(e, listener, false);\n });\n } else {\n setTimeout(listener, 0);\n }\n\n return function () {\n if (!events.length) return;\n events.forEach(function (e) {\n return node.removeEventListener(e, listener, false);\n });\n };\n}\n\nvar propTypes = {\n children: _propTypes2.default.node,\n name: _PropTypes.nameShape.isRequired,\n\n // Once we require timeouts to be specified, we can remove the\n // boolean flags (appear etc.) and just accept a number\n // or a bool for the timeout flags (appearTimeout etc.)\n appear: _propTypes2.default.bool,\n enter: _propTypes2.default.bool,\n leave: _propTypes2.default.bool,\n appearTimeout: _propTypes2.default.number,\n enterTimeout: _propTypes2.default.number,\n leaveTimeout: _propTypes2.default.number\n};\n\nvar CSSTransitionGroupChild = function (_React$Component) {\n _inherits(CSSTransitionGroupChild, _React$Component);\n\n function CSSTransitionGroupChild() {\n var _temp, _this, _ret;\n\n _classCallCheck(this, CSSTransitionGroupChild);\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 = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this.componentWillAppear = function (done) {\n if (_this.props.appear) {\n _this.transition('appear', done, _this.props.appearTimeout);\n } else {\n done();\n }\n }, _this.componentWillEnter = function (done) {\n if (_this.props.enter) {\n _this.transition('enter', done, _this.props.enterTimeout);\n } else {\n done();\n }\n }, _this.componentWillLeave = function (done) {\n if (_this.props.leave) {\n _this.transition('leave', done, _this.props.leaveTimeout);\n } else {\n done();\n }\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n CSSTransitionGroupChild.prototype.componentWillMount = function componentWillMount() {\n this.classNameAndNodeQueue = [];\n this.transitionTimeouts = [];\n };\n\n CSSTransitionGroupChild.prototype.componentWillUnmount = function componentWillUnmount() {\n this.unmounted = true;\n\n if (this.timeout) {\n clearTimeout(this.timeout);\n }\n this.transitionTimeouts.forEach(function (timeout) {\n clearTimeout(timeout);\n });\n\n this.classNameAndNodeQueue.length = 0;\n };\n\n CSSTransitionGroupChild.prototype.transition = function transition(animationType, finishCallback, timeout) {\n var node = (0, _reactDom.findDOMNode)(this);\n\n if (!node) {\n if (finishCallback) {\n finishCallback();\n }\n return;\n }\n\n var className = this.props.name[animationType] || this.props.name + '-' + animationType;\n var activeClassName = this.props.name[animationType + 'Active'] || className + '-active';\n var timer = null;\n var removeListeners = void 0;\n\n (0, _addClass2.default)(node, className);\n\n // Need to do this to actually trigger a transition.\n this.queueClassAndNode(activeClassName, node);\n\n // Clean-up the animation after the specified delay\n var finish = function finish(e) {\n if (e && e.target !== node) {\n return;\n }\n\n clearTimeout(timer);\n if (removeListeners) removeListeners();\n\n (0, _removeClass2.default)(node, className);\n (0, _removeClass2.default)(node, activeClassName);\n\n if (removeListeners) removeListeners();\n\n // Usually this optional callback is used for informing an owner of\n // a leave animation and telling it to remove the child.\n if (finishCallback) {\n finishCallback();\n }\n };\n\n if (timeout) {\n timer = setTimeout(finish, timeout);\n this.transitionTimeouts.push(timer);\n } else if (_properties.transitionEnd) {\n removeListeners = addEndListener(node, finish);\n }\n };\n\n CSSTransitionGroupChild.prototype.queueClassAndNode = function queueClassAndNode(className, node) {\n var _this2 = this;\n\n this.classNameAndNodeQueue.push({\n className: className,\n node: node\n });\n\n if (!this.rafHandle) {\n this.rafHandle = (0, _requestAnimationFrame2.default)(function () {\n return _this2.flushClassNameAndNodeQueue();\n });\n }\n };\n\n CSSTransitionGroupChild.prototype.flushClassNameAndNodeQueue = function flushClassNameAndNodeQueue() {\n if (!this.unmounted) {\n this.classNameAndNodeQueue.forEach(function (obj) {\n // This is for to force a repaint,\n // which is necessary in order to transition styles when adding a class name.\n /* eslint-disable no-unused-expressions */\n obj.node.scrollTop;\n /* eslint-enable no-unused-expressions */\n (0, _addClass2.default)(obj.node, obj.className);\n });\n }\n this.classNameAndNodeQueue.length = 0;\n this.rafHandle = null;\n };\n\n CSSTransitionGroupChild.prototype.render = function render() {\n var props = _extends({}, this.props);\n delete props.name;\n delete props.appear;\n delete props.enter;\n delete props.leave;\n delete props.appearTimeout;\n delete props.enterTimeout;\n delete props.leaveTimeout;\n delete props.children;\n return _react2.default.cloneElement(_react2.default.Children.only(this.props.children), props);\n };\n\n return CSSTransitionGroupChild;\n}(_react2.default.Component);\n\nCSSTransitionGroupChild.displayName = 'CSSTransitionGroupChild';\n\n\nCSSTransitionGroupChild.propTypes = false ? propTypes : {};\n\nexports.default = CSSTransitionGroupChild;\nmodule.exports = exports['default'];\n\n/***/ }),\n\n/***/ 465:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = addClass;\n\nvar _hasClass = __webpack_require__(466);\n\nvar _hasClass2 = _interopRequireDefault(_hasClass);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction addClass(element, className) {\n if (element.classList) element.classList.add(className);else if (!(0, _hasClass2.default)(element)) element.className = element.className + ' ' + className;\n}\nmodule.exports = exports['default'];\n\n/***/ }),\n\n/***/ 466:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = hasClass;\nfunction hasClass(element, className) {\n if (element.classList) return !!className && element.classList.contains(className);else return (\" \" + element.className + \" \").indexOf(\" \" + className + \" \") !== -1;\n}\nmodule.exports = exports[\"default\"];\n\n/***/ }),\n\n/***/ 467:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = function removeClass(element, className) {\n if (element.classList) element.classList.remove(className);else element.className = element.className.replace(new RegExp('(^|\\\\s)' + className + '(?:\\\\s|$)', 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n};\n\n/***/ }),\n\n/***/ 468:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _inDOM = __webpack_require__(183);\n\nvar _inDOM2 = _interopRequireDefault(_inDOM);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar vendors = ['', 'webkit', 'moz', 'o', 'ms'];\nvar cancel = 'clearTimeout';\nvar raf = fallback;\nvar compatRaf = void 0;\n\nvar getKey = function getKey(vendor, k) {\n return vendor + (!vendor ? k : k[0].toUpperCase() + k.substr(1)) + 'AnimationFrame';\n};\n\nif (_inDOM2.default) {\n vendors.some(function (vendor) {\n var rafKey = getKey(vendor, 'request');\n\n if (rafKey in window) {\n cancel = getKey(vendor, 'cancel');\n return raf = function raf(cb) {\n return window[rafKey](cb);\n };\n }\n });\n}\n\n/* https://github.com/component/raf */\nvar prev = new Date().getTime();\nfunction fallback(fn) {\n var curr = new Date().getTime(),\n ms = Math.max(0, 16 - (curr - prev)),\n req = setTimeout(fn, ms);\n\n prev = curr;\n return req;\n}\n\ncompatRaf = function compatRaf(cb) {\n return raf(cb);\n};\ncompatRaf.cancel = function (id) {\n window[cancel] && typeof window[cancel] === 'function' && window[cancel](id);\n};\nexports.default = compatRaf;\nmodule.exports = exports['default'];\n\n/***/ }),\n\n/***/ 469:\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.animationEnd = exports.animationDelay = exports.animationTiming = exports.animationDuration = exports.animationName = exports.transitionEnd = exports.transitionDuration = exports.transitionDelay = exports.transitionTiming = exports.transitionProperty = exports.transform = undefined;\n\nvar _inDOM = __webpack_require__(183);\n\nvar _inDOM2 = _interopRequireDefault(_inDOM);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar transform = 'transform';\nvar prefix = void 0,\n transitionEnd = void 0,\n animationEnd = void 0;\nvar transitionProperty = void 0,\n transitionDuration = void 0,\n transitionTiming = void 0,\n transitionDelay = void 0;\nvar animationName = void 0,\n animationDuration = void 0,\n animationTiming = void 0,\n animationDelay = void 0;\n\nif (_inDOM2.default) {\n var _getTransitionPropert = getTransitionProperties();\n\n prefix = _getTransitionPropert.prefix;\n exports.transitionEnd = transitionEnd = _getTransitionPropert.transitionEnd;\n exports.animationEnd = animationEnd = _getTransitionPropert.animationEnd;\n\n\n exports.transform = transform = prefix + '-' + transform;\n exports.transitionProperty = transitionProperty = prefix + '-transition-property';\n exports.transitionDuration = transitionDuration = prefix + '-transition-duration';\n exports.transitionDelay = transitionDelay = prefix + '-transition-delay';\n exports.transitionTiming = transitionTiming = prefix + '-transition-timing-function';\n\n exports.animationName = animationName = prefix + '-animation-name';\n exports.animationDuration = animationDuration = prefix + '-animation-duration';\n exports.animationTiming = animationTiming = prefix + '-animation-delay';\n exports.animationDelay = animationDelay = prefix + '-animation-timing-function';\n}\n\nexports.transform = transform;\nexports.transitionProperty = transitionProperty;\nexports.transitionTiming = transitionTiming;\nexports.transitionDelay = transitionDelay;\nexports.transitionDuration = transitionDuration;\nexports.transitionEnd = transitionEnd;\nexports.animationName = animationName;\nexports.animationDuration = animationDuration;\nexports.animationTiming = animationTiming;\nexports.animationDelay = animationDelay;\nexports.animationEnd = animationEnd;\nexports.default = {\n transform: transform,\n end: transitionEnd,\n property: transitionProperty,\n timing: transitionTiming,\n delay: transitionDelay,\n duration: transitionDuration\n};\n\n\nfunction getTransitionProperties() {\n var style = document.createElement('div').style;\n\n var vendorMap = {\n O: function O(e) {\n return 'o' + e.toLowerCase();\n },\n Moz: function Moz(e) {\n return e.toLowerCase();\n },\n Webkit: function Webkit(e) {\n return 'webkit' + e;\n },\n ms: function ms(e) {\n return 'MS' + e;\n }\n };\n\n var vendors = Object.keys(vendorMap);\n\n var transitionEnd = void 0,\n animationEnd = void 0;\n var prefix = '';\n\n for (var i = 0; i < vendors.length; i++) {\n var vendor = vendors[i];\n\n if (vendor + 'TransitionProperty' in style) {\n prefix = '-' + vendor.toLowerCase();\n transitionEnd = vendorMap[vendor]('TransitionEnd');\n animationEnd = vendorMap[vendor]('AnimationEnd');\n break;\n }\n }\n\n if (!transitionEnd && 'transitionProperty' in style) transitionEnd = 'transitionend';\n\n if (!animationEnd && 'animationName' in style) animationEnd = 'animationend';\n\n style = null;\n\n return { animationEnd: animationEnd, transitionEnd: transitionEnd, prefix: prefix };\n}\n\n/***/ }),\n\n/***/ 470:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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__config_wagtailConfig__ = __webpack_require__(17);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_Button_Button__ = __webpack_require__(72);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_Icon_Icon__ = __webpack_require__(46);\n\n\n\n\n\n\n\n/**\n * The bar at the top of the explorer, displaying the current level\n * and allowing access back to the parent level.\n */\nvar ExplorerHeader = function ExplorerHeader(_ref) {\n var page = _ref.page,\n depth = _ref.depth,\n onClick = _ref.onClick;\n\n var isRoot = depth === 1;\n\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_2__components_Button_Button__[\"a\" /* default */],\n {\n href: page.id ? '' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"b\" /* ADMIN_URLS */].PAGES + page.id + '/' : __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"b\" /* ADMIN_URLS */].PAGES,\n className: 'c-explorer__header',\n onClick: onClick\n },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { className: 'c-explorer__header__inner' },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_3__components_Icon_Icon__[\"a\" /* default */], { name: isRoot ? 'home' : 'arrow-left' }),\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'span',\n null,\n page.admin_display_title || __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].PAGES\n )\n )\n );\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (ExplorerHeader);\n\n/***/ }),\n\n/***/ 471:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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__config_wagtailConfig__ = __webpack_require__(17);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__ = __webpack_require__(46);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_Button_Button__ = __webpack_require__(72);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__components_PublicationStatus_PublicationStatus__ = __webpack_require__(185);\n\n\n\n\n\n\n\n\n// Hoist icons in the explorer item, as it is re-rendered many times.\nvar childrenIcon = __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__[\"a\" /* default */], { name: 'folder-inverse' });\n\n/**\n * One menu item in the page explorer, with different available actions\n * and information depending on the metadata of the page.\n */\nvar ExplorerItem = function ExplorerItem(_ref) {\n var item = _ref.item,\n onClick = _ref.onClick;\n var id = item.id,\n title = item.admin_display_title,\n meta = item.meta;\n\n var hasChildren = meta.children.count > 0;\n var isPublished = meta.status.live && !meta.status.has_unpublished_changes;\n\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'div',\n { className: 'c-explorer__item' },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_3__components_Button_Button__[\"a\" /* default */],\n { href: '' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"b\" /* ADMIN_URLS */].PAGES + id + '/', className: 'c-explorer__item__link' },\n hasChildren ? childrenIcon : null,\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'h3',\n { className: 'c-explorer__item__title' },\n title\n ),\n !isPublished ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'span',\n { className: 'c-explorer__meta' },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_4__components_PublicationStatus_PublicationStatus__[\"a\" /* default */], { status: meta.status })\n ) : null\n ),\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_3__components_Button_Button__[\"a\" /* default */],\n {\n href: '' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"b\" /* ADMIN_URLS */].PAGES + id + '/edit/',\n className: 'c-explorer__item__action c-explorer__item__action--small'\n },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__[\"a\" /* default */], { name: 'edit', title: __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].EDIT_PAGE.replace('{title}', title) })\n ),\n hasChildren ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_3__components_Button_Button__[\"a\" /* default */],\n {\n className: 'c-explorer__item__action',\n onClick: onClick,\n href: '' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"b\" /* ADMIN_URLS */].PAGES + id + '/'\n },\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_2__components_Icon_Icon__[\"a\" /* default */], { name: 'arrow-right', title: __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].VIEW_CHILD_PAGES_OF_PAGE.replace('{title}', title) })\n ) : null\n );\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (ExplorerItem);\n\n/***/ }),\n\n/***/ 472:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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__config_wagtailConfig__ = __webpack_require__(17);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__Icon_Icon__ = __webpack_require__(46);\n\n\n\n\n\n\nvar PageCount = function PageCount(_ref) {\n var page = _ref.page;\n\n var count = page.children.count;\n\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'a',\n {\n href: '' + __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"b\" /* ADMIN_URLS */].PAGES + page.id + '/',\n className: 'c-explorer__see-more'\n },\n __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].SEE_ALL,\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'span',\n null,\n ' ' + count + ' ' + (count === 1 ? __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].PAGE.toLowerCase() : __WEBPACK_IMPORTED_MODULE_1__config_wagtailConfig__[\"e\" /* STRINGS */].PAGES.toLowerCase())\n ),\n __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_2__Icon_Icon__[\"a\" /* default */], { name: 'arrow-right' })\n );\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (PageCount);\n\n/***/ }),\n\n/***/ 473:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\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_react_redux__ = __webpack_require__(122);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__actions__ = __webpack_require__(180);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_Button_Button__ = __webpack_require__(72);\n\n\n\n\n\n\n\n\n/**\n * A Button which toggles the explorer.\n */\nvar ExplorerToggle = function ExplorerToggle(_ref) {\n var children = _ref.children,\n onToggle = _ref.onToggle;\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n __WEBPACK_IMPORTED_MODULE_3__components_Button_Button__[\"a\" /* default */],\n {\n className: 'submenu-trigger',\n icon: 'folder-open-inverse',\n dialogTrigger: true,\n onClick: onToggle\n },\n children\n );\n};\n\nvar mapStateToProps = function mapStateToProps() {\n return {};\n};\n\nvar mapDispatchToProps = function mapDispatchToProps(dispatch) {\n return {\n onToggle: function onToggle(page) {\n return dispatch(__WEBPACK_IMPORTED_MODULE_2__actions__[\"d\" /* toggleExplorer */](page));\n }\n };\n};\n\nvar mergeProps = function mergeProps(stateProps, dispatchProps, ownProps) {\n return {\n children: ownProps.children,\n onToggle: dispatchProps.onToggle.bind(null, ownProps.startPage)\n };\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Object(__WEBPACK_IMPORTED_MODULE_1_react_redux__[\"b\" /* connect */])(mapStateToProps, mapDispatchToProps, mergeProps)(ExplorerToggle));\n\n/***/ }),\n\n/***/ 474:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = explorer;\nvar defaultState = {\n isVisible: false,\n path: []\n};\n\n/**\n * Oversees the state of the explorer. Defines:\n * - Where in the page tree the explorer is at.\n * - Whether the explorer is open or not.\n */\nfunction explorer() {\n var prevState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultState;\n var _ref = arguments[1];\n var type = _ref.type,\n payload = _ref.payload;\n\n switch (type) {\n case 'OPEN_EXPLORER':\n // Provide a starting page when opening the explorer.\n return {\n isVisible: true,\n path: [payload.id]\n };\n\n case 'CLOSE_EXPLORER':\n return defaultState;\n\n case 'PUSH_PAGE':\n return {\n isVisible: prevState.isVisible,\n path: prevState.path.concat([payload.id])\n };\n\n case 'POP_PAGE':\n return {\n isVisible: prevState.isVisible,\n path: prevState.path.slice(0, -1)\n };\n\n default:\n return prevState;\n }\n}\n\n/***/ }),\n\n/***/ 475:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = nodes;\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar defaultPageState = {\n isFetching: false,\n isError: false,\n children: {\n items: [],\n count: 0\n },\n meta: {\n children: {}\n }\n};\n\n/**\n * A single page node in the explorer.\n */\nvar node = function node() {\n var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultPageState;\n var _ref = arguments[1];\n var type = _ref.type,\n payload = _ref.payload;\n\n switch (type) {\n case 'OPEN_EXPLORER':\n return state || defaultPageState;\n\n case 'GET_PAGE_SUCCESS':\n return Object.assign({}, state, payload.data, {\n isError: false\n });\n\n case 'GET_CHILDREN_START':\n return Object.assign({}, state, {\n isFetching: true\n });\n\n case 'GET_CHILDREN_SUCCESS':\n return Object.assign({}, state, {\n isFetching: false,\n isError: false,\n children: {\n items: state.children.items.slice().concat(payload.items.map(function (item) {\n return item.id;\n })),\n count: payload.meta.total_count\n }\n });\n\n case 'GET_PAGE_FAILURE':\n case 'GET_CHILDREN_FAILURE':\n return Object.assign({}, state, {\n isFetching: false,\n isError: true\n });\n\n default:\n return state;\n }\n};\n\nvar defaultState = {};\n\n/**\n * Contains all of the page nodes in one object.\n */\nfunction nodes() {\n var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultState;\n var _ref2 = arguments[1];\n var type = _ref2.type,\n payload = _ref2.payload;\n\n switch (type) {\n case 'OPEN_EXPLORER':\n case 'GET_PAGE_SUCCESS':\n case 'GET_CHILDREN_START':\n case 'GET_PAGE_FAILURE':\n case 'GET_CHILDREN_FAILURE':\n return Object.assign({}, state, _defineProperty({}, payload.id, node(state[payload.id], { type: type, payload: payload })));\n\n // eslint-disable-next-line no-case-declarations\n case 'GET_CHILDREN_SUCCESS':\n var newState = Object.assign({}, state, _defineProperty({}, payload.id, node(state[payload.id], { type: type, payload: payload })));\n\n payload.items.forEach(function (item) {\n newState[item.id] = Object.assign({}, defaultPageState, item);\n });\n\n return newState;\n\n default:\n return state;\n }\n}\n\n/***/ }),\n\n/***/ 476:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return initFocusOutline; });\nvar OUTLINE_ON = 'focus-outline-on';\nvar OUTLINE_OFF = 'focus-outline-off';\n\nvar toggleFocusOutline = function toggleFocusOutline(isOn) {\n document.body.classList.toggle(OUTLINE_OFF, !isOn);\n document.body.classList.toggle(OUTLINE_ON, isOn);\n};\n\nvar removeFocusOutline = toggleFocusOutline.bind(null, false);\nvar addFocusOutline = toggleFocusOutline.bind(null, true);\n\n/**\n * Adds a heavy focus outline to the UI, only for users who tab through the page.\n * The outline is not useful with touch or mouse input – these remove the outline.\n */\nvar initFocusOutline = function initFocusOutline() {\n // Focus outline styles are added by default in the HTML, so they work without JS enabled.\n removeFocusOutline();\n\n window.addEventListener('mousedown', removeFocusOutline);\n window.addEventListener('touchstart', removeFocusOutline);\n\n window.addEventListener('keydown', function (e) {\n var isTabKey = e.keyCode === 9;\n\n if (isTabKey) {\n addFocusOutline();\n }\n });\n};\n\n/***/ }),\n\n/***/ 477:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return initSubmenus; });\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\n/**\n * Initialises the Submenus within the primary Wagtail menu (excluding the Explorer menu)\n */\n\nvar initSubmenus = function initSubmenus() {\n var primaryNavContainer = document.querySelector('[data-nav-primary]');\n\n if (!primaryNavContainer) {\n return;\n }\n\n var subMenuTriggers = document.querySelectorAll('[data-nav-primary-submenu-trigger]');\n var activeClass = 'submenu-active';\n\n [].concat(_toConsumableArray(subMenuTriggers)).forEach(function (subMenuTrigger) {\n subMenuTrigger.addEventListener('click', function (clickEvent) {\n var submenuContainer = subMenuTrigger.parentNode;\n\n primaryNavContainer.classList.remove(activeClass);\n [].concat(_toConsumableArray(subMenuTriggers)).forEach(function (sm) {\n return sm.classList.remove(activeClass);\n });\n\n primaryNavContainer.classList.toggle(activeClass);\n submenuContainer.classList.toggle(activeClass);\n\n document.addEventListener('mousedown', function (e) {\n if (!submenuContainer.contains(e.target) && subMenuTrigger !== e.target) {\n primaryNavContainer.classList.remove(activeClass);\n submenuContainer.classList.remove(activeClass);\n }\n });\n\n document.addEventListener('keydown', function (e) {\n // IE11 uses \"Esc\" instead of \"Escape\"\n if (e.key === 'Escape' || e.key === 'Esc') {\n primaryNavContainer.classList.remove(activeClass);\n submenuContainer.classList.remove(activeClass);\n }\n });\n\n clickEvent.preventDefault();\n });\n });\n};\n\n\n\n/***/ }),\n\n/***/ 478:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return initUpgradeNotification; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils_version__ = __webpack_require__(479);\n\n\nvar initUpgradeNotification = function initUpgradeNotification() {\n var container = document.querySelector('[data-upgrade]');\n\n if (!container) {\n return;\n }\n\n /*\n * Expected JSON payload:\n * {\n * \"version\" : \"1.2.3\", // Version number. Can only contain numbers and decimal point.\n * \"url\" : \"https://wagtail.io\" // Absolute URL to page/file containing release notes or actual package. It's up to you.\n * }\n */\n var releasesUrl = 'https://releases.wagtail.io/latest.txt';\n var currentVersion = container.dataset.wagtailVersion;\n\n fetch(releasesUrl).then(function (response) {\n if (response.status !== 200) {\n // eslint-disable-next-line no-console\n console.log('Unexpected response from ' + releasesUrl + '. Status: ' + response.status);\n return false;\n }\n return response.json();\n }).then(function (data) {\n if (data && data.version && Object(__WEBPACK_IMPORTED_MODULE_0__utils_version__[\"a\" /* versionOutOfDate */])(data.version, currentVersion)) {\n container.querySelector('[data-upgrade-version]').innerText = data.version;\n container.querySelector('[data-upgrade-link]').setAttribute('href', data.url);\n container.style.display = '';\n }\n }).catch(function (err) {\n // eslint-disable-next-line no-console\n console.log('Error fetching ' + releasesUrl + '. Error: ' + err);\n });\n};\n\n\n\n/***/ }),\n\n/***/ 479:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* unused harmony export compareVersion */\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"a\", function() { return versionOutOfDate; });\nfunction compareVersion(versionA, versionB) {\n var re = /(\\.0)+[^.]*$/;\n var va = (versionA + '').replace(re, '').split('.');\n var vb = (versionB + '').replace(re, '').split('.');\n var len = Math.min(va.length, vb.length);\n for (var i = 0; i < len; i++) {\n var cmp = parseInt(va[i], 10) - parseInt(vb[i], 10);\n if (cmp !== 0) {\n return cmp;\n }\n }\n\n return va.length - vb.length;\n}\n\nfunction versionOutOfDate(latestVersion, currentVersion) {\n return compareVersion(latestVersion, currentVersion) > 0;\n}\n\n\n\n/***/ }),\n\n/***/ 72:\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n\n\n\nvar getClassName = function getClassName(className, icon) {\n var hasIcon = icon !== '';\n var iconName = '';\n if (hasIcon) {\n if (typeof icon === 'string') {\n iconName = ' icon-' + icon;\n } else {\n iconName = icon.map(function (val) {\n return ' icon-' + val;\n }).join('');\n }\n }\n return className + ' ' + (hasIcon ? 'icon' : '') + iconName;\n};\n\nvar handleClick = function handleClick(href, onClick, preventDefault, e) {\n if (preventDefault && href === '#') {\n e.preventDefault();\n e.stopPropagation();\n }\n\n if (onClick) {\n onClick(e);\n }\n};\n\n/**\n * A reusable button. Uses a tag underneath.\n */\nvar Button = function Button(_ref) {\n var className = _ref.className,\n icon = _ref.icon,\n children = _ref.children,\n accessibleLabel = _ref.accessibleLabel,\n isLoading = _ref.isLoading,\n href = _ref.href,\n target = _ref.target,\n preventDefault = _ref.preventDefault,\n onClick = _ref.onClick,\n dialogTrigger = _ref.dialogTrigger;\n\n var hasText = children !== null;\n var iconName = isLoading ? 'spinner' : icon;\n var accessibleElt = accessibleLabel ? __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'span',\n { className: 'visuallyhidden' },\n accessibleLabel\n ) : null;\n\n return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\n 'a',\n {\n className: getClassName(className, iconName),\n onClick: handleClick.bind(null, href, onClick, preventDefault),\n rel: target === '_blank' ? 'noopener noreferrer' : null,\n href: href,\n target: target,\n 'aria-haspopup': dialogTrigger ? 'dialog' : null\n },\n hasText ? children : accessibleElt\n );\n};\n\nButton.defaultProps = {\n href: '#',\n className: '',\n icon: '',\n target: null,\n children: null,\n accessibleLabel: null,\n onClick: null,\n isLoading: false,\n preventDefault: true,\n dialogTrigger: false\n};\n\n/* harmony default export */ __webpack_exports__[\"a\"] = (Button);\n\n/***/ })\n\n},[414]);\n\n\n// WEBPACK FOOTER //\n// wagtail/admin/static/wagtailadmin/js/wagtailadmin.js","/**\n * Prints a warning in the console if it exists.\n *\n * @param {String} message The warning message.\n * @returns {void}\n */\nexport default function warning(message) {\n /* eslint-disable no-console */\n if (typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error(message);\n }\n /* eslint-enable no-console */\n try {\n // This error was thrown as a convenience so that if you enable\n // \"break on all exceptions\" in your console,\n // it would pause the execution at this line.\n throw new Error(message);\n /* eslint-disable no-empty */\n } catch (e) {}\n /* eslint-enable no-empty */\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/utils/warning.js\n// module id = 123\n// module chunks = 1","import PropTypes from 'prop-types';\n\nexport var subscriptionShape = PropTypes.shape({\n trySubscribe: PropTypes.func.isRequired,\n tryUnsubscribe: PropTypes.func.isRequired,\n notifyNestedSubs: PropTypes.func.isRequired,\n isSubscribed: PropTypes.func.isRequired\n});\n\nexport var storeShape = PropTypes.shape({\n subscribe: PropTypes.func.isRequired,\n dispatch: PropTypes.func.isRequired,\n getState: PropTypes.func.isRequired\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/utils/PropTypes.js\n// module id = 174\n// module chunks = 1","var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nimport hoistStatics from 'hoist-non-react-statics';\nimport invariant from 'invariant';\nimport { Component, createElement } from 'react';\n\nimport Subscription from '../utils/Subscription';\nimport { storeShape, subscriptionShape } from '../utils/PropTypes';\n\nvar hotReloadingVersion = 0;\nvar dummyState = {};\nfunction noop() {}\nfunction makeSelectorStateful(sourceSelector, store) {\n // wrap the selector in an object that tracks its results between runs.\n var selector = {\n run: function runComponentSelector(props) {\n try {\n var nextProps = sourceSelector(store.getState(), props);\n if (nextProps !== selector.props || selector.error) {\n selector.shouldComponentUpdate = true;\n selector.props = nextProps;\n selector.error = null;\n }\n } catch (error) {\n selector.shouldComponentUpdate = true;\n selector.error = error;\n }\n }\n };\n\n return selector;\n}\n\nexport default function connectAdvanced(\n/*\n selectorFactory is a func that is responsible for returning the selector function used to\n compute new props from state, props, and dispatch. For example:\n export default connectAdvanced((dispatch, options) => (state, props) => ({\n thing: state.things[props.thingId],\n saveThing: fields => dispatch(actionCreators.saveThing(props.thingId, fields)),\n }))(YourComponent)\n Access to dispatch is provided to the factory so selectorFactories can bind actionCreators\n outside of their selector as an optimization. Options passed to connectAdvanced are passed to\n the selectorFactory, along with displayName and WrappedComponent, as the second argument.\n Note that selectorFactory is responsible for all caching/memoization of inbound and outbound\n props. Do not use connectAdvanced directly without memoizing results between calls to your\n selector, otherwise the Connect component will re-render on every state or props change.\n*/\nselectorFactory) {\n var _contextTypes, _childContextTypes;\n\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$getDisplayName = _ref.getDisplayName,\n getDisplayName = _ref$getDisplayName === undefined ? function (name) {\n return 'ConnectAdvanced(' + name + ')';\n } : _ref$getDisplayName,\n _ref$methodName = _ref.methodName,\n methodName = _ref$methodName === undefined ? 'connectAdvanced' : _ref$methodName,\n _ref$renderCountProp = _ref.renderCountProp,\n renderCountProp = _ref$renderCountProp === undefined ? undefined : _ref$renderCountProp,\n _ref$shouldHandleStat = _ref.shouldHandleStateChanges,\n shouldHandleStateChanges = _ref$shouldHandleStat === undefined ? true : _ref$shouldHandleStat,\n _ref$storeKey = _ref.storeKey,\n storeKey = _ref$storeKey === undefined ? 'store' : _ref$storeKey,\n _ref$withRef = _ref.withRef,\n withRef = _ref$withRef === undefined ? false : _ref$withRef,\n connectOptions = _objectWithoutProperties(_ref, ['getDisplayName', 'methodName', 'renderCountProp', 'shouldHandleStateChanges', 'storeKey', 'withRef']);\n\n var subscriptionKey = storeKey + 'Subscription';\n var version = hotReloadingVersion++;\n\n var contextTypes = (_contextTypes = {}, _contextTypes[storeKey] = storeShape, _contextTypes[subscriptionKey] = subscriptionShape, _contextTypes);\n var childContextTypes = (_childContextTypes = {}, _childContextTypes[subscriptionKey] = subscriptionShape, _childContextTypes);\n\n return function wrapWithConnect(WrappedComponent) {\n invariant(typeof WrappedComponent == 'function', 'You must pass a component to the function returned by ' + ('connect. Instead received ' + JSON.stringify(WrappedComponent)));\n\n var wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n\n var displayName = getDisplayName(wrappedComponentName);\n\n var selectorFactoryOptions = _extends({}, connectOptions, {\n getDisplayName: getDisplayName,\n methodName: methodName,\n renderCountProp: renderCountProp,\n shouldHandleStateChanges: shouldHandleStateChanges,\n storeKey: storeKey,\n withRef: withRef,\n displayName: displayName,\n wrappedComponentName: wrappedComponentName,\n WrappedComponent: WrappedComponent\n });\n\n var Connect = function (_Component) {\n _inherits(Connect, _Component);\n\n function Connect(props, context) {\n _classCallCheck(this, Connect);\n\n var _this = _possibleConstructorReturn(this, _Component.call(this, props, context));\n\n _this.version = version;\n _this.state = {};\n _this.renderCount = 0;\n _this.store = props[storeKey] || context[storeKey];\n _this.propsMode = Boolean(props[storeKey]);\n _this.setWrappedInstance = _this.setWrappedInstance.bind(_this);\n\n invariant(_this.store, 'Could not find \"' + storeKey + '\" in either the context or props of ' + ('\"' + displayName + '\". Either wrap the root component in a , ') + ('or explicitly pass \"' + storeKey + '\" as a prop to \"' + displayName + '\".'));\n\n _this.initSelector();\n _this.initSubscription();\n return _this;\n }\n\n Connect.prototype.getChildContext = function getChildContext() {\n var _ref2;\n\n // If this component received store from props, its subscription should be transparent\n // to any descendants receiving store+subscription from context; it passes along\n // subscription passed to it. Otherwise, it shadows the parent subscription, which allows\n // Connect to control ordering of notifications to flow top-down.\n var subscription = this.propsMode ? null : this.subscription;\n return _ref2 = {}, _ref2[subscriptionKey] = subscription || this.context[subscriptionKey], _ref2;\n };\n\n Connect.prototype.componentDidMount = function componentDidMount() {\n if (!shouldHandleStateChanges) return;\n\n // componentWillMount fires during server side rendering, but componentDidMount and\n // componentWillUnmount do not. Because of this, trySubscribe happens during ...didMount.\n // Otherwise, unsubscription would never take place during SSR, causing a memory leak.\n // To handle the case where a child component may have triggered a state change by\n // dispatching an action in its componentWillMount, we have to re-run the select and maybe\n // re-render.\n this.subscription.trySubscribe();\n this.selector.run(this.props);\n if (this.selector.shouldComponentUpdate) this.forceUpdate();\n };\n\n Connect.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n this.selector.run(nextProps);\n };\n\n Connect.prototype.shouldComponentUpdate = function shouldComponentUpdate() {\n return this.selector.shouldComponentUpdate;\n };\n\n Connect.prototype.componentWillUnmount = function componentWillUnmount() {\n if (this.subscription) this.subscription.tryUnsubscribe();\n this.subscription = null;\n this.notifyNestedSubs = noop;\n this.store = null;\n this.selector.run = noop;\n this.selector.shouldComponentUpdate = false;\n };\n\n Connect.prototype.getWrappedInstance = function getWrappedInstance() {\n invariant(withRef, 'To access the wrapped instance, you need to specify ' + ('{ withRef: true } in the options argument of the ' + methodName + '() call.'));\n return this.wrappedInstance;\n };\n\n Connect.prototype.setWrappedInstance = function setWrappedInstance(ref) {\n this.wrappedInstance = ref;\n };\n\n Connect.prototype.initSelector = function initSelector() {\n var sourceSelector = selectorFactory(this.store.dispatch, selectorFactoryOptions);\n this.selector = makeSelectorStateful(sourceSelector, this.store);\n this.selector.run(this.props);\n };\n\n Connect.prototype.initSubscription = function initSubscription() {\n if (!shouldHandleStateChanges) return;\n\n // parentSub's source should match where store came from: props vs. context. A component\n // connected to the store via props shouldn't use subscription from context, or vice versa.\n var parentSub = (this.propsMode ? this.props : this.context)[subscriptionKey];\n this.subscription = new Subscription(this.store, parentSub, this.onStateChange.bind(this));\n\n // `notifyNestedSubs` is duplicated to handle the case where the component is unmounted in\n // the middle of the notification loop, where `this.subscription` will then be null. An\n // extra null check every change can be avoided by copying the method onto `this` and then\n // replacing it with a no-op on unmount. This can probably be avoided if Subscription's\n // listeners logic is changed to not call listeners that have been unsubscribed in the\n // middle of the notification loop.\n this.notifyNestedSubs = this.subscription.notifyNestedSubs.bind(this.subscription);\n };\n\n Connect.prototype.onStateChange = function onStateChange() {\n this.selector.run(this.props);\n\n if (!this.selector.shouldComponentUpdate) {\n this.notifyNestedSubs();\n } else {\n this.componentDidUpdate = this.notifyNestedSubsOnComponentDidUpdate;\n this.setState(dummyState);\n }\n };\n\n Connect.prototype.notifyNestedSubsOnComponentDidUpdate = function notifyNestedSubsOnComponentDidUpdate() {\n // `componentDidUpdate` is conditionally implemented when `onStateChange` determines it\n // needs to notify nested subs. Once called, it unimplements itself until further state\n // changes occur. Doing it this way vs having a permanent `componentDidUpdate` that does\n // a boolean check every time avoids an extra method call most of the time, resulting\n // in some perf boost.\n this.componentDidUpdate = undefined;\n this.notifyNestedSubs();\n };\n\n Connect.prototype.isSubscribed = function isSubscribed() {\n return Boolean(this.subscription) && this.subscription.isSubscribed();\n };\n\n Connect.prototype.addExtraProps = function addExtraProps(props) {\n if (!withRef && !renderCountProp && !(this.propsMode && this.subscription)) return props;\n // make a shallow copy so that fields added don't leak to the original selector.\n // this is especially important for 'ref' since that's a reference back to the component\n // instance. a singleton memoized selector would then be holding a reference to the\n // instance, preventing the instance from being garbage collected, and that would be bad\n var withExtras = _extends({}, props);\n if (withRef) withExtras.ref = this.setWrappedInstance;\n if (renderCountProp) withExtras[renderCountProp] = this.renderCount++;\n if (this.propsMode && this.subscription) withExtras[subscriptionKey] = this.subscription;\n return withExtras;\n };\n\n Connect.prototype.render = function render() {\n var selector = this.selector;\n selector.shouldComponentUpdate = false;\n\n if (selector.error) {\n throw selector.error;\n } else {\n return createElement(WrappedComponent, this.addExtraProps(selector.props));\n }\n };\n\n return Connect;\n }(Component);\n\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = displayName;\n Connect.childContextTypes = childContextTypes;\n Connect.contextTypes = contextTypes;\n Connect.propTypes = contextTypes;\n\n if (process.env.NODE_ENV !== 'production') {\n Connect.prototype.componentWillUpdate = function componentWillUpdate() {\n var _this2 = this;\n\n // We are hot reloading!\n if (this.version !== version) {\n this.version = version;\n this.initSelector();\n\n // If any connected descendants don't hot reload (and resubscribe in the process), their\n // listeners will be lost when we unsubscribe. Unfortunately, by copying over all\n // listeners, this does mean that the old versions of connected descendants will still be\n // notified of state changes; however, their onStateChange function is a no-op so this\n // isn't a huge deal.\n var oldListeners = [];\n\n if (this.subscription) {\n oldListeners = this.subscription.listeners.get();\n this.subscription.tryUnsubscribe();\n }\n this.initSubscription();\n if (shouldHandleStateChanges) {\n this.subscription.trySubscribe();\n oldListeners.forEach(function (listener) {\n return _this2.subscription.listeners.subscribe(listener);\n });\n }\n }\n };\n }\n\n return hoistStatics(Connect, WrappedComponent);\n };\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/components/connectAdvanced.js\n// module id = 175\n// module chunks = 1","import $$observable from 'symbol-observable';\n\n/**\n * These are private action types reserved by Redux.\n * For any unknown actions, you must return the current state.\n * If the current state is undefined, you must return the initial state.\n * Do not reference these action types directly in your code.\n */\nvar randomString = function randomString() {\n return Math.random().toString(36).substring(7).split('').join('.');\n};\n\nvar ActionTypes = {\n INIT: \"@@redux/INIT\" + randomString(),\n REPLACE: \"@@redux/REPLACE\" + randomString(),\n PROBE_UNKNOWN_ACTION: function PROBE_UNKNOWN_ACTION() {\n return \"@@redux/PROBE_UNKNOWN_ACTION\" + randomString();\n }\n};\n\n/**\n * @param {any} obj The object to inspect.\n * @returns {boolean} True if the argument appears to be a plain object.\n */\nfunction isPlainObject(obj) {\n if (typeof obj !== 'object' || obj === null) return false;\n var proto = obj;\n\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n\n return Object.getPrototypeOf(obj) === proto;\n}\n\n/**\n * Creates a Redux store that holds the state tree.\n * The only way to change the data in the store is to call `dispatch()` on it.\n *\n * There should only be a single store in your app. To specify how different\n * parts of the state tree respond to actions, you may combine several reducers\n * into a single reducer function by using `combineReducers`.\n *\n * @param {Function} reducer A function that returns the next state tree, given\n * the current state tree and the action to handle.\n *\n * @param {any} [preloadedState] The initial state. You may optionally specify it\n * to hydrate the state from the server in universal apps, or to restore a\n * previously serialized user session.\n * If you use `combineReducers` to produce the root reducer function, this must be\n * an object with the same shape as `combineReducers` keys.\n *\n * @param {Function} [enhancer] The store enhancer. You may optionally specify it\n * to enhance the store with third-party capabilities such as middleware,\n * time travel, persistence, etc. The only store enhancer that ships with Redux\n * is `applyMiddleware()`.\n *\n * @returns {Store} A Redux store that lets you read the state, dispatch actions\n * and subscribe to changes.\n */\n\nfunction createStore(reducer, preloadedState, enhancer) {\n var _ref2;\n\n if (typeof preloadedState === 'function' && typeof enhancer === 'function' || typeof enhancer === 'function' && typeof arguments[3] === 'function') {\n throw new Error('It looks like you are passing several store enhancers to ' + 'createStore(). This is not supported. Instead, compose them ' + 'together to a single function');\n }\n\n if (typeof preloadedState === 'function' && typeof enhancer === 'undefined') {\n enhancer = preloadedState;\n preloadedState = undefined;\n }\n\n if (typeof enhancer !== 'undefined') {\n if (typeof enhancer !== 'function') {\n throw new Error('Expected the enhancer to be a function.');\n }\n\n return enhancer(createStore)(reducer, preloadedState);\n }\n\n if (typeof reducer !== 'function') {\n throw new Error('Expected the reducer to be a function.');\n }\n\n var currentReducer = reducer;\n var currentState = preloadedState;\n var currentListeners = [];\n var nextListeners = currentListeners;\n var isDispatching = false;\n\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = currentListeners.slice();\n }\n }\n /**\n * Reads the state tree managed by the store.\n *\n * @returns {any} The current state tree of your application.\n */\n\n\n function getState() {\n if (isDispatching) {\n throw new Error('You may not call store.getState() while the reducer is executing. ' + 'The reducer has already received the state as an argument. ' + 'Pass it down from the top reducer instead of reading it from the store.');\n }\n\n return currentState;\n }\n /**\n * Adds a change listener. It will be called any time an action is dispatched,\n * and some part of the state tree may potentially have changed. You may then\n * call `getState()` to read the current state tree inside the callback.\n *\n * You may call `dispatch()` from a change listener, with the following\n * caveats:\n *\n * 1. The subscriptions are snapshotted just before every `dispatch()` call.\n * If you subscribe or unsubscribe while the listeners are being invoked, this\n * will not have any effect on the `dispatch()` that is currently in progress.\n * However, the next `dispatch()` call, whether nested or not, will use a more\n * recent snapshot of the subscription list.\n *\n * 2. The listener should not expect to see all state changes, as the state\n * might have been updated multiple times during a nested `dispatch()` before\n * the listener is called. It is, however, guaranteed that all subscribers\n * registered before the `dispatch()` started will be called with the latest\n * state by the time it exits.\n *\n * @param {Function} listener A callback to be invoked on every dispatch.\n * @returns {Function} A function to remove this change listener.\n */\n\n\n function subscribe(listener) {\n if (typeof listener !== 'function') {\n throw new Error('Expected the listener to be a function.');\n }\n\n if (isDispatching) {\n throw new Error('You may not call store.subscribe() while the reducer is executing. ' + 'If you would like to be notified after the store has been updated, subscribe from a ' + 'component and invoke store.getState() in the callback to access the latest state. ' + 'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');\n }\n\n var isSubscribed = true;\n ensureCanMutateNextListeners();\n nextListeners.push(listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n\n if (isDispatching) {\n throw new Error('You may not unsubscribe from a store listener while the reducer is executing. ' + 'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');\n }\n\n isSubscribed = false;\n ensureCanMutateNextListeners();\n var index = nextListeners.indexOf(listener);\n nextListeners.splice(index, 1);\n };\n }\n /**\n * Dispatches an action. It is the only way to trigger a state change.\n *\n * The `reducer` function, used to create the store, will be called with the\n * current state tree and the given `action`. Its return value will\n * be considered the **next** state of the tree, and the change listeners\n * will be notified.\n *\n * The base implementation only supports plain object actions. If you want to\n * dispatch a Promise, an Observable, a thunk, or something else, you need to\n * wrap your store creating function into the corresponding middleware. For\n * example, see the documentation for the `redux-thunk` package. Even the\n * middleware will eventually dispatch plain object actions using this method.\n *\n * @param {Object} action A plain object representing “what changed”. It is\n * a good idea to keep actions serializable so you can record and replay user\n * sessions, or use the time travelling `redux-devtools`. An action must have\n * a `type` property which may not be `undefined`. It is a good idea to use\n * string constants for action types.\n *\n * @returns {Object} For convenience, the same action object you dispatched.\n *\n * Note that, if you use a custom middleware, it may wrap `dispatch()` to\n * return something else (for example, a Promise you can await).\n */\n\n\n function dispatch(action) {\n if (!isPlainObject(action)) {\n throw new Error('Actions must be plain objects. ' + 'Use custom middleware for async actions.');\n }\n\n if (typeof action.type === 'undefined') {\n throw new Error('Actions may not have an undefined \"type\" property. ' + 'Have you misspelled a constant?');\n }\n\n if (isDispatching) {\n throw new Error('Reducers may not dispatch actions.');\n }\n\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n\n var listeners = currentListeners = nextListeners;\n\n for (var i = 0; i < listeners.length; i++) {\n var listener = listeners[i];\n listener();\n }\n\n return action;\n }\n /**\n * Replaces the reducer currently used by the store to calculate the state.\n *\n * You might need this if your app implements code splitting and you want to\n * load some of the reducers dynamically. You might also need this if you\n * implement a hot reloading mechanism for Redux.\n *\n * @param {Function} nextReducer The reducer for the store to use instead.\n * @returns {void}\n */\n\n\n function replaceReducer(nextReducer) {\n if (typeof nextReducer !== 'function') {\n throw new Error('Expected the nextReducer to be a function.');\n }\n\n currentReducer = nextReducer;\n dispatch({\n type: ActionTypes.REPLACE\n });\n }\n /**\n * Interoperability point for observable/reactive libraries.\n * @returns {observable} A minimal observable of state changes.\n * For more information, see the observable proposal:\n * https://github.com/tc39/proposal-observable\n */\n\n\n function observable() {\n var _ref;\n\n var outerSubscribe = subscribe;\n return _ref = {\n /**\n * The minimal observable subscription method.\n * @param {Object} observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns {subscription} An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe: function subscribe(observer) {\n if (typeof observer !== 'object' || observer === null) {\n throw new TypeError('Expected the observer to be an object.');\n }\n\n function observeState() {\n if (observer.next) {\n observer.next(getState());\n }\n }\n\n observeState();\n var unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe: unsubscribe\n };\n }\n }, _ref[$$observable] = function () {\n return this;\n }, _ref;\n } // When a store is created, an \"INIT\" action is dispatched so that every\n // reducer returns their initial state. This effectively populates\n // the initial state tree.\n\n\n dispatch({\n type: ActionTypes.INIT\n });\n return _ref2 = {\n dispatch: dispatch,\n subscribe: subscribe,\n getState: getState,\n replaceReducer: replaceReducer\n }, _ref2[$$observable] = observable, _ref2;\n}\n\n/**\n * Prints a warning in the console if it exists.\n *\n * @param {String} message The warning message.\n * @returns {void}\n */\nfunction warning(message) {\n /* eslint-disable no-console */\n if (typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error(message);\n }\n /* eslint-enable no-console */\n\n\n try {\n // This error was thrown as a convenience so that if you enable\n // \"break on all exceptions\" in your console,\n // it would pause the execution at this line.\n throw new Error(message);\n } catch (e) {} // eslint-disable-line no-empty\n\n}\n\nfunction getUndefinedStateErrorMessage(key, action) {\n var actionType = action && action.type;\n var actionDescription = actionType && \"action \\\"\" + String(actionType) + \"\\\"\" || 'an action';\n return \"Given \" + actionDescription + \", reducer \\\"\" + key + \"\\\" returned undefined. \" + \"To ignore an action, you must explicitly return the previous state. \" + \"If you want this reducer to hold no value, you can return null instead of undefined.\";\n}\n\nfunction getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) {\n var reducerKeys = Object.keys(reducers);\n var argumentName = action && action.type === ActionTypes.INIT ? 'preloadedState argument passed to createStore' : 'previous state received by the reducer';\n\n if (reducerKeys.length === 0) {\n return 'Store does not have a valid reducer. Make sure the argument passed ' + 'to combineReducers is an object whose values are reducers.';\n }\n\n if (!isPlainObject(inputState)) {\n return \"The \" + argumentName + \" has unexpected type of \\\"\" + {}.toString.call(inputState).match(/\\s([a-z|A-Z]+)/)[1] + \"\\\". Expected argument to be an object with the following \" + (\"keys: \\\"\" + reducerKeys.join('\", \"') + \"\\\"\");\n }\n\n var unexpectedKeys = Object.keys(inputState).filter(function (key) {\n return !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key];\n });\n unexpectedKeys.forEach(function (key) {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === ActionTypes.REPLACE) return;\n\n if (unexpectedKeys.length > 0) {\n return \"Unexpected \" + (unexpectedKeys.length > 1 ? 'keys' : 'key') + \" \" + (\"\\\"\" + unexpectedKeys.join('\", \"') + \"\\\" found in \" + argumentName + \". \") + \"Expected to find one of the known reducer keys instead: \" + (\"\\\"\" + reducerKeys.join('\", \"') + \"\\\". Unexpected keys will be ignored.\");\n }\n}\n\nfunction assertReducerShape(reducers) {\n Object.keys(reducers).forEach(function (key) {\n var reducer = reducers[key];\n var initialState = reducer(undefined, {\n type: ActionTypes.INIT\n });\n\n if (typeof initialState === 'undefined') {\n throw new Error(\"Reducer \\\"\" + key + \"\\\" returned undefined during initialization. \" + \"If the state passed to the reducer is undefined, you must \" + \"explicitly return the initial state. The initial state may \" + \"not be undefined. If you don't want to set a value for this reducer, \" + \"you can use null instead of undefined.\");\n }\n\n if (typeof reducer(undefined, {\n type: ActionTypes.PROBE_UNKNOWN_ACTION()\n }) === 'undefined') {\n throw new Error(\"Reducer \\\"\" + key + \"\\\" returned undefined when probed with a random type. \" + (\"Don't try to handle \" + ActionTypes.INIT + \" or other actions in \\\"redux/*\\\" \") + \"namespace. They are considered private. Instead, you must return the \" + \"current state for any unknown actions, unless it is undefined, \" + \"in which case you must return the initial state, regardless of the \" + \"action type. The initial state may not be undefined, but can be null.\");\n }\n });\n}\n/**\n * Turns an object whose values are different reducer functions, into a single\n * reducer function. It will call every child reducer, and gather their results\n * into a single state object, whose keys correspond to the keys of the passed\n * reducer functions.\n *\n * @param {Object} reducers An object whose values correspond to different\n * reducer functions that need to be combined into one. One handy way to obtain\n * it is to use ES6 `import * as reducers` syntax. The reducers may never return\n * undefined for any action. Instead, they should return their initial state\n * if the state passed to them was undefined, and the current state for any\n * unrecognized action.\n *\n * @returns {Function} A reducer function that invokes every reducer inside the\n * passed object, and builds a state object with the same shape.\n */\n\n\nfunction combineReducers(reducers) {\n var reducerKeys = Object.keys(reducers);\n var finalReducers = {};\n\n for (var i = 0; i < reducerKeys.length; i++) {\n var key = reducerKeys[i];\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof reducers[key] === 'undefined') {\n warning(\"No reducer provided for key \\\"\" + key + \"\\\"\");\n }\n }\n\n if (typeof reducers[key] === 'function') {\n finalReducers[key] = reducers[key];\n }\n }\n\n var finalReducerKeys = Object.keys(finalReducers);\n var unexpectedKeyCache;\n\n if (process.env.NODE_ENV !== 'production') {\n unexpectedKeyCache = {};\n }\n\n var shapeAssertionError;\n\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n\n return function combination(state, action) {\n if (state === void 0) {\n state = {};\n }\n\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n var warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n\n var hasChanged = false;\n var nextState = {};\n\n for (var _i = 0; _i < finalReducerKeys.length; _i++) {\n var _key = finalReducerKeys[_i];\n var reducer = finalReducers[_key];\n var previousStateForKey = state[_key];\n var nextStateForKey = reducer(previousStateForKey, action);\n\n if (typeof nextStateForKey === 'undefined') {\n var errorMessage = getUndefinedStateErrorMessage(_key, action);\n throw new Error(errorMessage);\n }\n\n nextState[_key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n\n return hasChanged ? nextState : state;\n };\n}\n\nfunction bindActionCreator(actionCreator, dispatch) {\n return function () {\n return dispatch(actionCreator.apply(this, arguments));\n };\n}\n/**\n * Turns an object whose values are action creators, into an object with the\n * same keys, but with every function wrapped into a `dispatch` call so they\n * may be invoked directly. This is just a convenience method, as you can call\n * `store.dispatch(MyActionCreators.doSomething())` yourself just fine.\n *\n * For convenience, you can also pass a single function as the first argument,\n * and get a function in return.\n *\n * @param {Function|Object} actionCreators An object whose values are action\n * creator functions. One handy way to obtain it is to use ES6 `import * as`\n * syntax. You may also pass a single function.\n *\n * @param {Function} dispatch The `dispatch` function available on your Redux\n * store.\n *\n * @returns {Function|Object} The object mimicking the original object, but with\n * every action creator wrapped into the `dispatch` call. If you passed a\n * function as `actionCreators`, the return value will also be a single\n * function.\n */\n\n\nfunction bindActionCreators(actionCreators, dispatch) {\n if (typeof actionCreators === 'function') {\n return bindActionCreator(actionCreators, dispatch);\n }\n\n if (typeof actionCreators !== 'object' || actionCreators === null) {\n throw new Error(\"bindActionCreators expected an object or a function, instead received \" + (actionCreators === null ? 'null' : typeof actionCreators) + \". \" + \"Did you write \\\"import ActionCreators from\\\" instead of \\\"import * as ActionCreators from\\\"?\");\n }\n\n var keys = Object.keys(actionCreators);\n var boundActionCreators = {};\n\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n var actionCreator = actionCreators[key];\n\n if (typeof actionCreator === 'function') {\n boundActionCreators[key] = bindActionCreator(actionCreator, dispatch);\n }\n }\n\n return boundActionCreators;\n}\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nfunction _objectSpread(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n\n if (typeof Object.getOwnPropertySymbols === 'function') {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n\n ownKeys.forEach(function (key) {\n _defineProperty(target, key, source[key]);\n });\n }\n\n return target;\n}\n\n/**\n * Composes single-argument functions from right to left. The rightmost\n * function can take multiple arguments as it provides the signature for\n * the resulting composite function.\n *\n * @param {...Function} funcs The functions to compose.\n * @returns {Function} A function obtained by composing the argument functions\n * from right to left. For example, compose(f, g, h) is identical to doing\n * (...args) => f(g(h(...args))).\n */\nfunction compose() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n if (funcs.length === 0) {\n return function (arg) {\n return arg;\n };\n }\n\n if (funcs.length === 1) {\n return funcs[0];\n }\n\n return funcs.reduce(function (a, b) {\n return function () {\n return a(b.apply(void 0, arguments));\n };\n });\n}\n\n/**\n * Creates a store enhancer that applies middleware to the dispatch method\n * of the Redux store. This is handy for a variety of tasks, such as expressing\n * asynchronous actions in a concise manner, or logging every action payload.\n *\n * See `redux-thunk` package as an example of the Redux middleware.\n *\n * Because middleware is potentially asynchronous, this should be the first\n * store enhancer in the composition chain.\n *\n * Note that each middleware will be given the `dispatch` and `getState` functions\n * as named arguments.\n *\n * @param {...Function} middlewares The middleware chain to be applied.\n * @returns {Function} A store enhancer applying the middleware.\n */\n\nfunction applyMiddleware() {\n for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) {\n middlewares[_key] = arguments[_key];\n }\n\n return function (createStore) {\n return function () {\n var store = createStore.apply(void 0, arguments);\n\n var _dispatch = function dispatch() {\n throw new Error(\"Dispatching while constructing your middleware is not allowed. \" + \"Other middleware would not be applied to this dispatch.\");\n };\n\n var middlewareAPI = {\n getState: store.getState,\n dispatch: function dispatch() {\n return _dispatch.apply(void 0, arguments);\n }\n };\n var chain = middlewares.map(function (middleware) {\n return middleware(middlewareAPI);\n });\n _dispatch = compose.apply(void 0, chain)(store.dispatch);\n return _objectSpread({}, store, {\n dispatch: _dispatch\n });\n };\n };\n}\n\n/*\n * This is a dummy function to check if the function name has been altered by minification.\n * If the function has been minified and NODE_ENV !== 'production', warn the user.\n */\n\nfunction isCrushed() {}\n\nif (process.env.NODE_ENV !== 'production' && typeof isCrushed.name === 'string' && isCrushed.name !== 'isCrushed') {\n warning('You are currently using minified code outside of NODE_ENV === \"production\". ' + 'This means that you are running a slower development build of Redux. ' + 'You can use loose-envify (https://github.com/zertosh/loose-envify) for browserify ' + 'or setting mode to production in webpack (https://webpack.js.org/concepts/mode/) ' + 'to ensure you have the correct code for your production build.');\n}\n\nexport { createStore, combineReducers, bindActionCreators, applyMiddleware, compose, ActionTypes as __DO_NOT_USE__ActionTypes };\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/redux/es/redux.js\n// module id = 176\n// module chunks = 1","import verifyPlainObject from '../utils/verifyPlainObject';\n\nexport function wrapMapToPropsConstant(getConstant) {\n return function initConstantSelector(dispatch, options) {\n var constant = getConstant(dispatch, options);\n\n function constantSelector() {\n return constant;\n }\n constantSelector.dependsOnOwnProps = false;\n return constantSelector;\n };\n}\n\n// dependsOnOwnProps is used by createMapToPropsProxy to determine whether to pass props as args\n// to the mapToProps function being wrapped. It is also used by makePurePropsSelector to determine\n// whether mapToProps needs to be invoked when props have changed.\n// \n// A length of one signals that mapToProps does not depend on props from the parent component.\n// A length of zero is assumed to mean mapToProps is getting args via arguments or ...args and\n// therefore not reporting its length accurately..\nexport function getDependsOnOwnProps(mapToProps) {\n return mapToProps.dependsOnOwnProps !== null && mapToProps.dependsOnOwnProps !== undefined ? Boolean(mapToProps.dependsOnOwnProps) : mapToProps.length !== 1;\n}\n\n// Used by whenMapStateToPropsIsFunction and whenMapDispatchToPropsIsFunction,\n// this function wraps mapToProps in a proxy function which does several things:\n// \n// * Detects whether the mapToProps function being called depends on props, which\n// is used by selectorFactory to decide if it should reinvoke on props changes.\n// \n// * On first call, handles mapToProps if returns another function, and treats that\n// new function as the true mapToProps for subsequent calls.\n// \n// * On first call, verifies the first result is a plain object, in order to warn\n// the developer that their mapToProps function is not returning a valid result.\n// \nexport function wrapMapToPropsFunc(mapToProps, methodName) {\n return function initProxySelector(dispatch, _ref) {\n var displayName = _ref.displayName;\n\n var proxy = function mapToPropsProxy(stateOrDispatch, ownProps) {\n return proxy.dependsOnOwnProps ? proxy.mapToProps(stateOrDispatch, ownProps) : proxy.mapToProps(stateOrDispatch);\n };\n\n // allow detectFactoryAndVerify to get ownProps\n proxy.dependsOnOwnProps = true;\n\n proxy.mapToProps = function detectFactoryAndVerify(stateOrDispatch, ownProps) {\n proxy.mapToProps = mapToProps;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(mapToProps);\n var props = proxy(stateOrDispatch, ownProps);\n\n if (typeof props === 'function') {\n proxy.mapToProps = props;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(props);\n props = proxy(stateOrDispatch, ownProps);\n }\n\n if (process.env.NODE_ENV !== 'production') verifyPlainObject(props, displayName, methodName);\n\n return props;\n };\n\n return proxy;\n };\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/connect/wrapMapToProps.js\n// module id = 177\n// module chunks = 1","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_Symbol.js\n// module id = 179\n// module chunks = 1","import * as admin from '../../api/admin';\nimport { createAction } from '../../utils/actions';\nimport { MAX_EXPLORER_PAGES } from '../../config/wagtailConfig';\n\nconst getPageStart = createAction('GET_PAGE_START');\nconst getPageSuccess = createAction('GET_PAGE_SUCCESS', (id, data) => ({ id, data }));\nconst getPageFailure = createAction('GET_PAGE_FAILURE', (id, error) => ({ id, error }));\n\n/**\n * Gets a page from the API.\n */\nfunction getPage(id) {\n return (dispatch) => {\n dispatch(getPageStart(id));\n\n return admin.getPage(id).then((data) => {\n dispatch(getPageSuccess(id, data));\n }, (error) => {\n dispatch(getPageFailure(id, error));\n });\n };\n}\n\nconst getChildrenStart = createAction('GET_CHILDREN_START', id => ({ id }));\nconst getChildrenSuccess = createAction('GET_CHILDREN_SUCCESS', (id, items, meta) => ({ id, items, meta }));\nconst getChildrenFailure = createAction('GET_CHILDREN_FAILURE', (id, error) => ({ id, error }));\n\n/**\n * Gets the children of a node from the API.\n */\nfunction getChildren(id, offset = 0) {\n return (dispatch) => {\n dispatch(getChildrenStart(id));\n\n return admin.getPageChildren(id, {\n offset: offset,\n }).then(({ items, meta }) => {\n const nbPages = offset + items.length;\n dispatch(getChildrenSuccess(id, items, meta));\n\n // Load more pages if necessary. Only one request is created even though\n // more might be needed, thus naturally throttling the loading.\n if (nbPages < meta.total_count && nbPages < MAX_EXPLORER_PAGES) {\n dispatch(getChildren(id, nbPages));\n }\n }, (error) => {\n dispatch(getChildrenFailure(id, error));\n });\n };\n}\n\nconst openExplorer = createAction('OPEN_EXPLORER', id => ({ id }));\nexport const closeExplorer = createAction('CLOSE_EXPLORER');\n\nexport function toggleExplorer(id) {\n return (dispatch, getState) => {\n const { explorer, nodes } = getState();\n\n if (explorer.isVisible) {\n dispatch(closeExplorer());\n } else {\n const page = nodes[id];\n\n dispatch(openExplorer(id));\n\n if (!page) {\n dispatch(getChildren(id));\n }\n\n // We need to get the title of the starting page, only if it is not the site's root.\n const isNotRoot = id !== 1;\n if (isNotRoot) {\n dispatch(getPage(id));\n }\n }\n };\n}\n\nexport const popPage = createAction('POP_PAGE');\nconst pushPagePrivate = createAction('PUSH_PAGE', id => ({ id }));\n\nexport function pushPage(id) {\n return (dispatch, getState) => {\n const { nodes } = getState();\n const page = nodes[id];\n\n dispatch(pushPagePrivate(id));\n\n if (page && !page.isFetching && !(page.children.count > 0)) {\n dispatch(getChildren(id));\n }\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/actions.js","import React from 'react';\nimport { STRINGS } from '../../config/wagtailConfig';\nimport Icon from '../../components/Icon/Icon';\n\n/**\n * A loading indicator with a text label next to it.\n */\nconst LoadingSpinner = () => (\n \n {` ${STRINGS.LOADING}`}\n \n);\n\nexport default LoadingSpinner;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/LoadingSpinner/LoadingSpinner.js","import PropTypes from 'prop-types';\nimport React from 'react';\n\nimport CSSTransitionGroup from 'react-transition-group/CSSTransitionGroup';\n\nconst TRANSITION_DURATION = 210;\n\n// The available transitions. Must match the class names in CSS.\nexport const PUSH = 'push';\nexport const POP = 'pop';\n\n/**\n * Wrapper arround react-transition-group with default values.\n */\nconst Transition = ({\n name,\n component,\n className,\n duration,\n children,\n label,\n}) => (\n \n {children}\n \n);\n\nTransition.propTypes = {\n name: PropTypes.oneOf([PUSH, POP]).isRequired,\n component: PropTypes.string,\n className: PropTypes.string,\n duration: PropTypes.number,\n children: PropTypes.node,\n label: PropTypes.string,\n};\n\nTransition.defaultProps = {\n component: 'div',\n children: null,\n className: null,\n duration: TRANSITION_DURATION,\n label: null,\n};\n\nexport default Transition;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Transition/Transition.js","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nmodule.exports = exports['default'];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/dom-helpers/util/inDOM.js\n// module id = 183\n// module chunks = 1","'use strict';\n\nexports.__esModule = true;\nexports.nameShape = undefined;\nexports.transitionTimeout = transitionTimeout;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction transitionTimeout(transitionType) {\n var timeoutPropName = 'transition' + transitionType + 'Timeout';\n var enabledPropName = 'transition' + transitionType;\n\n return function (props) {\n // If the transition is enabled\n if (props[enabledPropName]) {\n // If no timeout duration is provided\n if (props[timeoutPropName] == null) {\n return new Error(timeoutPropName + ' wasn\\'t supplied to CSSTransitionGroup: ' + 'this can cause unreliable animations and won\\'t be supported in ' + 'a future version of React. See ' + 'https://fb.me/react-animation-transition-group-timeout for more ' + 'information.');\n\n // If the duration isn't a number\n } else if (typeof props[timeoutPropName] !== 'number') {\n return new Error(timeoutPropName + ' must be a number (in milliseconds)');\n }\n }\n\n return null;\n };\n}\n\nvar nameShape = exports.nameShape = _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.shape({\n enter: _propTypes2.default.string,\n leave: _propTypes2.default.string,\n active: _propTypes2.default.string\n}), _propTypes2.default.shape({\n enter: _propTypes2.default.string,\n enterActive: _propTypes2.default.string,\n leave: _propTypes2.default.string,\n leaveActive: _propTypes2.default.string,\n appear: _propTypes2.default.string,\n appearActive: _propTypes2.default.string\n})]);\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-transition-group/utils/PropTypes.js\n// module id = 184\n// module chunks = 1","import PropTypes from 'prop-types';\nimport React from 'react';\n\n/**\n * Displays the publication status of a page in a pill.\n */\nconst PublicationStatus = ({ status }) => (\n \n {status.status}\n \n);\n\nPublicationStatus.propTypes = {\n status: PropTypes.shape({\n live: PropTypes.bool.isRequired,\n status: PropTypes.string.isRequired,\n }).isRequired,\n};\n\nexport default PublicationStatus;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/PublicationStatus/PublicationStatus.js","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport {\n Icon,\n Portal,\n initExplorer,\n initFocusOutline,\n initSubmenus,\n initUpgradeNotification,\n} from 'wagtail-client';\n\nif (process.env.NODE_ENV === 'development') {\n // Run react-axe in development only, so it does not affect performance\n // in production, and does not break unit tests either.\n // eslint-disable-next-line global-require\n const axe = require('react-axe');\n axe(React, ReactDOM, 1000);\n}\n\n// Expose components as globals for third-party reuse.\nwindow.wagtail.components = {\n Icon,\n Portal,\n};\n\n/**\n * Add in here code to run once the page is loaded.\n */\ndocument.addEventListener('DOMContentLoaded', () => {\n const explorerNode = document.querySelector('[data-explorer-menu]');\n const toggleNode = document.querySelector('[data-explorer-start-page]');\n\n if (explorerNode && toggleNode) {\n initExplorer(explorerNode, toggleNode);\n }\n\n initFocusOutline();\n initSubmenus();\n initUpgradeNotification();\n});\n\n\n\n// WEBPACK FOOTER //\n// ./wagtail/admin/static_src/wagtailadmin/app/wagtailadmin.entry.js","/**\n * Entry point for the wagtail package.\n * Re-exports components and other modules via a cleaner API.\n */\n\nimport Button from './components/Button/Button';\nimport Explorer, { ExplorerToggle, initExplorer } from './components/Explorer';\nimport Icon from './components/Icon/Icon';\nimport LoadingSpinner from './components/LoadingSpinner/LoadingSpinner';\nimport Portal from './components/Portal/Portal';\nimport PublicationStatus from './components/PublicationStatus/PublicationStatus';\nimport Transition from './components/Transition/Transition';\nimport { initFocusOutline } from './utils/focus';\nimport { initSubmenus } from './includes/initSubmenus';\nimport { initUpgradeNotification } from './components/UpgradeNotification';\n\nexport {\n Button,\n Explorer,\n ExplorerToggle,\n Icon,\n LoadingSpinner,\n Portal,\n PublicationStatus,\n Transition,\n initExplorer,\n initFocusOutline,\n initSubmenus,\n initUpgradeNotification,\n};\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/index.js","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { Provider } from 'react-redux';\nimport { createStore, combineReducers, applyMiddleware, compose } from 'redux';\nimport thunkMiddleware from 'redux-thunk';\n\n// import { perfMiddleware } from '../../utils/performance';\nimport Explorer from './Explorer';\nimport ExplorerToggle from './ExplorerToggle';\nimport explorer from './reducers/explorer';\nimport nodes from './reducers/nodes';\n\n/**\n * Initialises the explorer component on the given nodes.\n */\nconst initExplorer = (explorerNode, toggleNode) => {\n const rootReducer = combineReducers({\n explorer,\n nodes,\n });\n\n const middleware = [\n thunkMiddleware,\n ];\n\n // Uncomment this to use performance measurements.\n // if (process.env.NODE_ENV !== 'production') {\n // middleware.push(perfMiddleware);\n // }\n\n const store = createStore(rootReducer, {}, compose(\n applyMiddleware(...middleware),\n // Expose store to Redux DevTools extension.\n window.__REDUX_DEVTOOLS_EXTENSION__ ? window.__REDUX_DEVTOOLS_EXTENSION__() : func => func\n ));\n\n const startPage = parseInt(toggleNode.getAttribute('data-explorer-start-page'), 10);\n\n ReactDOM.render((\n \n {toggleNode.textContent}\n \n ), toggleNode.parentNode);\n\n ReactDOM.render((\n \n \n \n ), explorerNode);\n};\n\nexport default Explorer;\n\nexport {\n ExplorerToggle,\n initExplorer,\n};\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/index.js","function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nimport { Component, Children } from 'react';\nimport PropTypes from 'prop-types';\nimport { storeShape, subscriptionShape } from '../utils/PropTypes';\nimport warning from '../utils/warning';\n\nvar didWarnAboutReceivingStore = false;\nfunction warnAboutReceivingStore() {\n if (didWarnAboutReceivingStore) {\n return;\n }\n didWarnAboutReceivingStore = true;\n\n warning(' does not support changing `store` on the fly. ' + 'It is most likely that you see this error because you updated to ' + 'Redux 2.x and React Redux 2.x which no longer hot reload reducers ' + 'automatically. See https://github.com/reactjs/react-redux/releases/' + 'tag/v2.0.0 for the migration instructions.');\n}\n\nexport function createProvider() {\n var _Provider$childContex;\n\n var storeKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'store';\n var subKey = arguments[1];\n\n var subscriptionKey = subKey || storeKey + 'Subscription';\n\n var Provider = function (_Component) {\n _inherits(Provider, _Component);\n\n Provider.prototype.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[storeKey] = this[storeKey], _ref[subscriptionKey] = null, _ref;\n };\n\n function Provider(props, context) {\n _classCallCheck(this, Provider);\n\n var _this = _possibleConstructorReturn(this, _Component.call(this, props, context));\n\n _this[storeKey] = props.store;\n return _this;\n }\n\n Provider.prototype.render = function render() {\n return Children.only(this.props.children);\n };\n\n return Provider;\n }(Component);\n\n if (process.env.NODE_ENV !== 'production') {\n Provider.prototype.componentWillReceiveProps = function (nextProps) {\n if (this[storeKey] !== nextProps.store) {\n warnAboutReceivingStore();\n }\n };\n }\n\n Provider.propTypes = {\n store: storeShape.isRequired,\n children: PropTypes.element.isRequired\n };\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[storeKey] = storeShape.isRequired, _Provider$childContex[subscriptionKey] = subscriptionShape, _Provider$childContex);\n\n return Provider;\n}\n\nexport default createProvider();\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/components/Provider.js\n// module id = 423\n// module chunks = 1","/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\n'use strict';\n\nvar REACT_STATICS = {\n childContextTypes: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\n\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = getPrototypeOf && getPrototypeOf(Object);\n\nmodule.exports = function hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') { // don't hoist over string (html) components\n\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n if (!REACT_STATICS[key] && !KNOWN_STATICS[key] && (!blacklist || !blacklist[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n try { // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n\n return targetComponent;\n }\n\n return targetComponent;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/hoist-non-react-statics/index.js\n// module id = 426\n// module chunks = 1","/**\n * Copyright 2013-2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n */\n\n'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (process.env.NODE_ENV !== 'production') {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/invariant/browser.js\n// module id = 427\n// module chunks = 1","function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n// encapsulates the subscription logic for connecting a component to the redux store, as\n// well as nesting subscriptions of descendant components, so that we can ensure the\n// ancestor components re-render before descendants\n\nvar CLEARED = null;\nvar nullListeners = {\n notify: function notify() {}\n};\n\nfunction createListenerCollection() {\n // the current/next pattern is copied from redux's createStore code.\n // TODO: refactor+expose that code to be reusable here?\n var current = [];\n var next = [];\n\n return {\n clear: function clear() {\n next = CLEARED;\n current = CLEARED;\n },\n notify: function notify() {\n var listeners = current = next;\n for (var i = 0; i < listeners.length; i++) {\n listeners[i]();\n }\n },\n get: function get() {\n return next;\n },\n subscribe: function subscribe(listener) {\n var isSubscribed = true;\n if (next === current) next = current.slice();\n next.push(listener);\n\n return function unsubscribe() {\n if (!isSubscribed || current === CLEARED) return;\n isSubscribed = false;\n\n if (next === current) next = current.slice();\n next.splice(next.indexOf(listener), 1);\n };\n }\n };\n}\n\nvar Subscription = function () {\n function Subscription(store, parentSub, onStateChange) {\n _classCallCheck(this, Subscription);\n\n this.store = store;\n this.parentSub = parentSub;\n this.onStateChange = onStateChange;\n this.unsubscribe = null;\n this.listeners = nullListeners;\n }\n\n Subscription.prototype.addNestedSub = function addNestedSub(listener) {\n this.trySubscribe();\n return this.listeners.subscribe(listener);\n };\n\n Subscription.prototype.notifyNestedSubs = function notifyNestedSubs() {\n this.listeners.notify();\n };\n\n Subscription.prototype.isSubscribed = function isSubscribed() {\n return Boolean(this.unsubscribe);\n };\n\n Subscription.prototype.trySubscribe = function trySubscribe() {\n if (!this.unsubscribe) {\n this.unsubscribe = this.parentSub ? this.parentSub.addNestedSub(this.onStateChange) : this.store.subscribe(this.onStateChange);\n\n this.listeners = createListenerCollection();\n }\n };\n\n Subscription.prototype.tryUnsubscribe = function tryUnsubscribe() {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n this.listeners.clear();\n this.listeners = nullListeners;\n }\n };\n\n return Subscription;\n}();\n\nexport { Subscription as default };\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/utils/Subscription.js\n// module id = 428\n// module chunks = 1","var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nimport connectAdvanced from '../components/connectAdvanced';\nimport shallowEqual from '../utils/shallowEqual';\nimport defaultMapDispatchToPropsFactories from './mapDispatchToProps';\nimport defaultMapStateToPropsFactories from './mapStateToProps';\nimport defaultMergePropsFactories from './mergeProps';\nimport defaultSelectorFactory from './selectorFactory';\n\n/*\n connect is a facade over connectAdvanced. It turns its args into a compatible\n selectorFactory, which has the signature:\n\n (dispatch, options) => (nextState, nextOwnProps) => nextFinalProps\n \n connect passes its args to connectAdvanced as options, which will in turn pass them to\n selectorFactory each time a Connect component instance is instantiated or hot reloaded.\n\n selectorFactory returns a final props selector from its mapStateToProps,\n mapStateToPropsFactories, mapDispatchToProps, mapDispatchToPropsFactories, mergeProps,\n mergePropsFactories, and pure args.\n\n The resulting final props selector is called by the Connect component instance whenever\n it receives new props or store state.\n */\n\nfunction match(arg, factories, name) {\n for (var i = factories.length - 1; i >= 0; i--) {\n var result = factories[i](arg);\n if (result) return result;\n }\n\n return function (dispatch, options) {\n throw new Error('Invalid value of type ' + typeof arg + ' for ' + name + ' argument when connecting component ' + options.wrappedComponentName + '.');\n };\n}\n\nfunction strictEqual(a, b) {\n return a === b;\n}\n\n// createConnect with default args builds the 'official' connect behavior. Calling it with\n// different options opens up some testing and extensibility scenarios\nexport function createConnect() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n _ref$connectHOC = _ref.connectHOC,\n connectHOC = _ref$connectHOC === undefined ? connectAdvanced : _ref$connectHOC,\n _ref$mapStateToPropsF = _ref.mapStateToPropsFactories,\n mapStateToPropsFactories = _ref$mapStateToPropsF === undefined ? defaultMapStateToPropsFactories : _ref$mapStateToPropsF,\n _ref$mapDispatchToPro = _ref.mapDispatchToPropsFactories,\n mapDispatchToPropsFactories = _ref$mapDispatchToPro === undefined ? defaultMapDispatchToPropsFactories : _ref$mapDispatchToPro,\n _ref$mergePropsFactor = _ref.mergePropsFactories,\n mergePropsFactories = _ref$mergePropsFactor === undefined ? defaultMergePropsFactories : _ref$mergePropsFactor,\n _ref$selectorFactory = _ref.selectorFactory,\n selectorFactory = _ref$selectorFactory === undefined ? defaultSelectorFactory : _ref$selectorFactory;\n\n return function connect(mapStateToProps, mapDispatchToProps, mergeProps) {\n var _ref2 = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {},\n _ref2$pure = _ref2.pure,\n pure = _ref2$pure === undefined ? true : _ref2$pure,\n _ref2$areStatesEqual = _ref2.areStatesEqual,\n areStatesEqual = _ref2$areStatesEqual === undefined ? strictEqual : _ref2$areStatesEqual,\n _ref2$areOwnPropsEqua = _ref2.areOwnPropsEqual,\n areOwnPropsEqual = _ref2$areOwnPropsEqua === undefined ? shallowEqual : _ref2$areOwnPropsEqua,\n _ref2$areStatePropsEq = _ref2.areStatePropsEqual,\n areStatePropsEqual = _ref2$areStatePropsEq === undefined ? shallowEqual : _ref2$areStatePropsEq,\n _ref2$areMergedPropsE = _ref2.areMergedPropsEqual,\n areMergedPropsEqual = _ref2$areMergedPropsE === undefined ? shallowEqual : _ref2$areMergedPropsE,\n extraOptions = _objectWithoutProperties(_ref2, ['pure', 'areStatesEqual', 'areOwnPropsEqual', 'areStatePropsEqual', 'areMergedPropsEqual']);\n\n var initMapStateToProps = match(mapStateToProps, mapStateToPropsFactories, 'mapStateToProps');\n var initMapDispatchToProps = match(mapDispatchToProps, mapDispatchToPropsFactories, 'mapDispatchToProps');\n var initMergeProps = match(mergeProps, mergePropsFactories, 'mergeProps');\n\n return connectHOC(selectorFactory, _extends({\n // used in error messages\n methodName: 'connect',\n\n // used to compute Connect's displayName from the wrapped component's displayName.\n getDisplayName: function getDisplayName(name) {\n return 'Connect(' + name + ')';\n },\n\n // if mapStateToProps is falsy, the Connect component doesn't subscribe to store state changes\n shouldHandleStateChanges: Boolean(mapStateToProps),\n\n // passed through to selectorFactory\n initMapStateToProps: initMapStateToProps,\n initMapDispatchToProps: initMapDispatchToProps,\n initMergeProps: initMergeProps,\n pure: pure,\n areStatesEqual: areStatesEqual,\n areOwnPropsEqual: areOwnPropsEqual,\n areStatePropsEqual: areStatePropsEqual,\n areMergedPropsEqual: areMergedPropsEqual\n\n }, extraOptions));\n };\n}\n\nexport default createConnect();\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/connect/connect.js\n// module id = 429\n// module chunks = 1","var hasOwn = Object.prototype.hasOwnProperty;\n\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nexport default function shallowEqual(objA, objB) {\n if (is(objA, objB)) return true;\n\n if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {\n return false;\n }\n\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n\n if (keysA.length !== keysB.length) return false;\n\n for (var i = 0; i < keysA.length; i++) {\n if (!hasOwn.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n\n return true;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/utils/shallowEqual.js\n// module id = 430\n// module chunks = 1","import { bindActionCreators } from 'redux';\nimport { wrapMapToPropsConstant, wrapMapToPropsFunc } from './wrapMapToProps';\n\nexport function whenMapDispatchToPropsIsFunction(mapDispatchToProps) {\n return typeof mapDispatchToProps === 'function' ? wrapMapToPropsFunc(mapDispatchToProps, 'mapDispatchToProps') : undefined;\n}\n\nexport function whenMapDispatchToPropsIsMissing(mapDispatchToProps) {\n return !mapDispatchToProps ? wrapMapToPropsConstant(function (dispatch) {\n return { dispatch: dispatch };\n }) : undefined;\n}\n\nexport function whenMapDispatchToPropsIsObject(mapDispatchToProps) {\n return mapDispatchToProps && typeof mapDispatchToProps === 'object' ? wrapMapToPropsConstant(function (dispatch) {\n return bindActionCreators(mapDispatchToProps, dispatch);\n }) : undefined;\n}\n\nexport default [whenMapDispatchToPropsIsFunction, whenMapDispatchToPropsIsMissing, whenMapDispatchToPropsIsObject];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/connect/mapDispatchToProps.js\n// module id = 431\n// module chunks = 1","/* global window */\nimport ponyfill from './ponyfill.js';\n\nvar root;\n\nif (typeof self !== 'undefined') {\n root = self;\n} else if (typeof window !== 'undefined') {\n root = window;\n} else if (typeof global !== 'undefined') {\n root = global;\n} else if (typeof module !== 'undefined') {\n root = module;\n} else {\n root = Function('return this')();\n}\n\nvar result = ponyfill(root);\nexport default result;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/symbol-observable/es/index.js\n// module id = 432\n// module chunks = 1","module.exports = function(originalModule) {\r\n\tif(!originalModule.webpackPolyfill) {\r\n\t\tvar module = Object.create(originalModule);\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"exports\", {\r\n\t\t\tenumerable: true,\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/harmony-module.js\n// module id = 433\n// module chunks = 1","export default function symbolObservablePonyfill(root) {\n\tvar result;\n\tvar Symbol = root.Symbol;\n\n\tif (typeof Symbol === 'function') {\n\t\tif (Symbol.observable) {\n\t\t\tresult = Symbol.observable;\n\t\t} else {\n\t\t\tresult = Symbol('observable');\n\t\t\tSymbol.observable = result;\n\t\t}\n\t} else {\n\t\tresult = '@@observable';\n\t}\n\n\treturn result;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/symbol-observable/es/ponyfill.js\n// module id = 434\n// module chunks = 1","import baseGetTag from './_baseGetTag.js';\nimport getPrototype from './_getPrototype.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n}\n\nexport default isPlainObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/isPlainObject.js\n// module id = 435\n// module chunks = 1","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_baseGetTag.js\n// module id = 436\n// module chunks = 1","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_root.js\n// module id = 437\n// module chunks = 1","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_freeGlobal.js\n// module id = 438\n// module chunks = 1","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_getRawTag.js\n// module id = 439\n// module chunks = 1","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_objectToString.js\n// module id = 440\n// module chunks = 1","import overArg from './_overArg.js';\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nexport default getPrototype;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_getPrototype.js\n// module id = 441\n// module chunks = 1","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nexport default overArg;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/_overArg.js\n// module id = 442\n// module chunks = 1","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/lodash-es/isObjectLike.js\n// module id = 443\n// module chunks = 1","import { wrapMapToPropsConstant, wrapMapToPropsFunc } from './wrapMapToProps';\n\nexport function whenMapStateToPropsIsFunction(mapStateToProps) {\n return typeof mapStateToProps === 'function' ? wrapMapToPropsFunc(mapStateToProps, 'mapStateToProps') : undefined;\n}\n\nexport function whenMapStateToPropsIsMissing(mapStateToProps) {\n return !mapStateToProps ? wrapMapToPropsConstant(function () {\n return {};\n }) : undefined;\n}\n\nexport default [whenMapStateToPropsIsFunction, whenMapStateToPropsIsMissing];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/connect/mapStateToProps.js\n// module id = 444\n// module chunks = 1","var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nimport verifyPlainObject from '../utils/verifyPlainObject';\n\nexport function defaultMergeProps(stateProps, dispatchProps, ownProps) {\n return _extends({}, ownProps, stateProps, dispatchProps);\n}\n\nexport function wrapMergePropsFunc(mergeProps) {\n return function initMergePropsProxy(dispatch, _ref) {\n var displayName = _ref.displayName,\n pure = _ref.pure,\n areMergedPropsEqual = _ref.areMergedPropsEqual;\n\n var hasRunOnce = false;\n var mergedProps = void 0;\n\n return function mergePropsProxy(stateProps, dispatchProps, ownProps) {\n var nextMergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n\n if (hasRunOnce) {\n if (!pure || !areMergedPropsEqual(nextMergedProps, mergedProps)) mergedProps = nextMergedProps;\n } else {\n hasRunOnce = true;\n mergedProps = nextMergedProps;\n\n if (process.env.NODE_ENV !== 'production') verifyPlainObject(mergedProps, displayName, 'mergeProps');\n }\n\n return mergedProps;\n };\n };\n}\n\nexport function whenMergePropsIsFunction(mergeProps) {\n return typeof mergeProps === 'function' ? wrapMergePropsFunc(mergeProps) : undefined;\n}\n\nexport function whenMergePropsIsOmitted(mergeProps) {\n return !mergeProps ? function () {\n return defaultMergeProps;\n } : undefined;\n}\n\nexport default [whenMergePropsIsFunction, whenMergePropsIsOmitted];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/connect/mergeProps.js\n// module id = 445\n// module chunks = 1","function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nimport verifySubselectors from './verifySubselectors';\n\nexport function impureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch) {\n return function impureFinalPropsSelector(state, ownProps) {\n return mergeProps(mapStateToProps(state, ownProps), mapDispatchToProps(dispatch, ownProps), ownProps);\n };\n}\n\nexport function pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, _ref) {\n var areStatesEqual = _ref.areStatesEqual,\n areOwnPropsEqual = _ref.areOwnPropsEqual,\n areStatePropsEqual = _ref.areStatePropsEqual;\n\n var hasRunAtLeastOnce = false;\n var state = void 0;\n var ownProps = void 0;\n var stateProps = void 0;\n var dispatchProps = void 0;\n var mergedProps = void 0;\n\n function handleFirstCall(firstState, firstOwnProps) {\n state = firstState;\n ownProps = firstOwnProps;\n stateProps = mapStateToProps(state, ownProps);\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n hasRunAtLeastOnce = true;\n return mergedProps;\n }\n\n function handleNewPropsAndNewState() {\n stateProps = mapStateToProps(state, ownProps);\n\n if (mapDispatchToProps.dependsOnOwnProps) dispatchProps = mapDispatchToProps(dispatch, ownProps);\n\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleNewProps() {\n if (mapStateToProps.dependsOnOwnProps) stateProps = mapStateToProps(state, ownProps);\n\n if (mapDispatchToProps.dependsOnOwnProps) dispatchProps = mapDispatchToProps(dispatch, ownProps);\n\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleNewState() {\n var nextStateProps = mapStateToProps(state, ownProps);\n var statePropsChanged = !areStatePropsEqual(nextStateProps, stateProps);\n stateProps = nextStateProps;\n\n if (statePropsChanged) mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n\n return mergedProps;\n }\n\n function handleSubsequentCalls(nextState, nextOwnProps) {\n var propsChanged = !areOwnPropsEqual(nextOwnProps, ownProps);\n var stateChanged = !areStatesEqual(nextState, state);\n state = nextState;\n ownProps = nextOwnProps;\n\n if (propsChanged && stateChanged) return handleNewPropsAndNewState();\n if (propsChanged) return handleNewProps();\n if (stateChanged) return handleNewState();\n return mergedProps;\n }\n\n return function pureFinalPropsSelector(nextState, nextOwnProps) {\n return hasRunAtLeastOnce ? handleSubsequentCalls(nextState, nextOwnProps) : handleFirstCall(nextState, nextOwnProps);\n };\n}\n\n// TODO: Add more comments\n\n// If pure is true, the selector returned by selectorFactory will memoize its results,\n// allowing connectAdvanced's shouldComponentUpdate to return false if final\n// props have not changed. If false, the selector will always return a new\n// object and shouldComponentUpdate will always return true.\n\nexport default function finalPropsSelectorFactory(dispatch, _ref2) {\n var initMapStateToProps = _ref2.initMapStateToProps,\n initMapDispatchToProps = _ref2.initMapDispatchToProps,\n initMergeProps = _ref2.initMergeProps,\n options = _objectWithoutProperties(_ref2, ['initMapStateToProps', 'initMapDispatchToProps', 'initMergeProps']);\n\n var mapStateToProps = initMapStateToProps(dispatch, options);\n var mapDispatchToProps = initMapDispatchToProps(dispatch, options);\n var mergeProps = initMergeProps(dispatch, options);\n\n if (process.env.NODE_ENV !== 'production') {\n verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps, options.displayName);\n }\n\n var selectorFactory = options.pure ? pureFinalPropsSelectorFactory : impureFinalPropsSelectorFactory;\n\n return selectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, options);\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-redux/es/connect/selectorFactory.js\n// module id = 446\n// module chunks = 1","function createThunkMiddleware(extraArgument) {\n return function (_ref) {\n var dispatch = _ref.dispatch,\n getState = _ref.getState;\n return function (next) {\n return function (action) {\n if (typeof action === 'function') {\n return action(dispatch, getState, extraArgument);\n }\n\n return next(action);\n };\n };\n };\n}\n\nvar thunk = createThunkMiddleware();\nthunk.withExtraArgument = createThunkMiddleware;\n\nexport default thunk;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/redux-thunk/es/index.js\n// module id = 448\n// module chunks = 1","import PropTypes from 'prop-types';\nimport React from 'react';\nimport { connect } from 'react-redux';\n\nimport * as actions from './actions';\n\nimport ExplorerPanel from './ExplorerPanel';\n\nconst Explorer = ({\n isVisible,\n nodes,\n path,\n pushPage,\n popPage,\n onClose,\n}) => {\n const page = nodes[path[path.length - 1]];\n\n return isVisible ? (\n \n ) : null;\n};\n\nExplorer.propTypes = {\n isVisible: PropTypes.bool.isRequired,\n path: PropTypes.array.isRequired,\n nodes: PropTypes.object.isRequired,\n\n pushPage: PropTypes.func.isRequired,\n popPage: PropTypes.func.isRequired,\n onClose: PropTypes.func.isRequired,\n};\n\nconst mapStateToProps = (state) => ({\n isVisible: state.explorer.isVisible,\n path: state.explorer.path,\n nodes: state.nodes,\n});\n\nconst mapDispatchToProps = (dispatch) => ({\n pushPage: (id) => dispatch(actions.pushPage(id)),\n popPage: () => dispatch(actions.popPage()),\n onClose: () => dispatch(actions.closeExplorer()),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Explorer);\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/Explorer.js","import { get } from '../api/client';\n\nimport { ADMIN_API } from '../config/wagtailConfig';\n\n\nexport const getPage = (id) => {\n const url = `${ADMIN_API.PAGES}${id}/`;\n\n return get(url);\n};\n\nexport const getPageChildren = (id, options = {}) => {\n let url = `${ADMIN_API.PAGES}?child_of=${id}&for_explorer=1`;\n\n if (options.fields) {\n url += `&fields=${global.encodeURIComponent(options.fields.join(','))}`;\n }\n\n if (options.onlyWithChildren) {\n url += '&has_children=1';\n }\n\n if (options.offset) {\n url += `&offset=${options.offset}`;\n }\n\n url += ADMIN_API.EXTRA_CHILDREN_PARAMETERS;\n\n return get(url);\n};\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/api/admin.js","const fetch = global.fetch;\nconst Headers = global.Headers;\n\nconst REQUEST_TIMEOUT = 15000;\n\nconst checkStatus = (response) => {\n if (response.status >= 200 && response.status < 300) {\n return response;\n }\n\n const error = new Error(response.statusText);\n\n throw error;\n};\n\nconst parseJSON = response => response.json();\n\n// Response timeout cancelling the promise (not the request).\n// See https://github.com/github/fetch/issues/175#issuecomment-216791333.\nconst timeout = (ms, promise) => {\n const race = new Promise((resolve, reject) => {\n const timeoutId = setTimeout(() => {\n reject(new Error('Response timeout'));\n }, ms);\n\n promise.then((res) => {\n clearTimeout(timeoutId);\n resolve(res);\n }, (err) => {\n clearTimeout(timeoutId);\n reject(err);\n });\n });\n\n return race;\n};\n\n/**\n * Wrapper around fetch with sane defaults for behavior in the face of\n * errors.\n */\nconst request = (method, url) => {\n const options = {\n credentials: 'same-origin',\n headers: new Headers({\n 'Accept': 'application/json',\n 'Content-Type': 'application/json',\n }),\n method: method\n };\n\n return timeout(REQUEST_TIMEOUT, fetch(url, options))\n .then(checkStatus)\n .then(parseJSON);\n};\n\nexport const get = url => request('GET', url);\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/api/client.js","const identity = func => func;\n\n// Stolen from the following project (had a 18kb footprint at the time).\n// https://github.com/acdlite/redux-actions/blob/79c68635fb1524c1b1cf8e2398d4b099b53ca8de/src/createAction.js\nexport function createAction(type, actionCreator, metaCreator) {\n const finalActionCreator = typeof actionCreator === 'function' ? actionCreator : identity;\n\n return (...args) => {\n const action = {\n type,\n payload: finalActionCreator(...args),\n };\n\n if (action.payload instanceof Error) {\n // Handle FSA errors where the payload is an Error object. Set error.\n action.error = true;\n }\n\n if (typeof metaCreator === 'function') {\n action.meta = metaCreator(...args);\n }\n\n return action;\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/utils/actions.js","import PropTypes from 'prop-types';\nimport React from 'react';\nimport FocusTrap from 'focus-trap-react';\n\nimport { STRINGS, MAX_EXPLORER_PAGES } from '../../config/wagtailConfig';\n\nimport Button from '../Button/Button';\nimport LoadingSpinner from '../LoadingSpinner/LoadingSpinner';\nimport Transition, { PUSH, POP } from '../Transition/Transition';\nimport ExplorerHeader from './ExplorerHeader';\nimport ExplorerItem from './ExplorerItem';\nimport PageCount from './PageCount';\n\n/**\n * The main panel of the page explorer menu, with heading,\n * menu items, and special states.\n */\nclass ExplorerPanel extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n transition: PUSH,\n paused: false,\n };\n\n this.onItemClick = this.onItemClick.bind(this);\n this.onHeaderClick = this.onHeaderClick.bind(this);\n this.clickOutside = this.clickOutside.bind(this);\n }\n\n componentWillReceiveProps(newProps) {\n const { path } = this.props;\n const isPush = newProps.path.length > path.length;\n\n this.setState({\n transition: isPush ? PUSH : POP,\n });\n }\n\n componentDidMount() {\n document.querySelector('[data-explorer-menu-item]').classList.add('submenu-active');\n document.body.classList.add('explorer-open');\n document.addEventListener('mousedown', this.clickOutside);\n document.addEventListener('touchend', this.clickOutside);\n }\n\n componentWillUnmount() {\n document.querySelector('[data-explorer-menu-item]').classList.remove('submenu-active');\n document.body.classList.remove('explorer-open');\n document.removeEventListener('mousedown', this.clickOutside);\n document.removeEventListener('touchend', this.clickOutside);\n }\n\n clickOutside(e) {\n const { onClose } = this.props;\n const explorer = document.querySelector('[data-explorer-menu]');\n const toggle = document.querySelector('[data-explorer-menu-item]');\n\n const isInside = explorer.contains(e.target) || toggle.contains(e.target);\n if (!isInside) {\n onClose();\n }\n\n if (toggle.contains(e.target)) {\n this.setState({\n paused: true,\n });\n }\n }\n\n onItemClick(id, e) {\n const { pushPage } = this.props;\n\n e.preventDefault();\n e.stopPropagation();\n\n pushPage(id);\n }\n\n onHeaderClick(e) {\n const { path, popPage } = this.props;\n const hasBack = path.length > 1;\n\n if (hasBack) {\n e.preventDefault();\n e.stopPropagation();\n\n popPage();\n }\n }\n\n renderChildren() {\n const { page, nodes } = this.props;\n let children;\n\n if (!page.isFetching && !page.children.items) {\n children = (\n
\n {STRINGS.NO_RESULTS}\n
\n );\n } else {\n children = (\n
\n {page.children.items.map((id) => (\n \n ))}\n
\n );\n }\n\n return (\n
\n {children}\n {page.isFetching ? (\n
\n \n
\n ) : null}\n {page.isError ? (\n
\n {STRINGS.SERVER_ERROR}\n
\n ) : null}\n
\n );\n }\n\n render() {\n const { page, onClose, path } = this.props;\n const { transition, paused } = this.state;\n\n return (\n \n \n \n
\n \n\n {this.renderChildren()}\n\n {page.isError || page.children.items && page.children.count > MAX_EXPLORER_PAGES ? (\n \n ) : null}\n
\n
\n \n );\n }\n}\n\nExplorerPanel.propTypes = {\n nodes: PropTypes.object.isRequired,\n path: PropTypes.array.isRequired,\n page: PropTypes.shape({\n isFetching: PropTypes.bool,\n children: PropTypes.shape({\n count: PropTypes.number,\n items: PropTypes.array,\n }),\n }).isRequired,\n onClose: PropTypes.func.isRequired,\n popPage: PropTypes.func.isRequired,\n pushPage: PropTypes.func.isRequired,\n};\n\nexport default ExplorerPanel;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/ExplorerPanel.js","module.exports = global[\"FocusTrapReact\"] = require(\"-!./focus-trap-react.js\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/focus-trap-react/dist/focus-trap-react.js-exposed\n// module id = 454\n// module chunks = 1","'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar React = require('react');\nvar createFocusTrap = require('focus-trap');\n\nvar checkedProps = ['active', 'paused', 'tag', 'focusTrapOptions', '_createFocusTrap'];\n\nvar FocusTrap = function (_React$Component) {\n _inherits(FocusTrap, _React$Component);\n\n function FocusTrap() {\n var _ref;\n\n var _temp, _this, _ret;\n\n _classCallCheck(this, FocusTrap);\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 = _possibleConstructorReturn(this, (_ref = FocusTrap.__proto__ || Object.getPrototypeOf(FocusTrap)).call.apply(_ref, [this].concat(args))), _this), _this.setNode = function (el) {\n _this.node = el;\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n _createClass(FocusTrap, [{\n key: 'componentWillMount',\n value: function componentWillMount() {\n if (typeof document !== 'undefined') {\n this.previouslyFocusedElement = document.activeElement;\n }\n }\n }, {\n key: 'componentDidMount',\n value: function componentDidMount() {\n // We need to hijack the returnFocusOnDeactivate option,\n // because React can move focus into the element before we arrived at\n // this lifecycle hook (e.g. with autoFocus inputs). So the component\n // captures the previouslyFocusedElement in componentWillMount,\n // then (optionally) returns focus to it in componentWillUnmount.\n var specifiedFocusTrapOptions = this.props.focusTrapOptions;\n var tailoredFocusTrapOptions = {\n returnFocusOnDeactivate: false\n };\n for (var optionName in specifiedFocusTrapOptions) {\n if (!specifiedFocusTrapOptions.hasOwnProperty(optionName)) continue;\n if (optionName === 'returnFocusOnDeactivate') continue;\n tailoredFocusTrapOptions[optionName] = specifiedFocusTrapOptions[optionName];\n }\n\n this.focusTrap = this.props._createFocusTrap(this.node, tailoredFocusTrapOptions);\n if (this.props.active) {\n this.focusTrap.activate();\n }\n if (this.props.paused) {\n this.focusTrap.pause();\n }\n }\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(prevProps) {\n if (prevProps.active && !this.props.active) {\n this.focusTrap.deactivate();\n } else if (!prevProps.active && this.props.active) {\n this.focusTrap.activate();\n }\n\n if (prevProps.paused && !this.props.paused) {\n this.focusTrap.unpause();\n } else if (!prevProps.paused && this.props.paused) {\n this.focusTrap.pause();\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n this.focusTrap.deactivate();\n if (this.props.focusTrapOptions.returnFocusOnDeactivate !== false && this.previouslyFocusedElement && this.previouslyFocusedElement.focus) {\n this.previouslyFocusedElement.focus();\n }\n }\n }, {\n key: 'render',\n value: function render() {\n var elementProps = {\n ref: this.setNode\n };\n\n // This will get id, className, style, etc. -- arbitrary element props\n for (var prop in this.props) {\n if (!this.props.hasOwnProperty(prop)) continue;\n if (checkedProps.indexOf(prop) !== -1) continue;\n elementProps[prop] = this.props[prop];\n }\n\n return React.createElement(this.props.tag, elementProps, this.props.children);\n }\n }]);\n\n return FocusTrap;\n}(React.Component);\n\nFocusTrap.defaultProps = {\n active: true,\n tag: 'div',\n paused: false,\n focusTrapOptions: {},\n _createFocusTrap: createFocusTrap\n};\n\nmodule.exports = FocusTrap;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/focus-trap-react/dist/focus-trap-react.js\n// module id = 455\n// module chunks = 1","var tabbable = require('tabbable');\n\nvar listeningFocusTrap = null;\n\nfunction focusTrap(element, userOptions) {\n var tabbableNodes = [];\n var firstTabbableNode = null;\n var lastTabbableNode = null;\n var nodeFocusedBeforeActivation = null;\n var active = false;\n var paused = false;\n var tabEvent = null;\n\n var container = (typeof element === 'string')\n ? document.querySelector(element)\n : element;\n\n var config = userOptions || {};\n config.returnFocusOnDeactivate = (userOptions && userOptions.returnFocusOnDeactivate !== undefined)\n ? userOptions.returnFocusOnDeactivate\n : true;\n config.escapeDeactivates = (userOptions && userOptions.escapeDeactivates !== undefined)\n ? userOptions.escapeDeactivates\n : true;\n\n var trap = {\n activate: activate,\n deactivate: deactivate,\n pause: pause,\n unpause: unpause,\n };\n\n return trap;\n\n function activate(activateOptions) {\n if (active) return;\n\n var defaultedActivateOptions = {\n onActivate: (activateOptions && activateOptions.onActivate !== undefined)\n ? activateOptions.onActivate\n : config.onActivate,\n };\n\n active = true;\n paused = false;\n nodeFocusedBeforeActivation = document.activeElement;\n\n if (defaultedActivateOptions.onActivate) {\n defaultedActivateOptions.onActivate();\n }\n\n addListeners();\n return trap;\n }\n\n function deactivate(deactivateOptions) {\n if (!active) return;\n\n var defaultedDeactivateOptions = {\n returnFocus: (deactivateOptions && deactivateOptions.returnFocus !== undefined)\n ? deactivateOptions.returnFocus\n : config.returnFocusOnDeactivate,\n onDeactivate: (deactivateOptions && deactivateOptions.onDeactivate !== undefined)\n ? deactivateOptions.onDeactivate\n : config.onDeactivate,\n };\n\n removeListeners();\n\n if (defaultedDeactivateOptions.onDeactivate) {\n defaultedDeactivateOptions.onDeactivate();\n }\n\n if (defaultedDeactivateOptions.returnFocus) {\n setTimeout(function () {\n tryFocus(nodeFocusedBeforeActivation);\n }, 0);\n }\n\n active = false;\n paused = false;\n return this;\n }\n\n function pause() {\n if (paused || !active) return;\n paused = true;\n removeListeners();\n }\n\n function unpause() {\n if (!paused || !active) return;\n paused = false;\n addListeners();\n }\n\n function addListeners() {\n if (!active) return;\n\n // There can be only one listening focus trap at a time\n if (listeningFocusTrap) {\n listeningFocusTrap.pause();\n }\n listeningFocusTrap = trap;\n\n updateTabbableNodes();\n tryFocus(firstFocusNode());\n document.addEventListener('focus', checkFocus, true);\n document.addEventListener('click', checkClick, true);\n document.addEventListener('mousedown', checkPointerDown, true);\n document.addEventListener('touchstart', checkPointerDown, true);\n document.addEventListener('keydown', checkKey, true);\n\n return trap;\n }\n\n function removeListeners() {\n if (!active || listeningFocusTrap !== trap) return;\n\n document.removeEventListener('focus', checkFocus, true);\n document.removeEventListener('click', checkClick, true);\n document.removeEventListener('mousedown', checkPointerDown, true);\n document.removeEventListener('touchstart', checkPointerDown, true);\n document.removeEventListener('keydown', checkKey, true);\n\n listeningFocusTrap = null;\n\n return trap;\n }\n\n function getNodeForOption(optionName) {\n var optionValue = config[optionName];\n var node = optionValue;\n if (!optionValue) {\n return null;\n }\n if (typeof optionValue === 'string') {\n node = document.querySelector(optionValue);\n if (!node) {\n throw new Error('`' + optionName + '` refers to no known node');\n }\n }\n if (typeof optionValue === 'function') {\n node = optionValue();\n if (!node) {\n throw new Error('`' + optionName + '` did not return a node');\n }\n }\n return node;\n }\n\n function firstFocusNode() {\n var node;\n if (getNodeForOption('initialFocus') !== null) {\n node = getNodeForOption('initialFocus');\n } else if (container.contains(document.activeElement)) {\n node = document.activeElement;\n } else {\n node = tabbableNodes[0] || getNodeForOption('fallbackFocus');\n }\n\n if (!node) {\n throw new Error('You can\\'t have a focus-trap without at least one focusable element');\n }\n\n return node;\n }\n\n // This needs to be done on mousedown and touchstart instead of click\n // so that it precedes the focus event\n function checkPointerDown(e) {\n if (config.clickOutsideDeactivates && !container.contains(e.target)) {\n deactivate({ returnFocus: false });\n }\n }\n\n function checkClick(e) {\n if (config.clickOutsideDeactivates) return;\n if (container.contains(e.target)) return;\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n\n function checkFocus(e) {\n if (container.contains(e.target)) return;\n e.preventDefault();\n e.stopImmediatePropagation();\n // Checking for a blur method here resolves a Firefox issue (#15)\n if (typeof e.target.blur === 'function') e.target.blur();\n\n if (tabEvent) {\n readjustFocus(tabEvent);\n }\n }\n\n function checkKey(e) {\n if (e.key === 'Tab' || e.keyCode === 9) {\n handleTab(e);\n }\n\n if (config.escapeDeactivates !== false && isEscapeEvent(e)) {\n deactivate();\n }\n }\n\n function handleTab(e) {\n updateTabbableNodes();\n\n if (e.target.hasAttribute('tabindex') && Number(e.target.getAttribute('tabindex')) < 0) {\n return tabEvent = e;\n }\n\n e.preventDefault();\n var currentFocusIndex = tabbableNodes.indexOf(e.target);\n\n if (e.shiftKey) {\n if (e.target === firstTabbableNode || tabbableNodes.indexOf(e.target) === -1) {\n return tryFocus(lastTabbableNode);\n }\n return tryFocus(tabbableNodes[currentFocusIndex - 1]);\n }\n\n if (e.target === lastTabbableNode) return tryFocus(firstTabbableNode);\n\n tryFocus(tabbableNodes[currentFocusIndex + 1]);\n }\n\n function updateTabbableNodes() {\n tabbableNodes = tabbable(container);\n firstTabbableNode = tabbableNodes[0];\n lastTabbableNode = tabbableNodes[tabbableNodes.length - 1];\n }\n\n function readjustFocus(e) {\n if (e.shiftKey) return tryFocus(lastTabbableNode);\n\n tryFocus(firstTabbableNode);\n }\n}\n\nfunction isEscapeEvent(e) {\n return e.key === 'Escape' || e.key === 'Esc' || e.keyCode === 27;\n}\n\nfunction tryFocus(node) {\n if (!node || !node.focus) return;\n if (node === document.activeElement) return;\n\n node.focus();\n if (node.tagName.toLowerCase() === 'input') {\n node.select();\n }\n}\n\nmodule.exports = focusTrap;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/focus-trap/index.js\n// module id = 456\n// module chunks = 1","module.exports = function(el, options) {\n options = options || {};\n\n var elementDocument = el.ownerDocument || el;\n var basicTabbables = [];\n var orderedTabbables = [];\n\n // A node is \"available\" if\n // - it's computed style\n var isUnavailable = createIsUnavailable(elementDocument);\n\n var candidateSelectors = [\n 'input',\n 'select',\n 'a[href]',\n 'textarea',\n 'button',\n '[tabindex]',\n ];\n\n var candidates = el.querySelectorAll(candidateSelectors.join(','));\n\n if (options.includeContainer) {\n var matches = Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\n\n if (\n candidateSelectors.some(function(candidateSelector) {\n return matches.call(el, candidateSelector);\n })\n ) {\n candidates = Array.prototype.slice.apply(candidates);\n candidates.unshift(el);\n }\n }\n\n var candidate, candidateIndex;\n for (var i = 0, l = candidates.length; i < l; i++) {\n candidate = candidates[i];\n candidateIndex = parseInt(candidate.getAttribute('tabindex'), 10) || candidate.tabIndex;\n\n if (\n candidateIndex < 0\n || (candidate.tagName === 'INPUT' && candidate.type === 'hidden')\n || candidate.disabled\n || isUnavailable(candidate, elementDocument)\n ) {\n continue;\n }\n\n if (candidateIndex === 0) {\n basicTabbables.push(candidate);\n } else {\n orderedTabbables.push({\n index: i,\n tabIndex: candidateIndex,\n node: candidate,\n });\n }\n }\n\n var tabbableNodes = orderedTabbables\n .sort(function(a, b) {\n return a.tabIndex === b.tabIndex ? a.index - b.index : a.tabIndex - b.tabIndex;\n })\n .map(function(a) {\n return a.node\n });\n\n Array.prototype.push.apply(tabbableNodes, basicTabbables);\n\n return tabbableNodes;\n}\n\nfunction createIsUnavailable(elementDocument) {\n // Node cache must be refreshed on every check, in case\n // the content of the element has changed\n var isOffCache = [];\n\n // \"off\" means `display: none;`, as opposed to \"hidden\",\n // which means `visibility: hidden;`. getComputedStyle\n // accurately reflects visiblity in context but not\n // \"off\" state, so we need to recursively check parents.\n\n function isOff(node, nodeComputedStyle) {\n if (node === elementDocument.documentElement) return false;\n\n // Find the cached node (Array.prototype.find not available in IE9)\n for (var i = 0, length = isOffCache.length; i < length; i++) {\n if (isOffCache[i][0] === node) return isOffCache[i][1];\n }\n\n nodeComputedStyle = nodeComputedStyle || elementDocument.defaultView.getComputedStyle(node);\n\n var result = false;\n\n if (nodeComputedStyle.display === 'none') {\n result = true;\n } else if (node.parentNode) {\n result = isOff(node.parentNode);\n }\n\n isOffCache.push([node, result]);\n\n return result;\n }\n\n return function isUnavailable(node) {\n if (node === elementDocument.documentElement) return false;\n\n var computedStyle = elementDocument.defaultView.getComputedStyle(node);\n\n if (isOff(node, computedStyle)) return true;\n\n return computedStyle.visibility === 'hidden';\n }\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/tabbable/index.js\n// module id = 457\n// module chunks = 1","module.exports = global[\"CSSTransitionGroup\"] = require(\"-!./CSSTransitionGroup.js\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-transition-group/CSSTransitionGroup.js-exposed\n// module id = 458\n// module chunks = 1","'use strict';\n\nexports.__esModule = true;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _TransitionGroup = require('./TransitionGroup');\n\nvar _TransitionGroup2 = _interopRequireDefault(_TransitionGroup);\n\nvar _CSSTransitionGroupChild = require('./CSSTransitionGroupChild');\n\nvar _CSSTransitionGroupChild2 = _interopRequireDefault(_CSSTransitionGroupChild);\n\nvar _PropTypes = require('./utils/PropTypes');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar propTypes = {\n transitionName: _PropTypes.nameShape.isRequired,\n\n transitionAppear: _propTypes2.default.bool,\n transitionEnter: _propTypes2.default.bool,\n transitionLeave: _propTypes2.default.bool,\n transitionAppearTimeout: (0, _PropTypes.transitionTimeout)('Appear'),\n transitionEnterTimeout: (0, _PropTypes.transitionTimeout)('Enter'),\n transitionLeaveTimeout: (0, _PropTypes.transitionTimeout)('Leave')\n};\n\nvar defaultProps = {\n transitionAppear: false,\n transitionEnter: true,\n transitionLeave: true\n};\n\nvar CSSTransitionGroup = function (_React$Component) {\n _inherits(CSSTransitionGroup, _React$Component);\n\n function CSSTransitionGroup() {\n var _temp, _this, _ret;\n\n _classCallCheck(this, CSSTransitionGroup);\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 = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this._wrapChild = function (child) {\n return _react2.default.createElement(_CSSTransitionGroupChild2.default, {\n name: _this.props.transitionName,\n appear: _this.props.transitionAppear,\n enter: _this.props.transitionEnter,\n leave: _this.props.transitionLeave,\n appearTimeout: _this.props.transitionAppearTimeout,\n enterTimeout: _this.props.transitionEnterTimeout,\n leaveTimeout: _this.props.transitionLeaveTimeout\n }, child);\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n // We need to provide this childFactory so that\n // ReactCSSTransitionGroupChild can receive updates to name, enter, and\n // leave while it is leaving.\n\n\n CSSTransitionGroup.prototype.render = function render() {\n return _react2.default.createElement(_TransitionGroup2.default, _extends({}, this.props, { childFactory: this._wrapChild }));\n };\n\n return CSSTransitionGroup;\n}(_react2.default.Component);\n\nCSSTransitionGroup.displayName = 'CSSTransitionGroup';\n\n\nCSSTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nCSSTransitionGroup.defaultProps = defaultProps;\n\nexports.default = CSSTransitionGroup;\nmodule.exports = exports['default'];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-transition-group/CSSTransitionGroup.js\n// module id = 459\n// module chunks = 1","'use strict';\n\nexports.__esModule = true;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _chainFunction = require('chain-function');\n\nvar _chainFunction2 = _interopRequireDefault(_chainFunction);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _warning = require('warning');\n\nvar _warning2 = _interopRequireDefault(_warning);\n\nvar _ChildMapping = require('./utils/ChildMapping');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar propTypes = {\n component: _propTypes2.default.any,\n childFactory: _propTypes2.default.func,\n children: _propTypes2.default.node\n};\n\nvar defaultProps = {\n component: 'span',\n childFactory: function childFactory(child) {\n return child;\n }\n};\n\nvar TransitionGroup = function (_React$Component) {\n _inherits(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n _classCallCheck(this, TransitionGroup);\n\n var _this = _possibleConstructorReturn(this, _React$Component.call(this, props, context));\n\n _this.performAppear = function (key, component) {\n _this.currentlyTransitioningKeys[key] = true;\n\n if (component.componentWillAppear) {\n component.componentWillAppear(_this._handleDoneAppearing.bind(_this, key, component));\n } else {\n _this._handleDoneAppearing(key, component);\n }\n };\n\n _this._handleDoneAppearing = function (key, component) {\n if (component.componentDidAppear) {\n component.componentDidAppear();\n }\n\n delete _this.currentlyTransitioningKeys[key];\n\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(_this.props.children);\n\n if (!currentChildMapping || !currentChildMapping.hasOwnProperty(key)) {\n // This was removed before it had fully appeared. Remove it.\n _this.performLeave(key, component);\n }\n };\n\n _this.performEnter = function (key, component) {\n _this.currentlyTransitioningKeys[key] = true;\n\n if (component.componentWillEnter) {\n component.componentWillEnter(_this._handleDoneEntering.bind(_this, key, component));\n } else {\n _this._handleDoneEntering(key, component);\n }\n };\n\n _this._handleDoneEntering = function (key, component) {\n if (component.componentDidEnter) {\n component.componentDidEnter();\n }\n\n delete _this.currentlyTransitioningKeys[key];\n\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(_this.props.children);\n\n if (!currentChildMapping || !currentChildMapping.hasOwnProperty(key)) {\n // This was removed before it had fully entered. Remove it.\n _this.performLeave(key, component);\n }\n };\n\n _this.performLeave = function (key, component) {\n _this.currentlyTransitioningKeys[key] = true;\n\n if (component.componentWillLeave) {\n component.componentWillLeave(_this._handleDoneLeaving.bind(_this, key, component));\n } else {\n // Note that this is somewhat dangerous b/c it calls setState()\n // again, effectively mutating the component before all the work\n // is done.\n _this._handleDoneLeaving(key, component);\n }\n };\n\n _this._handleDoneLeaving = function (key, component) {\n if (component.componentDidLeave) {\n component.componentDidLeave();\n }\n\n delete _this.currentlyTransitioningKeys[key];\n\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(_this.props.children);\n\n if (currentChildMapping && currentChildMapping.hasOwnProperty(key)) {\n // This entered again before it fully left. Add it again.\n _this.keysToEnter.push(key);\n } else {\n _this.setState(function (state) {\n var newChildren = _extends({}, state.children);\n delete newChildren[key];\n return { children: newChildren };\n });\n }\n };\n\n _this.childRefs = Object.create(null);\n\n _this.state = {\n children: (0, _ChildMapping.getChildMapping)(props.children)\n };\n return _this;\n }\n\n TransitionGroup.prototype.componentWillMount = function componentWillMount() {\n this.currentlyTransitioningKeys = {};\n this.keysToEnter = [];\n this.keysToLeave = [];\n };\n\n TransitionGroup.prototype.componentDidMount = function componentDidMount() {\n var initialChildMapping = this.state.children;\n for (var key in initialChildMapping) {\n if (initialChildMapping[key]) {\n this.performAppear(key, this.childRefs[key]);\n }\n }\n };\n\n TransitionGroup.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var nextChildMapping = (0, _ChildMapping.getChildMapping)(nextProps.children);\n var prevChildMapping = this.state.children;\n\n this.setState({\n children: (0, _ChildMapping.mergeChildMappings)(prevChildMapping, nextChildMapping)\n });\n\n for (var key in nextChildMapping) {\n var hasPrev = prevChildMapping && prevChildMapping.hasOwnProperty(key);\n if (nextChildMapping[key] && !hasPrev && !this.currentlyTransitioningKeys[key]) {\n this.keysToEnter.push(key);\n }\n }\n\n for (var _key in prevChildMapping) {\n var hasNext = nextChildMapping && nextChildMapping.hasOwnProperty(_key);\n if (prevChildMapping[_key] && !hasNext && !this.currentlyTransitioningKeys[_key]) {\n this.keysToLeave.push(_key);\n }\n }\n\n // If we want to someday check for reordering, we could do it here.\n };\n\n TransitionGroup.prototype.componentDidUpdate = function componentDidUpdate() {\n var _this2 = this;\n\n var keysToEnter = this.keysToEnter;\n this.keysToEnter = [];\n keysToEnter.forEach(function (key) {\n return _this2.performEnter(key, _this2.childRefs[key]);\n });\n\n var keysToLeave = this.keysToLeave;\n this.keysToLeave = [];\n keysToLeave.forEach(function (key) {\n return _this2.performLeave(key, _this2.childRefs[key]);\n });\n };\n\n TransitionGroup.prototype.render = function render() {\n var _this3 = this;\n\n // TODO: we could get rid of the need for the wrapper node\n // by cloning a single child\n var childrenToRender = [];\n\n var _loop = function _loop(key) {\n var child = _this3.state.children[key];\n if (child) {\n var isCallbackRef = typeof child.ref !== 'string';\n var factoryChild = _this3.props.childFactory(child);\n var ref = function ref(r) {\n _this3.childRefs[key] = r;\n };\n\n process.env.NODE_ENV !== 'production' ? (0, _warning2.default)(isCallbackRef, 'string refs are not supported on children of TransitionGroup and will be ignored. ' + 'Please use a callback ref instead: https://facebook.github.io/react/docs/refs-and-the-dom.html#the-ref-callback-attribute') : void 0;\n\n // Always chaining the refs leads to problems when the childFactory\n // wraps the child. The child ref callback gets called twice with the\n // wrapper and the child. So we only need to chain the ref if the\n // factoryChild is not different from child.\n if (factoryChild === child && isCallbackRef) {\n ref = (0, _chainFunction2.default)(child.ref, ref);\n }\n\n // You may need to apply reactive updates to a child as it is leaving.\n // The normal React way to do it won't work since the child will have\n // already been removed. In case you need this behavior you can provide\n // a childFactory function to wrap every child, even the ones that are\n // leaving.\n childrenToRender.push(_react2.default.cloneElement(factoryChild, {\n key: key,\n ref: ref\n }));\n }\n };\n\n for (var key in this.state.children) {\n _loop(key);\n }\n\n // Do not forward TransitionGroup props to primitive DOM nodes\n var props = _extends({}, this.props);\n delete props.transitionLeave;\n delete props.transitionName;\n delete props.transitionAppear;\n delete props.transitionEnter;\n delete props.childFactory;\n delete props.transitionLeaveTimeout;\n delete props.transitionEnterTimeout;\n delete props.transitionAppearTimeout;\n delete props.component;\n\n return _react2.default.createElement(this.props.component, props, childrenToRender);\n };\n\n return TransitionGroup;\n}(_react2.default.Component);\n\nTransitionGroup.displayName = 'TransitionGroup';\n\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nTransitionGroup.defaultProps = defaultProps;\n\nexports.default = TransitionGroup;\nmodule.exports = exports['default'];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-transition-group/TransitionGroup.js\n// module id = 460\n// module chunks = 1","\r\nmodule.exports = function chain(){\r\n var len = arguments.length\r\n var args = [];\r\n\r\n for (var i = 0; i < len; i++)\r\n args[i] = arguments[i]\r\n\r\n args = args.filter(function(fn){ return fn != null })\r\n\r\n if (args.length === 0) return undefined\r\n if (args.length === 1) return args[0]\r\n\r\n return args.reduce(function(current, next){\r\n return function chainedFunction() {\r\n current.apply(this, arguments);\r\n next.apply(this, arguments);\r\n };\r\n })\r\n}\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/chain-function/index.js\n// module id = 461\n// module chunks = 1","/**\n * Copyright 2014-2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n */\n\n'use strict';\n\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar warning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n warning = function(condition, format, args) {\n var len = arguments.length;\n args = new Array(len > 2 ? len - 2 : 0);\n for (var key = 2; key < len; key++) {\n args[key - 2] = arguments[key];\n }\n if (format === undefined) {\n throw new Error(\n '`warning(condition, format, ...args)` requires a warning ' +\n 'message argument'\n );\n }\n\n if (format.length < 10 || (/^[s\\W]*$/).test(format)) {\n throw new Error(\n 'The warning format should be able to uniquely identify this ' +\n 'warning. Please, use a more descriptive format than: ' + format\n );\n }\n\n if (!condition) {\n var argIndex = 0;\n var message = 'Warning: ' +\n format.replace(/%s/g, function() {\n return args[argIndex++];\n });\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch(x) {}\n }\n };\n}\n\nmodule.exports = warning;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/warning/browser.js\n// module id = 462\n// module chunks = 1","'use strict';\n\nexports.__esModule = true;\nexports.getChildMapping = getChildMapping;\nexports.mergeChildMappings = mergeChildMappings;\n\nvar _react = require('react');\n\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\nfunction getChildMapping(children) {\n if (!children) {\n return children;\n }\n var result = {};\n _react.Children.map(children, function (child) {\n return child;\n }).forEach(function (child) {\n result[child.key] = child;\n });\n return result;\n}\n\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\nfunction mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n if (next.hasOwnProperty(key)) {\n return next[key];\n }\n\n return prev[key];\n }\n\n // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n var nextKeysPending = {};\n\n var pendingKeys = [];\n for (var prevKey in prev) {\n if (next.hasOwnProperty(prevKey)) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i = void 0;\n var childMapping = {};\n for (var nextKey in next) {\n if (nextKeysPending.hasOwnProperty(nextKey)) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n childMapping[nextKey] = getValueForKey(nextKey);\n }\n\n // Finally, add the keys which didn't appear before any key in `next`\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-transition-group/utils/ChildMapping.js\n// module id = 463\n// module chunks = 1","'use strict';\n\nexports.__esModule = true;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _addClass = require('dom-helpers/class/addClass');\n\nvar _addClass2 = _interopRequireDefault(_addClass);\n\nvar _removeClass = require('dom-helpers/class/removeClass');\n\nvar _removeClass2 = _interopRequireDefault(_removeClass);\n\nvar _requestAnimationFrame = require('dom-helpers/util/requestAnimationFrame');\n\nvar _requestAnimationFrame2 = _interopRequireDefault(_requestAnimationFrame);\n\nvar _properties = require('dom-helpers/transition/properties');\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _reactDom = require('react-dom');\n\nvar _PropTypes = require('./utils/PropTypes');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar events = [];\nif (_properties.transitionEnd) events.push(_properties.transitionEnd);\nif (_properties.animationEnd) events.push(_properties.animationEnd);\n\nfunction addEndListener(node, listener) {\n if (events.length) {\n events.forEach(function (e) {\n return node.addEventListener(e, listener, false);\n });\n } else {\n setTimeout(listener, 0);\n }\n\n return function () {\n if (!events.length) return;\n events.forEach(function (e) {\n return node.removeEventListener(e, listener, false);\n });\n };\n}\n\nvar propTypes = {\n children: _propTypes2.default.node,\n name: _PropTypes.nameShape.isRequired,\n\n // Once we require timeouts to be specified, we can remove the\n // boolean flags (appear etc.) and just accept a number\n // or a bool for the timeout flags (appearTimeout etc.)\n appear: _propTypes2.default.bool,\n enter: _propTypes2.default.bool,\n leave: _propTypes2.default.bool,\n appearTimeout: _propTypes2.default.number,\n enterTimeout: _propTypes2.default.number,\n leaveTimeout: _propTypes2.default.number\n};\n\nvar CSSTransitionGroupChild = function (_React$Component) {\n _inherits(CSSTransitionGroupChild, _React$Component);\n\n function CSSTransitionGroupChild() {\n var _temp, _this, _ret;\n\n _classCallCheck(this, CSSTransitionGroupChild);\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 = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this.componentWillAppear = function (done) {\n if (_this.props.appear) {\n _this.transition('appear', done, _this.props.appearTimeout);\n } else {\n done();\n }\n }, _this.componentWillEnter = function (done) {\n if (_this.props.enter) {\n _this.transition('enter', done, _this.props.enterTimeout);\n } else {\n done();\n }\n }, _this.componentWillLeave = function (done) {\n if (_this.props.leave) {\n _this.transition('leave', done, _this.props.leaveTimeout);\n } else {\n done();\n }\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n CSSTransitionGroupChild.prototype.componentWillMount = function componentWillMount() {\n this.classNameAndNodeQueue = [];\n this.transitionTimeouts = [];\n };\n\n CSSTransitionGroupChild.prototype.componentWillUnmount = function componentWillUnmount() {\n this.unmounted = true;\n\n if (this.timeout) {\n clearTimeout(this.timeout);\n }\n this.transitionTimeouts.forEach(function (timeout) {\n clearTimeout(timeout);\n });\n\n this.classNameAndNodeQueue.length = 0;\n };\n\n CSSTransitionGroupChild.prototype.transition = function transition(animationType, finishCallback, timeout) {\n var node = (0, _reactDom.findDOMNode)(this);\n\n if (!node) {\n if (finishCallback) {\n finishCallback();\n }\n return;\n }\n\n var className = this.props.name[animationType] || this.props.name + '-' + animationType;\n var activeClassName = this.props.name[animationType + 'Active'] || className + '-active';\n var timer = null;\n var removeListeners = void 0;\n\n (0, _addClass2.default)(node, className);\n\n // Need to do this to actually trigger a transition.\n this.queueClassAndNode(activeClassName, node);\n\n // Clean-up the animation after the specified delay\n var finish = function finish(e) {\n if (e && e.target !== node) {\n return;\n }\n\n clearTimeout(timer);\n if (removeListeners) removeListeners();\n\n (0, _removeClass2.default)(node, className);\n (0, _removeClass2.default)(node, activeClassName);\n\n if (removeListeners) removeListeners();\n\n // Usually this optional callback is used for informing an owner of\n // a leave animation and telling it to remove the child.\n if (finishCallback) {\n finishCallback();\n }\n };\n\n if (timeout) {\n timer = setTimeout(finish, timeout);\n this.transitionTimeouts.push(timer);\n } else if (_properties.transitionEnd) {\n removeListeners = addEndListener(node, finish);\n }\n };\n\n CSSTransitionGroupChild.prototype.queueClassAndNode = function queueClassAndNode(className, node) {\n var _this2 = this;\n\n this.classNameAndNodeQueue.push({\n className: className,\n node: node\n });\n\n if (!this.rafHandle) {\n this.rafHandle = (0, _requestAnimationFrame2.default)(function () {\n return _this2.flushClassNameAndNodeQueue();\n });\n }\n };\n\n CSSTransitionGroupChild.prototype.flushClassNameAndNodeQueue = function flushClassNameAndNodeQueue() {\n if (!this.unmounted) {\n this.classNameAndNodeQueue.forEach(function (obj) {\n // This is for to force a repaint,\n // which is necessary in order to transition styles when adding a class name.\n /* eslint-disable no-unused-expressions */\n obj.node.scrollTop;\n /* eslint-enable no-unused-expressions */\n (0, _addClass2.default)(obj.node, obj.className);\n });\n }\n this.classNameAndNodeQueue.length = 0;\n this.rafHandle = null;\n };\n\n CSSTransitionGroupChild.prototype.render = function render() {\n var props = _extends({}, this.props);\n delete props.name;\n delete props.appear;\n delete props.enter;\n delete props.leave;\n delete props.appearTimeout;\n delete props.enterTimeout;\n delete props.leaveTimeout;\n delete props.children;\n return _react2.default.cloneElement(_react2.default.Children.only(this.props.children), props);\n };\n\n return CSSTransitionGroupChild;\n}(_react2.default.Component);\n\nCSSTransitionGroupChild.displayName = 'CSSTransitionGroupChild';\n\n\nCSSTransitionGroupChild.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\n\nexports.default = CSSTransitionGroupChild;\nmodule.exports = exports['default'];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/react-transition-group/CSSTransitionGroupChild.js\n// module id = 464\n// module chunks = 1","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = addClass;\n\nvar _hasClass = require('./hasClass');\n\nvar _hasClass2 = _interopRequireDefault(_hasClass);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction addClass(element, className) {\n if (element.classList) element.classList.add(className);else if (!(0, _hasClass2.default)(element)) element.className = element.className + ' ' + className;\n}\nmodule.exports = exports['default'];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/dom-helpers/class/addClass.js\n// module id = 465\n// module chunks = 1","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = hasClass;\nfunction hasClass(element, className) {\n if (element.classList) return !!className && element.classList.contains(className);else return (\" \" + element.className + \" \").indexOf(\" \" + className + \" \") !== -1;\n}\nmodule.exports = exports[\"default\"];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/dom-helpers/class/hasClass.js\n// module id = 466\n// module chunks = 1","'use strict';\n\nmodule.exports = function removeClass(element, className) {\n if (element.classList) element.classList.remove(className);else element.className = element.className.replace(new RegExp('(^|\\\\s)' + className + '(?:\\\\s|$)', 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/dom-helpers/class/removeClass.js\n// module id = 467\n// module chunks = 1","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _inDOM = require('./inDOM');\n\nvar _inDOM2 = _interopRequireDefault(_inDOM);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar vendors = ['', 'webkit', 'moz', 'o', 'ms'];\nvar cancel = 'clearTimeout';\nvar raf = fallback;\nvar compatRaf = void 0;\n\nvar getKey = function getKey(vendor, k) {\n return vendor + (!vendor ? k : k[0].toUpperCase() + k.substr(1)) + 'AnimationFrame';\n};\n\nif (_inDOM2.default) {\n vendors.some(function (vendor) {\n var rafKey = getKey(vendor, 'request');\n\n if (rafKey in window) {\n cancel = getKey(vendor, 'cancel');\n return raf = function raf(cb) {\n return window[rafKey](cb);\n };\n }\n });\n}\n\n/* https://github.com/component/raf */\nvar prev = new Date().getTime();\nfunction fallback(fn) {\n var curr = new Date().getTime(),\n ms = Math.max(0, 16 - (curr - prev)),\n req = setTimeout(fn, ms);\n\n prev = curr;\n return req;\n}\n\ncompatRaf = function compatRaf(cb) {\n return raf(cb);\n};\ncompatRaf.cancel = function (id) {\n window[cancel] && typeof window[cancel] === 'function' && window[cancel](id);\n};\nexports.default = compatRaf;\nmodule.exports = exports['default'];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/dom-helpers/util/requestAnimationFrame.js\n// module id = 468\n// module chunks = 1","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.animationEnd = exports.animationDelay = exports.animationTiming = exports.animationDuration = exports.animationName = exports.transitionEnd = exports.transitionDuration = exports.transitionDelay = exports.transitionTiming = exports.transitionProperty = exports.transform = undefined;\n\nvar _inDOM = require('../util/inDOM');\n\nvar _inDOM2 = _interopRequireDefault(_inDOM);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar transform = 'transform';\nvar prefix = void 0,\n transitionEnd = void 0,\n animationEnd = void 0;\nvar transitionProperty = void 0,\n transitionDuration = void 0,\n transitionTiming = void 0,\n transitionDelay = void 0;\nvar animationName = void 0,\n animationDuration = void 0,\n animationTiming = void 0,\n animationDelay = void 0;\n\nif (_inDOM2.default) {\n var _getTransitionPropert = getTransitionProperties();\n\n prefix = _getTransitionPropert.prefix;\n exports.transitionEnd = transitionEnd = _getTransitionPropert.transitionEnd;\n exports.animationEnd = animationEnd = _getTransitionPropert.animationEnd;\n\n\n exports.transform = transform = prefix + '-' + transform;\n exports.transitionProperty = transitionProperty = prefix + '-transition-property';\n exports.transitionDuration = transitionDuration = prefix + '-transition-duration';\n exports.transitionDelay = transitionDelay = prefix + '-transition-delay';\n exports.transitionTiming = transitionTiming = prefix + '-transition-timing-function';\n\n exports.animationName = animationName = prefix + '-animation-name';\n exports.animationDuration = animationDuration = prefix + '-animation-duration';\n exports.animationTiming = animationTiming = prefix + '-animation-delay';\n exports.animationDelay = animationDelay = prefix + '-animation-timing-function';\n}\n\nexports.transform = transform;\nexports.transitionProperty = transitionProperty;\nexports.transitionTiming = transitionTiming;\nexports.transitionDelay = transitionDelay;\nexports.transitionDuration = transitionDuration;\nexports.transitionEnd = transitionEnd;\nexports.animationName = animationName;\nexports.animationDuration = animationDuration;\nexports.animationTiming = animationTiming;\nexports.animationDelay = animationDelay;\nexports.animationEnd = animationEnd;\nexports.default = {\n transform: transform,\n end: transitionEnd,\n property: transitionProperty,\n timing: transitionTiming,\n delay: transitionDelay,\n duration: transitionDuration\n};\n\n\nfunction getTransitionProperties() {\n var style = document.createElement('div').style;\n\n var vendorMap = {\n O: function O(e) {\n return 'o' + e.toLowerCase();\n },\n Moz: function Moz(e) {\n return e.toLowerCase();\n },\n Webkit: function Webkit(e) {\n return 'webkit' + e;\n },\n ms: function ms(e) {\n return 'MS' + e;\n }\n };\n\n var vendors = Object.keys(vendorMap);\n\n var transitionEnd = void 0,\n animationEnd = void 0;\n var prefix = '';\n\n for (var i = 0; i < vendors.length; i++) {\n var vendor = vendors[i];\n\n if (vendor + 'TransitionProperty' in style) {\n prefix = '-' + vendor.toLowerCase();\n transitionEnd = vendorMap[vendor]('TransitionEnd');\n animationEnd = vendorMap[vendor]('AnimationEnd');\n break;\n }\n }\n\n if (!transitionEnd && 'transitionProperty' in style) transitionEnd = 'transitionend';\n\n if (!animationEnd && 'animationName' in style) animationEnd = 'animationend';\n\n style = null;\n\n return { animationEnd: animationEnd, transitionEnd: transitionEnd, prefix: prefix };\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/dom-helpers/transition/properties.js\n// module id = 469\n// module chunks = 1","import PropTypes from 'prop-types';\nimport React from 'react';\nimport { ADMIN_URLS, STRINGS } from '../../config/wagtailConfig';\n\nimport Button from '../../components/Button/Button';\nimport Icon from '../../components/Icon/Icon';\n\n/**\n * The bar at the top of the explorer, displaying the current level\n * and allowing access back to the parent level.\n */\nconst ExplorerHeader = ({ page, depth, onClick }) => {\n const isRoot = depth === 1;\n\n return (\n \n
\n \n {page.admin_display_title || STRINGS.PAGES}\n
\n \n );\n};\n\nExplorerHeader.propTypes = {\n page: PropTypes.shape({\n id: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n admin_display_title: PropTypes.string,\n }).isRequired,\n depth: PropTypes.number.isRequired,\n onClick: PropTypes.func.isRequired,\n};\n\nexport default ExplorerHeader;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/ExplorerHeader.js","import PropTypes from 'prop-types';\nimport React from 'react';\n\nimport { ADMIN_URLS, STRINGS } from '../../config/wagtailConfig';\nimport Icon from '../../components/Icon/Icon';\nimport Button from '../../components/Button/Button';\nimport PublicationStatus from '../../components/PublicationStatus/PublicationStatus';\n\n// Hoist icons in the explorer item, as it is re-rendered many times.\nconst childrenIcon = (\n \n);\n\n/**\n * One menu item in the page explorer, with different available actions\n * and information depending on the metadata of the page.\n */\nconst ExplorerItem = ({ item, onClick }) => {\n const { id, admin_display_title: title, meta } = item;\n const hasChildren = meta.children.count > 0;\n const isPublished = meta.status.live && !meta.status.has_unpublished_changes;\n\n return (\n
\n \n \n \n \n {hasChildren ? (\n \n \n \n ) : null}\n
\n );\n};\n\nExplorerItem.propTypes = {\n item: PropTypes.shape({\n id: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).isRequired,\n admin_display_title: PropTypes.string.isRequired,\n meta: PropTypes.shape({\n status: PropTypes.object.isRequired,\n }).isRequired,\n }).isRequired,\n onClick: PropTypes.func.isRequired,\n};\n\nexport default ExplorerItem;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/ExplorerItem.js","import PropTypes from 'prop-types';\nimport React from 'react';\n\nimport { ADMIN_URLS, STRINGS } from '../../config/wagtailConfig';\nimport Icon from '../Icon/Icon';\n\nconst PageCount = ({ page }) => {\n const count = page.children.count;\n\n return (\n \n {STRINGS.SEE_ALL}\n {` ${count} ${count === 1 ? STRINGS.PAGE.toLowerCase() : STRINGS.PAGES.toLowerCase()}`}\n \n
\n );\n};\n\nPageCount.propTypes = {\n page: PropTypes.object.isRequired,\n};\n\nexport default PageCount;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/PageCount.js","import PropTypes from 'prop-types';\nimport React from 'react';\nimport { connect } from 'react-redux';\n\nimport * as actions from './actions';\n\nimport Button from '../../components/Button/Button';\n\n/**\n * A Button which toggles the explorer.\n */\nconst ExplorerToggle = ({ children, onToggle }) => (\n \n {children}\n \n);\n\nExplorerToggle.propTypes = {\n onToggle: PropTypes.func.isRequired,\n children: PropTypes.node.isRequired,\n};\n\nconst mapStateToProps = () => ({});\n\nconst mapDispatchToProps = (dispatch) => ({\n onToggle: (page) => dispatch(actions.toggleExplorer(page)),\n});\n\nconst mergeProps = (stateProps, dispatchProps, ownProps) => ({\n children: ownProps.children,\n onToggle: dispatchProps.onToggle.bind(null, ownProps.startPage),\n});\n\nexport default connect(mapStateToProps, mapDispatchToProps, mergeProps)(ExplorerToggle);\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/ExplorerToggle.js","const defaultState = {\n isVisible: false,\n path: [],\n};\n\n/**\n * Oversees the state of the explorer. Defines:\n * - Where in the page tree the explorer is at.\n * - Whether the explorer is open or not.\n */\nexport default function explorer(prevState = defaultState, { type, payload }) {\n switch (type) {\n case 'OPEN_EXPLORER':\n // Provide a starting page when opening the explorer.\n return {\n isVisible: true,\n path: [payload.id],\n };\n\n case 'CLOSE_EXPLORER':\n return defaultState;\n\n case 'PUSH_PAGE':\n return {\n isVisible: prevState.isVisible,\n path: prevState.path.concat([payload.id]),\n };\n\n case 'POP_PAGE':\n return {\n isVisible: prevState.isVisible,\n path: prevState.path.slice(0, -1),\n };\n\n default:\n return prevState;\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/reducers/explorer.js","const defaultPageState = {\n isFetching: false,\n isError: false,\n children: {\n items: [],\n count: 0,\n },\n meta: {\n children: {},\n },\n};\n\n/**\n * A single page node in the explorer.\n */\nconst node = (state = defaultPageState, { type, payload }) => {\n switch (type) {\n case 'OPEN_EXPLORER':\n return state || defaultPageState;\n\n case 'GET_PAGE_SUCCESS':\n return Object.assign({}, state, payload.data, {\n isError: false,\n });\n\n case 'GET_CHILDREN_START':\n return Object.assign({}, state, {\n isFetching: true,\n });\n\n case 'GET_CHILDREN_SUCCESS':\n return Object.assign({}, state, {\n isFetching: false,\n isError: false,\n children: {\n items: state.children.items.slice().concat(payload.items.map(item => item.id)),\n count: payload.meta.total_count,\n },\n });\n\n case 'GET_PAGE_FAILURE':\n case 'GET_CHILDREN_FAILURE':\n return Object.assign({}, state, {\n isFetching: false,\n isError: true,\n });\n\n default:\n return state;\n }\n};\n\nconst defaultState = {};\n\n/**\n * Contains all of the page nodes in one object.\n */\nexport default function nodes(state = defaultState, { type, payload }) {\n switch (type) {\n case 'OPEN_EXPLORER':\n case 'GET_PAGE_SUCCESS':\n case 'GET_CHILDREN_START':\n case 'GET_PAGE_FAILURE':\n case 'GET_CHILDREN_FAILURE':\n return Object.assign({}, state, {\n // Delegate logic to single-node reducer.\n [payload.id]: node(state[payload.id], { type, payload }),\n });\n\n // eslint-disable-next-line no-case-declarations\n case 'GET_CHILDREN_SUCCESS':\n const newState = Object.assign({}, state, {\n [payload.id]: node(state[payload.id], { type, payload }),\n });\n\n payload.items.forEach((item) => {\n newState[item.id] = Object.assign({}, defaultPageState, item);\n });\n\n return newState;\n\n default:\n return state;\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Explorer/reducers/nodes.js","const OUTLINE_ON = 'focus-outline-on';\nconst OUTLINE_OFF = 'focus-outline-off';\n\nconst toggleFocusOutline = (isOn) => {\n document.body.classList.toggle(OUTLINE_OFF, !isOn);\n document.body.classList.toggle(OUTLINE_ON, isOn);\n};\n\nconst removeFocusOutline = toggleFocusOutline.bind(null, false);\nconst addFocusOutline = toggleFocusOutline.bind(null, true);\n\n/**\n * Adds a heavy focus outline to the UI, only for users who tab through the page.\n * The outline is not useful with touch or mouse input – these remove the outline.\n */\nexport const initFocusOutline = () => {\n // Focus outline styles are added by default in the HTML, so they work without JS enabled.\n removeFocusOutline();\n\n window.addEventListener('mousedown', removeFocusOutline);\n window.addEventListener('touchstart', removeFocusOutline);\n\n window.addEventListener('keydown', e => {\n const isTabKey = e.keyCode === 9;\n\n if (isTabKey) {\n addFocusOutline();\n }\n });\n};\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/utils/focus.js","/**\n * Initialises the Submenus within the primary Wagtail menu (excluding the Explorer menu)\n */\n\nconst initSubmenus = () => {\n const primaryNavContainer = document.querySelector('[data-nav-primary]');\n\n if (!primaryNavContainer) {\n return;\n }\n\n const subMenuTriggers = document.querySelectorAll(\n '[data-nav-primary-submenu-trigger]'\n );\n const activeClass = 'submenu-active';\n\n [...subMenuTriggers].forEach(subMenuTrigger => {\n subMenuTrigger.addEventListener('click', clickEvent => {\n const submenuContainer = subMenuTrigger.parentNode;\n\n primaryNavContainer.classList.remove(activeClass);\n [...subMenuTriggers].forEach(sm => sm.classList.remove(activeClass));\n\n primaryNavContainer.classList.toggle(activeClass);\n submenuContainer.classList.toggle(activeClass);\n\n document.addEventListener('mousedown', e => {\n if (\n !submenuContainer.contains(e.target) &&\n subMenuTrigger !== e.target\n ) {\n primaryNavContainer.classList.remove(activeClass);\n submenuContainer.classList.remove(activeClass);\n }\n });\n\n document.addEventListener('keydown', e => {\n // IE11 uses \"Esc\" instead of \"Escape\"\n if (e.key === 'Escape' || e.key === 'Esc') {\n primaryNavContainer.classList.remove(activeClass);\n submenuContainer.classList.remove(activeClass);\n }\n });\n\n clickEvent.preventDefault();\n });\n });\n};\n\nexport { initSubmenus };\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/includes/initSubmenus.js","import { versionOutOfDate } from '../../utils/version';\n\nconst initUpgradeNotification = () => {\n const container = document.querySelector('[data-upgrade]');\n\n if (!container) {\n return;\n }\n\n /*\n * Expected JSON payload:\n * {\n * \"version\" : \"1.2.3\", // Version number. Can only contain numbers and decimal point.\n * \"url\" : \"https://wagtail.io\" // Absolute URL to page/file containing release notes or actual package. It's up to you.\n * }\n */\n const releasesUrl = 'https://releases.wagtail.io/latest.txt';\n const currentVersion = container.dataset.wagtailVersion;\n\n fetch(releasesUrl).then(response => {\n if (response.status !== 200) {\n // eslint-disable-next-line no-console\n console.log(`Unexpected response from ${releasesUrl}. Status: ${response.status}`);\n return false;\n }\n return response.json();\n }).then(data => {\n if (data && data.version && versionOutOfDate(data.version, currentVersion)) {\n container.querySelector('[data-upgrade-version]').innerText = data.version;\n container.querySelector('[data-upgrade-link]').setAttribute('href', data.url);\n container.style.display = '';\n }\n })\n .catch(err => {\n // eslint-disable-next-line no-console\n console.log(`Error fetching ${releasesUrl}. Error: ${err}`);\n });\n};\n\nexport { initUpgradeNotification };\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/UpgradeNotification/index.js","function compareVersion(versionA, versionB) {\n const re = /(\\.0)+[^.]*$/;\n const va = (versionA + '').replace(re, '').split('.');\n const vb = (versionB + '').replace(re, '').split('.');\n const len = Math.min(va.length, vb.length);\n for (let i = 0; i < len; i++) {\n const cmp = parseInt(va[i], 10) - parseInt(vb[i], 10);\n if (cmp !== 0) {\n return cmp;\n }\n }\n\n return va.length - vb.length;\n}\n\nfunction versionOutOfDate(latestVersion, currentVersion) {\n return compareVersion(latestVersion, currentVersion) > 0;\n}\n\nexport {\n compareVersion,\n versionOutOfDate,\n};\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/utils/version.js","import PropTypes from 'prop-types';\nimport React from 'react';\n\nconst getClassName = (className, icon) => {\n const hasIcon = icon !== '';\n let iconName = '';\n if (hasIcon) {\n if (typeof icon === 'string') {\n iconName = ` icon-${icon}`;\n } else {\n iconName = icon.map(val => ` icon-${val}`).join('');\n }\n }\n return `${className} ${hasIcon ? 'icon' : ''}${iconName}`;\n};\n\nconst handleClick = (href, onClick, preventDefault, e) => {\n if (preventDefault && href === '#') {\n e.preventDefault();\n e.stopPropagation();\n }\n\n if (onClick) {\n onClick(e);\n }\n};\n\n/**\n * A reusable button. Uses a tag underneath.\n */\nconst Button = ({\n className,\n icon,\n children,\n accessibleLabel,\n isLoading,\n href,\n target,\n preventDefault,\n onClick,\n dialogTrigger,\n}) => {\n const hasText = children !== null;\n const iconName = isLoading ? 'spinner' : icon;\n const accessibleElt = accessibleLabel ? (\n \n {accessibleLabel}\n \n ) : null;\n\n return (\n \n {hasText ? children : accessibleElt}\n \n );\n};\n\nButton.propTypes = {\n href: PropTypes.string,\n className: PropTypes.string,\n icon: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.arrayOf(PropTypes.string),\n ]),\n target: PropTypes.string,\n children: PropTypes.node,\n accessibleLabel: PropTypes.string,\n onClick: PropTypes.func,\n isLoading: PropTypes.bool,\n preventDefault: PropTypes.bool,\n dialogTrigger: PropTypes.bool,\n};\n\nButton.defaultProps = {\n href: '#',\n className: '',\n icon: '',\n target: null,\n children: null,\n accessibleLabel: null,\n onClick: null,\n isLoading: false,\n preventDefault: true,\n dialogTrigger: false,\n};\n\nexport default Button;\n\n\n\n// WEBPACK FOOTER //\n// ./client/src/components/Button/Button.js"],"sourceRoot":""}