{"version":3,"file":"application-BXhhS2xC.js","sources":["../../../node_modules/react/cjs/react.production.min.js","../../../node_modules/react/index.js","../../../node_modules/react/cjs/react-jsx-runtime.production.min.js","../../../node_modules/react/jsx-runtime.js","../../../app/javascript/constants/admin_pages.ts","../../../app/javascript/constants/camping_styles.ts","../../../app/javascript/constants/electrics.ts","../../../app/javascript/constants/long_term_reservation_kinds.ts","../../../app/javascript/constants/kinds.ts","../../../app/javascript/constants/payment_modes.ts","../../../app/javascript/constants/prerequisites.ts","../../../app/javascript/constants/reservation_kinds.ts","../../../app/javascript/constants/reservation_statuses.ts","../../../app/assets/images/park__icon_ux__electric_15_30a_split.svg","../../../app/assets/images/park__icon_ux__electric_20_30a_split.svg","../../../app/assets/images/park__icon_ux__electric_30_50a_split.svg","../../../app/assets/images/park__icon_ux__electric_15_30_50a_split.svg","../../../app/assets/images/park__icon_ux__electric_20_30_50a_split.svg","../../../app/assets/images/park__icon_ux__electric_15a.svg","../../../app/assets/images/park__icon_ux__electric_20a.svg","../../../app/assets/images/park__icon_ux__electric_30a.svg","../../../app/assets/images/park__icon_ux__electric_50a.svg","../../../app/assets/images/park__icon_ux__electric.svg","../../../app/assets/images/park__icon_ux__electric_none.svg","../../../app/assets/images/park__icon_ux__kind_back_in.svg","../../../app/assets/images/park__icon_ux__kind_pull_through.svg","../../../app/assets/images/park__icon_ux__kind_hybrid.svg","../../../app/assets/images/park__icon_ux__tent.svg","../../../app/assets/images/park__icon_ux__cabin.svg","../../../app/assets/images/park__icon_ux__docks.svg","../../../app/assets/images/park__icon_ux__boat.svg","../../../app/assets/images/park__icon_ux__mobile_home.svg","../../../app/assets/images/park__icon_ux__storage.svg","../../../app/assets/images/park__icon_ux__pavilion.svg","../../../app/assets/images/park__icon_ux__cabana.svg","../../../app/assets/images/park__icon_ux__garage.svg","../../../app/assets/images/park__icon_ux__horse_pen.svg","../../../app/assets/images/park__icon_ux__shelter.svg","../../../app/assets/images/park__icon_ux__rv_storage.svg","../../../app/assets/images/park__icon_ux__event_center.svg","../../../app/assets/images/park__icon_ux__rental_rv.svg","../../../app/assets/images/park__icon_ux__lodge.svg","../../../app/assets/images/park__icon_ux__golf_cart.svg","../../../app/assets/images/park__icon_ux__pool.svg","../../../app/assets/images/park__icon_ux__vendor_booth.svg","../../../app/assets/images/park__icon_ux__disc_golf.svg","../../../app/assets/images/park__icon_ux__cs__dry_camping.svg","../../../app/assets/images/park__icon_ux__fire_pit.svg","../../../app/assets/images/park__icon_ux__cs__dome.svg","../../../app/assets/images/park__icon_ux__cs__glamping.svg","../../../app/assets/images/park__icon_ux__cs__home.svg","../../../app/assets/images/park__icon_ux__food_truck.svg","../../../app/assets/images/park__icon_ux__cube.svg","../../../app/assets/images/park__icon_ux__cs__main_house.svg","../../../app/assets/images/park__icon_ux__cs__cottage.svg","../../../app/assets/images/park__icon_ux__cs__platform.svg","../../../app/assets/images/park__icon_ux__cs__canvas_tent.svg","../../../app/assets/images/park__icon_ux__linens.svg","../../../app/assets/images/park__icon_ux__no_linens.svg","../../../app/assets/images/park__icon_ux__bed-v0.svg","../../../app/assets/images/park__icon_ux__cable_tv.svg","../../../app/assets/images/park__icon_ux__car_space.svg","../../../app/assets/images/park__icon_ux__dog_park.svg","../../../app/assets/images/park__icon_ux__dump_station.svg","../../../app/assets/images/park__icon_ux__no_fire_pit.svg","../../../app/assets/images/park__icon_ux__general_store.svg","../../../app/assets/images/park__icon_ux__laundry.svg","../../../app/assets/images/park__icon_ux__max_rig_length.svg","../../../app/assets/images/park__icon_ux__pad_type.svg","../../../app/assets/images/park__icon_ux__pets.svg","../../../app/assets/images/park__icon_ux__picnic_table.svg","../../../app/assets/images/park__icon_ux__no_picnic_table.svg","../../../app/assets/images/park__icon_ux__public_bathrooms.svg","../../../app/assets/images/park__icon_ux__public_kitchen.svg","../../../app/assets/images/park__icon_ux__sewage.svg","../../../app/assets/images/park__icon_ux__showers.svg","../../../app/assets/images/park__icon_ux__swimming_pool.svg","../../../app/assets/images/park__icon_ux__water.svg","../../../app/assets/images/park__icon_ux__no_water.svg","../../../app/assets/images/park__icon_ux__wifi.svg","../../../app/assets/images/park__icon_ux__premium_view.svg","../../../app/assets/images/park__icon_ux__heating.svg","../../../app/assets/images/park__icon_ux__microwave.svg","../../../app/assets/images/park__icon_ux__oven.svg","../../../app/assets/images/park__icon_ux__refrigerator.svg","../../../app/assets/images/park__icon_ux__stove.svg","../../../app/assets/images/park__icon_ux__air_conditioning.svg","../../../app/assets/images/park__icon_ux__private_bathroom.svg","../../../app/assets/images/park__icon_ux__bed_futon.svg","../../../app/assets/images/park__icon_ux__bed_king.svg","../../../app/assets/images/park__icon_ux__bed_queen.svg","../../../app/assets/images/park__icon_ux__bed_twin.svg","../../../app/assets/images/park__icon_ux__bed_single.svg","../../../app/assets/images/park__icon_ux__bed_bunk.svg","../../../app/assets/images/park__icon_ux__grill_barbecue.svg","../../../app/assets/images/park__icon_ux__restaurant.svg","../../../app/assets/images/park__icon_ux__basketball_court.svg","../../../app/assets/images/park__icon_ux__golf_course.svg","../../../app/assets/images/park__icon_ux__mini_golf_course.svg","../../../app/assets/images/park__icon_ux__playground.svg","../../../app/assets/images/park__icon_ux__propane_fill_up.svg","../../../app/assets/images/park__icon_ux__volleyball_court.svg","../../../app/assets/images/park__icon_ux__tv.svg","../../../app/assets/images/park__icon_ux__kayak.svg","../../../app/assets/images/park__icon_ux__tipi.svg","../../../app/assets/images/park__icon_ux__towel.svg","../../../app/assets/images/park__icon_ux__no_towel.svg","../../../app/assets/images/park__icon_ux__hotplate.svg","../../../app/assets/images/park__icon_ux__van.svg","../../../app/assets/images/park__icon_ux__room.svg","../../../app/assets/images/park__icon_ux__rental_item.svg","../../../app/assets/images/park__icon_ux__generator.svg","../../../app/assets/images/park__icon_ux__lock_fee.svg","../../../app/assets/images/park__icon_ux__firewood.svg","../../../app/assets/images/park__icon_ux__ice.svg","../../../app/assets/images/park__icon_ux__propane.svg","../../../app/assets/images/park__icon_ux__pet.svg","../../../app/assets/images/park__icon_ux__group.svg","../../../app/assets/images/park__icon_ux__pickup_truck.svg","../../../app/javascript/api2/utils/handle_error.ts","../../../app/javascript/api2/utils/check_ok_response.ts","../../../node_modules/moment/dist/moment.js","../../../node_modules/lodash/lodash.js","../../../app/javascript/api2/utils/requests.ts","../../../app/javascript/api2/add_ons.ts","../../../app/javascript/decorators/CamperDecorator.ts","../../../app/javascript/api2/campers.ts","../../../app/javascript/api2/camps.ts","../../../app/javascript/api2/camping_styles.ts","../../../app/javascript/api2/coupons.ts","../../../app/javascript/api2/date_availabilities.ts","../../../app/javascript/api2/utils/configs.ts","../../../app/javascript/api2/sites/index.ts","../../../app/javascript/api2/grouped_reservations.ts","../../../app/javascript/decorators/InvoiceDecorator.ts","../../../app/javascript/api2/invoices.ts","../../../app/javascript/api2/long_term_reservations.ts","../../../app/javascript/api2/messages.ts","../../../app/javascript/api2/me.ts","../../../app/javascript/constants/line_item_kinds.ts","../../../app/javascript/api2/orders.ts","../../../app/javascript/api2/payments.ts","../../../app/javascript/api2/payment_intents.ts","../../../app/javascript/api2/payment_links.ts","../../../app/javascript/api2/products.ts","../../../app/javascript/api2/reservations.ts","../../../app/javascript/api2/search.ts","../../../app/javascript/api2/sessions.ts","../../../app/javascript/api2/sites.ts","../../../app/javascript/api2/terminal.ts","../../../app/javascript/api2/users.ts","../../../app/javascript/api2/price_details.ts","../../../app/javascript/api2/reports.ts","../../../app/javascript/api2/automated_message.ts","../../../app/javascript/api2/electric_prices.ts","../../../app/javascript/api2/index.ts","../../../node_modules/react-ga4/dist/gtag.js","../../../node_modules/react-ga4/dist/format.js","../../../node_modules/react-ga4/dist/ga4.js","../../../node_modules/react-ga4/dist/index.js","../../../app/javascript/hooks/useGoogleAnalytics.ts","../../../app/javascript/utils/intervalKindFor.ts","../../../app/javascript/contexts/BookerContext.tsx","../../../app/javascript/utils/iconFor.ts","../../../node_modules/@heroicons/react/24/outline/esm/ArchiveBoxXMarkIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ArrowDownTrayIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ArrowPathRoundedSquareIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ArrowTopRightOnSquareIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ArrowUturnLeftIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/BanknotesIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ChatBubbleLeftIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/CheckBadgeIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/CheckCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/CheckIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ChevronRightIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ChevronUpDownIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ClockIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/Cog6ToothIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/CreditCardIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/CubeIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/CurrencyDollarIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/DocumentIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/EllipsisHorizontalIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/EnvelopeIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ExclamationCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ExclamationTriangleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/GlobeAltIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/InformationCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/LinkIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/MinusCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/NoSymbolIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/PhoneIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/PlusCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/PrinterIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/QuestionMarkCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/ReceiptRefundIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/RectangleStackIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/TagIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/TrashIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/TruckIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/UserIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/VideoCameraIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/WifiIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/XCircleIcon.js","../../../node_modules/@heroicons/react/24/outline/esm/XMarkIcon.js","../../../app/javascript/utils/formatMoney.ts","../../../node_modules/use-debounce/dist/index.module.js","../../../node_modules/@sentry/core/build/esm/debug-build.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/version.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/worldwide.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/debug-build.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/logger.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/stacktrace.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/instrument/handlers.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/instrument/globalError.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/instrument/globalUnhandledRejection.js","../../../node_modules/@sentry/core/build/esm/carrier.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/is.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/browser.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/string.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/object.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/time.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/misc.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/syncpromise.js","../../../node_modules/@sentry/core/build/esm/session.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/propagationContext.js","../../../node_modules/@sentry/core/build/esm/utils/merge.js","../../../node_modules/@sentry/core/build/esm/utils/spanOnScope.js","../../../node_modules/@sentry/core/build/esm/scope.js","../../../node_modules/@sentry/core/build/esm/defaultScopes.js","../../../node_modules/@sentry/core/build/esm/asyncContext/stackStrategy.js","../../../node_modules/@sentry/core/build/esm/asyncContext/index.js","../../../node_modules/@sentry/core/build/esm/currentScopes.js","../../../node_modules/@sentry/core/build/esm/metrics/metric-summary.js","../../../node_modules/@sentry/core/build/esm/semanticAttributes.js","../../../node_modules/@sentry/core/build/esm/tracing/spanstatus.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/baggage.js","../../../node_modules/@sentry/core/build/esm/utils/spanUtils.js","../../../node_modules/@sentry/core/build/esm/utils/hasTracingEnabled.js","../../../node_modules/@sentry/core/build/esm/constants.js","../../../node_modules/@sentry/core/build/esm/tracing/dynamicSamplingContext.js","../../../node_modules/@sentry/core/build/esm/utils/parseSampleRate.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/dsn.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/memo.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/normalize.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/envelope.js","../../../node_modules/@sentry/core/build/esm/envelope.js","../../../node_modules/@sentry/core/build/esm/eventProcessors.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/debug-ids.js","../../../node_modules/@sentry/core/build/esm/utils/applyScopeDataToEvent.js","../../../node_modules/@sentry/core/build/esm/utils/prepareEvent.js","../../../node_modules/@sentry/core/build/esm/exports.js","../../../node_modules/@sentry/core/build/esm/api.js","../../../node_modules/@sentry/core/build/esm/integration.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/clientreport.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/error.js","../../../node_modules/@sentry/core/build/esm/baseclient.js","../../../node_modules/@sentry/core/build/esm/sdk.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/promisebuffer.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/ratelimit.js","../../../node_modules/@sentry/core/build/esm/transports/base.js","../../../node_modules/@sentry/core/build/esm/utils/sdkMetadata.js","../../../node_modules/@sentry/core/build/esm/breadcrumbs.js","../../../node_modules/@sentry/core/build/esm/integrations/functiontostring.js","../../../node_modules/@sentry/core/build/esm/integrations/inboundfilters.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/aggregate-errors.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/url.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/instrument/console.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/severity.js","../../../node_modules/@sentry/core/build/esm/integrations/dedupe.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/breadcrumb-log-level.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/supports.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/instrument/fetch.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/env.js","../../../node_modules/@sentry/core/build/esm/utils-hoist/vendor/supportsHistory.js","../../../node_modules/@sentry/browser/build/npm/esm/helpers.js","../../../node_modules/@sentry/browser/build/npm/esm/debug-build.js","../../../node_modules/@sentry/browser/build/npm/esm/eventbuilder.js","../../../node_modules/@sentry/browser/build/npm/esm/userfeedback.js","../../../node_modules/@sentry/browser/build/npm/esm/client.js","../../../node_modules/@sentry-internal/browser-utils/build/esm/debug-build.js","../../../node_modules/@sentry-internal/browser-utils/build/esm/types.js","../../../node_modules/@sentry-internal/browser-utils/build/esm/instrument/dom.js","../../../node_modules/@sentry-internal/browser-utils/build/esm/instrument/history.js","../../../node_modules/@sentry-internal/browser-utils/build/esm/getNativeImplementation.js","../../../node_modules/@sentry-internal/browser-utils/build/esm/instrument/xhr.js","../../../node_modules/@sentry/browser/build/npm/esm/transports/fetch.js","../../../node_modules/@sentry/browser/build/npm/esm/stack-parsers.js","../../../node_modules/@sentry/browser/build/npm/esm/integrations/breadcrumbs.js","../../../node_modules/@sentry/browser/build/npm/esm/integrations/browserapierrors.js","../../../node_modules/@sentry/browser/build/npm/esm/integrations/browsersession.js","../../../node_modules/@sentry/browser/build/npm/esm/integrations/globalhandlers.js","../../../node_modules/@sentry/browser/build/npm/esm/integrations/httpcontext.js","../../../node_modules/@sentry/browser/build/npm/esm/integrations/linkederrors.js","../../../node_modules/@sentry/browser/build/npm/esm/sdk.js","../../../node_modules/@sentry/react/build/esm/sdk.js","../../../node_modules/@sentry/react/build/esm/error.js","../../../node_modules/react-is/cjs/react-is.production.min.js","../../../node_modules/react-is/index.js","../../../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../../../node_modules/@sentry/react/build/esm/debug-build.js","../../../node_modules/@sentry/react/build/esm/errorboundary.js","../../../app/javascript/utils/classNames.ts","../../../app/javascript/utils/sorts.ts","../../../app/javascript/components/AddOns/AddOns.tsx","../../../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../../../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../../../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../../../node_modules/scheduler/cjs/scheduler.production.min.js","../../../node_modules/scheduler/index.js","../../../node_modules/react-dom/cjs/react-dom.production.min.js","../../../node_modules/react-dom/index.js","../../../node_modules/@fluentui/react-component-ref/dist/es/utils.js","../../../node_modules/@fluentui/react-component-ref/dist/es/RefFindNode.js","../../../node_modules/@fluentui/react-component-ref/dist/es/RefForward.js","../../../node_modules/@fluentui/react-component-ref/dist/es/Ref.js","../../../node_modules/@babel/runtime/helpers/esm/extends.js","../../../node_modules/lodash-es/_baseHas.js","../../../node_modules/lodash-es/isArray.js","../../../node_modules/lodash-es/_freeGlobal.js","../../../node_modules/lodash-es/_root.js","../../../node_modules/lodash-es/_Symbol.js","../../../node_modules/lodash-es/_getRawTag.js","../../../node_modules/lodash-es/_objectToString.js","../../../node_modules/lodash-es/_baseGetTag.js","../../../node_modules/lodash-es/isObjectLike.js","../../../node_modules/lodash-es/isSymbol.js","../../../node_modules/lodash-es/_isKey.js","../../../node_modules/lodash-es/isObject.js","../../../node_modules/lodash-es/isFunction.js","../../../node_modules/lodash-es/_coreJsData.js","../../../node_modules/lodash-es/_isMasked.js","../../../node_modules/lodash-es/_toSource.js","../../../node_modules/lodash-es/_baseIsNative.js","../../../node_modules/lodash-es/_getValue.js","../../../node_modules/lodash-es/_getNative.js","../../../node_modules/lodash-es/_nativeCreate.js","../../../node_modules/lodash-es/_hashClear.js","../../../node_modules/lodash-es/_hashDelete.js","../../../node_modules/lodash-es/_hashGet.js","../../../node_modules/lodash-es/_hashHas.js","../../../node_modules/lodash-es/_hashSet.js","../../../node_modules/lodash-es/_Hash.js","../../../node_modules/lodash-es/_listCacheClear.js","../../../node_modules/lodash-es/eq.js","../../../node_modules/lodash-es/_assocIndexOf.js","../../../node_modules/lodash-es/_listCacheDelete.js","../../../node_modules/lodash-es/_listCacheGet.js","../../../node_modules/lodash-es/_listCacheHas.js","../../../node_modules/lodash-es/_listCacheSet.js","../../../node_modules/lodash-es/_ListCache.js","../../../node_modules/lodash-es/_Map.js","../../../node_modules/lodash-es/_mapCacheClear.js","../../../node_modules/lodash-es/_isKeyable.js","../../../node_modules/lodash-es/_getMapData.js","../../../node_modules/lodash-es/_mapCacheDelete.js","../../../node_modules/lodash-es/_mapCacheGet.js","../../../node_modules/lodash-es/_mapCacheHas.js","../../../node_modules/lodash-es/_mapCacheSet.js","../../../node_modules/lodash-es/_MapCache.js","../../../node_modules/lodash-es/memoize.js","../../../node_modules/lodash-es/_memoizeCapped.js","../../../node_modules/lodash-es/_stringToPath.js","../../../node_modules/lodash-es/_arrayMap.js","../../../node_modules/lodash-es/_baseToString.js","../../../node_modules/lodash-es/toString.js","../../../node_modules/lodash-es/_castPath.js","../../../node_modules/lodash-es/_baseIsArguments.js","../../../node_modules/lodash-es/isArguments.js","../../../node_modules/lodash-es/_isIndex.js","../../../node_modules/lodash-es/isLength.js","../../../node_modules/lodash-es/_toKey.js","../../../node_modules/lodash-es/_hasPath.js","../../../node_modules/lodash-es/has.js","../../../node_modules/lodash-es/_apply.js","../../../node_modules/lodash-es/last.js","../../../node_modules/lodash-es/_baseGet.js","../../../node_modules/lodash-es/_baseSlice.js","../../../node_modules/lodash-es/_parent.js","../../../node_modules/lodash-es/_baseInvoke.js","../../../node_modules/lodash-es/identity.js","../../../node_modules/lodash-es/_overRest.js","../../../node_modules/lodash-es/constant.js","../../../node_modules/lodash-es/_defineProperty.js","../../../node_modules/lodash-es/_baseSetToString.js","../../../node_modules/lodash-es/_shortOut.js","../../../node_modules/lodash-es/_setToString.js","../../../node_modules/lodash-es/_baseRest.js","../../../node_modules/lodash-es/invoke.js","../../../node_modules/prop-types/lib/ReactPropTypesSecret.js","../../../node_modules/prop-types/factoryWithThrowingShims.js","../../../node_modules/prop-types/index.js","../../../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../../../node_modules/lodash-es/isUndefined.js","../../../node_modules/lodash-es/_trimmedEndIndex.js","../../../node_modules/lodash-es/_baseTrim.js","../../../node_modules/lodash-es/toNumber.js","../../../node_modules/lodash-es/toFinite.js","../../../node_modules/lodash-es/toInteger.js","../../../node_modules/lodash-es/_arrayFilter.js","../../../node_modules/lodash-es/_createBaseFor.js","../../../node_modules/lodash-es/_baseFor.js","../../../node_modules/lodash-es/_baseTimes.js","../../../node_modules/lodash-es/stubFalse.js","../../../node_modules/lodash-es/isBuffer.js","../../../node_modules/lodash-es/_baseIsTypedArray.js","../../../node_modules/lodash-es/_baseUnary.js","../../../node_modules/lodash-es/_nodeUtil.js","../../../node_modules/lodash-es/isTypedArray.js","../../../node_modules/lodash-es/_arrayLikeKeys.js","../../../node_modules/lodash-es/_isPrototype.js","../../../node_modules/lodash-es/_overArg.js","../../../node_modules/lodash-es/_nativeKeys.js","../../../node_modules/lodash-es/_baseKeys.js","../../../node_modules/lodash-es/isArrayLike.js","../../../node_modules/lodash-es/keys.js","../../../node_modules/lodash-es/_baseForOwn.js","../../../node_modules/lodash-es/_createBaseEach.js","../../../node_modules/lodash-es/_baseEach.js","../../../node_modules/lodash-es/_baseFilter.js","../../../node_modules/lodash-es/_stackClear.js","../../../node_modules/lodash-es/_stackDelete.js","../../../node_modules/lodash-es/_stackGet.js","../../../node_modules/lodash-es/_stackHas.js","../../../node_modules/lodash-es/_stackSet.js","../../../node_modules/lodash-es/_Stack.js","../../../node_modules/lodash-es/_setCacheAdd.js","../../../node_modules/lodash-es/_setCacheHas.js","../../../node_modules/lodash-es/_SetCache.js","../../../node_modules/lodash-es/_arraySome.js","../../../node_modules/lodash-es/_cacheHas.js","../../../node_modules/lodash-es/_equalArrays.js","../../../node_modules/lodash-es/_Uint8Array.js","../../../node_modules/lodash-es/_mapToArray.js","../../../node_modules/lodash-es/_setToArray.js","../../../node_modules/lodash-es/_equalByTag.js","../../../node_modules/lodash-es/_arrayPush.js","../../../node_modules/lodash-es/_baseGetAllKeys.js","../../../node_modules/lodash-es/stubArray.js","../../../node_modules/lodash-es/_getSymbols.js","../../../node_modules/lodash-es/_getAllKeys.js","../../../node_modules/lodash-es/_equalObjects.js","../../../node_modules/lodash-es/_DataView.js","../../../node_modules/lodash-es/_Promise.js","../../../node_modules/lodash-es/_Set.js","../../../node_modules/lodash-es/_WeakMap.js","../../../node_modules/lodash-es/_getTag.js","../../../node_modules/lodash-es/_baseIsEqualDeep.js","../../../node_modules/lodash-es/_baseIsEqual.js","../../../node_modules/lodash-es/_baseIsMatch.js","../../../node_modules/lodash-es/_isStrictComparable.js","../../../node_modules/lodash-es/_getMatchData.js","../../../node_modules/lodash-es/_matchesStrictComparable.js","../../../node_modules/lodash-es/_baseMatches.js","../../../node_modules/lodash-es/get.js","../../../node_modules/lodash-es/_baseHasIn.js","../../../node_modules/lodash-es/hasIn.js","../../../node_modules/lodash-es/_baseMatchesProperty.js","../../../node_modules/lodash-es/_baseProperty.js","../../../node_modules/lodash-es/_basePropertyDeep.js","../../../node_modules/lodash-es/property.js","../../../node_modules/lodash-es/_baseIteratee.js","../../../node_modules/lodash-es/filter.js","../../../node_modules/lodash-es/isEmpty.js","../../../node_modules/lodash-es/_baseFindIndex.js","../../../node_modules/lodash-es/_baseIsNaN.js","../../../node_modules/lodash-es/_strictIndexOf.js","../../../node_modules/lodash-es/_baseIndexOf.js","../../../node_modules/lodash-es/_arrayIncludes.js","../../../node_modules/lodash-es/isArrayLikeObject.js","../../../node_modules/lodash-es/_arrayEach.js","../../../node_modules/lodash-es/_castFunction.js","../../../node_modules/lodash-es/forEach.js","../../../node_modules/semantic-ui-react/dist/es/lib/ModernAutoControlledComponent.js","../../../node_modules/lodash-es/_createFind.js","../../../node_modules/lodash-es/findIndex.js","../../../node_modules/lodash-es/find.js","../../../node_modules/lodash-es/_baseSome.js","../../../node_modules/lodash-es/some.js","../../../node_modules/semantic-ui-react/dist/es/lib/childrenUtils.js","../../../node_modules/semantic-ui-react/dist/es/lib/numberToWord.js","../../../node_modules/semantic-ui-react/dist/es/lib/classNameBuilders.js","../../../node_modules/lodash-es/_baseDifference.js","../../../node_modules/lodash-es/_isFlattenable.js","../../../node_modules/lodash-es/_baseFlatten.js","../../../node_modules/lodash-es/difference.js","../../../node_modules/lodash-es/_castSlice.js","../../../node_modules/lodash-es/_asciiToArray.js","../../../node_modules/lodash-es/_hasUnicode.js","../../../node_modules/lodash-es/_unicodeToArray.js","../../../node_modules/lodash-es/_stringToArray.js","../../../node_modules/lodash-es/_baseAssignValue.js","../../../node_modules/lodash-es/_assignValue.js","../../../node_modules/lodash-es/_baseSet.js","../../../node_modules/lodash-es/_basePickBy.js","../../../node_modules/lodash-es/_basePick.js","../../../node_modules/lodash-es/flatten.js","../../../node_modules/lodash-es/_flatRest.js","../../../node_modules/lodash-es/pick.js","../../../node_modules/lodash-es/_getPrototype.js","../../../node_modules/lodash-es/isPlainObject.js","../../../node_modules/lodash-es/isNil.js","../../../node_modules/lodash-es/_baseMap.js","../../../node_modules/lodash-es/map.js","../../../node_modules/exenv/index.js","../../../node_modules/@semantic-ui-react/event-stack/lib/cjs/event-stack.production.js","../../../node_modules/@semantic-ui-react/event-stack/lib/index.js","../../../node_modules/lodash-es/noop.js","../../../node_modules/lodash-es/_createSet.js","../../../node_modules/lodash-es/_baseUniq.js","../../../node_modules/lodash-es/uniq.js","../../../node_modules/lodash-es/isNumber.js","../../../node_modules/lodash-es/isString.js","../../../node_modules/lodash-es/isBoolean.js","../../../node_modules/clsx/dist/clsx.m.js","../../../node_modules/semantic-ui-react/dist/es/lib/factories.js","../../../node_modules/semantic-ui-react/dist/es/lib/getUnhandledProps.js","../../../node_modules/semantic-ui-react/dist/es/lib/getElementType.js","../../../node_modules/lodash-es/_baseValues.js","../../../node_modules/lodash-es/values.js","../../../node_modules/lodash-es/includes.js","../../../node_modules/semantic-ui-react/dist/es/lib/htmlPropsUtils.js","../../../node_modules/semantic-ui-react/dist/es/lib/isBrowser.js","../../../node_modules/lodash-es/_baseInRange.js","../../../node_modules/lodash-es/inRange.js","../../../node_modules/lodash-es/head.js","../../../node_modules/semantic-ui-react/dist/es/lib/doesNodeContainClick.js","../../../node_modules/semantic-ui-react/dist/es/lib/SUI.js","../../../node_modules/semantic-ui-react/dist/es/lib/normalizeTransitionDuration.js","../../../node_modules/lodash-es/isEqual.js","../../../node_modules/lodash-es/without.js","../../../node_modules/semantic-ui-react/dist/es/elements/Icon/IconGroup.js","../../../node_modules/semantic-ui-react/dist/es/elements/Icon/Icon.js","../../../node_modules/keyboard-key/src/keyboardKey.js","../../../node_modules/semantic-ui-react/dist/es/addons/Portal/PortalInner.js","../../../node_modules/semantic-ui-react/dist/es/addons/Portal/Portal.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dimmer/DimmerDimmable.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dimmer/DimmerInner.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dimmer/Dimmer.js","../../../node_modules/semantic-ui-react/dist/es/elements/Image/ImageGroup.js","../../../node_modules/semantic-ui-react/dist/es/elements/Image/Image.js","../../../node_modules/semantic-ui-react/dist/es/elements/Label/LabelDetail.js","../../../node_modules/semantic-ui-react/dist/es/elements/Label/LabelGroup.js","../../../node_modules/semantic-ui-react/dist/es/elements/Label/Label.js","../../../node_modules/semantic-ui-react/dist/es/elements/Button/ButtonContent.js","../../../node_modules/semantic-ui-react/dist/es/elements/Button/ButtonGroup.js","../../../node_modules/semantic-ui-react/dist/es/elements/Button/ButtonOr.js","../../../node_modules/semantic-ui-react/dist/es/elements/Button/Button.js","../../../node_modules/lodash-es/_arrayReduce.js","../../../node_modules/lodash-es/_baseReduce.js","../../../node_modules/lodash-es/reduce.js","../../../node_modules/shallowequal/index.js","../../../node_modules/semantic-ui-react/dist/es/collections/Menu/MenuHeader.js","../../../node_modules/lodash-es/_basePropertyOf.js","../../../node_modules/lodash-es/_deburrLetter.js","../../../node_modules/lodash-es/deburr.js","../../../node_modules/lodash-es/_asciiWords.js","../../../node_modules/lodash-es/_hasUnicodeWord.js","../../../node_modules/lodash-es/_unicodeWords.js","../../../node_modules/lodash-es/words.js","../../../node_modules/lodash-es/_createCompounder.js","../../../node_modules/lodash-es/_createCaseFirst.js","../../../node_modules/lodash-es/upperFirst.js","../../../node_modules/lodash-es/startCase.js","../../../node_modules/semantic-ui-react/dist/es/collections/Menu/MenuItem.js","../../../node_modules/semantic-ui-react/dist/es/collections/Menu/MenuMenu.js","../../../node_modules/semantic-ui-react/dist/es/collections/Menu/Menu.js","../../../node_modules/lodash-es/set.js","../../../node_modules/semantic-ui-react/dist/es/modules/Checkbox/Checkbox.js","../../../node_modules/semantic-ui-react/dist/es/addons/Radio/Radio.js","../../../node_modules/lodash-es/compact.js","../../../node_modules/lodash-es/_arrayEvery.js","../../../node_modules/lodash-es/_baseEvery.js","../../../node_modules/lodash-es/every.js","../../../node_modules/lodash-es/dropRight.js","../../../node_modules/lodash-es/_asciiSize.js","../../../node_modules/lodash-es/_unicodeSize.js","../../../node_modules/lodash-es/_stringSize.js","../../../node_modules/lodash-es/size.js","../../../node_modules/lodash-es/union.js","../../../node_modules/semantic-ui-react/dist/es/elements/Flag/Flag.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownDivider.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownItem.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownHeader.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownMenu.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownSearchInput.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownText.js","../../../node_modules/lodash-es/escapeRegExp.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/utils/getMenuOptions.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/utils/getSelectedIndex.js","../../../node_modules/semantic-ui-react/dist/es/modules/Dropdown/Dropdown.js","../../../node_modules/semantic-ui-react/dist/es/addons/Select/Select.js","../../../node_modules/semantic-ui-react/dist/es/addons/TextArea/TextArea.js","../../../node_modules/lodash-es/mapValues.js","../../../node_modules/lodash-es/_arrayAggregator.js","../../../node_modules/lodash-es/_baseAggregator.js","../../../node_modules/lodash-es/_createAggregator.js","../../../node_modules/lodash-es/keyBy.js","../../../node_modules/semantic-ui-react/dist/es/modules/Transition/utils/childMapping.js","../../../node_modules/semantic-ui-react/dist/es/modules/Transition/utils/wrapChild.js","../../../node_modules/semantic-ui-react/dist/es/modules/Transition/TransitionGroup.js","../../../node_modules/semantic-ui-react/dist/es/modules/Transition/utils/computeStatuses.js","../../../node_modules/semantic-ui-react/dist/es/modules/Transition/Transition.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormField.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormButton.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormCheckbox.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormDropdown.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormGroup.js","../../../node_modules/semantic-ui-react/dist/es/elements/Input/Input.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormInput.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormRadio.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormSelect.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/FormTextArea.js","../../../node_modules/semantic-ui-react/dist/es/collections/Form/Form.js","../../../node_modules/semantic-ui-react/dist/es/collections/Grid/GridColumn.js","../../../node_modules/semantic-ui-react/dist/es/collections/Grid/GridRow.js","../../../node_modules/semantic-ui-react/dist/es/collections/Grid/Grid.js","../../../node_modules/semantic-ui-react/dist/es/collections/Message/MessageContent.js","../../../node_modules/semantic-ui-react/dist/es/collections/Message/MessageHeader.js","../../../node_modules/semantic-ui-react/dist/es/collections/Message/MessageItem.js","../../../node_modules/semantic-ui-react/dist/es/collections/Message/MessageList.js","../../../node_modules/semantic-ui-react/dist/es/collections/Message/Message.js","../../../node_modules/semantic-ui-react/dist/es/elements/Container/Container.js","../../../node_modules/semantic-ui-react/dist/es/elements/Divider/Divider.js","../../../node_modules/semantic-ui-react/dist/es/elements/Header/HeaderSubheader.js","../../../node_modules/semantic-ui-react/dist/es/elements/Header/HeaderContent.js","../../../node_modules/semantic-ui-react/dist/es/elements/Header/Header.js","../../../node_modules/semantic-ui-react/dist/es/elements/Loader/Loader.js","../../../node_modules/semantic-ui-react/dist/es/elements/Segment/SegmentGroup.js","../../../node_modules/semantic-ui-react/dist/es/elements/Segment/SegmentInline.js","../../../node_modules/semantic-ui-react/dist/es/elements/Segment/Segment.js","../../../node_modules/semantic-ui-react/dist/es/modules/Accordion/AccordionTitle.js","../../../node_modules/semantic-ui-react/dist/es/modules/Accordion/AccordionContent.js","../../../node_modules/semantic-ui-react/dist/es/modules/Accordion/AccordionPanel.js","../../../node_modules/semantic-ui-react/dist/es/modules/Accordion/AccordionAccordion.js","../../../node_modules/semantic-ui-react/dist/es/modules/Accordion/Accordion.js","../../../node_modules/lodash-es/isElement.js","../../../node_modules/react-popper/lib/esm/Manager.js","../../../node_modules/react-popper/lib/esm/utils.js","../../../node_modules/@popperjs/core/lib/enums.js","../../../node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","../../../node_modules/@popperjs/core/lib/dom-utils/getWindow.js","../../../node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","../../../node_modules/@popperjs/core/lib/modifiers/applyStyles.js","../../../node_modules/@popperjs/core/lib/utils/getBasePlacement.js","../../../node_modules/@popperjs/core/lib/utils/math.js","../../../node_modules/@popperjs/core/lib/utils/userAgent.js","../../../node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","../../../node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","../../../node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","../../../node_modules/@popperjs/core/lib/dom-utils/contains.js","../../../node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","../../../node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","../../../node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","../../../node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","../../../node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","../../../node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","../../../node_modules/@popperjs/core/lib/utils/within.js","../../../node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","../../../node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","../../../node_modules/@popperjs/core/lib/utils/expandToHashMap.js","../../../node_modules/@popperjs/core/lib/modifiers/arrow.js","../../../node_modules/@popperjs/core/lib/utils/getVariation.js","../../../node_modules/@popperjs/core/lib/modifiers/computeStyles.js","../../../node_modules/@popperjs/core/lib/modifiers/eventListeners.js","../../../node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","../../../node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","../../../node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","../../../node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","../../../node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","../../../node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","../../../node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","../../../node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","../../../node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","../../../node_modules/@popperjs/core/lib/utils/rectToClientRect.js","../../../node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","../../../node_modules/@popperjs/core/lib/utils/computeOffsets.js","../../../node_modules/@popperjs/core/lib/utils/detectOverflow.js","../../../node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","../../../node_modules/@popperjs/core/lib/modifiers/flip.js","../../../node_modules/@popperjs/core/lib/modifiers/hide.js","../../../node_modules/@popperjs/core/lib/modifiers/offset.js","../../../node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","../../../node_modules/@popperjs/core/lib/utils/getAltAxis.js","../../../node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","../../../node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","../../../node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","../../../node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","../../../node_modules/@popperjs/core/lib/utils/orderModifiers.js","../../../node_modules/@popperjs/core/lib/utils/debounce.js","../../../node_modules/@popperjs/core/lib/utils/mergeByName.js","../../../node_modules/@popperjs/core/lib/createPopper.js","../../../node_modules/@popperjs/core/lib/popper.js","../../../node_modules/react-fast-compare/index.js","../../../node_modules/react-popper/lib/esm/usePopper.js","../../../node_modules/react-popper/lib/esm/Popper.js","../../../node_modules/lodash-es/_baseInverter.js","../../../node_modules/lodash-es/_createInverter.js","../../../node_modules/lodash-es/invert.js","../../../node_modules/semantic-ui-react/dist/es/modules/Popup/lib/positions.js","../../../node_modules/@babel/runtime/helpers/esm/typeof.js","../../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../../../node_modules/@babel/runtime/helpers/esm/createClass.js","../../../node_modules/semantic-ui-react/dist/es/modules/Popup/lib/createReferenceProxy.js","../../../node_modules/semantic-ui-react/dist/es/modules/Popup/PopupContent.js","../../../node_modules/semantic-ui-react/dist/es/modules/Popup/PopupHeader.js","../../../node_modules/semantic-ui-react/dist/es/modules/Popup/Popup.js","../../../node_modules/semantic-ui-react/dist/es/views/Card/CardDescription.js","../../../node_modules/semantic-ui-react/dist/es/views/Card/CardHeader.js","../../../node_modules/semantic-ui-react/dist/es/views/Card/CardMeta.js","../../../node_modules/semantic-ui-react/dist/es/views/Card/CardContent.js","../../../node_modules/semantic-ui-react/dist/es/views/Card/CardGroup.js","../../../node_modules/semantic-ui-react/dist/es/views/Card/Card.js","../../../app/javascript/enums/ePaymentType.ts","../../../app/javascript/reducers/newReservation.tsx","../../../node_modules/preact/dist/preact.module.js","../../../node_modules/preact/hooks/dist/hooks.module.js","../../../node_modules/preact/compat/dist/compat.module.js","../../../node_modules/@fullcalendar/core/internal-common.js","../../../node_modules/@fullcalendar/core/index.js","../../../node_modules/@fullcalendar/react/dist/index.js","../../../node_modules/@fullcalendar/interaction/index.js","../../../node_modules/luxon/src/errors.js","../../../node_modules/luxon/src/impl/formats.js","../../../node_modules/luxon/src/zone.js","../../../node_modules/luxon/src/zones/systemZone.js","../../../node_modules/luxon/src/zones/IANAZone.js","../../../node_modules/luxon/src/impl/locale.js","../../../node_modules/luxon/src/zones/fixedOffsetZone.js","../../../node_modules/luxon/src/zones/invalidZone.js","../../../node_modules/luxon/src/impl/zoneUtil.js","../../../node_modules/luxon/src/impl/digits.js","../../../node_modules/luxon/src/settings.js","../../../node_modules/luxon/src/impl/invalid.js","../../../node_modules/luxon/src/impl/conversions.js","../../../node_modules/luxon/src/impl/util.js","../../../node_modules/luxon/src/impl/english.js","../../../node_modules/luxon/src/impl/formatter.js","../../../node_modules/luxon/src/impl/regexParser.js","../../../node_modules/luxon/src/duration.js","../../../node_modules/luxon/src/interval.js","../../../node_modules/luxon/src/info.js","../../../node_modules/luxon/src/impl/diff.js","../../../node_modules/luxon/src/impl/tokenParser.js","../../../node_modules/luxon/src/datetime.js","../../../node_modules/@fullcalendar/luxon2/index.js","../../../node_modules/@fullcalendar/premium-common/index.js","../../../node_modules/@fullcalendar/scrollgrid/internal.js","../../../node_modules/@fullcalendar/timeline/internal.js","../../../node_modules/@fullcalendar/timeline/index.js","../../../node_modules/@fullcalendar/resource/internal-common.js","../../../node_modules/@fullcalendar/resource/index.js","../../../node_modules/@fullcalendar/resource-timeline/internal.js","../../../node_modules/@fullcalendar/resource-timeline/index.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowLeftCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowLeftOnRectangleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowLeftIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowPathRoundedSquareIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowPathIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowRightCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowRightEndOnRectangleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowRightIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowSmallDownIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowSmallUpIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowTopRightOnSquareIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowUturnLeftIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowUturnRightIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ArrowsUpDownIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/BoltIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/BookOpenIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/BuildingLibraryIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CalendarDaysIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CalendarIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ChatBubbleLeftIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CheckBadgeIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CheckCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CheckIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ChevronDownIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ChevronRightIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ChevronUpDownIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ChevronUpIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/Cog6ToothIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CreditCardIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/CurrencyDollarIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/DocumentCheckIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/DocumentMinusIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/DocumentPlusIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/DocumentTextIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/DocumentIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/EllipsisHorizontalIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/EnvelopeIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/ExclamationTriangleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/EyeSlashIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/EyeIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/InboxArrowDownIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/InformationCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/LinkIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/LockClosedIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/MagnifyingGlassIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/MapPinIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/MapIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/MegaphoneIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/MinusCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/NoSymbolIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/PencilIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/PlusCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/PlusIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/PrinterIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/SparklesIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/TagIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/TicketIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/TrashIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/TruckIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/UserCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/UserGroupIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/UserMinusIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/UserPlusIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/UserIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/XCircleIcon.js","../../../node_modules/@heroicons/react/24/solid/esm/XMarkIcon.js","../../../node_modules/@tanstack/virtual-core/dist/esm/utils.js","../../../node_modules/@tanstack/virtual-core/dist/esm/index.js","../../../node_modules/@tanstack/react-virtual/dist/esm/index.js","../../../node_modules/@headlessui/react/dist/utils/env.js","../../../node_modules/@headlessui/react/dist/hooks/use-iso-morphic-effect.js","../../../node_modules/@headlessui/react/dist/hooks/use-latest-value.js","../../../node_modules/@headlessui/react/dist/hooks/use-computed.js","../../../node_modules/@headlessui/react/dist/hooks/use-event.js","../../../node_modules/@headlessui/react/dist/hooks/use-controllable.js","../../../node_modules/@headlessui/react/dist/utils/micro-task.js","../../../node_modules/@headlessui/react/dist/utils/disposables.js","../../../node_modules/@headlessui/react/dist/hooks/use-disposables.js","../../../node_modules/@headlessui/react/dist/hooks/use-server-handoff-complete.js","../../../node_modules/@headlessui/react/dist/hooks/use-id.js","../../../node_modules/@headlessui/react/dist/utils/match.js","../../../node_modules/@headlessui/react/dist/utils/owner.js","../../../node_modules/@headlessui/react/dist/utils/focus-management.js","../../../node_modules/@headlessui/react/dist/utils/platform.js","../../../node_modules/@headlessui/react/dist/hooks/use-document-event.js","../../../node_modules/@headlessui/react/dist/hooks/use-window-event.js","../../../node_modules/@headlessui/react/dist/hooks/use-outside-click.js","../../../node_modules/@headlessui/react/dist/hooks/use-owner.js","../../../node_modules/@headlessui/react/dist/hooks/use-resolve-button-type.js","../../../node_modules/@headlessui/react/dist/hooks/use-sync-refs.js","../../../node_modules/@headlessui/react/dist/hooks/use-tracked-pointer.js","../../../node_modules/@headlessui/react/dist/hooks/use-tree-walker.js","../../../node_modules/@headlessui/react/dist/hooks/use-watch.js","../../../node_modules/@headlessui/react/dist/utils/class-names.js","../../../node_modules/@headlessui/react/dist/utils/render.js","../../../node_modules/@headlessui/react/dist/internal/hidden.js","../../../node_modules/@headlessui/react/dist/internal/open-closed.js","../../../node_modules/@headlessui/react/dist/utils/document-ready.js","../../../node_modules/@headlessui/react/dist/utils/active-element-history.js","../../../node_modules/@headlessui/react/dist/utils/bugs.js","../../../node_modules/@headlessui/react/dist/utils/calculate-active-index.js","../../../node_modules/@headlessui/react/dist/utils/form.js","../../../node_modules/@headlessui/react/dist/components/keyboard.js","../../../node_modules/@headlessui/react/dist/components/combobox/combobox.js","../../../node_modules/@headlessui/react/dist/hooks/use-event-listener.js","../../../node_modules/@headlessui/react/dist/hooks/use-is-mounted.js","../../../node_modules/@headlessui/react/dist/hooks/use-on-unmount.js","../../../node_modules/@headlessui/react/dist/hooks/use-tab-direction.js","../../../node_modules/@headlessui/react/dist/components/focus-trap/focus-trap.js","../../../node_modules/@headlessui/react/dist/internal/portal-force-root.js","../../../node_modules/@headlessui/react/dist/components/portal/portal.js","../../../node_modules/@headlessui/react/dist/use-sync-external-store-shim/useSyncExternalStoreShimClient.js","../../../node_modules/@headlessui/react/dist/use-sync-external-store-shim/useSyncExternalStoreShimServer.js","../../../node_modules/@headlessui/react/dist/use-sync-external-store-shim/index.js","../../../node_modules/@headlessui/react/dist/hooks/use-store.js","../../../node_modules/@headlessui/react/dist/utils/store.js","../../../node_modules/@headlessui/react/dist/hooks/document-overflow/adjust-scrollbar-padding.js","../../../node_modules/@headlessui/react/dist/hooks/document-overflow/handle-ios-locking.js","../../../node_modules/@headlessui/react/dist/hooks/document-overflow/prevent-scroll.js","../../../node_modules/@headlessui/react/dist/hooks/document-overflow/overflow-store.js","../../../node_modules/@headlessui/react/dist/hooks/document-overflow/use-document-overflow.js","../../../node_modules/@headlessui/react/dist/hooks/use-inert.js","../../../node_modules/@headlessui/react/dist/hooks/use-root-containers.js","../../../node_modules/@headlessui/react/dist/internal/stack-context.js","../../../node_modules/@headlessui/react/dist/components/description/description.js","../../../node_modules/@headlessui/react/dist/components/dialog/dialog.js","../../../node_modules/@headlessui/react/dist/utils/start-transition.js","../../../node_modules/@headlessui/react/dist/components/disclosure/disclosure.js","../../../node_modules/@headlessui/react/dist/utils/get-text-value.js","../../../node_modules/@headlessui/react/dist/hooks/use-text-value.js","../../../node_modules/@headlessui/react/dist/components/listbox/listbox.js","../../../node_modules/@headlessui/react/dist/components/menu/menu.js","../../../node_modules/@headlessui/react/dist/components/popover/popover.js","../../../node_modules/@headlessui/react/dist/components/label/label.js","../../../node_modules/@headlessui/react/dist/hooks/use-flags.js","../../../node_modules/@headlessui/react/dist/components/radio-group/radio-group.js","../../../node_modules/@headlessui/react/dist/components/switch/switch.js","../../../node_modules/@headlessui/react/dist/internal/focus-sentinel.js","../../../node_modules/@headlessui/react/dist/utils/stable-collection.js","../../../node_modules/@headlessui/react/dist/components/tabs/tabs.js","../../../node_modules/@headlessui/react/dist/utils/once.js","../../../node_modules/@headlessui/react/dist/components/transitions/utils/transition.js","../../../node_modules/@headlessui/react/dist/hooks/use-transition.js","../../../node_modules/@headlessui/react/dist/components/transitions/transition.js","../../../node_modules/@heroicons/react/20/solid/esm/ArrowPathIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ArrowRightIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ArrowTopRightOnSquareIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/BanknotesIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/BoltIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/CheckBadgeIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/CheckCircleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/CheckIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ChevronDownIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ChevronLeftIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ChevronRightIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ChevronUpIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/Cog6ToothIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/CreditCardIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/CurrencyDollarIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/DocumentCheckIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/DocumentTextIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/EnvelopeIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ExclamationCircleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ExclamationTriangleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/EyeIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/HashtagIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/InformationCircleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/LinkIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/LockClosedIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/NoSymbolIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/PaperAirplaneIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/PencilSquareIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/PencilIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/PhoneIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/PlusIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/QuestionMarkCircleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/ReceiptRefundIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/TagIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/TrashIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/UserCircleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/UserGroupIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/UserIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/XCircleIcon.js","../../../node_modules/@heroicons/react/20/solid/esm/XMarkIcon.js","../../../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../../../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../../../node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../../../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../../../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.mjs","../../../node_modules/ua-parser-js/dist/ua-parser.min.js","../../../node_modules/react-device-detect/dist/lib.js","../../../app/javascript/components/ui/HoverTip.tsx","../../../app/javascript/components/ui/Spinner.tsx","../../../app/javascript/utils/titleCase.tsx","../../../app/javascript/utils/formatName.ts","../../../node_modules/@tanstack/query-core/build/modern/subscribable.js","../../../node_modules/@tanstack/query-core/build/modern/utils.js","../../../node_modules/@tanstack/query-core/build/modern/focusManager.js","../../../node_modules/@tanstack/query-core/build/modern/onlineManager.js","../../../node_modules/@tanstack/query-core/build/modern/thenable.js","../../../node_modules/@tanstack/query-core/build/modern/retryer.js","../../../node_modules/@tanstack/query-core/build/modern/notifyManager.js","../../../node_modules/@tanstack/query-core/build/modern/removable.js","../../../node_modules/@tanstack/query-core/build/modern/query.js","../../../node_modules/@tanstack/query-core/build/modern/queryCache.js","../../../node_modules/@tanstack/query-core/build/modern/mutation.js","../../../node_modules/@tanstack/query-core/build/modern/mutationCache.js","../../../node_modules/@tanstack/query-core/build/modern/infiniteQueryBehavior.js","../../../node_modules/@tanstack/query-core/build/modern/queryClient.js","../../../node_modules/@tanstack/query-core/build/modern/queryObserver.js","../../../node_modules/@tanstack/query-core/build/modern/mutationObserver.js","../../../node_modules/@tanstack/react-query/build/modern/QueryClientProvider.js","../../../node_modules/@tanstack/react-query/build/modern/isRestoring.js","../../../node_modules/@tanstack/react-query/build/modern/QueryErrorResetBoundary.js","../../../node_modules/@tanstack/react-query/build/modern/utils.js","../../../node_modules/@tanstack/react-query/build/modern/errorBoundaryUtils.js","../../../node_modules/@tanstack/react-query/build/modern/suspense.js","../../../node_modules/@tanstack/react-query/build/modern/useBaseQuery.js","../../../node_modules/@tanstack/react-query/build/modern/useQuery.js","../../../node_modules/@tanstack/react-query/build/modern/useMutation.js","../../../app/javascript/constants/queryKeys.ts","../../../app/javascript/components/Admin/Reservations/ReservationHooks/useOrder.ts","../../../app/javascript/components/Admin/Reservations/ReservationHooks/useOrderInvoice.ts","../../../app/javascript/components/helpers/ReservationInvoiceWrapper.tsx","../../../app/javascript/components/ui/Admin/ContextMenu.tsx","../../../app/javascript/enums/eAdminUserRole.ts","../../../app/javascript/contexts/AdminContext.tsx","../../../app/javascript/components/ui/Button.tsx","../../../app/javascript/contexts/admin/ModalContext.tsx","../../../node_modules/react-hook-form/dist/index.esm.mjs","../../../app/javascript/contexts/FormContext.tsx","../../../app/javascript/hooks/useAdminForm.ts","../../../app/assets/images/park__icon_ux_no_fill__rv.svg?react","../../../app/assets/images/park__icon_ux_no_fill__tent.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cabin.svg?react","../../../app/assets/images/park__icon_ux_no_fill__docks.svg?react","../../../app/assets/images/park__icon_ux_no_fill__boat.svg?react","../../../app/assets/images/park__icon_ux_no_fill__mobile_home.svg?react","../../../app/assets/images/park__icon_ux_no_fill__storage.svg?react","../../../app/assets/images/park__icon_ux_no_fill__pavilion.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cabana.svg?react","../../../app/assets/images/park__icon_ux_no_fill__garage.svg?react","../../../app/assets/images/park__icon_ux__morning.svg?react","../../../app/assets/images/park__icon_ux__afternoon.svg?react","../../../app/assets/images/park__icon_ux__all_day.svg?react","../../../app/assets/images/park__icon_ux_no_fill__horse_pen.svg?react","../../../app/assets/images/park__icon_ux_no_fill__rv_storage.svg?react","../../../app/assets/images/park__icon_ux_no_fill__event_center.svg?react","../../../app/assets/images/park__icon_ux_no_fill__rental_rv.svg?react","../../../app/assets/images/park__icon_ux__single_reservation.svg?react","../../../app/assets/images/park__icon_ux__recurring_reservation.svg?react","../../../app/assets/images/park__icon_ux__group_reservation.svg?react","../../../app/assets/images/park__icon_ux__blocked_reservation.svg?react","../../../app/assets/images/park__icon_ux_no_fill__lodge.svg?react","../../../app/assets/images/park__icon_ux_no_fill__golf_cart.svg?react","../../../app/assets/images/park__icon_ux_no_fill__pool.svg?react","../../../app/assets/images/park__icon_ux_no_fill__vendor_booth.svg?react","../../../app/assets/images/park__icon_ux_no_fill__disc_golf.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__dry_camping.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__dome.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__glamping.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__home.svg?react","../../../app/assets/images/park__icon_ux_no_fill__pickup_truck.svg?react","../../../app/assets/images/park__icon_ux_no_fill__group.svg?react","../../../app/assets/images/park__icon_ux_no_fill__food_truck.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cube.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__cottage.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__main_house.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__tipi.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__kayak.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__van.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__room.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__generator.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__rental_item.svg?react","../../../app/assets/images/park__icon_ux_no_fill__picnic_table.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__kitchen.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__platform.svg?react","../../../app/assets/images/park__icon_ux_no_fill__cs__canvas_tent.svg?react","../../../app/assets/images/park__icon_ux__group_pay_separately.svg?react","../../../app/assets/images/park__icon_ux__group_pay_together.svg?react","../../../app/assets/images/park__icon_ux__rent_and_electric.svg?react","../../../app/assets/images/park__icon_ux__rent.svg?react","../../../app/assets/images/park__icon_ux__seasonal_and_electric.svg?react","../../../app/assets/images/park__icon_ux__seasonal.svg?react","../../../app/javascript/icon/index.tsx","../../../app/javascript/components/ui/SelectInput.tsx","../../../app/javascript/enums/eSendingMode.ts","../../../app/javascript/components/Reservations/sendingOptions.ts","../../../app/javascript/components/ui/CheckboxWithLabelForForm.tsx","../../../app/javascript/utils/parseDateTime.ts","../../../app/javascript/utils/dynamicRound.ts","../../../app/javascript/components/Admin/Orders/OrderSummary.tsx","../../../app/javascript/hooks/useBreakpoint.ts","../../../app/javascript/components/Admin/Reservations/UpdatingReservationsTable.tsx","../../../app/javascript/components/ui/CheckboxWithLabel.tsx","../../../node_modules/universal-cookie/esm/index.mjs","../../../node_modules/react-cookie/esm/index.mjs","../../../app/javascript/enums/eSendingModeCookieName.ts","../../../app/javascript/components/Admin/Reservations/ConfirmationModalContent.tsx","../../../app/javascript/components/Admin/Reservations/DeleteConfirmationModalContent.tsx","../../../app/javascript/components/Admin/Invoices/PreviewInvoiceToggle.tsx","../../../app/javascript/utils/formatAddress.ts","../../../app/javascript/components/ui/Admin/Form/TextAreaInput.tsx","../../../app/javascript/components/ui/Admin/Form/TextInput.tsx","../../../app/javascript/components/ui/Admin/Form/NumberInput.tsx","../../../app/javascript/components/ui/Admin/Form/DecimalInput.tsx","../../../app/javascript/components/ui/Admin/Form/SelectInput.tsx","../../../node_modules/lodash/_listCacheClear.js","../../../node_modules/lodash/eq.js","../../../node_modules/lodash/_assocIndexOf.js","../../../node_modules/lodash/_listCacheDelete.js","../../../node_modules/lodash/_listCacheGet.js","../../../node_modules/lodash/_listCacheHas.js","../../../node_modules/lodash/_listCacheSet.js","../../../node_modules/lodash/_ListCache.js","../../../node_modules/lodash/_stackClear.js","../../../node_modules/lodash/_stackDelete.js","../../../node_modules/lodash/_stackGet.js","../../../node_modules/lodash/_stackHas.js","../../../node_modules/lodash/_freeGlobal.js","../../../node_modules/lodash/_root.js","../../../node_modules/lodash/_Symbol.js","../../../node_modules/lodash/_getRawTag.js","../../../node_modules/lodash/_objectToString.js","../../../node_modules/lodash/_baseGetTag.js","../../../node_modules/lodash/isObject.js","../../../node_modules/lodash/isFunction.js","../../../node_modules/lodash/_coreJsData.js","../../../node_modules/lodash/_isMasked.js","../../../node_modules/lodash/_toSource.js","../../../node_modules/lodash/_baseIsNative.js","../../../node_modules/lodash/_getValue.js","../../../node_modules/lodash/_getNative.js","../../../node_modules/lodash/_Map.js","../../../node_modules/lodash/_nativeCreate.js","../../../node_modules/lodash/_hashClear.js","../../../node_modules/lodash/_hashDelete.js","../../../node_modules/lodash/_hashGet.js","../../../node_modules/lodash/_hashHas.js","../../../node_modules/lodash/_hashSet.js","../../../node_modules/lodash/_Hash.js","../../../node_modules/lodash/_mapCacheClear.js","../../../node_modules/lodash/_isKeyable.js","../../../node_modules/lodash/_getMapData.js","../../../node_modules/lodash/_mapCacheDelete.js","../../../node_modules/lodash/_mapCacheGet.js","../../../node_modules/lodash/_mapCacheHas.js","../../../node_modules/lodash/_mapCacheSet.js","../../../node_modules/lodash/_MapCache.js","../../../node_modules/lodash/_stackSet.js","../../../node_modules/lodash/_Stack.js","../../../node_modules/lodash/_setCacheAdd.js","../../../node_modules/lodash/_setCacheHas.js","../../../node_modules/lodash/_SetCache.js","../../../node_modules/lodash/_arraySome.js","../../../node_modules/lodash/_cacheHas.js","../../../node_modules/lodash/_equalArrays.js","../../../node_modules/lodash/_Uint8Array.js","../../../node_modules/lodash/_mapToArray.js","../../../node_modules/lodash/_setToArray.js","../../../node_modules/lodash/_equalByTag.js","../../../node_modules/lodash/_arrayPush.js","../../../node_modules/lodash/isArray.js","../../../node_modules/lodash/_baseGetAllKeys.js","../../../node_modules/lodash/_arrayFilter.js","../../../node_modules/lodash/stubArray.js","../../../node_modules/lodash/_getSymbols.js","../../../node_modules/lodash/_baseTimes.js","../../../node_modules/lodash/isObjectLike.js","../../../node_modules/lodash/_baseIsArguments.js","../../../node_modules/lodash/isArguments.js","../../../node_modules/lodash/stubFalse.js","../../../node_modules/lodash/isBuffer.js","../../../node_modules/lodash/_isIndex.js","../../../node_modules/lodash/isLength.js","../../../node_modules/lodash/_baseIsTypedArray.js","../../../node_modules/lodash/_baseUnary.js","../../../node_modules/lodash/_nodeUtil.js","../../../node_modules/lodash/isTypedArray.js","../../../node_modules/lodash/_arrayLikeKeys.js","../../../node_modules/lodash/_isPrototype.js","../../../node_modules/lodash/_overArg.js","../../../node_modules/lodash/_nativeKeys.js","../../../node_modules/lodash/_baseKeys.js","../../../node_modules/lodash/isArrayLike.js","../../../node_modules/lodash/keys.js","../../../node_modules/lodash/_getAllKeys.js","../../../node_modules/lodash/_equalObjects.js","../../../node_modules/lodash/_DataView.js","../../../node_modules/lodash/_Promise.js","../../../node_modules/lodash/_Set.js","../../../node_modules/lodash/_WeakMap.js","../../../node_modules/lodash/_getTag.js","../../../node_modules/lodash/_baseIsEqualDeep.js","../../../node_modules/lodash/_baseIsEqual.js","../../../node_modules/lodash/isEqual.js","../../../node_modules/quill/dist/quill.js","../../../node_modules/react-quill/lib/index.js","../../../app/javascript/utils/formatPhoneNumber.tsx","../../../app/javascript/utils/displayDates.tsx","../../../app/javascript/utils/displayPercentage.tsx","../../../app/javascript/config/quillToolbar.ts","../../../node_modules/domelementtype/lib/esm/index.js","../../../node_modules/domhandler/lib/esm/node.js","../../../node_modules/domhandler/lib/esm/index.js","../../../node_modules/entities/lib/generated/decode-data-html.js","../../../node_modules/entities/lib/generated/decode-data-xml.js","../../../node_modules/entities/lib/decode_codepoint.js","../../../node_modules/entities/lib/decode.js","../../../node_modules/entities/lib/generated/encode-html.js","../../../node_modules/entities/lib/escape.js","../../../node_modules/entities/lib/encode.js","../../../node_modules/entities/lib/index.js","../../../node_modules/dom-serializer/lib/esm/foreignNames.js","../../../node_modules/dom-serializer/lib/esm/index.js","../../../node_modules/domutils/lib/esm/stringify.js","../../../node_modules/domutils/lib/esm/traversal.js","../../../node_modules/domutils/lib/esm/manipulation.js","../../../node_modules/domutils/lib/esm/querying.js","../../../node_modules/domutils/lib/esm/legacy.js","../../../node_modules/domutils/lib/esm/helpers.js","../../../node_modules/domutils/lib/esm/feeds.js","../../../node_modules/cheerio/dist/browser/options.js","../../../node_modules/cheerio/dist/browser/static.js","../../../node_modules/cheerio/dist/browser/utils.js","../../../node_modules/cheerio/dist/browser/api/attributes.js","../../../node_modules/css-what/lib/es/types.js","../../../node_modules/css-what/lib/es/parse.js","../../../node_modules/boolbase/index.js","../../../node_modules/css-select/lib/esm/sort.js","../../../node_modules/css-select/lib/esm/attributes.js","../../../node_modules/nth-check/lib/esm/parse.js","../../../node_modules/nth-check/lib/esm/compile.js","../../../node_modules/nth-check/lib/esm/index.js","../../../node_modules/css-select/lib/esm/pseudo-selectors/filters.js","../../../node_modules/css-select/lib/esm/pseudo-selectors/pseudos.js","../../../node_modules/css-select/lib/esm/pseudo-selectors/aliases.js","../../../node_modules/css-select/lib/esm/pseudo-selectors/subselects.js","../../../node_modules/css-select/lib/esm/pseudo-selectors/index.js","../../../node_modules/css-select/lib/esm/general.js","../../../node_modules/css-select/lib/esm/compile.js","../../../node_modules/css-select/lib/esm/index.js","../../../node_modules/cheerio-select/lib/esm/positionals.js","../../../node_modules/cheerio-select/lib/esm/helpers.js","../../../node_modules/cheerio-select/lib/esm/index.js","../../../node_modules/cheerio/dist/browser/api/traversing.js","../../../node_modules/cheerio/dist/browser/parse.js","../../../node_modules/cheerio/dist/browser/api/manipulation.js","../../../node_modules/cheerio/dist/browser/api/css.js","../../../node_modules/cheerio/dist/browser/api/forms.js","../../../node_modules/cheerio/dist/browser/api/extract.js","../../../node_modules/cheerio/dist/browser/cheerio.js","../../../node_modules/cheerio/dist/browser/load.js","../../../node_modules/parse5/dist/common/unicode.js","../../../node_modules/parse5/dist/common/error-codes.js","../../../node_modules/parse5/dist/tokenizer/preprocessor.js","../../../node_modules/parse5/dist/common/token.js","../../../node_modules/entities/lib/esm/generated/decode-data-html.js","../../../node_modules/entities/lib/esm/generated/decode-data-xml.js","../../../node_modules/entities/lib/esm/decode_codepoint.js","../../../node_modules/entities/lib/esm/decode.js","../../../node_modules/parse5/dist/common/html.js","../../../node_modules/parse5/dist/tokenizer/index.js","../../../node_modules/parse5/dist/parser/open-element-stack.js","../../../node_modules/parse5/dist/parser/formatting-element-list.js","../../../node_modules/parse5/dist/tree-adapters/default.js","../../../node_modules/parse5/dist/common/doctype.js","../../../node_modules/parse5/dist/common/foreign-content.js","../../../node_modules/parse5/dist/parser/index.js","../../../node_modules/entities/lib/esm/escape.js","../../../node_modules/parse5/dist/serializer/index.js","../../../node_modules/parse5/dist/index.js","../../../node_modules/parse5-htmlparser2-tree-adapter/dist/index.js","../../../node_modules/cheerio/dist/browser/parsers/parse5-adapter.js","../../../node_modules/cheerio/node_modules/htmlparser2/lib/esm/Tokenizer.js","../../../node_modules/cheerio/node_modules/htmlparser2/lib/esm/Parser.js","../../../node_modules/cheerio/node_modules/htmlparser2/lib/esm/index.js","../../../node_modules/cheerio/dist/browser/load-parse.js","../../../node_modules/mensch/lib/debug.js","../../../node_modules/mensch/lib/lexer.js","../../../node_modules/mensch/lib/parser.js","../../../node_modules/mensch/lib/stringify.js","../../../node_modules/mensch/index.js","../../../node_modules/slick/parser.js","../../../node_modules/juice/lib/selector.js","../../../node_modules/juice/lib/property.js","../../../node_modules/juice/lib/utils.js","../../../node_modules/juice/lib/cheerio.js","../../../node_modules/juice/lib/numbers.js","../../../node_modules/juice/lib/variables.js","../../../node_modules/juice/lib/inline.js","../../../node_modules/juice/client.js","../../../app/javascript/constants/rich_text_input_styles.ts","../../../app/javascript/components/ui/Admin/Form/RichTextInput.tsx","../../../app/javascript/components/ui/Admin/Form/DollarFieldWithLabel.tsx","../../../app/javascript/components/ui/PercentFieldWithLabel.tsx","../../../app/javascript/components/ui/Admin/Form/index.ts","../../../node_modules/react-to-print/lib/index.js","../../../app/javascript/utils/createMarkup.ts","../../../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../../../node_modules/object-keys/isArguments.js","../../../node_modules/object-keys/implementation.js","../../../node_modules/object-keys/index.js","../../../node_modules/es-define-property/index.js","../../../node_modules/es-errors/syntax.js","../../../node_modules/es-errors/type.js","../../../node_modules/gopd/gOPD.js","../../../node_modules/gopd/index.js","../../../node_modules/define-data-property/index.js","../../../node_modules/has-property-descriptors/index.js","../../../node_modules/define-properties/index.js","../../../node_modules/es-object-atoms/index.js","../../../node_modules/es-errors/index.js","../../../node_modules/es-errors/eval.js","../../../node_modules/es-errors/range.js","../../../node_modules/es-errors/ref.js","../../../node_modules/es-errors/uri.js","../../../node_modules/math-intrinsics/abs.js","../../../node_modules/math-intrinsics/floor.js","../../../node_modules/math-intrinsics/max.js","../../../node_modules/math-intrinsics/min.js","../../../node_modules/math-intrinsics/pow.js","../../../node_modules/math-intrinsics/round.js","../../../node_modules/math-intrinsics/isNaN.js","../../../node_modules/math-intrinsics/sign.js","../../../node_modules/has-symbols/shams.js","../../../node_modules/has-symbols/index.js","../../../node_modules/get-proto/Reflect.getPrototypeOf.js","../../../node_modules/get-proto/Object.getPrototypeOf.js","../../../node_modules/function-bind/implementation.js","../../../node_modules/function-bind/index.js","../../../node_modules/call-bind-apply-helpers/functionCall.js","../../../node_modules/call-bind-apply-helpers/functionApply.js","../../../node_modules/call-bind-apply-helpers/reflectApply.js","../../../node_modules/call-bind-apply-helpers/actualApply.js","../../../node_modules/call-bind-apply-helpers/index.js","../../../node_modules/dunder-proto/get.js","../../../node_modules/get-proto/index.js","../../../node_modules/hasown/index.js","../../../node_modules/get-intrinsic/index.js","../../../node_modules/set-function-length/index.js","../../../node_modules/call-bind-apply-helpers/applyBind.js","../../../node_modules/call-bind/index.js","../../../node_modules/object-is/implementation.js","../../../node_modules/object-is/polyfill.js","../../../node_modules/object-is/shim.js","../../../node_modules/object-is/index.js","../../../node_modules/enzyme-shallow-equal/build/index.js","../../../node_modules/@babel/runtime/helpers/extends.js","../../../node_modules/@babel/runtime/helpers/assertThisInitialized.js","../../../node_modules/@babel/runtime/helpers/setPrototypeOf.js","../../../node_modules/@babel/runtime/helpers/inheritsLoose.js","../../../node_modules/@babel/runtime/helpers/typeof.js","../../../node_modules/@babel/runtime/helpers/toPrimitive.js","../../../node_modules/@babel/runtime/helpers/toPropertyKey.js","../../../node_modules/@babel/runtime/helpers/defineProperty.js","../../../node_modules/react-moment-proptypes/src/moment-validation-wrapper.js","../../../node_modules/react-moment-proptypes/src/core.js","../../../node_modules/react-moment-proptypes/src/index.js","../../../node_modules/airbnb-prop-types/build/mocks/index.js","../../../node_modules/airbnb-prop-types/index.js","../../../node_modules/@babel/runtime/helpers/interopRequireWildcard.js","../../../node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","../../../node_modules/@babel/runtime/helpers/objectWithoutProperties.js","../../../node_modules/is-callable/index.js","../../../node_modules/functions-have-names/index.js","../../../node_modules/call-bound/index.js","../../../node_modules/function.prototype.name/implementation.js","../../../node_modules/function.prototype.name/polyfill.js","../../../node_modules/function.prototype.name/shim.js","../../../node_modules/function.prototype.name/index.js","../../../node_modules/airbnb-prop-types/build/helpers/getComponentName.js","../../../node_modules/isarray/index.js","../../../node_modules/prop-types-exact/build/helpers/isPlainObject.js","../../../node_modules/airbnb-prop-types/build/helpers/isPlainObject.js","../../../node_modules/object.assign/implementation.js","../../../node_modules/object.assign/polyfill.js","../../../node_modules/object.assign/shim.js","../../../node_modules/object.assign/index.js","../../../node_modules/airbnb-prop-types/build/helpers/wrapValidator.js","../../../node_modules/airbnb-prop-types/build/ref.js","../../../node_modules/react-dates/node_modules/react-with-styles/lib/utils/emptyStylesFn.js","../../../node_modules/react-dates/node_modules/react-with-styles/lib/utils/perf.js","../../../node_modules/deepmerge/dist/cjs.js","../../../node_modules/react-with-direction/dist/constants.js","../../../node_modules/react-with-direction/dist/proptypes/brcast.js","../../../node_modules/es-object-atoms/RequireObjectCoercible.js","../../../node_modules/object.values/implementation.js","../../../node_modules/object.values/polyfill.js","../../../node_modules/object.values/shim.js","../../../node_modules/object.values/index.js","../../../node_modules/react-with-direction/dist/proptypes/direction.js","../../../node_modules/react-with-direction/dist/withDirection.js","../../../node_modules/react-dates/node_modules/react-with-styles/lib/WithStylesContext.js","../../../node_modules/react-dates/node_modules/react-with-styles/lib/ThemedStyleSheet.js","../../../node_modules/react-dates/node_modules/react-with-styles/lib/withStylesPropTypes.js","../../../node_modules/react-dates/node_modules/react-with-styles/lib/withStyles.js","../../../node_modules/performance-now/lib/performance-now.js","../../../node_modules/raf/index.js","../../../node_modules/react-dates/lib/defaultPhrases.js","../../../node_modules/react-dates/lib/utils/getPhrasePropTypes.js","../../../node_modules/react-dates/lib/utils/getPhrase.js","../../../node_modules/react-dates/lib/constants.js","../../../node_modules/react-dates/lib/utils/getCalendarDaySettings.js","../../../node_modules/@babel/runtime/helpers/arrayLikeToArray.js","../../../node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","../../../node_modules/@babel/runtime/helpers/iterableToArray.js","../../../node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","../../../node_modules/@babel/runtime/helpers/nonIterableSpread.js","../../../node_modules/@babel/runtime/helpers/toConsumableArray.js","../../../node_modules/react-dates/lib/shapes/ModifiersShape.js","../../../node_modules/react-dates/lib/components/CalendarDay.js","../../../node_modules/react-dates/lib/components/CalendarWeek.js","../../../node_modules/react-dates/lib/utils/calculateDimension.js","../../../node_modules/react-dates/lib/utils/getCalendarMonthWeeks.js","../../../node_modules/react-dates/lib/utils/isSameDay.js","../../../node_modules/react-dates/lib/utils/toMomentObject.js","../../../node_modules/react-dates/lib/utils/toISODateString.js","../../../node_modules/react-dates/lib/shapes/ScrollableOrientationShape.js","../../../node_modules/react-dates/lib/shapes/DayOfWeekShape.js","../../../node_modules/react-dates/lib/components/CalendarMonth.js","../../../node_modules/consolidated-events/lib/index.esm.js","../../../node_modules/react-dates/lib/utils/noflip.js","../../../node_modules/react-dates/lib/utils/isTransitionEndSupported.js","../../../node_modules/react-dates/lib/utils/getTransformStyles.js","../../../node_modules/react-dates/lib/utils/getCalendarMonthWidth.js","../../../node_modules/react-dates/lib/utils/toISOMonthString.js","../../../node_modules/react-dates/lib/utils/isSameMonth.js","../../../node_modules/react-dates/lib/utils/isPrevMonth.js","../../../node_modules/react-dates/lib/utils/isNextMonth.js","../../../node_modules/react-dates/lib/components/CalendarMonthGrid.js","../../../node_modules/react-portal/es/utils.js","../../../node_modules/react-portal/es/Portal.js","../../../node_modules/react-portal/es/LegacyPortal.js","../../../node_modules/react-portal/es/PortalCompat.js","../../../node_modules/react-portal/es/PortalWithState.js","../../../node_modules/is-touch-device/build/index.js","../../../node_modules/document.contains/implementation.js","../../../node_modules/document.contains/polyfill.js","../../../node_modules/document.contains/shim.js","../../../node_modules/document.contains/index.js","../../../node_modules/react-outside-click-handler/build/OutsideClickHandler.js","../../../node_modules/react-outside-click-handler/index.js","../../../node_modules/react-dates/lib/shapes/FocusedInputShape.js","../../../node_modules/react-dates/lib/shapes/IconPositionShape.js","../../../node_modules/react-dates/lib/shapes/OrientationShape.js","../../../node_modules/react-dates/lib/shapes/DisabledShape.js","../../../node_modules/react-dates/lib/shapes/AnchorDirectionShape.js","../../../node_modules/react-dates/lib/shapes/OpenDirectionShape.js","../../../node_modules/react-dates/lib/shapes/CalendarInfoPositionShape.js","../../../node_modules/react-dates/lib/shapes/NavPositionShape.js","../../../node_modules/react-dates/lib/shapes/DateRangePickerShape.js","../../../node_modules/react-dates/lib/utils/getResponsiveContainerStyles.js","../../../node_modules/react-dates/lib/utils/getDetachedContainerStyles.js","../../../node_modules/react-dates/lib/utils/getInputHeight.js","../../../node_modules/react-dates/lib/utils/isBeforeDay.js","../../../node_modules/react-dates/lib/utils/isInclusivelyAfterDay.js","../../../node_modules/react-dates/lib/utils/disableScroll.js","../../../node_modules/lodash/now.js","../../../node_modules/lodash/_trimmedEndIndex.js","../../../node_modules/lodash/_baseTrim.js","../../../node_modules/lodash/isSymbol.js","../../../node_modules/lodash/toNumber.js","../../../node_modules/lodash/debounce.js","../../../node_modules/lodash/throttle.js","../../../node_modules/react-dates/lib/components/DateInput.js","../../../node_modules/react-dates/lib/components/RightArrow.js","../../../node_modules/react-dates/lib/components/LeftArrow.js","../../../node_modules/react-dates/lib/components/CloseButton.js","../../../node_modules/react-dates/lib/components/CalendarIcon.js","../../../node_modules/react-dates/lib/components/DateRangePickerInput.js","../../../node_modules/react-dates/lib/utils/toLocalizedDateString.js","../../../node_modules/react-dates/lib/components/DateRangePickerInputController.js","../../../node_modules/@babel/runtime/helpers/arrayWithHoles.js","../../../node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","../../../node_modules/@babel/runtime/helpers/nonIterableRest.js","../../../node_modules/@babel/runtime/helpers/slicedToArray.js","../../../node_modules/react-dates/lib/utils/isNextDay.js","../../../node_modules/react-dates/lib/utils/isAfterDay.js","../../../node_modules/react-dates/lib/utils/isPreviousDay.js","../../../node_modules/react-dates/lib/utils/getVisibleDays.js","../../../node_modules/react-dates/lib/utils/isDayVisible.js","../../../node_modules/react-dates/lib/utils/getSelectedDateOffset.js","../../../node_modules/react-dates/lib/utils/getPreviousMonthMemoLast.js","../../../node_modules/react-dates/lib/utils/modifiers.js","../../../node_modules/react-dates/lib/components/ChevronUp.js","../../../node_modules/react-dates/lib/components/ChevronDown.js","../../../node_modules/react-dates/lib/components/DayPickerNavigation.js","../../../node_modules/react-dates/lib/components/KeyboardShortcutRow.js","../../../node_modules/react-dates/lib/components/DayPickerKeyboardShortcuts.js","../../../node_modules/react-dates/lib/utils/getNumberOfCalendarMonthWeeks.js","../../../node_modules/react-dates/lib/utils/getActiveElement.js","../../../node_modules/react-dates/lib/components/DayPicker.js","../../../node_modules/react-dates/lib/utils/getPooledMoment.js","../../../node_modules/react-dates/lib/components/DayPickerRangeController.js","../../../node_modules/react-dates/lib/components/DateRangePicker.js","../../../node_modules/react-dates/lib/components/DayPickerSingleDateController.js","../../../node_modules/react-dates/lib/shapes/SingleDatePickerShape.js","../../../node_modules/react-dates/lib/components/SingleDatePickerInput.js","../../../node_modules/react-dates/lib/components/SingleDatePickerInputController.js","../../../node_modules/react-dates/lib/components/SingleDatePicker.js","../../../node_modules/react-dates/lib/utils/isInclusivelyBeforeDay.js","../../../node_modules/react-dates/lib/index.js","../../../node_modules/react-dates/index.js","../../../app/javascript/interfaces/IAddOn.ts","../../../app/javascript/components/ErrorBoundary.tsx","../../../app/javascript/contexts/admin/ModalProvider.tsx","../../../app/javascript/components/ui/Modal.tsx","../../../app/javascript/components/Admin/Products/ProductDropdown.tsx","../../../app/javascript/utils/currencySymbol.ts","../../../app/javascript/components/Admin/Invoices/EditInvoice/components/LineItemRow.tsx","../../../app/javascript/components/Admin/Invoices/EditInvoice/components/LineItemsTable.tsx","../../../app/javascript/components/Admin/Invoices/EditInvoice/components/MobileLineItemsTable.tsx","../../../app/javascript/components/ui/Admin/DropdownButton.tsx","../../../app/javascript/components/ui/Toggle.tsx","../../../app/javascript/components/ui/PortalHoverTip.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/FeesAndTaxesSettings.tsx","../../../app/javascript/components/Admin/Invoices/hooks/useSetTaxFees.tsx","../../../app/javascript/components/Admin/Invoices/constants/index.ts","../../../node_modules/moment/moment.js","../../../app/javascript/components/Admin/Invoices/utils/index.ts","../../../app/javascript/components/Admin/Invoices/hooks/useApplyElectricFees.ts","../../../app/javascript/utils/isValidEmail.ts","../../../app/javascript/components/Reservations/components/IsInvalidSendingMode.tsx","../../../app/javascript/utils/pluralize.ts","../../../app/javascript/components/ui/StatusBadges.tsx","../../../app/javascript/utils/avatarFor.tsx","../../../app/javascript/utils/generateAvatar.ts","../../../app/javascript/utils/generateNaturalHexColor.ts","../../../app/javascript/utils/formatLengthUnit.ts","../../../app/javascript/components/Admin/Campers/Camper/ProfileCard.tsx","../../../app/javascript/utils/admin/electricOptionsFor.ts","../../../app/javascript/constants/camp_slugs_with_company_name_field.ts","../../../app/javascript/components/Admin/Reservations/CamperDropdown.tsx","../../../app/javascript/components/Admin/Reservations/ReservationHooks/useReservation.ts","../../../app/javascript/components/Admin/Campers/NewCamperModalContent.tsx","../../../app/javascript/components/Admin/Reservations/ReservationHooks/usePreviews.ts","../../../node_modules/@stripe/stripe-js/dist/index.mjs","../../../app/javascript/constants/stripe.ts","../../../app/javascript/hooks/useCreateOrderPreview.ts","../../../app/javascript/components/Invoices/PublicInvoices/useBuildPriceDetails.ts","../../../node_modules/@rails/actioncable/app/assets/javascripts/actioncable.esm.js","../../../app/javascript/channels/consumer.js","../../../app/javascript/channels/reservations_channel.js","../../../app/javascript/channels/live_web_app_notifications_channel.js","../../../app/javascript/hooks/useWebsocket.ts","../../../app/javascript/contexts/InvoicePaymentsProvider.tsx","../../../app/javascript/components/Admin/Invoices/EditInvoice.tsx","../../../app/javascript/decorators/ReservationDecorator.ts","../../../app/javascript/contexts/admin/ReservationContextMenuContext.tsx","../../../app/assets/images/vendor_icons/Airbnb.svg?react","../../../app/assets/images/vendor_icons/booking.svg?react","../../../app/assets/images/vendor_icons/hipcamp.svg?react","../../../app/assets/images/vendor_icons/vrbo.svg?react","../../../app/assets/images/park__icon_ux__check_out.svg","../../../app/javascript/components/Reservations/EventButton.tsx","../../../app/javascript/utils/isRvKind.ts","../../../app/javascript/components/ui/ExternalSvg.tsx","../../../app/javascript/components/SiteIcons.tsx","../../../app/javascript/components/ui/SlideoverForm.tsx","../../../app/javascript/constants/price_durations.ts","../../../node_modules/styled-components/node_modules/tslib/tslib.es6.mjs","../../../node_modules/stylis/src/Enum.js","../../../node_modules/stylis/src/Utility.js","../../../node_modules/stylis/src/Tokenizer.js","../../../node_modules/stylis/src/Parser.js","../../../node_modules/stylis/src/Prefixer.js","../../../node_modules/stylis/src/Serializer.js","../../../node_modules/stylis/src/Middleware.js","../../../node_modules/@emotion/unitless/dist/emotion-unitless.esm.js","../../../node_modules/styled-components/dist/styled-components.browser.esm.js","../../../node_modules/react-drag-drop-files/dist/react-drag-drop-files.esm.js","../../../app/javascript/hooks/useSitePhotos.ts","../../../app/javascript/components/Admin/SitePhotoUpload.tsx","../../../app/javascript/components/ui/RichTextInput.tsx","../../../app/javascript/components/Admin/Inputs/InputFieldWithCurrency.tsx","../../../app/javascript/components/Admin/Inputs/InputFieldWithButton.tsx","../../../app/javascript/utils/copyText.ts","../../../app/javascript/components/ui/CopyPasteButton.tsx","../../../app/javascript/utils/admin/baseUrl.ts","../../../app/javascript/components/Admin/VendorCalendars/VendorCalendarModalContent.tsx","../../../app/javascript/utils/formatCampingStyleName.ts","../../../app/javascript/components/DetailsPayment/Feature.tsx","../../../app/javascript/components/Sites/SiteFeatures.ts","../../../app/javascript/components/Admin/Reservations/EditSiteForm.tsx","../../../app/javascript/components/Admin/Reservations/ReservationHooks/useHistory.ts","../../../app/javascript/contexts/admin/EditReservationContext.tsx","../../../app/javascript/utils/formatDateRange.ts","../../../app/javascript/components/ui/ReservationSlideoverForm.tsx","../../../node_modules/math-intrinsics/isFinite.js","../../../node_modules/math-intrinsics/isInteger.js","../../../node_modules/math-intrinsics/constants/maxArrayLength.js","../../../node_modules/set-proto/Reflect.setPrototypeOf.js","../../../node_modules/set-proto/Object.setPrototypeOf.js","../../../node_modules/dunder-proto/set.js","../../../node_modules/set-proto/index.js","../../../node_modules/es-abstract/2024/ArrayCreate.js","../../../__vite-browser-external","../../../node_modules/object-inspect/index.js","../../../node_modules/es-abstract/helpers/isObject.js","../../../node_modules/es-abstract/helpers/isPropertyKey.js","../../../node_modules/es-abstract/2024/Get.js","../../../node_modules/es-abstract/helpers/IsArray.js","../../../node_modules/es-abstract/2024/IsArray.js","../../../node_modules/es-abstract/GetIntrinsic.js","../../../node_modules/es-abstract/helpers/records/property-descriptor.js","../../../node_modules/es-abstract/helpers/DefineOwnProperty.js","../../../node_modules/es-abstract/helpers/fromPropertyDescriptor.js","../../../node_modules/es-abstract/2024/FromPropertyDescriptor.js","../../../node_modules/es-abstract/2024/IsDataDescriptor.js","../../../node_modules/es-abstract/2024/SameValue.js","../../../node_modules/es-abstract/2024/IsCallable.js","../../../node_modules/es-abstract/2024/ToBoolean.js","../../../node_modules/es-abstract/2024/ToPropertyDescriptor.js","../../../node_modules/es-abstract/2024/DefinePropertyOrThrow.js","../../../node_modules/es-abstract/2024/IsConstructor.js","../../../node_modules/es-abstract/2024/ArraySpeciesCreate.js","../../../node_modules/math-intrinsics/constants/maxSafeInteger.js","../../../node_modules/es-abstract/2024/Call.js","../../../node_modules/es-abstract/2024/IsAccessorDescriptor.js","../../../node_modules/es-abstract/helpers/isPrimitive.js","../../../node_modules/es-abstract/2024/IsExtensible.js","../../../node_modules/es-abstract/helpers/isFullyPopulatedPropertyDescriptor.js","../../../node_modules/es-abstract/2024/IsGenericDescriptor.js","../../../node_modules/es-abstract/5/Type.js","../../../node_modules/es-abstract/2024/Type.js","../../../node_modules/es-abstract/2024/ValidateAndApplyPropertyDescriptor.js","../../../node_modules/es-abstract/2024/OrdinaryDefineOwnProperty.js","../../../node_modules/es-abstract/2024/CreateDataProperty.js","../../../node_modules/es-abstract/2024/CreateDataPropertyOrThrow.js","../../../node_modules/es-abstract/2024/HasProperty.js","../../../node_modules/es-to-primitive/helpers/isPrimitive.js","../../../node_modules/has-tostringtag/shams.js","../../../node_modules/is-date-object/index.js","../../../node_modules/is-regex/index.js","../../../node_modules/safe-regex-test/index.js","../../../node_modules/is-symbol/index.js","../../../node_modules/es-to-primitive/es2015.js","../../../node_modules/es-abstract/2024/ToPrimitive.js","../../../node_modules/es-abstract/2024/ToString.js","../../../node_modules/string.prototype.trim/implementation.js","../../../node_modules/string.prototype.trim/polyfill.js","../../../node_modules/string.prototype.trim/shim.js","../../../node_modules/string.prototype.trim/index.js","../../../node_modules/es-abstract/2024/StringToNumber.js","../../../node_modules/es-abstract/2024/ToNumber.js","../../../node_modules/es-abstract/2024/floor.js","../../../node_modules/es-abstract/2024/truncate.js","../../../node_modules/es-abstract/2024/ToIntegerOrInfinity.js","../../../node_modules/es-abstract/2024/ToLength.js","../../../node_modules/es-abstract/2024/LengthOfArrayLike.js","../../../node_modules/es-abstract/2024/FlattenIntoArray.js","../../../node_modules/es-object-atoms/ToObject.js","../../../node_modules/es-abstract/2024/ToObject.js","../../../node_modules/array.prototype.flat/implementation.js","../../../node_modules/array.prototype.flat/polyfill.js","../../../node_modules/es-shim-unscopables/index.js","../../../node_modules/array.prototype.flat/shim.js","../../../node_modules/array.prototype.flat/index.js","../../../node_modules/global-cache/index.js","../../../node_modules/react-with-styles-interface-css/dist/utils/constants.js","../../../node_modules/react-with-styles-interface-css/dist/utils/getClassName.js","../../../node_modules/react-with-styles-interface-css/dist/utils/separateStyles.js","../../../node_modules/react-with-styles-interface-css/dist/index.js","../../../node_modules/react-with-styles-interface-css/index.js","../../../node_modules/react-dates/lib/theme/DefaultTheme.js","../../../node_modules/react-dates/lib/utils/registerInterfaceWithDefaultTheme.js","../../../node_modules/react-dates/lib/utils/registerCSSInterfaceWithDefaultTheme.js","../../../node_modules/react-dates/lib/initialize.js","../../../app/javascript/components/Admin/Reservations/ReservationsDatePicker.tsx","../../../app/javascript/components/Admin/Reservations/CampingStyleSettingsSlideover.tsx","../../../app/javascript/components/ui/Accordian.tsx","../../../app/javascript/utils/admin/isServiceFeePaymentMethod.ts","../../../app/javascript/utils/serviceRateModeForPaymentType.ts","../../../app/javascript/utils/priceDetailsFor.ts","../../../app/javascript/components/Admin/Reservations/NewReservationModal/utils.ts","../../../app/javascript/contexts/admin/NewReservationContext.tsx","../../../app/javascript/components/Admin/PriceDetail.tsx","../../../app/javascript/utils/twoDecimalPlaces.ts","../../../app/javascript/components/Admin/Reservations/AutochargeConfirmationContent.tsx","../../../app/javascript/api.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/Summary/useSummary.ts","../../../app/javascript/components/Reservations/SitesDropdown/generateSiteOptions.ts","../../../app/javascript/components/Reservations/components/InlineWarningNotification.tsx","../../../node_modules/@heroicons/react/16/solid/esm/CheckIcon.js","../../../node_modules/@heroicons/react/16/solid/esm/LockClosedIcon.js","../../../node_modules/@heroicons/react/16/solid/esm/MapPinIcon.js","../../../node_modules/@heroicons/react/16/solid/esm/SparklesIcon.js","../../../app/javascript/components/Reservations/SitesDropdown/SitesDropdown.tsx","../../../app/javascript/components/Admin/Reservations/BookingIntervalsDropdown.tsx","../../../app/javascript/components/Admin/Inputs/InputFieldWithLabel.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/Summary/Summary.tsx","../../../app/javascript/components/Admin/Reservations/ReservationHooks/useCamper.ts","../../../node_modules/@stripe/react-stripe-js/dist/react-stripe.esm.mjs","../../../app/javascript/components/Admin/Campers/PaymentMethodModalContent.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/Guests/useGuest.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/Guests/Guest.tsx","../../../app/assets/images/refund.png","../../../app/javascript/components/Admin/Inputs/TextAreaWithLabel.tsx","../../../app/javascript/components/ui/Admin/ProcessingState.tsx","../../../app/javascript/components/Reservations/RefundModal/RefundOptionsSelector.tsx","../../../app/javascript/components/Reservations/RefundModal/RefundOptions.ts","../../../app/javascript/components/Reservations/RefundModal/RefundOrderSummary.tsx","../../../app/javascript/enums/ePaymentMode.ts","../../../app/javascript/components/Reservations/RefundModal/RefundModalContents.tsx","../../../app/javascript/hooks/useRevertPayment.ts","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationHistory/ReservationHistory.tsx","../../../app/javascript/components/ui/ToggleLine.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationInvoice/useReservationInvoice.ts","../../../app/javascript/components/ui/Admin/Badge.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationInvoice/TakePaymentButton/useTakePaymentButton.ts","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationInvoice/TakePaymentButton/index.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationInvoice/EditInvoiceButton/useEditInvoiceButton.ts","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationInvoice/EditInvoiceButton/index.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/ReservationInvoice/ReservationInvoice.tsx","../../../node_modules/signature_pad/dist/signature_pad.mjs","../../../node_modules/trim-canvas/build/index.js","../../../node_modules/react-signature-canvas/build/index.js","../../../app/javascript/components/TermsAgreementModal.tsx","../../../app/javascript/components/Admin/LongTermReservations/hooks/useLongTermReservation.ts","../../../app/javascript/components/Admin/LongTermReservations/LongTermReservationModalContent.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm/GroupedReservationLinkField.tsx","../../../app/javascript/constants/group_payment_types.ts","../../../app/javascript/utils/mergePriceDetails.ts","../../../app/javascript/components/ui/NumberInput.tsx","../../../app/javascript/hooks/useAdminForm2.ts","../../../app/javascript/utils/admin/stripeIntentUrlFor.ts","../../../app/javascript/components/Admin/GroupedReservations/GroupModalContents.tsx","../../../app/javascript/components/Admin/Reservations/EditReservationForm.tsx","../../../app/javascript/utils/admin/slugify.ts","../../../app/javascript/components/Reservations/Calendar.tsx","../../../app/javascript/components/Reservations/RealTimeIndicator.tsx","../../../app/javascript/components/Reservations/ConfirmChanges.tsx","../../../app/javascript/components/UpdatedReservationsTable.tsx","../../../app/javascript/components/Reservations/DiscountFormGroup.tsx","../../../app/javascript/components/ui/ReservationOptionsSelector.tsx","../../../app/javascript/components/ui/Alert.tsx","../../../app/javascript/components/Admin/PriceDetailsSection.tsx","../../../app/assets/images/park__icon_ux__pay_separately.svg?react","../../../app/assets/images/park__icon_ux__pay_together.svg?react","../../../app/javascript/components/ui/ReservationTypeSelector.tsx","../../../app/javascript/constants/rigTypes.ts","../../../app/javascript/constants/recurring_limit_in_years.ts","../../../app/javascript/utils/admin/createElectricOptions.ts","../../../app/javascript/components/Reservations/NewReservationForm.tsx","../../../app/javascript/components/Reservations/CreateReservationDropdown.tsx","../../../app/javascript/utils/applyTime.ts","../../../app/javascript/components/Reservations/NewReservation.tsx","../../../app/javascript/components/ui/Image.tsx","../../../app/javascript/components/ui/Tooltip.tsx","../../../node_modules/react-zoom-pan-pinch/dist/index.esm.js","../../../app/javascript/components/Reservations/CampMap.tsx","../../../app/javascript/components/Reservations/LineItems.tsx","../../../app/javascript/constants/NewReservation.ts","../../../app/javascript/components/Reservations/PaymentModal/PaymentTypeSelector.tsx","../../../app/javascript/utils/isValidPhoneNumber.ts","../../../app/javascript/components/Reservations/PaymentModal/PaymentLinkForm.tsx","../../../app/javascript/components/Reservations/PaymentModal/CreditCardForm/PaymentMethodsList.tsx","../../../app/javascript/components/Reservations/PaymentModal/StripeCardForm.tsx","../../../app/javascript/components/Reservations/ConfirmationModal/index.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/PaymentMethod.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/CreateReservationOrder.tsx","../../../app/javascript/components/Admin/Reservations/ReservationHooks/useExistingCamperWillBeOverridden.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/CreateReservationInfo.tsx","../../../app/javascript/components/ui/Notification.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/NewReservationModalToolbar.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/TakeDepositField.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/NewReservationPaymentLineItemRow.tsx","../../../node_modules/uuid/dist/esm-browser/stringify.js","../../../node_modules/uuid/dist/esm-browser/rng.js","../../../node_modules/uuid/dist/esm-browser/native.js","../../../node_modules/uuid/dist/esm-browser/v4.js","../../../app/javascript/components/Admin/Reservations/NewReservationModal/NewReservationPayment.tsx","../../../app/javascript/components/Admin/Reservations/NewReservationModal/index.tsx","../../../app/javascript/components/Reservations/Reservations.tsx","../../../app/javascript/components/ui/TodoDropdownButton.tsx","../../../app/javascript/components/ToDos/ToDoStatusBadge.tsx","../../../app/javascript/utils/stripHtmlTags.ts","../../../app/javascript/components/ToDos/ToDoItem.tsx","../../../app/javascript/components/ToDos/ToDosDatePicker.tsx","../../../app/javascript/ComponentsLibrary/Separator.tsx","../../../node_modules/qr.js/lib/ErrorCorrectLevel.js","../../../node_modules/qr.js/lib/mode.js","../../../node_modules/qr.js/lib/8BitByte.js","../../../node_modules/qr.js/lib/RSBlock.js","../../../node_modules/qr.js/lib/BitBuffer.js","../../../node_modules/qr.js/lib/math.js","../../../node_modules/qr.js/lib/Polynomial.js","../../../node_modules/qr.js/lib/util.js","../../../node_modules/qr.js/lib/QRCode.js","../../../node_modules/react-qr-code/lib/QRCodeSvg/index.js","../../../node_modules/react-qr-code/lib/index.js","../../../app/javascript/components/ToDos/ParkingPass.tsx","../../../app/javascript/components/ToDos/ToDos.tsx","../../../app/javascript/constants/reportIntervalOptions.ts","../../../app/javascript/utils/luxonDisplayDates.tsx","../../../app/javascript/components/Admin/Reports/ReportsDatePicker.tsx","../../../node_modules/@kurkle/color/dist/color.esm.js","../../../node_modules/chart.js/dist/chunks/helpers.segment.js","../../../node_modules/chart.js/dist/chart.js","../../../node_modules/react-chartjs-2/dist/index.js","../../../node_modules/chart.js/auto/auto.js","../../../node_modules/react-slick/lib/initial-state.js","../../../node_modules/lodash.debounce/index.js","../../../node_modules/classnames/index.js","../../../node_modules/react-slick/lib/default-props.js","../../../node_modules/react-slick/lib/utils/innerSliderUtils.js","../../../node_modules/react-slick/lib/track.js","../../../node_modules/react-slick/lib/dots.js","../../../node_modules/react-slick/lib/arrows.js","../../../node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js","../../../node_modules/react-slick/lib/inner-slider.js","../../../node_modules/string-convert/camel2hyphen.js","../../../node_modules/json2mq/index.js","../../../node_modules/enquire.js/src/QueryHandler.js","../../../node_modules/enquire.js/src/Util.js","../../../node_modules/enquire.js/src/MediaQuery.js","../../../node_modules/enquire.js/src/MediaQueryDispatch.js","../../../node_modules/enquire.js/src/index.js","../../../node_modules/react-slick/lib/slider.js","../../../node_modules/react-slick/lib/index.js","../../../app/javascript/components/Admin/Reports/ChartsGrid.tsx","../../../app/javascript/components/Admin/Reports/skeletons/ReportButtonSkeleton.tsx","../../../app/javascript/components/ui/ReportButton.tsx","../../../app/javascript/components/Admin/Reports/FilterBy.tsx","../../../app/javascript/constants/cookies.ts","../../../app/javascript/utils/downloadCsv.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsSitesOccupancy.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsReservationsVolume.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsReservationsDashboard.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsSitesDashboard.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsPaymentsDashboard.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsRentRollDashboard.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsAddonsDashboard.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsSites.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsAddons.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsReservations.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsPayments.ts","../../../app/javascript/components/Admin/Reports/ReportsHooks/useReportsRentRoll.ts","../../../app/javascript/components/Admin/Reports/ReportsSites/SiteCard.tsx","../../../app/javascript/components/Admin/Reports/ReportsSites/SitesCardList.tsx","../../../app/javascript/components/Admin/Reports/ReportsSites/SitesTable.tsx","../../../app/javascript/components/Admin/Reports/SummaryStat.tsx","../../../app/javascript/components/Admin/Reports/ReportsSites/SitesSummarySection.tsx","../../../app/javascript/components/Admin/Reports/ReportsSites/index.tsx","../../../app/javascript/components/Admin/Reports/ReportsReservations/ReservationsSummarySection.tsx","../../../app/javascript/components/Admin/Reports/ReportsReservations/ReservationCard.tsx","../../../app/javascript/components/Admin/Reports/ReportsReservations/ReservationsCardList.tsx","../../../app/javascript/components/Admin/Reports/ReportsReservations/ReservationsTable.tsx","../../../app/javascript/components/Admin/Reports/ReportsReservations/index.tsx","../../../app/javascript/components/Admin/Reports/ReportsRentRoll/RentRollSummarySection.tsx","../../../app/javascript/components/Admin/Reports/ReportsRentRoll/RentRollCard.tsx","../../../app/javascript/components/Admin/Reports/ReportsRentRoll/RentRollCardList.tsx","../../../app/javascript/components/Admin/Reports/ReportsRentRoll/RentRollTable.tsx","../../../app/javascript/components/Admin/Reports/ReportsRentRoll/index.tsx","../../../app/javascript/components/Admin/Reports/ReportsProducts/ProductsCard.tsx","../../../app/javascript/components/Admin/Reports/ReportsProducts/ProductsList.tsx","../../../app/javascript/components/Admin/Reports/ReportsProducts/ProductsTable.tsx","../../../app/javascript/components/Admin/Reports/ReportsProducts/ProductsSummarySection.tsx","../../../app/javascript/components/Admin/Reports/ReportsProducts/index.tsx","../../../app/javascript/components/Admin/Reports/ReportsPayments/PaymentsCard.tsx","../../../app/javascript/components/Admin/Reports/ReportsPayments/PaymentsList.tsx","../../../app/javascript/components/Admin/Reports/ReportsPayments/PaymentsSummarySection.tsx","../../../app/javascript/components/Admin/Reports/ReportsPayments/PaymentsTable.tsx","../../../app/javascript/components/Admin/Reports/ReportsPayments/index.tsx","../../../app/javascript/components/Admin/Reports/PaymentFiltersDropdown.tsx","../../../app/javascript/components/Admin/Reports/Reports.tsx","../../../app/javascript/components/Admin/SearchBar.tsx","../../../app/javascript/utils/admin/formatDateRange.ts","../../../app/javascript/components/Admin/SearchDropDown.tsx","../../../app/javascript/constants/admin_navbar_items.ts","../../../app/javascript/components/Admin/Navigation/AdminDropdown.tsx","../../../node_modules/moment-timezone/moment-timezone.js","../../../node_modules/moment-timezone/index.js","../../../node_modules/caldate/src/utils.js","../../../node_modules/caldate/src/CalDate.js","../../../node_modules/date-holidays-parser/node_modules/deepmerge/dist/cjs.js","../../../node_modules/date-holidays-parser/src/utils.js","../../../node_modules/date-holidays-parser/src/internal/utils.js","../../../node_modules/date-holidays-parser/src/Data.js","../../../node_modules/date-holidays-parser/src/Parser.js","../../../node_modules/date-holidays-parser/src/Rule.js","../../../node_modules/date-holidays-parser/src/CalEvent.js","../../../node_modules/date-holidays-parser/src/PostRule.js","../../../node_modules/date-easter/src/index.js","../../../node_modules/date-holidays-parser/src/Easter.js","../../../node_modules/astronomia/src/base.js","../../../node_modules/astronomia/src/interpolation.js","../../../node_modules/astronomia/src/sexagesimal.js","../../../node_modules/astronomia/src/coord.js","../../../node_modules/astronomia/src/nutation.js","../../../node_modules/astronomia/src/elementequinox.js","../../../node_modules/astronomia/src/precess.js","../../../node_modules/astronomia/src/planetposition.js","../../../node_modules/astronomia/src/solar.js","../../../node_modules/astronomia/data/deltat.js","../../../node_modules/astronomia/src/deltat.js","../../../node_modules/astronomia/src/moonphase.js","../../../node_modules/astronomia/src/julian.js","../../../node_modules/astronomia/src/moonposition.js","../../../node_modules/astronomia/src/refraction.js","../../../node_modules/astronomia/src/rise.js","../../../node_modules/astronomia/src/solstice.js","../../../node_modules/astronomia/src/sunrise.js","../../../node_modules/date-holidays-parser/src/Julian.js","../../../node_modules/date-holidays-parser/src/CalEventMap.js","../../../node_modules/date-holidays-parser/src/internal/hebrew-calendar.js","../../../node_modules/date-holidays-parser/src/Hebrew.js","../../../node_modules/date-holidays-parser/src/internal/hijri-calendar.js","../../../node_modules/date-holidays-parser/src/Hijri.js","../../../node_modules/jalaali-js/index.js","../../../node_modules/date-holidays-parser/src/Jalaali.js","../../../node_modules/astronomia/data/vsop87Bearth.js","../../../node_modules/date-holidays-parser/src/vsop87Bearth.js","../../../node_modules/date-holidays-parser/src/Equinox.js","../../../node_modules/date-chinese/src/vsop87Bearth.js","../../../node_modules/date-chinese/src/Chinese.js","../../../node_modules/date-chinese/src/Korean.js","../../../node_modules/date-chinese/src/Vietnamese.js","../../../node_modules/date-holidays-parser/src/Chinese.js","../../../node_modules/date-bengali-revised/src/convert.js","../../../node_modules/date-bengali-revised/src/index.js","../../../node_modules/date-holidays-parser/src/BengaliRevised.js","../../../node_modules/date-holidays-parser/src/CalEventFactory.js","../../../node_modules/date-holidays-parser/src/DateFn.js","../../../node_modules/date-holidays-parser/src/HolidayRule.js","../../../node_modules/date-holidays-parser/src/Holidays.js","../../../node_modules/date-holidays/src/data.js","../../../node_modules/date-holidays/src/Holidays.js","../../../app/assets/images/park_logo__green.svg","../../../app/assets/images/park_icon__green.svg","../../../app/javascript/components/Admin/Navigation/fetchParkLogoSrc.ts","../../../app/javascript/components/Admin/Navigation/Navbar.tsx","../../../app/javascript/components/Admin/RefreshModal.tsx","../../../app/javascript/components/Admin/Reservations/MessageTypeSelector.tsx","../../../node_modules/react-tag-input-component/dist/esm/index.js","../../../app/javascript/components/Admin/Reservations/MessageModal.tsx","../../../app/javascript/components/Reservations/PaymentModal/AdminAddOns.tsx","../../../app/javascript/components/ui/CampingStyleSelector.tsx","../../../app/javascript/components/Admin/Settings/Product/Products.tsx","../../../app/javascript/components/Admin/Settings/Coupons/CouponsModalContent/CouponsDatePicker.tsx","../../../app/javascript/components/Admin/Settings/Product/ProductModalContent.tsx","../../../app/javascript/components/Reservations/PaymentModal/PartialPaymentInput.tsx","../../../app/javascript/hooks/usePosModal.ts","../../../app/javascript/components/Reservations/PosModal.tsx","../../../app/javascript/hooks/useConfirm.tsx","../../../app/javascript/components/Admin/HelpPopover.tsx","../../../app/javascript/contexts/AdminProvider.tsx","../../../node_modules/logrocket/dist/build.umd.js","../../../app/javascript/hooks/useLogRocket.ts","../../../app/javascript/constants/dateFormats.ts","../../../app/javascript/components/Admin/Settings/skeletons/EditCampForm.tsx","../../../app/javascript/components/Admin/Settings/skeletons/TextInputSkeleton.tsx","../../../app/javascript/hooks/useCampImageUploader.ts","../../../app/javascript/components/Admin/Settings/components/CampLogoUpload.tsx","../../../app/javascript/components/Admin/Settings/components/CampImagesUpload.tsx","../../../app/javascript/components/Admin/Settings/components/CampMapUpload.tsx","../../../app/javascript/components/Admin/Settings/EditCampForm/components/SeasonDatesFields/constants/monthOptionsConstant.ts","../../../app/javascript/components/Admin/Settings/EditCampForm/components/SeasonDatesFields/helpers/dayOptionsHelper.ts","../../../app/javascript/components/ui/DropdownSelector/DropdownSelector.tsx","../../../app/javascript/components/Admin/Settings/EditCampForm/components/SeasonDatesFields/index.tsx","../../../app/javascript/components/Admin/Settings/EditCampForm/components/SeasonDatesFields/helpers/getFirstPartOfDateType.ts","../../../app/javascript/components/Admin/Settings/EditCampForm/EditCampForm.tsx","../../../app/javascript/components/Admin/Settings/PolicyAndRulesForm.tsx","../../../app/javascript/constants/price_modes.ts","../../../app/javascript/components/Admin/Settings/pages/pricing/components/PriceModeSelector.tsx","../../../app/javascript/components/Admin/Settings/pages/pricing/constants/index.ts","../../../app/javascript/components/Admin/Settings/pages/pricing/components/table/SettingsPricingTable.tsx","../../../app/javascript/components/Admin/Settings/pages/pricing/components/AddEditPriceModal.tsx","../../../app/javascript/components/Admin/Settings/pages/pricing/components/skeletons/SettingsPricingTableSkeleton.tsx","../../../app/javascript/components/Admin/Settings/pages/pricing/utils/index.ts","../../../app/javascript/components/Admin/Settings/pages/pricing/hooks/usePricingTable.ts","../../../app/javascript/components/Admin/Settings/pages/pricing/components/PricingMatrixConfirmationModal.tsx","../../../app/javascript/components/Admin/Settings/pages/pricing/components/table/index.tsx","../../../app/javascript/components/Admin/Settings/pages/pricing/index.tsx","../../../app/javascript/components/Admin/Settings/InvoiceSettings.tsx","../../../app/assets/images/copy_icons/copyOutline.svg?react","../../../app/assets/images/copy_icons/copiedOutline.svg?react","../../../app/javascript/utils/convertFloatToPercentageString.ts","../../../app/javascript/constants/coupons.ts","../../../app/javascript/utils/coupons.ts","../../../app/assets/images/copy_icons/copyOutline.svg","../../../app/assets/images/copy_icons/copiedOutline.svg","../../../app/javascript/components/Admin/Settings/Coupons/PercentInputWithLabel.tsx","../../../app/javascript/components/Admin/Settings/Coupons/DollarInputWithLabel.tsx","../../../app/javascript/components/Admin/Settings/Coupons/CouponsModalContent/CouponsSelector.tsx","../../../app/javascript/components/Admin/Settings/Coupons/CouponsModalContent/CouponsActiveDates.tsx","../../../app/javascript/components/Admin/Settings/Coupons/CouponsModalContent/index.tsx","../../../app/javascript/utils/admin/formatDate.ts","../../../app/javascript/components/Admin/Settings/Coupons/Coupons.tsx","../../../app/javascript/components/Admin/Settings/AutomatedMessages.tsx","../../../app/javascript/components/Admin/Settings/components/SettingsNavBar.tsx","../../../app/javascript/utils/isEmailValidAndSingle.ts","../../../app/javascript/components/Admin/Settings/Users/components/Fields/CampsDropdown.tsx","../../../app/javascript/components/Admin/Settings/Users/hooks/useUser.tsx","../../../app/javascript/components/Admin/Settings/Users/constants/AccessRadioOptions.ts","../../../app/javascript/components/Admin/Settings/Users/components/Fields/ReservationOptionsSelector.tsx","../../../app/javascript/components/Admin/Settings/Users/helpers/userHelper.ts","../../../app/javascript/components/Admin/Settings/Users/constants/UserModalId.ts","../../../app/javascript/components/Admin/Settings/Users/constants/AdminUserStatuses.ts","../../../node_modules/tailwind-merge/dist/bundle-mjs.mjs","../../../app/javascript/utils/tailwind.ts","../../../app/javascript/components/Admin/Settings/Users/components/Modals/UserModalContent.tsx","../../../app/javascript/components/Admin/Settings/Users/helpers/GridTemplateConstant.ts","../../../app/javascript/components/Admin/Settings/Users/Users.tsx","../../../app/javascript/components/Admin/Settings/index.tsx","../../../app/javascript/components/Admin/Campers/Camper/History.tsx","../../../app/javascript/components/Admin/Campers/Camper/Info.tsx","../../../app/javascript/components/Admin/Campers/CamperDocumentUpload.tsx","../../../app/javascript/components/Admin/Campers/Camper/CamperPaymentMethods.tsx","../../../app/javascript/components/Admin/Campers/Camper.tsx","../../../app/javascript/components/Admin/SortableTableHeader.tsx","../../../app/javascript/components/Admin/Campers/PaginatedTable.tsx","../../../app/javascript/components/Admin/Campers/Campers.tsx","../../../app/javascript/utils/roundToMaxPrecision.ts","../../../app/javascript/utils/dateUtils.ts","../../../app/javascript/components/Admin/Invoices/Table/row.utils.tsx","../../../app/javascript/components/Admin/Invoices/InvoicesModalContent.tsx","../../../app/javascript/components/Admin/Invoices/Table/useTableRow.tsx","../../../app/javascript/components/Admin/Invoices/Table/Row.tsx","../../../app/javascript/components/Admin/Invoices/InvoiceFilterOptions.ts","../../../app/javascript/components/ui/Admin/OptionSelector.tsx","../../../app/javascript/components/Admin/Invoices/InvoicesDatePicker.tsx","../../../app/javascript/components/Admin/Invoices/BulkActionsButton.tsx","../../../app/javascript/ComponentsLibrary/List/List.tsx","../../../app/javascript/components/Admin/Invoices/Table/RowMobile.tsx","../../../app/javascript/components/Admin/Invoices/Table.tsx","../../../app/javascript/components/Admin/Invoices/InvoicesPage.tsx","../../../app/javascript/hooks/useAdminCamp.ts","../../../app/javascript/components/Admin/Store/StoreSearchBar.tsx","../../../app/javascript/components/Admin/Store/CamperSearchBar.tsx","../../../app/javascript/components/ui/CamperCard.tsx","../../../app/javascript/components/Admin/Store/useStoreContent.ts","../../../app/javascript/components/Admin/Store/StoreContent.tsx","../../../app/javascript/components/ReactQueryProvider.tsx","../../../app/javascript/components/Admin.tsx","../../../app/javascript/components/Admin/Inputs/InputFieldWithIcon.tsx","../../../app/javascript/components/Admin/Reports/Table.tsx","../../../app/javascript/components/Admin/Reservations/EditSiteForm/CalendarSyncInputs.tsx","../../../app/javascript/components/Admin/StripeCardSetupForm.tsx","../../../app/javascript/components/ui/Admin/Form/PasswordInput.tsx","../../../app/javascript/components/AdminLogin/LoginForm.tsx","../../../app/javascript/components/AdminLogin.tsx","../../../app/javascript/components/AdminSettings.tsx","../../../app/javascript/components/AdminSettings/CampStatistics.tsx","../../../app/javascript/components/AdminSignup/SignupForm.tsx","../../../app/javascript/components/AdminSignup.tsx","../../../app/javascript/components/AdminStatistics.tsx","../../../app/assets/images/illustration__isaac_lefever__wilderness.png","../../../app/javascript/components/Booker/ErrorBoundaries/AppBoundary.tsx","../../../app/javascript/utils/rigLabel.ts","../../../app/javascript/components/Sites/prerequisites/MaxRigLengthField.tsx","../../../app/javascript/types/validElectric.ts","../../../app/javascript/components/Sites/prerequisites/electricOptions.ts","../../../app/javascript/components/Sites/prerequisites/ElectricField.tsx","../../../app/javascript/components/Sites/prerequisites/RigTypeField.tsx","../../../app/javascript/components/Sites/prerequisites/PassengersField.tsx","../../../app/javascript/components/Sites/prerequisites/PetsField.tsx","../../../app/javascript/components/Sites/prerequisites/YearField.tsx","../../../app/javascript/components/ui/BookerButton.tsx","../../../app/javascript/utils/booker.ts","../../../app/javascript/components/Sites/Prerequisites.tsx","../../../app/javascript/components/Booker/utils/BookerDropdownButton.tsx","../../../app/assets/images/park_logo__white.svg","../../../node_modules/react-dates/src/constants.js","../../../app/javascript/decorators/CampDecorator.ts","../../../app/javascript/components/Dates/DatePicker.tsx","../../../app/javascript/components/Dates/SelectedDates.tsx","../../../app/javascript/components/ui/TimeSelector.tsx","../../../app/javascript/components/Dates/DatesCard.tsx","../../../app/javascript/components/ui/CampImagesCarousel.tsx","../../../app/javascript/components/DetailsPayment/Features.tsx","../../../app/javascript/components/Sites/Site.tsx","../../../app/javascript/utils/sortSites.ts","../../../app/javascript/components/Sites/SiteFields/RigTypeField.tsx","../../../app/javascript/components/Sites/NoAvailableSites.tsx","../../../app/javascript/components/Sites/Sites.tsx","../../../app/javascript/components/Sites/SelectedSite.tsx","../../../app/javascript/components/Sites/SitesCard.tsx","../../../app/javascript/components/DetailsPayment/DiscountOption.tsx","../../../app/javascript/components/DetailsPayment/DiscountForm.tsx","../../../app/javascript/reducers/userParamsReducer.tsx","../../../app/javascript/components/DetailsPayment/PurchaseBottomBar.tsx","../../../app/javascript/components/DetailsPayment/CheckoutForm.tsx","../../../app/javascript/components/DetailsPayment/CouponForm.tsx","../../../app/javascript/components/DetailsPayment/PriceDetails.tsx","../../../app/javascript/components/DetailsPayment/Payment.tsx","../../../app/javascript/components/DetailsPayment/SelectionCard.tsx","../../../app/javascript/hooks/useCampTheme.ts","../../../app/javascript/components/Camp.tsx","../../../app/javascript/components/CampNotFound.tsx","../../../app/assets/images/arrow_icons/left_right_arrows.svg","../../../app/assets/images/copy_icons/copy.svg?react","../../../app/assets/images/copy_icons/copied.svg?react","../../../app/javascript/components/Confirmation.tsx","../../../app/javascript/components/Confirmation/ReferralModal.tsx","../../../app/javascript/components/Invoices/PublicInvoices/PaymentDisclaimer.tsx","../../../app/javascript/components/Invoices/PublicInvoices/CustomerPayments.tsx","../../../node_modules/@lottiefiles/dotlottie-react/dist/browser/index.js","../../../app/javascript/components/Invoices/PublicInvoices/ProcessingPayment.tsx","../../../app/javascript/components/Invoices/PublicInvoices/CustomerInvoiceContent.tsx","../../../app/javascript/components/Invoices/PublicInvoices/CustomerInvoice.tsx","../../../app/javascript/components/NotFound.tsx","../../../app/javascript/components/ResetPassword.tsx","../../../app/javascript/components/UpdatePassword.tsx","../../../app/javascript/components/ui/form.tsx","../../../app/javascript/components/ui/input.tsx","../../../node_modules/@rails/ujs/app/assets/javascripts/rails-ujs.esm.js","../../../node_modules/@hotwired/turbo/dist/turbo.es2017-esm.js","../../../node_modules/@rails/activestorage/app/assets/javascripts/activestorage.esm.js","../../../node_modules/react-dom/client.js","../../../node_modules/react-router/node_modules/cookie/dist/index.js","../../../node_modules/react-router/dist/development/chunk-GNGMS2XR.mjs","../../../app/javascript/App.tsx","../../../node_modules/react-dom/cjs/react-dom-server-legacy.browser.production.min.js","../../../node_modules/react-dom/cjs/react-dom-server.browser.production.min.js","../../../node_modules/react-dom/server.browser.js","../../../node_modules/react_ujs/react_ujs/src/events/native.js","../../../node_modules/react_ujs/react_ujs/src/events/pjax.js","../../../node_modules/react_ujs/react_ujs/src/events/turbolinks.js","../../../node_modules/react_ujs/react_ujs/src/events/turbolinksClassicDeprecated.js","../../../node_modules/react_ujs/react_ujs/src/events/turbolinksClassic.js","../../../node_modules/react_ujs/react_ujs/src/events/detect.js","../../../node_modules/react_ujs/react_ujs/src/getConstructor/fromGlobal.js","../../../node_modules/react_ujs/react_ujs/src/getConstructor/fromRequireContext.js","../../../node_modules/react_ujs/react_ujs/src/getConstructor/fromRequireContextWithGlobalFallback.js","../../../node_modules/react_ujs/react_ujs/src/getConstructor/fromRequireContextsWithGlobalFallback.js","../../../node_modules/react_ujs/react_ujs/src/supportsRootApi.js","../../../node_modules/react_ujs/react_ujs/src/reactDomClient.js","../../../node_modules/react_ujs/react_ujs/src/renderHelpers.js","../../../node_modules/react_ujs/react_ujs/index.js","../../../app/javascript/entrypoints/application.tsx"],"sourcesContent":["/**\n * @license React\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1 {\n if (typeof error.json === \"function\") {\n let result: any\n\n await error\n .json()\n .then(jsonError => {\n // console.log(\"[DEBUG] Json error from API\")\n // console.log(jsonError)\n\n result = jsonError\n })\n .catch(genericError => {\n // console.log(\"[DEBUG] Generic error from API\")\n // console.log(error.statusText)\n\n let status = error.status\n\n if (error.statusText.toLowerCase().includes('internal server error')) {\n result = 'Something unexpected went wrong. If this persists, please reach out to Park Support at support@poweredbypark.com'\n } else {\n result = error.statusText\n }\n\n result = { message: result, status: status }\n })\n\n return Promise.reject(result)\n } else {\n // console.log(\"[DEBUG] Fetch error\")\n // console.log(error)\n\n return Promise.reject({ message: error })\n }\n}\n","export default (resp: Response, headers?: any) => {\n if (resp.ok) {\n return handleOkResponseByContent(resp, headers)\n } else {\n return Promise.reject(resp)\n }\n}\n\nconst handleOkResponseByContent = async (resp: Response, headers?: any) => {\n switch(headers && headers['Accept']) {\n case 'text/csv':\n return resp.text()\n default:\n return resp.json()\n }\n}\n","//! moment.js\n//! version : 2.30.1\n//! authors : Tim Wood, Iskren Chernev, Moment.js contributors\n//! license : MIT\n//! momentjs.com\n\nvar hookCallback;\n\nfunction hooks() {\n return hookCallback.apply(null, arguments);\n}\n\n// This is done to register the method called with moment()\n// without creating circular dependencies.\nfunction setHookCallback(callback) {\n hookCallback = callback;\n}\n\nfunction isArray(input) {\n return (\n input instanceof Array ||\n Object.prototype.toString.call(input) === '[object Array]'\n );\n}\n\nfunction isObject(input) {\n // IE8 will treat undefined and null as object if it wasn't for\n // input != null\n return (\n input != null &&\n Object.prototype.toString.call(input) === '[object Object]'\n );\n}\n\nfunction hasOwnProp(a, b) {\n return Object.prototype.hasOwnProperty.call(a, b);\n}\n\nfunction isObjectEmpty(obj) {\n if (Object.getOwnPropertyNames) {\n return Object.getOwnPropertyNames(obj).length === 0;\n } else {\n var k;\n for (k in obj) {\n if (hasOwnProp(obj, k)) {\n return false;\n }\n }\n return true;\n }\n}\n\nfunction isUndefined(input) {\n return input === void 0;\n}\n\nfunction isNumber(input) {\n return (\n typeof input === 'number' ||\n Object.prototype.toString.call(input) === '[object Number]'\n );\n}\n\nfunction isDate(input) {\n return (\n input instanceof Date ||\n Object.prototype.toString.call(input) === '[object Date]'\n );\n}\n\nfunction map(arr, fn) {\n var res = [],\n i,\n arrLen = arr.length;\n for (i = 0; i < arrLen; ++i) {\n res.push(fn(arr[i], i));\n }\n return res;\n}\n\nfunction extend(a, b) {\n for (var i in b) {\n if (hasOwnProp(b, i)) {\n a[i] = b[i];\n }\n }\n\n if (hasOwnProp(b, 'toString')) {\n a.toString = b.toString;\n }\n\n if (hasOwnProp(b, 'valueOf')) {\n a.valueOf = b.valueOf;\n }\n\n return a;\n}\n\nfunction createUTC(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, true).utc();\n}\n\nfunction defaultParsingFlags() {\n // We need to deep clone this object.\n return {\n empty: false,\n unusedTokens: [],\n unusedInput: [],\n overflow: -2,\n charsLeftOver: 0,\n nullInput: false,\n invalidEra: null,\n invalidMonth: null,\n invalidFormat: false,\n userInvalidated: false,\n iso: false,\n parsedDateParts: [],\n era: null,\n meridiem: null,\n rfc2822: false,\n weekdayMismatch: false,\n };\n}\n\nfunction getParsingFlags(m) {\n if (m._pf == null) {\n m._pf = defaultParsingFlags();\n }\n return m._pf;\n}\n\nvar some;\nif (Array.prototype.some) {\n some = Array.prototype.some;\n} else {\n some = function (fun) {\n var t = Object(this),\n len = t.length >>> 0,\n i;\n\n for (i = 0; i < len; i++) {\n if (i in t && fun.call(this, t[i], i, t)) {\n return true;\n }\n }\n\n return false;\n };\n}\n\nfunction isValid(m) {\n var flags = null,\n parsedParts = false,\n isNowValid = m._d && !isNaN(m._d.getTime());\n if (isNowValid) {\n flags = getParsingFlags(m);\n parsedParts = some.call(flags.parsedDateParts, function (i) {\n return i != null;\n });\n isNowValid =\n flags.overflow < 0 &&\n !flags.empty &&\n !flags.invalidEra &&\n !flags.invalidMonth &&\n !flags.invalidWeekday &&\n !flags.weekdayMismatch &&\n !flags.nullInput &&\n !flags.invalidFormat &&\n !flags.userInvalidated &&\n (!flags.meridiem || (flags.meridiem && parsedParts));\n if (m._strict) {\n isNowValid =\n isNowValid &&\n flags.charsLeftOver === 0 &&\n flags.unusedTokens.length === 0 &&\n flags.bigHour === undefined;\n }\n }\n if (Object.isFrozen == null || !Object.isFrozen(m)) {\n m._isValid = isNowValid;\n } else {\n return isNowValid;\n }\n return m._isValid;\n}\n\nfunction createInvalid(flags) {\n var m = createUTC(NaN);\n if (flags != null) {\n extend(getParsingFlags(m), flags);\n } else {\n getParsingFlags(m).userInvalidated = true;\n }\n\n return m;\n}\n\n// Plugins that add properties should also add the key here (null value),\n// so we can properly clone ourselves.\nvar momentProperties = (hooks.momentProperties = []),\n updateInProgress = false;\n\nfunction copyConfig(to, from) {\n var i,\n prop,\n val,\n momentPropertiesLen = momentProperties.length;\n\n if (!isUndefined(from._isAMomentObject)) {\n to._isAMomentObject = from._isAMomentObject;\n }\n if (!isUndefined(from._i)) {\n to._i = from._i;\n }\n if (!isUndefined(from._f)) {\n to._f = from._f;\n }\n if (!isUndefined(from._l)) {\n to._l = from._l;\n }\n if (!isUndefined(from._strict)) {\n to._strict = from._strict;\n }\n if (!isUndefined(from._tzm)) {\n to._tzm = from._tzm;\n }\n if (!isUndefined(from._isUTC)) {\n to._isUTC = from._isUTC;\n }\n if (!isUndefined(from._offset)) {\n to._offset = from._offset;\n }\n if (!isUndefined(from._pf)) {\n to._pf = getParsingFlags(from);\n }\n if (!isUndefined(from._locale)) {\n to._locale = from._locale;\n }\n\n if (momentPropertiesLen > 0) {\n for (i = 0; i < momentPropertiesLen; i++) {\n prop = momentProperties[i];\n val = from[prop];\n if (!isUndefined(val)) {\n to[prop] = val;\n }\n }\n }\n\n return to;\n}\n\n// Moment prototype object\nfunction Moment(config) {\n copyConfig(this, config);\n this._d = new Date(config._d != null ? config._d.getTime() : NaN);\n if (!this.isValid()) {\n this._d = new Date(NaN);\n }\n // Prevent infinite loop in case updateOffset creates new moment\n // objects.\n if (updateInProgress === false) {\n updateInProgress = true;\n hooks.updateOffset(this);\n updateInProgress = false;\n }\n}\n\nfunction isMoment(obj) {\n return (\n obj instanceof Moment || (obj != null && obj._isAMomentObject != null)\n );\n}\n\nfunction warn(msg) {\n if (\n hooks.suppressDeprecationWarnings === false &&\n typeof console !== 'undefined' &&\n console.warn\n ) {\n console.warn('Deprecation warning: ' + msg);\n }\n}\n\nfunction deprecate(msg, fn) {\n var firstTime = true;\n\n return extend(function () {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(null, msg);\n }\n if (firstTime) {\n var args = [],\n arg,\n i,\n key,\n argLen = arguments.length;\n for (i = 0; i < argLen; i++) {\n arg = '';\n if (typeof arguments[i] === 'object') {\n arg += '\\n[' + i + '] ';\n for (key in arguments[0]) {\n if (hasOwnProp(arguments[0], key)) {\n arg += key + ': ' + arguments[0][key] + ', ';\n }\n }\n arg = arg.slice(0, -2); // Remove trailing comma and space\n } else {\n arg = arguments[i];\n }\n args.push(arg);\n }\n warn(\n msg +\n '\\nArguments: ' +\n Array.prototype.slice.call(args).join('') +\n '\\n' +\n new Error().stack\n );\n firstTime = false;\n }\n return fn.apply(this, arguments);\n }, fn);\n}\n\nvar deprecations = {};\n\nfunction deprecateSimple(name, msg) {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(name, msg);\n }\n if (!deprecations[name]) {\n warn(msg);\n deprecations[name] = true;\n }\n}\n\nhooks.suppressDeprecationWarnings = false;\nhooks.deprecationHandler = null;\n\nfunction isFunction(input) {\n return (\n (typeof Function !== 'undefined' && input instanceof Function) ||\n Object.prototype.toString.call(input) === '[object Function]'\n );\n}\n\nfunction set(config) {\n var prop, i;\n for (i in config) {\n if (hasOwnProp(config, i)) {\n prop = config[i];\n if (isFunction(prop)) {\n this[i] = prop;\n } else {\n this['_' + i] = prop;\n }\n }\n }\n this._config = config;\n // Lenient ordinal parsing accepts just a number in addition to\n // number + (possibly) stuff coming from _dayOfMonthOrdinalParse.\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n this._dayOfMonthOrdinalParseLenient = new RegExp(\n (this._dayOfMonthOrdinalParse.source || this._ordinalParse.source) +\n '|' +\n /\\d{1,2}/.source\n );\n}\n\nfunction mergeConfigs(parentConfig, childConfig) {\n var res = extend({}, parentConfig),\n prop;\n for (prop in childConfig) {\n if (hasOwnProp(childConfig, prop)) {\n if (isObject(parentConfig[prop]) && isObject(childConfig[prop])) {\n res[prop] = {};\n extend(res[prop], parentConfig[prop]);\n extend(res[prop], childConfig[prop]);\n } else if (childConfig[prop] != null) {\n res[prop] = childConfig[prop];\n } else {\n delete res[prop];\n }\n }\n }\n for (prop in parentConfig) {\n if (\n hasOwnProp(parentConfig, prop) &&\n !hasOwnProp(childConfig, prop) &&\n isObject(parentConfig[prop])\n ) {\n // make sure changes to properties don't modify parent config\n res[prop] = extend({}, res[prop]);\n }\n }\n return res;\n}\n\nfunction Locale(config) {\n if (config != null) {\n this.set(config);\n }\n}\n\nvar keys;\n\nif (Object.keys) {\n keys = Object.keys;\n} else {\n keys = function (obj) {\n var i,\n res = [];\n for (i in obj) {\n if (hasOwnProp(obj, i)) {\n res.push(i);\n }\n }\n return res;\n };\n}\n\nvar defaultCalendar = {\n sameDay: '[Today at] LT',\n nextDay: '[Tomorrow at] LT',\n nextWeek: 'dddd [at] LT',\n lastDay: '[Yesterday at] LT',\n lastWeek: '[Last] dddd [at] LT',\n sameElse: 'L',\n};\n\nfunction calendar(key, mom, now) {\n var output = this._calendar[key] || this._calendar['sameElse'];\n return isFunction(output) ? output.call(mom, now) : output;\n}\n\nfunction zeroFill(number, targetLength, forceSign) {\n var absNumber = '' + Math.abs(number),\n zerosToFill = targetLength - absNumber.length,\n sign = number >= 0;\n return (\n (sign ? (forceSign ? '+' : '') : '-') +\n Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) +\n absNumber\n );\n}\n\nvar formattingTokens =\n /(\\[[^\\[]*\\])|(\\\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|N{1,5}|YYYYYY|YYYYY|YYYY|YY|y{2,4}|yo?|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,\n localFormattingTokens = /(\\[[^\\[]*\\])|(\\\\)?(LTS|LT|LL?L?L?|l{1,4})/g,\n formatFunctions = {},\n formatTokenFunctions = {};\n\n// token: 'M'\n// padded: ['MM', 2]\n// ordinal: 'Mo'\n// callback: function () { this.month() + 1 }\nfunction addFormatToken(token, padded, ordinal, callback) {\n var func = callback;\n if (typeof callback === 'string') {\n func = function () {\n return this[callback]();\n };\n }\n if (token) {\n formatTokenFunctions[token] = func;\n }\n if (padded) {\n formatTokenFunctions[padded[0]] = function () {\n return zeroFill(func.apply(this, arguments), padded[1], padded[2]);\n };\n }\n if (ordinal) {\n formatTokenFunctions[ordinal] = function () {\n return this.localeData().ordinal(\n func.apply(this, arguments),\n token\n );\n };\n }\n}\n\nfunction removeFormattingTokens(input) {\n if (input.match(/\\[[\\s\\S]/)) {\n return input.replace(/^\\[|\\]$/g, '');\n }\n return input.replace(/\\\\/g, '');\n}\n\nfunction makeFormatFunction(format) {\n var array = format.match(formattingTokens),\n i,\n length;\n\n for (i = 0, length = array.length; i < length; i++) {\n if (formatTokenFunctions[array[i]]) {\n array[i] = formatTokenFunctions[array[i]];\n } else {\n array[i] = removeFormattingTokens(array[i]);\n }\n }\n\n return function (mom) {\n var output = '',\n i;\n for (i = 0; i < length; i++) {\n output += isFunction(array[i])\n ? array[i].call(mom, format)\n : array[i];\n }\n return output;\n };\n}\n\n// format date using native date object\nfunction formatMoment(m, format) {\n if (!m.isValid()) {\n return m.localeData().invalidDate();\n }\n\n format = expandFormat(format, m.localeData());\n formatFunctions[format] =\n formatFunctions[format] || makeFormatFunction(format);\n\n return formatFunctions[format](m);\n}\n\nfunction expandFormat(format, locale) {\n var i = 5;\n\n function replaceLongDateFormatTokens(input) {\n return locale.longDateFormat(input) || input;\n }\n\n localFormattingTokens.lastIndex = 0;\n while (i >= 0 && localFormattingTokens.test(format)) {\n format = format.replace(\n localFormattingTokens,\n replaceLongDateFormatTokens\n );\n localFormattingTokens.lastIndex = 0;\n i -= 1;\n }\n\n return format;\n}\n\nvar defaultLongDateFormat = {\n LTS: 'h:mm:ss A',\n LT: 'h:mm A',\n L: 'MM/DD/YYYY',\n LL: 'MMMM D, YYYY',\n LLL: 'MMMM D, YYYY h:mm A',\n LLLL: 'dddd, MMMM D, YYYY h:mm A',\n};\n\nfunction longDateFormat(key) {\n var format = this._longDateFormat[key],\n formatUpper = this._longDateFormat[key.toUpperCase()];\n\n if (format || !formatUpper) {\n return format;\n }\n\n this._longDateFormat[key] = formatUpper\n .match(formattingTokens)\n .map(function (tok) {\n if (\n tok === 'MMMM' ||\n tok === 'MM' ||\n tok === 'DD' ||\n tok === 'dddd'\n ) {\n return tok.slice(1);\n }\n return tok;\n })\n .join('');\n\n return this._longDateFormat[key];\n}\n\nvar defaultInvalidDate = 'Invalid date';\n\nfunction invalidDate() {\n return this._invalidDate;\n}\n\nvar defaultOrdinal = '%d',\n defaultDayOfMonthOrdinalParse = /\\d{1,2}/;\n\nfunction ordinal(number) {\n return this._ordinal.replace('%d', number);\n}\n\nvar defaultRelativeTime = {\n future: 'in %s',\n past: '%s ago',\n s: 'a few seconds',\n ss: '%d seconds',\n m: 'a minute',\n mm: '%d minutes',\n h: 'an hour',\n hh: '%d hours',\n d: 'a day',\n dd: '%d days',\n w: 'a week',\n ww: '%d weeks',\n M: 'a month',\n MM: '%d months',\n y: 'a year',\n yy: '%d years',\n};\n\nfunction relativeTime(number, withoutSuffix, string, isFuture) {\n var output = this._relativeTime[string];\n return isFunction(output)\n ? output(number, withoutSuffix, string, isFuture)\n : output.replace(/%d/i, number);\n}\n\nfunction pastFuture(diff, output) {\n var format = this._relativeTime[diff > 0 ? 'future' : 'past'];\n return isFunction(format) ? format(output) : format.replace(/%s/i, output);\n}\n\nvar aliases = {\n D: 'date',\n dates: 'date',\n date: 'date',\n d: 'day',\n days: 'day',\n day: 'day',\n e: 'weekday',\n weekdays: 'weekday',\n weekday: 'weekday',\n E: 'isoWeekday',\n isoweekdays: 'isoWeekday',\n isoweekday: 'isoWeekday',\n DDD: 'dayOfYear',\n dayofyears: 'dayOfYear',\n dayofyear: 'dayOfYear',\n h: 'hour',\n hours: 'hour',\n hour: 'hour',\n ms: 'millisecond',\n milliseconds: 'millisecond',\n millisecond: 'millisecond',\n m: 'minute',\n minutes: 'minute',\n minute: 'minute',\n M: 'month',\n months: 'month',\n month: 'month',\n Q: 'quarter',\n quarters: 'quarter',\n quarter: 'quarter',\n s: 'second',\n seconds: 'second',\n second: 'second',\n gg: 'weekYear',\n weekyears: 'weekYear',\n weekyear: 'weekYear',\n GG: 'isoWeekYear',\n isoweekyears: 'isoWeekYear',\n isoweekyear: 'isoWeekYear',\n w: 'week',\n weeks: 'week',\n week: 'week',\n W: 'isoWeek',\n isoweeks: 'isoWeek',\n isoweek: 'isoWeek',\n y: 'year',\n years: 'year',\n year: 'year',\n};\n\nfunction normalizeUnits(units) {\n return typeof units === 'string'\n ? aliases[units] || aliases[units.toLowerCase()]\n : undefined;\n}\n\nfunction normalizeObjectUnits(inputObject) {\n var normalizedInput = {},\n normalizedProp,\n prop;\n\n for (prop in inputObject) {\n if (hasOwnProp(inputObject, prop)) {\n normalizedProp = normalizeUnits(prop);\n if (normalizedProp) {\n normalizedInput[normalizedProp] = inputObject[prop];\n }\n }\n }\n\n return normalizedInput;\n}\n\nvar priorities = {\n date: 9,\n day: 11,\n weekday: 11,\n isoWeekday: 11,\n dayOfYear: 4,\n hour: 13,\n millisecond: 16,\n minute: 14,\n month: 8,\n quarter: 7,\n second: 15,\n weekYear: 1,\n isoWeekYear: 1,\n week: 5,\n isoWeek: 5,\n year: 1,\n};\n\nfunction getPrioritizedUnits(unitsObj) {\n var units = [],\n u;\n for (u in unitsObj) {\n if (hasOwnProp(unitsObj, u)) {\n units.push({ unit: u, priority: priorities[u] });\n }\n }\n units.sort(function (a, b) {\n return a.priority - b.priority;\n });\n return units;\n}\n\nvar match1 = /\\d/, // 0 - 9\n match2 = /\\d\\d/, // 00 - 99\n match3 = /\\d{3}/, // 000 - 999\n match4 = /\\d{4}/, // 0000 - 9999\n match6 = /[+-]?\\d{6}/, // -999999 - 999999\n match1to2 = /\\d\\d?/, // 0 - 99\n match3to4 = /\\d\\d\\d\\d?/, // 999 - 9999\n match5to6 = /\\d\\d\\d\\d\\d\\d?/, // 99999 - 999999\n match1to3 = /\\d{1,3}/, // 0 - 999\n match1to4 = /\\d{1,4}/, // 0 - 9999\n match1to6 = /[+-]?\\d{1,6}/, // -999999 - 999999\n matchUnsigned = /\\d+/, // 0 - inf\n matchSigned = /[+-]?\\d+/, // -inf - inf\n matchOffset = /Z|[+-]\\d\\d:?\\d\\d/gi, // +00:00 -00:00 +0000 -0000 or Z\n matchShortOffset = /Z|[+-]\\d\\d(?::?\\d\\d)?/gi, // +00 -00 +00:00 -00:00 +0000 -0000 or Z\n matchTimestamp = /[+-]?\\d+(\\.\\d{1,3})?/, // 123456789 123456789.123\n // any word (or two) characters or numbers including two/three word month in arabic.\n // includes scottish gaelic two word and hyphenated months\n matchWord =\n /[0-9]{0,256}['a-z\\u00A0-\\u05FF\\u0700-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFF07\\uFF10-\\uFFEF]{1,256}|[\\u0600-\\u06FF\\/]{1,256}(\\s*?[\\u0600-\\u06FF]{1,256}){1,2}/i,\n match1to2NoLeadingZero = /^[1-9]\\d?/, // 1-99\n match1to2HasZero = /^([1-9]\\d|\\d)/, // 0-99\n regexes;\n\nregexes = {};\n\nfunction addRegexToken(token, regex, strictRegex) {\n regexes[token] = isFunction(regex)\n ? regex\n : function (isStrict, localeData) {\n return isStrict && strictRegex ? strictRegex : regex;\n };\n}\n\nfunction getParseRegexForToken(token, config) {\n if (!hasOwnProp(regexes, token)) {\n return new RegExp(unescapeFormat(token));\n }\n\n return regexes[token](config._strict, config._locale);\n}\n\n// Code from http://stackoverflow.com/questions/3561493/is-there-a-regexp-escape-function-in-javascript\nfunction unescapeFormat(s) {\n return regexEscape(\n s\n .replace('\\\\', '')\n .replace(\n /\\\\(\\[)|\\\\(\\])|\\[([^\\]\\[]*)\\]|\\\\(.)/g,\n function (matched, p1, p2, p3, p4) {\n return p1 || p2 || p3 || p4;\n }\n )\n );\n}\n\nfunction regexEscape(s) {\n return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&');\n}\n\nfunction absFloor(number) {\n if (number < 0) {\n // -0 -> 0\n return Math.ceil(number) || 0;\n } else {\n return Math.floor(number);\n }\n}\n\nfunction toInt(argumentForCoercion) {\n var coercedNumber = +argumentForCoercion,\n value = 0;\n\n if (coercedNumber !== 0 && isFinite(coercedNumber)) {\n value = absFloor(coercedNumber);\n }\n\n return value;\n}\n\nvar tokens = {};\n\nfunction addParseToken(token, callback) {\n var i,\n func = callback,\n tokenLen;\n if (typeof token === 'string') {\n token = [token];\n }\n if (isNumber(callback)) {\n func = function (input, array) {\n array[callback] = toInt(input);\n };\n }\n tokenLen = token.length;\n for (i = 0; i < tokenLen; i++) {\n tokens[token[i]] = func;\n }\n}\n\nfunction addWeekParseToken(token, callback) {\n addParseToken(token, function (input, array, config, token) {\n config._w = config._w || {};\n callback(input, config._w, config, token);\n });\n}\n\nfunction addTimeToArrayFromToken(token, input, config) {\n if (input != null && hasOwnProp(tokens, token)) {\n tokens[token](input, config._a, config, token);\n }\n}\n\nfunction isLeapYear(year) {\n return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;\n}\n\nvar YEAR = 0,\n MONTH = 1,\n DATE = 2,\n HOUR = 3,\n MINUTE = 4,\n SECOND = 5,\n MILLISECOND = 6,\n WEEK = 7,\n WEEKDAY = 8;\n\n// FORMATTING\n\naddFormatToken('Y', 0, 0, function () {\n var y = this.year();\n return y <= 9999 ? zeroFill(y, 4) : '+' + y;\n});\n\naddFormatToken(0, ['YY', 2], 0, function () {\n return this.year() % 100;\n});\n\naddFormatToken(0, ['YYYY', 4], 0, 'year');\naddFormatToken(0, ['YYYYY', 5], 0, 'year');\naddFormatToken(0, ['YYYYYY', 6, true], 0, 'year');\n\n// PARSING\n\naddRegexToken('Y', matchSigned);\naddRegexToken('YY', match1to2, match2);\naddRegexToken('YYYY', match1to4, match4);\naddRegexToken('YYYYY', match1to6, match6);\naddRegexToken('YYYYYY', match1to6, match6);\n\naddParseToken(['YYYYY', 'YYYYYY'], YEAR);\naddParseToken('YYYY', function (input, array) {\n array[YEAR] =\n input.length === 2 ? hooks.parseTwoDigitYear(input) : toInt(input);\n});\naddParseToken('YY', function (input, array) {\n array[YEAR] = hooks.parseTwoDigitYear(input);\n});\naddParseToken('Y', function (input, array) {\n array[YEAR] = parseInt(input, 10);\n});\n\n// HELPERS\n\nfunction daysInYear(year) {\n return isLeapYear(year) ? 366 : 365;\n}\n\n// HOOKS\n\nhooks.parseTwoDigitYear = function (input) {\n return toInt(input) + (toInt(input) > 68 ? 1900 : 2000);\n};\n\n// MOMENTS\n\nvar getSetYear = makeGetSet('FullYear', true);\n\nfunction getIsLeapYear() {\n return isLeapYear(this.year());\n}\n\nfunction makeGetSet(unit, keepTime) {\n return function (value) {\n if (value != null) {\n set$1(this, unit, value);\n hooks.updateOffset(this, keepTime);\n return this;\n } else {\n return get(this, unit);\n }\n };\n}\n\nfunction get(mom, unit) {\n if (!mom.isValid()) {\n return NaN;\n }\n\n var d = mom._d,\n isUTC = mom._isUTC;\n\n switch (unit) {\n case 'Milliseconds':\n return isUTC ? d.getUTCMilliseconds() : d.getMilliseconds();\n case 'Seconds':\n return isUTC ? d.getUTCSeconds() : d.getSeconds();\n case 'Minutes':\n return isUTC ? d.getUTCMinutes() : d.getMinutes();\n case 'Hours':\n return isUTC ? d.getUTCHours() : d.getHours();\n case 'Date':\n return isUTC ? d.getUTCDate() : d.getDate();\n case 'Day':\n return isUTC ? d.getUTCDay() : d.getDay();\n case 'Month':\n return isUTC ? d.getUTCMonth() : d.getMonth();\n case 'FullYear':\n return isUTC ? d.getUTCFullYear() : d.getFullYear();\n default:\n return NaN; // Just in case\n }\n}\n\nfunction set$1(mom, unit, value) {\n var d, isUTC, year, month, date;\n\n if (!mom.isValid() || isNaN(value)) {\n return;\n }\n\n d = mom._d;\n isUTC = mom._isUTC;\n\n switch (unit) {\n case 'Milliseconds':\n return void (isUTC\n ? d.setUTCMilliseconds(value)\n : d.setMilliseconds(value));\n case 'Seconds':\n return void (isUTC ? d.setUTCSeconds(value) : d.setSeconds(value));\n case 'Minutes':\n return void (isUTC ? d.setUTCMinutes(value) : d.setMinutes(value));\n case 'Hours':\n return void (isUTC ? d.setUTCHours(value) : d.setHours(value));\n case 'Date':\n return void (isUTC ? d.setUTCDate(value) : d.setDate(value));\n // case 'Day': // Not real\n // return void (isUTC ? d.setUTCDay(value) : d.setDay(value));\n // case 'Month': // Not used because we need to pass two variables\n // return void (isUTC ? d.setUTCMonth(value) : d.setMonth(value));\n case 'FullYear':\n break; // See below ...\n default:\n return; // Just in case\n }\n\n year = value;\n month = mom.month();\n date = mom.date();\n date = date === 29 && month === 1 && !isLeapYear(year) ? 28 : date;\n void (isUTC\n ? d.setUTCFullYear(year, month, date)\n : d.setFullYear(year, month, date));\n}\n\n// MOMENTS\n\nfunction stringGet(units) {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units]();\n }\n return this;\n}\n\nfunction stringSet(units, value) {\n if (typeof units === 'object') {\n units = normalizeObjectUnits(units);\n var prioritized = getPrioritizedUnits(units),\n i,\n prioritizedLen = prioritized.length;\n for (i = 0; i < prioritizedLen; i++) {\n this[prioritized[i].unit](units[prioritized[i].unit]);\n }\n } else {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units](value);\n }\n }\n return this;\n}\n\nfunction mod(n, x) {\n return ((n % x) + x) % x;\n}\n\nvar indexOf;\n\nif (Array.prototype.indexOf) {\n indexOf = Array.prototype.indexOf;\n} else {\n indexOf = function (o) {\n // I know\n var i;\n for (i = 0; i < this.length; ++i) {\n if (this[i] === o) {\n return i;\n }\n }\n return -1;\n };\n}\n\nfunction daysInMonth(year, month) {\n if (isNaN(year) || isNaN(month)) {\n return NaN;\n }\n var modMonth = mod(month, 12);\n year += (month - modMonth) / 12;\n return modMonth === 1\n ? isLeapYear(year)\n ? 29\n : 28\n : 31 - ((modMonth % 7) % 2);\n}\n\n// FORMATTING\n\naddFormatToken('M', ['MM', 2], 'Mo', function () {\n return this.month() + 1;\n});\n\naddFormatToken('MMM', 0, 0, function (format) {\n return this.localeData().monthsShort(this, format);\n});\n\naddFormatToken('MMMM', 0, 0, function (format) {\n return this.localeData().months(this, format);\n});\n\n// PARSING\n\naddRegexToken('M', match1to2, match1to2NoLeadingZero);\naddRegexToken('MM', match1to2, match2);\naddRegexToken('MMM', function (isStrict, locale) {\n return locale.monthsShortRegex(isStrict);\n});\naddRegexToken('MMMM', function (isStrict, locale) {\n return locale.monthsRegex(isStrict);\n});\n\naddParseToken(['M', 'MM'], function (input, array) {\n array[MONTH] = toInt(input) - 1;\n});\n\naddParseToken(['MMM', 'MMMM'], function (input, array, config, token) {\n var month = config._locale.monthsParse(input, token, config._strict);\n // if we didn't find a month name, mark the date as invalid.\n if (month != null) {\n array[MONTH] = month;\n } else {\n getParsingFlags(config).invalidMonth = input;\n }\n});\n\n// LOCALES\n\nvar defaultLocaleMonths =\n 'January_February_March_April_May_June_July_August_September_October_November_December'.split(\n '_'\n ),\n defaultLocaleMonthsShort =\n 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_'),\n MONTHS_IN_FORMAT = /D[oD]?(\\[[^\\[\\]]*\\]|\\s)+MMMM?/,\n defaultMonthsShortRegex = matchWord,\n defaultMonthsRegex = matchWord;\n\nfunction localeMonths(m, format) {\n if (!m) {\n return isArray(this._months)\n ? this._months\n : this._months['standalone'];\n }\n return isArray(this._months)\n ? this._months[m.month()]\n : this._months[\n (this._months.isFormat || MONTHS_IN_FORMAT).test(format)\n ? 'format'\n : 'standalone'\n ][m.month()];\n}\n\nfunction localeMonthsShort(m, format) {\n if (!m) {\n return isArray(this._monthsShort)\n ? this._monthsShort\n : this._monthsShort['standalone'];\n }\n return isArray(this._monthsShort)\n ? this._monthsShort[m.month()]\n : this._monthsShort[\n MONTHS_IN_FORMAT.test(format) ? 'format' : 'standalone'\n ][m.month()];\n}\n\nfunction handleStrictParse(monthName, format, strict) {\n var i,\n ii,\n mom,\n llc = monthName.toLocaleLowerCase();\n if (!this._monthsParse) {\n // this is not used\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n for (i = 0; i < 12; ++i) {\n mom = createUTC([2000, i]);\n this._shortMonthsParse[i] = this.monthsShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._longMonthsParse[i] = this.months(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n}\n\nfunction localeMonthsParse(monthName, format, strict) {\n var i, mom, regex;\n\n if (this._monthsParseExact) {\n return handleStrictParse.call(this, monthName, format, strict);\n }\n\n if (!this._monthsParse) {\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n }\n\n // TODO: add sorting\n // Sorting makes sure if one month (or abbr) is a prefix of another\n // see sorting in computeMonthsParse\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n if (strict && !this._longMonthsParse[i]) {\n this._longMonthsParse[i] = new RegExp(\n '^' + this.months(mom, '').replace('.', '') + '$',\n 'i'\n );\n this._shortMonthsParse[i] = new RegExp(\n '^' + this.monthsShort(mom, '').replace('.', '') + '$',\n 'i'\n );\n }\n if (!strict && !this._monthsParse[i]) {\n regex =\n '^' + this.months(mom, '') + '|^' + this.monthsShort(mom, '');\n this._monthsParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'MMMM' &&\n this._longMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'MMM' &&\n this._shortMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (!strict && this._monthsParse[i].test(monthName)) {\n return i;\n }\n }\n}\n\n// MOMENTS\n\nfunction setMonth(mom, value) {\n if (!mom.isValid()) {\n // No op\n return mom;\n }\n\n if (typeof value === 'string') {\n if (/^\\d+$/.test(value)) {\n value = toInt(value);\n } else {\n value = mom.localeData().monthsParse(value);\n // TODO: Another silent failure?\n if (!isNumber(value)) {\n return mom;\n }\n }\n }\n\n var month = value,\n date = mom.date();\n\n date = date < 29 ? date : Math.min(date, daysInMonth(mom.year(), month));\n void (mom._isUTC\n ? mom._d.setUTCMonth(month, date)\n : mom._d.setMonth(month, date));\n return mom;\n}\n\nfunction getSetMonth(value) {\n if (value != null) {\n setMonth(this, value);\n hooks.updateOffset(this, true);\n return this;\n } else {\n return get(this, 'Month');\n }\n}\n\nfunction getDaysInMonth() {\n return daysInMonth(this.year(), this.month());\n}\n\nfunction monthsShortRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsShortStrictRegex;\n } else {\n return this._monthsShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsShortRegex')) {\n this._monthsShortRegex = defaultMonthsShortRegex;\n }\n return this._monthsShortStrictRegex && isStrict\n ? this._monthsShortStrictRegex\n : this._monthsShortRegex;\n }\n}\n\nfunction monthsRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsStrictRegex;\n } else {\n return this._monthsRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsRegex')) {\n this._monthsRegex = defaultMonthsRegex;\n }\n return this._monthsStrictRegex && isStrict\n ? this._monthsStrictRegex\n : this._monthsRegex;\n }\n}\n\nfunction computeMonthsParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n shortP,\n longP;\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n shortP = regexEscape(this.monthsShort(mom, ''));\n longP = regexEscape(this.months(mom, ''));\n shortPieces.push(shortP);\n longPieces.push(longP);\n mixedPieces.push(longP);\n mixedPieces.push(shortP);\n }\n // Sorting makes sure if one month (or abbr) is a prefix of another it\n // will match the longer piece.\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._monthsRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._monthsShortRegex = this._monthsRegex;\n this._monthsStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._monthsShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n}\n\nfunction createDate(y, m, d, h, M, s, ms) {\n // can't just apply() to create a date:\n // https://stackoverflow.com/q/181348\n var date;\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n date = new Date(y + 400, m, d, h, M, s, ms);\n if (isFinite(date.getFullYear())) {\n date.setFullYear(y);\n }\n } else {\n date = new Date(y, m, d, h, M, s, ms);\n }\n\n return date;\n}\n\nfunction createUTCDate(y) {\n var date, args;\n // the Date.UTC function remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n args = Array.prototype.slice.call(arguments);\n // preserve leap years using a full 400 year cycle, then reset\n args[0] = y + 400;\n date = new Date(Date.UTC.apply(null, args));\n if (isFinite(date.getUTCFullYear())) {\n date.setUTCFullYear(y);\n }\n } else {\n date = new Date(Date.UTC.apply(null, arguments));\n }\n\n return date;\n}\n\n// start-of-first-week - start-of-year\nfunction firstWeekOffset(year, dow, doy) {\n var // first-week day -- which january is always in the first week (4 for iso, 1 for other)\n fwd = 7 + dow - doy,\n // first-week day local weekday -- which local weekday is fwd\n fwdlw = (7 + createUTCDate(year, 0, fwd).getUTCDay() - dow) % 7;\n\n return -fwdlw + fwd - 1;\n}\n\n// https://en.wikipedia.org/wiki/ISO_week_date#Calculating_a_date_given_the_year.2C_week_number_and_weekday\nfunction dayOfYearFromWeeks(year, week, weekday, dow, doy) {\n var localWeekday = (7 + weekday - dow) % 7,\n weekOffset = firstWeekOffset(year, dow, doy),\n dayOfYear = 1 + 7 * (week - 1) + localWeekday + weekOffset,\n resYear,\n resDayOfYear;\n\n if (dayOfYear <= 0) {\n resYear = year - 1;\n resDayOfYear = daysInYear(resYear) + dayOfYear;\n } else if (dayOfYear > daysInYear(year)) {\n resYear = year + 1;\n resDayOfYear = dayOfYear - daysInYear(year);\n } else {\n resYear = year;\n resDayOfYear = dayOfYear;\n }\n\n return {\n year: resYear,\n dayOfYear: resDayOfYear,\n };\n}\n\nfunction weekOfYear(mom, dow, doy) {\n var weekOffset = firstWeekOffset(mom.year(), dow, doy),\n week = Math.floor((mom.dayOfYear() - weekOffset - 1) / 7) + 1,\n resWeek,\n resYear;\n\n if (week < 1) {\n resYear = mom.year() - 1;\n resWeek = week + weeksInYear(resYear, dow, doy);\n } else if (week > weeksInYear(mom.year(), dow, doy)) {\n resWeek = week - weeksInYear(mom.year(), dow, doy);\n resYear = mom.year() + 1;\n } else {\n resYear = mom.year();\n resWeek = week;\n }\n\n return {\n week: resWeek,\n year: resYear,\n };\n}\n\nfunction weeksInYear(year, dow, doy) {\n var weekOffset = firstWeekOffset(year, dow, doy),\n weekOffsetNext = firstWeekOffset(year + 1, dow, doy);\n return (daysInYear(year) - weekOffset + weekOffsetNext) / 7;\n}\n\n// FORMATTING\n\naddFormatToken('w', ['ww', 2], 'wo', 'week');\naddFormatToken('W', ['WW', 2], 'Wo', 'isoWeek');\n\n// PARSING\n\naddRegexToken('w', match1to2, match1to2NoLeadingZero);\naddRegexToken('ww', match1to2, match2);\naddRegexToken('W', match1to2, match1to2NoLeadingZero);\naddRegexToken('WW', match1to2, match2);\n\naddWeekParseToken(\n ['w', 'ww', 'W', 'WW'],\n function (input, week, config, token) {\n week[token.substr(0, 1)] = toInt(input);\n }\n);\n\n// HELPERS\n\n// LOCALES\n\nfunction localeWeek(mom) {\n return weekOfYear(mom, this._week.dow, this._week.doy).week;\n}\n\nvar defaultLocaleWeek = {\n dow: 0, // Sunday is the first day of the week.\n doy: 6, // The week that contains Jan 6th is the first week of the year.\n};\n\nfunction localeFirstDayOfWeek() {\n return this._week.dow;\n}\n\nfunction localeFirstDayOfYear() {\n return this._week.doy;\n}\n\n// MOMENTS\n\nfunction getSetWeek(input) {\n var week = this.localeData().week(this);\n return input == null ? week : this.add((input - week) * 7, 'd');\n}\n\nfunction getSetISOWeek(input) {\n var week = weekOfYear(this, 1, 4).week;\n return input == null ? week : this.add((input - week) * 7, 'd');\n}\n\n// FORMATTING\n\naddFormatToken('d', 0, 'do', 'day');\n\naddFormatToken('dd', 0, 0, function (format) {\n return this.localeData().weekdaysMin(this, format);\n});\n\naddFormatToken('ddd', 0, 0, function (format) {\n return this.localeData().weekdaysShort(this, format);\n});\n\naddFormatToken('dddd', 0, 0, function (format) {\n return this.localeData().weekdays(this, format);\n});\n\naddFormatToken('e', 0, 0, 'weekday');\naddFormatToken('E', 0, 0, 'isoWeekday');\n\n// PARSING\n\naddRegexToken('d', match1to2);\naddRegexToken('e', match1to2);\naddRegexToken('E', match1to2);\naddRegexToken('dd', function (isStrict, locale) {\n return locale.weekdaysMinRegex(isStrict);\n});\naddRegexToken('ddd', function (isStrict, locale) {\n return locale.weekdaysShortRegex(isStrict);\n});\naddRegexToken('dddd', function (isStrict, locale) {\n return locale.weekdaysRegex(isStrict);\n});\n\naddWeekParseToken(['dd', 'ddd', 'dddd'], function (input, week, config, token) {\n var weekday = config._locale.weekdaysParse(input, token, config._strict);\n // if we didn't get a weekday name, mark the date as invalid\n if (weekday != null) {\n week.d = weekday;\n } else {\n getParsingFlags(config).invalidWeekday = input;\n }\n});\n\naddWeekParseToken(['d', 'e', 'E'], function (input, week, config, token) {\n week[token] = toInt(input);\n});\n\n// HELPERS\n\nfunction parseWeekday(input, locale) {\n if (typeof input !== 'string') {\n return input;\n }\n\n if (!isNaN(input)) {\n return parseInt(input, 10);\n }\n\n input = locale.weekdaysParse(input);\n if (typeof input === 'number') {\n return input;\n }\n\n return null;\n}\n\nfunction parseIsoWeekday(input, locale) {\n if (typeof input === 'string') {\n return locale.weekdaysParse(input) % 7 || 7;\n }\n return isNaN(input) ? null : input;\n}\n\n// LOCALES\nfunction shiftWeekdays(ws, n) {\n return ws.slice(n, 7).concat(ws.slice(0, n));\n}\n\nvar defaultLocaleWeekdays =\n 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_'),\n defaultLocaleWeekdaysShort = 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_'),\n defaultLocaleWeekdaysMin = 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_'),\n defaultWeekdaysRegex = matchWord,\n defaultWeekdaysShortRegex = matchWord,\n defaultWeekdaysMinRegex = matchWord;\n\nfunction localeWeekdays(m, format) {\n var weekdays = isArray(this._weekdays)\n ? this._weekdays\n : this._weekdays[\n m && m !== true && this._weekdays.isFormat.test(format)\n ? 'format'\n : 'standalone'\n ];\n return m === true\n ? shiftWeekdays(weekdays, this._week.dow)\n : m\n ? weekdays[m.day()]\n : weekdays;\n}\n\nfunction localeWeekdaysShort(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysShort, this._week.dow)\n : m\n ? this._weekdaysShort[m.day()]\n : this._weekdaysShort;\n}\n\nfunction localeWeekdaysMin(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysMin, this._week.dow)\n : m\n ? this._weekdaysMin[m.day()]\n : this._weekdaysMin;\n}\n\nfunction handleStrictParse$1(weekdayName, format, strict) {\n var i,\n ii,\n mom,\n llc = weekdayName.toLocaleLowerCase();\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._minWeekdaysParse = [];\n\n for (i = 0; i < 7; ++i) {\n mom = createUTC([2000, 1]).day(i);\n this._minWeekdaysParse[i] = this.weekdaysMin(\n mom,\n ''\n ).toLocaleLowerCase();\n this._shortWeekdaysParse[i] = this.weekdaysShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._weekdaysParse[i] = this.weekdays(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n}\n\nfunction localeWeekdaysParse(weekdayName, format, strict) {\n var i, mom, regex;\n\n if (this._weekdaysParseExact) {\n return handleStrictParse$1.call(this, weekdayName, format, strict);\n }\n\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._minWeekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._fullWeekdaysParse = [];\n }\n\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n\n mom = createUTC([2000, 1]).day(i);\n if (strict && !this._fullWeekdaysParse[i]) {\n this._fullWeekdaysParse[i] = new RegExp(\n '^' + this.weekdays(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._shortWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysShort(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._minWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysMin(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n }\n if (!this._weekdaysParse[i]) {\n regex =\n '^' +\n this.weekdays(mom, '') +\n '|^' +\n this.weekdaysShort(mom, '') +\n '|^' +\n this.weekdaysMin(mom, '');\n this._weekdaysParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'dddd' &&\n this._fullWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'ddd' &&\n this._shortWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'dd' &&\n this._minWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (!strict && this._weekdaysParse[i].test(weekdayName)) {\n return i;\n }\n }\n}\n\n// MOMENTS\n\nfunction getSetDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n var day = get(this, 'Day');\n if (input != null) {\n input = parseWeekday(input, this.localeData());\n return this.add(input - day, 'd');\n } else {\n return day;\n }\n}\n\nfunction getSetLocaleDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7;\n return input == null ? weekday : this.add(input - weekday, 'd');\n}\n\nfunction getSetISODayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n // behaves the same as moment#day except\n // as a getter, returns 7 instead of 0 (1-7 range instead of 0-6)\n // as a setter, sunday should belong to the previous week.\n\n if (input != null) {\n var weekday = parseIsoWeekday(input, this.localeData());\n return this.day(this.day() % 7 ? weekday : weekday - 7);\n } else {\n return this.day() || 7;\n }\n}\n\nfunction weekdaysRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysStrictRegex;\n } else {\n return this._weekdaysRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n this._weekdaysRegex = defaultWeekdaysRegex;\n }\n return this._weekdaysStrictRegex && isStrict\n ? this._weekdaysStrictRegex\n : this._weekdaysRegex;\n }\n}\n\nfunction weekdaysShortRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysShortStrictRegex;\n } else {\n return this._weekdaysShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysShortRegex')) {\n this._weekdaysShortRegex = defaultWeekdaysShortRegex;\n }\n return this._weekdaysShortStrictRegex && isStrict\n ? this._weekdaysShortStrictRegex\n : this._weekdaysShortRegex;\n }\n}\n\nfunction weekdaysMinRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysMinStrictRegex;\n } else {\n return this._weekdaysMinRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysMinRegex')) {\n this._weekdaysMinRegex = defaultWeekdaysMinRegex;\n }\n return this._weekdaysMinStrictRegex && isStrict\n ? this._weekdaysMinStrictRegex\n : this._weekdaysMinRegex;\n }\n}\n\nfunction computeWeekdaysParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var minPieces = [],\n shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n minp,\n shortp,\n longp;\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, 1]).day(i);\n minp = regexEscape(this.weekdaysMin(mom, ''));\n shortp = regexEscape(this.weekdaysShort(mom, ''));\n longp = regexEscape(this.weekdays(mom, ''));\n minPieces.push(minp);\n shortPieces.push(shortp);\n longPieces.push(longp);\n mixedPieces.push(minp);\n mixedPieces.push(shortp);\n mixedPieces.push(longp);\n }\n // Sorting makes sure if one weekday (or abbr) is a prefix of another it\n // will match the longer piece.\n minPieces.sort(cmpLenRev);\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._weekdaysRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._weekdaysShortRegex = this._weekdaysRegex;\n this._weekdaysMinRegex = this._weekdaysRegex;\n\n this._weekdaysStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysMinStrictRegex = new RegExp(\n '^(' + minPieces.join('|') + ')',\n 'i'\n );\n}\n\n// FORMATTING\n\nfunction hFormat() {\n return this.hours() % 12 || 12;\n}\n\nfunction kFormat() {\n return this.hours() || 24;\n}\n\naddFormatToken('H', ['HH', 2], 0, 'hour');\naddFormatToken('h', ['hh', 2], 0, hFormat);\naddFormatToken('k', ['kk', 2], 0, kFormat);\n\naddFormatToken('hmm', 0, 0, function () {\n return '' + hFormat.apply(this) + zeroFill(this.minutes(), 2);\n});\n\naddFormatToken('hmmss', 0, 0, function () {\n return (\n '' +\n hFormat.apply(this) +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n});\n\naddFormatToken('Hmm', 0, 0, function () {\n return '' + this.hours() + zeroFill(this.minutes(), 2);\n});\n\naddFormatToken('Hmmss', 0, 0, function () {\n return (\n '' +\n this.hours() +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n});\n\nfunction meridiem(token, lowercase) {\n addFormatToken(token, 0, 0, function () {\n return this.localeData().meridiem(\n this.hours(),\n this.minutes(),\n lowercase\n );\n });\n}\n\nmeridiem('a', true);\nmeridiem('A', false);\n\n// PARSING\n\nfunction matchMeridiem(isStrict, locale) {\n return locale._meridiemParse;\n}\n\naddRegexToken('a', matchMeridiem);\naddRegexToken('A', matchMeridiem);\naddRegexToken('H', match1to2, match1to2HasZero);\naddRegexToken('h', match1to2, match1to2NoLeadingZero);\naddRegexToken('k', match1to2, match1to2NoLeadingZero);\naddRegexToken('HH', match1to2, match2);\naddRegexToken('hh', match1to2, match2);\naddRegexToken('kk', match1to2, match2);\n\naddRegexToken('hmm', match3to4);\naddRegexToken('hmmss', match5to6);\naddRegexToken('Hmm', match3to4);\naddRegexToken('Hmmss', match5to6);\n\naddParseToken(['H', 'HH'], HOUR);\naddParseToken(['k', 'kk'], function (input, array, config) {\n var kInput = toInt(input);\n array[HOUR] = kInput === 24 ? 0 : kInput;\n});\naddParseToken(['a', 'A'], function (input, array, config) {\n config._isPm = config._locale.isPM(input);\n config._meridiem = input;\n});\naddParseToken(['h', 'hh'], function (input, array, config) {\n array[HOUR] = toInt(input);\n getParsingFlags(config).bigHour = true;\n});\naddParseToken('hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n getParsingFlags(config).bigHour = true;\n});\naddParseToken('hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n getParsingFlags(config).bigHour = true;\n});\naddParseToken('Hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n});\naddParseToken('Hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n});\n\n// LOCALES\n\nfunction localeIsPM(input) {\n // IE8 Quirks Mode & IE7 Standards Mode do not allow accessing strings like arrays\n // Using charAt should be more compatible.\n return (input + '').toLowerCase().charAt(0) === 'p';\n}\n\nvar defaultLocaleMeridiemParse = /[ap]\\.?m?\\.?/i,\n // Setting the hour should keep the time, because the user explicitly\n // specified which hour they want. So trying to maintain the same hour (in\n // a new timezone) makes sense. Adding/subtracting hours does not follow\n // this rule.\n getSetHour = makeGetSet('Hours', true);\n\nfunction localeMeridiem(hours, minutes, isLower) {\n if (hours > 11) {\n return isLower ? 'pm' : 'PM';\n } else {\n return isLower ? 'am' : 'AM';\n }\n}\n\nvar baseConfig = {\n calendar: defaultCalendar,\n longDateFormat: defaultLongDateFormat,\n invalidDate: defaultInvalidDate,\n ordinal: defaultOrdinal,\n dayOfMonthOrdinalParse: defaultDayOfMonthOrdinalParse,\n relativeTime: defaultRelativeTime,\n\n months: defaultLocaleMonths,\n monthsShort: defaultLocaleMonthsShort,\n\n week: defaultLocaleWeek,\n\n weekdays: defaultLocaleWeekdays,\n weekdaysMin: defaultLocaleWeekdaysMin,\n weekdaysShort: defaultLocaleWeekdaysShort,\n\n meridiemParse: defaultLocaleMeridiemParse,\n};\n\n// internal storage for locale config files\nvar locales = {},\n localeFamilies = {},\n globalLocale;\n\nfunction commonPrefix(arr1, arr2) {\n var i,\n minl = Math.min(arr1.length, arr2.length);\n for (i = 0; i < minl; i += 1) {\n if (arr1[i] !== arr2[i]) {\n return i;\n }\n }\n return minl;\n}\n\nfunction normalizeLocale(key) {\n return key ? key.toLowerCase().replace('_', '-') : key;\n}\n\n// pick the locale from the array\n// try ['en-au', 'en-gb'] as 'en-au', 'en-gb', 'en', as in move through the list trying each\n// substring from most specific to least, but move to the next array item if it's a more specific variant than the current root\nfunction chooseLocale(names) {\n var i = 0,\n j,\n next,\n locale,\n split;\n\n while (i < names.length) {\n split = normalizeLocale(names[i]).split('-');\n j = split.length;\n next = normalizeLocale(names[i + 1]);\n next = next ? next.split('-') : null;\n while (j > 0) {\n locale = loadLocale(split.slice(0, j).join('-'));\n if (locale) {\n return locale;\n }\n if (\n next &&\n next.length >= j &&\n commonPrefix(split, next) >= j - 1\n ) {\n //the next array item is better than a shallower substring of this one\n break;\n }\n j--;\n }\n i++;\n }\n return globalLocale;\n}\n\nfunction isLocaleNameSane(name) {\n // Prevent names that look like filesystem paths, i.e contain '/' or '\\'\n // Ensure name is available and function returns boolean\n return !!(name && name.match('^[^/\\\\\\\\]*$'));\n}\n\nfunction loadLocale(name) {\n var oldLocale = null,\n aliasedRequire;\n // TODO: Find a better way to register and load all the locales in Node\n if (\n locales[name] === undefined &&\n typeof module !== 'undefined' &&\n module &&\n module.exports &&\n isLocaleNameSane(name)\n ) {\n try {\n oldLocale = globalLocale._abbr;\n aliasedRequire = require;\n aliasedRequire('./locale/' + name);\n getSetGlobalLocale(oldLocale);\n } catch (e) {\n // mark as not found to avoid repeating expensive file require call causing high CPU\n // when trying to find en-US, en_US, en-us for every format call\n locales[name] = null; // null means not found\n }\n }\n return locales[name];\n}\n\n// This function will load locale and then set the global locale. If\n// no arguments are passed in, it will simply return the current global\n// locale key.\nfunction getSetGlobalLocale(key, values) {\n var data;\n if (key) {\n if (isUndefined(values)) {\n data = getLocale(key);\n } else {\n data = defineLocale(key, values);\n }\n\n if (data) {\n // moment.duration._locale = moment._locale = data;\n globalLocale = data;\n } else {\n if (typeof console !== 'undefined' && console.warn) {\n //warn user if arguments are passed but the locale could not be set\n console.warn(\n 'Locale ' + key + ' not found. Did you forget to load it?'\n );\n }\n }\n }\n\n return globalLocale._abbr;\n}\n\nfunction defineLocale(name, config) {\n if (config !== null) {\n var locale,\n parentConfig = baseConfig;\n config.abbr = name;\n if (locales[name] != null) {\n deprecateSimple(\n 'defineLocaleOverride',\n 'use moment.updateLocale(localeName, config) to change ' +\n 'an existing locale. moment.defineLocale(localeName, ' +\n 'config) should only be used for creating a new locale ' +\n 'See http://momentjs.com/guides/#/warnings/define-locale/ for more info.'\n );\n parentConfig = locales[name]._config;\n } else if (config.parentLocale != null) {\n if (locales[config.parentLocale] != null) {\n parentConfig = locales[config.parentLocale]._config;\n } else {\n locale = loadLocale(config.parentLocale);\n if (locale != null) {\n parentConfig = locale._config;\n } else {\n if (!localeFamilies[config.parentLocale]) {\n localeFamilies[config.parentLocale] = [];\n }\n localeFamilies[config.parentLocale].push({\n name: name,\n config: config,\n });\n return null;\n }\n }\n }\n locales[name] = new Locale(mergeConfigs(parentConfig, config));\n\n if (localeFamilies[name]) {\n localeFamilies[name].forEach(function (x) {\n defineLocale(x.name, x.config);\n });\n }\n\n // backwards compat for now: also set the locale\n // make sure we set the locale AFTER all child locales have been\n // created, so we won't end up with the child locale set.\n getSetGlobalLocale(name);\n\n return locales[name];\n } else {\n // useful for testing\n delete locales[name];\n return null;\n }\n}\n\nfunction updateLocale(name, config) {\n if (config != null) {\n var locale,\n tmpLocale,\n parentConfig = baseConfig;\n\n if (locales[name] != null && locales[name].parentLocale != null) {\n // Update existing child locale in-place to avoid memory-leaks\n locales[name].set(mergeConfigs(locales[name]._config, config));\n } else {\n // MERGE\n tmpLocale = loadLocale(name);\n if (tmpLocale != null) {\n parentConfig = tmpLocale._config;\n }\n config = mergeConfigs(parentConfig, config);\n if (tmpLocale == null) {\n // updateLocale is called for creating a new locale\n // Set abbr so it will have a name (getters return\n // undefined otherwise).\n config.abbr = name;\n }\n locale = new Locale(config);\n locale.parentLocale = locales[name];\n locales[name] = locale;\n }\n\n // backwards compat for now: also set the locale\n getSetGlobalLocale(name);\n } else {\n // pass null for config to unupdate, useful for tests\n if (locales[name] != null) {\n if (locales[name].parentLocale != null) {\n locales[name] = locales[name].parentLocale;\n if (name === getSetGlobalLocale()) {\n getSetGlobalLocale(name);\n }\n } else if (locales[name] != null) {\n delete locales[name];\n }\n }\n }\n return locales[name];\n}\n\n// returns locale data\nfunction getLocale(key) {\n var locale;\n\n if (key && key._locale && key._locale._abbr) {\n key = key._locale._abbr;\n }\n\n if (!key) {\n return globalLocale;\n }\n\n if (!isArray(key)) {\n //short-circuit everything else\n locale = loadLocale(key);\n if (locale) {\n return locale;\n }\n key = [key];\n }\n\n return chooseLocale(key);\n}\n\nfunction listLocales() {\n return keys(locales);\n}\n\nfunction checkOverflow(m) {\n var overflow,\n a = m._a;\n\n if (a && getParsingFlags(m).overflow === -2) {\n overflow =\n a[MONTH] < 0 || a[MONTH] > 11\n ? MONTH\n : a[DATE] < 1 || a[DATE] > daysInMonth(a[YEAR], a[MONTH])\n ? DATE\n : a[HOUR] < 0 ||\n a[HOUR] > 24 ||\n (a[HOUR] === 24 &&\n (a[MINUTE] !== 0 ||\n a[SECOND] !== 0 ||\n a[MILLISECOND] !== 0))\n ? HOUR\n : a[MINUTE] < 0 || a[MINUTE] > 59\n ? MINUTE\n : a[SECOND] < 0 || a[SECOND] > 59\n ? SECOND\n : a[MILLISECOND] < 0 || a[MILLISECOND] > 999\n ? MILLISECOND\n : -1;\n\n if (\n getParsingFlags(m)._overflowDayOfYear &&\n (overflow < YEAR || overflow > DATE)\n ) {\n overflow = DATE;\n }\n if (getParsingFlags(m)._overflowWeeks && overflow === -1) {\n overflow = WEEK;\n }\n if (getParsingFlags(m)._overflowWeekday && overflow === -1) {\n overflow = WEEKDAY;\n }\n\n getParsingFlags(m).overflow = overflow;\n }\n\n return m;\n}\n\n// iso 8601 regex\n// 0000-00-00 0000-W00 or 0000-W00-0 + T + 00 or 00:00 or 00:00:00 or 00:00:00.000 + +00:00 or +0000 or +00)\nvar extendedIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})-(?:\\d\\d-\\d\\d|W\\d\\d-\\d|W\\d\\d|\\d\\d\\d|\\d\\d))(?:(T| )(\\d\\d(?::\\d\\d(?::\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n basicIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})(?:\\d\\d\\d\\d|W\\d\\d\\d|W\\d\\d|\\d\\d\\d|\\d\\d|))(?:(T| )(\\d\\d(?:\\d\\d(?:\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n tzRegex = /Z|[+-]\\d\\d(?::?\\d\\d)?/,\n isoDates = [\n ['YYYYYY-MM-DD', /[+-]\\d{6}-\\d\\d-\\d\\d/],\n ['YYYY-MM-DD', /\\d{4}-\\d\\d-\\d\\d/],\n ['GGGG-[W]WW-E', /\\d{4}-W\\d\\d-\\d/],\n ['GGGG-[W]WW', /\\d{4}-W\\d\\d/, false],\n ['YYYY-DDD', /\\d{4}-\\d{3}/],\n ['YYYY-MM', /\\d{4}-\\d\\d/, false],\n ['YYYYYYMMDD', /[+-]\\d{10}/],\n ['YYYYMMDD', /\\d{8}/],\n ['GGGG[W]WWE', /\\d{4}W\\d{3}/],\n ['GGGG[W]WW', /\\d{4}W\\d{2}/, false],\n ['YYYYDDD', /\\d{7}/],\n ['YYYYMM', /\\d{6}/, false],\n ['YYYY', /\\d{4}/, false],\n ],\n // iso time formats and regexes\n isoTimes = [\n ['HH:mm:ss.SSSS', /\\d\\d:\\d\\d:\\d\\d\\.\\d+/],\n ['HH:mm:ss,SSSS', /\\d\\d:\\d\\d:\\d\\d,\\d+/],\n ['HH:mm:ss', /\\d\\d:\\d\\d:\\d\\d/],\n ['HH:mm', /\\d\\d:\\d\\d/],\n ['HHmmss.SSSS', /\\d\\d\\d\\d\\d\\d\\.\\d+/],\n ['HHmmss,SSSS', /\\d\\d\\d\\d\\d\\d,\\d+/],\n ['HHmmss', /\\d\\d\\d\\d\\d\\d/],\n ['HHmm', /\\d\\d\\d\\d/],\n ['HH', /\\d\\d/],\n ],\n aspNetJsonRegex = /^\\/?Date\\((-?\\d+)/i,\n // RFC 2822 regex: For details see https://tools.ietf.org/html/rfc2822#section-3.3\n rfc2822 =\n /^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\\s)?(\\d{1,2})\\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\\s(\\d{2,4})\\s(\\d\\d):(\\d\\d)(?::(\\d\\d))?\\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\\d{4}))$/,\n obsOffsets = {\n UT: 0,\n GMT: 0,\n EDT: -4 * 60,\n EST: -5 * 60,\n CDT: -5 * 60,\n CST: -6 * 60,\n MDT: -6 * 60,\n MST: -7 * 60,\n PDT: -7 * 60,\n PST: -8 * 60,\n };\n\n// date from iso format\nfunction configFromISO(config) {\n var i,\n l,\n string = config._i,\n match = extendedIsoRegex.exec(string) || basicIsoRegex.exec(string),\n allowTime,\n dateFormat,\n timeFormat,\n tzFormat,\n isoDatesLen = isoDates.length,\n isoTimesLen = isoTimes.length;\n\n if (match) {\n getParsingFlags(config).iso = true;\n for (i = 0, l = isoDatesLen; i < l; i++) {\n if (isoDates[i][1].exec(match[1])) {\n dateFormat = isoDates[i][0];\n allowTime = isoDates[i][2] !== false;\n break;\n }\n }\n if (dateFormat == null) {\n config._isValid = false;\n return;\n }\n if (match[3]) {\n for (i = 0, l = isoTimesLen; i < l; i++) {\n if (isoTimes[i][1].exec(match[3])) {\n // match[2] should be 'T' or space\n timeFormat = (match[2] || ' ') + isoTimes[i][0];\n break;\n }\n }\n if (timeFormat == null) {\n config._isValid = false;\n return;\n }\n }\n if (!allowTime && timeFormat != null) {\n config._isValid = false;\n return;\n }\n if (match[4]) {\n if (tzRegex.exec(match[4])) {\n tzFormat = 'Z';\n } else {\n config._isValid = false;\n return;\n }\n }\n config._f = dateFormat + (timeFormat || '') + (tzFormat || '');\n configFromStringAndFormat(config);\n } else {\n config._isValid = false;\n }\n}\n\nfunction extractFromRFC2822Strings(\n yearStr,\n monthStr,\n dayStr,\n hourStr,\n minuteStr,\n secondStr\n) {\n var result = [\n untruncateYear(yearStr),\n defaultLocaleMonthsShort.indexOf(monthStr),\n parseInt(dayStr, 10),\n parseInt(hourStr, 10),\n parseInt(minuteStr, 10),\n ];\n\n if (secondStr) {\n result.push(parseInt(secondStr, 10));\n }\n\n return result;\n}\n\nfunction untruncateYear(yearStr) {\n var year = parseInt(yearStr, 10);\n if (year <= 49) {\n return 2000 + year;\n } else if (year <= 999) {\n return 1900 + year;\n }\n return year;\n}\n\nfunction preprocessRFC2822(s) {\n // Remove comments and folding whitespace and replace multiple-spaces with a single space\n return s\n .replace(/\\([^()]*\\)|[\\n\\t]/g, ' ')\n .replace(/(\\s\\s+)/g, ' ')\n .replace(/^\\s\\s*/, '')\n .replace(/\\s\\s*$/, '');\n}\n\nfunction checkWeekday(weekdayStr, parsedInput, config) {\n if (weekdayStr) {\n // TODO: Replace the vanilla JS Date object with an independent day-of-week check.\n var weekdayProvided = defaultLocaleWeekdaysShort.indexOf(weekdayStr),\n weekdayActual = new Date(\n parsedInput[0],\n parsedInput[1],\n parsedInput[2]\n ).getDay();\n if (weekdayProvided !== weekdayActual) {\n getParsingFlags(config).weekdayMismatch = true;\n config._isValid = false;\n return false;\n }\n }\n return true;\n}\n\nfunction calculateOffset(obsOffset, militaryOffset, numOffset) {\n if (obsOffset) {\n return obsOffsets[obsOffset];\n } else if (militaryOffset) {\n // the only allowed military tz is Z\n return 0;\n } else {\n var hm = parseInt(numOffset, 10),\n m = hm % 100,\n h = (hm - m) / 100;\n return h * 60 + m;\n }\n}\n\n// date and time from ref 2822 format\nfunction configFromRFC2822(config) {\n var match = rfc2822.exec(preprocessRFC2822(config._i)),\n parsedArray;\n if (match) {\n parsedArray = extractFromRFC2822Strings(\n match[4],\n match[3],\n match[2],\n match[5],\n match[6],\n match[7]\n );\n if (!checkWeekday(match[1], parsedArray, config)) {\n return;\n }\n\n config._a = parsedArray;\n config._tzm = calculateOffset(match[8], match[9], match[10]);\n\n config._d = createUTCDate.apply(null, config._a);\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n\n getParsingFlags(config).rfc2822 = true;\n } else {\n config._isValid = false;\n }\n}\n\n// date from 1) ASP.NET, 2) ISO, 3) RFC 2822 formats, or 4) optional fallback if parsing isn't strict\nfunction configFromString(config) {\n var matched = aspNetJsonRegex.exec(config._i);\n if (matched !== null) {\n config._d = new Date(+matched[1]);\n return;\n }\n\n configFromISO(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n configFromRFC2822(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n if (config._strict) {\n config._isValid = false;\n } else {\n // Final attempt, use Input Fallback\n hooks.createFromInputFallback(config);\n }\n}\n\nhooks.createFromInputFallback = deprecate(\n 'value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), ' +\n 'which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are ' +\n 'discouraged. Please refer to http://momentjs.com/guides/#/warnings/js-date/ for more info.',\n function (config) {\n config._d = new Date(config._i + (config._useUTC ? ' UTC' : ''));\n }\n);\n\n// Pick the first defined of two or three arguments.\nfunction defaults(a, b, c) {\n if (a != null) {\n return a;\n }\n if (b != null) {\n return b;\n }\n return c;\n}\n\nfunction currentDateArray(config) {\n // hooks is actually the exported moment object\n var nowValue = new Date(hooks.now());\n if (config._useUTC) {\n return [\n nowValue.getUTCFullYear(),\n nowValue.getUTCMonth(),\n nowValue.getUTCDate(),\n ];\n }\n return [nowValue.getFullYear(), nowValue.getMonth(), nowValue.getDate()];\n}\n\n// convert an array to a date.\n// the array should mirror the parameters below\n// note: all values past the year are optional and will default to the lowest possible value.\n// [year, month, day , hour, minute, second, millisecond]\nfunction configFromArray(config) {\n var i,\n date,\n input = [],\n currentDate,\n expectedWeekday,\n yearToUse;\n\n if (config._d) {\n return;\n }\n\n currentDate = currentDateArray(config);\n\n //compute day of the year from weeks and weekdays\n if (config._w && config._a[DATE] == null && config._a[MONTH] == null) {\n dayOfYearFromWeekInfo(config);\n }\n\n //if the day of the year is set, figure out what it is\n if (config._dayOfYear != null) {\n yearToUse = defaults(config._a[YEAR], currentDate[YEAR]);\n\n if (\n config._dayOfYear > daysInYear(yearToUse) ||\n config._dayOfYear === 0\n ) {\n getParsingFlags(config)._overflowDayOfYear = true;\n }\n\n date = createUTCDate(yearToUse, 0, config._dayOfYear);\n config._a[MONTH] = date.getUTCMonth();\n config._a[DATE] = date.getUTCDate();\n }\n\n // Default to current date.\n // * if no year, month, day of month are given, default to today\n // * if day of month is given, default month and year\n // * if month is given, default only year\n // * if year is given, don't default anything\n for (i = 0; i < 3 && config._a[i] == null; ++i) {\n config._a[i] = input[i] = currentDate[i];\n }\n\n // Zero out whatever was not defaulted, including time\n for (; i < 7; i++) {\n config._a[i] = input[i] =\n config._a[i] == null ? (i === 2 ? 1 : 0) : config._a[i];\n }\n\n // Check for 24:00:00.000\n if (\n config._a[HOUR] === 24 &&\n config._a[MINUTE] === 0 &&\n config._a[SECOND] === 0 &&\n config._a[MILLISECOND] === 0\n ) {\n config._nextDay = true;\n config._a[HOUR] = 0;\n }\n\n config._d = (config._useUTC ? createUTCDate : createDate).apply(\n null,\n input\n );\n expectedWeekday = config._useUTC\n ? config._d.getUTCDay()\n : config._d.getDay();\n\n // Apply timezone offset from input. The actual utcOffset can be changed\n // with parseZone.\n if (config._tzm != null) {\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n }\n\n if (config._nextDay) {\n config._a[HOUR] = 24;\n }\n\n // check for mismatching day of week\n if (\n config._w &&\n typeof config._w.d !== 'undefined' &&\n config._w.d !== expectedWeekday\n ) {\n getParsingFlags(config).weekdayMismatch = true;\n }\n}\n\nfunction dayOfYearFromWeekInfo(config) {\n var w, weekYear, week, weekday, dow, doy, temp, weekdayOverflow, curWeek;\n\n w = config._w;\n if (w.GG != null || w.W != null || w.E != null) {\n dow = 1;\n doy = 4;\n\n // TODO: We need to take the current isoWeekYear, but that depends on\n // how we interpret now (local, utc, fixed offset). So create\n // a now version of current config (take local/utc/offset flags, and\n // create now).\n weekYear = defaults(\n w.GG,\n config._a[YEAR],\n weekOfYear(createLocal(), 1, 4).year\n );\n week = defaults(w.W, 1);\n weekday = defaults(w.E, 1);\n if (weekday < 1 || weekday > 7) {\n weekdayOverflow = true;\n }\n } else {\n dow = config._locale._week.dow;\n doy = config._locale._week.doy;\n\n curWeek = weekOfYear(createLocal(), dow, doy);\n\n weekYear = defaults(w.gg, config._a[YEAR], curWeek.year);\n\n // Default to current week.\n week = defaults(w.w, curWeek.week);\n\n if (w.d != null) {\n // weekday -- low day numbers are considered next week\n weekday = w.d;\n if (weekday < 0 || weekday > 6) {\n weekdayOverflow = true;\n }\n } else if (w.e != null) {\n // local weekday -- counting starts from beginning of week\n weekday = w.e + dow;\n if (w.e < 0 || w.e > 6) {\n weekdayOverflow = true;\n }\n } else {\n // default to beginning of week\n weekday = dow;\n }\n }\n if (week < 1 || week > weeksInYear(weekYear, dow, doy)) {\n getParsingFlags(config)._overflowWeeks = true;\n } else if (weekdayOverflow != null) {\n getParsingFlags(config)._overflowWeekday = true;\n } else {\n temp = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy);\n config._a[YEAR] = temp.year;\n config._dayOfYear = temp.dayOfYear;\n }\n}\n\n// constant that refers to the ISO standard\nhooks.ISO_8601 = function () {};\n\n// constant that refers to the RFC 2822 form\nhooks.RFC_2822 = function () {};\n\n// date from string and format string\nfunction configFromStringAndFormat(config) {\n // TODO: Move this to another part of the creation flow to prevent circular deps\n if (config._f === hooks.ISO_8601) {\n configFromISO(config);\n return;\n }\n if (config._f === hooks.RFC_2822) {\n configFromRFC2822(config);\n return;\n }\n config._a = [];\n getParsingFlags(config).empty = true;\n\n // This array is used to make a Date, either with `new Date` or `Date.UTC`\n var string = '' + config._i,\n i,\n parsedInput,\n tokens,\n token,\n skipped,\n stringLength = string.length,\n totalParsedInputLength = 0,\n era,\n tokenLen;\n\n tokens =\n expandFormat(config._f, config._locale).match(formattingTokens) || [];\n tokenLen = tokens.length;\n for (i = 0; i < tokenLen; i++) {\n token = tokens[i];\n parsedInput = (string.match(getParseRegexForToken(token, config)) ||\n [])[0];\n if (parsedInput) {\n skipped = string.substr(0, string.indexOf(parsedInput));\n if (skipped.length > 0) {\n getParsingFlags(config).unusedInput.push(skipped);\n }\n string = string.slice(\n string.indexOf(parsedInput) + parsedInput.length\n );\n totalParsedInputLength += parsedInput.length;\n }\n // don't parse if it's not a known token\n if (formatTokenFunctions[token]) {\n if (parsedInput) {\n getParsingFlags(config).empty = false;\n } else {\n getParsingFlags(config).unusedTokens.push(token);\n }\n addTimeToArrayFromToken(token, parsedInput, config);\n } else if (config._strict && !parsedInput) {\n getParsingFlags(config).unusedTokens.push(token);\n }\n }\n\n // add remaining unparsed input length to the string\n getParsingFlags(config).charsLeftOver =\n stringLength - totalParsedInputLength;\n if (string.length > 0) {\n getParsingFlags(config).unusedInput.push(string);\n }\n\n // clear _12h flag if hour is <= 12\n if (\n config._a[HOUR] <= 12 &&\n getParsingFlags(config).bigHour === true &&\n config._a[HOUR] > 0\n ) {\n getParsingFlags(config).bigHour = undefined;\n }\n\n getParsingFlags(config).parsedDateParts = config._a.slice(0);\n getParsingFlags(config).meridiem = config._meridiem;\n // handle meridiem\n config._a[HOUR] = meridiemFixWrap(\n config._locale,\n config._a[HOUR],\n config._meridiem\n );\n\n // handle era\n era = getParsingFlags(config).era;\n if (era !== null) {\n config._a[YEAR] = config._locale.erasConvertYear(era, config._a[YEAR]);\n }\n\n configFromArray(config);\n checkOverflow(config);\n}\n\nfunction meridiemFixWrap(locale, hour, meridiem) {\n var isPm;\n\n if (meridiem == null) {\n // nothing to do\n return hour;\n }\n if (locale.meridiemHour != null) {\n return locale.meridiemHour(hour, meridiem);\n } else if (locale.isPM != null) {\n // Fallback\n isPm = locale.isPM(meridiem);\n if (isPm && hour < 12) {\n hour += 12;\n }\n if (!isPm && hour === 12) {\n hour = 0;\n }\n return hour;\n } else {\n // this is not supposed to happen\n return hour;\n }\n}\n\n// date from string and array of format strings\nfunction configFromStringAndArray(config) {\n var tempConfig,\n bestMoment,\n scoreToBeat,\n i,\n currentScore,\n validFormatFound,\n bestFormatIsValid = false,\n configfLen = config._f.length;\n\n if (configfLen === 0) {\n getParsingFlags(config).invalidFormat = true;\n config._d = new Date(NaN);\n return;\n }\n\n for (i = 0; i < configfLen; i++) {\n currentScore = 0;\n validFormatFound = false;\n tempConfig = copyConfig({}, config);\n if (config._useUTC != null) {\n tempConfig._useUTC = config._useUTC;\n }\n tempConfig._f = config._f[i];\n configFromStringAndFormat(tempConfig);\n\n if (isValid(tempConfig)) {\n validFormatFound = true;\n }\n\n // if there is any input that was not parsed add a penalty for that format\n currentScore += getParsingFlags(tempConfig).charsLeftOver;\n\n //or tokens\n currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10;\n\n getParsingFlags(tempConfig).score = currentScore;\n\n if (!bestFormatIsValid) {\n if (\n scoreToBeat == null ||\n currentScore < scoreToBeat ||\n validFormatFound\n ) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n if (validFormatFound) {\n bestFormatIsValid = true;\n }\n }\n } else {\n if (currentScore < scoreToBeat) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n }\n }\n }\n\n extend(config, bestMoment || tempConfig);\n}\n\nfunction configFromObject(config) {\n if (config._d) {\n return;\n }\n\n var i = normalizeObjectUnits(config._i),\n dayOrDate = i.day === undefined ? i.date : i.day;\n config._a = map(\n [i.year, i.month, dayOrDate, i.hour, i.minute, i.second, i.millisecond],\n function (obj) {\n return obj && parseInt(obj, 10);\n }\n );\n\n configFromArray(config);\n}\n\nfunction createFromConfig(config) {\n var res = new Moment(checkOverflow(prepareConfig(config)));\n if (res._nextDay) {\n // Adding is smart enough around DST\n res.add(1, 'd');\n res._nextDay = undefined;\n }\n\n return res;\n}\n\nfunction prepareConfig(config) {\n var input = config._i,\n format = config._f;\n\n config._locale = config._locale || getLocale(config._l);\n\n if (input === null || (format === undefined && input === '')) {\n return createInvalid({ nullInput: true });\n }\n\n if (typeof input === 'string') {\n config._i = input = config._locale.preparse(input);\n }\n\n if (isMoment(input)) {\n return new Moment(checkOverflow(input));\n } else if (isDate(input)) {\n config._d = input;\n } else if (isArray(format)) {\n configFromStringAndArray(config);\n } else if (format) {\n configFromStringAndFormat(config);\n } else {\n configFromInput(config);\n }\n\n if (!isValid(config)) {\n config._d = null;\n }\n\n return config;\n}\n\nfunction configFromInput(config) {\n var input = config._i;\n if (isUndefined(input)) {\n config._d = new Date(hooks.now());\n } else if (isDate(input)) {\n config._d = new Date(input.valueOf());\n } else if (typeof input === 'string') {\n configFromString(config);\n } else if (isArray(input)) {\n config._a = map(input.slice(0), function (obj) {\n return parseInt(obj, 10);\n });\n configFromArray(config);\n } else if (isObject(input)) {\n configFromObject(config);\n } else if (isNumber(input)) {\n // from milliseconds\n config._d = new Date(input);\n } else {\n hooks.createFromInputFallback(config);\n }\n}\n\nfunction createLocalOrUTC(input, format, locale, strict, isUTC) {\n var c = {};\n\n if (format === true || format === false) {\n strict = format;\n format = undefined;\n }\n\n if (locale === true || locale === false) {\n strict = locale;\n locale = undefined;\n }\n\n if (\n (isObject(input) && isObjectEmpty(input)) ||\n (isArray(input) && input.length === 0)\n ) {\n input = undefined;\n }\n // object construction must be done this way.\n // https://github.com/moment/moment/issues/1423\n c._isAMomentObject = true;\n c._useUTC = c._isUTC = isUTC;\n c._l = locale;\n c._i = input;\n c._f = format;\n c._strict = strict;\n\n return createFromConfig(c);\n}\n\nfunction createLocal(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, false);\n}\n\nvar prototypeMin = deprecate(\n 'moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other < this ? this : other;\n } else {\n return createInvalid();\n }\n }\n ),\n prototypeMax = deprecate(\n 'moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other > this ? this : other;\n } else {\n return createInvalid();\n }\n }\n );\n\n// Pick a moment m from moments so that m[fn](other) is true for all\n// other. This relies on the function fn to be transitive.\n//\n// moments should either be an array of moment objects or an array, whose\n// first element is an array of moment objects.\nfunction pickBy(fn, moments) {\n var res, i;\n if (moments.length === 1 && isArray(moments[0])) {\n moments = moments[0];\n }\n if (!moments.length) {\n return createLocal();\n }\n res = moments[0];\n for (i = 1; i < moments.length; ++i) {\n if (!moments[i].isValid() || moments[i][fn](res)) {\n res = moments[i];\n }\n }\n return res;\n}\n\n// TODO: Use [].sort instead?\nfunction min() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isBefore', args);\n}\n\nfunction max() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isAfter', args);\n}\n\nvar now = function () {\n return Date.now ? Date.now() : +new Date();\n};\n\nvar ordering = [\n 'year',\n 'quarter',\n 'month',\n 'week',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'millisecond',\n];\n\nfunction isDurationValid(m) {\n var key,\n unitHasDecimal = false,\n i,\n orderLen = ordering.length;\n for (key in m) {\n if (\n hasOwnProp(m, key) &&\n !(\n indexOf.call(ordering, key) !== -1 &&\n (m[key] == null || !isNaN(m[key]))\n )\n ) {\n return false;\n }\n }\n\n for (i = 0; i < orderLen; ++i) {\n if (m[ordering[i]]) {\n if (unitHasDecimal) {\n return false; // only allow non-integers for smallest unit\n }\n if (parseFloat(m[ordering[i]]) !== toInt(m[ordering[i]])) {\n unitHasDecimal = true;\n }\n }\n }\n\n return true;\n}\n\nfunction isValid$1() {\n return this._isValid;\n}\n\nfunction createInvalid$1() {\n return createDuration(NaN);\n}\n\nfunction Duration(duration) {\n var normalizedInput = normalizeObjectUnits(duration),\n years = normalizedInput.year || 0,\n quarters = normalizedInput.quarter || 0,\n months = normalizedInput.month || 0,\n weeks = normalizedInput.week || normalizedInput.isoWeek || 0,\n days = normalizedInput.day || 0,\n hours = normalizedInput.hour || 0,\n minutes = normalizedInput.minute || 0,\n seconds = normalizedInput.second || 0,\n milliseconds = normalizedInput.millisecond || 0;\n\n this._isValid = isDurationValid(normalizedInput);\n\n // representation for dateAddRemove\n this._milliseconds =\n +milliseconds +\n seconds * 1e3 + // 1000\n minutes * 6e4 + // 1000 * 60\n hours * 1000 * 60 * 60; //using 1000 * 60 * 60 instead of 36e5 to avoid floating point rounding errors https://github.com/moment/moment/issues/2978\n // Because of dateAddRemove treats 24 hours as different from a\n // day when working around DST, we need to store them separately\n this._days = +days + weeks * 7;\n // It is impossible to translate months into days without knowing\n // which months you are are talking about, so we have to store\n // it separately.\n this._months = +months + quarters * 3 + years * 12;\n\n this._data = {};\n\n this._locale = getLocale();\n\n this._bubble();\n}\n\nfunction isDuration(obj) {\n return obj instanceof Duration;\n}\n\nfunction absRound(number) {\n if (number < 0) {\n return Math.round(-1 * number) * -1;\n } else {\n return Math.round(number);\n }\n}\n\n// compare two arrays, return the number of differences\nfunction compareArrays(array1, array2, dontConvert) {\n var len = Math.min(array1.length, array2.length),\n lengthDiff = Math.abs(array1.length - array2.length),\n diffs = 0,\n i;\n for (i = 0; i < len; i++) {\n if (\n (dontConvert && array1[i] !== array2[i]) ||\n (!dontConvert && toInt(array1[i]) !== toInt(array2[i]))\n ) {\n diffs++;\n }\n }\n return diffs + lengthDiff;\n}\n\n// FORMATTING\n\nfunction offset(token, separator) {\n addFormatToken(token, 0, 0, function () {\n var offset = this.utcOffset(),\n sign = '+';\n if (offset < 0) {\n offset = -offset;\n sign = '-';\n }\n return (\n sign +\n zeroFill(~~(offset / 60), 2) +\n separator +\n zeroFill(~~offset % 60, 2)\n );\n });\n}\n\noffset('Z', ':');\noffset('ZZ', '');\n\n// PARSING\n\naddRegexToken('Z', matchShortOffset);\naddRegexToken('ZZ', matchShortOffset);\naddParseToken(['Z', 'ZZ'], function (input, array, config) {\n config._useUTC = true;\n config._tzm = offsetFromString(matchShortOffset, input);\n});\n\n// HELPERS\n\n// timezone chunker\n// '+10:00' > ['10', '00']\n// '-1530' > ['-15', '30']\nvar chunkOffset = /([\\+\\-]|\\d\\d)/gi;\n\nfunction offsetFromString(matcher, string) {\n var matches = (string || '').match(matcher),\n chunk,\n parts,\n minutes;\n\n if (matches === null) {\n return null;\n }\n\n chunk = matches[matches.length - 1] || [];\n parts = (chunk + '').match(chunkOffset) || ['-', 0, 0];\n minutes = +(parts[1] * 60) + toInt(parts[2]);\n\n return minutes === 0 ? 0 : parts[0] === '+' ? minutes : -minutes;\n}\n\n// Return a moment from input, that is local/utc/zone equivalent to model.\nfunction cloneWithOffset(input, model) {\n var res, diff;\n if (model._isUTC) {\n res = model.clone();\n diff =\n (isMoment(input) || isDate(input)\n ? input.valueOf()\n : createLocal(input).valueOf()) - res.valueOf();\n // Use low-level api, because this fn is low-level api.\n res._d.setTime(res._d.valueOf() + diff);\n hooks.updateOffset(res, false);\n return res;\n } else {\n return createLocal(input).local();\n }\n}\n\nfunction getDateOffset(m) {\n // On Firefox.24 Date#getTimezoneOffset returns a floating point.\n // https://github.com/moment/moment/pull/1871\n return -Math.round(m._d.getTimezoneOffset());\n}\n\n// HOOKS\n\n// This function will be called whenever a moment is mutated.\n// It is intended to keep the offset in sync with the timezone.\nhooks.updateOffset = function () {};\n\n// MOMENTS\n\n// keepLocalTime = true means only change the timezone, without\n// affecting the local hour. So 5:31:26 +0300 --[utcOffset(2, true)]-->\n// 5:31:26 +0200 It is possible that 5:31:26 doesn't exist with offset\n// +0200, so we adjust the time as needed, to be valid.\n//\n// Keeping the time actually adds/subtracts (one hour)\n// from the actual represented time. That is why we call updateOffset\n// a second time. In case it wants us to change the offset again\n// _changeInProgress == true case, then we have to adjust, because\n// there is no such time in the given timezone.\nfunction getSetOffset(input, keepLocalTime, keepMinutes) {\n var offset = this._offset || 0,\n localAdjust;\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n if (input != null) {\n if (typeof input === 'string') {\n input = offsetFromString(matchShortOffset, input);\n if (input === null) {\n return this;\n }\n } else if (Math.abs(input) < 16 && !keepMinutes) {\n input = input * 60;\n }\n if (!this._isUTC && keepLocalTime) {\n localAdjust = getDateOffset(this);\n }\n this._offset = input;\n this._isUTC = true;\n if (localAdjust != null) {\n this.add(localAdjust, 'm');\n }\n if (offset !== input) {\n if (!keepLocalTime || this._changeInProgress) {\n addSubtract(\n this,\n createDuration(input - offset, 'm'),\n 1,\n false\n );\n } else if (!this._changeInProgress) {\n this._changeInProgress = true;\n hooks.updateOffset(this, true);\n this._changeInProgress = null;\n }\n }\n return this;\n } else {\n return this._isUTC ? offset : getDateOffset(this);\n }\n}\n\nfunction getSetZone(input, keepLocalTime) {\n if (input != null) {\n if (typeof input !== 'string') {\n input = -input;\n }\n\n this.utcOffset(input, keepLocalTime);\n\n return this;\n } else {\n return -this.utcOffset();\n }\n}\n\nfunction setOffsetToUTC(keepLocalTime) {\n return this.utcOffset(0, keepLocalTime);\n}\n\nfunction setOffsetToLocal(keepLocalTime) {\n if (this._isUTC) {\n this.utcOffset(0, keepLocalTime);\n this._isUTC = false;\n\n if (keepLocalTime) {\n this.subtract(getDateOffset(this), 'm');\n }\n }\n return this;\n}\n\nfunction setOffsetToParsedOffset() {\n if (this._tzm != null) {\n this.utcOffset(this._tzm, false, true);\n } else if (typeof this._i === 'string') {\n var tZone = offsetFromString(matchOffset, this._i);\n if (tZone != null) {\n this.utcOffset(tZone);\n } else {\n this.utcOffset(0, true);\n }\n }\n return this;\n}\n\nfunction hasAlignedHourOffset(input) {\n if (!this.isValid()) {\n return false;\n }\n input = input ? createLocal(input).utcOffset() : 0;\n\n return (this.utcOffset() - input) % 60 === 0;\n}\n\nfunction isDaylightSavingTime() {\n return (\n this.utcOffset() > this.clone().month(0).utcOffset() ||\n this.utcOffset() > this.clone().month(5).utcOffset()\n );\n}\n\nfunction isDaylightSavingTimeShifted() {\n if (!isUndefined(this._isDSTShifted)) {\n return this._isDSTShifted;\n }\n\n var c = {},\n other;\n\n copyConfig(c, this);\n c = prepareConfig(c);\n\n if (c._a) {\n other = c._isUTC ? createUTC(c._a) : createLocal(c._a);\n this._isDSTShifted =\n this.isValid() && compareArrays(c._a, other.toArray()) > 0;\n } else {\n this._isDSTShifted = false;\n }\n\n return this._isDSTShifted;\n}\n\nfunction isLocal() {\n return this.isValid() ? !this._isUTC : false;\n}\n\nfunction isUtcOffset() {\n return this.isValid() ? this._isUTC : false;\n}\n\nfunction isUtc() {\n return this.isValid() ? this._isUTC && this._offset === 0 : false;\n}\n\n// ASP.NET json date format regex\nvar aspNetRegex = /^(-|\\+)?(?:(\\d*)[. ])?(\\d+):(\\d+)(?::(\\d+)(\\.\\d*)?)?$/,\n // from http://docs.closure-library.googlecode.com/git/closure_goog_date_date.js.source.html\n // somewhat more in line with 4.4.3.2 2004 spec, but allows decimal anywhere\n // and further modified to allow for strings containing both week and day\n isoRegex =\n /^(-|\\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;\n\nfunction createDuration(input, key) {\n var duration = input,\n // matching against regexp is expensive, do it on demand\n match = null,\n sign,\n ret,\n diffRes;\n\n if (isDuration(input)) {\n duration = {\n ms: input._milliseconds,\n d: input._days,\n M: input._months,\n };\n } else if (isNumber(input) || !isNaN(+input)) {\n duration = {};\n if (key) {\n duration[key] = +input;\n } else {\n duration.milliseconds = +input;\n }\n } else if ((match = aspNetRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: 0,\n d: toInt(match[DATE]) * sign,\n h: toInt(match[HOUR]) * sign,\n m: toInt(match[MINUTE]) * sign,\n s: toInt(match[SECOND]) * sign,\n ms: toInt(absRound(match[MILLISECOND] * 1000)) * sign, // the millisecond decimal point is included in the match\n };\n } else if ((match = isoRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: parseIso(match[2], sign),\n M: parseIso(match[3], sign),\n w: parseIso(match[4], sign),\n d: parseIso(match[5], sign),\n h: parseIso(match[6], sign),\n m: parseIso(match[7], sign),\n s: parseIso(match[8], sign),\n };\n } else if (duration == null) {\n // checks for null or undefined\n duration = {};\n } else if (\n typeof duration === 'object' &&\n ('from' in duration || 'to' in duration)\n ) {\n diffRes = momentsDifference(\n createLocal(duration.from),\n createLocal(duration.to)\n );\n\n duration = {};\n duration.ms = diffRes.milliseconds;\n duration.M = diffRes.months;\n }\n\n ret = new Duration(duration);\n\n if (isDuration(input) && hasOwnProp(input, '_locale')) {\n ret._locale = input._locale;\n }\n\n if (isDuration(input) && hasOwnProp(input, '_isValid')) {\n ret._isValid = input._isValid;\n }\n\n return ret;\n}\n\ncreateDuration.fn = Duration.prototype;\ncreateDuration.invalid = createInvalid$1;\n\nfunction parseIso(inp, sign) {\n // We'd normally use ~~inp for this, but unfortunately it also\n // converts floats to ints.\n // inp may be undefined, so careful calling replace on it.\n var res = inp && parseFloat(inp.replace(',', '.'));\n // apply sign while we're at it\n return (isNaN(res) ? 0 : res) * sign;\n}\n\nfunction positiveMomentsDifference(base, other) {\n var res = {};\n\n res.months =\n other.month() - base.month() + (other.year() - base.year()) * 12;\n if (base.clone().add(res.months, 'M').isAfter(other)) {\n --res.months;\n }\n\n res.milliseconds = +other - +base.clone().add(res.months, 'M');\n\n return res;\n}\n\nfunction momentsDifference(base, other) {\n var res;\n if (!(base.isValid() && other.isValid())) {\n return { milliseconds: 0, months: 0 };\n }\n\n other = cloneWithOffset(other, base);\n if (base.isBefore(other)) {\n res = positiveMomentsDifference(base, other);\n } else {\n res = positiveMomentsDifference(other, base);\n res.milliseconds = -res.milliseconds;\n res.months = -res.months;\n }\n\n return res;\n}\n\n// TODO: remove 'name' arg after deprecation is removed\nfunction createAdder(direction, name) {\n return function (val, period) {\n var dur, tmp;\n //invert the arguments, but complain about it\n if (period !== null && !isNaN(+period)) {\n deprecateSimple(\n name,\n 'moment().' +\n name +\n '(period, number) is deprecated. Please use moment().' +\n name +\n '(number, period). ' +\n 'See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info.'\n );\n tmp = val;\n val = period;\n period = tmp;\n }\n\n dur = createDuration(val, period);\n addSubtract(this, dur, direction);\n return this;\n };\n}\n\nfunction addSubtract(mom, duration, isAdding, updateOffset) {\n var milliseconds = duration._milliseconds,\n days = absRound(duration._days),\n months = absRound(duration._months);\n\n if (!mom.isValid()) {\n // No op\n return;\n }\n\n updateOffset = updateOffset == null ? true : updateOffset;\n\n if (months) {\n setMonth(mom, get(mom, 'Month') + months * isAdding);\n }\n if (days) {\n set$1(mom, 'Date', get(mom, 'Date') + days * isAdding);\n }\n if (milliseconds) {\n mom._d.setTime(mom._d.valueOf() + milliseconds * isAdding);\n }\n if (updateOffset) {\n hooks.updateOffset(mom, days || months);\n }\n}\n\nvar add = createAdder(1, 'add'),\n subtract = createAdder(-1, 'subtract');\n\nfunction isString(input) {\n return typeof input === 'string' || input instanceof String;\n}\n\n// type MomentInput = Moment | Date | string | number | (number | string)[] | MomentInputObject | void; // null | undefined\nfunction isMomentInput(input) {\n return (\n isMoment(input) ||\n isDate(input) ||\n isString(input) ||\n isNumber(input) ||\n isNumberOrStringArray(input) ||\n isMomentInputObject(input) ||\n input === null ||\n input === undefined\n );\n}\n\nfunction isMomentInputObject(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'years',\n 'year',\n 'y',\n 'months',\n 'month',\n 'M',\n 'days',\n 'day',\n 'd',\n 'dates',\n 'date',\n 'D',\n 'hours',\n 'hour',\n 'h',\n 'minutes',\n 'minute',\n 'm',\n 'seconds',\n 'second',\n 's',\n 'milliseconds',\n 'millisecond',\n 'ms',\n ],\n i,\n property,\n propertyLen = properties.length;\n\n for (i = 0; i < propertyLen; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n}\n\nfunction isNumberOrStringArray(input) {\n var arrayTest = isArray(input),\n dataTypeTest = false;\n if (arrayTest) {\n dataTypeTest =\n input.filter(function (item) {\n return !isNumber(item) && isString(input);\n }).length === 0;\n }\n return arrayTest && dataTypeTest;\n}\n\nfunction isCalendarSpec(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'sameDay',\n 'nextDay',\n 'lastDay',\n 'nextWeek',\n 'lastWeek',\n 'sameElse',\n ],\n i,\n property;\n\n for (i = 0; i < properties.length; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n}\n\nfunction getCalendarFormat(myMoment, now) {\n var diff = myMoment.diff(now, 'days', true);\n return diff < -6\n ? 'sameElse'\n : diff < -1\n ? 'lastWeek'\n : diff < 0\n ? 'lastDay'\n : diff < 1\n ? 'sameDay'\n : diff < 2\n ? 'nextDay'\n : diff < 7\n ? 'nextWeek'\n : 'sameElse';\n}\n\nfunction calendar$1(time, formats) {\n // Support for single parameter, formats only overload to the calendar function\n if (arguments.length === 1) {\n if (!arguments[0]) {\n time = undefined;\n formats = undefined;\n } else if (isMomentInput(arguments[0])) {\n time = arguments[0];\n formats = undefined;\n } else if (isCalendarSpec(arguments[0])) {\n formats = arguments[0];\n time = undefined;\n }\n }\n // We want to compare the start of today, vs this.\n // Getting start-of-today depends on whether we're local/utc/offset or not.\n var now = time || createLocal(),\n sod = cloneWithOffset(now, this).startOf('day'),\n format = hooks.calendarFormat(this, sod) || 'sameElse',\n output =\n formats &&\n (isFunction(formats[format])\n ? formats[format].call(this, now)\n : formats[format]);\n\n return this.format(\n output || this.localeData().calendar(format, this, createLocal(now))\n );\n}\n\nfunction clone() {\n return new Moment(this);\n}\n\nfunction isAfter(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() > localInput.valueOf();\n } else {\n return localInput.valueOf() < this.clone().startOf(units).valueOf();\n }\n}\n\nfunction isBefore(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() < localInput.valueOf();\n } else {\n return this.clone().endOf(units).valueOf() < localInput.valueOf();\n }\n}\n\nfunction isBetween(from, to, units, inclusivity) {\n var localFrom = isMoment(from) ? from : createLocal(from),\n localTo = isMoment(to) ? to : createLocal(to);\n if (!(this.isValid() && localFrom.isValid() && localTo.isValid())) {\n return false;\n }\n inclusivity = inclusivity || '()';\n return (\n (inclusivity[0] === '('\n ? this.isAfter(localFrom, units)\n : !this.isBefore(localFrom, units)) &&\n (inclusivity[1] === ')'\n ? this.isBefore(localTo, units)\n : !this.isAfter(localTo, units))\n );\n}\n\nfunction isSame(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input),\n inputMs;\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() === localInput.valueOf();\n } else {\n inputMs = localInput.valueOf();\n return (\n this.clone().startOf(units).valueOf() <= inputMs &&\n inputMs <= this.clone().endOf(units).valueOf()\n );\n }\n}\n\nfunction isSameOrAfter(input, units) {\n return this.isSame(input, units) || this.isAfter(input, units);\n}\n\nfunction isSameOrBefore(input, units) {\n return this.isSame(input, units) || this.isBefore(input, units);\n}\n\nfunction diff(input, units, asFloat) {\n var that, zoneDelta, output;\n\n if (!this.isValid()) {\n return NaN;\n }\n\n that = cloneWithOffset(input, this);\n\n if (!that.isValid()) {\n return NaN;\n }\n\n zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4;\n\n units = normalizeUnits(units);\n\n switch (units) {\n case 'year':\n output = monthDiff(this, that) / 12;\n break;\n case 'month':\n output = monthDiff(this, that);\n break;\n case 'quarter':\n output = monthDiff(this, that) / 3;\n break;\n case 'second':\n output = (this - that) / 1e3;\n break; // 1000\n case 'minute':\n output = (this - that) / 6e4;\n break; // 1000 * 60\n case 'hour':\n output = (this - that) / 36e5;\n break; // 1000 * 60 * 60\n case 'day':\n output = (this - that - zoneDelta) / 864e5;\n break; // 1000 * 60 * 60 * 24, negate dst\n case 'week':\n output = (this - that - zoneDelta) / 6048e5;\n break; // 1000 * 60 * 60 * 24 * 7, negate dst\n default:\n output = this - that;\n }\n\n return asFloat ? output : absFloor(output);\n}\n\nfunction monthDiff(a, b) {\n if (a.date() < b.date()) {\n // end-of-month calculations work correct when the start month has more\n // days than the end month.\n return -monthDiff(b, a);\n }\n // difference in months\n var wholeMonthDiff = (b.year() - a.year()) * 12 + (b.month() - a.month()),\n // b is in (anchor - 1 month, anchor + 1 month)\n anchor = a.clone().add(wholeMonthDiff, 'months'),\n anchor2,\n adjust;\n\n if (b - anchor < 0) {\n anchor2 = a.clone().add(wholeMonthDiff - 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor - anchor2);\n } else {\n anchor2 = a.clone().add(wholeMonthDiff + 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor2 - anchor);\n }\n\n //check for negative zero, return zero if negative zero\n return -(wholeMonthDiff + adjust) || 0;\n}\n\nhooks.defaultFormat = 'YYYY-MM-DDTHH:mm:ssZ';\nhooks.defaultFormatUtc = 'YYYY-MM-DDTHH:mm:ss[Z]';\n\nfunction toString() {\n return this.clone().locale('en').format('ddd MMM DD YYYY HH:mm:ss [GMT]ZZ');\n}\n\nfunction toISOString(keepOffset) {\n if (!this.isValid()) {\n return null;\n }\n var utc = keepOffset !== true,\n m = utc ? this.clone().utc() : this;\n if (m.year() < 0 || m.year() > 9999) {\n return formatMoment(\n m,\n utc\n ? 'YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]'\n : 'YYYYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n if (isFunction(Date.prototype.toISOString)) {\n // native implementation is ~50x faster, use it when we can\n if (utc) {\n return this.toDate().toISOString();\n } else {\n return new Date(this.valueOf() + this.utcOffset() * 60 * 1000)\n .toISOString()\n .replace('Z', formatMoment(m, 'Z'));\n }\n }\n return formatMoment(\n m,\n utc ? 'YYYY-MM-DD[T]HH:mm:ss.SSS[Z]' : 'YYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n}\n\n/**\n * Return a human readable representation of a moment that can\n * also be evaluated to get a new moment which is the same\n *\n * @link https://nodejs.org/dist/latest/docs/api/util.html#util_custom_inspect_function_on_objects\n */\nfunction inspect() {\n if (!this.isValid()) {\n return 'moment.invalid(/* ' + this._i + ' */)';\n }\n var func = 'moment',\n zone = '',\n prefix,\n year,\n datetime,\n suffix;\n if (!this.isLocal()) {\n func = this.utcOffset() === 0 ? 'moment.utc' : 'moment.parseZone';\n zone = 'Z';\n }\n prefix = '[' + func + '(\"]';\n year = 0 <= this.year() && this.year() <= 9999 ? 'YYYY' : 'YYYYYY';\n datetime = '-MM-DD[T]HH:mm:ss.SSS';\n suffix = zone + '[\")]';\n\n return this.format(prefix + year + datetime + suffix);\n}\n\nfunction format(inputString) {\n if (!inputString) {\n inputString = this.isUtc()\n ? hooks.defaultFormatUtc\n : hooks.defaultFormat;\n }\n var output = formatMoment(this, inputString);\n return this.localeData().postformat(output);\n}\n\nfunction from(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ to: this, from: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n}\n\nfunction fromNow(withoutSuffix) {\n return this.from(createLocal(), withoutSuffix);\n}\n\nfunction to(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ from: this, to: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n}\n\nfunction toNow(withoutSuffix) {\n return this.to(createLocal(), withoutSuffix);\n}\n\n// If passed a locale key, it will set the locale for this\n// instance. Otherwise, it will return the locale configuration\n// variables for this instance.\nfunction locale(key) {\n var newLocaleData;\n\n if (key === undefined) {\n return this._locale._abbr;\n } else {\n newLocaleData = getLocale(key);\n if (newLocaleData != null) {\n this._locale = newLocaleData;\n }\n return this;\n }\n}\n\nvar lang = deprecate(\n 'moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.',\n function (key) {\n if (key === undefined) {\n return this.localeData();\n } else {\n return this.locale(key);\n }\n }\n);\n\nfunction localeData() {\n return this._locale;\n}\n\nvar MS_PER_SECOND = 1000,\n MS_PER_MINUTE = 60 * MS_PER_SECOND,\n MS_PER_HOUR = 60 * MS_PER_MINUTE,\n MS_PER_400_YEARS = (365 * 400 + 97) * 24 * MS_PER_HOUR;\n\n// actual modulo - handles negative numbers (for dates before 1970):\nfunction mod$1(dividend, divisor) {\n return ((dividend % divisor) + divisor) % divisor;\n}\n\nfunction localStartOfDate(y, m, d) {\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return new Date(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return new Date(y, m, d).valueOf();\n }\n}\n\nfunction utcStartOfDate(y, m, d) {\n // Date.UTC remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return Date.UTC(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return Date.UTC(y, m, d);\n }\n}\n\nfunction startOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year(), 0, 1);\n break;\n case 'quarter':\n time = startOfDate(\n this.year(),\n this.month() - (this.month() % 3),\n 1\n );\n break;\n case 'month':\n time = startOfDate(this.year(), this.month(), 1);\n break;\n case 'week':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday()\n );\n break;\n case 'isoWeek':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1)\n );\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date());\n break;\n case 'hour':\n time = this._d.valueOf();\n time -= mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n );\n break;\n case 'minute':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_MINUTE);\n break;\n case 'second':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_SECOND);\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n}\n\nfunction endOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year() + 1, 0, 1) - 1;\n break;\n case 'quarter':\n time =\n startOfDate(\n this.year(),\n this.month() - (this.month() % 3) + 3,\n 1\n ) - 1;\n break;\n case 'month':\n time = startOfDate(this.year(), this.month() + 1, 1) - 1;\n break;\n case 'week':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday() + 7\n ) - 1;\n break;\n case 'isoWeek':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1) + 7\n ) - 1;\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date() + 1) - 1;\n break;\n case 'hour':\n time = this._d.valueOf();\n time +=\n MS_PER_HOUR -\n mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n ) -\n 1;\n break;\n case 'minute':\n time = this._d.valueOf();\n time += MS_PER_MINUTE - mod$1(time, MS_PER_MINUTE) - 1;\n break;\n case 'second':\n time = this._d.valueOf();\n time += MS_PER_SECOND - mod$1(time, MS_PER_SECOND) - 1;\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n}\n\nfunction valueOf() {\n return this._d.valueOf() - (this._offset || 0) * 60000;\n}\n\nfunction unix() {\n return Math.floor(this.valueOf() / 1000);\n}\n\nfunction toDate() {\n return new Date(this.valueOf());\n}\n\nfunction toArray() {\n var m = this;\n return [\n m.year(),\n m.month(),\n m.date(),\n m.hour(),\n m.minute(),\n m.second(),\n m.millisecond(),\n ];\n}\n\nfunction toObject() {\n var m = this;\n return {\n years: m.year(),\n months: m.month(),\n date: m.date(),\n hours: m.hours(),\n minutes: m.minutes(),\n seconds: m.seconds(),\n milliseconds: m.milliseconds(),\n };\n}\n\nfunction toJSON() {\n // new Date(NaN).toJSON() === null\n return this.isValid() ? this.toISOString() : null;\n}\n\nfunction isValid$2() {\n return isValid(this);\n}\n\nfunction parsingFlags() {\n return extend({}, getParsingFlags(this));\n}\n\nfunction invalidAt() {\n return getParsingFlags(this).overflow;\n}\n\nfunction creationData() {\n return {\n input: this._i,\n format: this._f,\n locale: this._locale,\n isUTC: this._isUTC,\n strict: this._strict,\n };\n}\n\naddFormatToken('N', 0, 0, 'eraAbbr');\naddFormatToken('NN', 0, 0, 'eraAbbr');\naddFormatToken('NNN', 0, 0, 'eraAbbr');\naddFormatToken('NNNN', 0, 0, 'eraName');\naddFormatToken('NNNNN', 0, 0, 'eraNarrow');\n\naddFormatToken('y', ['y', 1], 'yo', 'eraYear');\naddFormatToken('y', ['yy', 2], 0, 'eraYear');\naddFormatToken('y', ['yyy', 3], 0, 'eraYear');\naddFormatToken('y', ['yyyy', 4], 0, 'eraYear');\n\naddRegexToken('N', matchEraAbbr);\naddRegexToken('NN', matchEraAbbr);\naddRegexToken('NNN', matchEraAbbr);\naddRegexToken('NNNN', matchEraName);\naddRegexToken('NNNNN', matchEraNarrow);\n\naddParseToken(\n ['N', 'NN', 'NNN', 'NNNN', 'NNNNN'],\n function (input, array, config, token) {\n var era = config._locale.erasParse(input, token, config._strict);\n if (era) {\n getParsingFlags(config).era = era;\n } else {\n getParsingFlags(config).invalidEra = input;\n }\n }\n);\n\naddRegexToken('y', matchUnsigned);\naddRegexToken('yy', matchUnsigned);\naddRegexToken('yyy', matchUnsigned);\naddRegexToken('yyyy', matchUnsigned);\naddRegexToken('yo', matchEraYearOrdinal);\n\naddParseToken(['y', 'yy', 'yyy', 'yyyy'], YEAR);\naddParseToken(['yo'], function (input, array, config, token) {\n var match;\n if (config._locale._eraYearOrdinalRegex) {\n match = input.match(config._locale._eraYearOrdinalRegex);\n }\n\n if (config._locale.eraYearOrdinalParse) {\n array[YEAR] = config._locale.eraYearOrdinalParse(input, match);\n } else {\n array[YEAR] = parseInt(input, 10);\n }\n});\n\nfunction localeEras(m, format) {\n var i,\n l,\n date,\n eras = this._eras || getLocale('en')._eras;\n for (i = 0, l = eras.length; i < l; ++i) {\n switch (typeof eras[i].since) {\n case 'string':\n // truncate time\n date = hooks(eras[i].since).startOf('day');\n eras[i].since = date.valueOf();\n break;\n }\n\n switch (typeof eras[i].until) {\n case 'undefined':\n eras[i].until = +Infinity;\n break;\n case 'string':\n // truncate time\n date = hooks(eras[i].until).startOf('day').valueOf();\n eras[i].until = date.valueOf();\n break;\n }\n }\n return eras;\n}\n\nfunction localeErasParse(eraName, format, strict) {\n var i,\n l,\n eras = this.eras(),\n name,\n abbr,\n narrow;\n eraName = eraName.toUpperCase();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n name = eras[i].name.toUpperCase();\n abbr = eras[i].abbr.toUpperCase();\n narrow = eras[i].narrow.toUpperCase();\n\n if (strict) {\n switch (format) {\n case 'N':\n case 'NN':\n case 'NNN':\n if (abbr === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNN':\n if (name === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNNN':\n if (narrow === eraName) {\n return eras[i];\n }\n break;\n }\n } else if ([name, abbr, narrow].indexOf(eraName) >= 0) {\n return eras[i];\n }\n }\n}\n\nfunction localeErasConvertYear(era, year) {\n var dir = era.since <= era.until ? +1 : -1;\n if (year === undefined) {\n return hooks(era.since).year();\n } else {\n return hooks(era.since).year() + (year - era.offset) * dir;\n }\n}\n\nfunction getEraName() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].name;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].name;\n }\n }\n\n return '';\n}\n\nfunction getEraNarrow() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].narrow;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].narrow;\n }\n }\n\n return '';\n}\n\nfunction getEraAbbr() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].abbr;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].abbr;\n }\n }\n\n return '';\n}\n\nfunction getEraYear() {\n var i,\n l,\n dir,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n dir = eras[i].since <= eras[i].until ? +1 : -1;\n\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (\n (eras[i].since <= val && val <= eras[i].until) ||\n (eras[i].until <= val && val <= eras[i].since)\n ) {\n return (\n (this.year() - hooks(eras[i].since).year()) * dir +\n eras[i].offset\n );\n }\n }\n\n return this.year();\n}\n\nfunction erasNameRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNameRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNameRegex : this._erasRegex;\n}\n\nfunction erasAbbrRegex(isStrict) {\n if (!hasOwnProp(this, '_erasAbbrRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasAbbrRegex : this._erasRegex;\n}\n\nfunction erasNarrowRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNarrowRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNarrowRegex : this._erasRegex;\n}\n\nfunction matchEraAbbr(isStrict, locale) {\n return locale.erasAbbrRegex(isStrict);\n}\n\nfunction matchEraName(isStrict, locale) {\n return locale.erasNameRegex(isStrict);\n}\n\nfunction matchEraNarrow(isStrict, locale) {\n return locale.erasNarrowRegex(isStrict);\n}\n\nfunction matchEraYearOrdinal(isStrict, locale) {\n return locale._eraYearOrdinalRegex || matchUnsigned;\n}\n\nfunction computeErasParse() {\n var abbrPieces = [],\n namePieces = [],\n narrowPieces = [],\n mixedPieces = [],\n i,\n l,\n erasName,\n erasAbbr,\n erasNarrow,\n eras = this.eras();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n erasName = regexEscape(eras[i].name);\n erasAbbr = regexEscape(eras[i].abbr);\n erasNarrow = regexEscape(eras[i].narrow);\n\n namePieces.push(erasName);\n abbrPieces.push(erasAbbr);\n narrowPieces.push(erasNarrow);\n mixedPieces.push(erasName);\n mixedPieces.push(erasAbbr);\n mixedPieces.push(erasNarrow);\n }\n\n this._erasRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._erasNameRegex = new RegExp('^(' + namePieces.join('|') + ')', 'i');\n this._erasAbbrRegex = new RegExp('^(' + abbrPieces.join('|') + ')', 'i');\n this._erasNarrowRegex = new RegExp(\n '^(' + narrowPieces.join('|') + ')',\n 'i'\n );\n}\n\n// FORMATTING\n\naddFormatToken(0, ['gg', 2], 0, function () {\n return this.weekYear() % 100;\n});\n\naddFormatToken(0, ['GG', 2], 0, function () {\n return this.isoWeekYear() % 100;\n});\n\nfunction addWeekYearFormatToken(token, getter) {\n addFormatToken(0, [token, token.length], 0, getter);\n}\n\naddWeekYearFormatToken('gggg', 'weekYear');\naddWeekYearFormatToken('ggggg', 'weekYear');\naddWeekYearFormatToken('GGGG', 'isoWeekYear');\naddWeekYearFormatToken('GGGGG', 'isoWeekYear');\n\n// ALIASES\n\n// PARSING\n\naddRegexToken('G', matchSigned);\naddRegexToken('g', matchSigned);\naddRegexToken('GG', match1to2, match2);\naddRegexToken('gg', match1to2, match2);\naddRegexToken('GGGG', match1to4, match4);\naddRegexToken('gggg', match1to4, match4);\naddRegexToken('GGGGG', match1to6, match6);\naddRegexToken('ggggg', match1to6, match6);\n\naddWeekParseToken(\n ['gggg', 'ggggg', 'GGGG', 'GGGGG'],\n function (input, week, config, token) {\n week[token.substr(0, 2)] = toInt(input);\n }\n);\n\naddWeekParseToken(['gg', 'GG'], function (input, week, config, token) {\n week[token] = hooks.parseTwoDigitYear(input);\n});\n\n// MOMENTS\n\nfunction getSetWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.week(),\n this.weekday() + this.localeData()._week.dow,\n this.localeData()._week.dow,\n this.localeData()._week.doy\n );\n}\n\nfunction getSetISOWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.isoWeek(),\n this.isoWeekday(),\n 1,\n 4\n );\n}\n\nfunction getISOWeeksInYear() {\n return weeksInYear(this.year(), 1, 4);\n}\n\nfunction getISOWeeksInISOWeekYear() {\n return weeksInYear(this.isoWeekYear(), 1, 4);\n}\n\nfunction getWeeksInYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy);\n}\n\nfunction getWeeksInWeekYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.weekYear(), weekInfo.dow, weekInfo.doy);\n}\n\nfunction getSetWeekYearHelper(input, week, weekday, dow, doy) {\n var weeksTarget;\n if (input == null) {\n return weekOfYear(this, dow, doy).year;\n } else {\n weeksTarget = weeksInYear(input, dow, doy);\n if (week > weeksTarget) {\n week = weeksTarget;\n }\n return setWeekAll.call(this, input, week, weekday, dow, doy);\n }\n}\n\nfunction setWeekAll(weekYear, week, weekday, dow, doy) {\n var dayOfYearData = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy),\n date = createUTCDate(dayOfYearData.year, 0, dayOfYearData.dayOfYear);\n\n this.year(date.getUTCFullYear());\n this.month(date.getUTCMonth());\n this.date(date.getUTCDate());\n return this;\n}\n\n// FORMATTING\n\naddFormatToken('Q', 0, 'Qo', 'quarter');\n\n// PARSING\n\naddRegexToken('Q', match1);\naddParseToken('Q', function (input, array) {\n array[MONTH] = (toInt(input) - 1) * 3;\n});\n\n// MOMENTS\n\nfunction getSetQuarter(input) {\n return input == null\n ? Math.ceil((this.month() + 1) / 3)\n : this.month((input - 1) * 3 + (this.month() % 3));\n}\n\n// FORMATTING\n\naddFormatToken('D', ['DD', 2], 'Do', 'date');\n\n// PARSING\n\naddRegexToken('D', match1to2, match1to2NoLeadingZero);\naddRegexToken('DD', match1to2, match2);\naddRegexToken('Do', function (isStrict, locale) {\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n return isStrict\n ? locale._dayOfMonthOrdinalParse || locale._ordinalParse\n : locale._dayOfMonthOrdinalParseLenient;\n});\n\naddParseToken(['D', 'DD'], DATE);\naddParseToken('Do', function (input, array) {\n array[DATE] = toInt(input.match(match1to2)[0]);\n});\n\n// MOMENTS\n\nvar getSetDayOfMonth = makeGetSet('Date', true);\n\n// FORMATTING\n\naddFormatToken('DDD', ['DDDD', 3], 'DDDo', 'dayOfYear');\n\n// PARSING\n\naddRegexToken('DDD', match1to3);\naddRegexToken('DDDD', match3);\naddParseToken(['DDD', 'DDDD'], function (input, array, config) {\n config._dayOfYear = toInt(input);\n});\n\n// HELPERS\n\n// MOMENTS\n\nfunction getSetDayOfYear(input) {\n var dayOfYear =\n Math.round(\n (this.clone().startOf('day') - this.clone().startOf('year')) / 864e5\n ) + 1;\n return input == null ? dayOfYear : this.add(input - dayOfYear, 'd');\n}\n\n// FORMATTING\n\naddFormatToken('m', ['mm', 2], 0, 'minute');\n\n// PARSING\n\naddRegexToken('m', match1to2, match1to2HasZero);\naddRegexToken('mm', match1to2, match2);\naddParseToken(['m', 'mm'], MINUTE);\n\n// MOMENTS\n\nvar getSetMinute = makeGetSet('Minutes', false);\n\n// FORMATTING\n\naddFormatToken('s', ['ss', 2], 0, 'second');\n\n// PARSING\n\naddRegexToken('s', match1to2, match1to2HasZero);\naddRegexToken('ss', match1to2, match2);\naddParseToken(['s', 'ss'], SECOND);\n\n// MOMENTS\n\nvar getSetSecond = makeGetSet('Seconds', false);\n\n// FORMATTING\n\naddFormatToken('S', 0, 0, function () {\n return ~~(this.millisecond() / 100);\n});\n\naddFormatToken(0, ['SS', 2], 0, function () {\n return ~~(this.millisecond() / 10);\n});\n\naddFormatToken(0, ['SSS', 3], 0, 'millisecond');\naddFormatToken(0, ['SSSS', 4], 0, function () {\n return this.millisecond() * 10;\n});\naddFormatToken(0, ['SSSSS', 5], 0, function () {\n return this.millisecond() * 100;\n});\naddFormatToken(0, ['SSSSSS', 6], 0, function () {\n return this.millisecond() * 1000;\n});\naddFormatToken(0, ['SSSSSSS', 7], 0, function () {\n return this.millisecond() * 10000;\n});\naddFormatToken(0, ['SSSSSSSS', 8], 0, function () {\n return this.millisecond() * 100000;\n});\naddFormatToken(0, ['SSSSSSSSS', 9], 0, function () {\n return this.millisecond() * 1000000;\n});\n\n// PARSING\n\naddRegexToken('S', match1to3, match1);\naddRegexToken('SS', match1to3, match2);\naddRegexToken('SSS', match1to3, match3);\n\nvar token, getSetMillisecond;\nfor (token = 'SSSS'; token.length <= 9; token += 'S') {\n addRegexToken(token, matchUnsigned);\n}\n\nfunction parseMs(input, array) {\n array[MILLISECOND] = toInt(('0.' + input) * 1000);\n}\n\nfor (token = 'S'; token.length <= 9; token += 'S') {\n addParseToken(token, parseMs);\n}\n\ngetSetMillisecond = makeGetSet('Milliseconds', false);\n\n// FORMATTING\n\naddFormatToken('z', 0, 0, 'zoneAbbr');\naddFormatToken('zz', 0, 0, 'zoneName');\n\n// MOMENTS\n\nfunction getZoneAbbr() {\n return this._isUTC ? 'UTC' : '';\n}\n\nfunction getZoneName() {\n return this._isUTC ? 'Coordinated Universal Time' : '';\n}\n\nvar proto = Moment.prototype;\n\nproto.add = add;\nproto.calendar = calendar$1;\nproto.clone = clone;\nproto.diff = diff;\nproto.endOf = endOf;\nproto.format = format;\nproto.from = from;\nproto.fromNow = fromNow;\nproto.to = to;\nproto.toNow = toNow;\nproto.get = stringGet;\nproto.invalidAt = invalidAt;\nproto.isAfter = isAfter;\nproto.isBefore = isBefore;\nproto.isBetween = isBetween;\nproto.isSame = isSame;\nproto.isSameOrAfter = isSameOrAfter;\nproto.isSameOrBefore = isSameOrBefore;\nproto.isValid = isValid$2;\nproto.lang = lang;\nproto.locale = locale;\nproto.localeData = localeData;\nproto.max = prototypeMax;\nproto.min = prototypeMin;\nproto.parsingFlags = parsingFlags;\nproto.set = stringSet;\nproto.startOf = startOf;\nproto.subtract = subtract;\nproto.toArray = toArray;\nproto.toObject = toObject;\nproto.toDate = toDate;\nproto.toISOString = toISOString;\nproto.inspect = inspect;\nif (typeof Symbol !== 'undefined' && Symbol.for != null) {\n proto[Symbol.for('nodejs.util.inspect.custom')] = function () {\n return 'Moment<' + this.format() + '>';\n };\n}\nproto.toJSON = toJSON;\nproto.toString = toString;\nproto.unix = unix;\nproto.valueOf = valueOf;\nproto.creationData = creationData;\nproto.eraName = getEraName;\nproto.eraNarrow = getEraNarrow;\nproto.eraAbbr = getEraAbbr;\nproto.eraYear = getEraYear;\nproto.year = getSetYear;\nproto.isLeapYear = getIsLeapYear;\nproto.weekYear = getSetWeekYear;\nproto.isoWeekYear = getSetISOWeekYear;\nproto.quarter = proto.quarters = getSetQuarter;\nproto.month = getSetMonth;\nproto.daysInMonth = getDaysInMonth;\nproto.week = proto.weeks = getSetWeek;\nproto.isoWeek = proto.isoWeeks = getSetISOWeek;\nproto.weeksInYear = getWeeksInYear;\nproto.weeksInWeekYear = getWeeksInWeekYear;\nproto.isoWeeksInYear = getISOWeeksInYear;\nproto.isoWeeksInISOWeekYear = getISOWeeksInISOWeekYear;\nproto.date = getSetDayOfMonth;\nproto.day = proto.days = getSetDayOfWeek;\nproto.weekday = getSetLocaleDayOfWeek;\nproto.isoWeekday = getSetISODayOfWeek;\nproto.dayOfYear = getSetDayOfYear;\nproto.hour = proto.hours = getSetHour;\nproto.minute = proto.minutes = getSetMinute;\nproto.second = proto.seconds = getSetSecond;\nproto.millisecond = proto.milliseconds = getSetMillisecond;\nproto.utcOffset = getSetOffset;\nproto.utc = setOffsetToUTC;\nproto.local = setOffsetToLocal;\nproto.parseZone = setOffsetToParsedOffset;\nproto.hasAlignedHourOffset = hasAlignedHourOffset;\nproto.isDST = isDaylightSavingTime;\nproto.isLocal = isLocal;\nproto.isUtcOffset = isUtcOffset;\nproto.isUtc = isUtc;\nproto.isUTC = isUtc;\nproto.zoneAbbr = getZoneAbbr;\nproto.zoneName = getZoneName;\nproto.dates = deprecate(\n 'dates accessor is deprecated. Use date instead.',\n getSetDayOfMonth\n);\nproto.months = deprecate(\n 'months accessor is deprecated. Use month instead',\n getSetMonth\n);\nproto.years = deprecate(\n 'years accessor is deprecated. Use year instead',\n getSetYear\n);\nproto.zone = deprecate(\n 'moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/',\n getSetZone\n);\nproto.isDSTShifted = deprecate(\n 'isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information',\n isDaylightSavingTimeShifted\n);\n\nfunction createUnix(input) {\n return createLocal(input * 1000);\n}\n\nfunction createInZone() {\n return createLocal.apply(null, arguments).parseZone();\n}\n\nfunction preParsePostFormat(string) {\n return string;\n}\n\nvar proto$1 = Locale.prototype;\n\nproto$1.calendar = calendar;\nproto$1.longDateFormat = longDateFormat;\nproto$1.invalidDate = invalidDate;\nproto$1.ordinal = ordinal;\nproto$1.preparse = preParsePostFormat;\nproto$1.postformat = preParsePostFormat;\nproto$1.relativeTime = relativeTime;\nproto$1.pastFuture = pastFuture;\nproto$1.set = set;\nproto$1.eras = localeEras;\nproto$1.erasParse = localeErasParse;\nproto$1.erasConvertYear = localeErasConvertYear;\nproto$1.erasAbbrRegex = erasAbbrRegex;\nproto$1.erasNameRegex = erasNameRegex;\nproto$1.erasNarrowRegex = erasNarrowRegex;\n\nproto$1.months = localeMonths;\nproto$1.monthsShort = localeMonthsShort;\nproto$1.monthsParse = localeMonthsParse;\nproto$1.monthsRegex = monthsRegex;\nproto$1.monthsShortRegex = monthsShortRegex;\nproto$1.week = localeWeek;\nproto$1.firstDayOfYear = localeFirstDayOfYear;\nproto$1.firstDayOfWeek = localeFirstDayOfWeek;\n\nproto$1.weekdays = localeWeekdays;\nproto$1.weekdaysMin = localeWeekdaysMin;\nproto$1.weekdaysShort = localeWeekdaysShort;\nproto$1.weekdaysParse = localeWeekdaysParse;\n\nproto$1.weekdaysRegex = weekdaysRegex;\nproto$1.weekdaysShortRegex = weekdaysShortRegex;\nproto$1.weekdaysMinRegex = weekdaysMinRegex;\n\nproto$1.isPM = localeIsPM;\nproto$1.meridiem = localeMeridiem;\n\nfunction get$1(format, index, field, setter) {\n var locale = getLocale(),\n utc = createUTC().set(setter, index);\n return locale[field](utc, format);\n}\n\nfunction listMonthsImpl(format, index, field) {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n\n if (index != null) {\n return get$1(format, index, field, 'month');\n }\n\n var i,\n out = [];\n for (i = 0; i < 12; i++) {\n out[i] = get$1(format, i, field, 'month');\n }\n return out;\n}\n\n// ()\n// (5)\n// (fmt, 5)\n// (fmt)\n// (true)\n// (true, 5)\n// (true, fmt, 5)\n// (true, fmt)\nfunction listWeekdaysImpl(localeSorted, format, index, field) {\n if (typeof localeSorted === 'boolean') {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n } else {\n format = localeSorted;\n index = format;\n localeSorted = false;\n\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n }\n\n var locale = getLocale(),\n shift = localeSorted ? locale._week.dow : 0,\n i,\n out = [];\n\n if (index != null) {\n return get$1(format, (index + shift) % 7, field, 'day');\n }\n\n for (i = 0; i < 7; i++) {\n out[i] = get$1(format, (i + shift) % 7, field, 'day');\n }\n return out;\n}\n\nfunction listMonths(format, index) {\n return listMonthsImpl(format, index, 'months');\n}\n\nfunction listMonthsShort(format, index) {\n return listMonthsImpl(format, index, 'monthsShort');\n}\n\nfunction listWeekdays(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdays');\n}\n\nfunction listWeekdaysShort(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysShort');\n}\n\nfunction listWeekdaysMin(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysMin');\n}\n\ngetSetGlobalLocale('en', {\n eras: [\n {\n since: '0001-01-01',\n until: +Infinity,\n offset: 1,\n name: 'Anno Domini',\n narrow: 'AD',\n abbr: 'AD',\n },\n {\n since: '0000-12-31',\n until: -Infinity,\n offset: 1,\n name: 'Before Christ',\n narrow: 'BC',\n abbr: 'BC',\n },\n ],\n dayOfMonthOrdinalParse: /\\d{1,2}(th|st|nd|rd)/,\n ordinal: function (number) {\n var b = number % 10,\n output =\n toInt((number % 100) / 10) === 1\n ? 'th'\n : b === 1\n ? 'st'\n : b === 2\n ? 'nd'\n : b === 3\n ? 'rd'\n : 'th';\n return number + output;\n },\n});\n\n// Side effect imports\n\nhooks.lang = deprecate(\n 'moment.lang is deprecated. Use moment.locale instead.',\n getSetGlobalLocale\n);\nhooks.langData = deprecate(\n 'moment.langData is deprecated. Use moment.localeData instead.',\n getLocale\n);\n\nvar mathAbs = Math.abs;\n\nfunction abs() {\n var data = this._data;\n\n this._milliseconds = mathAbs(this._milliseconds);\n this._days = mathAbs(this._days);\n this._months = mathAbs(this._months);\n\n data.milliseconds = mathAbs(data.milliseconds);\n data.seconds = mathAbs(data.seconds);\n data.minutes = mathAbs(data.minutes);\n data.hours = mathAbs(data.hours);\n data.months = mathAbs(data.months);\n data.years = mathAbs(data.years);\n\n return this;\n}\n\nfunction addSubtract$1(duration, input, value, direction) {\n var other = createDuration(input, value);\n\n duration._milliseconds += direction * other._milliseconds;\n duration._days += direction * other._days;\n duration._months += direction * other._months;\n\n return duration._bubble();\n}\n\n// supports only 2.0-style add(1, 's') or add(duration)\nfunction add$1(input, value) {\n return addSubtract$1(this, input, value, 1);\n}\n\n// supports only 2.0-style subtract(1, 's') or subtract(duration)\nfunction subtract$1(input, value) {\n return addSubtract$1(this, input, value, -1);\n}\n\nfunction absCeil(number) {\n if (number < 0) {\n return Math.floor(number);\n } else {\n return Math.ceil(number);\n }\n}\n\nfunction bubble() {\n var milliseconds = this._milliseconds,\n days = this._days,\n months = this._months,\n data = this._data,\n seconds,\n minutes,\n hours,\n years,\n monthsFromDays;\n\n // if we have a mix of positive and negative values, bubble down first\n // check: https://github.com/moment/moment/issues/2166\n if (\n !(\n (milliseconds >= 0 && days >= 0 && months >= 0) ||\n (milliseconds <= 0 && days <= 0 && months <= 0)\n )\n ) {\n milliseconds += absCeil(monthsToDays(months) + days) * 864e5;\n days = 0;\n months = 0;\n }\n\n // The following code bubbles up values, see the tests for\n // examples of what that means.\n data.milliseconds = milliseconds % 1000;\n\n seconds = absFloor(milliseconds / 1000);\n data.seconds = seconds % 60;\n\n minutes = absFloor(seconds / 60);\n data.minutes = minutes % 60;\n\n hours = absFloor(minutes / 60);\n data.hours = hours % 24;\n\n days += absFloor(hours / 24);\n\n // convert days to months\n monthsFromDays = absFloor(daysToMonths(days));\n months += monthsFromDays;\n days -= absCeil(monthsToDays(monthsFromDays));\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n data.days = days;\n data.months = months;\n data.years = years;\n\n return this;\n}\n\nfunction daysToMonths(days) {\n // 400 years have 146097 days (taking into account leap year rules)\n // 400 years have 12 months === 4800\n return (days * 4800) / 146097;\n}\n\nfunction monthsToDays(months) {\n // the reverse of daysToMonths\n return (months * 146097) / 4800;\n}\n\nfunction as(units) {\n if (!this.isValid()) {\n return NaN;\n }\n var days,\n months,\n milliseconds = this._milliseconds;\n\n units = normalizeUnits(units);\n\n if (units === 'month' || units === 'quarter' || units === 'year') {\n days = this._days + milliseconds / 864e5;\n months = this._months + daysToMonths(days);\n switch (units) {\n case 'month':\n return months;\n case 'quarter':\n return months / 3;\n case 'year':\n return months / 12;\n }\n } else {\n // handle milliseconds separately because of floating point math errors (issue #1867)\n days = this._days + Math.round(monthsToDays(this._months));\n switch (units) {\n case 'week':\n return days / 7 + milliseconds / 6048e5;\n case 'day':\n return days + milliseconds / 864e5;\n case 'hour':\n return days * 24 + milliseconds / 36e5;\n case 'minute':\n return days * 1440 + milliseconds / 6e4;\n case 'second':\n return days * 86400 + milliseconds / 1000;\n // Math.floor prevents floating point math errors here\n case 'millisecond':\n return Math.floor(days * 864e5) + milliseconds;\n default:\n throw new Error('Unknown unit ' + units);\n }\n }\n}\n\nfunction makeAs(alias) {\n return function () {\n return this.as(alias);\n };\n}\n\nvar asMilliseconds = makeAs('ms'),\n asSeconds = makeAs('s'),\n asMinutes = makeAs('m'),\n asHours = makeAs('h'),\n asDays = makeAs('d'),\n asWeeks = makeAs('w'),\n asMonths = makeAs('M'),\n asQuarters = makeAs('Q'),\n asYears = makeAs('y'),\n valueOf$1 = asMilliseconds;\n\nfunction clone$1() {\n return createDuration(this);\n}\n\nfunction get$2(units) {\n units = normalizeUnits(units);\n return this.isValid() ? this[units + 's']() : NaN;\n}\n\nfunction makeGetter(name) {\n return function () {\n return this.isValid() ? this._data[name] : NaN;\n };\n}\n\nvar milliseconds = makeGetter('milliseconds'),\n seconds = makeGetter('seconds'),\n minutes = makeGetter('minutes'),\n hours = makeGetter('hours'),\n days = makeGetter('days'),\n months = makeGetter('months'),\n years = makeGetter('years');\n\nfunction weeks() {\n return absFloor(this.days() / 7);\n}\n\nvar round = Math.round,\n thresholds = {\n ss: 44, // a few seconds to seconds\n s: 45, // seconds to minute\n m: 45, // minutes to hour\n h: 22, // hours to day\n d: 26, // days to month/week\n w: null, // weeks to month\n M: 11, // months to year\n };\n\n// helper function for moment.fn.from, moment.fn.fromNow, and moment.duration.fn.humanize\nfunction substituteTimeAgo(string, number, withoutSuffix, isFuture, locale) {\n return locale.relativeTime(number || 1, !!withoutSuffix, string, isFuture);\n}\n\nfunction relativeTime$1(posNegDuration, withoutSuffix, thresholds, locale) {\n var duration = createDuration(posNegDuration).abs(),\n seconds = round(duration.as('s')),\n minutes = round(duration.as('m')),\n hours = round(duration.as('h')),\n days = round(duration.as('d')),\n months = round(duration.as('M')),\n weeks = round(duration.as('w')),\n years = round(duration.as('y')),\n a =\n (seconds <= thresholds.ss && ['s', seconds]) ||\n (seconds < thresholds.s && ['ss', seconds]) ||\n (minutes <= 1 && ['m']) ||\n (minutes < thresholds.m && ['mm', minutes]) ||\n (hours <= 1 && ['h']) ||\n (hours < thresholds.h && ['hh', hours]) ||\n (days <= 1 && ['d']) ||\n (days < thresholds.d && ['dd', days]);\n\n if (thresholds.w != null) {\n a =\n a ||\n (weeks <= 1 && ['w']) ||\n (weeks < thresholds.w && ['ww', weeks]);\n }\n a = a ||\n (months <= 1 && ['M']) ||\n (months < thresholds.M && ['MM', months]) ||\n (years <= 1 && ['y']) || ['yy', years];\n\n a[2] = withoutSuffix;\n a[3] = +posNegDuration > 0;\n a[4] = locale;\n return substituteTimeAgo.apply(null, a);\n}\n\n// This function allows you to set the rounding function for relative time strings\nfunction getSetRelativeTimeRounding(roundingFunction) {\n if (roundingFunction === undefined) {\n return round;\n }\n if (typeof roundingFunction === 'function') {\n round = roundingFunction;\n return true;\n }\n return false;\n}\n\n// This function allows you to set a threshold for relative time strings\nfunction getSetRelativeTimeThreshold(threshold, limit) {\n if (thresholds[threshold] === undefined) {\n return false;\n }\n if (limit === undefined) {\n return thresholds[threshold];\n }\n thresholds[threshold] = limit;\n if (threshold === 's') {\n thresholds.ss = limit - 1;\n }\n return true;\n}\n\nfunction humanize(argWithSuffix, argThresholds) {\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var withSuffix = false,\n th = thresholds,\n locale,\n output;\n\n if (typeof argWithSuffix === 'object') {\n argThresholds = argWithSuffix;\n argWithSuffix = false;\n }\n if (typeof argWithSuffix === 'boolean') {\n withSuffix = argWithSuffix;\n }\n if (typeof argThresholds === 'object') {\n th = Object.assign({}, thresholds, argThresholds);\n if (argThresholds.s != null && argThresholds.ss == null) {\n th.ss = argThresholds.s - 1;\n }\n }\n\n locale = this.localeData();\n output = relativeTime$1(this, !withSuffix, th, locale);\n\n if (withSuffix) {\n output = locale.pastFuture(+this, output);\n }\n\n return locale.postformat(output);\n}\n\nvar abs$1 = Math.abs;\n\nfunction sign(x) {\n return (x > 0) - (x < 0) || +x;\n}\n\nfunction toISOString$1() {\n // for ISO strings we do not use the normal bubbling rules:\n // * milliseconds bubble up until they become hours\n // * days do not bubble at all\n // * months bubble up until they become years\n // This is because there is no context-free conversion between hours and days\n // (think of clock changes)\n // and also not between days and months (28-31 days per month)\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var seconds = abs$1(this._milliseconds) / 1000,\n days = abs$1(this._days),\n months = abs$1(this._months),\n minutes,\n hours,\n years,\n s,\n total = this.asSeconds(),\n totalSign,\n ymSign,\n daysSign,\n hmsSign;\n\n if (!total) {\n // this is the same as C#'s (Noda) and python (isodate)...\n // but not other JS (goog.date)\n return 'P0D';\n }\n\n // 3600 seconds -> 60 minutes -> 1 hour\n minutes = absFloor(seconds / 60);\n hours = absFloor(minutes / 60);\n seconds %= 60;\n minutes %= 60;\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n // inspired by https://github.com/dordille/moment-isoduration/blob/master/moment.isoduration.js\n s = seconds ? seconds.toFixed(3).replace(/\\.?0+$/, '') : '';\n\n totalSign = total < 0 ? '-' : '';\n ymSign = sign(this._months) !== sign(total) ? '-' : '';\n daysSign = sign(this._days) !== sign(total) ? '-' : '';\n hmsSign = sign(this._milliseconds) !== sign(total) ? '-' : '';\n\n return (\n totalSign +\n 'P' +\n (years ? ymSign + years + 'Y' : '') +\n (months ? ymSign + months + 'M' : '') +\n (days ? daysSign + days + 'D' : '') +\n (hours || minutes || seconds ? 'T' : '') +\n (hours ? hmsSign + hours + 'H' : '') +\n (minutes ? hmsSign + minutes + 'M' : '') +\n (seconds ? hmsSign + s + 'S' : '')\n );\n}\n\nvar proto$2 = Duration.prototype;\n\nproto$2.isValid = isValid$1;\nproto$2.abs = abs;\nproto$2.add = add$1;\nproto$2.subtract = subtract$1;\nproto$2.as = as;\nproto$2.asMilliseconds = asMilliseconds;\nproto$2.asSeconds = asSeconds;\nproto$2.asMinutes = asMinutes;\nproto$2.asHours = asHours;\nproto$2.asDays = asDays;\nproto$2.asWeeks = asWeeks;\nproto$2.asMonths = asMonths;\nproto$2.asQuarters = asQuarters;\nproto$2.asYears = asYears;\nproto$2.valueOf = valueOf$1;\nproto$2._bubble = bubble;\nproto$2.clone = clone$1;\nproto$2.get = get$2;\nproto$2.milliseconds = milliseconds;\nproto$2.seconds = seconds;\nproto$2.minutes = minutes;\nproto$2.hours = hours;\nproto$2.days = days;\nproto$2.weeks = weeks;\nproto$2.months = months;\nproto$2.years = years;\nproto$2.humanize = humanize;\nproto$2.toISOString = toISOString$1;\nproto$2.toString = toISOString$1;\nproto$2.toJSON = toISOString$1;\nproto$2.locale = locale;\nproto$2.localeData = localeData;\n\nproto$2.toIsoString = deprecate(\n 'toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)',\n toISOString$1\n);\nproto$2.lang = lang;\n\n// FORMATTING\n\naddFormatToken('X', 0, 0, 'unix');\naddFormatToken('x', 0, 0, 'valueOf');\n\n// PARSING\n\naddRegexToken('x', matchSigned);\naddRegexToken('X', matchTimestamp);\naddParseToken('X', function (input, array, config) {\n config._d = new Date(parseFloat(input) * 1000);\n});\naddParseToken('x', function (input, array, config) {\n config._d = new Date(toInt(input));\n});\n\n//! moment.js\n\nhooks.version = '2.30.1';\n\nsetHookCallback(createLocal);\n\nhooks.fn = proto;\nhooks.min = min;\nhooks.max = max;\nhooks.now = now;\nhooks.utc = createUTC;\nhooks.unix = createUnix;\nhooks.months = listMonths;\nhooks.isDate = isDate;\nhooks.locale = getSetGlobalLocale;\nhooks.invalid = createInvalid;\nhooks.duration = createDuration;\nhooks.isMoment = isMoment;\nhooks.weekdays = listWeekdays;\nhooks.parseZone = createInZone;\nhooks.localeData = getLocale;\nhooks.isDuration = isDuration;\nhooks.monthsShort = listMonthsShort;\nhooks.weekdaysMin = listWeekdaysMin;\nhooks.defineLocale = defineLocale;\nhooks.updateLocale = updateLocale;\nhooks.locales = listLocales;\nhooks.weekdaysShort = listWeekdaysShort;\nhooks.normalizeUnits = normalizeUnits;\nhooks.relativeTimeRounding = getSetRelativeTimeRounding;\nhooks.relativeTimeThreshold = getSetRelativeTimeThreshold;\nhooks.calendarFormat = getCalendarFormat;\nhooks.prototype = proto;\n\n// currently HTML5 input type only supports 24-hour formats\nhooks.HTML5_FMT = {\n DATETIME_LOCAL: 'YYYY-MM-DDTHH:mm', // \n DATETIME_LOCAL_SECONDS: 'YYYY-MM-DDTHH:mm:ss', // \n DATETIME_LOCAL_MS: 'YYYY-MM-DDTHH:mm:ss.SSS', // \n DATE: 'YYYY-MM-DD', // \n TIME: 'HH:mm', // \n TIME_SECONDS: 'HH:mm:ss', // \n TIME_MS: 'HH:mm:ss.SSS', // \n WEEK: 'GGGG-[W]WW', // \n MONTH: 'YYYY-MM', // \n};\n\nexport default hooks;\n","/**\n * @license\n * Lodash \n * Copyright OpenJS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n;(function() {\n\n /** Used as a safe reference for `undefined` in pre-ES5 environments. */\n var undefined;\n\n /** Used as the semantic version number. */\n var VERSION = '4.17.21';\n\n /** Used as the size to enable large array optimizations. */\n var LARGE_ARRAY_SIZE = 200;\n\n /** Error message constants. */\n var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://npms.io/search?q=ponyfill.',\n FUNC_ERROR_TEXT = 'Expected a function',\n INVALID_TEMPL_VAR_ERROR_TEXT = 'Invalid `variable` option passed into `_.template`';\n\n /** Used to stand-in for `undefined` hash values. */\n var HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n /** Used as the maximum memoize cache size. */\n var MAX_MEMOIZE_SIZE = 500;\n\n /** Used as the internal argument placeholder. */\n var PLACEHOLDER = '__lodash_placeholder__';\n\n /** Used to compose bitmasks for cloning. */\n var CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n /** Used to compose bitmasks for value comparisons. */\n var COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n /** Used to compose bitmasks for function metadata. */\n var WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_BOUND_FLAG = 4,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64,\n WRAP_ARY_FLAG = 128,\n WRAP_REARG_FLAG = 256,\n WRAP_FLIP_FLAG = 512;\n\n /** Used as default options for `_.truncate`. */\n var DEFAULT_TRUNC_LENGTH = 30,\n DEFAULT_TRUNC_OMISSION = '...';\n\n /** Used to detect hot functions by number of calls within a span of milliseconds. */\n var HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n /** Used to indicate the type of lazy iteratees. */\n var LAZY_FILTER_FLAG = 1,\n LAZY_MAP_FLAG = 2,\n LAZY_WHILE_FLAG = 3;\n\n /** Used as references for various `Number` constants. */\n var INFINITY = 1 / 0,\n MAX_SAFE_INTEGER = 9007199254740991,\n MAX_INTEGER = 1.7976931348623157e+308,\n NAN = 0 / 0;\n\n /** Used as references for the maximum length and index of an array. */\n var MAX_ARRAY_LENGTH = 4294967295,\n MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1,\n HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;\n\n /** Used to associate wrap methods with their bit flags. */\n var wrapFlags = [\n ['ary', WRAP_ARY_FLAG],\n ['bind', WRAP_BIND_FLAG],\n ['bindKey', WRAP_BIND_KEY_FLAG],\n ['curry', WRAP_CURRY_FLAG],\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\n ['flip', WRAP_FLIP_FLAG],\n ['partial', WRAP_PARTIAL_FLAG],\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\n ['rearg', WRAP_REARG_FLAG]\n ];\n\n /** `Object#toString` result references. */\n var argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n domExcTag = '[object DOMException]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]',\n weakSetTag = '[object WeakSet]';\n\n var arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n /** Used to match empty string literals in compiled template source. */\n var reEmptyStringLeading = /\\b__p \\+= '';/g,\n reEmptyStringMiddle = /\\b(__p \\+=) '' \\+/g,\n reEmptyStringTrailing = /(__e\\(.*?\\)|\\b__t\\)) \\+\\n'';/g;\n\n /** Used to match HTML entities and HTML characters. */\n var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g,\n reUnescapedHtml = /[&<>\"']/g,\n reHasEscapedHtml = RegExp(reEscapedHtml.source),\n reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\n\n /** Used to match template delimiters. */\n var reEscape = /<%-([\\s\\S]+?)%>/g,\n reEvaluate = /<%([\\s\\S]+?)%>/g,\n reInterpolate = /<%=([\\s\\S]+?)%>/g;\n\n /** Used to match property names within property paths. */\n var reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/,\n rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n /**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\n var reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g,\n reHasRegExpChar = RegExp(reRegExpChar.source);\n\n /** Used to match leading whitespace. */\n var reTrimStart = /^\\s+/;\n\n /** Used to match a single whitespace character. */\n var reWhitespace = /\\s/;\n\n /** Used to match wrap detail comments. */\n var reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/,\n reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\n reSplitDetails = /,? & /;\n\n /** Used to match words composed of alphanumeric characters. */\n var reAsciiWord = /[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g;\n\n /**\n * Used to validate the `validate` option in `_.template` variable.\n *\n * Forbids characters which could potentially change the meaning of the function argument definition:\n * - \"(),\" (modification of function parameters)\n * - \"=\" (default value)\n * - \"[]{}\" (destructuring of function parameters)\n * - \"/\" (beginning of a comment)\n * - whitespace\n */\n var reForbiddenIdentifierChars = /[()=,{}\\[\\]\\/\\s]/;\n\n /** Used to match backslashes in property paths. */\n var reEscapeChar = /\\\\(\\\\)?/g;\n\n /**\n * Used to match\n * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components).\n */\n var reEsTemplate = /\\$\\{([^\\\\}]*(?:\\\\.[^\\\\}]*)*)\\}/g;\n\n /** Used to match `RegExp` flags from their coerced string values. */\n var reFlags = /\\w*$/;\n\n /** Used to detect bad signed hexadecimal string values. */\n var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n /** Used to detect binary string values. */\n var reIsBinary = /^0b[01]+$/i;\n\n /** Used to detect host constructors (Safari). */\n var reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n /** Used to detect octal string values. */\n var reIsOctal = /^0o[0-7]+$/i;\n\n /** Used to detect unsigned integer values. */\n var reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n /** Used to match Latin Unicode letters (excluding mathematical operators). */\n var reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n\n /** Used to ensure capturing order of template delimiters. */\n var reNoMatch = /($^)/;\n\n /** Used to match unescaped characters in compiled string literals. */\n var reUnescapedString = /['\\n\\r\\u2028\\u2029\\\\]/g;\n\n /** Used to compose unicode character classes. */\n var rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsDingbatRange = '\\\\u2700-\\\\u27bf',\n rsLowerRange = 'a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff',\n rsMathOpRange = '\\\\xac\\\\xb1\\\\xd7\\\\xf7',\n rsNonCharRange = '\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf',\n rsPunctuationRange = '\\\\u2000-\\\\u206f',\n rsSpaceRange = ' \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000',\n rsUpperRange = 'A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde',\n rsVarRange = '\\\\ufe0e\\\\ufe0f',\n rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;\n\n /** Used to compose unicode capture groups. */\n var rsApos = \"['\\u2019]\",\n rsAstral = '[' + rsAstralRange + ']',\n rsBreak = '[' + rsBreakRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsDigits = '\\\\d+',\n rsDingbat = '[' + rsDingbatRange + ']',\n rsLower = '[' + rsLowerRange + ']',\n rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsUpper = '[' + rsUpperRange + ']',\n rsZWJ = '\\\\u200d';\n\n /** Used to compose unicode regexes. */\n var rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')',\n rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')',\n rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',\n rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',\n reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsOrdLower = '\\\\d*(?:1st|2nd|3rd|(?![123])\\\\dth)(?=\\\\b|[A-Z_])',\n rsOrdUpper = '\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\dTH)(?=\\\\b|[a-z_])',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n /** Used to match apostrophes. */\n var reApos = RegExp(rsApos, 'g');\n\n /**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\n var reComboMark = RegExp(rsCombo, 'g');\n\n /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\n var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n /** Used to match complex or compound words. */\n var reUnicodeWord = RegExp([\n rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',\n rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')',\n rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower,\n rsUpper + '+' + rsOptContrUpper,\n rsOrdUpper,\n rsOrdLower,\n rsDigits,\n rsEmoji\n ].join('|'), 'g');\n\n /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\n var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n /** Used to detect strings that need a more robust regexp to match words. */\n var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;\n\n /** Used to assign default `context` object properties. */\n var contextProps = [\n 'Array', 'Buffer', 'DataView', 'Date', 'Error', 'Float32Array', 'Float64Array',\n 'Function', 'Int8Array', 'Int16Array', 'Int32Array', 'Map', 'Math', 'Object',\n 'Promise', 'RegExp', 'Set', 'String', 'Symbol', 'TypeError', 'Uint8Array',\n 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'WeakMap',\n '_', 'clearTimeout', 'isFinite', 'parseInt', 'setTimeout'\n ];\n\n /** Used to make template sourceURLs easier to identify. */\n var templateCounter = -1;\n\n /** Used to identify `toStringTag` values of typed arrays. */\n var typedArrayTags = {};\n typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\n typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\n typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\n typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\n typedArrayTags[uint32Tag] = true;\n typedArrayTags[argsTag] = typedArrayTags[arrayTag] =\n typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\n typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\n typedArrayTags[errorTag] = typedArrayTags[funcTag] =\n typedArrayTags[mapTag] = typedArrayTags[numberTag] =\n typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\n typedArrayTags[setTag] = typedArrayTags[stringTag] =\n typedArrayTags[weakMapTag] = false;\n\n /** Used to identify `toStringTag` values supported by `_.clone`. */\n var cloneableTags = {};\n cloneableTags[argsTag] = cloneableTags[arrayTag] =\n cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\n cloneableTags[boolTag] = cloneableTags[dateTag] =\n cloneableTags[float32Tag] = cloneableTags[float64Tag] =\n cloneableTags[int8Tag] = cloneableTags[int16Tag] =\n cloneableTags[int32Tag] = cloneableTags[mapTag] =\n cloneableTags[numberTag] = cloneableTags[objectTag] =\n cloneableTags[regexpTag] = cloneableTags[setTag] =\n cloneableTags[stringTag] = cloneableTags[symbolTag] =\n cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\n cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\n cloneableTags[errorTag] = cloneableTags[funcTag] =\n cloneableTags[weakMapTag] = false;\n\n /** Used to map Latin Unicode letters to basic Latin letters. */\n var deburredLetters = {\n // Latin-1 Supplement block.\n '\\xc0': 'A', '\\xc1': 'A', '\\xc2': 'A', '\\xc3': 'A', '\\xc4': 'A', '\\xc5': 'A',\n '\\xe0': 'a', '\\xe1': 'a', '\\xe2': 'a', '\\xe3': 'a', '\\xe4': 'a', '\\xe5': 'a',\n '\\xc7': 'C', '\\xe7': 'c',\n '\\xd0': 'D', '\\xf0': 'd',\n '\\xc8': 'E', '\\xc9': 'E', '\\xca': 'E', '\\xcb': 'E',\n '\\xe8': 'e', '\\xe9': 'e', '\\xea': 'e', '\\xeb': 'e',\n '\\xcc': 'I', '\\xcd': 'I', '\\xce': 'I', '\\xcf': 'I',\n '\\xec': 'i', '\\xed': 'i', '\\xee': 'i', '\\xef': 'i',\n '\\xd1': 'N', '\\xf1': 'n',\n '\\xd2': 'O', '\\xd3': 'O', '\\xd4': 'O', '\\xd5': 'O', '\\xd6': 'O', '\\xd8': 'O',\n '\\xf2': 'o', '\\xf3': 'o', '\\xf4': 'o', '\\xf5': 'o', '\\xf6': 'o', '\\xf8': 'o',\n '\\xd9': 'U', '\\xda': 'U', '\\xdb': 'U', '\\xdc': 'U',\n '\\xf9': 'u', '\\xfa': 'u', '\\xfb': 'u', '\\xfc': 'u',\n '\\xdd': 'Y', '\\xfd': 'y', '\\xff': 'y',\n '\\xc6': 'Ae', '\\xe6': 'ae',\n '\\xde': 'Th', '\\xfe': 'th',\n '\\xdf': 'ss',\n // Latin Extended-A block.\n '\\u0100': 'A', '\\u0102': 'A', '\\u0104': 'A',\n '\\u0101': 'a', '\\u0103': 'a', '\\u0105': 'a',\n '\\u0106': 'C', '\\u0108': 'C', '\\u010a': 'C', '\\u010c': 'C',\n '\\u0107': 'c', '\\u0109': 'c', '\\u010b': 'c', '\\u010d': 'c',\n '\\u010e': 'D', '\\u0110': 'D', '\\u010f': 'd', '\\u0111': 'd',\n '\\u0112': 'E', '\\u0114': 'E', '\\u0116': 'E', '\\u0118': 'E', '\\u011a': 'E',\n '\\u0113': 'e', '\\u0115': 'e', '\\u0117': 'e', '\\u0119': 'e', '\\u011b': 'e',\n '\\u011c': 'G', '\\u011e': 'G', '\\u0120': 'G', '\\u0122': 'G',\n '\\u011d': 'g', '\\u011f': 'g', '\\u0121': 'g', '\\u0123': 'g',\n '\\u0124': 'H', '\\u0126': 'H', '\\u0125': 'h', '\\u0127': 'h',\n '\\u0128': 'I', '\\u012a': 'I', '\\u012c': 'I', '\\u012e': 'I', '\\u0130': 'I',\n '\\u0129': 'i', '\\u012b': 'i', '\\u012d': 'i', '\\u012f': 'i', '\\u0131': 'i',\n '\\u0134': 'J', '\\u0135': 'j',\n '\\u0136': 'K', '\\u0137': 'k', '\\u0138': 'k',\n '\\u0139': 'L', '\\u013b': 'L', '\\u013d': 'L', '\\u013f': 'L', '\\u0141': 'L',\n '\\u013a': 'l', '\\u013c': 'l', '\\u013e': 'l', '\\u0140': 'l', '\\u0142': 'l',\n '\\u0143': 'N', '\\u0145': 'N', '\\u0147': 'N', '\\u014a': 'N',\n '\\u0144': 'n', '\\u0146': 'n', '\\u0148': 'n', '\\u014b': 'n',\n '\\u014c': 'O', '\\u014e': 'O', '\\u0150': 'O',\n '\\u014d': 'o', '\\u014f': 'o', '\\u0151': 'o',\n '\\u0154': 'R', '\\u0156': 'R', '\\u0158': 'R',\n '\\u0155': 'r', '\\u0157': 'r', '\\u0159': 'r',\n '\\u015a': 'S', '\\u015c': 'S', '\\u015e': 'S', '\\u0160': 'S',\n '\\u015b': 's', '\\u015d': 's', '\\u015f': 's', '\\u0161': 's',\n '\\u0162': 'T', '\\u0164': 'T', '\\u0166': 'T',\n '\\u0163': 't', '\\u0165': 't', '\\u0167': 't',\n '\\u0168': 'U', '\\u016a': 'U', '\\u016c': 'U', '\\u016e': 'U', '\\u0170': 'U', '\\u0172': 'U',\n '\\u0169': 'u', '\\u016b': 'u', '\\u016d': 'u', '\\u016f': 'u', '\\u0171': 'u', '\\u0173': 'u',\n '\\u0174': 'W', '\\u0175': 'w',\n '\\u0176': 'Y', '\\u0177': 'y', '\\u0178': 'Y',\n '\\u0179': 'Z', '\\u017b': 'Z', '\\u017d': 'Z',\n '\\u017a': 'z', '\\u017c': 'z', '\\u017e': 'z',\n '\\u0132': 'IJ', '\\u0133': 'ij',\n '\\u0152': 'Oe', '\\u0153': 'oe',\n '\\u0149': \"'n\", '\\u017f': 's'\n };\n\n /** Used to map characters to HTML entities. */\n var htmlEscapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n };\n\n /** Used to map HTML entities to characters. */\n var htmlUnescapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '"': '\"',\n ''': \"'\"\n };\n\n /** Used to escape characters for inclusion in compiled string literals. */\n var stringEscapes = {\n '\\\\': '\\\\',\n \"'\": \"'\",\n '\\n': 'n',\n '\\r': 'r',\n '\\u2028': 'u2028',\n '\\u2029': 'u2029'\n };\n\n /** Built-in method references without a dependency on `root`. */\n var freeParseFloat = parseFloat,\n freeParseInt = parseInt;\n\n /** Detect free variable `global` from Node.js. */\n var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n /** Detect free variable `self`. */\n var freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n /** Used as a reference to the global object. */\n var root = freeGlobal || freeSelf || Function('return this')();\n\n /** Detect free variable `exports`. */\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n /** Detect free variable `module`. */\n var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n /** Detect the popular CommonJS extension `module.exports`. */\n var moduleExports = freeModule && freeModule.exports === freeExports;\n\n /** Detect free variable `process` from Node.js. */\n var freeProcess = moduleExports && freeGlobal.process;\n\n /** Used to access faster Node.js helpers. */\n var nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n }());\n\n /* Node.js helper references. */\n var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer,\n nodeIsDate = nodeUtil && nodeUtil.isDate,\n nodeIsMap = nodeUtil && nodeUtil.isMap,\n nodeIsRegExp = nodeUtil && nodeUtil.isRegExp,\n nodeIsSet = nodeUtil && nodeUtil.isSet,\n nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\n function apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n }\n\n /**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.forEachRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEachRight(array, iteratee) {\n var length = array == null ? 0 : array.length;\n\n while (length--) {\n if (iteratee(array[length], length, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.every` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n */\n function arrayEvery(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (!predicate(array[index], index, array)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\n function arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n }\n\n /**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\n function arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n function arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n }\n\n /**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\n function arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n }\n\n /**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.reduceRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the last element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduceRight(array, iteratee, accumulator, initAccum) {\n var length = array == null ? 0 : array.length;\n if (initAccum && length) {\n accumulator = array[--length];\n }\n while (length--) {\n accumulator = iteratee(accumulator, array[length], length, array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n var asciiSize = baseProperty('length');\n\n /**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function asciiToArray(string) {\n return string.split('');\n }\n\n /**\n * Splits an ASCII `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function asciiWords(string) {\n return string.match(reAsciiWord) || [];\n }\n\n /**\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\n * without support for iteratee shorthands, which iterates over `collection`\n * using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the found element or its key, else `undefined`.\n */\n function baseFindKey(collection, predicate, eachFunc) {\n var result;\n eachFunc(collection, function(value, key, collection) {\n if (predicate(value, key, collection)) {\n result = key;\n return false;\n }\n });\n return result;\n }\n\n /**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n }\n\n /**\n * This function is like `baseIndexOf` except that it accepts a comparator.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseIndexOfWith(array, value, fromIndex, comparator) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (comparator(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\n function baseIsNaN(value) {\n return value !== value;\n }\n\n /**\n * The base implementation of `_.mean` and `_.meanBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the mean.\n */\n function baseMean(array, iteratee) {\n var length = array == null ? 0 : array.length;\n return length ? (baseSum(array, iteratee) / length) : NAN;\n }\n\n /**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n function baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyOf(object) {\n return function(key) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n * `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\n function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n eachFunc(collection, function(value, index, collection) {\n accumulator = initAccum\n ? (initAccum = false, value)\n : iteratee(accumulator, value, index, collection);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.sortBy` which uses `comparer` to define the\n * sort order of `array` and replaces criteria objects with their corresponding\n * values.\n *\n * @private\n * @param {Array} array The array to sort.\n * @param {Function} comparer The function to define sort order.\n * @returns {Array} Returns `array`.\n */\n function baseSortBy(array, comparer) {\n var length = array.length;\n\n array.sort(comparer);\n while (length--) {\n array[length] = array[length].value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.sum` and `_.sumBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the sum.\n */\n function baseSum(array, iteratee) {\n var result,\n index = -1,\n length = array.length;\n\n while (++index < length) {\n var current = iteratee(array[index]);\n if (current !== undefined) {\n result = result === undefined ? current : (result + current);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\n function baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array\n * of key-value pairs for `object` corresponding to the property names of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the key-value pairs.\n */\n function baseToPairs(object, props) {\n return arrayMap(props, function(key) {\n return [key, object[key]];\n });\n }\n\n /**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\n function baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n }\n\n /**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\n function baseUnary(func) {\n return function(value) {\n return func(value);\n };\n }\n\n /**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\n function baseValues(object, props) {\n return arrayMap(props, function(key) {\n return object[key];\n });\n }\n\n /**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function cacheHas(cache, key) {\n return cache.has(key);\n }\n\n /**\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the first unmatched string symbol.\n */\n function charsStartIndex(strSymbols, chrSymbols) {\n var index = -1,\n length = strSymbols.length;\n\n while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the last unmatched string symbol.\n */\n function charsEndIndex(strSymbols, chrSymbols) {\n var index = strSymbols.length;\n\n while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Gets the number of `placeholder` occurrences in `array`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} placeholder The placeholder to search for.\n * @returns {number} Returns the placeholder count.\n */\n function countHolders(array, placeholder) {\n var length = array.length,\n result = 0;\n\n while (length--) {\n if (array[length] === placeholder) {\n ++result;\n }\n }\n return result;\n }\n\n /**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\n var deburrLetter = basePropertyOf(deburredLetters);\n\n /**\n * Used by `_.escape` to convert characters to HTML entities.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n var escapeHtmlChar = basePropertyOf(htmlEscapes);\n\n /**\n * Used by `_.template` to escape characters for inclusion in compiled string literals.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n function escapeStringChar(chr) {\n return '\\\\' + stringEscapes[chr];\n }\n\n /**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\n function getValue(object, key) {\n return object == null ? undefined : object[key];\n }\n\n /**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\n function hasUnicode(string) {\n return reHasUnicode.test(string);\n }\n\n /**\n * Checks if `string` contains a word composed of Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a word is found, else `false`.\n */\n function hasUnicodeWord(string) {\n return reHasUnicodeWord.test(string);\n }\n\n /**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\n function iteratorToArray(iterator) {\n var data,\n result = [];\n\n while (!(data = iterator.next()).done) {\n result.push(data.value);\n }\n return result;\n }\n\n /**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\n function mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n }\n\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 */\n function overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n }\n\n /**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\n function replaceHolders(array, placeholder) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value === placeholder || value === PLACEHOLDER) {\n array[index] = PLACEHOLDER;\n result[resIndex++] = index;\n }\n }\n return result;\n }\n\n /**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\n function setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n }\n\n /**\n * Converts `set` to its value-value pairs.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the value-value pairs.\n */\n function setToPairs(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = [value, value];\n });\n return result;\n }\n\n /**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictIndexOf(array, value, fromIndex) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * A specialized version of `_.lastIndexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictLastIndexOf(array, value, fromIndex) {\n var index = fromIndex + 1;\n while (index--) {\n if (array[index] === value) {\n return index;\n }\n }\n return index;\n }\n\n /**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\n function stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n }\n\n /**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function stringToArray(string) {\n return hasUnicode(string)\n ? unicodeToArray(string)\n : asciiToArray(string);\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\n function trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n }\n\n /**\n * Used by `_.unescape` to convert HTML entities to characters.\n *\n * @private\n * @param {string} chr The matched character to unescape.\n * @returns {string} Returns the unescaped character.\n */\n var unescapeHtmlChar = basePropertyOf(htmlUnescapes);\n\n /**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n function unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n }\n\n /**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function unicodeToArray(string) {\n return string.match(reUnicode) || [];\n }\n\n /**\n * Splits a Unicode `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function unicodeWords(string) {\n return string.match(reUnicodeWord) || [];\n }\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * Create a new pristine `lodash` function using the `context` object.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Util\n * @param {Object} [context=root] The context object.\n * @returns {Function} Returns a new `lodash` function.\n * @example\n *\n * _.mixin({ 'foo': _.constant('foo') });\n *\n * var lodash = _.runInContext();\n * lodash.mixin({ 'bar': lodash.constant('bar') });\n *\n * _.isFunction(_.foo);\n * // => true\n * _.isFunction(_.bar);\n * // => false\n *\n * lodash.isFunction(lodash.foo);\n * // => false\n * lodash.isFunction(lodash.bar);\n * // => true\n *\n * // Create a suped-up `defer` in Node.js.\n * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer;\n */\n var runInContext = (function runInContext(context) {\n context = context == null ? root : _.defaults(root.Object(), context, _.pick(root, contextProps));\n\n /** Built-in constructor references. */\n var Array = context.Array,\n Date = context.Date,\n Error = context.Error,\n Function = context.Function,\n Math = context.Math,\n Object = context.Object,\n RegExp = context.RegExp,\n String = context.String,\n TypeError = context.TypeError;\n\n /** Used for built-in method references. */\n var arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n /** Used to detect overreaching core-js shims. */\n var coreJsData = context['__core-js_shared__'];\n\n /** Used to resolve the decompiled source of functions. */\n var funcToString = funcProto.toString;\n\n /** Used to check objects for own properties. */\n var hasOwnProperty = objectProto.hasOwnProperty;\n\n /** Used to generate unique IDs. */\n var idCounter = 0;\n\n /** Used to detect methods masquerading as native. */\n var maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n }());\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 */\n var nativeObjectToString = objectProto.toString;\n\n /** Used to infer the `Object` constructor. */\n var objectCtorString = funcToString.call(Object);\n\n /** Used to restore the original `_` reference in `_.noConflict`. */\n var oldDash = root._;\n\n /** Used to detect if a method is native. */\n var reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n );\n\n /** Built-in value references. */\n var Buffer = moduleExports ? context.Buffer : undefined,\n Symbol = context.Symbol,\n Uint8Array = context.Uint8Array,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,\n getPrototype = overArg(Object.getPrototypeOf, Object),\n objectCreate = Object.create,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined,\n symIterator = Symbol ? Symbol.iterator : undefined,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n var defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n }());\n\n /** Mocked built-ins. */\n var ctxClearTimeout = context.clearTimeout !== root.clearTimeout && context.clearTimeout,\n ctxNow = Date && Date.now !== root.Date.now && Date.now,\n ctxSetTimeout = context.setTimeout !== root.setTimeout && context.setTimeout;\n\n /* Built-in method references for those with the same name as other `lodash` methods. */\n var nativeCeil = Math.ceil,\n nativeFloor = Math.floor,\n nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeIsFinite = context.isFinite,\n nativeJoin = arrayProto.join,\n nativeKeys = overArg(Object.keys, Object),\n nativeMax = Math.max,\n nativeMin = Math.min,\n nativeNow = Date.now,\n nativeParseInt = context.parseInt,\n nativeRandom = Math.random,\n nativeReverse = arrayProto.reverse;\n\n /* Built-in method references that are verified to be native. */\n var DataView = getNative(context, 'DataView'),\n Map = getNative(context, 'Map'),\n Promise = getNative(context, 'Promise'),\n Set = getNative(context, 'Set'),\n WeakMap = getNative(context, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n /** Used to store function metadata. */\n var metaMap = WeakMap && new WeakMap;\n\n /** Used to lookup unminified function names. */\n var realNames = {};\n\n /** Used to detect maps, sets, and weakmaps. */\n var dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n /** Used to convert symbols to primitives and strings. */\n var symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` object which wraps `value` to enable implicit method\n * chain sequences. Methods that operate on and return arrays, collections,\n * and functions can be chained together. Methods that retrieve a single value\n * or may return a primitive value will automatically end the chain sequence\n * and return the unwrapped value. Otherwise, the value must be unwrapped\n * with `_#value`.\n *\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\n * enabled using `_.chain`.\n *\n * The execution of chained methods is lazy, that is, it's deferred until\n * `_#value` is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion.\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\n * the creation of intermediate arrays and can greatly reduce the number of\n * iteratee executions. Sections of a chain sequence qualify for shortcut\n * fusion if the section is applied to an array and iteratees accept only\n * one argument. The heuristic for whether a section qualifies for shortcut\n * fusion is subject to change.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\n * `zipObject`, `zipObjectDeep`, and `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\n * `upperFirst`, `value`, and `words`\n *\n * @name _\n * @constructor\n * @category Seq\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // Returns an unwrapped value.\n * wrapped.reduce(_.add);\n * // => 6\n *\n * // Returns a wrapped value.\n * var squares = wrapped.map(square);\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\n function lodash(value) {\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n if (value instanceof LodashWrapper) {\n return value;\n }\n if (hasOwnProperty.call(value, '__wrapped__')) {\n return wrapperClone(value);\n }\n }\n return new LodashWrapper(value);\n }\n\n /**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\n var baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n }());\n\n /**\n * The function whose prototype chain sequence wrappers inherit from.\n *\n * @private\n */\n function baseLodash() {\n // No operation performed.\n }\n\n /**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\n */\n function LodashWrapper(value, chainAll) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__chain__ = !!chainAll;\n this.__index__ = 0;\n this.__values__ = undefined;\n }\n\n /**\n * By default, the template delimiters used by lodash are like those in\n * embedded Ruby (ERB) as well as ES2015 template strings. Change the\n * following template settings to use alternative delimiters.\n *\n * @static\n * @memberOf _\n * @type {Object}\n */\n lodash.templateSettings = {\n\n /**\n * Used to detect `data` property values to be HTML-escaped.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'escape': reEscape,\n\n /**\n * Used to detect code to be evaluated.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'evaluate': reEvaluate,\n\n /**\n * Used to detect `data` property values to inject.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'interpolate': reInterpolate,\n\n /**\n * Used to reference the data object in the template text.\n *\n * @memberOf _.templateSettings\n * @type {string}\n */\n 'variable': '',\n\n /**\n * Used to import variables into the compiled template.\n *\n * @memberOf _.templateSettings\n * @type {Object}\n */\n 'imports': {\n\n /**\n * A reference to the `lodash` function.\n *\n * @memberOf _.templateSettings.imports\n * @type {Function}\n */\n '_': lodash\n }\n };\n\n // Ensure wrappers are instances of `baseLodash`.\n lodash.prototype = baseLodash.prototype;\n lodash.prototype.constructor = lodash;\n\n LodashWrapper.prototype = baseCreate(baseLodash.prototype);\n LodashWrapper.prototype.constructor = LodashWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @constructor\n * @param {*} value The value to wrap.\n */\n function LazyWrapper(value) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__dir__ = 1;\n this.__filtered__ = false;\n this.__iteratees__ = [];\n this.__takeCount__ = MAX_ARRAY_LENGTH;\n this.__views__ = [];\n }\n\n /**\n * Creates a clone of the lazy wrapper object.\n *\n * @private\n * @name clone\n * @memberOf LazyWrapper\n * @returns {Object} Returns the cloned `LazyWrapper` object.\n */\n function lazyClone() {\n var result = new LazyWrapper(this.__wrapped__);\n result.__actions__ = copyArray(this.__actions__);\n result.__dir__ = this.__dir__;\n result.__filtered__ = this.__filtered__;\n result.__iteratees__ = copyArray(this.__iteratees__);\n result.__takeCount__ = this.__takeCount__;\n result.__views__ = copyArray(this.__views__);\n return result;\n }\n\n /**\n * Reverses the direction of lazy iteration.\n *\n * @private\n * @name reverse\n * @memberOf LazyWrapper\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\n */\n function lazyReverse() {\n if (this.__filtered__) {\n var result = new LazyWrapper(this);\n result.__dir__ = -1;\n result.__filtered__ = true;\n } else {\n result = this.clone();\n result.__dir__ *= -1;\n }\n return result;\n }\n\n /**\n * Extracts the unwrapped value from its lazy wrapper.\n *\n * @private\n * @name value\n * @memberOf LazyWrapper\n * @returns {*} Returns the unwrapped value.\n */\n function lazyValue() {\n var array = this.__wrapped__.value(),\n dir = this.__dir__,\n isArr = isArray(array),\n isRight = dir < 0,\n arrLength = isArr ? array.length : 0,\n view = getView(0, arrLength, this.__views__),\n start = view.start,\n end = view.end,\n length = end - start,\n index = isRight ? end : (start - 1),\n iteratees = this.__iteratees__,\n iterLength = iteratees.length,\n resIndex = 0,\n takeCount = nativeMin(length, this.__takeCount__);\n\n if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\n return baseWrapperValue(array, this.__actions__);\n }\n var result = [];\n\n outer:\n while (length-- && resIndex < takeCount) {\n index += dir;\n\n var iterIndex = -1,\n value = array[index];\n\n while (++iterIndex < iterLength) {\n var data = iteratees[iterIndex],\n iteratee = data.iteratee,\n type = data.type,\n computed = iteratee(value);\n\n if (type == LAZY_MAP_FLAG) {\n value = computed;\n } else if (!computed) {\n if (type == LAZY_FILTER_FLAG) {\n continue outer;\n } else {\n break outer;\n }\n }\n }\n result[resIndex++] = value;\n }\n return result;\n }\n\n // Ensure `LazyWrapper` is an instance of `baseLodash`.\n LazyWrapper.prototype = baseCreate(baseLodash.prototype);\n LazyWrapper.prototype.constructor = LazyWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\n function hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n }\n\n /**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n }\n\n /**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n }\n\n /**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\n function hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n }\n\n // Add methods to `Hash`.\n Hash.prototype.clear = hashClear;\n Hash.prototype['delete'] = hashDelete;\n Hash.prototype.get = hashGet;\n Hash.prototype.has = hashHas;\n Hash.prototype.set = hashSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\n function listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n }\n\n /**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n }\n\n /**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n }\n\n /**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\n function listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n }\n\n // Add methods to `ListCache`.\n ListCache.prototype.clear = listCacheClear;\n ListCache.prototype['delete'] = listCacheDelete;\n ListCache.prototype.get = listCacheGet;\n ListCache.prototype.has = listCacheHas;\n ListCache.prototype.set = listCacheSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\n function mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n }\n\n /**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n }\n\n /**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function mapCacheGet(key) {\n return getMapData(this, key).get(key);\n }\n\n /**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function mapCacheHas(key) {\n return getMapData(this, key).has(key);\n }\n\n /**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\n function mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n }\n\n // Add methods to `MapCache`.\n MapCache.prototype.clear = mapCacheClear;\n MapCache.prototype['delete'] = mapCacheDelete;\n MapCache.prototype.get = mapCacheGet;\n MapCache.prototype.has = mapCacheHas;\n MapCache.prototype.set = mapCacheSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\n function SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n }\n\n /**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\n function setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n }\n\n /**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\n function setCacheHas(value) {\n return this.__data__.has(value);\n }\n\n // Add methods to `SetCache`.\n SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\n SetCache.prototype.has = setCacheHas;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n }\n\n /**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\n function stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n }\n\n /**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function stackGet(key) {\n return this.__data__.get(key);\n }\n\n /**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function stackHas(key) {\n return this.__data__.has(key);\n }\n\n /**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\n function stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n }\n\n // Add methods to `Stack`.\n Stack.prototype.clear = stackClear;\n Stack.prototype['delete'] = stackDelete;\n Stack.prototype.get = stackGet;\n Stack.prototype.has = stackHas;\n Stack.prototype.set = stackSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\n function arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `_.sample` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @returns {*} Returns the random element.\n */\n function arraySample(array) {\n var length = array.length;\n return length ? array[baseRandom(0, length - 1)] : undefined;\n }\n\n /**\n * A specialized version of `_.sampleSize` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function arraySampleSize(array, n) {\n return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length));\n }\n\n /**\n * A specialized version of `_.shuffle` for arrays.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function arrayShuffle(array) {\n return shuffleSelf(copyArray(array));\n }\n\n /**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function assignMergeValue(object, key, value) {\n if ((value !== undefined && !eq(object[key], value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n }\n\n /**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n }\n\n /**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n }\n\n /**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\n function baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n }\n\n /**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\n function baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n }\n\n /**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n }\n\n /**\n * The base implementation of `_.at` without support for individual paths.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {string[]} paths The property paths to pick.\n * @returns {Array} Returns the picked elements.\n */\n function baseAt(object, paths) {\n var index = -1,\n length = paths.length,\n result = Array(length),\n skip = object == null;\n\n while (++index < length) {\n result[index] = skip ? undefined : get(object, paths[index]);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\n function baseClamp(number, lower, upper) {\n if (number === number) {\n if (upper !== undefined) {\n number = number <= upper ? number : upper;\n }\n if (lower !== undefined) {\n number = number >= lower ? number : lower;\n }\n }\n return number;\n }\n\n /**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\n function baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n }\n\n /**\n * The base implementation of `_.conforms` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n */\n function baseConforms(source) {\n var props = keys(source);\n return function(object) {\n return baseConformsTo(object, source, props);\n };\n }\n\n /**\n * The base implementation of `_.conformsTo` which accepts `props` to check.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n */\n function baseConformsTo(object, source, props) {\n var length = props.length;\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (length--) {\n var key = props[length],\n predicate = source[key],\n value = object[key];\n\n if ((value === undefined && !(key in object)) || !predicate(value)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\n * to provide to `func`.\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {Array} args The arguments to provide to `func`.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n function baseDelay(func, wait, args) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return setTimeout(function() { func.apply(undefined, args); }, wait);\n }\n\n /**\n * The base implementation of methods like `_.difference` without support\n * for excluding multiple arrays or iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Array} values The values to exclude.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n */\n function baseDifference(array, values, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n isCommon = true,\n length = array.length,\n result = [],\n valuesLength = values.length;\n\n if (!length) {\n return result;\n }\n if (iteratee) {\n values = arrayMap(values, baseUnary(iteratee));\n }\n if (comparator) {\n includes = arrayIncludesWith;\n isCommon = false;\n }\n else if (values.length >= LARGE_ARRAY_SIZE) {\n includes = cacheHas;\n isCommon = false;\n values = new SetCache(values);\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee == null ? value : iteratee(value);\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var valuesIndex = valuesLength;\n while (valuesIndex--) {\n if (values[valuesIndex] === computed) {\n continue outer;\n }\n }\n result.push(value);\n }\n else if (!includes(values, computed, comparator)) {\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEach = createBaseEach(baseForOwn);\n\n /**\n * The base implementation of `_.forEachRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEachRight = createBaseEach(baseForOwnRight, true);\n\n /**\n * The base implementation of `_.every` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`\n */\n function baseEvery(collection, predicate) {\n var result = true;\n baseEach(collection, function(value, index, collection) {\n result = !!predicate(value, index, collection);\n return result;\n });\n return result;\n }\n\n /**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\n function baseExtremum(array, iteratee, comparator) {\n var index = -1,\n length = array.length;\n\n while (++index < length) {\n var value = array[index],\n current = iteratee(value);\n\n if (current != null && (computed === undefined\n ? (current === current && !isSymbol(current))\n : comparator(current, computed)\n )) {\n var computed = current,\n result = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\n function baseFill(array, value, start, end) {\n var length = array.length;\n\n start = toInteger(start);\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = (end === undefined || end > length) ? length : toInteger(end);\n if (end < 0) {\n end += length;\n }\n end = start > end ? 0 : toLength(end);\n while (start < end) {\n array[start++] = value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function baseFilter(collection, predicate) {\n var result = [];\n baseEach(collection, function(value, index, collection) {\n if (predicate(value, index, collection)) {\n result.push(value);\n }\n });\n return result;\n }\n\n /**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\n function baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseFor = createBaseFor();\n\n /**\n * This function is like `baseFor` except that it iterates over properties\n * in the opposite order.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseForRight = createBaseFor(true);\n\n /**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwnRight(object, iteratee) {\n return object && baseForRight(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.functions` which creates an array of\n * `object` function property names filtered from `props`.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Array} props The property names to filter.\n * @returns {Array} Returns the function names.\n */\n function baseFunctions(object, props) {\n return arrayFilter(props, function(key) {\n return isFunction(object[key]);\n });\n }\n\n /**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\n function baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n }\n\n /**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n }\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 */\n function 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\n /**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n */\n function baseGt(value, other) {\n return value > other;\n }\n\n /**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\n function baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n }\n\n /**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\n function baseHasIn(object, key) {\n return object != null && key in Object(object);\n }\n\n /**\n * The base implementation of `_.inRange` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to check.\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n */\n function baseInRange(number, start, end) {\n return number >= nativeMin(start, end) && number < nativeMax(start, end);\n }\n\n /**\n * The base implementation of methods like `_.intersection`, without support\n * for iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of shared values.\n */\n function baseIntersection(arrays, iteratee, comparator) {\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\n length = arrays[0].length,\n othLength = arrays.length,\n othIndex = othLength,\n caches = Array(othLength),\n maxLength = Infinity,\n result = [];\n\n while (othIndex--) {\n var array = arrays[othIndex];\n if (othIndex && iteratee) {\n array = arrayMap(array, baseUnary(iteratee));\n }\n maxLength = nativeMin(array.length, maxLength);\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\n ? new SetCache(othIndex && array)\n : undefined;\n }\n array = arrays[0];\n\n var index = -1,\n seen = caches[0];\n\n outer:\n while (++index < length && result.length < maxLength) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (!(seen\n ? cacheHas(seen, computed)\n : includes(result, computed, comparator)\n )) {\n othIndex = othLength;\n while (--othIndex) {\n var cache = caches[othIndex];\n if (!(cache\n ? cacheHas(cache, computed)\n : includes(arrays[othIndex], computed, comparator))\n ) {\n continue outer;\n }\n }\n if (seen) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.invert` and `_.invertBy` which inverts\n * `object` with values transformed by `iteratee` and set by `setter`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform values.\n * @param {Object} accumulator The initial inverted object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseInverter(object, setter, iteratee, accumulator) {\n baseForOwn(object, function(value, key, object) {\n setter(accumulator, iteratee(value), key, object);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.invoke` without support for individual\n * method arguments.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {Array} args The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n */\n function baseInvoke(object, path, args) {\n path = castPath(path, object);\n object = parent(object, path);\n var func = object == null ? object : object[toKey(last(path))];\n return func == null ? undefined : apply(func, object, args);\n }\n\n /**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\n function baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n }\n\n /**\n * The base implementation of `_.isArrayBuffer` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n */\n function baseIsArrayBuffer(value) {\n return isObjectLike(value) && baseGetTag(value) == arrayBufferTag;\n }\n\n /**\n * The base implementation of `_.isDate` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n */\n function baseIsDate(value) {\n return isObjectLike(value) && baseGetTag(value) == dateTag;\n }\n\n /**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\n function baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n }\n\n /**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n }\n\n /**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\n function baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n }\n\n /**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\n function baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\n function baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n }\n\n /**\n * The base implementation of `_.isRegExp` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n */\n function baseIsRegExp(value) {\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\n }\n\n /**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\n function baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n }\n\n /**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\n function baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n }\n\n /**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\n function baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n }\n\n /**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n */\n function baseLt(value, other) {\n return value < other;\n }\n\n /**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n function baseMap(collection, iteratee) {\n var index = -1,\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value, key, collection) {\n result[++index] = iteratee(value, key, collection);\n });\n return result;\n }\n\n /**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\n function baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n }\n\n /**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\n function baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n }\n\n /**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\n function baseMerge(object, source, srcIndex, customizer, stack) {\n if (object === source) {\n return;\n }\n baseFor(source, function(srcValue, key) {\n stack || (stack = new Stack);\n if (isObject(srcValue)) {\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n }\n else {\n var newValue = customizer\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n : undefined;\n\n if (newValue === undefined) {\n newValue = srcValue;\n }\n assignMergeValue(object, key, newValue);\n }\n }, keysIn);\n }\n\n /**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\n function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n var objValue = safeGet(object, key),\n srcValue = safeGet(source, key),\n stacked = stack.get(srcValue);\n\n if (stacked) {\n assignMergeValue(object, key, stacked);\n return;\n }\n var newValue = customizer\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n : undefined;\n\n var isCommon = newValue === undefined;\n\n if (isCommon) {\n var isArr = isArray(srcValue),\n isBuff = !isArr && isBuffer(srcValue),\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n newValue = srcValue;\n if (isArr || isBuff || isTyped) {\n if (isArray(objValue)) {\n newValue = objValue;\n }\n else if (isArrayLikeObject(objValue)) {\n newValue = copyArray(objValue);\n }\n else if (isBuff) {\n isCommon = false;\n newValue = cloneBuffer(srcValue, true);\n }\n else if (isTyped) {\n isCommon = false;\n newValue = cloneTypedArray(srcValue, true);\n }\n else {\n newValue = [];\n }\n }\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n newValue = objValue;\n if (isArguments(objValue)) {\n newValue = toPlainObject(objValue);\n }\n else if (!isObject(objValue) || isFunction(objValue)) {\n newValue = initCloneObject(srcValue);\n }\n }\n else {\n isCommon = false;\n }\n }\n if (isCommon) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, newValue);\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n stack['delete'](srcValue);\n }\n assignMergeValue(object, key, newValue);\n }\n\n /**\n * The base implementation of `_.nth` which doesn't coerce arguments.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {number} n The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n */\n function baseNth(array, n) {\n var length = array.length;\n if (!length) {\n return;\n }\n n += n < 0 ? length : 0;\n return isIndex(n, length) ? array[n] : undefined;\n }\n\n /**\n * The base implementation of `_.orderBy` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\n * @param {string[]} orders The sort orders of `iteratees`.\n * @returns {Array} Returns the new sorted array.\n */\n function baseOrderBy(collection, iteratees, orders) {\n if (iteratees.length) {\n iteratees = arrayMap(iteratees, function(iteratee) {\n if (isArray(iteratee)) {\n return function(value) {\n return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);\n }\n }\n return iteratee;\n });\n } else {\n iteratees = [identity];\n }\n\n var index = -1;\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n\n var result = baseMap(collection, function(value, key, collection) {\n var criteria = arrayMap(iteratees, function(iteratee) {\n return iteratee(value);\n });\n return { 'criteria': criteria, 'index': ++index, 'value': value };\n });\n\n return baseSortBy(result, function(object, other) {\n return compareMultiple(object, other, orders);\n });\n }\n\n /**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\n function basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n }\n\n /**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\n function basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n }\n\n /**\n * The base implementation of `_.pullAllBy` without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n */\n function basePullAll(array, values, iteratee, comparator) {\n var indexOf = comparator ? baseIndexOfWith : baseIndexOf,\n index = -1,\n length = values.length,\n seen = array;\n\n if (array === values) {\n values = copyArray(values);\n }\n if (iteratee) {\n seen = arrayMap(array, baseUnary(iteratee));\n }\n while (++index < length) {\n var fromIndex = 0,\n value = values[index],\n computed = iteratee ? iteratee(value) : value;\n\n while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) {\n if (seen !== array) {\n splice.call(seen, fromIndex, 1);\n }\n splice.call(array, fromIndex, 1);\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.pullAt` without support for individual\n * indexes or capturing the removed elements.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {number[]} indexes The indexes of elements to remove.\n * @returns {Array} Returns `array`.\n */\n function basePullAt(array, indexes) {\n var length = array ? indexes.length : 0,\n lastIndex = length - 1;\n\n while (length--) {\n var index = indexes[length];\n if (length == lastIndex || index !== previous) {\n var previous = index;\n if (isIndex(index)) {\n splice.call(array, index, 1);\n } else {\n baseUnset(array, index);\n }\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.random` without support for returning\n * floating-point numbers.\n *\n * @private\n * @param {number} lower The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the random number.\n */\n function baseRandom(lower, upper) {\n return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\n }\n\n /**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\n function baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n }\n\n /**\n * The base implementation of `_.repeat` which doesn't coerce arguments.\n *\n * @private\n * @param {string} string The string to repeat.\n * @param {number} n The number of times to repeat the string.\n * @returns {string} Returns the repeated string.\n */\n function baseRepeat(string, n) {\n var result = '';\n if (!string || n < 1 || n > MAX_SAFE_INTEGER) {\n return result;\n }\n // Leverage the exponentiation by squaring algorithm for a faster repeat.\n // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details.\n do {\n if (n % 2) {\n result += string;\n }\n n = nativeFloor(n / 2);\n if (n) {\n string += string;\n }\n } while (n);\n\n return result;\n }\n\n /**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\n function baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n }\n\n /**\n * The base implementation of `_.sample`.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n */\n function baseSample(collection) {\n return arraySample(values(collection));\n }\n\n /**\n * The base implementation of `_.sampleSize` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function baseSampleSize(collection, n) {\n var array = values(collection);\n return shuffleSelf(array, baseClamp(n, 0, array.length));\n }\n\n /**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n }\n\n /**\n * The base implementation of `setData` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var baseSetData = !metaMap ? identity : function(func, data) {\n metaMap.set(func, data);\n return func;\n };\n\n /**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\n var baseSetToString = !defineProperty ? identity : function(func, string) {\n return defineProperty(func, 'toString', {\n 'configurable': true,\n 'enumerable': false,\n 'value': constant(string),\n 'writable': true\n });\n };\n\n /**\n * The base implementation of `_.shuffle`.\n *\n * @private\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function baseShuffle(collection) {\n return shuffleSelf(values(collection));\n }\n\n /**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n }\n\n /**\n * The base implementation of `_.some` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function baseSome(collection, predicate) {\n var result;\n\n baseEach(collection, function(value, index, collection) {\n result = predicate(value, index, collection);\n return !result;\n });\n return !!result;\n }\n\n /**\n * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which\n * performs a binary search of `array` to determine the index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndex(array, value, retHighest) {\n var low = 0,\n high = array == null ? low : array.length;\n\n if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) {\n while (low < high) {\n var mid = (low + high) >>> 1,\n computed = array[mid];\n\n if (computed !== null && !isSymbol(computed) &&\n (retHighest ? (computed <= value) : (computed < value))) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return high;\n }\n return baseSortedIndexBy(array, value, identity, retHighest);\n }\n\n /**\n * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy`\n * which invokes `iteratee` for `value` and each element of `array` to compute\n * their sort ranking. The iteratee is invoked with one argument; (value).\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} iteratee The iteratee invoked per element.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndexBy(array, value, iteratee, retHighest) {\n var low = 0,\n high = array == null ? 0 : array.length;\n if (high === 0) {\n return 0;\n }\n\n value = iteratee(value);\n var valIsNaN = value !== value,\n valIsNull = value === null,\n valIsSymbol = isSymbol(value),\n valIsUndefined = value === undefined;\n\n while (low < high) {\n var mid = nativeFloor((low + high) / 2),\n computed = iteratee(array[mid]),\n othIsDefined = computed !== undefined,\n othIsNull = computed === null,\n othIsReflexive = computed === computed,\n othIsSymbol = isSymbol(computed);\n\n if (valIsNaN) {\n var setLow = retHighest || othIsReflexive;\n } else if (valIsUndefined) {\n setLow = othIsReflexive && (retHighest || othIsDefined);\n } else if (valIsNull) {\n setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull);\n } else if (valIsSymbol) {\n setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol);\n } else if (othIsNull || othIsSymbol) {\n setLow = false;\n } else {\n setLow = retHighest ? (computed <= value) : (computed < value);\n }\n if (setLow) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return nativeMin(high, MAX_ARRAY_INDEX);\n }\n\n /**\n * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseSortedUniq(array, iteratee) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n if (!index || !eq(computed, seen)) {\n var seen = computed;\n result[resIndex++] = value === 0 ? 0 : value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toNumber` which doesn't ensure correct\n * conversions of binary, hexadecimal, or octal string values.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n */\n function baseToNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n return +value;\n }\n\n /**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\n function baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n }\n\n /**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseUniq(array, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n length = array.length,\n isCommon = true,\n result = [],\n seen = result;\n\n if (comparator) {\n isCommon = false;\n includes = arrayIncludesWith;\n }\n else if (length >= LARGE_ARRAY_SIZE) {\n var set = iteratee ? null : createSet(array);\n if (set) {\n return setToArray(set);\n }\n isCommon = false;\n includes = cacheHas;\n seen = new SetCache;\n }\n else {\n seen = iteratee ? [] : result;\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var seenIndex = seen.length;\n while (seenIndex--) {\n if (seen[seenIndex] === computed) {\n continue outer;\n }\n }\n if (iteratee) {\n seen.push(computed);\n }\n result.push(value);\n }\n else if (!includes(seen, computed, comparator)) {\n if (seen !== result) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\n function baseUnset(object, path) {\n path = castPath(path, object);\n object = parent(object, path);\n return object == null || delete object[toKey(last(path))];\n }\n\n /**\n * The base implementation of `_.update`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to update.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseUpdate(object, path, updater, customizer) {\n return baseSet(object, path, updater(baseGet(object, path)), customizer);\n }\n\n /**\n * The base implementation of methods like `_.dropWhile` and `_.takeWhile`\n * without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {Function} predicate The function invoked per iteration.\n * @param {boolean} [isDrop] Specify dropping elements instead of taking them.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseWhile(array, predicate, isDrop, fromRight) {\n var length = array.length,\n index = fromRight ? length : -1;\n\n while ((fromRight ? index-- : ++index < length) &&\n predicate(array[index], index, array)) {}\n\n return isDrop\n ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length))\n : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index));\n }\n\n /**\n * The base implementation of `wrapperValue` which returns the result of\n * performing a sequence of actions on the unwrapped `value`, where each\n * successive action is supplied the return value of the previous.\n *\n * @private\n * @param {*} value The unwrapped value.\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\n * @returns {*} Returns the resolved value.\n */\n function baseWrapperValue(value, actions) {\n var result = value;\n if (result instanceof LazyWrapper) {\n result = result.value();\n }\n return arrayReduce(actions, function(result, action) {\n return action.func.apply(action.thisArg, arrayPush([result], action.args));\n }, result);\n }\n\n /**\n * The base implementation of methods like `_.xor`, without support for\n * iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of values.\n */\n function baseXor(arrays, iteratee, comparator) {\n var length = arrays.length;\n if (length < 2) {\n return length ? baseUniq(arrays[0]) : [];\n }\n var index = -1,\n result = Array(length);\n\n while (++index < length) {\n var array = arrays[index],\n othIndex = -1;\n\n while (++othIndex < length) {\n if (othIndex != index) {\n result[index] = baseDifference(result[index] || array, arrays[othIndex], iteratee, comparator);\n }\n }\n }\n return baseUniq(baseFlatten(result, 1), iteratee, comparator);\n }\n\n /**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\n function baseZipObject(props, values, assignFunc) {\n var index = -1,\n length = props.length,\n valsLength = values.length,\n result = {};\n\n while (++index < length) {\n var value = index < valsLength ? values[index] : undefined;\n assignFunc(result, props[index], value);\n }\n return result;\n }\n\n /**\n * Casts `value` to an empty array if it's not an array like object.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array|Object} Returns the cast array-like object.\n */\n function castArrayLikeObject(value) {\n return isArrayLikeObject(value) ? value : [];\n }\n\n /**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\n function castFunction(value) {\n return typeof value == 'function' ? value : identity;\n }\n\n /**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\n function castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n }\n\n /**\n * A `baseRest` alias which can be replaced with `identity` by module\n * replacement plugins.\n *\n * @private\n * @type {Function}\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n var castRest = baseRest;\n\n /**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\n function castSlice(array, start, end) {\n var length = array.length;\n end = end === undefined ? length : end;\n return (!start && end >= length) ? array : baseSlice(array, start, end);\n }\n\n /**\n * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout).\n *\n * @private\n * @param {number|Object} id The timer id or timeout object of the timer to clear.\n */\n var clearTimeout = ctxClearTimeout || function(id) {\n return root.clearTimeout(id);\n };\n\n /**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\n function cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n }\n\n /**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\n function cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n }\n\n /**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\n function cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n }\n\n /**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\n function cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n }\n\n /**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\n function cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n }\n\n /**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\n function cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n }\n\n /**\n * Compares values to sort them in ascending order.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {number} Returns the sort order indicator for `value`.\n */\n function compareAscending(value, other) {\n if (value !== other) {\n var valIsDefined = value !== undefined,\n valIsNull = value === null,\n valIsReflexive = value === value,\n valIsSymbol = isSymbol(value);\n\n var othIsDefined = other !== undefined,\n othIsNull = other === null,\n othIsReflexive = other === other,\n othIsSymbol = isSymbol(other);\n\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\n (valIsNull && othIsDefined && othIsReflexive) ||\n (!valIsDefined && othIsReflexive) ||\n !valIsReflexive) {\n return 1;\n }\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\n (othIsNull && valIsDefined && valIsReflexive) ||\n (!othIsDefined && valIsReflexive) ||\n !othIsReflexive) {\n return -1;\n }\n }\n return 0;\n }\n\n /**\n * Used by `_.orderBy` to compare multiple properties of a value to another\n * and stable sort them.\n *\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\n * of corresponding values.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {boolean[]|string[]} orders The order to sort by for each property.\n * @returns {number} Returns the sort order indicator for `object`.\n */\n function compareMultiple(object, other, orders) {\n var index = -1,\n objCriteria = object.criteria,\n othCriteria = other.criteria,\n length = objCriteria.length,\n ordersLength = orders.length;\n\n while (++index < length) {\n var result = compareAscending(objCriteria[index], othCriteria[index]);\n if (result) {\n if (index >= ordersLength) {\n return result;\n }\n var order = orders[index];\n return result * (order == 'desc' ? -1 : 1);\n }\n }\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\n // that causes it, under certain circumstances, to provide the same value for\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\n // for more details.\n //\n // This also ensures a stable sort in V8 and other engines.\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n return object.index - other.index;\n }\n\n /**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgs(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersLength = holders.length,\n leftIndex = -1,\n leftLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(leftLength + rangeLength),\n isUncurried = !isCurried;\n\n while (++leftIndex < leftLength) {\n result[leftIndex] = partials[leftIndex];\n }\n while (++argsIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[holders[argsIndex]] = args[argsIndex];\n }\n }\n while (rangeLength--) {\n result[leftIndex++] = args[argsIndex++];\n }\n return result;\n }\n\n /**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgsRight(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersIndex = -1,\n holdersLength = holders.length,\n rightIndex = -1,\n rightLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(rangeLength + rightLength),\n isUncurried = !isCurried;\n\n while (++argsIndex < rangeLength) {\n result[argsIndex] = args[argsIndex];\n }\n var offset = argsIndex;\n while (++rightIndex < rightLength) {\n result[offset + rightIndex] = partials[rightIndex];\n }\n while (++holdersIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[offset + holders[holdersIndex]] = args[argsIndex++];\n }\n }\n return result;\n }\n\n /**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\n function copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n }\n\n /**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\n function copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n }\n\n /**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\n function copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n }\n\n /**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\n function copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n }\n\n /**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\n function createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, getIteratee(iteratee, 2), accumulator);\n };\n }\n\n /**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\n function createAssigner(assigner) {\n return baseRest(function(object, sources) {\n var index = -1,\n length = sources.length,\n customizer = length > 1 ? sources[length - 1] : undefined,\n guard = length > 2 ? sources[2] : undefined;\n\n customizer = (assigner.length > 3 && typeof customizer == 'function')\n ? (length--, customizer)\n : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n customizer = length < 3 ? undefined : customizer;\n length = 1;\n }\n object = Object(object);\n while (++index < length) {\n var source = sources[index];\n if (source) {\n assigner(object, source, index, customizer);\n }\n }\n return object;\n });\n }\n\n /**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n function createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n }\n\n /**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n function createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the optional `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createBind(func, bitmask, thisArg) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return fn.apply(isBind ? thisArg : this, arguments);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.lowerFirst`.\n *\n * @private\n * @param {string} methodName The name of the `String` case method to use.\n * @returns {Function} Returns the new case function.\n */\n function createCaseFirst(methodName) {\n return function(string) {\n string = toString(string);\n\n var strSymbols = hasUnicode(string)\n ? stringToArray(string)\n : undefined;\n\n var chr = strSymbols\n ? strSymbols[0]\n : string.charAt(0);\n\n var trailing = strSymbols\n ? castSlice(strSymbols, 1).join('')\n : string.slice(1);\n\n return chr[methodName]() + trailing;\n };\n }\n\n /**\n * Creates a function like `_.camelCase`.\n *\n * @private\n * @param {Function} callback The function to combine each word.\n * @returns {Function} Returns the new compounder function.\n */\n function createCompounder(callback) {\n return function(string) {\n return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');\n };\n }\n\n /**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCtor(Ctor) {\n return function() {\n // Use a `switch` statement to work with class constructors. See\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n // for more details.\n var args = arguments;\n switch (args.length) {\n case 0: return new Ctor;\n case 1: return new Ctor(args[0]);\n case 2: return new Ctor(args[0], args[1]);\n case 3: return new Ctor(args[0], args[1], args[2]);\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n }\n var thisBinding = baseCreate(Ctor.prototype),\n result = Ctor.apply(thisBinding, args);\n\n // Mimic the constructor's `return` behavior.\n // See https://es5.github.io/#x13.2.2 for more details.\n return isObject(result) ? result : thisBinding;\n };\n }\n\n /**\n * Creates a function that wraps `func` to enable currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {number} arity The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCurry(func, bitmask, arity) {\n var Ctor = createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length,\n placeholder = getHolder(wrapper);\n\n while (index--) {\n args[index] = arguments[index];\n }\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\n ? []\n : replaceHolders(args, placeholder);\n\n length -= holders.length;\n if (length < arity) {\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\n args, holders, undefined, undefined, arity - length);\n }\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return apply(fn, this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\n function createFind(findIndexFunc) {\n return function(collection, predicate, fromIndex) {\n var iterable = Object(collection);\n if (!isArrayLike(collection)) {\n var iteratee = getIteratee(predicate, 3);\n collection = keys(collection);\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n }\n var index = findIndexFunc(collection, predicate, fromIndex);\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n };\n }\n\n /**\n * Creates a `_.flow` or `_.flowRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new flow function.\n */\n function createFlow(fromRight) {\n return flatRest(function(funcs) {\n var length = funcs.length,\n index = length,\n prereq = LodashWrapper.prototype.thru;\n\n if (fromRight) {\n funcs.reverse();\n }\n while (index--) {\n var func = funcs[index];\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (prereq && !wrapper && getFuncName(func) == 'wrapper') {\n var wrapper = new LodashWrapper([], true);\n }\n }\n index = wrapper ? index : length;\n while (++index < length) {\n func = funcs[index];\n\n var funcName = getFuncName(func),\n data = funcName == 'wrapper' ? getData(func) : undefined;\n\n if (data && isLaziable(data[0]) &&\n data[1] == (WRAP_ARY_FLAG | WRAP_CURRY_FLAG | WRAP_PARTIAL_FLAG | WRAP_REARG_FLAG) &&\n !data[4].length && data[9] == 1\n ) {\n wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]);\n } else {\n wrapper = (func.length == 1 && isLaziable(func))\n ? wrapper[funcName]()\n : wrapper.thru(func);\n }\n }\n return function() {\n var args = arguments,\n value = args[0];\n\n if (wrapper && args.length == 1 && isArray(value)) {\n return wrapper.plant(value).value();\n }\n var index = 0,\n result = length ? funcs[index].apply(this, args) : value;\n\n while (++index < length) {\n result = funcs[index].call(this, result);\n }\n return result;\n };\n });\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with optional `this`\n * binding of `thisArg`, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided\n * to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n var isAry = bitmask & WRAP_ARY_FLAG,\n isBind = bitmask & WRAP_BIND_FLAG,\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\n isFlip = bitmask & WRAP_FLIP_FLAG,\n Ctor = isBindKey ? undefined : createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length;\n\n while (index--) {\n args[index] = arguments[index];\n }\n if (isCurried) {\n var placeholder = getHolder(wrapper),\n holdersCount = countHolders(args, placeholder);\n }\n if (partials) {\n args = composeArgs(args, partials, holders, isCurried);\n }\n if (partialsRight) {\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\n }\n length -= holdersCount;\n if (isCurried && length < arity) {\n var newHolders = replaceHolders(args, placeholder);\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\n args, newHolders, argPos, ary, arity - length\n );\n }\n var thisBinding = isBind ? thisArg : this,\n fn = isBindKey ? thisBinding[func] : func;\n\n length = args.length;\n if (argPos) {\n args = reorder(args, argPos);\n } else if (isFlip && length > 1) {\n args.reverse();\n }\n if (isAry && ary < length) {\n args.length = ary;\n }\n if (this && this !== root && this instanceof wrapper) {\n fn = Ctor || createCtor(fn);\n }\n return fn.apply(thisBinding, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.invertBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} toIteratee The function to resolve iteratees.\n * @returns {Function} Returns the new inverter function.\n */\n function createInverter(setter, toIteratee) {\n return function(object, iteratee) {\n return baseInverter(object, setter, toIteratee(iteratee), {});\n };\n }\n\n /**\n * Creates a function that performs a mathematical operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @param {number} [defaultValue] The value used for `undefined` arguments.\n * @returns {Function} Returns the new mathematical operation function.\n */\n function createMathOperation(operator, defaultValue) {\n return function(value, other) {\n var result;\n if (value === undefined && other === undefined) {\n return defaultValue;\n }\n if (value !== undefined) {\n result = value;\n }\n if (other !== undefined) {\n if (result === undefined) {\n return other;\n }\n if (typeof value == 'string' || typeof other == 'string') {\n value = baseToString(value);\n other = baseToString(other);\n } else {\n value = baseToNumber(value);\n other = baseToNumber(other);\n }\n result = operator(value, other);\n }\n return result;\n };\n }\n\n /**\n * Creates a function like `_.over`.\n *\n * @private\n * @param {Function} arrayFunc The function to iterate over iteratees.\n * @returns {Function} Returns the new over function.\n */\n function createOver(arrayFunc) {\n return flatRest(function(iteratees) {\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n return baseRest(function(args) {\n var thisArg = this;\n return arrayFunc(iteratees, function(iteratee) {\n return apply(iteratee, thisArg, args);\n });\n });\n });\n }\n\n /**\n * Creates the padding for `string` based on `length`. The `chars` string\n * is truncated if the number of characters exceeds `length`.\n *\n * @private\n * @param {number} length The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padding for `string`.\n */\n function createPadding(length, chars) {\n chars = chars === undefined ? ' ' : baseToString(chars);\n\n var charsLength = chars.length;\n if (charsLength < 2) {\n return charsLength ? baseRepeat(chars, length) : chars;\n }\n var result = baseRepeat(chars, nativeCeil(length / stringSize(chars)));\n return hasUnicode(chars)\n ? castSlice(stringToArray(result), 0, length).join('')\n : result.slice(0, length);\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the `this` binding\n * of `thisArg` and `partials` prepended to the arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to\n * the new function.\n * @returns {Function} Returns the new wrapped function.\n */\n function createPartial(func, bitmask, thisArg, partials) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var argsIndex = -1,\n argsLength = arguments.length,\n leftIndex = -1,\n leftLength = partials.length,\n args = Array(leftLength + argsLength),\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n\n while (++leftIndex < leftLength) {\n args[leftIndex] = partials[leftIndex];\n }\n while (argsLength--) {\n args[leftIndex++] = arguments[++argsIndex];\n }\n return apply(fn, isBind ? thisArg : this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\n function createRange(fromRight) {\n return function(start, end, step) {\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n // Ensure the sign of `-0` is preserved.\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n return baseRange(start, end, step, fromRight);\n };\n }\n\n /**\n * Creates a function that performs a relational operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @returns {Function} Returns the new relational operation function.\n */\n function createRelationalOperation(operator) {\n return function(value, other) {\n if (!(typeof value == 'string' && typeof other == 'string')) {\n value = toNumber(value);\n other = toNumber(other);\n }\n return operator(value, other);\n };\n }\n\n /**\n * Creates a function that wraps `func` to continue currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {Function} wrapFunc The function to create the `func` wrapper.\n * @param {*} placeholder The placeholder value.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\n var isCurry = bitmask & WRAP_CURRY_FLAG,\n newHolders = isCurry ? holders : undefined,\n newHoldersRight = isCurry ? undefined : holders,\n newPartials = isCurry ? partials : undefined,\n newPartialsRight = isCurry ? undefined : partials;\n\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\n\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\n }\n var newData = [\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\n newHoldersRight, argPos, ary, arity\n ];\n\n var result = wrapFunc.apply(undefined, newData);\n if (isLaziable(func)) {\n setData(result, newData);\n }\n result.placeholder = placeholder;\n return setWrapToString(result, func, bitmask);\n }\n\n /**\n * Creates a function like `_.round`.\n *\n * @private\n * @param {string} methodName The name of the `Math` method to use when rounding.\n * @returns {Function} Returns the new round function.\n */\n function createRound(methodName) {\n var func = Math[methodName];\n return function(number, precision) {\n number = toNumber(number);\n precision = precision == null ? 0 : nativeMin(toInteger(precision), 292);\n if (precision && nativeIsFinite(number)) {\n // Shift with exponential notation to avoid floating-point issues.\n // See [MDN](https://mdn.io/round#Examples) for more details.\n var pair = (toString(number) + 'e').split('e'),\n value = func(pair[0] + 'e' + (+pair[1] + precision));\n\n pair = (toString(value) + 'e').split('e');\n return +(pair[0] + 'e' + (+pair[1] - precision));\n }\n return func(number);\n };\n }\n\n /**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\n var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n };\n\n /**\n * Creates a `_.toPairs` or `_.toPairsIn` function.\n *\n * @private\n * @param {Function} keysFunc The function to get the keys of a given object.\n * @returns {Function} Returns the new pairs function.\n */\n function createToPairs(keysFunc) {\n return function(object) {\n var tag = getTag(object);\n if (tag == mapTag) {\n return mapToArray(object);\n }\n if (tag == setTag) {\n return setToPairs(object);\n }\n return baseToPairs(object, keysFunc(object));\n };\n }\n\n /**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags.\n * 1 - `_.bind`\n * 2 - `_.bindKey`\n * 4 - `_.curry` or `_.curryRight` of a bound function\n * 8 - `_.curry`\n * 16 - `_.curryRight`\n * 32 - `_.partial`\n * 64 - `_.partialRight`\n * 128 - `_.rearg`\n * 256 - `_.ary`\n * 512 - `_.flip`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\n if (!isBindKey && typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var length = partials ? partials.length : 0;\n if (!length) {\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\n partials = holders = undefined;\n }\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\n arity = arity === undefined ? arity : toInteger(arity);\n length -= holders ? holders.length : 0;\n\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\n var partialsRight = partials,\n holdersRight = holders;\n\n partials = holders = undefined;\n }\n var data = isBindKey ? undefined : getData(func);\n\n var newData = [\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\n argPos, ary, arity\n ];\n\n if (data) {\n mergeData(newData, data);\n }\n func = newData[0];\n bitmask = newData[1];\n thisArg = newData[2];\n partials = newData[3];\n holders = newData[4];\n arity = newData[9] = newData[9] === undefined\n ? (isBindKey ? 0 : func.length)\n : nativeMax(newData[9] - length, 0);\n\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\n }\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\n var result = createBind(func, bitmask, thisArg);\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\n result = createCurry(func, bitmask, arity);\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\n result = createPartial(func, bitmask, thisArg, partials);\n } else {\n result = createHybrid.apply(undefined, newData);\n }\n var setter = data ? baseSetData : setData;\n return setWrapToString(setter(result, newData), func, bitmask);\n }\n\n /**\n * Used by `_.defaults` to customize its `_.assignIn` use to assign properties\n * of source objects to the destination object for all destination properties\n * that resolve to `undefined`.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to assign.\n * @param {Object} object The parent object of `objValue`.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsAssignIn(objValue, srcValue, key, object) {\n if (objValue === undefined ||\n (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n return srcValue;\n }\n return objValue;\n }\n\n /**\n * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source\n * objects into destination objects that are passed thru.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to merge.\n * @param {Object} object The parent object of `objValue`.\n * @param {Object} source The parent object of `srcValue`.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {\n if (isObject(objValue) && isObject(srcValue)) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, objValue);\n baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);\n stack['delete'](srcValue);\n }\n return objValue;\n }\n\n /**\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\n * objects.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {string} key The key of the property to inspect.\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\n */\n function customOmitClone(value) {\n return isPlainObject(value) ? undefined : value;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\n function equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n }\n\n /**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n function flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n }\n\n /**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n }\n\n /**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n }\n\n /**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\n var getData = !metaMap ? noop : function(func) {\n return metaMap.get(func);\n };\n\n /**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\n function getFuncName(func) {\n var result = (func.name + ''),\n array = realNames[result],\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\n\n while (length--) {\n var data = array[length],\n otherFunc = data.func;\n if (otherFunc == null || otherFunc == func) {\n return data.name;\n }\n }\n return result;\n }\n\n /**\n * Gets the argument placeholder value for `func`.\n *\n * @private\n * @param {Function} func The function to inspect.\n * @returns {*} Returns the placeholder value.\n */\n function getHolder(func) {\n var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func;\n return object.placeholder;\n }\n\n /**\n * Gets the appropriate \"iteratee\" function. If `_.iteratee` is customized,\n * this function returns the custom method, otherwise it returns `baseIteratee`.\n * If arguments are provided, the chosen function is invoked with them and\n * its result is returned.\n *\n * @private\n * @param {*} [value] The value to convert to an iteratee.\n * @param {number} [arity] The arity of the created iteratee.\n * @returns {Function} Returns the chosen function or its result.\n */\n function getIteratee() {\n var result = lodash.iteratee || iteratee;\n result = result === iteratee ? baseIteratee : result;\n return arguments.length ? result(arguments[0], arguments[1]) : result;\n }\n\n /**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\n function getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n }\n\n /**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\n function getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n }\n\n /**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\n function getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n }\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 */\n function 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 /**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\n var getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n };\n\n /**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\n var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n };\n\n /**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\n var getTag = baseGetTag;\n\n // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\n if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n }\n\n /**\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\n *\n * @private\n * @param {number} start The start of the view.\n * @param {number} end The end of the view.\n * @param {Array} transforms The transformations to apply to the view.\n * @returns {Object} Returns an object containing the `start` and `end`\n * positions of the view.\n */\n function getView(start, end, transforms) {\n var index = -1,\n length = transforms.length;\n\n while (++index < length) {\n var data = transforms[index],\n size = data.size;\n\n switch (data.type) {\n case 'drop': start += size; break;\n case 'dropRight': end -= size; break;\n case 'take': end = nativeMin(end, start + size); break;\n case 'takeRight': start = nativeMax(start, end - size); break;\n }\n }\n return { 'start': start, 'end': end };\n }\n\n /**\n * Extracts wrapper details from the `source` body comment.\n *\n * @private\n * @param {string} source The source to inspect.\n * @returns {Array} Returns the wrapper details.\n */\n function getWrapDetails(source) {\n var match = source.match(reWrapDetails);\n return match ? match[1].split(reSplitDetails) : [];\n }\n\n /**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\n function hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n }\n\n /**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\n function initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n }\n\n /**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\n function initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n }\n\n /**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\n function initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n }\n\n /**\n * Inserts wrapper `details` in a comment at the top of the `source` body.\n *\n * @private\n * @param {string} source The source to modify.\n * @returns {Array} details The details to insert.\n * @returns {string} Returns the modified source.\n */\n function insertWrapDetails(source, details) {\n var length = details.length;\n if (!length) {\n return source;\n }\n var lastIndex = length - 1;\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\n details = details.join(length > 2 ? ', ' : ' ');\n return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\n }\n\n /**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\n function isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n }\n\n /**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\n function isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n }\n\n /**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\n function isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n }\n\n /**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\n function isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n }\n\n /**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\n function isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n }\n\n /**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\n * else `false`.\n */\n function isLaziable(func) {\n var funcName = getFuncName(func),\n other = lodash[funcName];\n\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n return false;\n }\n if (func === other) {\n return true;\n }\n var data = getData(other);\n return !!data && func === data[0];\n }\n\n /**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\n function isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n }\n\n /**\n * Checks if `func` is capable of being masked.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `func` is maskable, else `false`.\n */\n var isMaskable = coreJsData ? isFunction : stubFalse;\n\n /**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\n function isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n }\n\n /**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\n function isStrictComparable(value) {\n return value === value && !isObject(value);\n }\n\n /**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\n function matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n }\n\n /**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\n function memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n }\n\n /**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers used to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and\n * `_.rearg` modify function arguments, making the order in which they are\n * executed important, preventing the merging of metadata. However, we make\n * an exception for a safe combined case where curried functions have `_.ary`\n * and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\n function mergeData(data, source) {\n var bitmask = data[1],\n srcBitmask = source[1],\n newBitmask = bitmask | srcBitmask,\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\n\n var isCombo =\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\n\n // Exit early if metadata can't be merged.\n if (!(isCommon || isCombo)) {\n return data;\n }\n // Use source `thisArg` if available.\n if (srcBitmask & WRAP_BIND_FLAG) {\n data[2] = source[2];\n // Set when currying a bound function.\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\n }\n // Compose partial arguments.\n var value = source[3];\n if (value) {\n var partials = data[3];\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\n }\n // Compose partial right arguments.\n value = source[5];\n if (value) {\n partials = data[5];\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\n }\n // Use source `argPos` if available.\n value = source[7];\n if (value) {\n data[7] = value;\n }\n // Use source `ary` if it's smaller.\n if (srcBitmask & WRAP_ARY_FLAG) {\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n }\n // Use source `arity` if one is not provided.\n if (data[9] == null) {\n data[9] = source[9];\n }\n // Use source `func` and merge bitmasks.\n data[0] = source[0];\n data[1] = newBitmask;\n\n return data;\n }\n\n /**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n }\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 */\n function objectToString(value) {\n return nativeObjectToString.call(value);\n }\n\n /**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\n function overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n }\n\n /**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\n function parent(object, path) {\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n }\n\n /**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\n function reorder(array, indexes) {\n var arrLength = array.length,\n length = nativeMin(indexes.length, arrLength),\n oldArray = copyArray(array);\n\n while (length--) {\n var index = indexes[length];\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n }\n return array;\n }\n\n /**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\n function safeGet(object, key) {\n if (key === 'constructor' && typeof object[key] === 'function') {\n return;\n }\n\n if (key == '__proto__') {\n return;\n }\n\n return object[key];\n }\n\n /**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity\n * function to avoid garbage collection pauses in V8. See\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var setData = shortOut(baseSetData);\n\n /**\n * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout).\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n var setTimeout = ctxSetTimeout || function(func, wait) {\n return root.setTimeout(func, wait);\n };\n\n /**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\n var setToString = shortOut(baseSetToString);\n\n /**\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\n * with wrapper details in a comment at the top of the source body.\n *\n * @private\n * @param {Function} wrapper The function to modify.\n * @param {Function} reference The reference function.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Function} Returns `wrapper`.\n */\n function setWrapToString(wrapper, reference, bitmask) {\n var source = (reference + '');\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\n }\n\n /**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\n function shortOut(func) {\n var count = 0,\n lastCalled = 0;\n\n return function() {\n var stamp = nativeNow(),\n remaining = HOT_SPAN - (stamp - lastCalled);\n\n lastCalled = stamp;\n if (remaining > 0) {\n if (++count >= HOT_COUNT) {\n return arguments[0];\n }\n } else {\n count = 0;\n }\n return func.apply(undefined, arguments);\n };\n }\n\n /**\n * A specialized version of `_.shuffle` which mutates and sets the size of `array`.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @param {number} [size=array.length] The size of `array`.\n * @returns {Array} Returns `array`.\n */\n function shuffleSelf(array, size) {\n var index = -1,\n length = array.length,\n lastIndex = length - 1;\n\n size = size === undefined ? length : size;\n while (++index < size) {\n var rand = baseRandom(index, lastIndex),\n value = array[rand];\n\n array[rand] = array[index];\n array[index] = value;\n }\n array.length = size;\n return array;\n }\n\n /**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\n var stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n });\n\n /**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\n function toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n }\n\n /**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\n function toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n }\n\n /**\n * Updates wrapper `details` based on `bitmask` flags.\n *\n * @private\n * @returns {Array} details The details to modify.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Array} Returns `details`.\n */\n function updateWrapDetails(details, bitmask) {\n arrayEach(wrapFlags, function(pair) {\n var value = '_.' + pair[0];\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\n details.push(value);\n }\n });\n return details.sort();\n }\n\n /**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\n function wrapperClone(wrapper) {\n if (wrapper instanceof LazyWrapper) {\n return wrapper.clone();\n }\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\n result.__actions__ = copyArray(wrapper.__actions__);\n result.__index__ = wrapper.__index__;\n result.__values__ = wrapper.__values__;\n return result;\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\n function chunk(array, size, guard) {\n if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n size = 1;\n } else {\n size = nativeMax(toInteger(size), 0);\n }\n var length = array == null ? 0 : array.length;\n if (!length || size < 1) {\n return [];\n }\n var index = 0,\n resIndex = 0,\n result = Array(nativeCeil(length / size));\n\n while (index < length) {\n result[resIndex++] = baseSlice(array, index, (index += size));\n }\n return result;\n }\n\n /**\n * Creates an array with all falsey values removed. The values `false`, `null`,\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to compact.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.compact([0, 1, false, 2, '', 3]);\n * // => [1, 2, 3]\n */\n function compact(array) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * Creates a new array concatenating `array` with any additional arrays\n * and/or values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to concatenate.\n * @param {...*} [values] The values to concatenate.\n * @returns {Array} Returns the new concatenated array.\n * @example\n *\n * var array = [1];\n * var other = _.concat(array, 2, [3], [[4]]);\n *\n * console.log(other);\n * // => [1, 2, 3, [4]]\n *\n * console.log(array);\n * // => [1]\n */\n function concat() {\n var length = arguments.length;\n if (!length) {\n return [];\n }\n var args = Array(length - 1),\n array = arguments[0],\n index = length;\n\n while (index--) {\n args[index - 1] = arguments[index];\n }\n return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\n }\n\n /**\n * Creates an array of `array` values not included in the other given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.without, _.xor\n * @example\n *\n * _.difference([2, 1], [2, 3]);\n * // => [1]\n */\n var difference = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `iteratee` which\n * is invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * **Note:** Unlike `_.pullAllBy`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var differenceBy = baseRest(function(array, values) {\n var iteratee = last(values);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `comparator`\n * which is invoked to compare elements of `array` to `values`. The order and\n * references of result values are determined by the first array. The comparator\n * is invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.pullAllWith`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n *\n * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }]\n */\n var differenceWith = baseRest(function(array, values) {\n var comparator = last(values);\n if (isArrayLikeObject(comparator)) {\n comparator = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator)\n : [];\n });\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.drop([1, 2, 3]);\n * // => [2, 3]\n *\n * _.drop([1, 2, 3], 2);\n * // => [3]\n *\n * _.drop([1, 2, 3], 5);\n * // => []\n *\n * _.drop([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function drop(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.dropRight([1, 2, 3]);\n * // => [1, 2]\n *\n * _.dropRight([1, 2, 3], 2);\n * // => [1]\n *\n * _.dropRight([1, 2, 3], 5);\n * // => []\n *\n * _.dropRight([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function dropRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the end.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.dropRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropRightWhile(users, ['active', false]);\n * // => objects for ['barney']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropRightWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the beginning.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.dropWhile(users, function(o) { return !o.active; });\n * // => objects for ['pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropWhile(users, ['active', false]);\n * // => objects for ['pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true)\n : [];\n }\n\n /**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\n function fill(array, value, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n start = 0;\n end = length;\n }\n return baseFill(array, value, start, end);\n }\n\n /**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\n function findIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index);\n }\n\n /**\n * This method is like `_.findIndex` except that it iterates over elements\n * of `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\n * // => 2\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\n * // => 0\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastIndex(users, ['active', false]);\n * // => 2\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastIndex(users, 'active');\n * // => 0\n */\n function findLastIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length - 1;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = fromIndex < 0\n ? nativeMax(length + index, 0)\n : nativeMin(index, length - 1);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index, true);\n }\n\n /**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\n function flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n }\n\n /**\n * Recursively flattens `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\n * // => [1, 2, 3, 4, 5]\n */\n function flattenDeep(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, INFINITY) : [];\n }\n\n /**\n * Recursively flatten `array` up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * var array = [1, [2, [3, [4]], 5]];\n *\n * _.flattenDepth(array, 1);\n * // => [1, 2, [3, [4]], 5]\n *\n * _.flattenDepth(array, 2);\n * // => [1, 2, 3, [4], 5]\n */\n function flattenDepth(array, depth) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(array, depth);\n }\n\n /**\n * The inverse of `_.toPairs`; this method returns an object composed\n * from key-value `pairs`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} pairs The key-value pairs.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.fromPairs([['a', 1], ['b', 2]]);\n * // => { 'a': 1, 'b': 2 }\n */\n function fromPairs(pairs) {\n var index = -1,\n length = pairs == null ? 0 : pairs.length,\n result = {};\n\n while (++index < length) {\n var pair = pairs[index];\n result[pair[0]] = pair[1];\n }\n return result;\n }\n\n /**\n * Gets the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias first\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the first element of `array`.\n * @example\n *\n * _.head([1, 2, 3]);\n * // => 1\n *\n * _.head([]);\n * // => undefined\n */\n function head(array) {\n return (array && array.length) ? array[0] : undefined;\n }\n\n /**\n * Gets the index at which the first occurrence of `value` is found in `array`\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the\n * offset from the end of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.indexOf([1, 2, 1, 2], 2);\n * // => 1\n *\n * // Search from the `fromIndex`.\n * _.indexOf([1, 2, 1, 2], 2, 2);\n * // => 3\n */\n function indexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseIndexOf(array, value, index);\n }\n\n /**\n * Gets all but the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.initial([1, 2, 3]);\n * // => [1, 2]\n */\n function initial(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 0, -1) : [];\n }\n\n /**\n * Creates an array of unique values that are included in all given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersection([2, 1], [2, 3]);\n * // => [2]\n */\n var intersection = baseRest(function(arrays) {\n var mapped = arrayMap(arrays, castArrayLikeObject);\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped)\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `iteratee`\n * which is invoked for each element of each `arrays` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [2.1]\n *\n * // The `_.property` iteratee shorthand.\n * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }]\n */\n var intersectionBy = baseRest(function(arrays) {\n var iteratee = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n if (iteratee === last(mapped)) {\n iteratee = undefined;\n } else {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `comparator`\n * which is invoked to compare elements of `arrays`. The order and references\n * of result values are determined by the first array. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.intersectionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }]\n */\n var intersectionWith = baseRest(function(arrays) {\n var comparator = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n comparator = typeof comparator == 'function' ? comparator : undefined;\n if (comparator) {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, undefined, comparator)\n : [];\n });\n\n /**\n * Converts all elements in `array` into a string separated by `separator`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to convert.\n * @param {string} [separator=','] The element separator.\n * @returns {string} Returns the joined string.\n * @example\n *\n * _.join(['a', 'b', 'c'], '~');\n * // => 'a~b~c'\n */\n function join(array, separator) {\n return array == null ? '' : nativeJoin.call(array, separator);\n }\n\n /**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\n function last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n }\n\n /**\n * This method is like `_.indexOf` except that it iterates over elements of\n * `array` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.lastIndexOf([1, 2, 1, 2], 2);\n * // => 3\n *\n * // Search from the `fromIndex`.\n * _.lastIndexOf([1, 2, 1, 2], 2, 2);\n * // => 1\n */\n function lastIndexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1);\n }\n return value === value\n ? strictLastIndexOf(array, value, index)\n : baseFindIndex(array, baseIsNaN, index, true);\n }\n\n /**\n * Gets the element at index `n` of `array`. If `n` is negative, the nth\n * element from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.11.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=0] The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n *\n * _.nth(array, 1);\n * // => 'b'\n *\n * _.nth(array, -2);\n * // => 'c';\n */\n function nth(array, n) {\n return (array && array.length) ? baseNth(array, toInteger(n)) : undefined;\n }\n\n /**\n * Removes all given values from `array` using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove`\n * to remove elements from an array by predicate.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...*} [values] The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pull(array, 'a', 'c');\n * console.log(array);\n * // => ['b', 'b']\n */\n var pull = baseRest(pullAll);\n\n /**\n * This method is like `_.pull` except that it accepts an array of values to remove.\n *\n * **Note:** Unlike `_.difference`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pullAll(array, ['a', 'c']);\n * console.log(array);\n * // => ['b', 'b']\n */\n function pullAll(array, values) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values)\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `iteratee` which is\n * invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The iteratee is invoked with one argument: (value).\n *\n * **Note:** Unlike `_.differenceBy`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }];\n *\n * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x');\n * console.log(array);\n * // => [{ 'x': 2 }]\n */\n function pullAllBy(array, values, iteratee) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, getIteratee(iteratee, 2))\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `comparator` which\n * is invoked to compare elements of `array` to `values`. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.differenceWith`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];\n *\n * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);\n * console.log(array);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]\n */\n function pullAllWith(array, values, comparator) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, undefined, comparator)\n : array;\n }\n\n /**\n * Removes elements from `array` corresponding to `indexes` and returns an\n * array of removed elements.\n *\n * **Note:** Unlike `_.at`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...(number|number[])} [indexes] The indexes of elements to remove.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n * var pulled = _.pullAt(array, [1, 3]);\n *\n * console.log(array);\n * // => ['a', 'c']\n *\n * console.log(pulled);\n * // => ['b', 'd']\n */\n var pullAt = flatRest(function(array, indexes) {\n var length = array == null ? 0 : array.length,\n result = baseAt(array, indexes);\n\n basePullAt(array, arrayMap(indexes, function(index) {\n return isIndex(index, length) ? +index : index;\n }).sort(compareAscending));\n\n return result;\n });\n\n /**\n * Removes all elements from `array` that `predicate` returns truthy for\n * and returns an array of the removed elements. The predicate is invoked\n * with three arguments: (value, index, array).\n *\n * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull`\n * to pull elements from an array by value.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = [1, 2, 3, 4];\n * var evens = _.remove(array, function(n) {\n * return n % 2 == 0;\n * });\n *\n * console.log(array);\n * // => [1, 3]\n *\n * console.log(evens);\n * // => [2, 4]\n */\n function remove(array, predicate) {\n var result = [];\n if (!(array && array.length)) {\n return result;\n }\n var index = -1,\n indexes = [],\n length = array.length;\n\n predicate = getIteratee(predicate, 3);\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result.push(value);\n indexes.push(index);\n }\n }\n basePullAt(array, indexes);\n return result;\n }\n\n /**\n * Reverses `array` so that the first element becomes the last, the second\n * element becomes the second to last, and so on.\n *\n * **Note:** This method mutates `array` and is based on\n * [`Array#reverse`](https://mdn.io/Array/reverse).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.reverse(array);\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function reverse(array) {\n return array == null ? array : nativeReverse.call(array);\n }\n\n /**\n * Creates a slice of `array` from `start` up to, but not including, `end`.\n *\n * **Note:** This method is used instead of\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\n * returned.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function slice(array, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\n start = 0;\n end = length;\n }\n else {\n start = start == null ? 0 : toInteger(start);\n end = end === undefined ? length : toInteger(end);\n }\n return baseSlice(array, start, end);\n }\n\n /**\n * Uses a binary search to determine the lowest index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedIndex([30, 50], 40);\n * // => 1\n */\n function sortedIndex(array, value) {\n return baseSortedIndex(array, value);\n }\n\n /**\n * This method is like `_.sortedIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedIndexBy(objects, { 'x': 4 }, 'x');\n * // => 0\n */\n function sortedIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2));\n }\n\n /**\n * This method is like `_.indexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedIndexOf([4, 5, 5, 5, 6], 5);\n * // => 1\n */\n function sortedIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value);\n if (index < length && eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.sortedIndex` except that it returns the highest\n * index at which `value` should be inserted into `array` in order to\n * maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedLastIndex([4, 5, 5, 5, 6], 5);\n * // => 4\n */\n function sortedLastIndex(array, value) {\n return baseSortedIndex(array, value, true);\n }\n\n /**\n * This method is like `_.sortedLastIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 1\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x');\n * // => 1\n */\n function sortedLastIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2), true);\n }\n\n /**\n * This method is like `_.lastIndexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5);\n * // => 3\n */\n function sortedLastIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value, true) - 1;\n if (eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.uniq` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniq([1, 1, 2]);\n * // => [1, 2]\n */\n function sortedUniq(array) {\n return (array && array.length)\n ? baseSortedUniq(array)\n : [];\n }\n\n /**\n * This method is like `_.uniqBy` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor);\n * // => [1.1, 2.3]\n */\n function sortedUniqBy(array, iteratee) {\n return (array && array.length)\n ? baseSortedUniq(array, getIteratee(iteratee, 2))\n : [];\n }\n\n /**\n * Gets all but the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.tail([1, 2, 3]);\n * // => [2, 3]\n */\n function tail(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 1, length) : [];\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.take([1, 2, 3]);\n * // => [1]\n *\n * _.take([1, 2, 3], 2);\n * // => [1, 2]\n *\n * _.take([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.take([1, 2, 3], 0);\n * // => []\n */\n function take(array, n, guard) {\n if (!(array && array.length)) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.takeRight([1, 2, 3]);\n * // => [3]\n *\n * _.takeRight([1, 2, 3], 2);\n * // => [2, 3]\n *\n * _.takeRight([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.takeRight([1, 2, 3], 0);\n * // => []\n */\n function takeRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with elements taken from the end. Elements are\n * taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.takeRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeRightWhile(users, ['active', false]);\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeRightWhile(users, 'active');\n * // => []\n */\n function takeRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), false, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` with elements taken from the beginning. Elements\n * are taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.takeWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeWhile(users, ['active', false]);\n * // => objects for ['barney', 'fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeWhile(users, 'active');\n * // => []\n */\n function takeWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3))\n : [];\n }\n\n /**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\n var union = baseRest(function(arrays) {\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n });\n\n /**\n * This method is like `_.union` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which uniqueness is computed. Result values are chosen from the first\n * array in which the value occurs. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.unionBy([2.1], [1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n var unionBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.union` except that it accepts `comparator` which\n * is invoked to compare elements of `arrays`. Result values are chosen from\n * the first array in which the value occurs. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.unionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var unionWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator);\n });\n\n /**\n * Creates a duplicate-free version of an array, using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons, in which only the first occurrence of each element\n * is kept. The order of result values is determined by the order they occur\n * in the array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniq([2, 1, 2]);\n * // => [2, 1]\n */\n function uniq(array) {\n return (array && array.length) ? baseUniq(array) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * uniqueness is computed. The order of result values is determined by the\n * order they occur in the array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n function uniqBy(array, iteratee) {\n return (array && array.length) ? baseUniq(array, getIteratee(iteratee, 2)) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `comparator` which\n * is invoked to compare elements of `array`. The order of result values is\n * determined by the order they occur in the array.The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.uniqWith(objects, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]\n */\n function uniqWith(array, comparator) {\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return (array && array.length) ? baseUniq(array, undefined, comparator) : [];\n }\n\n /**\n * This method is like `_.zip` except that it accepts an array of grouped\n * elements and creates an array regrouping the elements to their pre-zip\n * configuration.\n *\n * @static\n * @memberOf _\n * @since 1.2.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n *\n * _.unzip(zipped);\n * // => [['a', 'b'], [1, 2], [true, false]]\n */\n function unzip(array) {\n if (!(array && array.length)) {\n return [];\n }\n var length = 0;\n array = arrayFilter(array, function(group) {\n if (isArrayLikeObject(group)) {\n length = nativeMax(group.length, length);\n return true;\n }\n });\n return baseTimes(length, function(index) {\n return arrayMap(array, baseProperty(index));\n });\n }\n\n /**\n * This method is like `_.unzip` except that it accepts `iteratee` to specify\n * how regrouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * regrouped values.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip([1, 2], [10, 20], [100, 200]);\n * // => [[1, 10, 100], [2, 20, 200]]\n *\n * _.unzipWith(zipped, _.add);\n * // => [3, 30, 300]\n */\n function unzipWith(array, iteratee) {\n if (!(array && array.length)) {\n return [];\n }\n var result = unzip(array);\n if (iteratee == null) {\n return result;\n }\n return arrayMap(result, function(group) {\n return apply(iteratee, undefined, group);\n });\n }\n\n /**\n * Creates an array excluding all given values using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.pull`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...*} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.xor\n * @example\n *\n * _.without([2, 1, 2, 3], 1, 2);\n * // => [3]\n */\n var without = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, values)\n : [];\n });\n\n /**\n * Creates an array of unique values that is the\n * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference)\n * of the given arrays. The order of result values is determined by the order\n * they occur in the arrays.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.without\n * @example\n *\n * _.xor([2, 1], [2, 3]);\n * // => [1, 3]\n */\n var xor = baseRest(function(arrays) {\n return baseXor(arrayFilter(arrays, isArrayLikeObject));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which by which they're compared. The order of result values is determined\n * by the order they occur in the arrays. The iteratee is invoked with one\n * argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2, 3.4]\n *\n * // The `_.property` iteratee shorthand.\n * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var xorBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseXor(arrayFilter(arrays, isArrayLikeObject), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `comparator` which is\n * invoked to compare elements of `arrays`. The order of result values is\n * determined by the order they occur in the arrays. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.xorWith(objects, others, _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var xorWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator);\n });\n\n /**\n * Creates an array of grouped elements, the first of which contains the\n * first elements of the given arrays, the second of which contains the\n * second elements of the given arrays, and so on.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n */\n var zip = baseRest(unzip);\n\n /**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\n function zipObject(props, values) {\n return baseZipObject(props || [], values || [], assignValue);\n }\n\n /**\n * This method is like `_.zipObject` except that it supports property paths.\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]);\n * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } }\n */\n function zipObjectDeep(props, values) {\n return baseZipObject(props || [], values || [], baseSet);\n }\n\n /**\n * This method is like `_.zip` except that it accepts `iteratee` to specify\n * how grouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * grouped values.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) {\n * return a + b + c;\n * });\n * // => [111, 222]\n */\n var zipWith = baseRest(function(arrays) {\n var length = arrays.length,\n iteratee = length > 1 ? arrays[length - 1] : undefined;\n\n iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined;\n return unzipWith(arrays, iteratee);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\n * chain sequences enabled. The result of such sequences must be unwrapped\n * with `_#value`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Seq\n * @param {*} value The value to wrap.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'pebbles', 'age': 1 }\n * ];\n *\n * var youngest = _\n * .chain(users)\n * .sortBy('age')\n * .map(function(o) {\n * return o.user + ' is ' + o.age;\n * })\n * .head()\n * .value();\n * // => 'pebbles is 1'\n */\n function chain(value) {\n var result = lodash(value);\n result.__chain__ = true;\n return result;\n }\n\n /**\n * This method invokes `interceptor` and returns `value`. The interceptor\n * is invoked with one argument; (value). The purpose of this method is to\n * \"tap into\" a method chain sequence in order to modify intermediate results.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns `value`.\n * @example\n *\n * _([1, 2, 3])\n * .tap(function(array) {\n * // Mutate input array.\n * array.pop();\n * })\n * .reverse()\n * .value();\n * // => [2, 1]\n */\n function tap(value, interceptor) {\n interceptor(value);\n return value;\n }\n\n /**\n * This method is like `_.tap` except that it returns the result of `interceptor`.\n * The purpose of this method is to \"pass thru\" values replacing intermediate\n * results in a method chain sequence.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns the result of `interceptor`.\n * @example\n *\n * _(' abc ')\n * .chain()\n * .trim()\n * .thru(function(value) {\n * return [value];\n * })\n * .value();\n * // => ['abc']\n */\n function thru(value, interceptor) {\n return interceptor(value);\n }\n\n /**\n * This method is the wrapper version of `_.at`.\n *\n * @name at\n * @memberOf _\n * @since 1.0.0\n * @category Seq\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _(object).at(['a[0].b.c', 'a[1]']).value();\n * // => [3, 4]\n */\n var wrapperAt = flatRest(function(paths) {\n var length = paths.length,\n start = length ? paths[0] : 0,\n value = this.__wrapped__,\n interceptor = function(object) { return baseAt(object, paths); };\n\n if (length > 1 || this.__actions__.length ||\n !(value instanceof LazyWrapper) || !isIndex(start)) {\n return this.thru(interceptor);\n }\n value = value.slice(start, +start + (length ? 1 : 0));\n value.__actions__.push({\n 'func': thru,\n 'args': [interceptor],\n 'thisArg': undefined\n });\n return new LodashWrapper(value, this.__chain__).thru(function(array) {\n if (length && !array.length) {\n array.push(undefined);\n }\n return array;\n });\n });\n\n /**\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\n *\n * @name chain\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 }\n * ];\n *\n * // A sequence without explicit chaining.\n * _(users).head();\n * // => { 'user': 'barney', 'age': 36 }\n *\n * // A sequence with explicit chaining.\n * _(users)\n * .chain()\n * .head()\n * .pick('user')\n * .value();\n * // => { 'user': 'barney' }\n */\n function wrapperChain() {\n return chain(this);\n }\n\n /**\n * Executes the chain sequence and returns the wrapped result.\n *\n * @name commit\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2];\n * var wrapped = _(array).push(3);\n *\n * console.log(array);\n * // => [1, 2]\n *\n * wrapped = wrapped.commit();\n * console.log(array);\n * // => [1, 2, 3]\n *\n * wrapped.last();\n * // => 3\n *\n * console.log(array);\n * // => [1, 2, 3]\n */\n function wrapperCommit() {\n return new LodashWrapper(this.value(), this.__chain__);\n }\n\n /**\n * Gets the next value on a wrapped object following the\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\n *\n * @name next\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the next iterator value.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 1 }\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 2 }\n *\n * wrapped.next();\n * // => { 'done': true, 'value': undefined }\n */\n function wrapperNext() {\n if (this.__values__ === undefined) {\n this.__values__ = toArray(this.value());\n }\n var done = this.__index__ >= this.__values__.length,\n value = done ? undefined : this.__values__[this.__index__++];\n\n return { 'done': done, 'value': value };\n }\n\n /**\n * Enables the wrapper to be iterable.\n *\n * @name Symbol.iterator\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the wrapper object.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped[Symbol.iterator]() === wrapped;\n * // => true\n *\n * Array.from(wrapped);\n * // => [1, 2]\n */\n function wrapperToIterator() {\n return this;\n }\n\n /**\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\n *\n * @name plant\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @param {*} value The value to plant.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2]).map(square);\n * var other = wrapped.plant([3, 4]);\n *\n * other.value();\n * // => [9, 16]\n *\n * wrapped.value();\n * // => [1, 4]\n */\n function wrapperPlant(value) {\n var result,\n parent = this;\n\n while (parent instanceof baseLodash) {\n var clone = wrapperClone(parent);\n clone.__index__ = 0;\n clone.__values__ = undefined;\n if (result) {\n previous.__wrapped__ = clone;\n } else {\n result = clone;\n }\n var previous = clone;\n parent = parent.__wrapped__;\n }\n previous.__wrapped__ = value;\n return result;\n }\n\n /**\n * This method is the wrapper version of `_.reverse`.\n *\n * **Note:** This method mutates the wrapped array.\n *\n * @name reverse\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _(array).reverse().value()\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function wrapperReverse() {\n var value = this.__wrapped__;\n if (value instanceof LazyWrapper) {\n var wrapped = value;\n if (this.__actions__.length) {\n wrapped = new LazyWrapper(this);\n }\n wrapped = wrapped.reverse();\n wrapped.__actions__.push({\n 'func': thru,\n 'args': [reverse],\n 'thisArg': undefined\n });\n return new LodashWrapper(wrapped, this.__chain__);\n }\n return this.thru(reverse);\n }\n\n /**\n * Executes the chain sequence to resolve the unwrapped value.\n *\n * @name value\n * @memberOf _\n * @since 0.1.0\n * @alias toJSON, valueOf\n * @category Seq\n * @returns {*} Returns the resolved unwrapped value.\n * @example\n *\n * _([1, 2, 3]).value();\n * // => [1, 2, 3]\n */\n function wrapperValue() {\n return baseWrapperValue(this.__wrapped__, this.__actions__);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the number of times the key was returned by `iteratee`. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': 1, '6': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.countBy(['one', 'two', 'three'], 'length');\n * // => { '3': 2, '5': 1 }\n */\n var countBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n ++result[key];\n } else {\n baseAssignValue(result, key, 1);\n }\n });\n\n /**\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\n * Iteration is stopped once `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * **Note:** This method returns `true` for\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\n * elements of empty collections.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n * @example\n *\n * _.every([true, 1, null, 'yes'], Boolean);\n * // => false\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.every(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.every(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.every(users, 'active');\n * // => false\n */\n function every(collection, predicate, guard) {\n var func = isArray(collection) ? arrayEvery : baseEvery;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\n function filter(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false },\n * { 'user': 'pebbles', 'age': 1, 'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\n var find = createFind(findIndex);\n\n /**\n * This method is like `_.find` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=collection.length-1] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * _.findLast([1, 2, 3, 4], function(n) {\n * return n % 2 == 1;\n * });\n * // => 3\n */\n var findLast = createFind(findLastIndex);\n\n /**\n * Creates a flattened array of values by running each element in `collection`\n * thru `iteratee` and flattening the mapped results. The iteratee is invoked\n * with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [n, n];\n * }\n *\n * _.flatMap([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMap(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), 1);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDeep([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMapDeep(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), INFINITY);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDepth([1, 2], duplicate, 2);\n * // => [[1, 1], [2, 2]]\n */\n function flatMapDepth(collection, iteratee, depth) {\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(map(collection, iteratee), depth);\n }\n\n /**\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\n * The iteratee is invoked with three arguments: (value, index|key, collection).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\n * or `_.forOwn` for object iteration.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias each\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEachRight\n * @example\n *\n * _.forEach([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `1` then `2`.\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forEach(collection, iteratee) {\n var func = isArray(collection) ? arrayEach : baseEach;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forEach` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @alias eachRight\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEach\n * @example\n *\n * _.forEachRight([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `2` then `1`.\n */\n function forEachRight(collection, iteratee) {\n var func = isArray(collection) ? arrayEachRight : baseEachRight;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\n var groupBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n result[key].push(value);\n } else {\n baseAssignValue(result, key, [value]);\n }\n });\n\n /**\n * Checks if `value` is in `collection`. If `collection` is a string, it's\n * checked for a substring of `value`, otherwise\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * is used for equality comparisons. If `fromIndex` is negative, it's used as\n * the offset from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {boolean} Returns `true` if `value` is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'a': 1, 'b': 2 }, 1);\n * // => true\n *\n * _.includes('abcd', 'bc');\n * // => true\n */\n function includes(collection, value, fromIndex, guard) {\n collection = isArrayLike(collection) ? collection : values(collection);\n fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0;\n\n var length = collection.length;\n if (fromIndex < 0) {\n fromIndex = nativeMax(length + fromIndex, 0);\n }\n return isString(collection)\n ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1)\n : (!!length && baseIndexOf(collection, value, fromIndex) > -1);\n }\n\n /**\n * Invokes the method at `path` of each element in `collection`, returning\n * an array of the results of each invoked method. Any additional arguments\n * are provided to each invoked method. If `path` is a function, it's invoked\n * for, and `this` bound to, each element in `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array|Function|string} path The path of the method to invoke or\n * the function invoked per iteration.\n * @param {...*} [args] The arguments to invoke each method with.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort');\n * // => [[1, 5, 7], [1, 2, 3]]\n *\n * _.invokeMap([123, 456], String.prototype.split, '');\n * // => [['1', '2', '3'], ['4', '5', '6']]\n */\n var invokeMap = baseRest(function(collection, path, args) {\n var index = -1,\n isFunc = typeof path == 'function',\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value) {\n result[++index] = isFunc ? apply(path, value, args) : baseInvoke(value, path, args);\n });\n return result;\n });\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the last element responsible for generating the key. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * var array = [\n * { 'dir': 'left', 'code': 97 },\n * { 'dir': 'right', 'code': 100 }\n * ];\n *\n * _.keyBy(array, function(o) {\n * return String.fromCharCode(o.code);\n * });\n * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }\n *\n * _.keyBy(array, 'dir');\n * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }\n */\n var keyBy = createAggregator(function(result, value, key) {\n baseAssignValue(result, key, value);\n });\n\n /**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\n function map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.sortBy` except that it allows specifying the sort\n * orders of the iteratees to sort by. If `orders` is unspecified, all values\n * are sorted in ascending order. Otherwise, specify an order of \"desc\" for\n * descending or \"asc\" for ascending sort order of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @param {string[]} [orders] The sort orders of `iteratees`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 34 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'barney', 'age': 36 }\n * ];\n *\n * // Sort by `user` in ascending order and by `age` in descending order.\n * _.orderBy(users, ['user', 'age'], ['asc', 'desc']);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\n */\n function orderBy(collection, iteratees, orders, guard) {\n if (collection == null) {\n return [];\n }\n if (!isArray(iteratees)) {\n iteratees = iteratees == null ? [] : [iteratees];\n }\n orders = guard ? undefined : orders;\n if (!isArray(orders)) {\n orders = orders == null ? [] : [orders];\n }\n return baseOrderBy(collection, iteratees, orders);\n }\n\n /**\n * Creates an array of elements split into two groups, the first of which\n * contains elements `predicate` returns truthy for, the second of which\n * contains elements `predicate` returns falsey for. The predicate is\n * invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of grouped elements.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true },\n * { 'user': 'pebbles', 'age': 1, 'active': false }\n * ];\n *\n * _.partition(users, function(o) { return o.active; });\n * // => objects for [['fred'], ['barney', 'pebbles']]\n *\n * // The `_.matches` iteratee shorthand.\n * _.partition(users, { 'age': 1, 'active': false });\n * // => objects for [['pebbles'], ['barney', 'fred']]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.partition(users, ['active', false]);\n * // => objects for [['barney', 'pebbles'], ['fred']]\n *\n * // The `_.property` iteratee shorthand.\n * _.partition(users, 'active');\n * // => objects for [['fred'], ['barney', 'pebbles']]\n */\n var partition = createAggregator(function(result, value, key) {\n result[key ? 0 : 1].push(value);\n }, function() { return [[], []]; });\n\n /**\n * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n * return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\n function reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n }\n\n /**\n * This method is like `_.reduce` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduce\n * @example\n *\n * var array = [[0, 1], [2, 3], [4, 5]];\n *\n * _.reduceRight(array, function(flattened, other) {\n * return flattened.concat(other);\n * }, []);\n * // => [4, 5, 2, 3, 0, 1]\n */\n function reduceRight(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduceRight : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEachRight);\n }\n\n /**\n * The opposite of `_.filter`; this method returns the elements of `collection`\n * that `predicate` does **not** return truthy for.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.filter\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true }\n * ];\n *\n * _.reject(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.reject(users, { 'age': 40, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.reject(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.reject(users, 'active');\n * // => objects for ['barney']\n */\n function reject(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, negate(getIteratee(predicate, 3)));\n }\n\n /**\n * Gets a random element from `collection`.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n * @example\n *\n * _.sample([1, 2, 3, 4]);\n * // => 2\n */\n function sample(collection) {\n var func = isArray(collection) ? arraySample : baseSample;\n return func(collection);\n }\n\n /**\n * Gets `n` random elements at unique keys from `collection` up to the\n * size of `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @param {number} [n=1] The number of elements to sample.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the random elements.\n * @example\n *\n * _.sampleSize([1, 2, 3], 2);\n * // => [3, 1]\n *\n * _.sampleSize([1, 2, 3], 4);\n * // => [2, 3, 1]\n */\n function sampleSize(collection, n, guard) {\n if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n var func = isArray(collection) ? arraySampleSize : baseSampleSize;\n return func(collection, n);\n }\n\n /**\n * Creates an array of shuffled values, using a version of the\n * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n * @example\n *\n * _.shuffle([1, 2, 3, 4]);\n * // => [4, 1, 3, 2]\n */\n function shuffle(collection) {\n var func = isArray(collection) ? arrayShuffle : baseShuffle;\n return func(collection);\n }\n\n /**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\n function size(collection) {\n if (collection == null) {\n return 0;\n }\n if (isArrayLike(collection)) {\n return isString(collection) ? stringSize(collection) : collection.length;\n }\n var tag = getTag(collection);\n if (tag == mapTag || tag == setTag) {\n return collection.size;\n }\n return baseKeys(collection).length;\n }\n\n /**\n * Checks if `predicate` returns truthy for **any** element of `collection`.\n * Iteration is stopped once `predicate` returns truthy. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n * @example\n *\n * _.some([null, 0, 'yes', false], Boolean);\n * // => true\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.some(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.some(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.some(users, 'active');\n * // => true\n */\n function some(collection, predicate, guard) {\n var func = isArray(collection) ? arraySome : baseSome;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Creates an array of elements, sorted in ascending order by the results of\n * running each element in a collection thru each iteratee. This method\n * performs a stable sort, that is, it preserves the original sort order of\n * equal elements. The iteratees are invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 30 },\n * { 'user': 'barney', 'age': 34 }\n * ];\n *\n * _.sortBy(users, [function(o) { return o.user; }]);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]]\n *\n * _.sortBy(users, ['user', 'age']);\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]]\n */\n var sortBy = baseRest(function(collection, iteratees) {\n if (collection == null) {\n return [];\n }\n var length = iteratees.length;\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\n iteratees = [];\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\n iteratees = [iteratees[0]];\n }\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\n var now = ctxNow || function() {\n return root.Date.now();\n };\n\n /*------------------------------------------------------------------------*/\n\n /**\n * The opposite of `_.before`; this method creates a function that invokes\n * `func` once it's called `n` or more times.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {number} n The number of calls before `func` is invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var saves = ['profile', 'settings'];\n *\n * var done = _.after(saves.length, function() {\n * console.log('done saving!');\n * });\n *\n * _.forEach(saves, function(type) {\n * asyncSave({ 'type': type, 'complete': done });\n * });\n * // => Logs 'done saving!' after the two async saves have completed.\n */\n function after(n, func) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n < 1) {\n return func.apply(this, arguments);\n }\n };\n }\n\n /**\n * Creates a function that invokes `func`, with up to `n` arguments,\n * ignoring any additional arguments.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @param {number} [n=func.length] The arity cap.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.ary(parseInt, 1));\n * // => [6, 8, 10]\n */\n function ary(func, n, guard) {\n n = guard ? undefined : n;\n n = (func && n == null) ? func.length : n;\n return createWrap(func, WRAP_ARY_FLAG, undefined, undefined, undefined, undefined, n);\n }\n\n /**\n * Creates a function that invokes `func`, with the `this` binding and arguments\n * of the created function, while it's called less than `n` times. Subsequent\n * calls to the created function return the result of the last `func` invocation.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {number} n The number of calls at which `func` is no longer invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * jQuery(element).on('click', _.before(5, addContactToList));\n * // => Allows adding up to 4 contacts to the list.\n */\n function before(n, func) {\n var result;\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n > 0) {\n result = func.apply(this, arguments);\n }\n if (n <= 1) {\n func = undefined;\n }\n return result;\n };\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\n * and `partials` prepended to the arguments it receives.\n *\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for partially applied arguments.\n *\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \"length\"\n * property of bound functions.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * function greet(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n *\n * var object = { 'user': 'fred' };\n *\n * var bound = _.bind(greet, object, 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bind(greet, object, _, '!');\n * bound('hi');\n * // => 'hi fred!'\n */\n var bind = baseRest(function(func, thisArg, partials) {\n var bitmask = WRAP_BIND_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bind));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(func, bitmask, thisArg, partials, holders);\n });\n\n /**\n * Creates a function that invokes the method at `object[key]` with `partials`\n * prepended to the arguments it receives.\n *\n * This method differs from `_.bind` by allowing bound functions to reference\n * methods that may be redefined or don't yet exist. See\n * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern)\n * for more details.\n *\n * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Function\n * @param {Object} object The object to invoke the method on.\n * @param {string} key The key of the method.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * var object = {\n * 'user': 'fred',\n * 'greet': function(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n * };\n *\n * var bound = _.bindKey(object, 'greet', 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * object.greet = function(greeting, punctuation) {\n * return greeting + 'ya ' + this.user + punctuation;\n * };\n *\n * bound('!');\n * // => 'hiya fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bindKey(object, 'greet', _, '!');\n * bound('hi');\n * // => 'hiya fred!'\n */\n var bindKey = baseRest(function(object, key, partials) {\n var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bindKey));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(key, bitmask, object, partials, holders);\n });\n\n /**\n * Creates a function that accepts arguments of `func` and either invokes\n * `func` returning its result, if at least `arity` number of arguments have\n * been provided, or returns a function that accepts the remaining `func`\n * arguments, and so on. The arity of `func` may be specified if `func.length`\n * is not sufficient.\n *\n * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curry(abc);\n *\n * curried(1)(2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(1)(_, 3)(2);\n * // => [1, 2, 3]\n */\n function curry(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curry.placeholder;\n return result;\n }\n\n /**\n * This method is like `_.curry` except that arguments are applied to `func`\n * in the manner of `_.partialRight` instead of `_.partial`.\n *\n * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curryRight(abc);\n *\n * curried(3)(2)(1);\n * // => [1, 2, 3]\n *\n * curried(2, 3)(1);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(3)(1, _)(2);\n * // => [1, 2, 3]\n */\n function curryRight(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curryRight.placeholder;\n return result;\n }\n\n /**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\n function debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n }\n\n /**\n * Defers invoking the `func` until the current call stack has cleared. Any\n * additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to defer.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.defer(function(text) {\n * console.log(text);\n * }, 'deferred');\n * // => Logs 'deferred' after one millisecond.\n */\n var defer = baseRest(function(func, args) {\n return baseDelay(func, 1, args);\n });\n\n /**\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\n * provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.delay(function(text) {\n * console.log(text);\n * }, 1000, 'later');\n * // => Logs 'later' after one second.\n */\n var delay = baseRest(function(func, wait, args) {\n return baseDelay(func, toNumber(wait) || 0, args);\n });\n\n /**\n * Creates a function that invokes `func` with arguments reversed.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to flip arguments for.\n * @returns {Function} Returns the new flipped function.\n * @example\n *\n * var flipped = _.flip(function() {\n * return _.toArray(arguments);\n * });\n *\n * flipped('a', 'b', 'c', 'd');\n * // => ['d', 'c', 'b', 'a']\n */\n function flip(func) {\n return createWrap(func, WRAP_FLIP_FLAG);\n }\n\n /**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\n function memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n }\n\n // Expose `MapCache`.\n memoize.Cache = MapCache;\n\n /**\n * Creates a function that negates the result of the predicate `func`. The\n * `func` predicate is invoked with the `this` binding and arguments of the\n * created function.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} predicate The predicate to negate.\n * @returns {Function} Returns the new negated function.\n * @example\n *\n * function isEven(n) {\n * return n % 2 == 0;\n * }\n *\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\n * // => [1, 3, 5]\n */\n function negate(predicate) {\n if (typeof predicate != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return function() {\n var args = arguments;\n switch (args.length) {\n case 0: return !predicate.call(this);\n case 1: return !predicate.call(this, args[0]);\n case 2: return !predicate.call(this, args[0], args[1]);\n case 3: return !predicate.call(this, args[0], args[1], args[2]);\n }\n return !predicate.apply(this, args);\n };\n }\n\n /**\n * Creates a function that is restricted to invoking `func` once. Repeat calls\n * to the function return the value of the first invocation. The `func` is\n * invoked with the `this` binding and arguments of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var initialize = _.once(createApplication);\n * initialize();\n * initialize();\n * // => `createApplication` is invoked once\n */\n function once(func) {\n return before(2, func);\n }\n\n /**\n * Creates a function that invokes `func` with its arguments transformed.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Function\n * @param {Function} func The function to wrap.\n * @param {...(Function|Function[])} [transforms=[_.identity]]\n * The argument transforms.\n * @returns {Function} Returns the new function.\n * @example\n *\n * function doubled(n) {\n * return n * 2;\n * }\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var func = _.overArgs(function(x, y) {\n * return [x, y];\n * }, [square, doubled]);\n *\n * func(9, 3);\n * // => [81, 6]\n *\n * func(10, 5);\n * // => [100, 10]\n */\n var overArgs = castRest(function(func, transforms) {\n transforms = (transforms.length == 1 && isArray(transforms[0]))\n ? arrayMap(transforms[0], baseUnary(getIteratee()))\n : arrayMap(baseFlatten(transforms, 1), baseUnary(getIteratee()));\n\n var funcsLength = transforms.length;\n return baseRest(function(args) {\n var index = -1,\n length = nativeMin(args.length, funcsLength);\n\n while (++index < length) {\n args[index] = transforms[index].call(this, args[index]);\n }\n return apply(func, this, args);\n });\n });\n\n /**\n * Creates a function that invokes `func` with `partials` prepended to the\n * arguments it receives. This method is like `_.bind` except it does **not**\n * alter the `this` binding.\n *\n * The `_.partial.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 0.2.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var sayHelloTo = _.partial(greet, 'hello');\n * sayHelloTo('fred');\n * // => 'hello fred'\n *\n * // Partially applied with placeholders.\n * var greetFred = _.partial(greet, _, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n */\n var partial = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partial));\n return createWrap(func, WRAP_PARTIAL_FLAG, undefined, partials, holders);\n });\n\n /**\n * This method is like `_.partial` except that partially applied arguments\n * are appended to the arguments it receives.\n *\n * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var greetFred = _.partialRight(greet, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n *\n * // Partially applied with placeholders.\n * var sayHelloTo = _.partialRight(greet, 'hello', _);\n * sayHelloTo('fred');\n * // => 'hello fred'\n */\n var partialRight = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partialRight));\n return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders);\n });\n\n /**\n * Creates a function that invokes `func` with arguments arranged according\n * to the specified `indexes` where the argument value at the first index is\n * provided as the first argument, the argument value at the second index is\n * provided as the second argument, and so on.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to rearrange arguments for.\n * @param {...(number|number[])} indexes The arranged argument indexes.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var rearged = _.rearg(function(a, b, c) {\n * return [a, b, c];\n * }, [2, 0, 1]);\n *\n * rearged('b', 'c', 'a')\n * // => ['a', 'b', 'c']\n */\n var rearg = flatRest(function(func, indexes) {\n return createWrap(func, WRAP_REARG_FLAG, undefined, undefined, undefined, indexes);\n });\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as\n * an array.\n *\n * **Note:** This method is based on the\n * [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.rest(function(what, names) {\n * return what + ' ' + _.initial(names).join(', ') +\n * (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\n function rest(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start === undefined ? start : toInteger(start);\n return baseRest(func, start);\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * create function and an array of arguments much like\n * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).\n *\n * **Note:** This method is based on the\n * [spread operator](https://mdn.io/spread_operator).\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Function\n * @param {Function} func The function to spread arguments over.\n * @param {number} [start=0] The start position of the spread.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.spread(function(who, what) {\n * return who + ' says ' + what;\n * });\n *\n * say(['fred', 'hello']);\n * // => 'fred says hello'\n *\n * var numbers = Promise.all([\n * Promise.resolve(40),\n * Promise.resolve(36)\n * ]);\n *\n * numbers.then(_.spread(function(x, y) {\n * return x + y;\n * }));\n * // => a Promise of 76\n */\n function spread(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start == null ? 0 : nativeMax(toInteger(start), 0);\n return baseRest(function(args) {\n var array = args[start],\n otherArgs = castSlice(args, 0, start);\n\n if (array) {\n arrayPush(otherArgs, array);\n }\n return apply(func, this, otherArgs);\n });\n }\n\n /**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\n function throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n }\n\n /**\n * Creates a function that accepts up to one argument, ignoring any\n * additional arguments.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.unary(parseInt));\n * // => [6, 8, 10]\n */\n function unary(func) {\n return ary(func, 1);\n }\n\n /**\n * Creates a function that provides `value` to `wrapper` as its first\n * argument. Any additional arguments provided to the function are appended\n * to those provided to the `wrapper`. The wrapper is invoked with the `this`\n * binding of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {*} value The value to wrap.\n * @param {Function} [wrapper=identity] The wrapper function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var p = _.wrap(_.escape, function(func, text) {\n * return '

' + func(text) + '

';\n * });\n *\n * p('fred, barney, & pebbles');\n * // => '

fred, barney, & pebbles

'\n */\n function wrap(value, wrapper) {\n return partial(castFunction(wrapper), value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Casts `value` as an array if it's not one.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Lang\n * @param {*} value The value to inspect.\n * @returns {Array} Returns the cast array.\n * @example\n *\n * _.castArray(1);\n * // => [1]\n *\n * _.castArray({ 'a': 1 });\n * // => [{ 'a': 1 }]\n *\n * _.castArray('abc');\n * // => ['abc']\n *\n * _.castArray(null);\n * // => [null]\n *\n * _.castArray(undefined);\n * // => [undefined]\n *\n * _.castArray();\n * // => []\n *\n * var array = [1, 2, 3];\n * console.log(_.castArray(array) === array);\n * // => true\n */\n function castArray() {\n if (!arguments.length) {\n return [];\n }\n var value = arguments[0];\n return isArray(value) ? value : [value];\n }\n\n /**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\n function clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.clone` except that it accepts `customizer` which\n * is invoked to produce the cloned value. If `customizer` returns `undefined`,\n * cloning is handled by the method instead. The `customizer` is invoked with\n * up to four arguments; (value [, index|key, object, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeepWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(false);\n * }\n * }\n *\n * var el = _.cloneWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 0\n */\n function cloneWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\n function cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.cloneWith` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the deep cloned value.\n * @see _.cloneWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(true);\n * }\n * }\n *\n * var el = _.cloneDeepWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 20\n */\n function cloneDeepWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * Checks if `object` conforms to `source` by invoking the predicate\n * properties of `source` with the corresponding property values of `object`.\n *\n * **Note:** This method is equivalent to `_.conforms` when `source` is\n * partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 1; } });\n * // => true\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 2; } });\n * // => false\n */\n function conformsTo(object, source) {\n return source == null || baseConformsTo(object, source, keys(source));\n }\n\n /**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\n function eq(value, other) {\n return value === other || (value !== value && other !== other);\n }\n\n /**\n * Checks if `value` is greater than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n * @see _.lt\n * @example\n *\n * _.gt(3, 1);\n * // => true\n *\n * _.gt(3, 3);\n * // => false\n *\n * _.gt(1, 3);\n * // => false\n */\n var gt = createRelationalOperation(baseGt);\n\n /**\n * Checks if `value` is greater than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than or equal to\n * `other`, else `false`.\n * @see _.lte\n * @example\n *\n * _.gte(3, 1);\n * // => true\n *\n * _.gte(3, 3);\n * // => true\n *\n * _.gte(1, 3);\n * // => false\n */\n var gte = createRelationalOperation(function(value, other) {\n return value >= other;\n });\n\n /**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\n var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n };\n\n /**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\n var isArray = Array.isArray;\n\n /**\n * Checks if `value` is classified as an `ArrayBuffer` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n * @example\n *\n * _.isArrayBuffer(new ArrayBuffer(2));\n * // => true\n *\n * _.isArrayBuffer(new Array(2));\n * // => false\n */\n var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer;\n\n /**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\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 array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\n function isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n }\n\n /**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an 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 an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\n function isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n }\n\n /**\n * Checks if `value` is classified as a boolean primitive or object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.\n * @example\n *\n * _.isBoolean(false);\n * // => true\n *\n * _.isBoolean(null);\n * // => false\n */\n function isBoolean(value) {\n return value === true || value === false ||\n (isObjectLike(value) && baseGetTag(value) == boolTag);\n }\n\n /**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\n var isBuffer = nativeIsBuffer || stubFalse;\n\n /**\n * Checks if `value` is classified as a `Date` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n * @example\n *\n * _.isDate(new Date);\n * // => true\n *\n * _.isDate('Mon April 23 2012');\n * // => false\n */\n var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\n\n /**\n * Checks if `value` is likely a DOM element.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`.\n * @example\n *\n * _.isElement(document.body);\n * // => true\n *\n * _.isElement('');\n * // => false\n */\n function isElement(value) {\n return isObjectLike(value) && value.nodeType === 1 && !isPlainObject(value);\n }\n\n /**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\n function isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\n function isEqual(value, other) {\n return baseIsEqual(value, other);\n }\n\n /**\n * This method is like `_.isEqual` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with up to\n * six arguments: (objValue, othValue [, index|key, object, other, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n * if (isGreeting(objValue) && isGreeting(othValue)) {\n * return true;\n * }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * _.isEqualWith(array, other, customizer);\n * // => true\n */\n function isEqualWith(value, other, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n var result = customizer ? customizer(value, other) : undefined;\n return result === undefined ? baseIsEqual(value, other, undefined, customizer) : !!result;\n }\n\n /**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an error object, else `false`.\n * @example\n *\n * _.isError(new Error);\n * // => true\n *\n * _.isError(Error);\n * // => false\n */\n function isError(value) {\n if (!isObjectLike(value)) {\n return false;\n }\n var tag = baseGetTag(value);\n return tag == errorTag || tag == domExcTag ||\n (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value));\n }\n\n /**\n * Checks if `value` is a finite primitive number.\n *\n * **Note:** This method is based on\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\n * @example\n *\n * _.isFinite(3);\n * // => true\n *\n * _.isFinite(Number.MIN_VALUE);\n * // => true\n *\n * _.isFinite(Infinity);\n * // => false\n *\n * _.isFinite('3');\n * // => false\n */\n function isFinite(value) {\n return typeof value == 'number' && nativeIsFinite(value);\n }\n\n /**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\n function isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n }\n\n /**\n * Checks if `value` is an integer.\n *\n * **Note:** This method is based on\n * [`Number.isInteger`](https://mdn.io/Number/isInteger).\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 an integer, else `false`.\n * @example\n *\n * _.isInteger(3);\n * // => true\n *\n * _.isInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isInteger(Infinity);\n * // => false\n *\n * _.isInteger('3');\n * // => false\n */\n function isInteger(value) {\n return typeof value == 'number' && value == toInteger(value);\n }\n\n /**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\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 a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\n function isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n }\n\n /**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\n function isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n }\n\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 */\n function isObjectLike(value) {\n return value != null && typeof value == 'object';\n }\n\n /**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\n var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\n /**\n * Performs a partial deep comparison between `object` and `source` to\n * determine if `object` contains equivalent property values.\n *\n * **Note:** This method is equivalent to `_.matches` when `source` is\n * partially applied.\n *\n * Partial comparisons will match empty array and empty object `source`\n * values against any array or object value, respectively. See `_.isEqual`\n * for a list of supported value comparisons.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.isMatch(object, { 'b': 2 });\n * // => true\n *\n * _.isMatch(object, { 'b': 1 });\n * // => false\n */\n function isMatch(object, source) {\n return object === source || baseIsMatch(object, source, getMatchData(source));\n }\n\n /**\n * This method is like `_.isMatch` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with five\n * arguments: (objValue, srcValue, index|key, object, source).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, srcValue) {\n * if (isGreeting(objValue) && isGreeting(srcValue)) {\n * return true;\n * }\n * }\n *\n * var object = { 'greeting': 'hello' };\n * var source = { 'greeting': 'hi' };\n *\n * _.isMatchWith(object, source, customizer);\n * // => true\n */\n function isMatchWith(object, source, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseIsMatch(object, source, getMatchData(source), customizer);\n }\n\n /**\n * Checks if `value` is `NaN`.\n *\n * **Note:** This method is based on\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\n * `undefined` and other non-number values.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n * @example\n *\n * _.isNaN(NaN);\n * // => true\n *\n * _.isNaN(new Number(NaN));\n * // => true\n *\n * isNaN(undefined);\n * // => true\n *\n * _.isNaN(undefined);\n * // => false\n */\n function isNaN(value) {\n // An `NaN` primitive is the only value that is not equal to itself.\n // Perform the `toStringTag` check first to avoid errors with some\n // ActiveX objects in IE.\n return isNumber(value) && value != +value;\n }\n\n /**\n * Checks if `value` is a pristine native function.\n *\n * **Note:** This method can't reliably detect native functions in the presence\n * of the core-js package because core-js circumvents this kind of detection.\n * Despite multiple requests, the core-js maintainer has made it clear: any\n * attempt to fix the detection will be obstructed. As a result, we're left\n * with little choice but to throw an error. Unfortunately, this also affects\n * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill),\n * which rely on core-js.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\n function isNative(value) {\n if (isMaskable(value)) {\n throw new Error(CORE_ERROR_TEXT);\n }\n return baseIsNative(value);\n }\n\n /**\n * Checks if `value` is `null`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\n * @example\n *\n * _.isNull(null);\n * // => true\n *\n * _.isNull(void 0);\n * // => false\n */\n function isNull(value) {\n return value === null;\n }\n\n /**\n * Checks if `value` is `null` or `undefined`.\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 nullish, else `false`.\n * @example\n *\n * _.isNil(null);\n * // => true\n *\n * _.isNil(void 0);\n * // => true\n *\n * _.isNil(NaN);\n * // => false\n */\n function isNil(value) {\n return value == null;\n }\n\n /**\n * Checks if `value` is classified as a `Number` primitive or object.\n *\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\n * classified as numbers, use the `_.isFinite` method.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\n * @example\n *\n * _.isNumber(3);\n * // => true\n *\n * _.isNumber(Number.MIN_VALUE);\n * // => true\n *\n * _.isNumber(Infinity);\n * // => true\n *\n * _.isNumber('3');\n * // => false\n */\n function isNumber(value) {\n return typeof value == 'number' ||\n (isObjectLike(value) && baseGetTag(value) == numberTag);\n }\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 */\n function 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\n /**\n * Checks if `value` is classified as a `RegExp` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n * @example\n *\n * _.isRegExp(/abc/);\n * // => true\n *\n * _.isRegExp('/abc/');\n * // => false\n */\n var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\n\n /**\n * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754\n * double precision number which isn't the result of a rounded unsafe integer.\n *\n * **Note:** This method is based on\n * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger).\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 a safe integer, else `false`.\n * @example\n *\n * _.isSafeInteger(3);\n * // => true\n *\n * _.isSafeInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isSafeInteger(Infinity);\n * // => false\n *\n * _.isSafeInteger('3');\n * // => false\n */\n function isSafeInteger(value) {\n return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER;\n }\n\n /**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\n var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\n /**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\n function isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n }\n\n /**\n * Checks if `value` is classified as a `Symbol` primitive or 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 a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\n function isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n }\n\n /**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\n var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n /**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\n function isUndefined(value) {\n return value === undefined;\n }\n\n /**\n * Checks if `value` is classified as a `WeakMap` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak map, else `false`.\n * @example\n *\n * _.isWeakMap(new WeakMap);\n * // => true\n *\n * _.isWeakMap(new Map);\n * // => false\n */\n function isWeakMap(value) {\n return isObjectLike(value) && getTag(value) == weakMapTag;\n }\n\n /**\n * Checks if `value` is classified as a `WeakSet` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak set, else `false`.\n * @example\n *\n * _.isWeakSet(new WeakSet);\n * // => true\n *\n * _.isWeakSet(new Set);\n * // => false\n */\n function isWeakSet(value) {\n return isObjectLike(value) && baseGetTag(value) == weakSetTag;\n }\n\n /**\n * Checks if `value` is less than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n * @see _.gt\n * @example\n *\n * _.lt(1, 3);\n * // => true\n *\n * _.lt(3, 3);\n * // => false\n *\n * _.lt(3, 1);\n * // => false\n */\n var lt = createRelationalOperation(baseLt);\n\n /**\n * Checks if `value` is less than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than or equal to\n * `other`, else `false`.\n * @see _.gte\n * @example\n *\n * _.lte(1, 3);\n * // => true\n *\n * _.lte(3, 3);\n * // => true\n *\n * _.lte(3, 1);\n * // => false\n */\n var lte = createRelationalOperation(function(value, other) {\n return value <= other;\n });\n\n /**\n * Converts `value` to an array.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Array} Returns the converted array.\n * @example\n *\n * _.toArray({ 'a': 1, 'b': 2 });\n * // => [1, 2]\n *\n * _.toArray('abc');\n * // => ['a', 'b', 'c']\n *\n * _.toArray(1);\n * // => []\n *\n * _.toArray(null);\n * // => []\n */\n function toArray(value) {\n if (!value) {\n return [];\n }\n if (isArrayLike(value)) {\n return isString(value) ? stringToArray(value) : copyArray(value);\n }\n if (symIterator && value[symIterator]) {\n return iteratorToArray(value[symIterator]());\n }\n var tag = getTag(value),\n func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\n\n return func(value);\n }\n\n /**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\n function toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n }\n\n /**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\n function toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n }\n\n /**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\n function toLength(value) {\n return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n }\n\n /**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\n function toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n }\n\n /**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\n function toPlainObject(value) {\n return copyObject(value, keysIn(value));\n }\n\n /**\n * Converts `value` to a safe integer. A safe integer can be compared and\n * represented correctly.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toSafeInteger(3.2);\n * // => 3\n *\n * _.toSafeInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toSafeInteger(Infinity);\n * // => 9007199254740991\n *\n * _.toSafeInteger('3.2');\n * // => 3\n */\n function toSafeInteger(value) {\n return value\n ? baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER)\n : (value === 0 ? value : 0);\n }\n\n /**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\n function toString(value) {\n return value == null ? '' : baseToString(value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Assigns own enumerable string keyed properties of source objects to the\n * destination object. Source objects are applied from left to right.\n * Subsequent sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object` and is loosely based on\n * [`Object.assign`](https://mdn.io/Object/assign).\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assignIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assign({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'c': 3 }\n */\n var assign = createAssigner(function(object, source) {\n if (isPrototype(source) || isArrayLike(source)) {\n copyObject(source, keys(source), object);\n return;\n }\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n assignValue(object, key, source[key]);\n }\n }\n });\n\n /**\n * This method is like `_.assign` except that it iterates over own and\n * inherited source properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extend\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assign\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\n */\n var assignIn = createAssigner(function(object, source) {\n copyObject(source, keysIn(source), object);\n });\n\n /**\n * This method is like `_.assignIn` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extendWith\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignInWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignInWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keysIn(source), object, customizer);\n });\n\n /**\n * This method is like `_.assign` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignInWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keys(source), object, customizer);\n });\n\n /**\n * Creates an array of values corresponding to `paths` of `object`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Array} Returns the picked values.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _.at(object, ['a[0].b.c', 'a[1]']);\n * // => [3, 4]\n */\n var at = flatRest(baseAt);\n\n /**\n * Creates an object that inherits from the `prototype` object. If a\n * `properties` object is given, its own enumerable string keyed properties\n * are assigned to the created object.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Object\n * @param {Object} prototype The object to inherit from.\n * @param {Object} [properties] The properties to assign to the object.\n * @returns {Object} Returns the new object.\n * @example\n *\n * function Shape() {\n * this.x = 0;\n * this.y = 0;\n * }\n *\n * function Circle() {\n * Shape.call(this);\n * }\n *\n * Circle.prototype = _.create(Shape.prototype, {\n * 'constructor': Circle\n * });\n *\n * var circle = new Circle;\n * circle instanceof Circle;\n * // => true\n *\n * circle instanceof Shape;\n * // => true\n */\n function create(prototype, properties) {\n var result = baseCreate(prototype);\n return properties == null ? result : baseAssign(result, properties);\n }\n\n /**\n * Assigns own and inherited enumerable string keyed properties of source\n * objects to the destination object for all destination properties that\n * resolve to `undefined`. Source objects are applied from left to right.\n * Once a property is set, additional values of the same property are ignored.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaultsDeep\n * @example\n *\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var defaults = baseRest(function(object, sources) {\n object = Object(object);\n\n var index = -1;\n var length = sources.length;\n var guard = length > 2 ? sources[2] : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n length = 1;\n }\n\n while (++index < length) {\n var source = sources[index];\n var props = keysIn(source);\n var propsIndex = -1;\n var propsLength = props.length;\n\n while (++propsIndex < propsLength) {\n var key = props[propsIndex];\n var value = object[key];\n\n if (value === undefined ||\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n object[key] = source[key];\n }\n }\n }\n\n return object;\n });\n\n /**\n * This method is like `_.defaults` except that it recursively assigns\n * default properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaults\n * @example\n *\n * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });\n * // => { 'a': { 'b': 2, 'c': 3 } }\n */\n var defaultsDeep = baseRest(function(args) {\n args.push(undefined, customDefaultsMerge);\n return apply(mergeWith, undefined, args);\n });\n\n /**\n * This method is like `_.find` except that it returns the key of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findKey(users, function(o) { return o.age < 40; });\n * // => 'barney' (iteration order is not guaranteed)\n *\n * // The `_.matches` iteratee shorthand.\n * _.findKey(users, { 'age': 1, 'active': true });\n * // => 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findKey(users, 'active');\n * // => 'barney'\n */\n function findKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwn);\n }\n\n /**\n * This method is like `_.findKey` except that it iterates over elements of\n * a collection in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findLastKey(users, function(o) { return o.age < 40; });\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastKey(users, { 'age': 36, 'active': true });\n * // => 'barney'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastKey(users, 'active');\n * // => 'pebbles'\n */\n function findLastKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwnRight);\n }\n\n /**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\n function forIn(object, iteratee) {\n return object == null\n ? object\n : baseFor(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * This method is like `_.forIn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forInRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'.\n */\n function forInRight(object, iteratee) {\n return object == null\n ? object\n : baseForRight(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * Iterates over own enumerable string keyed properties of an object and\n * invokes `iteratee` for each property. The iteratee is invoked with three\n * arguments: (value, key, object). Iteratee functions may exit iteration\n * early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwnRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forOwn(object, iteratee) {\n return object && baseForOwn(object, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forOwn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwnRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'.\n */\n function forOwnRight(object, iteratee) {\n return object && baseForOwnRight(object, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an array of function property names from own enumerable properties\n * of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functionsIn\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functions(new Foo);\n * // => ['a', 'b']\n */\n function functions(object) {\n return object == null ? [] : baseFunctions(object, keys(object));\n }\n\n /**\n * Creates an array of function property names from own and inherited\n * enumerable properties of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functions\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functionsIn(new Foo);\n * // => ['a', 'b', 'c']\n */\n function functionsIn(object) {\n return object == null ? [] : baseFunctions(object, keysIn(object));\n }\n\n /**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\n function get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n }\n\n /**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\n function has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n }\n\n /**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\n function hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n }\n\n /**\n * Creates an object composed of the inverted keys and values of `object`.\n * If `object` contains duplicate values, subsequent values overwrite\n * property assignments of previous values.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Object\n * @param {Object} object The object to invert.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invert(object);\n * // => { '1': 'c', '2': 'b' }\n */\n var invert = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n result[value] = key;\n }, constant(identity));\n\n /**\n * This method is like `_.invert` except that the inverted object is generated\n * from the results of running each element of `object` thru `iteratee`. The\n * corresponding inverted value of each inverted key is an array of keys\n * responsible for generating the inverted value. The iteratee is invoked\n * with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Object\n * @param {Object} object The object to invert.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invertBy(object);\n * // => { '1': ['a', 'c'], '2': ['b'] }\n *\n * _.invertBy(object, function(value) {\n * return 'group' + value;\n * });\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\n */\n var invertBy = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n if (hasOwnProperty.call(result, value)) {\n result[value].push(key);\n } else {\n result[value] = [key];\n }\n }, getIteratee);\n\n /**\n * Invokes the method at `path` of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] };\n *\n * _.invoke(object, 'a[0].b.c.slice', 1, 3);\n * // => [2, 3]\n */\n var invoke = baseRest(baseInvoke);\n\n /**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\n function keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n }\n\n /**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\n function keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n }\n\n /**\n * The opposite of `_.mapValues`; this method creates an object with the\n * same values as `object` and keys generated by running each own enumerable\n * string keyed property of `object` thru `iteratee`. The iteratee is invoked\n * with three arguments: (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapValues\n * @example\n *\n * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {\n * return key + value;\n * });\n * // => { 'a1': 1, 'b2': 2 }\n */\n function mapKeys(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, iteratee(value, key, object), value);\n });\n return result;\n }\n\n /**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\n function mapValues(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n }\n\n /**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\n var merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n });\n\n /**\n * This method is like `_.merge` except that it accepts `customizer` which\n * is invoked to produce the merged values of the destination and source\n * properties. If `customizer` returns `undefined`, merging is handled by the\n * method instead. The `customizer` is invoked with six arguments:\n * (objValue, srcValue, key, object, source, stack).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} customizer The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * function customizer(objValue, srcValue) {\n * if (_.isArray(objValue)) {\n * return objValue.concat(srcValue);\n * }\n * }\n *\n * var object = { 'a': [1], 'b': [2] };\n * var other = { 'a': [3], 'b': [4] };\n *\n * _.mergeWith(object, other, customizer);\n * // => { 'a': [1, 3], 'b': [2, 4] }\n */\n var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\n baseMerge(object, source, srcIndex, customizer);\n });\n\n /**\n * The opposite of `_.pick`; this method creates an object composed of the\n * own and inherited enumerable property paths of `object` that are not omitted.\n *\n * **Note:** This method is considerably slower than `_.pick`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to omit.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omit(object, ['a', 'c']);\n * // => { 'b': '2' }\n */\n var omit = flatRest(function(object, paths) {\n var result = {};\n if (object == null) {\n return result;\n }\n var isDeep = false;\n paths = arrayMap(paths, function(path) {\n path = castPath(path, object);\n isDeep || (isDeep = path.length > 1);\n return path;\n });\n copyObject(object, getAllKeysIn(object), result);\n if (isDeep) {\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\n }\n var length = paths.length;\n while (length--) {\n baseUnset(result, paths[length]);\n }\n return result;\n });\n\n /**\n * The opposite of `_.pickBy`; this method creates an object composed of\n * the own and inherited enumerable string keyed properties of `object` that\n * `predicate` doesn't return truthy for. The predicate is invoked with two\n * arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omitBy(object, _.isNumber);\n * // => { 'b': '2' }\n */\n function omitBy(object, predicate) {\n return pickBy(object, negate(getIteratee(predicate)));\n }\n\n /**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\n var pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n });\n\n /**\n * Creates an object composed of the `object` properties `predicate` returns\n * truthy for. The predicate is invoked with two arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pickBy(object, _.isNumber);\n * // => { 'a': 1, 'c': 3 }\n */\n function pickBy(object, predicate) {\n if (object == null) {\n return {};\n }\n var props = arrayMap(getAllKeysIn(object), function(prop) {\n return [prop];\n });\n predicate = getIteratee(predicate);\n return basePickBy(object, props, function(value, path) {\n return predicate(value, path[0]);\n });\n }\n\n /**\n * This method is like `_.get` except that if the resolved value is a\n * function it's invoked with the `this` binding of its parent object and\n * its result is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to resolve.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\n *\n * _.result(object, 'a[0].b.c1');\n * // => 3\n *\n * _.result(object, 'a[0].b.c2');\n * // => 4\n *\n * _.result(object, 'a[0].b.c3', 'default');\n * // => 'default'\n *\n * _.result(object, 'a[0].b.c3', _.constant('default'));\n * // => 'default'\n */\n function result(object, path, defaultValue) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length;\n\n // Ensure the loop is entered when path is empty.\n if (!length) {\n length = 1;\n object = undefined;\n }\n while (++index < length) {\n var value = object == null ? undefined : object[toKey(path[index])];\n if (value === undefined) {\n index = length;\n value = defaultValue;\n }\n object = isFunction(value) ? value.call(object) : value;\n }\n return object;\n }\n\n /**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\n function set(object, path, value) {\n return object == null ? object : baseSet(object, path, value);\n }\n\n /**\n * This method is like `_.set` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.setWith(object, '[0][1]', 'a', Object);\n * // => { '0': { '1': 'a' } }\n */\n function setWith(object, path, value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseSet(object, path, value, customizer);\n }\n\n /**\n * Creates an array of own enumerable string keyed-value pairs for `object`\n * which can be consumed by `_.fromPairs`. If `object` is a map or set, its\n * entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entries\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairs(new Foo);\n * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed)\n */\n var toPairs = createToPairs(keys);\n\n /**\n * Creates an array of own and inherited enumerable string keyed-value pairs\n * for `object` which can be consumed by `_.fromPairs`. If `object` is a map\n * or set, its entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entriesIn\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairsIn(new Foo);\n * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed)\n */\n var toPairsIn = createToPairs(keysIn);\n\n /**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n * result.push(n *= n);\n * return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\n function transform(object, iteratee, accumulator) {\n var isArr = isArray(object),\n isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n iteratee = getIteratee(iteratee, 4);\n if (accumulator == null) {\n var Ctor = object && object.constructor;\n if (isArrLike) {\n accumulator = isArr ? new Ctor : [];\n }\n else if (isObject(object)) {\n accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n }\n else {\n accumulator = {};\n }\n }\n (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n return iteratee(accumulator, value, index, object);\n });\n return accumulator;\n }\n\n /**\n * Removes the property at `path` of `object`.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 7 } }] };\n * _.unset(object, 'a[0].b.c');\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n *\n * _.unset(object, ['a', '0', 'b', 'c']);\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n */\n function unset(object, path) {\n return object == null ? true : baseUnset(object, path);\n }\n\n /**\n * This method is like `_.set` except that accepts `updater` to produce the\n * value to set. Use `_.updateWith` to customize `path` creation. The `updater`\n * is invoked with one argument: (value).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.update(object, 'a[0].b.c', function(n) { return n * n; });\n * console.log(object.a[0].b.c);\n * // => 9\n *\n * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });\n * console.log(object.x[0].y.z);\n * // => 0\n */\n function update(object, path, updater) {\n return object == null ? object : baseUpdate(object, path, castFunction(updater));\n }\n\n /**\n * This method is like `_.update` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.updateWith(object, '[0][1]', _.constant('a'), Object);\n * // => { '0': { '1': 'a' } }\n */\n function updateWith(object, path, updater, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer);\n }\n\n /**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\n function values(object) {\n return object == null ? [] : baseValues(object, keys(object));\n }\n\n /**\n * Creates an array of the own and inherited enumerable string keyed property\n * values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.valuesIn(new Foo);\n * // => [1, 2, 3] (iteration order is not guaranteed)\n */\n function valuesIn(object) {\n return object == null ? [] : baseValues(object, keysIn(object));\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Number\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n * @example\n *\n * _.clamp(-10, -5, 5);\n * // => -5\n *\n * _.clamp(10, -5, 5);\n * // => 5\n */\n function clamp(number, lower, upper) {\n if (upper === undefined) {\n upper = lower;\n lower = undefined;\n }\n if (upper !== undefined) {\n upper = toNumber(upper);\n upper = upper === upper ? upper : 0;\n }\n if (lower !== undefined) {\n lower = toNumber(lower);\n lower = lower === lower ? lower : 0;\n }\n return baseClamp(toNumber(number), lower, upper);\n }\n\n /**\n * Checks if `n` is between `start` and up to, but not including, `end`. If\n * `end` is not specified, it's set to `start` with `start` then set to `0`.\n * If `start` is greater than `end` the params are swapped to support\n * negative ranges.\n *\n * @static\n * @memberOf _\n * @since 3.3.0\n * @category Number\n * @param {number} number The number to check.\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n * @see _.range, _.rangeRight\n * @example\n *\n * _.inRange(3, 2, 4);\n * // => true\n *\n * _.inRange(4, 8);\n * // => true\n *\n * _.inRange(4, 2);\n * // => false\n *\n * _.inRange(2, 2);\n * // => false\n *\n * _.inRange(1.2, 2);\n * // => true\n *\n * _.inRange(5.2, 4);\n * // => false\n *\n * _.inRange(-3, -2, -6);\n * // => true\n */\n function inRange(number, start, end) {\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n number = toNumber(number);\n return baseInRange(number, start, end);\n }\n\n /**\n * Produces a random number between the inclusive `lower` and `upper` bounds.\n * If only one argument is provided a number between `0` and the given number\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\n * floats, a floating-point number is returned instead of an integer.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Number\n * @param {number} [lower=0] The lower bound.\n * @param {number} [upper=1] The upper bound.\n * @param {boolean} [floating] Specify returning a floating-point number.\n * @returns {number} Returns the random number.\n * @example\n *\n * _.random(0, 5);\n * // => an integer between 0 and 5\n *\n * _.random(5);\n * // => also an integer between 0 and 5\n *\n * _.random(5, true);\n * // => a floating-point number between 0 and 5\n *\n * _.random(1.2, 5.2);\n * // => a floating-point number between 1.2 and 5.2\n */\n function random(lower, upper, floating) {\n if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\n upper = floating = undefined;\n }\n if (floating === undefined) {\n if (typeof upper == 'boolean') {\n floating = upper;\n upper = undefined;\n }\n else if (typeof lower == 'boolean') {\n floating = lower;\n lower = undefined;\n }\n }\n if (lower === undefined && upper === undefined) {\n lower = 0;\n upper = 1;\n }\n else {\n lower = toFinite(lower);\n if (upper === undefined) {\n upper = lower;\n lower = 0;\n } else {\n upper = toFinite(upper);\n }\n }\n if (lower > upper) {\n var temp = lower;\n lower = upper;\n upper = temp;\n }\n if (floating || lower % 1 || upper % 1) {\n var rand = nativeRandom();\n return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\n }\n return baseRandom(lower, upper);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the camel cased string.\n * @example\n *\n * _.camelCase('Foo Bar');\n * // => 'fooBar'\n *\n * _.camelCase('--foo-bar--');\n * // => 'fooBar'\n *\n * _.camelCase('__FOO_BAR__');\n * // => 'fooBar'\n */\n var camelCase = createCompounder(function(result, word, index) {\n word = word.toLowerCase();\n return result + (index ? capitalize(word) : word);\n });\n\n /**\n * Converts the first character of `string` to upper case and the remaining\n * to lower case.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to capitalize.\n * @returns {string} Returns the capitalized string.\n * @example\n *\n * _.capitalize('FRED');\n * // => 'Fred'\n */\n function capitalize(string) {\n return upperFirst(toString(string).toLowerCase());\n }\n\n /**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\n function deburr(string) {\n string = toString(string);\n return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n }\n\n /**\n * Checks if `string` ends with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=string.length] The position to search up to.\n * @returns {boolean} Returns `true` if `string` ends with `target`,\n * else `false`.\n * @example\n *\n * _.endsWith('abc', 'c');\n * // => true\n *\n * _.endsWith('abc', 'b');\n * // => false\n *\n * _.endsWith('abc', 'b', 2);\n * // => true\n */\n function endsWith(string, target, position) {\n string = toString(string);\n target = baseToString(target);\n\n var length = string.length;\n position = position === undefined\n ? length\n : baseClamp(toInteger(position), 0, length);\n\n var end = position;\n position -= target.length;\n return position >= 0 && string.slice(position, end) == target;\n }\n\n /**\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * corresponding HTML entities.\n *\n * **Note:** No other characters are escaped. To escape additional\n * characters use a third-party library like [_he_](https://mths.be/he).\n *\n * Though the \">\" character is escaped for symmetry, characters like\n * \">\" and \"/\" don't need escaping in HTML and have no special meaning\n * unless they're part of a tag or unquoted attribute value. See\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\n * (under \"semi-related fun fact\") for more details.\n *\n * When working with HTML you should always\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\n * XSS vectors.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escape('fred, barney, & pebbles');\n * // => 'fred, barney, & pebbles'\n */\n function escape(string) {\n string = toString(string);\n return (string && reHasUnescapedHtml.test(string))\n ? string.replace(reUnescapedHtml, escapeHtmlChar)\n : string;\n }\n\n /**\n * Escapes the `RegExp` special characters \"^\", \"$\", \"\\\", \".\", \"*\", \"+\",\n * \"?\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", and \"|\" in `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escapeRegExp('[lodash](https://lodash.com/)');\n * // => '\\[lodash\\]\\(https://lodash\\.com/\\)'\n */\n function escapeRegExp(string) {\n string = toString(string);\n return (string && reHasRegExpChar.test(string))\n ? string.replace(reRegExpChar, '\\\\$&')\n : string;\n }\n\n /**\n * Converts `string` to\n * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the kebab cased string.\n * @example\n *\n * _.kebabCase('Foo Bar');\n * // => 'foo-bar'\n *\n * _.kebabCase('fooBar');\n * // => 'foo-bar'\n *\n * _.kebabCase('__FOO_BAR__');\n * // => 'foo-bar'\n */\n var kebabCase = createCompounder(function(result, word, index) {\n return result + (index ? '-' : '') + word.toLowerCase();\n });\n\n /**\n * Converts `string`, as space separated words, to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the lower cased string.\n * @example\n *\n * _.lowerCase('--Foo-Bar--');\n * // => 'foo bar'\n *\n * _.lowerCase('fooBar');\n * // => 'foo bar'\n *\n * _.lowerCase('__FOO_BAR__');\n * // => 'foo bar'\n */\n var lowerCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + word.toLowerCase();\n });\n\n /**\n * Converts the first character of `string` to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.lowerFirst('Fred');\n * // => 'fred'\n *\n * _.lowerFirst('FRED');\n * // => 'fRED'\n */\n var lowerFirst = createCaseFirst('toLowerCase');\n\n /**\n * Pads `string` on the left and right sides if it's shorter than `length`.\n * Padding characters are truncated if they can't be evenly divided by `length`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.pad('abc', 8);\n * // => ' abc '\n *\n * _.pad('abc', 8, '_-');\n * // => '_-abc_-_'\n *\n * _.pad('abc', 3);\n * // => 'abc'\n */\n function pad(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n if (!length || strLength >= length) {\n return string;\n }\n var mid = (length - strLength) / 2;\n return (\n createPadding(nativeFloor(mid), chars) +\n string +\n createPadding(nativeCeil(mid), chars)\n );\n }\n\n /**\n * Pads `string` on the right side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padEnd('abc', 6);\n * // => 'abc '\n *\n * _.padEnd('abc', 6, '_-');\n * // => 'abc_-_'\n *\n * _.padEnd('abc', 3);\n * // => 'abc'\n */\n function padEnd(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (string + createPadding(length - strLength, chars))\n : string;\n }\n\n /**\n * Pads `string` on the left side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padStart('abc', 6);\n * // => ' abc'\n *\n * _.padStart('abc', 6, '_-');\n * // => '_-_abc'\n *\n * _.padStart('abc', 3);\n * // => 'abc'\n */\n function padStart(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (createPadding(length - strLength, chars) + string)\n : string;\n }\n\n /**\n * Converts `string` to an integer of the specified radix. If `radix` is\n * `undefined` or `0`, a `radix` of `10` is used unless `value` is a\n * hexadecimal, in which case a `radix` of `16` is used.\n *\n * **Note:** This method aligns with the\n * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category String\n * @param {string} string The string to convert.\n * @param {number} [radix=10] The radix to interpret `value` by.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.parseInt('08');\n * // => 8\n *\n * _.map(['6', '08', '10'], _.parseInt);\n * // => [6, 8, 10]\n */\n function parseInt(string, radix, guard) {\n if (guard || radix == null) {\n radix = 0;\n } else if (radix) {\n radix = +radix;\n }\n return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0);\n }\n\n /**\n * Repeats the given string `n` times.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to repeat.\n * @param {number} [n=1] The number of times to repeat the string.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the repeated string.\n * @example\n *\n * _.repeat('*', 3);\n * // => '***'\n *\n * _.repeat('abc', 2);\n * // => 'abcabc'\n *\n * _.repeat('abc', 0);\n * // => ''\n */\n function repeat(string, n, guard) {\n if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n return baseRepeat(toString(string), n);\n }\n\n /**\n * Replaces matches for `pattern` in `string` with `replacement`.\n *\n * **Note:** This method is based on\n * [`String#replace`](https://mdn.io/String/replace).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to modify.\n * @param {RegExp|string} pattern The pattern to replace.\n * @param {Function|string} replacement The match replacement.\n * @returns {string} Returns the modified string.\n * @example\n *\n * _.replace('Hi Fred', 'Fred', 'Barney');\n * // => 'Hi Barney'\n */\n function replace() {\n var args = arguments,\n string = toString(args[0]);\n\n return args.length < 3 ? string : string.replace(args[1], args[2]);\n }\n\n /**\n * Converts `string` to\n * [snake case](https://en.wikipedia.org/wiki/Snake_case).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the snake cased string.\n * @example\n *\n * _.snakeCase('Foo Bar');\n * // => 'foo_bar'\n *\n * _.snakeCase('fooBar');\n * // => 'foo_bar'\n *\n * _.snakeCase('--FOO-BAR--');\n * // => 'foo_bar'\n */\n var snakeCase = createCompounder(function(result, word, index) {\n return result + (index ? '_' : '') + word.toLowerCase();\n });\n\n /**\n * Splits `string` by `separator`.\n *\n * **Note:** This method is based on\n * [`String#split`](https://mdn.io/String/split).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to split.\n * @param {RegExp|string} separator The separator pattern to split by.\n * @param {number} [limit] The length to truncate results to.\n * @returns {Array} Returns the string segments.\n * @example\n *\n * _.split('a-b-c', '-', 2);\n * // => ['a', 'b']\n */\n function split(string, separator, limit) {\n if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) {\n separator = limit = undefined;\n }\n limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0;\n if (!limit) {\n return [];\n }\n string = toString(string);\n if (string && (\n typeof separator == 'string' ||\n (separator != null && !isRegExp(separator))\n )) {\n separator = baseToString(separator);\n if (!separator && hasUnicode(string)) {\n return castSlice(stringToArray(string), 0, limit);\n }\n }\n return string.split(separator, limit);\n }\n\n /**\n * Converts `string` to\n * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage).\n *\n * @static\n * @memberOf _\n * @since 3.1.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the start cased string.\n * @example\n *\n * _.startCase('--foo-bar--');\n * // => 'Foo Bar'\n *\n * _.startCase('fooBar');\n * // => 'Foo Bar'\n *\n * _.startCase('__FOO_BAR__');\n * // => 'FOO BAR'\n */\n var startCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + upperFirst(word);\n });\n\n /**\n * Checks if `string` starts with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=0] The position to search from.\n * @returns {boolean} Returns `true` if `string` starts with `target`,\n * else `false`.\n * @example\n *\n * _.startsWith('abc', 'a');\n * // => true\n *\n * _.startsWith('abc', 'b');\n * // => false\n *\n * _.startsWith('abc', 'b', 1);\n * // => true\n */\n function startsWith(string, target, position) {\n string = toString(string);\n position = position == null\n ? 0\n : baseClamp(toInteger(position), 0, string.length);\n\n target = baseToString(target);\n return string.slice(position, position + target.length) == target;\n }\n\n /**\n * Creates a compiled template function that can interpolate data properties\n * in \"interpolate\" delimiters, HTML-escape interpolated data properties in\n * \"escape\" delimiters, and execute JavaScript in \"evaluate\" delimiters. Data\n * properties may be accessed as free variables in the template. If a setting\n * object is given, it takes precedence over `_.templateSettings` values.\n *\n * **Note:** In the development build `_.template` utilizes\n * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl)\n * for easier debugging.\n *\n * For more information on precompiling templates see\n * [lodash's custom builds documentation](https://lodash.com/custom-builds).\n *\n * For more information on Chrome extension sandboxes see\n * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The template string.\n * @param {Object} [options={}] The options object.\n * @param {RegExp} [options.escape=_.templateSettings.escape]\n * The HTML \"escape\" delimiter.\n * @param {RegExp} [options.evaluate=_.templateSettings.evaluate]\n * The \"evaluate\" delimiter.\n * @param {Object} [options.imports=_.templateSettings.imports]\n * An object to import into the template as free variables.\n * @param {RegExp} [options.interpolate=_.templateSettings.interpolate]\n * The \"interpolate\" delimiter.\n * @param {string} [options.sourceURL='lodash.templateSources[n]']\n * The sourceURL of the compiled template.\n * @param {string} [options.variable='obj']\n * The data object variable name.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the compiled template function.\n * @example\n *\n * // Use the \"interpolate\" delimiter to create a compiled template.\n * var compiled = _.template('hello <%= user %>!');\n * compiled({ 'user': 'fred' });\n * // => 'hello fred!'\n *\n * // Use the HTML \"escape\" delimiter to escape data property values.\n * var compiled = _.template('<%- value %>');\n * compiled({ 'value': '`.\n this.sequenceIndex = Number(c === CharCodes.Lt);\n }\n }\n stateCDATASequence(c) {\n if (c === Sequences.Cdata[this.sequenceIndex]) {\n if (++this.sequenceIndex === Sequences.Cdata.length) {\n this.state = State.InCommentLike;\n this.currentSequence = Sequences.CdataEnd;\n this.sequenceIndex = 0;\n this.sectionStart = this.index + 1;\n }\n }\n else {\n this.sequenceIndex = 0;\n this.state = State.InDeclaration;\n this.stateInDeclaration(c); // Reconsume the character\n }\n }\n /**\n * When we wait for one specific character, we can speed things up\n * by skipping through the buffer until we find it.\n *\n * @returns Whether the character was found.\n */\n fastForwardTo(c) {\n while (++this.index < this.buffer.length + this.offset) {\n if (this.buffer.charCodeAt(this.index - this.offset) === c) {\n return true;\n }\n }\n /*\n * We increment the index at the end of the `parse` loop,\n * so set it to `buffer.length - 1` here.\n *\n * TODO: Refactor `parse` to increment index before calling states.\n */\n this.index = this.buffer.length + this.offset - 1;\n return false;\n }\n /**\n * Comments and CDATA end with `-->` and `]]>`.\n *\n * Their common qualities are:\n * - Their end sequences have a distinct character they start with.\n * - That character is then repeated, so we have to check multiple repeats.\n * - All characters but the start character of the sequence can be skipped.\n */\n stateInCommentLike(c) {\n if (c === this.currentSequence[this.sequenceIndex]) {\n if (++this.sequenceIndex === this.currentSequence.length) {\n if (this.currentSequence === Sequences.CdataEnd) {\n this.cbs.oncdata(this.sectionStart, this.index, 2);\n }\n else {\n this.cbs.oncomment(this.sectionStart, this.index, 2);\n }\n this.sequenceIndex = 0;\n this.sectionStart = this.index + 1;\n this.state = State.Text;\n }\n }\n else if (this.sequenceIndex === 0) {\n // Fast-forward to the first character of the sequence\n if (this.fastForwardTo(this.currentSequence[0])) {\n this.sequenceIndex = 1;\n }\n }\n else if (c !== this.currentSequence[this.sequenceIndex - 1]) {\n // Allow long sequences, eg. --->, ]]]>\n this.sequenceIndex = 0;\n }\n }\n /**\n * HTML only allows ASCII alpha characters (a-z and A-Z) at the beginning of a tag name.\n *\n * XML allows a lot more characters here (@see https://www.w3.org/TR/REC-xml/#NT-NameStartChar).\n * We allow anything that wouldn't end the tag.\n */\n isTagStartChar(c) {\n return this.xmlMode ? !isEndOfTagSection(c) : isASCIIAlpha(c);\n }\n startSpecial(sequence, offset) {\n this.isSpecial = true;\n this.currentSequence = sequence;\n this.sequenceIndex = offset;\n this.state = State.SpecialStartSequence;\n }\n stateBeforeTagName(c) {\n if (c === CharCodes.ExclamationMark) {\n this.state = State.BeforeDeclaration;\n this.sectionStart = this.index + 1;\n }\n else if (c === CharCodes.Questionmark) {\n this.state = State.InProcessingInstruction;\n this.sectionStart = this.index + 1;\n }\n else if (this.isTagStartChar(c)) {\n const lower = c | 0x20;\n this.sectionStart = this.index;\n if (this.xmlMode) {\n this.state = State.InTagName;\n }\n else if (lower === Sequences.ScriptEnd[2]) {\n this.state = State.BeforeSpecialS;\n }\n else if (lower === Sequences.TitleEnd[2]) {\n this.state = State.BeforeSpecialT;\n }\n else {\n this.state = State.InTagName;\n }\n }\n else if (c === CharCodes.Slash) {\n this.state = State.BeforeClosingTagName;\n }\n else {\n this.state = State.Text;\n this.stateText(c);\n }\n }\n stateInTagName(c) {\n if (isEndOfTagSection(c)) {\n this.cbs.onopentagname(this.sectionStart, this.index);\n this.sectionStart = -1;\n this.state = State.BeforeAttributeName;\n this.stateBeforeAttributeName(c);\n }\n }\n stateBeforeClosingTagName(c) {\n if (isWhitespace(c)) {\n // Ignore\n }\n else if (c === CharCodes.Gt) {\n this.state = State.Text;\n }\n else {\n this.state = this.isTagStartChar(c)\n ? State.InClosingTagName\n : State.InSpecialComment;\n this.sectionStart = this.index;\n }\n }\n stateInClosingTagName(c) {\n if (c === CharCodes.Gt || isWhitespace(c)) {\n this.cbs.onclosetag(this.sectionStart, this.index);\n this.sectionStart = -1;\n this.state = State.AfterClosingTagName;\n this.stateAfterClosingTagName(c);\n }\n }\n stateAfterClosingTagName(c) {\n // Skip everything until \">\"\n if (c === CharCodes.Gt || this.fastForwardTo(CharCodes.Gt)) {\n this.state = State.Text;\n this.sectionStart = this.index + 1;\n }\n }\n stateBeforeAttributeName(c) {\n if (c === CharCodes.Gt) {\n this.cbs.onopentagend(this.index);\n if (this.isSpecial) {\n this.state = State.InSpecialTag;\n this.sequenceIndex = 0;\n }\n else {\n this.state = State.Text;\n }\n this.sectionStart = this.index + 1;\n }\n else if (c === CharCodes.Slash) {\n this.state = State.InSelfClosingTag;\n }\n else if (!isWhitespace(c)) {\n this.state = State.InAttributeName;\n this.sectionStart = this.index;\n }\n }\n stateInSelfClosingTag(c) {\n if (c === CharCodes.Gt) {\n this.cbs.onselfclosingtag(this.index);\n this.state = State.Text;\n this.sectionStart = this.index + 1;\n this.isSpecial = false; // Reset special state, in case of self-closing special tags\n }\n else if (!isWhitespace(c)) {\n this.state = State.BeforeAttributeName;\n this.stateBeforeAttributeName(c);\n }\n }\n stateInAttributeName(c) {\n if (c === CharCodes.Eq || isEndOfTagSection(c)) {\n this.cbs.onattribname(this.sectionStart, this.index);\n this.sectionStart = this.index;\n this.state = State.AfterAttributeName;\n this.stateAfterAttributeName(c);\n }\n }\n stateAfterAttributeName(c) {\n if (c === CharCodes.Eq) {\n this.state = State.BeforeAttributeValue;\n }\n else if (c === CharCodes.Slash || c === CharCodes.Gt) {\n this.cbs.onattribend(QuoteType.NoValue, this.sectionStart);\n this.sectionStart = -1;\n this.state = State.BeforeAttributeName;\n this.stateBeforeAttributeName(c);\n }\n else if (!isWhitespace(c)) {\n this.cbs.onattribend(QuoteType.NoValue, this.sectionStart);\n this.state = State.InAttributeName;\n this.sectionStart = this.index;\n }\n }\n stateBeforeAttributeValue(c) {\n if (c === CharCodes.DoubleQuote) {\n this.state = State.InAttributeValueDq;\n this.sectionStart = this.index + 1;\n }\n else if (c === CharCodes.SingleQuote) {\n this.state = State.InAttributeValueSq;\n this.sectionStart = this.index + 1;\n }\n else if (!isWhitespace(c)) {\n this.sectionStart = this.index;\n this.state = State.InAttributeValueNq;\n this.stateInAttributeValueNoQuotes(c); // Reconsume token\n }\n }\n handleInAttributeValue(c, quote) {\n if (c === quote ||\n (!this.decodeEntities && this.fastForwardTo(quote))) {\n this.cbs.onattribdata(this.sectionStart, this.index);\n this.sectionStart = -1;\n this.cbs.onattribend(quote === CharCodes.DoubleQuote\n ? QuoteType.Double\n : QuoteType.Single, this.index + 1);\n this.state = State.BeforeAttributeName;\n }\n else if (this.decodeEntities && c === CharCodes.Amp) {\n this.startEntity();\n }\n }\n stateInAttributeValueDoubleQuotes(c) {\n this.handleInAttributeValue(c, CharCodes.DoubleQuote);\n }\n stateInAttributeValueSingleQuotes(c) {\n this.handleInAttributeValue(c, CharCodes.SingleQuote);\n }\n stateInAttributeValueNoQuotes(c) {\n if (isWhitespace(c) || c === CharCodes.Gt) {\n this.cbs.onattribdata(this.sectionStart, this.index);\n this.sectionStart = -1;\n this.cbs.onattribend(QuoteType.Unquoted, this.index);\n this.state = State.BeforeAttributeName;\n this.stateBeforeAttributeName(c);\n }\n else if (this.decodeEntities && c === CharCodes.Amp) {\n this.startEntity();\n }\n }\n stateBeforeDeclaration(c) {\n if (c === CharCodes.OpeningSquareBracket) {\n this.state = State.CDATASequence;\n this.sequenceIndex = 0;\n }\n else {\n this.state =\n c === CharCodes.Dash\n ? State.BeforeComment\n : State.InDeclaration;\n }\n }\n stateInDeclaration(c) {\n if (c === CharCodes.Gt || this.fastForwardTo(CharCodes.Gt)) {\n this.cbs.ondeclaration(this.sectionStart, this.index);\n this.state = State.Text;\n this.sectionStart = this.index + 1;\n }\n }\n stateInProcessingInstruction(c) {\n if (c === CharCodes.Gt || this.fastForwardTo(CharCodes.Gt)) {\n this.cbs.onprocessinginstruction(this.sectionStart, this.index);\n this.state = State.Text;\n this.sectionStart = this.index + 1;\n }\n }\n stateBeforeComment(c) {\n if (c === CharCodes.Dash) {\n this.state = State.InCommentLike;\n this.currentSequence = Sequences.CommentEnd;\n // Allow short comments (eg. )\n this.sequenceIndex = 2;\n this.sectionStart = this.index + 1;\n }\n else {\n this.state = State.InDeclaration;\n }\n }\n stateInSpecialComment(c) {\n if (c === CharCodes.Gt || this.fastForwardTo(CharCodes.Gt)) {\n this.cbs.oncomment(this.sectionStart, this.index, 0);\n this.state = State.Text;\n this.sectionStart = this.index + 1;\n }\n }\n stateBeforeSpecialS(c) {\n const lower = c | 0x20;\n if (lower === Sequences.ScriptEnd[3]) {\n this.startSpecial(Sequences.ScriptEnd, 4);\n }\n else if (lower === Sequences.StyleEnd[3]) {\n this.startSpecial(Sequences.StyleEnd, 4);\n }\n else {\n this.state = State.InTagName;\n this.stateInTagName(c); // Consume the token again\n }\n }\n stateBeforeSpecialT(c) {\n const lower = c | 0x20;\n if (lower === Sequences.TitleEnd[3]) {\n this.startSpecial(Sequences.TitleEnd, 4);\n }\n else if (lower === Sequences.TextareaEnd[3]) {\n this.startSpecial(Sequences.TextareaEnd, 4);\n }\n else {\n this.state = State.InTagName;\n this.stateInTagName(c); // Consume the token again\n }\n }\n startEntity() {\n this.baseState = this.state;\n this.state = State.InEntity;\n this.entityStart = this.index;\n this.entityDecoder.startEntity(this.xmlMode\n ? DecodingMode.Strict\n : this.baseState === State.Text ||\n this.baseState === State.InSpecialTag\n ? DecodingMode.Legacy\n : DecodingMode.Attribute);\n }\n stateInEntity() {\n const length = this.entityDecoder.write(this.buffer, this.index - this.offset);\n // If `length` is positive, we are done with the entity.\n if (length >= 0) {\n this.state = this.baseState;\n if (length === 0) {\n this.index = this.entityStart;\n }\n }\n else {\n // Mark buffer as consumed.\n this.index = this.offset + this.buffer.length - 1;\n }\n }\n /**\n * Remove data that has already been consumed from the buffer.\n */\n cleanup() {\n // If we are inside of text or attributes, emit what we already have.\n if (this.running && this.sectionStart !== this.index) {\n if (this.state === State.Text ||\n (this.state === State.InSpecialTag && this.sequenceIndex === 0)) {\n this.cbs.ontext(this.sectionStart, this.index);\n this.sectionStart = this.index;\n }\n else if (this.state === State.InAttributeValueDq ||\n this.state === State.InAttributeValueSq ||\n this.state === State.InAttributeValueNq) {\n this.cbs.onattribdata(this.sectionStart, this.index);\n this.sectionStart = this.index;\n }\n }\n }\n shouldContinue() {\n return this.index < this.buffer.length + this.offset && this.running;\n }\n /**\n * Iterates through the buffer, calling the function corresponding to the current state.\n *\n * States that are more likely to be hit are higher up, as a performance improvement.\n */\n parse() {\n while (this.shouldContinue()) {\n const c = this.buffer.charCodeAt(this.index - this.offset);\n switch (this.state) {\n case State.Text: {\n this.stateText(c);\n break;\n }\n case State.SpecialStartSequence: {\n this.stateSpecialStartSequence(c);\n break;\n }\n case State.InSpecialTag: {\n this.stateInSpecialTag(c);\n break;\n }\n case State.CDATASequence: {\n this.stateCDATASequence(c);\n break;\n }\n case State.InAttributeValueDq: {\n this.stateInAttributeValueDoubleQuotes(c);\n break;\n }\n case State.InAttributeName: {\n this.stateInAttributeName(c);\n break;\n }\n case State.InCommentLike: {\n this.stateInCommentLike(c);\n break;\n }\n case State.InSpecialComment: {\n this.stateInSpecialComment(c);\n break;\n }\n case State.BeforeAttributeName: {\n this.stateBeforeAttributeName(c);\n break;\n }\n case State.InTagName: {\n this.stateInTagName(c);\n break;\n }\n case State.InClosingTagName: {\n this.stateInClosingTagName(c);\n break;\n }\n case State.BeforeTagName: {\n this.stateBeforeTagName(c);\n break;\n }\n case State.AfterAttributeName: {\n this.stateAfterAttributeName(c);\n break;\n }\n case State.InAttributeValueSq: {\n this.stateInAttributeValueSingleQuotes(c);\n break;\n }\n case State.BeforeAttributeValue: {\n this.stateBeforeAttributeValue(c);\n break;\n }\n case State.BeforeClosingTagName: {\n this.stateBeforeClosingTagName(c);\n break;\n }\n case State.AfterClosingTagName: {\n this.stateAfterClosingTagName(c);\n break;\n }\n case State.BeforeSpecialS: {\n this.stateBeforeSpecialS(c);\n break;\n }\n case State.BeforeSpecialT: {\n this.stateBeforeSpecialT(c);\n break;\n }\n case State.InAttributeValueNq: {\n this.stateInAttributeValueNoQuotes(c);\n break;\n }\n case State.InSelfClosingTag: {\n this.stateInSelfClosingTag(c);\n break;\n }\n case State.InDeclaration: {\n this.stateInDeclaration(c);\n break;\n }\n case State.BeforeDeclaration: {\n this.stateBeforeDeclaration(c);\n break;\n }\n case State.BeforeComment: {\n this.stateBeforeComment(c);\n break;\n }\n case State.InProcessingInstruction: {\n this.stateInProcessingInstruction(c);\n break;\n }\n case State.InEntity: {\n this.stateInEntity();\n break;\n }\n }\n this.index++;\n }\n this.cleanup();\n }\n finish() {\n if (this.state === State.InEntity) {\n this.entityDecoder.end();\n this.state = this.baseState;\n }\n this.handleTrailingData();\n this.cbs.onend();\n }\n /** Handle any trailing data. */\n handleTrailingData() {\n const endIndex = this.buffer.length + this.offset;\n // If there is no remaining data, we are done.\n if (this.sectionStart >= endIndex) {\n return;\n }\n if (this.state === State.InCommentLike) {\n if (this.currentSequence === Sequences.CdataEnd) {\n this.cbs.oncdata(this.sectionStart, endIndex, 0);\n }\n else {\n this.cbs.oncomment(this.sectionStart, endIndex, 0);\n }\n }\n else if (this.state === State.InTagName ||\n this.state === State.BeforeAttributeName ||\n this.state === State.BeforeAttributeValue ||\n this.state === State.AfterAttributeName ||\n this.state === State.InAttributeName ||\n this.state === State.InAttributeValueSq ||\n this.state === State.InAttributeValueDq ||\n this.state === State.InAttributeValueNq ||\n this.state === State.InClosingTagName) {\n /*\n * If we are currently in an opening or closing tag, us not calling the\n * respective callback signals that the tag should be ignored.\n */\n }\n else {\n this.cbs.ontext(this.sectionStart, endIndex);\n }\n }\n emitCodePoint(cp, consumed) {\n if (this.baseState !== State.Text &&\n this.baseState !== State.InSpecialTag) {\n if (this.sectionStart < this.entityStart) {\n this.cbs.onattribdata(this.sectionStart, this.entityStart);\n }\n this.sectionStart = this.entityStart + consumed;\n this.index = this.sectionStart - 1;\n this.cbs.onattribentity(cp);\n }\n else {\n if (this.sectionStart < this.entityStart) {\n this.cbs.ontext(this.sectionStart, this.entityStart);\n }\n this.sectionStart = this.entityStart + consumed;\n this.index = this.sectionStart - 1;\n this.cbs.ontextentity(cp, this.sectionStart);\n }\n }\n}\n//# sourceMappingURL=Tokenizer.js.map","import Tokenizer, { QuoteType } from \"./Tokenizer.js\";\nimport { fromCodePoint } from \"entities/lib/decode.js\";\nconst formTags = new Set([\n \"input\",\n \"option\",\n \"optgroup\",\n \"select\",\n \"button\",\n \"datalist\",\n \"textarea\",\n]);\nconst pTag = new Set([\"p\"]);\nconst tableSectionTags = new Set([\"thead\", \"tbody\"]);\nconst ddtTags = new Set([\"dd\", \"dt\"]);\nconst rtpTags = new Set([\"rt\", \"rp\"]);\nconst openImpliesClose = new Map([\n [\"tr\", new Set([\"tr\", \"th\", \"td\"])],\n [\"th\", new Set([\"th\"])],\n [\"td\", new Set([\"thead\", \"th\", \"td\"])],\n [\"body\", new Set([\"head\", \"link\", \"script\"])],\n [\"li\", new Set([\"li\"])],\n [\"p\", pTag],\n [\"h1\", pTag],\n [\"h2\", pTag],\n [\"h3\", pTag],\n [\"h4\", pTag],\n [\"h5\", pTag],\n [\"h6\", pTag],\n [\"select\", formTags],\n [\"input\", formTags],\n [\"output\", formTags],\n [\"button\", formTags],\n [\"datalist\", formTags],\n [\"textarea\", formTags],\n [\"option\", new Set([\"option\"])],\n [\"optgroup\", new Set([\"optgroup\", \"option\"])],\n [\"dd\", ddtTags],\n [\"dt\", ddtTags],\n [\"address\", pTag],\n [\"article\", pTag],\n [\"aside\", pTag],\n [\"blockquote\", pTag],\n [\"details\", pTag],\n [\"div\", pTag],\n [\"dl\", pTag],\n [\"fieldset\", pTag],\n [\"figcaption\", pTag],\n [\"figure\", pTag],\n [\"footer\", pTag],\n [\"form\", pTag],\n [\"header\", pTag],\n [\"hr\", pTag],\n [\"main\", pTag],\n [\"nav\", pTag],\n [\"ol\", pTag],\n [\"pre\", pTag],\n [\"section\", pTag],\n [\"table\", pTag],\n [\"ul\", pTag],\n [\"rt\", rtpTags],\n [\"rp\", rtpTags],\n [\"tbody\", tableSectionTags],\n [\"tfoot\", tableSectionTags],\n]);\nconst voidElements = new Set([\n \"area\",\n \"base\",\n \"basefont\",\n \"br\",\n \"col\",\n \"command\",\n \"embed\",\n \"frame\",\n \"hr\",\n \"img\",\n \"input\",\n \"isindex\",\n \"keygen\",\n \"link\",\n \"meta\",\n \"param\",\n \"source\",\n \"track\",\n \"wbr\",\n]);\nconst foreignContextElements = new Set([\"math\", \"svg\"]);\nconst htmlIntegrationElements = new Set([\n \"mi\",\n \"mo\",\n \"mn\",\n \"ms\",\n \"mtext\",\n \"annotation-xml\",\n \"foreignobject\",\n \"desc\",\n \"title\",\n]);\nconst reNameEnd = /\\s|\\//;\nexport class Parser {\n constructor(cbs, options = {}) {\n var _a, _b, _c, _d, _e, _f;\n this.options = options;\n /** The start index of the last event. */\n this.startIndex = 0;\n /** The end index of the last event. */\n this.endIndex = 0;\n /**\n * Store the start index of the current open tag,\n * so we can update the start index for attributes.\n */\n this.openTagStart = 0;\n this.tagname = \"\";\n this.attribname = \"\";\n this.attribvalue = \"\";\n this.attribs = null;\n this.stack = [];\n this.buffers = [];\n this.bufferOffset = 0;\n /** The index of the last written buffer. Used when resuming after a `pause()`. */\n this.writeIndex = 0;\n /** Indicates whether the parser has finished running / `.end` has been called. */\n this.ended = false;\n this.cbs = cbs !== null && cbs !== void 0 ? cbs : {};\n this.htmlMode = !this.options.xmlMode;\n this.lowerCaseTagNames = (_a = options.lowerCaseTags) !== null && _a !== void 0 ? _a : this.htmlMode;\n this.lowerCaseAttributeNames =\n (_b = options.lowerCaseAttributeNames) !== null && _b !== void 0 ? _b : this.htmlMode;\n this.recognizeSelfClosing =\n (_c = options.recognizeSelfClosing) !== null && _c !== void 0 ? _c : !this.htmlMode;\n this.tokenizer = new ((_d = options.Tokenizer) !== null && _d !== void 0 ? _d : Tokenizer)(this.options, this);\n this.foreignContext = [!this.htmlMode];\n (_f = (_e = this.cbs).onparserinit) === null || _f === void 0 ? void 0 : _f.call(_e, this);\n }\n // Tokenizer event handlers\n /** @internal */\n ontext(start, endIndex) {\n var _a, _b;\n const data = this.getSlice(start, endIndex);\n this.endIndex = endIndex - 1;\n (_b = (_a = this.cbs).ontext) === null || _b === void 0 ? void 0 : _b.call(_a, data);\n this.startIndex = endIndex;\n }\n /** @internal */\n ontextentity(cp, endIndex) {\n var _a, _b;\n this.endIndex = endIndex - 1;\n (_b = (_a = this.cbs).ontext) === null || _b === void 0 ? void 0 : _b.call(_a, fromCodePoint(cp));\n this.startIndex = endIndex;\n }\n /**\n * Checks if the current tag is a void element. Override this if you want\n * to specify your own additional void elements.\n */\n isVoidElement(name) {\n return this.htmlMode && voidElements.has(name);\n }\n /** @internal */\n onopentagname(start, endIndex) {\n this.endIndex = endIndex;\n let name = this.getSlice(start, endIndex);\n if (this.lowerCaseTagNames) {\n name = name.toLowerCase();\n }\n this.emitOpenTag(name);\n }\n emitOpenTag(name) {\n var _a, _b, _c, _d;\n this.openTagStart = this.startIndex;\n this.tagname = name;\n const impliesClose = this.htmlMode && openImpliesClose.get(name);\n if (impliesClose) {\n while (this.stack.length > 0 && impliesClose.has(this.stack[0])) {\n const element = this.stack.shift();\n (_b = (_a = this.cbs).onclosetag) === null || _b === void 0 ? void 0 : _b.call(_a, element, true);\n }\n }\n if (!this.isVoidElement(name)) {\n this.stack.unshift(name);\n if (this.htmlMode) {\n if (foreignContextElements.has(name)) {\n this.foreignContext.unshift(true);\n }\n else if (htmlIntegrationElements.has(name)) {\n this.foreignContext.unshift(false);\n }\n }\n }\n (_d = (_c = this.cbs).onopentagname) === null || _d === void 0 ? void 0 : _d.call(_c, name);\n if (this.cbs.onopentag)\n this.attribs = {};\n }\n endOpenTag(isImplied) {\n var _a, _b;\n this.startIndex = this.openTagStart;\n if (this.attribs) {\n (_b = (_a = this.cbs).onopentag) === null || _b === void 0 ? void 0 : _b.call(_a, this.tagname, this.attribs, isImplied);\n this.attribs = null;\n }\n if (this.cbs.onclosetag && this.isVoidElement(this.tagname)) {\n this.cbs.onclosetag(this.tagname, true);\n }\n this.tagname = \"\";\n }\n /** @internal */\n onopentagend(endIndex) {\n this.endIndex = endIndex;\n this.endOpenTag(false);\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n /** @internal */\n onclosetag(start, endIndex) {\n var _a, _b, _c, _d, _e, _f, _g, _h;\n this.endIndex = endIndex;\n let name = this.getSlice(start, endIndex);\n if (this.lowerCaseTagNames) {\n name = name.toLowerCase();\n }\n if (this.htmlMode &&\n (foreignContextElements.has(name) ||\n htmlIntegrationElements.has(name))) {\n this.foreignContext.shift();\n }\n if (!this.isVoidElement(name)) {\n const pos = this.stack.indexOf(name);\n if (pos !== -1) {\n for (let index = 0; index <= pos; index++) {\n const element = this.stack.shift();\n // We know the stack has sufficient elements.\n (_b = (_a = this.cbs).onclosetag) === null || _b === void 0 ? void 0 : _b.call(_a, element, index !== pos);\n }\n }\n else if (this.htmlMode && name === \"p\") {\n // Implicit open before close\n this.emitOpenTag(\"p\");\n this.closeCurrentTag(true);\n }\n }\n else if (this.htmlMode && name === \"br\") {\n // We can't use `emitOpenTag` for implicit open, as `br` would be implicitly closed.\n (_d = (_c = this.cbs).onopentagname) === null || _d === void 0 ? void 0 : _d.call(_c, \"br\");\n (_f = (_e = this.cbs).onopentag) === null || _f === void 0 ? void 0 : _f.call(_e, \"br\", {}, true);\n (_h = (_g = this.cbs).onclosetag) === null || _h === void 0 ? void 0 : _h.call(_g, \"br\", false);\n }\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n /** @internal */\n onselfclosingtag(endIndex) {\n this.endIndex = endIndex;\n if (this.recognizeSelfClosing || this.foreignContext[0]) {\n this.closeCurrentTag(false);\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n else {\n // Ignore the fact that the tag is self-closing.\n this.onopentagend(endIndex);\n }\n }\n closeCurrentTag(isOpenImplied) {\n var _a, _b;\n const name = this.tagname;\n this.endOpenTag(isOpenImplied);\n // Self-closing tags will be on the top of the stack\n if (this.stack[0] === name) {\n // If the opening tag isn't implied, the closing tag has to be implied.\n (_b = (_a = this.cbs).onclosetag) === null || _b === void 0 ? void 0 : _b.call(_a, name, !isOpenImplied);\n this.stack.shift();\n }\n }\n /** @internal */\n onattribname(start, endIndex) {\n this.startIndex = start;\n const name = this.getSlice(start, endIndex);\n this.attribname = this.lowerCaseAttributeNames\n ? name.toLowerCase()\n : name;\n }\n /** @internal */\n onattribdata(start, endIndex) {\n this.attribvalue += this.getSlice(start, endIndex);\n }\n /** @internal */\n onattribentity(cp) {\n this.attribvalue += fromCodePoint(cp);\n }\n /** @internal */\n onattribend(quote, endIndex) {\n var _a, _b;\n this.endIndex = endIndex;\n (_b = (_a = this.cbs).onattribute) === null || _b === void 0 ? void 0 : _b.call(_a, this.attribname, this.attribvalue, quote === QuoteType.Double\n ? '\"'\n : quote === QuoteType.Single\n ? \"'\"\n : quote === QuoteType.NoValue\n ? undefined\n : null);\n if (this.attribs &&\n !Object.prototype.hasOwnProperty.call(this.attribs, this.attribname)) {\n this.attribs[this.attribname] = this.attribvalue;\n }\n this.attribvalue = \"\";\n }\n getInstructionName(value) {\n const index = value.search(reNameEnd);\n let name = index < 0 ? value : value.substr(0, index);\n if (this.lowerCaseTagNames) {\n name = name.toLowerCase();\n }\n return name;\n }\n /** @internal */\n ondeclaration(start, endIndex) {\n this.endIndex = endIndex;\n const value = this.getSlice(start, endIndex);\n if (this.cbs.onprocessinginstruction) {\n const name = this.getInstructionName(value);\n this.cbs.onprocessinginstruction(`!${name}`, `!${value}`);\n }\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n /** @internal */\n onprocessinginstruction(start, endIndex) {\n this.endIndex = endIndex;\n const value = this.getSlice(start, endIndex);\n if (this.cbs.onprocessinginstruction) {\n const name = this.getInstructionName(value);\n this.cbs.onprocessinginstruction(`?${name}`, `?${value}`);\n }\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n /** @internal */\n oncomment(start, endIndex, offset) {\n var _a, _b, _c, _d;\n this.endIndex = endIndex;\n (_b = (_a = this.cbs).oncomment) === null || _b === void 0 ? void 0 : _b.call(_a, this.getSlice(start, endIndex - offset));\n (_d = (_c = this.cbs).oncommentend) === null || _d === void 0 ? void 0 : _d.call(_c);\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n /** @internal */\n oncdata(start, endIndex, offset) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;\n this.endIndex = endIndex;\n const value = this.getSlice(start, endIndex - offset);\n if (!this.htmlMode || this.options.recognizeCDATA) {\n (_b = (_a = this.cbs).oncdatastart) === null || _b === void 0 ? void 0 : _b.call(_a);\n (_d = (_c = this.cbs).ontext) === null || _d === void 0 ? void 0 : _d.call(_c, value);\n (_f = (_e = this.cbs).oncdataend) === null || _f === void 0 ? void 0 : _f.call(_e);\n }\n else {\n (_h = (_g = this.cbs).oncomment) === null || _h === void 0 ? void 0 : _h.call(_g, `[CDATA[${value}]]`);\n (_k = (_j = this.cbs).oncommentend) === null || _k === void 0 ? void 0 : _k.call(_j);\n }\n // Set `startIndex` for next node\n this.startIndex = endIndex + 1;\n }\n /** @internal */\n onend() {\n var _a, _b;\n if (this.cbs.onclosetag) {\n // Set the end index for all remaining tags\n this.endIndex = this.startIndex;\n for (let index = 0; index < this.stack.length; index++) {\n this.cbs.onclosetag(this.stack[index], true);\n }\n }\n (_b = (_a = this.cbs).onend) === null || _b === void 0 ? void 0 : _b.call(_a);\n }\n /**\n * Resets the parser to a blank state, ready to parse a new HTML document\n */\n reset() {\n var _a, _b, _c, _d;\n (_b = (_a = this.cbs).onreset) === null || _b === void 0 ? void 0 : _b.call(_a);\n this.tokenizer.reset();\n this.tagname = \"\";\n this.attribname = \"\";\n this.attribs = null;\n this.stack.length = 0;\n this.startIndex = 0;\n this.endIndex = 0;\n (_d = (_c = this.cbs).onparserinit) === null || _d === void 0 ? void 0 : _d.call(_c, this);\n this.buffers.length = 0;\n this.foreignContext.length = 0;\n this.foreignContext.unshift(!this.htmlMode);\n this.bufferOffset = 0;\n this.writeIndex = 0;\n this.ended = false;\n }\n /**\n * Resets the parser, then parses a complete document and\n * pushes it to the handler.\n *\n * @param data Document to parse.\n */\n parseComplete(data) {\n this.reset();\n this.end(data);\n }\n getSlice(start, end) {\n while (start - this.bufferOffset >= this.buffers[0].length) {\n this.shiftBuffer();\n }\n let slice = this.buffers[0].slice(start - this.bufferOffset, end - this.bufferOffset);\n while (end - this.bufferOffset > this.buffers[0].length) {\n this.shiftBuffer();\n slice += this.buffers[0].slice(0, end - this.bufferOffset);\n }\n return slice;\n }\n shiftBuffer() {\n this.bufferOffset += this.buffers[0].length;\n this.writeIndex--;\n this.buffers.shift();\n }\n /**\n * Parses a chunk of data and calls the corresponding callbacks.\n *\n * @param chunk Chunk to parse.\n */\n write(chunk) {\n var _a, _b;\n if (this.ended) {\n (_b = (_a = this.cbs).onerror) === null || _b === void 0 ? void 0 : _b.call(_a, new Error(\".write() after done!\"));\n return;\n }\n this.buffers.push(chunk);\n if (this.tokenizer.running) {\n this.tokenizer.write(chunk);\n this.writeIndex++;\n }\n }\n /**\n * Parses the end of the buffer and clears the stack, calls onend.\n *\n * @param chunk Optional final chunk to parse.\n */\n end(chunk) {\n var _a, _b;\n if (this.ended) {\n (_b = (_a = this.cbs).onerror) === null || _b === void 0 ? void 0 : _b.call(_a, new Error(\".end() after done!\"));\n return;\n }\n if (chunk)\n this.write(chunk);\n this.ended = true;\n this.tokenizer.end();\n }\n /**\n * Pauses parsing. The parser won't emit events until `resume` is called.\n */\n pause() {\n this.tokenizer.pause();\n }\n /**\n * Resumes parsing after `pause` was called.\n */\n resume() {\n this.tokenizer.resume();\n while (this.tokenizer.running &&\n this.writeIndex < this.buffers.length) {\n this.tokenizer.write(this.buffers[this.writeIndex++]);\n }\n if (this.ended)\n this.tokenizer.end();\n }\n /**\n * Alias of `write`, for backwards compatibility.\n *\n * @param chunk Chunk to parse.\n * @deprecated\n */\n parseChunk(chunk) {\n this.write(chunk);\n }\n /**\n * Alias of `end`, for backwards compatibility.\n *\n * @param chunk Optional final chunk to parse.\n * @deprecated\n */\n done(chunk) {\n this.end(chunk);\n }\n}\n//# sourceMappingURL=Parser.js.map","import { Parser } from \"./Parser.js\";\nexport { Parser } from \"./Parser.js\";\nimport { DomHandler, } from \"domhandler\";\nexport { DomHandler, \n// Old name for DomHandler\nDomHandler as DefaultHandler, } from \"domhandler\";\n// Helper methods\n/**\n * Parses the data, returns the resulting document.\n *\n * @param data The data that should be parsed.\n * @param options Optional options for the parser and DOM handler.\n */\nexport function parseDocument(data, options) {\n const handler = new DomHandler(undefined, options);\n new Parser(handler, options).end(data);\n return handler.root;\n}\n/**\n * Parses data, returns an array of the root nodes.\n *\n * Note that the root nodes still have a `Document` node as their parent.\n * Use `parseDocument` to get the `Document` node instead.\n *\n * @param data The data that should be parsed.\n * @param options Optional options for the parser and DOM handler.\n * @deprecated Use `parseDocument` instead.\n */\nexport function parseDOM(data, options) {\n return parseDocument(data, options).children;\n}\n/**\n * Creates a parser instance, with an attached DOM handler.\n *\n * @param callback A callback that will be called once parsing has been completed, with the resulting document.\n * @param options Optional options for the parser and DOM handler.\n * @param elementCallback An optional callback that will be called every time a tag has been completed inside of the DOM.\n */\nexport function createDocumentStream(callback, options, elementCallback) {\n const handler = new DomHandler((error) => callback(error, handler.root), options, elementCallback);\n return new Parser(handler, options);\n}\n/**\n * Creates a parser instance, with an attached DOM handler.\n *\n * @param callback A callback that will be called once parsing has been completed, with an array of root nodes.\n * @param options Optional options for the parser and DOM handler.\n * @param elementCallback An optional callback that will be called every time a tag has been completed inside of the DOM.\n * @deprecated Use `createDocumentStream` instead.\n */\nexport function createDomStream(callback, options, elementCallback) {\n const handler = new DomHandler(callback, options, elementCallback);\n return new Parser(handler, options);\n}\nexport { default as Tokenizer, QuoteType, } from \"./Tokenizer.js\";\n/*\n * All of the following exports exist for backwards-compatibility.\n * They should probably be removed eventually.\n */\nexport * as ElementType from \"domelementtype\";\nimport { getFeed } from \"domutils\";\nexport { getFeed } from \"domutils\";\nconst parseFeedDefaultOptions = { xmlMode: true };\n/**\n * Parse a feed.\n *\n * @param feed The feed that should be parsed, as a string.\n * @param options Optionally, options for parsing. When using this, you should set `xmlMode` to `true`.\n */\nexport function parseFeed(feed, options = parseFeedDefaultOptions) {\n return getFeed(parseDOM(feed, options));\n}\nexport * as DomUtils from \"domutils\";\n//# sourceMappingURL=index.js.map","import { getLoad } from './load.js';\nimport { getParse } from './parse.js';\nimport { renderWithParse5, parseWithParse5 } from './parsers/parse5-adapter.js';\nimport renderWithHtmlparser2 from 'dom-serializer';\nimport { parseDocument as parseWithHtmlparser2 } from 'htmlparser2';\nconst parse = getParse((content, options, isDocument, context) => options._useHtmlParser2\n ? parseWithHtmlparser2(content, options)\n : parseWithParse5(content, options, isDocument, context));\n// Duplicate docs due to https://github.com/TypeStrong/typedoc/issues/1616\n/**\n * Create a querying function, bound to a document created from the provided\n * markup.\n *\n * Note that similar to web browser contexts, this operation may introduce\n * ``, ``, and `` elements; set `isDocument` to `false` to\n * switch to fragment mode and disable this.\n *\n * @category Loading\n * @param content - Markup to be loaded.\n * @param options - Options for the created instance.\n * @param isDocument - Allows parser to be switched to fragment mode.\n * @returns The loaded document.\n * @see {@link https://cheerio.js.org#loading} for additional usage information.\n */\nexport const load = getLoad(parse, (dom, options) => options._useHtmlParser2\n ? renderWithHtmlparser2(dom, options)\n : renderWithParse5(dom));\n//# sourceMappingURL=load-parse.js.map","exports = module.exports = debug;\n\nfunction debug(label) {\n return _debug.bind(null, label);\n}\n\nfunction _debug(label) {\n var args = [].slice.call(arguments, 1);\n args.unshift('[' + label + ']');\n process.stderr.write(args.join(' ') + '\\n');\n}","var DEBUG = false; // `true` to print debugging info.\nvar TIMER = false; // `true` to time calls to `lex()` and print the results.\n\nvar debug = require('./debug')('lex');\n\nexports = module.exports = lex;\n\n/**\n * Convert a CSS string into an array of lexical tokens.\n *\n * @param {String} css CSS\n * @returns {Array} lexical tokens\n */\nfunction lex(css) {\n var start; // Debug timer start.\n\n var buffer = ''; // Character accumulator\n var ch; // Current character\n var column = 0; // Current source column number\n var cursor = -1; // Current source cursor position\n var depth = 0; // Current nesting depth\n var line = 1; // Current source line number\n var state = 'before-selector'; // Current state\n var stack = [state]; // State stack\n var token = {}; // Current token\n var tokens = []; // Token accumulator\n\n // Supported @-rules, in roughly descending order of usage probability.\n var atRules = [\n 'media',\n 'keyframes',\n { name: '-webkit-keyframes', type: 'keyframes', prefix: '-webkit-' },\n { name: '-moz-keyframes', type: 'keyframes', prefix: '-moz-' },\n { name: '-ms-keyframes', type: 'keyframes', prefix: '-ms-' },\n { name: '-o-keyframes', type: 'keyframes', prefix: '-o-' },\n 'font-face',\n { name: 'import', state: 'before-at-value' },\n { name: 'charset', state: 'before-at-value' },\n 'supports',\n 'viewport',\n { name: 'namespace', state: 'before-at-value' },\n 'document',\n { name: '-moz-document', type: 'document', prefix: '-moz-' },\n 'page'\n ];\n\n // -- Functions ------------------------------------------------------------\n\n /**\n * Advance the character cursor and return the next character.\n *\n * @returns {String} The next character.\n */\n function getCh() {\n skip();\n return css[cursor];\n }\n\n /**\n * Return the state at the given index in the stack.\n * The stack is LIFO so indexing is from the right.\n *\n * @param {Number} [index=0] Index to return.\n * @returns {String} state\n */\n function getState(index) {\n return index ? stack[stack.length - 1 - index] : state;\n }\n\n /**\n * Look ahead for a string beginning from the next position. The string\n * being looked for must start at the next position.\n *\n * @param {String} str The string to look for.\n * @returns {Boolean} Whether the string was found.\n */\n function isNextString(str) {\n var start = cursor + 1;\n return (str === css.slice(start, start + str.length));\n }\n\n /**\n * Find the start position of a substring beginning from the next\n * position. The string being looked for may begin anywhere.\n *\n * @param {String} str The substring to look for.\n * @returns {Number|false} The position, or `false` if not found.\n */\n function find(str) {\n var pos = css.slice(cursor).indexOf(str);\n\n return pos > 0 ? pos : false;\n }\n\n /**\n * Determine whether a character is next.\n *\n * @param {String} ch Character.\n * @returns {Boolean} Whether the character is next.\n */\n function isNextChar(ch) {\n return ch === peek(1);\n }\n\n /**\n * Return the character at the given cursor offset. The offset is relative\n * to the cursor, so negative values move backwards.\n *\n * @param {Number} [offset=1] Cursor offset.\n * @returns {String} Character.\n */\n function peek(offset) {\n return css[cursor + (offset || 1)];\n }\n\n /**\n * Remove the current state from the stack and set the new current state.\n *\n * @returns {String} The removed state.\n */\n function popState() {\n var removed = stack.pop();\n state = stack[stack.length - 1];\n\n return removed;\n }\n\n /**\n * Set the current state and add it to the stack.\n *\n * @param {String} newState The new state.\n * @returns {Number} The new stack length.\n */\n function pushState(newState) {\n state = newState;\n stack.push(state);\n\n return stack.length;\n }\n\n /**\n * Replace the current state with a new state.\n *\n * @param {String} newState The new state.\n * @returns {String} The replaced state.\n */\n function replaceState(newState) {\n var previousState = state;\n stack[stack.length - 1] = state = newState;\n\n return previousState;\n }\n\n /**\n * Move the character cursor. Positive numbers move the cursor forward.\n * Negative numbers are not supported!\n *\n * @param {Number} [n=1] Number of characters to skip.\n */\n function skip(n) {\n if ((n || 1) == 1) {\n if (css[cursor] == '\\n') {\n line++;\n column = 1;\n } else {\n column++;\n }\n cursor++;\n } else {\n var skipStr = css.slice(cursor, cursor + n).split('\\n');\n if (skipStr.length > 1) {\n line += skipStr.length - 1;\n column = 1;\n }\n column += skipStr[skipStr.length - 1].length;\n cursor = cursor + n;\n }\n }\n\n /**\n * Add the current token to the pile and reset the buffer.\n */\n function addToken() {\n token.end = {\n line: line,\n col: column\n };\n\n DEBUG && debug('addToken:', JSON.stringify(token, null, 2));\n\n tokens.push(token);\n\n buffer = '';\n token = {};\n }\n\n /**\n * Set the current token.\n *\n * @param {String} type Token type.\n */\n function initializeToken(type) {\n token = {\n type: type,\n start: {\n line: line,\n col : column\n }\n };\n }\n\n // -- Main Loop ------------------------------------------------------------\n\n /*\n The main loop is a state machine that reads in one character at a time,\n and determines what to do based on the current state and character.\n This is implemented as a series of nested `switch` statements and the\n case orders have been mildly optimized based on rough probabilities\n calculated by processing a small sample of real-world CSS.\n\n Further optimization (such as a dispatch table) shouldn't be necessary\n since the total number of cases is very low.\n */\n\n TIMER && (start = Date.now());\n\n while (ch = getCh()) {\n DEBUG && debug(ch, getState());\n\n // column += 1;\n\n switch (ch) {\n // Space\n case ' ':\n switch (getState()) {\n case 'selector':\n case 'value':\n case 'value-paren':\n case 'at-group':\n case 'at-value':\n case 'comment':\n case 'double-string':\n case 'single-string':\n buffer += ch;\n break;\n }\n break;\n\n // Newline or tab\n case '\\n':\n case '\\t':\n case '\\r':\n case '\\f':\n switch (getState()) {\n case 'value':\n case 'value-paren':\n case 'at-group':\n case 'comment':\n case 'single-string':\n case 'double-string':\n case 'selector':\n buffer += ch;\n break;\n\n case 'at-value':\n // Tokenize an @-rule if a semi-colon was omitted.\n if ('\\n' === ch) {\n token.value = buffer.trim();\n addToken();\n popState();\n }\n break;\n }\n\n // if ('\\n' === ch) {\n // column = 0;\n // line += 1;\n // }\n break;\n\n case ':':\n switch (getState()) {\n case 'name':\n token.name = buffer.trim();\n buffer = '';\n\n replaceState('before-value');\n break;\n\n case 'before-selector':\n buffer += ch;\n\n initializeToken('selector');\n pushState('selector');\n break;\n\n case 'before-value':\n replaceState('value');\n buffer += ch;\n break;\n\n default:\n buffer += ch;\n break;\n }\n break;\n\n case ';':\n switch (getState()) {\n case 'name':\n case 'before-value':\n case 'value':\n // Tokenize a declaration\n // if value is empty skip the declaration\n if (buffer.trim().length > 0) {\n token.value = buffer.trim(),\n addToken();\n }\n replaceState('before-name');\n break;\n\n case 'value-paren':\n // Insignificant semi-colon\n buffer += ch;\n break;\n\n case 'at-value':\n // Tokenize an @-rule\n token.value = buffer.trim();\n addToken();\n popState();\n break;\n\n case 'before-name':\n // Extraneous semi-colon\n break;\n\n default:\n buffer += ch;\n break;\n }\n break;\n\n case '{':\n switch (getState()) {\n case 'selector':\n // If the sequence is `\\{` then assume that the brace should be escaped.\n if (peek(-1) === '\\\\') {\n buffer += ch;\n break;\n }\n\n // Tokenize a selector\n token.text = buffer.trim();\n addToken();\n replaceState('before-name');\n depth = depth + 1;\n break;\n\n case 'at-group':\n // Tokenize an @-group\n token.name = buffer.trim();\n\n // XXX: @-rules are starting to get hairy\n switch (token.type) {\n case 'font-face':\n case 'viewport' :\n case 'page' :\n pushState('before-name');\n break;\n\n default:\n pushState('before-selector');\n }\n\n addToken();\n depth = depth + 1;\n break;\n\n case 'name':\n case 'at-rule':\n // Tokenize a declaration or an @-rule\n token.name = buffer.trim();\n addToken();\n pushState('before-name');\n depth = depth + 1;\n break;\n\n case 'comment':\n case 'double-string':\n case 'single-string':\n // Ignore braces in comments and strings\n buffer += ch;\n break;\n case 'before-value':\n replaceState('value');\n buffer += ch;\n break;\n }\n\n break;\n\n case '}':\n switch (getState()) {\n case 'before-name':\n case 'name':\n case 'before-value':\n case 'value':\n // If the buffer contains anything, it is a value\n if (buffer) {\n token.value = buffer.trim();\n }\n\n // If the current token has a name and a value it should be tokenized.\n if (token.name && token.value) {\n addToken();\n }\n\n // Leave the block\n initializeToken('end');\n addToken();\n popState();\n\n // We might need to leave again.\n // XXX: What about 3 levels deep?\n if ('at-group' === getState()) {\n initializeToken('at-group-end');\n addToken();\n popState();\n }\n \n if (depth > 0) {\n depth = depth - 1;\n }\n\n break;\n\n case 'at-group':\n case 'before-selector':\n case 'selector':\n // If the sequence is `\\}` then assume that the brace should be escaped.\n if (peek(-1) === '\\\\') {\n buffer += ch;\n break;\n }\n\n if (depth > 0) {\n // Leave block if in an at-group\n if ('at-group' === getState(1)) {\n initializeToken('at-group-end');\n addToken();\n }\n }\n\n if (depth > 1) {\n popState();\n }\n\n if (depth > 0) {\n depth = depth - 1;\n }\n break;\n\n case 'double-string':\n case 'single-string':\n case 'comment':\n // Ignore braces in comments and strings.\n buffer += ch;\n break;\n }\n\n break;\n\n // Strings\n case '\"':\n case \"'\":\n switch (getState()) {\n case 'double-string':\n if ('\"' === ch && '\\\\' !== peek(-1)) {\n popState();\n }\n break;\n\n case 'single-string':\n if (\"'\" === ch && '\\\\' !== peek(-1)) {\n popState();\n }\n break;\n\n case 'before-at-value':\n replaceState('at-value');\n pushState('\"' === ch ? 'double-string' : 'single-string');\n break;\n\n case 'before-value':\n replaceState('value');\n pushState('\"' === ch ? 'double-string' : 'single-string');\n break;\n\n case 'comment':\n // Ignore strings within comments.\n break;\n\n default:\n if ('\\\\' !== peek(-1)) {\n pushState('\"' === ch ? 'double-string' : 'single-string');\n }\n }\n\n buffer += ch;\n break;\n\n // Comments\n case '/':\n switch (getState()) {\n case 'comment':\n case 'double-string':\n case 'single-string':\n // Ignore\n buffer += ch;\n break;\n\n case 'before-value':\n case 'selector':\n case 'name':\n case 'value':\n if (isNextChar('*')) {\n // Ignore comments in selectors, properties and values. They are\n // difficult to represent in the AST.\n var pos = find('*/');\n\n if (pos) {\n skip(pos + 1);\n }\n } else {\n if (getState() == 'before-value') replaceState('value');\n buffer += ch;\n }\n break;\n\n default:\n if (isNextChar('*')) {\n // Create a comment token\n initializeToken('comment');\n pushState('comment');\n skip();\n }\n else {\n buffer += ch;\n }\n break;\n }\n break;\n\n // Comment end or universal selector\n case '*':\n switch (getState()) {\n case 'comment':\n if (isNextChar('/')) {\n // Tokenize a comment\n token.text = buffer; // Don't trim()!\n skip();\n addToken();\n popState();\n }\n else {\n buffer += ch;\n }\n break;\n\n case 'before-selector':\n buffer += ch;\n initializeToken('selector');\n pushState('selector');\n break;\n\n case 'before-value':\n replaceState('value');\n buffer += ch;\n break;\n\n default:\n buffer += ch;\n }\n break;\n\n // @-rules\n case '@':\n switch (getState()) {\n case 'comment':\n case 'double-string':\n case 'single-string':\n buffer += ch;\n break;\n case 'before-value':\n replaceState('value');\n buffer += ch;\n break;\n\n default:\n // Iterate over the supported @-rules and attempt to tokenize one.\n var tokenized = false;\n var name;\n var rule;\n\n for (var j = 0, len = atRules.length; !tokenized && j < len; ++j) {\n rule = atRules[j];\n name = rule.name || rule;\n\n if (!isNextString(name)) { continue; }\n\n tokenized = true;\n\n initializeToken(name);\n pushState(rule.state || 'at-group');\n skip(name.length);\n\n if (rule.prefix) {\n token.prefix = rule.prefix;\n }\n\n if (rule.type) {\n token.type = rule.type;\n }\n }\n\n if (!tokenized) {\n // Keep on truckin' America!\n buffer += ch;\n }\n break;\n }\n break;\n\n // Parentheses are tracked to disambiguate semi-colons, such as within a\n // data URI.\n case '(':\n switch (getState()) {\n case 'value':\n pushState('value-paren');\n break;\n case 'before-value':\n replaceState('value');\n break;\n }\n\n buffer += ch;\n break;\n\n case ')':\n switch (getState()) {\n case 'value-paren':\n popState();\n break;\n case 'before-value':\n replaceState('value');\n break;\n }\n\n buffer += ch;\n break;\n\n default:\n switch (getState()) {\n case 'before-selector':\n initializeToken('selector');\n pushState('selector');\n break;\n\n case 'before-name':\n initializeToken('property');\n replaceState('name');\n break;\n\n case 'before-value':\n replaceState('value');\n break;\n\n case 'before-at-value':\n replaceState('at-value');\n break;\n }\n\n buffer += ch;\n break;\n }\n }\n\n TIMER && debug('ran in', (Date.now() - start) + 'ms');\n\n return tokens;\n}\n","var DEBUG = false; // `true` to print debugging info.\nvar TIMER = false; // `true` to time calls to `parse()` and print the results.\n\nvar debug = require('./debug')('parse');\nvar lex = require('./lexer');\n\nexports = module.exports = parse;\n\nvar _comments; // Whether comments are allowed.\nvar _depth; // Current block nesting depth.\nvar _position; // Whether to include line/column position.\nvar _tokens; // Array of lexical tokens.\n\n/**\n * Convert a CSS string or array of lexical tokens into a `stringify`-able AST.\n *\n * @param {String} css CSS string or array of lexical token\n * @param {Object} [options]\n * @param {Boolean} [options.comments=false] allow comment nodes in the AST\n * @returns {Object} `stringify`-able AST\n */\nfunction parse(css, options) {\n var start; // Debug timer start.\n\n options || (options = {});\n _comments = !!options.comments;\n _position = !!options.position;\n\n _depth = 0;\n\n // Operate on a copy of the given tokens, or the lex()'d CSS string.\n _tokens = Array.isArray(css) ? css.slice() : lex(css);\n\n var rule;\n var rules = [];\n var token;\n\n TIMER && (start = Date.now());\n\n while ((token = next())) {\n rule = parseToken(token);\n rule && rules.push(rule);\n }\n\n TIMER && debug('ran in', (Date.now() - start) + 'ms');\n\n return {\n type: \"stylesheet\",\n stylesheet: {\n rules: rules\n }\n };\n}\n\n// -- Functions --------------------------------------------------------------\n\n/**\n * Build an AST node from a lexical token.\n *\n * @param {Object} token lexical token\n * @param {Object} [override] object hash of properties that override those\n * already in the token, or that will be added to the token.\n * @returns {Object} AST node\n */\nfunction astNode(token, override) {\n override || (override = {});\n\n var key;\n var keys = ['type', 'name', 'value'];\n var node = {};\n\n // Avoiding [].forEach for performance reasons.\n for (var i = 0; i < keys.length; ++i) {\n key = keys[i];\n\n if (token[key]) {\n node[key] = override[key] || token[key];\n }\n }\n\n keys = Object.keys(override);\n\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n\n if (!node[key]) {\n node[key] = override[key];\n }\n }\n\n if (_position) {\n node.position = {\n start: token.start,\n end: token.end\n };\n }\n\n DEBUG && debug('astNode:', JSON.stringify(node, null, 2));\n\n return node;\n}\n\n/**\n * Remove a lexical token from the stack and return the removed token.\n *\n * @returns {Object} lexical token\n */\nfunction next() {\n var token = _tokens.shift();\n DEBUG && debug('next:', JSON.stringify(token, null, 2));\n return token;\n}\n\n// -- Parse* Functions ---------------------------------------------------------\n\n/**\n * Convert an @-group lexical token to an AST node.\n *\n * @param {Object} token @-group lexical token\n * @returns {Object} @-group AST node\n */\nfunction parseAtGroup(token) {\n _depth = _depth + 1;\n\n // As the @-group token is assembled, relevant token values are captured here\n // temporarily. They will later be used as `tokenize()` overrides.\n var overrides = {};\n\n switch (token.type) {\n case 'font-face':\n case 'viewport' :\n overrides.declarations = parseDeclarations();\n break;\n\n case 'page':\n overrides.prefix = token.prefix;\n overrides.declarations = parseDeclarations();\n break;\n\n default:\n overrides.prefix = token.prefix;\n overrides.rules = parseRules();\n }\n\n return astNode(token, overrides);\n}\n\n/**\n * Convert an @import lexical token to an AST node.\n *\n * @param {Object} token @import lexical token\n * @returns {Object} @import AST node\n */\nfunction parseAtImport(token) {\n return astNode(token);\n}\n\n/**\n * Convert an @charset token to an AST node.\n *\n * @param {Object} token @charset lexical token\n * @returns {Object} @charset node\n */\nfunction parseCharset(token) {\n return astNode(token);\n}\n\n/**\n * Convert a comment token to an AST Node.\n *\n * @param {Object} token comment lexical token\n * @returns {Object} comment node\n */\nfunction parseComment(token) {\n return astNode(token, {text: token.text});\n}\n\nfunction parseNamespace(token) {\n return astNode(token);\n}\n\n/**\n * Convert a property lexical token to a property AST node.\n *\n * @returns {Object} property node\n */\nfunction parseProperty(token) {\n return astNode(token);\n}\n\n/**\n * Convert a selector lexical token to a selector AST node.\n *\n * @param {Object} token selector lexical token\n * @returns {Object} selector node\n */\nfunction parseSelector(token) {\n function trim(str) {\n return str.trim();\n }\n\n return astNode(token, {\n type: 'rule',\n selectors: token.text.split(',').map(trim),\n declarations: parseDeclarations(token)\n });\n}\n\n/**\n * Convert a lexical token to an AST node.\n *\n * @returns {Object|undefined} AST node\n */\nfunction parseToken(token) {\n switch (token.type) {\n // Cases are listed in roughly descending order of probability.\n case 'property': return parseProperty(token);\n\n case 'selector': return parseSelector(token);\n\n case 'at-group-end': _depth = _depth - 1; return;\n\n case 'media' :\n case 'keyframes' :return parseAtGroup(token);\n\n case 'comment': if (_comments) { return parseComment(token); } break;\n\n case 'charset': return parseCharset(token);\n case 'import': return parseAtImport(token);\n\n case 'namespace': return parseNamespace(token);\n\n case 'font-face':\n case 'supports' :\n case 'viewport' :\n case 'document' :\n case 'page' : return parseAtGroup(token);\n }\n\n DEBUG && debug('parseToken: unexpected token:', JSON.stringify(token));\n}\n\n// -- Parse Helper Functions ---------------------------------------------------\n\n/**\n * Iteratively parses lexical tokens from the stack into AST nodes until a\n * conditional function returns `false`, at which point iteration terminates\n * and any AST nodes collected are returned.\n *\n * @param {Function} conditionFn\n * @param {Object} token the lexical token being parsed\n * @returns {Boolean} `true` if the token should be parsed, `false` otherwise\n * @return {Array} AST nodes\n */\nfunction parseTokensWhile(conditionFn) {\n var node;\n var nodes = [];\n var token;\n\n while ((token = next()) && (conditionFn && conditionFn(token))) {\n node = parseToken(token);\n node && nodes.push(node);\n }\n\n // Place an unused non-`end` lexical token back onto the stack.\n if (token && token.type !== 'end') {\n _tokens.unshift(token);\n }\n\n return nodes;\n}\n\n/**\n * Convert a series of tokens into a sequence of declaration AST nodes.\n *\n * @returns {Array} declaration nodes\n */\nfunction parseDeclarations() {\n return parseTokensWhile(function (token) {\n return (token.type === 'property' || token.type === 'comment');\n });\n}\n\n/**\n * Convert a series of tokens into a sequence of rule nodes.\n *\n * @returns {Array} rule nodes\n */\nfunction parseRules() {\n return parseTokensWhile(function () { return _depth; });\n}\n","var DEBUG = false; // `true` to print debugging info.\nvar TIMER = false; // `true` to time calls to `stringify()` and print the results.\n\nvar debug = require('./debug')('stringify');\n\nvar _comments; // Whether comments are allowed in the stringified CSS.\nvar _compress; // Whether the stringified CSS should be compressed.\nvar _indentation; // Indentation option value.\nvar _level; // Current indentation level.\nvar _n; // Compression-aware newline character.\nvar _s; // Compression-aware space character.\n\nexports = module.exports = stringify;\n\n/**\n * Convert a `stringify`-able AST into a CSS string.\n *\n * @param {Object} `stringify`-able AST\n * @param {Object} [options]\n * @param {Boolean} [options.comments=false] allow comments in the CSS\n * @param {Boolean} [options.compress=false] compress whitespace\n * @param {String} [options.indentation=''] indentation sequence\n * @returns {String} CSS\n */\nfunction stringify(ast, options) {\n var start; // Debug timer start.\n\n options || (options = {});\n _indentation = options.indentation || '';\n _compress = !!options.compress;\n _comments = !!options.comments;\n _level = 1;\n\n if (_compress) {\n _n = _s = '';\n } else {\n _n = '\\n';\n _s = ' ';\n }\n\n TIMER && (start = Date.now());\n\n var css = reduce(ast.stylesheet.rules, stringifyNode).join('\\n').trim();\n\n TIMER && debug('ran in', (Date.now() - start) + 'ms');\n\n return css;\n}\n\n// -- Functions --------------------------------------------------------------\n\n/**\n * Modify the indentation level, or return a compression-aware sequence of\n * spaces equal to the current indentation level.\n *\n * @param {Number} [level=undefined] indentation level modifier\n * @returns {String} sequence of spaces\n */\nfunction indent(level) {\n if (level) {\n _level += level;\n return;\n }\n\n if (_compress) { return ''; }\n\n return Array(_level).join(_indentation || '');\n}\n\n// -- Stringify Functions ------------------------------------------------------\n\n/**\n * Stringify an @-rule AST node.\n *\n * Use `stringifyAtGroup()` when dealing with @-groups that may contain blocks\n * such as @media.\n *\n * @param {String} type @-rule type. E.g., import, charset\n * @returns {String} Stringified @-rule\n */\nfunction stringifyAtRule(node) {\n return '@' + node.type + ' ' + node.value + ';' + _n;\n}\n\n/**\n * Stringify an @-group AST node.\n *\n * Use `stringifyAtRule()` when dealing with @-rules that may not contain blocks\n * such as @import.\n *\n * @param {Object} node @-group AST node\n * @returns {String}\n */\nfunction stringifyAtGroup(node) {\n var label = '';\n var prefix = node.prefix || '';\n\n if (node.name) {\n label = ' ' + node.name;\n }\n\n // FIXME: @-rule conditional logic is leaking everywhere.\n var chomp = node.type !== 'page';\n\n return '@' + prefix + node.type + label + _s + stringifyBlock(node, chomp) + _n;\n}\n\n/**\n * Stringify a comment AST node.\n *\n * @param {Object} node comment AST node\n * @returns {String}\n */\nfunction stringifyComment(node) {\n if (!_comments) { return ''; }\n\n return '/*' + (node.text || '') + '*/' + _n;\n}\n\n/**\n * Stringify a rule AST node.\n *\n * @param {Object} node rule AST node\n * @returns {String}\n */\nfunction stringifyRule(node) {\n var label;\n\n if (node.selectors) {\n label = node.selectors.join(',' + _n);\n } else {\n label = '@' + node.type;\n label += node.name ? ' ' + node.name : '';\n }\n\n return indent() + label + _s + stringifyBlock(node) + _n;\n}\n\n\n// -- Stringify Helper Functions -----------------------------------------------\n\n/**\n * Reduce an array by applying a function to each item and retaining the truthy\n * results.\n *\n * When `item.type` is `'comment'` `stringifyComment` will be applied instead.\n *\n * @param {Array} items array to reduce\n * @param {Function} fn function to call for each item in the array\n * @returns {Mixed} Truthy values will be retained, falsy values omitted\n * @returns {Array} retained results\n */\nfunction reduce(items, fn) {\n return items.reduce(function (results, item) {\n var result = (item.type === 'comment') ? stringifyComment(item) : fn(item);\n result && results.push(result);\n return results;\n }, []);\n}\n\n/**\n * Stringify an AST node with the assumption that it represents a block of\n * declarations or other @-group contents.\n *\n * @param {Object} node AST node\n * @returns {String}\n */\n// FIXME: chomp should not be a magic boolean parameter\nfunction stringifyBlock(node, chomp) {\n var children = node.declarations;\n var fn = stringifyDeclaration;\n\n if (node.rules) {\n children = node.rules;\n fn = stringifyRule;\n }\n\n children = stringifyChildren(children, fn);\n children && (children = _n + children + (chomp ? '' : _n));\n\n return '{' + children + indent() + '}';\n}\n\n/**\n * Stringify an array of child AST nodes by calling the given stringify function\n * once for each child, and concatenating the results.\n *\n * @param {Array} children `node.rules` or `node.declarations`\n * @param {Function} fn stringify function\n * @returns {String}\n */\nfunction stringifyChildren(children, fn) {\n if (!children) { return ''; }\n\n indent(1);\n var results = reduce(children, fn);\n indent(-1);\n\n if (!results.length) { return ''; }\n\n return results.join(_n);\n}\n\n/**\n * Stringify a declaration AST node.\n *\n * @param {Object} node declaration AST node\n * @returns {String}\n */\nfunction stringifyDeclaration(node) {\n if (node.type === 'property') {\n return stringifyProperty(node);\n }\n\n DEBUG && debug('stringifyDeclaration: unexpected node:', JSON.stringify(node));\n}\n\n/**\n * Stringify an AST node.\n *\n * @param {Object} node AST node\n * @returns {String}\n */\nfunction stringifyNode(node) {\n switch (node.type) {\n // Cases are listed in roughly descending order of probability.\n case 'rule': return stringifyRule(node);\n\n case 'media' :\n case 'keyframes': return stringifyAtGroup(node);\n\n case 'comment': return stringifyComment(node);\n\n case 'import' :\n case 'charset' :\n case 'namespace': return stringifyAtRule(node);\n\n case 'font-face':\n case 'supports' :\n case 'viewport' :\n case 'document' :\n case 'page' : return stringifyAtGroup(node);\n }\n\n DEBUG && debug('stringifyNode: unexpected node: ' + JSON.stringify(node));\n}\n\n/**\n * Stringify an AST property node.\n *\n * @param {Object} node AST property node\n * @returns {String}\n */\nfunction stringifyProperty(node) {\n var name = node.name ? node.name + ':' + _s : '';\n\n return indent() + name + node.value + ';';\n}\n","module.exports = {\n lex : require('./lib/lexer'),\n parse: require('./lib/parser'),\n stringify: require('./lib/stringify')\n};\n","/*\r\nSlick Parser\r\n - originally created by the almighty Thomas Aylott <@subtlegradient> (http://subtlegradient.com)\r\n*/\"use strict\"\r\n\r\n// Notable changes from Slick.Parser 1.0.x\r\n\r\n// The parser now uses 2 classes: Expressions and Expression\r\n// `new Expressions` produces an array-like object containing a list of Expression objects\r\n// - Expressions::toString() produces a cleaned up expressions string\r\n// `new Expression` produces an array-like object\r\n// - Expression::toString() produces a cleaned up expression string\r\n// The only exposed method is parse, which produces a (cached) `new Expressions` instance\r\n// parsed.raw is no longer present, use .toString()\r\n// parsed.expression is now useless, just use the indices\r\n// parsed.reverse() has been removed for now, due to its apparent uselessness\r\n// Other changes in the Expressions object:\r\n// - classNames are now unique, and save both escaped and unescaped values\r\n// - attributes now save both escaped and unescaped values\r\n// - pseudos now save both escaped and unescaped values\r\n\r\nvar escapeRe = /([-.*+?^${}()|[\\]\\/\\\\])/g,\r\n unescapeRe = /\\\\/g\r\n\r\nvar escape = function(string){\r\n // XRegExp v2.0.0-beta-3\r\n // « https://github.com/slevithan/XRegExp/blob/master/src/xregexp.js\r\n return (string + \"\").replace(escapeRe, '\\\\$1')\r\n}\r\n\r\nvar unescape = function(string){\r\n return (string + \"\").replace(unescapeRe, '')\r\n}\r\n\r\nvar slickRe = RegExp(\r\n/*\r\n#!/usr/bin/env ruby\r\nputs \"\\t\\t\" + DATA.read.gsub(/\\(\\?x\\)|\\s+#.*$|\\s+|\\\\$|\\\\n/,'')\r\n__END__\r\n \"(?x)^(?:\\\r\n \\\\s* ( , ) \\\\s* # Separator \\n\\\r\n | \\\\s* ( + ) \\\\s* # Combinator \\n\\\r\n | ( \\\\s+ ) # CombinatorChildren \\n\\\r\n | ( + | \\\\* ) # Tag \\n\\\r\n | \\\\# ( + ) # ID \\n\\\r\n | \\\\. ( + ) # ClassName \\n\\\r\n | # Attribute \\n\\\r\n \\\\[ \\\r\n \\\\s* (+) (?: \\\r\n \\\\s* ([*^$!~|]?=) (?: \\\r\n \\\\s* (?:\\\r\n ([\\\"']?)(.*?)\\\\9 \\\r\n )\\\r\n ) \\\r\n )? \\\\s* \\\r\n \\\\](?!\\\\]) \\n\\\r\n | :+ ( + )(?:\\\r\n \\\\( (?:\\\r\n (?:([\\\"'])([^\\\\12]*)\\\\12)|((?:\\\\([^)]+\\\\)|[^()]*)+)\\\r\n ) \\\\)\\\r\n )?\\\r\n )\"\r\n*/\r\n\"^(?:\\\\s*(,)\\\\s*|\\\\s*(+)\\\\s*|(\\\\s+)|(+|\\\\*)|\\\\#(+)|\\\\.(+)|\\\\[\\\\s*(+)(?:\\\\s*([*^$!~|]?=)(?:\\\\s*(?:([\\\"']?)(.*?)\\\\9)))?\\\\s*\\\\](?!\\\\])|(:+)(+)(?:\\\\((?:(?:([\\\"'])([^\\\\13]*)\\\\13)|((?:\\\\([^)]+\\\\)|[^()]*)+))\\\\))?)\"\r\n .replace(//, '[' + escape(\">+~`!@$%^&={}\\\\;/g, '(?:[\\\\w\\\\u00a1-\\\\uFFFF-]|\\\\\\\\[^\\\\s0-9a-f])')\r\n .replace(//g, '(?:[:\\\\w\\\\u00a1-\\\\uFFFF-]|\\\\\\\\[^\\\\s0-9a-f])')\r\n)\r\n\r\n// Part\r\n\r\nvar Part = function Part(combinator){\r\n this.combinator = combinator || \" \"\r\n this.tag = \"*\"\r\n}\r\n\r\nPart.prototype.toString = function(){\r\n\r\n if (!this.raw){\r\n\r\n var xpr = \"\", k, part\r\n\r\n xpr += this.tag || \"*\"\r\n if (this.id) xpr += \"#\" + this.id\r\n if (this.classes) xpr += \".\" + this.classList.join(\".\")\r\n if (this.attributes) for (k = 0; part = this.attributes[k++];){\r\n xpr += \"[\" + part.name + (part.operator ? part.operator + '\"' + part.value + '\"' : '') + \"]\"\r\n }\r\n if (this.pseudos) for (k = 0; part = this.pseudos[k++];){\r\n xpr += \":\" + part.name\r\n if (part.value) xpr += \"(\" + part.value + \")\"\r\n }\r\n\r\n this.raw = xpr\r\n\r\n }\r\n\r\n return this.raw\r\n}\r\n\r\n// Expression\r\n\r\nvar Expression = function Expression(){\r\n this.length = 0\r\n}\r\n\r\nExpression.prototype.toString = function(){\r\n\r\n if (!this.raw){\r\n\r\n var xpr = \"\"\r\n\r\n for (var j = 0, bit; bit = this[j++];){\r\n if (j !== 1) xpr += \" \"\r\n if (bit.combinator !== \" \") xpr += bit.combinator + \" \"\r\n xpr += bit\r\n }\r\n\r\n this.raw = xpr\r\n\r\n }\r\n\r\n return this.raw\r\n}\r\n\r\nvar replacer = function(\r\n rawMatch,\r\n\r\n separator,\r\n combinator,\r\n combinatorChildren,\r\n\r\n tagName,\r\n id,\r\n className,\r\n\r\n attributeKey,\r\n attributeOperator,\r\n attributeQuote,\r\n attributeValue,\r\n\r\n pseudoMarker,\r\n pseudoClass,\r\n pseudoQuote,\r\n pseudoClassQuotedValue,\r\n pseudoClassValue\r\n){\r\n\r\n var expression, current\r\n\r\n if (separator || !this.length){\r\n expression = this[this.length++] = new Expression\r\n if (separator) return ''\r\n }\r\n\r\n if (!expression) expression = this[this.length - 1]\r\n\r\n if (combinator || combinatorChildren || !expression.length){\r\n current = expression[expression.length++] = new Part(combinator)\r\n }\r\n\r\n if (!current) current = expression[expression.length - 1]\r\n\r\n if (tagName){\r\n\r\n current.tag = unescape(tagName)\r\n\r\n } else if (id){\r\n\r\n current.id = unescape(id)\r\n\r\n } else if (className){\r\n\r\n var unescaped = unescape(className)\r\n\r\n var classes = current.classes || (current.classes = {})\r\n if (!classes[unescaped]){\r\n classes[unescaped] = escape(className)\r\n var classList = current.classList || (current.classList = [])\r\n classList.push(unescaped)\r\n classList.sort()\r\n }\r\n\r\n } else if (pseudoClass){\r\n\r\n pseudoClassValue = pseudoClassValue || pseudoClassQuotedValue\r\n\r\n ;(current.pseudos || (current.pseudos = [])).push({\r\n type : pseudoMarker.length == 1 ? 'class' : 'element',\r\n name : unescape(pseudoClass),\r\n escapedName : escape(pseudoClass),\r\n value : pseudoClassValue ? unescape(pseudoClassValue) : null,\r\n escapedValue : pseudoClassValue ? escape(pseudoClassValue) : null\r\n })\r\n\r\n } else if (attributeKey){\r\n\r\n attributeValue = attributeValue ? escape(attributeValue) : null\r\n\r\n ;(current.attributes || (current.attributes = [])).push({\r\n operator : attributeOperator,\r\n name : unescape(attributeKey),\r\n escapedName : escape(attributeKey),\r\n value : attributeValue ? unescape(attributeValue) : null,\r\n escapedValue : attributeValue ? escape(attributeValue) : null\r\n })\r\n\r\n }\r\n\r\n return ''\r\n\r\n}\r\n\r\n// Expressions\r\n\r\nvar Expressions = function Expressions(expression){\r\n this.length = 0\r\n\r\n var self = this\r\n\r\n var original = expression, replaced\r\n\r\n while (expression){\r\n replaced = expression.replace(slickRe, function(){\r\n return replacer.apply(self, arguments)\r\n })\r\n if (replaced === expression) throw new Error(original + ' is an invalid expression')\r\n expression = replaced\r\n }\r\n}\r\n\r\nExpressions.prototype.toString = function(){\r\n if (!this.raw){\r\n var expressions = []\r\n for (var i = 0, expression; expression = this[i++];) expressions.push(expression)\r\n this.raw = expressions.join(\", \")\r\n }\r\n\r\n return this.raw\r\n}\r\n\r\nvar cache = {}\r\n\r\nvar parse = function(expression){\r\n if (expression == null) return null\r\n expression = ('' + expression).replace(/^\\s+|\\s+$/g, '')\r\n return cache[expression] || (cache[expression] = new Expressions(expression))\r\n}\r\n\r\nmodule.exports = parse\r\n","'use strict';\n\nvar parser = require('slick/parser');\n\nmodule.exports = exports = Selector;\n\n/**\n * CSS selector constructor.\n *\n * @param {String} selector text\n * @param {Array} optionally, precalculated specificity\n * @api public\n */\n\nfunction Selector(text, styleAttribute) {\n this.text = text;\n this.spec = undefined;\n this.styleAttribute = styleAttribute || false;\n}\n\n/**\n * Get parsed selector.\n *\n * @api public\n */\n\nSelector.prototype.parsed = function() {\n if (!this.tokens) { this.tokens = parse(this.text); }\n return this.tokens;\n};\n\n/**\n * Lazy specificity getter\n *\n * @api public\n */\n\nSelector.prototype.specificity = function() {\n var styleAttribute = this.styleAttribute;\n if (!this.spec) { this.spec = specificity(this.text, this.parsed()); }\n return this.spec;\n\n function specificity(text, parsed) {\n var expressions = parsed || parse(text);\n var spec = [styleAttribute ? 1 : 0, 0, 0, 0];\n var nots = [];\n\n for (var i = 0; i < expressions.length; i++) {\n var expression = expressions[i];\n var pseudos = expression.pseudos;\n\n // id awards a point in the second column\n if (expression.id) { spec[1]++; }\n\n // classes and attributes award a point each in the third column\n if (expression.attributes) { spec[2] += expression.attributes.length; }\n if (expression.classList) { spec[2] += expression.classList.length; }\n\n // tag awards a point in the fourth column\n if (expression.tag && expression.tag !== '*') { spec[3]++; }\n\n // pseudos award a point each in the fourth column\n if (pseudos) {\n spec[3] += pseudos.length;\n\n for (var p = 0; p < pseudos.length; p++) {\n if (pseudos[p].name === 'not') {\n nots.push(pseudos[p].value);\n spec[3]--;\n }\n }\n }\n }\n\n for (var ii = nots.length; ii--;) {\n var not = specificity(nots[ii]);\n for (var jj = 4; jj--;) { spec[jj] += not[jj]; }\n }\n\n return spec;\n }\n};\n\n/**\n * Parses a selector and returns the tokens.\n *\n * @param {String} selector\n * @api private.\n */\n\nfunction parse(text) {\n try {\n return parser(text)[0];\n } catch (e) {\n return [];\n }\n}\n","'use strict';\n\nmodule.exports = exports = Property;\n\n/**\n * Module dependencies.\n */\n\nvar utils = require('./utils');\n\n/**\n * CSS property constructor.\n *\n * @param {String} property\n * @param {String} value\n * @param {Selector} selector the property originates from\n * @param {Integer} priority 0 for normal properties, 2 for !important properties.\n * @param {Array} additional array of integers representing more detailed priorities (sorting)\n * @api public\n */\n\nfunction Property(prop, value, selector, priority, additionalPriority) {\n this.prop = prop;\n this.value = value;\n this.selector = selector;\n this.priority = priority || 0;\n this.additionalPriority = additionalPriority || [];\n}\n\n/**\n * Compares with another Property based on Selector#specificity.\n *\n * @api public\n */\n\nProperty.prototype.compareFunc = function(property) {\n var a = [];\n a.push.apply(a, this.selector.specificity());\n a.push.apply(a, this.additionalPriority);\n a[0] += this.priority;\n var b = [];\n b.push.apply(b, property.selector.specificity());\n b.push.apply(b, property.additionalPriority);\n b[0] += property.priority;\n return utils.compareFunc(a, b);\n};\n\nProperty.prototype.compare = function(property) {\n var winner = this.compareFunc(property);\n if (winner === 1) {\n return this;\n }\n return property;\n};\n\n\n/**\n * Returns CSS property\n *\n * @api public\n */\n\nProperty.prototype.toString = function() {\n return this.prop + ': ' + this.value.replace(/['\"]+/g, '') + ';';\n};\n","'use strict';\n\n/**\n * Module dependencies.\n */\n\nvar mensch = require('mensch');\nvar Selector = require('./selector');\nvar Property = require('./property');\n\nexports.Selector = Selector;\nexports.Property = Property;\n\n/**\n * Returns an array of the selectors.\n *\n * @license Sizzle CSS Selector Engine - MIT\n * @param {String} selectorText from mensch\n * @api public\n */\n\nexports.extract = function extract(selectorText) {\n var attr = 0;\n var sels = [];\n var sel = '';\n\n for (var i = 0, l = selectorText.length; i < l; i++) {\n var c = selectorText.charAt(i);\n\n if (attr) {\n if (']' === c || ')' === c) { attr--; }\n sel += c;\n } else {\n if (',' === c) {\n sels.push(sel);\n sel = '';\n } else {\n if ('[' === c || '(' === c) { attr++; }\n if (sel.length || (c !== ',' && c !== '\\n' && c !== ' ')) { sel += c; }\n }\n }\n }\n\n if (sel.length) {\n sels.push(sel);\n }\n return sels;\n};\n\n/**\n * Returns a parse tree for a CSS source.\n * If it encounters multiple selectors separated by a comma, it splits the\n * tree.\n *\n * @param {String} css source\n * @api public\n */\n\nexports.parseCSS = function(css) {\n var parsed = mensch.parse(css, {position: true, comments: true});\n var rules = typeof parsed.stylesheet != 'undefined' && parsed.stylesheet.rules ? parsed.stylesheet.rules : [];\n var ret = [];\n\n for (var i = 0, l = rules.length; i < l; i++) {\n if (rules[i].type == 'rule') {\n var rule = rules[i];\n var selectors = rule.selectors;\n\n for (var ii = 0, ll = selectors.length; ii < ll; ii++) {\n ret.push([selectors[ii], rule.declarations]);\n }\n }\n }\n\n return ret;\n};\n\n/**\n * Returns preserved text for a CSS source.\n *\n * @param {String} css source\n * @param {Object} options\n * @api public\n */\n\nexports.getPreservedText = function(css, options, ignoredPseudos) {\n var parsed = mensch.parse(css, {position: true, comments: true});\n var rules = typeof parsed.stylesheet != 'undefined' && parsed.stylesheet.rules ? parsed.stylesheet.rules : [];\n var preserved = [];\n var lastStart = null;\n\n for (var i = rules.length - 1; i >= 0; i--) {\n if ((options.fontFaces && rules[i].type === 'font-face') ||\n (options.mediaQueries && rules[i].type === 'media') ||\n (options.keyFrames && rules[i].type === 'keyframes') ||\n (options.pseudos && rules[i].selectors && this.matchesPseudo(rules[i].selectors[0], ignoredPseudos))) {\n preserved.unshift(\n mensch.stringify(\n { stylesheet: { rules: [ rules[i] ] }},\n { comments: false, indentation: ' ' }\n )\n );\n }\n lastStart = rules[i].position.start;\n }\n\n if (preserved.length === 0) {\n return false;\n }\n return '\\n' + preserved.join('\\n') + '\\n';\n};\n\nexports.normalizeLineEndings = function(text) {\n return text.replace(/\\r\\n/g, '\\n').replace(/\\n/g, '\\r\\n');\n};\n\nexports.matchesPseudo = function(needle, haystack) {\n return haystack.find(function (element) {\n return needle.indexOf(element) > -1;\n })\n}\n\n/**\n * Compares two specificity vectors, returning the winning one.\n *\n * @param {Array} vector a\n * @param {Array} vector b\n * @return {Array}\n * @api public\n */\n\nexports.compareFunc = function(a, b) {\n var min = Math.min(a.length, b.length);\n for (var i = 0; i < min; i++) {\n if (a[i] === b[i]) { continue; }\n if (a[i] > b[i]) { return 1; }\n return -1;\n }\n\n return a.length - b.length;\n};\n\nexports.compare = function(a, b) {\n return exports.compareFunc(a, b) == 1 ? a : b;\n};\n\nexports.getDefaultOptions = function(options) {\n var result = Object.assign({\n extraCss: '',\n insertPreservedExtraCss: true,\n applyStyleTags: true,\n removeStyleTags: true,\n preserveMediaQueries: true,\n preserveFontFaces: true,\n preserveKeyFrames: true,\n preservePseudos: true,\n applyWidthAttributes: true,\n applyHeightAttributes: true,\n applyAttributesTableElements: true,\n resolveCSSVariables: true,\n url: ''\n }, options);\n\n result.webResources = result.webResources || {};\n\n return result;\n};\n","'use strict';\n\n/**\n * Module dependencies.\n */\nvar cheerio = require('cheerio');\nvar utils = require('./utils');\n\nvar cheerioLoad = function(html, options, encodeEntities) {\n const { xmlMode, ...rest } = options;\n options = Object.assign({ xml: { decodeEntities: false, xmlMode } }, rest);\n html = encodeEntities(html);\n return cheerio.load(html, options);\n};\n\nvar createEntityConverters = function () {\n var codeBlockLookup = [];\n\n var encodeCodeBlocks = function(html) {\n var blocks = module.exports.codeBlocks;\n Object.keys(blocks).forEach(function(key) {\n var re = new RegExp(blocks[key].start + '([\\\\S\\\\s]*?)' + blocks[key].end, 'g');\n html = html.replace(re, function(match, subMatch) {\n codeBlockLookup.push(match);\n return 'JUICE_CODE_BLOCK_' + (codeBlockLookup.length - 1) + '_';\n });\n });\n return html;\n };\n\n var decodeCodeBlocks = function(html) {\n for(var index = 0; index < codeBlockLookup.length; index++) {\n var re = new RegExp('JUICE_CODE_BLOCK_' + index + '_(=\"\")?', 'gi');\n html = html.replace(re, function() {\n return codeBlockLookup[index];\n });\n }\n return html;\n };\n\n return {\n encodeEntities: encodeCodeBlocks,\n decodeEntities: decodeCodeBlocks,\n };\n};\n\n/**\n * Parses the input, calls the callback on the parsed DOM, and generates the output\n *\n * @param {String} html input html to be processed\n * @param {Object} options for the parser\n * @param {Function} callback to be invoked on the DOM\n * @param {Array} callbackExtraArguments to be passed to the callback\n * @return {String} resulting html\n */\nmodule.exports = function(html, options, callback, callbackExtraArguments) {\n var entityConverters = createEntityConverters();\n\n var $ = cheerioLoad(html, options, entityConverters.encodeEntities);\n var args = [ $ ];\n args.push.apply(args, callbackExtraArguments);\n var doc = callback.apply(undefined, args) || $;\n\n if (options && options.xmlMode) {\n return entityConverters.decodeEntities(doc.xml());\n }\n return entityConverters.decodeEntities(doc.html());\n};\n\nmodule.exports.codeBlocks = {\n EJS: { start: '<%', end: '%>' },\n HBS: { start: '{{', end: '}}' }\n};\n","'use strict';\n\n/**\n * Converts a decimal number to roman numeral.\n * https://stackoverflow.com/questions/9083037/convert-a-number-into-a-roman-numeral-in-javascript\n *\n * @param {Number} number\n * @api private.\n */\nexports.romanize = function(num) {\n if (isNaN(num))\n return NaN;\n var digits = String(+num).split(\"\"),\n key = [\"\",\"C\",\"CC\",\"CCC\",\"CD\",\"D\",\"DC\",\"DCC\",\"DCCC\",\"CM\",\n \"\",\"X\",\"XX\",\"XXX\",\"XL\",\"L\",\"LX\",\"LXX\",\"LXXX\",\"XC\",\n \"\",\"I\",\"II\",\"III\",\"IV\",\"V\",\"VI\",\"VII\",\"VIII\",\"IX\"],\n roman = \"\",\n i = 3;\n while (i--)\n roman = (key[+digits.pop() + (i * 10)] || \"\") + roman;\n return Array(+digits.join(\"\") + 1).join(\"M\") + roman;\n}\n\n/**\n * Converts a decimal number to alphanumeric numeral.\n * https://stackoverflow.com/questions/45787459/convert-number-to-alphabet-string-javascript\n *\n * @param {Number} number\n * @api private.\n */\nexports.alphanumeric = function(num) {\n var s = '', t;\n\n while (num > 0) {\n t = (num - 1) % 26;\n s = String.fromCharCode(65 + t) + s;\n num = (num - t)/26 | 0;\n }\n return s || undefined;\n}","'use strict';\n\nconst uniqueString = (string) => {\n let str = '';\n do{\n str = (Math.random() + 1).toString(36).substring(2);\n\n }while(string.indexOf(str) !== -1);\n\n return str;\n}\n\n/**\n * Replace css variables with their value\n */\nconst replaceVariables = (el,value) => {\n\n // find non-nested css function calls\n // eg: rgb(...), drop-shadow(...)\n\tlet funcReg = /([a-z\\-]+)\\s*\\(\\s*([^\\(\\)]*?)\\s*(?:,\\s*([^\\(\\)]*?)\\s*)?\\s*\\)/i;\n let replacements = [];\n let match;\n let uniq = uniqueString(value);\n\n\twhile( (match = funcReg.exec(value)) !== null ){\n let i = `${replacements.length}`;\n\n\n // attempt to resolve variables\n if( match[1].toLowerCase() == 'var' ){\n const varValue = findVariableValue(el, match[2]);\n \n // found variable value\n if( varValue ){\n value = value.replace(match[0],varValue);\n continue;\n }\n\n // use default value\n // var(--name , default-value)\n if( match[3] ){\n value = value.replace(match[0],match[3]);\n continue;\n }\n }\n \n let placeholder = `${uniq}${i.padStart(5,'-')}`;\n value = value.replace(match[0],placeholder);\n replacements.push({placeholder,replace:match[0]});\n }\n\n for( var i = replacements.length-1; i >=0; i--){\n const replacement = replacements[i];\n\t\tvalue = value.replace(replacement.placeholder,replacement.replace);\n }\n \n return value;\n}\n\nconst findVariableValue = (el, variable) => {\n while (el) {\n if (el.styleProps && variable in el.styleProps) {\n return el.styleProps[variable].value;\n }\n\n var el = el.pseudoElementParent || el.parent;\n }\n}\n\nmodule.exports = { replaceVariables, findVariableValue };","'use strict';\n\nvar { decode } = require('entities');\n\nvar utils = require('./utils');\nvar numbers = require('./numbers');\nvar variables = require('./variables');\n\nmodule.exports = function makeJuiceClient(juiceClient) {\n\njuiceClient.ignoredPseudos = ['hover', 'active', 'focus', 'visited', 'link'];\njuiceClient.widthElements = ['TABLE', 'TD', 'TH', 'IMG'];\njuiceClient.heightElements = ['TABLE', 'TD', 'TH', 'IMG'];\njuiceClient.tableElements = ['TABLE', 'TH', 'TR', 'TD', 'CAPTION', 'COLGROUP', 'COL', 'THEAD', 'TBODY', 'TFOOT'];\njuiceClient.nonVisualElements = [ 'HEAD', 'TITLE', 'BASE', 'LINK', 'STYLE', 'META', 'SCRIPT', 'NOSCRIPT' ];\njuiceClient.styleToAttribute = {\n 'background-color': 'bgcolor',\n 'background-image': 'background',\n 'text-align': 'align',\n 'vertical-align': 'valign'\n};\njuiceClient.excludedProperties = [];\n\njuiceClient.juiceDocument = juiceDocument;\njuiceClient.inlineDocument = inlineDocument;\n\nfunction inlineDocument($, css, options) {\n\n options = options || {};\n var rules = utils.parseCSS(css);\n var editedElements = [];\n var styleAttributeName = 'style';\n var counters = {};\n\n if (options.styleAttributeName) {\n styleAttributeName = options.styleAttributeName;\n }\n\n rules.forEach(handleRule);\n editedElements.forEach(setStyleAttrs);\n\n if (options.inlinePseudoElements) {\n editedElements.forEach(inlinePseudoElements);\n }\n\n if (options.applyWidthAttributes) {\n editedElements.forEach(function(el) {\n setDimensionAttrs(el, 'width');\n });\n }\n\n if (options.applyHeightAttributes) {\n editedElements.forEach(function(el) {\n setDimensionAttrs(el, 'height');\n });\n }\n\n if (options.applyAttributesTableElements) {\n editedElements.forEach(setAttributesOnTableElements);\n }\n\n if (options.insertPreservedExtraCss && options.extraCss) {\n var preservedText = utils.getPreservedText(options.extraCss, {\n mediaQueries: options.preserveMediaQueries,\n fontFaces: options.preserveFontFaces,\n keyFrames: options.preserveKeyFrames\n });\n if (preservedText) {\n var $appendTo = null;\n if (options.insertPreservedExtraCss !== true) {\n $appendTo = $(options.insertPreservedExtraCss);\n } else {\n $appendTo = $('head');\n if (!$appendTo.length) { $appendTo = $('body'); }\n if (!$appendTo.length) { $appendTo = $.root(); }\n }\n\n $appendTo.first().append('');\n }\n }\n\n function handleRule(rule) {\n var sel = rule[0];\n var style = rule[1];\n var selector = new utils.Selector(sel);\n var parsedSelector = selector.parsed();\n\n if (!parsedSelector) {\n return;\n }\n\n var pseudoElementType = getPseudoElementType(parsedSelector);\n\n // skip rule if the selector has any pseudos which are ignored\n for (var i = 0; i < parsedSelector.length; ++i) {\n var subSel = parsedSelector[i];\n if (subSel.pseudos) {\n for (var j = 0; j < subSel.pseudos.length; ++j) {\n var subSelPseudo = subSel.pseudos[j];\n if (juiceClient.ignoredPseudos.indexOf(subSelPseudo.name) >= 0) {\n return;\n }\n }\n }\n }\n\n if (pseudoElementType) {\n var last = parsedSelector[parsedSelector.length - 1];\n var pseudos = last.pseudos;\n last.pseudos = filterElementPseudos(last.pseudos);\n sel = parsedSelector.toString();\n last.pseudos = pseudos;\n }\n\n var els;\n try {\n els = $(sel);\n } catch (err) {\n // skip invalid selector\n return;\n }\n\n els.each(function() {\n var el = this;\n\n if (el.name && juiceClient.nonVisualElements.indexOf(el.name.toUpperCase()) >= 0) {\n return;\n }\n\n if (!el.counterProps) {\n el.counterProps = el.parent && el.parent.counterProps\n ? Object.create(el.parent.counterProps)\n : {};\n }\n\n if (pseudoElementType) {\n var pseudoElPropName = 'pseudo' + pseudoElementType;\n var pseudoEl = el[pseudoElPropName];\n if (!pseudoEl) {\n pseudoEl = el[pseudoElPropName] = $('').get(0);\n pseudoEl.pseudoElementType = pseudoElementType;\n pseudoEl.pseudoElementParent = el;\n pseudoEl.counterProps = el.counterProps;\n el[pseudoElPropName] = pseudoEl;\n }\n el = pseudoEl;\n }\n\n if (!el.styleProps) {\n el.styleProps = {};\n\n // if the element has inline styles, fake selector with topmost specificity\n if ($(el).attr(styleAttributeName)) {\n var styleAttributeValue = $(el).attr(styleAttributeName);\n var cssStyleAttributeValue = options.decodeStyleAttributes\n ? decode(styleAttributeValue)\n : styleAttributeValue;\n var cssText = '* { ' + cssStyleAttributeValue + ' } ';\n addProps(utils.parseCSS(cssText)[0][1], new utils.Selector('`","import React, { useContext, useEffect, useState } from 'react'\nimport ReactQuill from 'react-quill'\nimport { FormContext } from '../../../../contexts/FormContext'\nimport { Controller } from 'react-hook-form'\nimport classNames from '../../../../utils/classNames'\nimport { titleCase } from '../../../../utils'\nimport { desktopToolbar, mobileToolbar } from '../../../../config/quillToolbar'\nimport juice from 'juice'\nimport { richTextInputStyles } from '../../../../constants/rich_text_input_styles'\nimport 'react-quill/dist/quill.snow.css'\ninterface ComponentProps {\n field: string\n label?: string\n subheader?: string\n inputType?: string\n className?: string\n disabled?: boolean\n required?: boolean\n}\n\nexport const removeNonColorStyles = (htmlString: string) => {\n const stylePattern: RegExp = /style=\"([^\"]*)\"/g\n\n const colorPattern: RegExp = /(color|background-color):[^;\"]+;/g\n\n if (!htmlString) {\n return ''\n }\n\n const modifiedHtml: string = htmlString.replace(stylePattern, (match: string) => {\n const styles: string = match.match(/\"([^\"]*)\"/)![1]\n const colorStyles: string[] = styles.match(colorPattern) || []\n return colorStyles.length > 0 ? `style=\"${colorStyles.join(';')}\"` : ''\n })\n\n return modifiedHtml\n}\n\nconst RichTextInput = ({\n field,\n label,\n subheader,\n className,\n disabled,\n required,\n}: ComponentProps) => {\n const { isChanged, control, resource, errors, clearError } = useContext(FormContext)\n const [isReady, setIsReady] = useState(false)\n const [isFieldDirty, setIsFieldDirty] = useState(false)\n\n const [quillValue, setQuillValue] = useState('')\n\n useEffect(() => {\n // Hacky solution to stop from autofocusing\n const timer = setTimeout(() => {\n setIsReady(true)\n }, 100)\n\n return () => clearTimeout(timer)\n }, [])\n\n useEffect(() => {\n setIsFieldDirty(isChanged(field))\n }, [resource])\n\n return (\n
\n {label?.length && (\n
\n \n {label || titleCase(field)}\n {errors[field] && (\n {errors[field].message}\n )}\n \n {subheader && {subheader}}\n
\n )}\n {\n if (!quillValue.length) {\n setQuillValue(removeNonColorStyles(field.value))\n }\n\n return (\n 550 ? desktopToolbar : mobileToolbar,\n }}\n className={classNames(\n errors[field.name] ? 'border-red-600' : 'border-gray-300',\n isFieldDirty ? 'bg-blue-50' : 'bg-white',\n className\n )}\n value={quillValue}\n readOnly={!isReady || disabled}\n onChange={(v) => {\n if (errors[field.name]) clearError(field.name)\n setQuillValue(v)\n field.onChange(v === '


' ? null : juice(richTextInputStyles + v))\n }}\n />\n )\n }}\n />\n
\n )\n}\n\nexport default RichTextInput\n","import React, { useState, useEffect } from \"react\"\nimport useAdminForm from \"../../../../hooks/useAdminForm\"\nimport { CampingStyleProps } from \"../../../../interfaces\"\nimport classNames from \"../../../../utils/classNames\"\n\ninterface NumberInputProps {\n field: keyof CampingStyleProps\n label?: string\n subheader?: string\n prefix?: string\n suffix?: string\n suffixButtonCta?: string | JSX.Element\n placeholder?: string\n onSuffixButtonClick?: () => void\n className?: string\n hidden?: boolean\n disabled?: boolean\n stopPropagation?: boolean\n onInput?: (e: React.FormEvent) => void\n asText?: boolean\n}\n\nconst DollarFieldWithLabel = ({\n field,\n label,\n subheader,\n prefix,\n suffix,\n placeholder,\n className,\n hidden,\n disabled,\n stopPropagation,\n onInput,\n}: NumberInputProps) => {\n \n const { resource, isChanged, setValue, errors, clearError, register } = useAdminForm()\n\n const convertToDollars = (value) => {\n return value === null ? null : Number(value) / 100\n }\n\n const convertToCents = (value) => {\n return (value === null || !value?.length) ? null : Number(value) * 100\n }\n \n const convertToNumber = (value) => {\n return (value === null || !value?.length) ? null : Number(value)\n }\n\n const defaultValue = convertToDollars(resource[field])\n\n const [fieldValue, setFieldValue] = useState(defaultValue)\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (['.', ','].includes(e.key)) {\n e.preventDefault()\n }\n }\n \n useEffect(() => {\n register(field, {})\n }, [register])\n\n return (\n \n )\n}\n\nexport default DollarFieldWithLabel","import React, { useState, useEffect } from 'react'\nimport useAdminForm from '../../hooks/useAdminForm'\nimport { CampingStyleProps } from '../../interfaces'\nimport classNames from '../../utils/classNames'\n\ninterface NumberInputProps {\n field: keyof CampingStyleProps\n label?: string\n subheader?: string\n prefix?: string\n suffix?: string\n suffixButtonCta?: string | JSX.Element\n placeholder?: string\n onSuffixButtonClick?: () => void\n className?: string\n hidden?: boolean\n disabled?: boolean\n stopPropagation?: boolean\n onInput?: (e: React.FormEvent) => void\n asText?: boolean\n}\n\nconst PercentFieldWithLabel = ({\n field,\n label,\n subheader,\n prefix,\n suffix,\n placeholder,\n className,\n hidden,\n disabled,\n stopPropagation,\n onInput,\n}: NumberInputProps) => {\n const { resource, isChanged, setValue, errors, clearError, register } = useAdminForm()\n\n const convertToPercentInFractions = (value) => {\n let precision = value?.toString()?.split('.')?.[1]?.length + 2\n\n if (!precision || precision < 0) {\n precision = 0\n }\n \n const divisionResult = parseFloat(value) / 100\n\n return value === null ? null : parseFloat(precision > 0 ? divisionResult.toFixed(precision) : divisionResult.toString())\n }\n\n const convertToPercent = (value) => {\n let precision = resource[field]?.toString()?.split('.')?.[1]?.length - 2\n\n if (!precision || precision < 0) {\n precision = 0\n }\n\n return value === null || !value?.length ? null : parseFloat((parseFloat(value as string) * 100).toFixed(precision))\n }\n\n const convertToNumber = (value) => {\n return value === null || !value?.length ? null : parseFloat(value)\n }\n\n const defaultValue = convertToPercent(resource[field])\n\n const [fieldValue, setFieldValue] = useState(defaultValue)\n\n useEffect(() => {\n register(field, {})\n }, [register])\n\n return (\n \n )\n}\n\nexport default PercentFieldWithLabel\n","import TextAreaInput from './TextAreaInput'\nimport TextInput from './TextInput'\nimport NumberInput from './NumberInput'\nimport DecimalInput from './DecimalInput'\nimport SelectInput from './SelectInput'\nimport RichTextInput from './RichTextInput'\nimport DollarFieldWithLabel from './DollarFieldWithLabel'\nimport PercentFieldWithLabel from '../../PercentFieldWithLabel'\n\nconst Form = {\n NumberInput,\n DecimalInput,\n RichTextInput,\n SelectInput,\n TextAreaInput,\n TextInput,\n DollarFieldWithLabel,\n PercentFieldWithLabel\n}\n\nexport default Form\n","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t(require(\"react\"),require(\"react-dom\")):\"function\"==typeof define&&define.amd?define(\"lib\",[\"react\",\"react-dom\"],t):\"object\"==typeof exports?exports.lib=t(require(\"react\"),require(\"react-dom\")):e.lib=t(e.react,e[\"react-dom\"])}(\"undefined\"!=typeof self?self:this,(function(e,t){return function(){\"use strict\";var r={328:function(e,t,r){Object.defineProperty(t,\"__esModule\",{value:!0}),t.PrintContextConsumer=t.PrintContext=void 0;var n=r(496),o=Object.prototype.hasOwnProperty.call(n,\"createContext\");t.PrintContext=o?n.createContext({}):null,t.PrintContextConsumer=t.PrintContext?t.PrintContext.Consumer:function(){return null}},428:function(e,t,r){Object.defineProperty(t,\"__esModule\",{value:!0}),t.ReactToPrint=void 0;var n=r(316),o=r(496),i=r(190),a=r(328),c=r(940),s=function(e){function t(){var t=e.apply(this,n.__spreadArray([],n.__read(arguments),!1))||this;return t.startPrint=function(e){var r=t.props,n=r.onAfterPrint,o=r.onPrintError,i=r.print,a=r.documentTitle;setTimeout((function(){var r,c;if(e.contentWindow)if(e.contentWindow.focus(),i)i(e).then((function(){return null==n?void 0:n()})).then((function(){return t.handleRemoveIframe()})).catch((function(e){o?o(\"print\",e):t.logMessages([\"An error was thrown by the specified `print` function\"])}));else{if(e.contentWindow.print){var s=null!==(c=null===(r=e.contentDocument)||void 0===r?void 0:r.title)&&void 0!==c?c:\"\",u=e.ownerDocument.title;a&&(e.ownerDocument.title=a,e.contentDocument&&(e.contentDocument.title=a)),e.contentWindow.print(),a&&(e.ownerDocument.title=u,e.contentDocument&&(e.contentDocument.title=s))}else t.logMessages([\"Printing for this browser is not currently possible: the browser does not have a `print` method available for iframes.\"]);null==n||n(),t.handleRemoveIframe()}else t.logMessages([\"Printing failed because the `contentWindow` of the print iframe did not load. This is possibly an error with `react-to-print`. Please file an issue: https://github.com/gregnb/react-to-print/issues/\"])}),500)},t.triggerPrint=function(e){var r=t.props,n=r.onBeforePrint,o=r.onPrintError;if(n){var i=n();i&&\"function\"==typeof i.then?i.then((function(){t.startPrint(e)})).catch((function(e){o&&o(\"onBeforePrint\",e)})):t.startPrint(e)}else t.startPrint(e)},t.handlePrint=function(e){var r=t.props,o=r.bodyClass,a=r.content,c=r.copyStyles,s=r.fonts,u=r.pageStyle,l=r.nonce,f=\"function\"==typeof e?e():null;if(f&&\"function\"==typeof a&&t.logMessages(['\"react-to-print\" received a `content` prop and a content param passed the callback return by `useReactToPrint. The `content` prop will be ignored.'],\"warning\"),f||\"function\"!=typeof a||(f=a()),void 0!==f)if(null!==f){var d=document.createElement(\"iframe\");d.width=\"\".concat(document.documentElement.clientWidth,\"px\"),d.height=\"\".concat(document.documentElement.clientHeight,\"px\"),d.style.position=\"absolute\",d.style.top=\"-\".concat(document.documentElement.clientHeight+100,\"px\"),d.style.left=\"-\".concat(document.documentElement.clientWidth+100,\"px\"),d.id=\"printWindow\",d.srcdoc=\"\";var p=(0,i.findDOMNode)(f);if(p){var h=p.cloneNode(!0),y=h instanceof Text,b=document.querySelectorAll(\"link[rel~='stylesheet'], link[as='style']\"),v=y?[]:h.querySelectorAll(\"img\"),g=y?[]:h.querySelectorAll(\"video\"),m=s?s.length:0;t.numResourcesToLoad=b.length+v.length+g.length+m,t.resourcesLoaded=[],t.resourcesErrored=[];var _=function(e,r){t.resourcesLoaded.includes(e)?t.logMessages([\"Tried to mark a resource that has already been handled\",e],\"debug\"):(r?(t.logMessages(n.__spreadArray(['\"react-to-print\" was unable to load a resource but will continue attempting to print the page'],n.__read(r),!1)),t.resourcesErrored.push(e)):t.resourcesLoaded.push(e),t.resourcesLoaded.length+t.resourcesErrored.length===t.numResourcesToLoad&&t.triggerPrint(d))};d.onload=function(){var e,r,i,a;d.onload=null;var f=d.contentDocument||(null===(r=d.contentWindow)||void 0===r?void 0:r.document);if(f){f.body.appendChild(h),s&&((null===(i=d.contentDocument)||void 0===i?void 0:i.fonts)&&(null===(a=d.contentWindow)||void 0===a?void 0:a.FontFace)?s.forEach((function(e){var t=new FontFace(e.family,e.source,{weight:e.weight,style:e.style});d.contentDocument.fonts.add(t),t.loaded.then((function(){_(t)})).catch((function(e){_(t,[\"Failed loading the font:\",t,\"Load error:\",e])}))})):(s.forEach((function(e){return _(e)})),t.logMessages(['\"react-to-print\" is not able to load custom fonts because the browser does not support the FontFace API but will continue attempting to print the page'])));var b=\"function\"==typeof u?u():u;if(\"string\"!=typeof b)t.logMessages(['\"react-to-print\" expected a \"string\" from `pageStyle` but received \"'.concat(typeof b,'\". Styles from `pageStyle` will not be applied.')]);else{var m=f.createElement(\"style\");l&&(m.setAttribute(\"nonce\",l),f.head.setAttribute(\"nonce\",l)),m.appendChild(f.createTextNode(b)),f.head.appendChild(m)}if(o&&(e=f.body.classList).add.apply(e,n.__spreadArray([],n.__read(o.split(\" \")),!1)),!y){for(var w=y?[]:p.querySelectorAll(\"canvas\"),P=f.querySelectorAll(\"canvas\"),O=0;O\",t,\"Error\",i])},n.src=r}else _(t,['Found an tag with an empty \"src\" attribute. This prevents pre-loading it. The is:',t])};for(O=0;O=2?_(t):(t.onloadeddata=function(){return _(t)},t.onerror=function(e,r,n,o,i){return _(t,[\"Error loading video\",t,\"Error\",i])},t.onstalled=function(){return _(t,[\"Loading video stalled, skipping\",t])})};for(O=0;O tag with a `disabled` attribute and will ignore it. Note that the `disabled` attribute is deprecated, and some browsers ignore it. You should stop using it. https://developer.mozilla.org/en-US/docs/Web/HTML/Element/link#attr-disabled. The is:\",n],\"warning\"),_(n);else{for(var u=f.createElement(n.tagName),d=(s=0,n.attributes.length);s tag with an empty `href` attribute. In addition to being invalid HTML, this can cause problems in many browsers, and so the was not loaded. The is:\",n],\"warning\"),_(n)},L=(O=0,F.length);O=0;c--)(o=e[c])&&(a=(i<3?o(a):i>3?o(t,r,a):o(t,r))||a);return i>3&&a&&Object.defineProperty(t,r,a),a}function s(e,t){return function(r,n){t(r,n,e)}}function u(e,t,r,n,o,i){function a(e){if(void 0!==e&&\"function\"!=typeof e)throw new TypeError(\"Function expected\");return e}for(var c,s=n.kind,u=\"getter\"===s?\"get\":\"setter\"===s?\"set\":\"value\",l=!t&&e?n.static?e:e.prototype:null,f=t||(l?Object.getOwnPropertyDescriptor(l,n.name):{}),d=!1,p=r.length-1;p>=0;p--){var h={};for(var y in n)h[y]=\"access\"===y?{}:n[y];for(var y in n.access)h.access[y]=n.access[y];h.addInitializer=function(e){if(d)throw new TypeError(\"Cannot add initializers after decoration has completed\");i.push(a(e||null))};var b=(0,r[p])(\"accessor\"===s?{get:f.get,set:f.set}:f[u],h);if(\"accessor\"===s){if(void 0===b)continue;if(null===b||\"object\"!=typeof b)throw new TypeError(\"Object expected\");(c=a(b.get))&&(f.get=c),(c=a(b.set))&&(f.set=c),(c=a(b.init))&&o.unshift(c)}else(c=a(b))&&(\"field\"===s?o.unshift(c):f[u]=c)}l&&Object.defineProperty(l,n.name,f),d=!0}function l(e,t,r){for(var n=arguments.length>2,o=0;o0&&o[o.length-1])||6!==c[0]&&2!==c[0])){a=0;continue}if(3===c[0]&&(!o||c[1]>o[0]&&c[1]=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?\"Object is not iterable.\":\"Symbol.iterator is not defined.\")}function m(e,t){var r=\"function\"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,i=r.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(n=i.next()).done;)a.push(n.value)}catch(e){o={error:e}}finally{try{n&&!n.done&&(r=i.return)&&r.call(i)}finally{if(o)throw o.error}}return a}function _(){for(var e=[],t=0;t1||c(e,t)}))})}function c(e,t){try{(r=o[e](t)).value instanceof O?Promise.resolve(r.value.v).then(s,u):l(i[0][2],r)}catch(e){l(i[0][3],e)}var r}function s(e){c(\"next\",e)}function u(e){c(\"throw\",e)}function l(e,t){e(t),i.shift(),i.length&&c(i[0][0],i[0][1])}}function S(e){var t,r;return t={},n(\"next\"),n(\"throw\",(function(e){throw e})),n(\"return\"),t[Symbol.iterator]=function(){return this},t;function n(n,o){t[n]=e[n]?function(t){return(r=!r)?{value:O(e[n](t)),done:!1}:o?o(t):t}:o}}function E(e){if(!Symbol.asyncIterator)throw new TypeError(\"Symbol.asyncIterator is not defined.\");var t,r=e[Symbol.asyncIterator];return r?r.call(e):(e=g(e),t={},n(\"next\"),n(\"throw\"),n(\"return\"),t[Symbol.asyncIterator]=function(){return this},t);function n(r){t[r]=e[r]&&function(t){return new Promise((function(n,o){!function(e,t,r,n){Promise.resolve(n).then((function(t){e({value:t,done:r})}),t)}(n,o,(t=e[r](t)).done,t.value)}))}}}function T(e,t){return Object.defineProperty?Object.defineProperty(e,\"raw\",{value:t}):e.raw=t,e}var j=Object.create?function(e,t){Object.defineProperty(e,\"default\",{enumerable:!0,value:t})}:function(e,t){e.default=t};function C(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)\"default\"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&b(t,e,r);return j(t,e),t}function A(e){return e&&e.__esModule?e:{default:e}}function k(e,t,r,n){if(\"a\"===r&&!n)throw new TypeError(\"Private accessor was defined without a getter\");if(\"function\"==typeof t?e!==t||!n:!t.has(e))throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");return\"m\"===r?n:\"a\"===r?n.call(e):n?n.value:t.get(e)}function R(e,t,r,n,o){if(\"m\"===n)throw new TypeError(\"Private method is not writable\");if(\"a\"===n&&!o)throw new TypeError(\"Private accessor was defined without a setter\");if(\"function\"==typeof t?e!==t||!o:!t.has(e))throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");return\"a\"===n?o.call(e,r):o?o.value=r:t.set(e,r),r}function M(e,t){if(null===t||\"object\"!=typeof t&&\"function\"!=typeof t)throw new TypeError(\"Cannot use 'in' operator on non-object\");return\"function\"==typeof e?t===e:e.has(t)}function D(e,t,r){if(null!=t){if(\"object\"!=typeof t&&\"function\"!=typeof t)throw new TypeError(\"Object expected.\");var n;if(r){if(!Symbol.asyncDispose)throw new TypeError(\"Symbol.asyncDispose is not defined.\");n=t[Symbol.asyncDispose]}if(void 0===n){if(!Symbol.dispose)throw new TypeError(\"Symbol.dispose is not defined.\");n=t[Symbol.dispose]}if(\"function\"!=typeof n)throw new TypeError(\"Object not disposable.\");e.stack.push({value:t,dispose:n,async:r})}else r&&e.stack.push({async:!0});return t}var I=\"function\"==typeof SuppressedError?SuppressedError:function(e,t,r){var n=new Error(r);return n.name=\"SuppressedError\",n.error=e,n.suppressed=t,n};function q(e){function t(t){e.error=e.hasError?new I(t,e.error,\"An error was suppressed during disposal.\"):t,e.hasError=!0}return function r(){for(;e.stack.length;){var n=e.stack.pop();try{var o=n.dispose&&n.dispose.call(n.value);if(n.async)return Promise.resolve(o).then(r,(function(e){return t(e),r()}))}catch(e){t(e)}}if(e.hasError)throw e.error}()}t.default={__extends:o,__assign:i,__rest:a,__decorate:c,__param:s,__metadata:p,__awaiter:h,__generator:y,__createBinding:b,__exportStar:v,__values:g,__read:m,__spread:_,__spreadArrays:w,__spreadArray:P,__await:O,__asyncGenerator:x,__asyncDelegator:S,__asyncValues:E,__makeTemplateObject:T,__importStar:C,__importDefault:A,__classPrivateFieldGet:k,__classPrivateFieldSet:R,__classPrivateFieldIn:M,__addDisposableResource:D,__disposeResources:q}}},n={};function o(e){var t=n[e];if(void 0!==t)return t.exports;var i=n[e]={exports:{}};return r[e](i,i.exports,o),i.exports}o.d=function(e,t){for(var r in t)o.o(t,r)&&!o.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})};var i={};return function(){var e=i;Object.defineProperty(e,\"__esModule\",{value:!0}),e.useReactToPrint=e.ReactToPrint=e.PrintContextConsumer=void 0;var t=o(328);Object.defineProperty(e,\"PrintContextConsumer\",{enumerable:!0,get:function(){return t.PrintContextConsumer}});var r=o(428);Object.defineProperty(e,\"ReactToPrint\",{enumerable:!0,get:function(){return r.ReactToPrint}});var n=o(892);Object.defineProperty(e,\"useReactToPrint\",{enumerable:!0,get:function(){return n.useReactToPrint}});var a=o(428);e.default=a.ReactToPrint}(),i}()}));","const createMarkup = (rules: string) => {\n return { __html: rules }\n}\n\nexport default createMarkup\n","function _interopRequireDefault(e) {\n return e && e.__esModule ? e : {\n \"default\": e\n };\n}\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar toStr = Object.prototype.toString;\n\nmodule.exports = function isArguments(value) {\n\tvar str = toStr.call(value);\n\tvar isArgs = str === '[object Arguments]';\n\tif (!isArgs) {\n\t\tisArgs = str !== '[object Array]' &&\n\t\t\tvalue !== null &&\n\t\t\ttypeof value === 'object' &&\n\t\t\ttypeof value.length === 'number' &&\n\t\t\tvalue.length >= 0 &&\n\t\t\ttoStr.call(value.callee) === '[object Function]';\n\t}\n\treturn isArgs;\n};\n","'use strict';\n\nvar keysShim;\nif (!Object.keys) {\n\t// modified from https://github.com/es-shims/es5-shim\n\tvar has = Object.prototype.hasOwnProperty;\n\tvar toStr = Object.prototype.toString;\n\tvar isArgs = require('./isArguments'); // eslint-disable-line global-require\n\tvar isEnumerable = Object.prototype.propertyIsEnumerable;\n\tvar hasDontEnumBug = !isEnumerable.call({ toString: null }, 'toString');\n\tvar hasProtoEnumBug = isEnumerable.call(function () {}, 'prototype');\n\tvar dontEnums = [\n\t\t'toString',\n\t\t'toLocaleString',\n\t\t'valueOf',\n\t\t'hasOwnProperty',\n\t\t'isPrototypeOf',\n\t\t'propertyIsEnumerable',\n\t\t'constructor'\n\t];\n\tvar equalsConstructorPrototype = function (o) {\n\t\tvar ctor = o.constructor;\n\t\treturn ctor && ctor.prototype === o;\n\t};\n\tvar excludedKeys = {\n\t\t$applicationCache: true,\n\t\t$console: true,\n\t\t$external: true,\n\t\t$frame: true,\n\t\t$frameElement: true,\n\t\t$frames: true,\n\t\t$innerHeight: true,\n\t\t$innerWidth: true,\n\t\t$onmozfullscreenchange: true,\n\t\t$onmozfullscreenerror: true,\n\t\t$outerHeight: true,\n\t\t$outerWidth: true,\n\t\t$pageXOffset: true,\n\t\t$pageYOffset: true,\n\t\t$parent: true,\n\t\t$scrollLeft: true,\n\t\t$scrollTop: true,\n\t\t$scrollX: true,\n\t\t$scrollY: true,\n\t\t$self: true,\n\t\t$webkitIndexedDB: true,\n\t\t$webkitStorageInfo: true,\n\t\t$window: true\n\t};\n\tvar hasAutomationEqualityBug = (function () {\n\t\t/* global window */\n\t\tif (typeof window === 'undefined') { return false; }\n\t\tfor (var k in window) {\n\t\t\ttry {\n\t\t\t\tif (!excludedKeys['$' + k] && has.call(window, k) && window[k] !== null && typeof window[k] === 'object') {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tequalsConstructorPrototype(window[k]);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\treturn false;\n\t}());\n\tvar equalsConstructorPrototypeIfNotBuggy = function (o) {\n\t\t/* global window */\n\t\tif (typeof window === 'undefined' || !hasAutomationEqualityBug) {\n\t\t\treturn equalsConstructorPrototype(o);\n\t\t}\n\t\ttry {\n\t\t\treturn equalsConstructorPrototype(o);\n\t\t} catch (e) {\n\t\t\treturn false;\n\t\t}\n\t};\n\n\tkeysShim = function keys(object) {\n\t\tvar isObject = object !== null && typeof object === 'object';\n\t\tvar isFunction = toStr.call(object) === '[object Function]';\n\t\tvar isArguments = isArgs(object);\n\t\tvar isString = isObject && toStr.call(object) === '[object String]';\n\t\tvar theKeys = [];\n\n\t\tif (!isObject && !isFunction && !isArguments) {\n\t\t\tthrow new TypeError('Object.keys called on a non-object');\n\t\t}\n\n\t\tvar skipProto = hasProtoEnumBug && isFunction;\n\t\tif (isString && object.length > 0 && !has.call(object, 0)) {\n\t\t\tfor (var i = 0; i < object.length; ++i) {\n\t\t\t\ttheKeys.push(String(i));\n\t\t\t}\n\t\t}\n\n\t\tif (isArguments && object.length > 0) {\n\t\t\tfor (var j = 0; j < object.length; ++j) {\n\t\t\t\ttheKeys.push(String(j));\n\t\t\t}\n\t\t} else {\n\t\t\tfor (var name in object) {\n\t\t\t\tif (!(skipProto && name === 'prototype') && has.call(object, name)) {\n\t\t\t\t\ttheKeys.push(String(name));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (hasDontEnumBug) {\n\t\t\tvar skipConstructor = equalsConstructorPrototypeIfNotBuggy(object);\n\n\t\t\tfor (var k = 0; k < dontEnums.length; ++k) {\n\t\t\t\tif (!(skipConstructor && dontEnums[k] === 'constructor') && has.call(object, dontEnums[k])) {\n\t\t\t\t\ttheKeys.push(dontEnums[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn theKeys;\n\t};\n}\nmodule.exports = keysShim;\n","'use strict';\n\nvar slice = Array.prototype.slice;\nvar isArgs = require('./isArguments');\n\nvar origKeys = Object.keys;\nvar keysShim = origKeys ? function keys(o) { return origKeys(o); } : require('./implementation');\n\nvar originalKeys = Object.keys;\n\nkeysShim.shim = function shimObjectKeys() {\n\tif (Object.keys) {\n\t\tvar keysWorksWithArguments = (function () {\n\t\t\t// Safari 5.0 bug\n\t\t\tvar args = Object.keys(arguments);\n\t\t\treturn args && args.length === arguments.length;\n\t\t}(1, 2));\n\t\tif (!keysWorksWithArguments) {\n\t\t\tObject.keys = function keys(object) { // eslint-disable-line func-name-matching\n\t\t\t\tif (isArgs(object)) {\n\t\t\t\t\treturn originalKeys(slice.call(object));\n\t\t\t\t}\n\t\t\t\treturn originalKeys(object);\n\t\t\t};\n\t\t}\n\t} else {\n\t\tObject.keys = keysShim;\n\t}\n\treturn Object.keys || keysShim;\n};\n\nmodule.exports = keysShim;\n","'use strict';\n\n/** @type {import('.')} */\nvar $defineProperty = Object.defineProperty || false;\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = false;\n\t}\n}\n\nmodule.exports = $defineProperty;\n","'use strict';\n\n/** @type {import('./syntax')} */\nmodule.exports = SyntaxError;\n","'use strict';\n\n/** @type {import('./type')} */\nmodule.exports = TypeError;\n","'use strict';\n\n/** @type {import('./gOPD')} */\nmodule.exports = Object.getOwnPropertyDescriptor;\n","'use strict';\n\n/** @type {import('.')} */\nvar $gOPD = require('./gOPD');\n\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\n\nvar gopd = require('gopd');\n\n/** @type {import('.')} */\nmodule.exports = function defineDataProperty(\n\tobj,\n\tproperty,\n\tvalue\n) {\n\tif (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) {\n\t\tthrow new $TypeError('`obj` must be an object or a function`');\n\t}\n\tif (typeof property !== 'string' && typeof property !== 'symbol') {\n\t\tthrow new $TypeError('`property` must be a string or a symbol`');\n\t}\n\tif (arguments.length > 3 && typeof arguments[3] !== 'boolean' && arguments[3] !== null) {\n\t\tthrow new $TypeError('`nonEnumerable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 4 && typeof arguments[4] !== 'boolean' && arguments[4] !== null) {\n\t\tthrow new $TypeError('`nonWritable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 5 && typeof arguments[5] !== 'boolean' && arguments[5] !== null) {\n\t\tthrow new $TypeError('`nonConfigurable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 6 && typeof arguments[6] !== 'boolean') {\n\t\tthrow new $TypeError('`loose`, if provided, must be a boolean');\n\t}\n\n\tvar nonEnumerable = arguments.length > 3 ? arguments[3] : null;\n\tvar nonWritable = arguments.length > 4 ? arguments[4] : null;\n\tvar nonConfigurable = arguments.length > 5 ? arguments[5] : null;\n\tvar loose = arguments.length > 6 ? arguments[6] : false;\n\n\t/* @type {false | TypedPropertyDescriptor} */\n\tvar desc = !!gopd && gopd(obj, property);\n\n\tif ($defineProperty) {\n\t\t$defineProperty(obj, property, {\n\t\t\tconfigurable: nonConfigurable === null && desc ? desc.configurable : !nonConfigurable,\n\t\t\tenumerable: nonEnumerable === null && desc ? desc.enumerable : !nonEnumerable,\n\t\t\tvalue: value,\n\t\t\twritable: nonWritable === null && desc ? desc.writable : !nonWritable\n\t\t});\n\t} else if (loose || (!nonEnumerable && !nonWritable && !nonConfigurable)) {\n\t\t// must fall back to [[Set]], and was not explicitly asked to make non-enumerable, non-writable, or non-configurable\n\t\tobj[property] = value; // eslint-disable-line no-param-reassign\n\t} else {\n\t\tthrow new $SyntaxError('This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.');\n\t}\n};\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar hasPropertyDescriptors = function hasPropertyDescriptors() {\n\treturn !!$defineProperty;\n};\n\nhasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() {\n\t// node v0.6 has a bug where array lengths can be Set but not Defined\n\tif (!$defineProperty) {\n\t\treturn null;\n\t}\n\ttry {\n\t\treturn $defineProperty([], 'length', { value: 1 }).length !== 1;\n\t} catch (e) {\n\t\t// In Firefox 4-22, defining length on an array throws an exception.\n\t\treturn true;\n\t}\n};\n\nmodule.exports = hasPropertyDescriptors;\n","'use strict';\n\nvar keys = require('object-keys');\nvar hasSymbols = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol';\n\nvar toStr = Object.prototype.toString;\nvar concat = Array.prototype.concat;\nvar defineDataProperty = require('define-data-property');\n\nvar isFunction = function (fn) {\n\treturn typeof fn === 'function' && toStr.call(fn) === '[object Function]';\n};\n\nvar supportsDescriptors = require('has-property-descriptors')();\n\nvar defineProperty = function (object, name, value, predicate) {\n\tif (name in object) {\n\t\tif (predicate === true) {\n\t\t\tif (object[name] === value) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t} else if (!isFunction(predicate) || !predicate()) {\n\t\t\treturn;\n\t\t}\n\t}\n\n\tif (supportsDescriptors) {\n\t\tdefineDataProperty(object, name, value, true);\n\t} else {\n\t\tdefineDataProperty(object, name, value);\n\t}\n};\n\nvar defineProperties = function (object, map) {\n\tvar predicates = arguments.length > 2 ? arguments[2] : {};\n\tvar props = keys(map);\n\tif (hasSymbols) {\n\t\tprops = concat.call(props, Object.getOwnPropertySymbols(map));\n\t}\n\tfor (var i = 0; i < props.length; i += 1) {\n\t\tdefineProperty(object, props[i], map[props[i]], predicates[props[i]]);\n\t}\n};\n\ndefineProperties.supportsDescriptors = !!supportsDescriptors;\n\nmodule.exports = defineProperties;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Object;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Error;\n","'use strict';\n\n/** @type {import('./eval')} */\nmodule.exports = EvalError;\n","'use strict';\n\n/** @type {import('./range')} */\nmodule.exports = RangeError;\n","'use strict';\n\n/** @type {import('./ref')} */\nmodule.exports = ReferenceError;\n","'use strict';\n\n/** @type {import('./uri')} */\nmodule.exports = URIError;\n","'use strict';\n\n/** @type {import('./abs')} */\nmodule.exports = Math.abs;\n","'use strict';\n\n/** @type {import('./floor')} */\nmodule.exports = Math.floor;\n","'use strict';\n\n/** @type {import('./max')} */\nmodule.exports = Math.max;\n","'use strict';\n\n/** @type {import('./min')} */\nmodule.exports = Math.min;\n","'use strict';\n\n/** @type {import('./pow')} */\nmodule.exports = Math.pow;\n","'use strict';\n\n/** @type {import('./round')} */\nmodule.exports = Math.round;\n","'use strict';\n\n/** @type {import('./isNaN')} */\nmodule.exports = Number.isNaN || function isNaN(a) {\n\treturn a !== a;\n};\n","'use strict';\n\nvar $isNaN = require('./isNaN');\n\n/** @type {import('./sign')} */\nmodule.exports = function sign(number) {\n\tif ($isNaN(number) || number === 0) {\n\t\treturn number;\n\t}\n\treturn number < 0 ? -1 : +1;\n};\n","'use strict';\n\n/** @type {import('./shams')} */\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\t/** @type {{ [k in symbol]?: unknown }} */\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (var _ in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\t// eslint-disable-next-line no-extra-parens\n\t\tvar descriptor = /** @type {PropertyDescriptor} */ (Object.getOwnPropertyDescriptor(obj, sym));\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\n/** @type {import('./Reflect.getPrototypeOf')} */\nmodule.exports = (typeof Reflect !== 'undefined' && Reflect.getPrototypeOf) || null;\n","'use strict';\n\nvar $Object = require('es-object-atoms');\n\n/** @type {import('./Object.getPrototypeOf')} */\nmodule.exports = $Object.getPrototypeOf || null;\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar toStr = Object.prototype.toString;\nvar max = Math.max;\nvar funcType = '[object Function]';\n\nvar concatty = function concatty(a, b) {\n var arr = [];\n\n for (var i = 0; i < a.length; i += 1) {\n arr[i] = a[i];\n }\n for (var j = 0; j < b.length; j += 1) {\n arr[j + a.length] = b[j];\n }\n\n return arr;\n};\n\nvar slicy = function slicy(arrLike, offset) {\n var arr = [];\n for (var i = offset || 0, j = 0; i < arrLike.length; i += 1, j += 1) {\n arr[j] = arrLike[i];\n }\n return arr;\n};\n\nvar joiny = function (arr, joiner) {\n var str = '';\n for (var i = 0; i < arr.length; i += 1) {\n str += arr[i];\n if (i + 1 < arr.length) {\n str += joiner;\n }\n }\n return str;\n};\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.apply(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slicy(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n concatty(args, arguments)\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n }\n return target.apply(\n that,\n concatty(args, arguments)\n );\n\n };\n\n var boundLength = max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs[i] = '$' + i;\n }\n\n bound = Function('binder', 'return function (' + joiny(boundArgs, ',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","'use strict';\n\n/** @type {import('./functionCall')} */\nmodule.exports = Function.prototype.call;\n","'use strict';\n\n/** @type {import('./functionApply')} */\nmodule.exports = Function.prototype.apply;\n","'use strict';\n\n/** @type {import('./reflectApply')} */\nmodule.exports = typeof Reflect !== 'undefined' && Reflect && Reflect.apply;\n","'use strict';\n\nvar bind = require('function-bind');\n\nvar $apply = require('./functionApply');\nvar $call = require('./functionCall');\nvar $reflectApply = require('./reflectApply');\n\n/** @type {import('./actualApply')} */\nmodule.exports = $reflectApply || bind.call($call, $apply);\n","'use strict';\n\nvar bind = require('function-bind');\nvar $TypeError = require('es-errors/type');\n\nvar $call = require('./functionCall');\nvar $actualApply = require('./actualApply');\n\n/** @type {(args: [Function, thisArg?: unknown, ...args: unknown[]]) => Function} TODO FIXME, find a way to use import('.') */\nmodule.exports = function callBindBasic(args) {\n\tif (args.length < 1 || typeof args[0] !== 'function') {\n\t\tthrow new $TypeError('a function is required');\n\t}\n\treturn $actualApply(bind, $call, args);\n};\n","'use strict';\n\nvar callBind = require('call-bind-apply-helpers');\nvar gOPD = require('gopd');\n\nvar hasProtoAccessor;\ntry {\n\t// eslint-disable-next-line no-extra-parens, no-proto\n\thasProtoAccessor = /** @type {{ __proto__?: typeof Array.prototype }} */ ([]).__proto__ === Array.prototype;\n} catch (e) {\n\tif (!e || typeof e !== 'object' || !('code' in e) || e.code !== 'ERR_PROTO_ACCESS') {\n\t\tthrow e;\n\t}\n}\n\n// eslint-disable-next-line no-extra-parens\nvar desc = !!hasProtoAccessor && gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));\n\nvar $Object = Object;\nvar $getPrototypeOf = $Object.getPrototypeOf;\n\n/** @type {import('./get')} */\nmodule.exports = desc && typeof desc.get === 'function'\n\t? callBind([desc.get])\n\t: typeof $getPrototypeOf === 'function'\n\t\t? /** @type {import('./get')} */ function getDunder(value) {\n\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\treturn $getPrototypeOf(value == null ? value : $Object(value));\n\t\t}\n\t\t: false;\n","'use strict';\n\nvar reflectGetProto = require('./Reflect.getPrototypeOf');\nvar originalGetProto = require('./Object.getPrototypeOf');\n\nvar getDunderProto = require('dunder-proto/get');\n\n/** @type {import('.')} */\nmodule.exports = reflectGetProto\n\t? function getProto(O) {\n\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\treturn reflectGetProto(O);\n\t}\n\t: originalGetProto\n\t\t? function getProto(O) {\n\t\t\tif (!O || (typeof O !== 'object' && typeof O !== 'function')) {\n\t\t\t\tthrow new TypeError('getProto: not an object');\n\t\t\t}\n\t\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\t\treturn originalGetProto(O);\n\t\t}\n\t\t: getDunderProto\n\t\t\t? function getProto(O) {\n\t\t\t\t// @ts-expect-error TS can't narrow inside a closure, for some reason\n\t\t\t\treturn getDunderProto(O);\n\t\t\t}\n\t\t\t: null;\n","'use strict';\n\nvar call = Function.prototype.call;\nvar $hasOwn = Object.prototype.hasOwnProperty;\nvar bind = require('function-bind');\n\n/** @type {import('.')} */\nmodule.exports = bind.call(call, $hasOwn);\n","'use strict';\n\nvar undefined;\n\nvar $Object = require('es-object-atoms');\n\nvar $Error = require('es-errors');\nvar $EvalError = require('es-errors/eval');\nvar $RangeError = require('es-errors/range');\nvar $ReferenceError = require('es-errors/ref');\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\nvar $URIError = require('es-errors/uri');\n\nvar abs = require('math-intrinsics/abs');\nvar floor = require('math-intrinsics/floor');\nvar max = require('math-intrinsics/max');\nvar min = require('math-intrinsics/min');\nvar pow = require('math-intrinsics/pow');\nvar round = require('math-intrinsics/round');\nvar sign = require('math-intrinsics/sign');\n\nvar $Function = Function;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = require('gopd');\nvar $defineProperty = require('es-define-property');\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\n\nvar getProto = require('get-proto');\nvar $ObjectGPO = require('get-proto/Object.getPrototypeOf');\nvar $ReflectGPO = require('get-proto/Reflect.getPrototypeOf');\n\nvar $apply = require('call-bind-apply-helpers/functionApply');\nvar $call = require('call-bind-apply-helpers/functionCall');\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' || !getProto ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t__proto__: null,\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols && getProto ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%BigInt64Array%': typeof BigInt64Array === 'undefined' ? undefined : BigInt64Array,\n\t'%BigUint64Array%': typeof BigUint64Array === 'undefined' ? undefined : BigUint64Array,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': $Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': $EvalError,\n\t'%Float16Array%': typeof Float16Array === 'undefined' ? undefined : Float16Array,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols && getProto ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': $Object,\n\t'%Object.getOwnPropertyDescriptor%': $gOPD,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': $RangeError,\n\t'%ReferenceError%': $ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols && getProto ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': $URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet,\n\n\t'%Function.prototype.call%': $call,\n\t'%Function.prototype.apply%': $apply,\n\t'%Object.defineProperty%': $defineProperty,\n\t'%Object.getPrototypeOf%': $ObjectGPO,\n\t'%Math.abs%': abs,\n\t'%Math.floor%': floor,\n\t'%Math.max%': max,\n\t'%Math.min%': min,\n\t'%Math.pow%': pow,\n\t'%Math.round%': round,\n\t'%Math.sign%': sign,\n\t'%Reflect.getPrototypeOf%': $ReflectGPO\n};\n\nif (getProto) {\n\ttry {\n\t\tnull.error; // eslint-disable-line no-unused-expressions\n\t} catch (e) {\n\t\t// https://github.com/tc39/proposal-shadowrealm/pull/384#issuecomment-1364264229\n\t\tvar errorProto = getProto(getProto(e));\n\t\tINTRINSICS['%Error.prototype%'] = errorProto;\n\t}\n}\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen && getProto) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t__proto__: null,\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('hasown');\nvar $concat = bind.call($call, Array.prototype.concat);\nvar $spliceApply = bind.call($apply, Array.prototype.splice);\nvar $replace = bind.call($call, String.prototype.replace);\nvar $strSlice = bind.call($call, String.prototype.slice);\nvar $exec = bind.call($call, RegExp.prototype.exec);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tif ($exec(/^%?[^%]*%?$/, name) === null) {\n\t\tthrow new $SyntaxError('`%` may not be present anywhere but at the beginning and end of the intrinsic name');\n\t}\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\n\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tif (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n\t\tthrow new $TypeError('`length` must be a positive 32-bit integer');\n\t}\n\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\n\tvar functionLengthIsConfigurable = true;\n\tvar functionLengthIsWritable = true;\n\tif ('length' in fn && gOPD) {\n\t\tvar desc = gOPD(fn, 'length');\n\t\tif (desc && !desc.configurable) {\n\t\t\tfunctionLengthIsConfigurable = false;\n\t\t}\n\t\tif (desc && !desc.writable) {\n\t\t\tfunctionLengthIsWritable = false;\n\t\t}\n\t}\n\n\tif (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length);\n\t\t}\n\t}\n\treturn fn;\n};\n","'use strict';\n\nvar bind = require('function-bind');\nvar $apply = require('./functionApply');\nvar actualApply = require('./actualApply');\n\n/** @type {import('./applyBind')} */\nmodule.exports = function applyBind() {\n\treturn actualApply(bind, $apply, arguments);\n};\n","'use strict';\n\nvar setFunctionLength = require('set-function-length');\n\nvar $defineProperty = require('es-define-property');\n\nvar callBindBasic = require('call-bind-apply-helpers');\nvar applyBind = require('call-bind-apply-helpers/applyBind');\n\nmodule.exports = function callBind(originalFunction) {\n\tvar func = callBindBasic(arguments);\n\tvar adjustedLength = originalFunction.length - (arguments.length - 1);\n\treturn setFunctionLength(\n\t\tfunc,\n\t\t1 + (adjustedLength > 0 ? adjustedLength : 0),\n\t\ttrue\n\t);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","'use strict';\n\nvar numberIsNaN = function (value) {\n\treturn value !== value;\n};\n\nmodule.exports = function is(a, b) {\n\tif (a === 0 && b === 0) {\n\t\treturn 1 / a === 1 / b;\n\t}\n\tif (a === b) {\n\t\treturn true;\n\t}\n\tif (numberIsNaN(a) && numberIsNaN(b)) {\n\t\treturn true;\n\t}\n\treturn false;\n};\n\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = function getPolyfill() {\n\treturn typeof Object.is === 'function' ? Object.is : implementation;\n};\n","'use strict';\n\nvar getPolyfill = require('./polyfill');\nvar define = require('define-properties');\n\nmodule.exports = function shimObjectIs() {\n\tvar polyfill = getPolyfill();\n\tdefine(Object, { is: polyfill }, {\n\t\tis: function testObjectIs() {\n\t\t\treturn Object.is !== polyfill;\n\t\t}\n\t});\n\treturn polyfill;\n};\n","'use strict';\n\nvar define = require('define-properties');\nvar callBind = require('call-bind');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\n\nvar polyfill = callBind(getPolyfill(), Object);\n\ndefine(polyfill, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = polyfill;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = shallowEqual;\nvar _objectIs = _interopRequireDefault(require(\"object-is\"));\nvar _hasown = _interopRequireDefault(require(\"hasown\"));\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\n// adapted from https://github.com/facebook/react/blob/144328fe81719e916b946e22660479e31561bb0b/packages/shared/shallowEqual.js#L36-L68\nfunction shallowEqual(objA, objB) {\n if ((0, _objectIs[\"default\"])(objA, objB)) {\n return true;\n }\n if (!objA || !objB || _typeof(objA) !== 'object' || _typeof(objB) !== 'object') {\n return false;\n }\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) {\n return false;\n }\n keysA.sort();\n keysB.sort();\n\n // Test for A's keys different from B.\n for (var i = 0; i < keysA.length; i += 1) {\n if (!(0, _hasown[\"default\"])(objB, keysA[i]) || !(0, _objectIs[\"default\"])(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n return true;\n}\nmodule.exports = exports.default;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfb2JqZWN0SXMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9oYXNvd24iLCJvYmoiLCJfX2VzTW9kdWxlIiwiX3R5cGVvZiIsIm8iLCJTeW1ib2wiLCJpdGVyYXRvciIsImNvbnN0cnVjdG9yIiwicHJvdG90eXBlIiwic2hhbGxvd0VxdWFsIiwib2JqQSIsIm9iakIiLCJpcyIsImtleXNBIiwiT2JqZWN0Iiwia2V5cyIsImtleXNCIiwibGVuZ3RoIiwic29ydCIsImkiLCJoYXNPd24iLCJtb2R1bGUiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaXMgZnJvbSAnb2JqZWN0LWlzJztcbmltcG9ydCBoYXNPd24gZnJvbSAnaGFzb3duJztcblxuLy8gYWRhcHRlZCBmcm9tIGh0dHBzOi8vZ2l0aHViLmNvbS9mYWNlYm9vay9yZWFjdC9ibG9iLzE0NDMyOGZlODE3MTllOTE2Yjk0NmUyMjY2MDQ3OWUzMTU2MWJiMGIvcGFja2FnZXMvc2hhcmVkL3NoYWxsb3dFcXVhbC5qcyNMMzYtTDY4XG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBzaGFsbG93RXF1YWwob2JqQSwgb2JqQikge1xuICBpZiAoaXMob2JqQSwgb2JqQikpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGlmICghb2JqQSB8fCAhb2JqQiB8fCB0eXBlb2Ygb2JqQSAhPT0gJ29iamVjdCcgfHwgdHlwZW9mIG9iakIgIT09ICdvYmplY3QnKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY29uc3Qga2V5c0EgPSBPYmplY3Qua2V5cyhvYmpBKTtcbiAgY29uc3Qga2V5c0IgPSBPYmplY3Qua2V5cyhvYmpCKTtcblxuICBpZiAoa2V5c0EubGVuZ3RoICE9PSBrZXlzQi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBrZXlzQS5zb3J0KCk7XG4gIGtleXNCLnNvcnQoKTtcblxuICAvLyBUZXN0IGZvciBBJ3Mga2V5cyBkaWZmZXJlbnQgZnJvbSBCLlxuICBmb3IgKGxldCBpID0gMDsgaSA8IGtleXNBLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgaWYgKCFoYXNPd24ob2JqQiwga2V5c0FbaV0pIHx8ICFpcyhvYmpBW2tleXNBW2ldXSwgb2JqQltrZXlzQVtpXV0pKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLFNBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE9BQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUE0QixTQUFBRCx1QkFBQUcsR0FBQSxXQUFBQSxHQUFBLElBQUFBLEdBQUEsQ0FBQUMsVUFBQSxHQUFBRCxHQUFBLGdCQUFBQSxHQUFBO0FBQUEsU0FBQUUsUUFBQUMsQ0FBQSxzQ0FBQUQsT0FBQSx3QkFBQUUsTUFBQSx1QkFBQUEsTUFBQSxDQUFBQyxRQUFBLGFBQUFGLENBQUEsa0JBQUFBLENBQUEsZ0JBQUFBLENBQUEsV0FBQUEsQ0FBQSx5QkFBQUMsTUFBQSxJQUFBRCxDQUFBLENBQUFHLFdBQUEsS0FBQUYsTUFBQSxJQUFBRCxDQUFBLEtBQUFDLE1BQUEsQ0FBQUcsU0FBQSxxQkFBQUosQ0FBQSxLQUFBRCxPQUFBLENBQUFDLENBQUE7QUFFNUI7QUFDZSxTQUFTSyxZQUFZQSxDQUFDQyxJQUFJLEVBQUVDLElBQUksRUFBRTtFQUMvQyxJQUFJLElBQUFDLG9CQUFFLEVBQUNGLElBQUksRUFBRUMsSUFBSSxDQUFDLEVBQUU7SUFDbEIsT0FBTyxJQUFJO0VBQ2I7RUFFQSxJQUFJLENBQUNELElBQUksSUFBSSxDQUFDQyxJQUFJLElBQUlSLE9BQUEsQ0FBT08sSUFBSSxNQUFLLFFBQVEsSUFBSVAsT0FBQSxDQUFPUSxJQUFJLE1BQUssUUFBUSxFQUFFO0lBQzFFLE9BQU8sS0FBSztFQUNkO0VBRUEsSUFBTUUsS0FBSyxHQUFHQyxNQUFNLENBQUNDLElBQUksQ0FBQ0wsSUFBSSxDQUFDO0VBQy9CLElBQU1NLEtBQUssR0FBR0YsTUFBTSxDQUFDQyxJQUFJLENBQUNKLElBQUksQ0FBQztFQUUvQixJQUFJRSxLQUFLLENBQUNJLE1BQU0sS0FBS0QsS0FBSyxDQUFDQyxNQUFNLEVBQUU7SUFDakMsT0FBTyxLQUFLO0VBQ2Q7RUFFQUosS0FBSyxDQUFDSyxJQUFJLENBQUMsQ0FBQztFQUNaRixLQUFLLENBQUNFLElBQUksQ0FBQyxDQUFDOztFQUVaO0VBQ0EsS0FBSyxJQUFJQyxDQUFDLEdBQUcsQ0FBQyxFQUFFQSxDQUFDLEdBQUdOLEtBQUssQ0FBQ0ksTUFBTSxFQUFFRSxDQUFDLElBQUksQ0FBQyxFQUFFO0lBQ3hDLElBQUksQ0FBQyxJQUFBQyxrQkFBTSxFQUFDVCxJQUFJLEVBQUVFLEtBQUssQ0FBQ00sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUFQLG9CQUFFLEVBQUNGLElBQUksQ0FBQ0csS0FBSyxDQUFDTSxDQUFDLENBQUMsQ0FBQyxFQUFFUixJQUFJLENBQUNFLEtBQUssQ0FBQ00sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFO01BQ2xFLE9BQU8sS0FBSztJQUNkO0VBQ0Y7RUFFQSxPQUFPLElBQUk7QUFDYjtBQUFDRSxNQUFBLENBQUFDLE9BQUEsR0FBQUEsT0FBQSxDQUFBQyxPQUFBIn0=\n//# sourceMappingURL=index.js.map","function _extends() {\n return module.exports = _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _extends.apply(null, arguments);\n}\nmodule.exports = _extends, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(e) {\n if (void 0 === e) throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n return e;\n}\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(t, e) {\n return module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {\n return t.__proto__ = e, t;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _setPrototypeOf(t, e);\n}\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _inheritsLoose(t, o) {\n t.prototype = Object.create(o.prototype), t.prototype.constructor = t, setPrototypeOf(t, o);\n}\nmodule.exports = _inheritsLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _typeof(o);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nmodule.exports = toPrimitive, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar toPrimitive = require(\"./toPrimitive.js\");\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nmodule.exports = toPropertyKey, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperty(e, r, t) {\n return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var moment = require('moment');\n\nfunction isValidMoment(testMoment) {\n if (typeof moment.isMoment === 'function' && !moment.isMoment(testMoment)) {\n return false;\n }\n\n /* istanbul ignore else */\n if (typeof testMoment.isValid === 'function') {\n // moment 1.7.0+\n return testMoment.isValid();\n }\n\n /* istanbul ignore next */\n return !isNaN(testMoment);\n}\n\nmodule.exports = {\n isValidMoment : isValidMoment,\n};\n","var messages = {\n invalidPredicate: '`predicate` must be a function',\n invalidPropValidator: '`propValidator` must be a function',\n requiredCore: 'is marked as required',\n invalidTypeCore: 'Invalid input type',\n predicateFailureCore: 'Failed to succeed with predicate',\n anonymousMessage: '<>',\n baseInvalidMessage: 'Invalid ',\n};\n\nfunction constructPropValidatorVariations(propValidator) {\n if (typeof propValidator !== 'function') {\n throw new Error(messages.invalidPropValidator);\n }\n\n var requiredPropValidator = propValidator.bind(null, false, null);\n requiredPropValidator.isRequired = propValidator.bind(null, true, null);\n\n requiredPropValidator.withPredicate = function predicateApplication(predicate) {\n if (typeof predicate !== 'function') {\n throw new Error(messages.invalidPredicate);\n }\n var basePropValidator = propValidator.bind(null, false, predicate);\n basePropValidator.isRequired = propValidator.bind(null, true, predicate);\n return basePropValidator;\n };\n\n return requiredPropValidator;\n}\n\nfunction createInvalidRequiredErrorMessage(propName, componentName, value) {\n return new Error(\n 'The prop `' + propName + '` ' + messages.requiredCore +\n ' in `' + componentName + '`, but its value is `' + value + '`.'\n );\n}\n\nvar independentGuardianValue = -1;\n\nfunction preValidationRequireCheck(isRequired, componentName, propFullName, propValue) {\n var isPropValueUndefined = typeof propValue === 'undefined';\n var isPropValueNull = propValue === null;\n\n if (isRequired) {\n if (isPropValueUndefined) {\n return createInvalidRequiredErrorMessage(propFullName, componentName, 'undefined');\n } else if (isPropValueNull) {\n return createInvalidRequiredErrorMessage(propFullName, componentName, 'null');\n }\n }\n\n if (isPropValueUndefined || isPropValueNull) {\n return null;\n }\n\n return independentGuardianValue;\n}\n\nfunction createMomentChecker(type, typeValidator, validator, momentType) {\n\n function propValidator(\n isRequired, // Bound parameter to indicate with the propType is required\n predicate, // Bound parameter to allow user to add dynamic validation\n props,\n propName,\n componentName,\n location,\n propFullName\n ) {\n var propValue = props[ propName ];\n var propType = typeof propValue;\n\n componentName = componentName || messages.anonymousMessage;\n propFullName = propFullName || propName;\n\n var preValidationRequireCheckValue = preValidationRequireCheck(\n isRequired, componentName, propFullName, propValue\n );\n\n if (preValidationRequireCheckValue !== independentGuardianValue) {\n return preValidationRequireCheckValue;\n }\n\n if (typeValidator && !typeValidator(propValue)) {\n return new Error(\n messages.invalidTypeCore + ': `' + propName + '` of type `' + propType + '` ' +\n 'supplied to `' + componentName + '`, expected `' + type + '`.'\n );\n }\n\n if (!validator(propValue)) {\n return new Error(\n messages.baseInvalidMessage + location + ' `' + propName + '` of type `' + propType + '` ' +\n 'supplied to `' + componentName + '`, expected `' + momentType + '`.'\n );\n }\n\n if (predicate && !predicate(propValue)) {\n var predicateName = predicate.name || messages.anonymousMessage;\n return new Error(\n messages.baseInvalidMessage + location + ' `' + propName + '` of type `' + propType + '` ' +\n 'supplied to `' + componentName + '`. ' + messages.predicateFailureCore + ' `' +\n predicateName + '`.'\n );\n }\n\n return null;\n\n }\n\n return constructPropValidatorVariations(propValidator);\n\n}\n\nmodule.exports = {\n constructPropValidatorVariations: constructPropValidatorVariations,\n createMomentChecker: createMomentChecker,\n messages: messages,\n};\n","var moment = require('moment');\nvar momentValidationWrapper = require('./moment-validation-wrapper');\nvar core = require('./core');\n\nmodule.exports = {\n\n momentObj : core.createMomentChecker(\n 'object',\n function(obj) {\n return typeof obj === 'object';\n },\n function isValid(value) {\n return momentValidationWrapper.isValidMoment(value);\n },\n 'Moment'\n ),\n\n momentString : core.createMomentChecker(\n 'string',\n function(str) {\n return typeof str === 'string';\n },\n function isValid(value) {\n return momentValidationWrapper.isValidMoment(moment(value));\n },\n 'Moment'\n ),\n\n momentDurationObj : core.createMomentChecker(\n 'object',\n function(obj) {\n return typeof obj === 'object';\n },\n function isValid(value) {\n return moment.isDuration(value);\n },\n 'Duration'\n ),\n\n};\n","\"use strict\";\n\nfunction noop() {\n return null;\n}\n\nnoop.isRequired = noop;\n\nfunction noopThunk() {\n return noop;\n}\n\nmodule.exports = {\n and: noopThunk,\n between: noopThunk,\n booleanSome: noopThunk,\n childrenHavePropXorChildren: noopThunk,\n childrenOf: noopThunk,\n childrenOfType: noopThunk,\n childrenSequenceOf: noopThunk,\n componentWithName: noopThunk,\n disallowedIf: noopThunk,\n elementType: noopThunk,\n empty: noopThunk,\n explicitNull: noopThunk,\n forbidExtraProps: Object,\n integer: noopThunk,\n keysOf: noopThunk,\n mutuallyExclusiveProps: noopThunk,\n mutuallyExclusiveTrueProps: noopThunk,\n nChildren: noopThunk,\n nonNegativeInteger: noop,\n nonNegativeNumber: noopThunk,\n numericString: noopThunk,\n object: noopThunk,\n or: noopThunk,\n predicate: noopThunk,\n range: noopThunk,\n ref: noopThunk,\n requiredBy: noopThunk,\n restrictedProp: noopThunk,\n sequenceOf: noopThunk,\n shape: noopThunk,\n stringEndsWith: noopThunk,\n stringStartsWith: noopThunk,\n uniqueArray: noopThunk,\n uniqueArrayOf: noopThunk,\n valuesOf: noopThunk,\n withShape: noopThunk\n};\n//# sourceMappingURL=index.js.map","module.exports = process.env.NODE_ENV === 'production' ? require('./build/mocks') : require('./build');\n\n//# sourceMappingURL=index.js.map","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _getRequireWildcardCache(e) {\n if (\"function\" != typeof WeakMap) return null;\n var r = new WeakMap(),\n t = new WeakMap();\n return (_getRequireWildcardCache = function _getRequireWildcardCache(e) {\n return e ? t : r;\n })(e);\n}\nfunction _interopRequireWildcard(e, r) {\n if (!r && e && e.__esModule) return e;\n if (null === e || \"object\" != _typeof(e) && \"function\" != typeof e) return {\n \"default\": e\n };\n var t = _getRequireWildcardCache(r);\n if (t && t.has(e)) return t.get(e);\n var n = {\n __proto__: null\n },\n a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n for (var u in e) if (\"default\" !== u && {}.hasOwnProperty.call(e, u)) {\n var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n }\n return n[\"default\"] = e, t && t.set(e, n), n;\n}\nmodule.exports = _interopRequireWildcard, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (-1 !== e.indexOf(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nmodule.exports = _objectWithoutPropertiesLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var objectWithoutPropertiesLoose = require(\"./objectWithoutPropertiesLoose.js\");\nfunction _objectWithoutProperties(e, t) {\n if (null == e) return {};\n var o,\n r,\n i = objectWithoutPropertiesLoose(e, t);\n if (Object.getOwnPropertySymbols) {\n var n = Object.getOwnPropertySymbols(e);\n for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]);\n }\n return i;\n}\nmodule.exports = _objectWithoutProperties, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar fnToStr = Function.prototype.toString;\nvar reflectApply = typeof Reflect === 'object' && Reflect !== null && Reflect.apply;\nvar badArrayLike;\nvar isCallableMarker;\nif (typeof reflectApply === 'function' && typeof Object.defineProperty === 'function') {\n\ttry {\n\t\tbadArrayLike = Object.defineProperty({}, 'length', {\n\t\t\tget: function () {\n\t\t\t\tthrow isCallableMarker;\n\t\t\t}\n\t\t});\n\t\tisCallableMarker = {};\n\t\t// eslint-disable-next-line no-throw-literal\n\t\treflectApply(function () { throw 42; }, null, badArrayLike);\n\t} catch (_) {\n\t\tif (_ !== isCallableMarker) {\n\t\t\treflectApply = null;\n\t\t}\n\t}\n} else {\n\treflectApply = null;\n}\n\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n\ttry {\n\t\tvar fnStr = fnToStr.call(value);\n\t\treturn constructorRegex.test(fnStr);\n\t} catch (e) {\n\t\treturn false; // not a function\n\t}\n};\n\nvar tryFunctionObject = function tryFunctionToStr(value) {\n\ttry {\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tfnToStr.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\nvar toStr = Object.prototype.toString;\nvar objectClass = '[object Object]';\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar ddaClass = '[object HTMLAllCollection]'; // IE 11\nvar ddaClass2 = '[object HTML document.all class]';\nvar ddaClass3 = '[object HTMLCollection]'; // IE 9-10\nvar hasToStringTag = typeof Symbol === 'function' && !!Symbol.toStringTag; // better: use `has-tostringtag`\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar isDDA = function isDocumentDotAll() { return false; };\nif (typeof document === 'object') {\n\t// Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n\tvar all = document.all;\n\tif (toStr.call(all) === toStr.call(document.all)) {\n\t\tisDDA = function isDocumentDotAll(value) {\n\t\t\t/* globals document: false */\n\t\t\t// in IE 6-8, typeof document.all is \"object\" and it's truthy\n\t\t\tif ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n\t\t\t\ttry {\n\t\t\t\t\tvar str = toStr.call(value);\n\t\t\t\t\treturn (\n\t\t\t\t\t\tstr === ddaClass\n\t\t\t\t\t\t|| str === ddaClass2\n\t\t\t\t\t\t|| str === ddaClass3 // opera 12.16\n\t\t\t\t\t\t|| str === objectClass // IE 6-8\n\t\t\t\t\t) && value('') == null; // eslint-disable-line eqeqeq\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\t}\n}\n\nmodule.exports = reflectApply\n\t? function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\ttry {\n\t\t\treflectApply(value, null, badArrayLike);\n\t\t} catch (e) {\n\t\t\tif (e !== isCallableMarker) { return false; }\n\t\t}\n\t\treturn !isES6ClassFn(value) && tryFunctionObject(value);\n\t}\n\t: function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\tif (hasToStringTag) { return tryFunctionObject(value); }\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tvar strClass = toStr.call(value);\n\t\tif (strClass !== fnClass && strClass !== genClass && !(/^\\[object HTML/).test(strClass)) { return false; }\n\t\treturn tryFunctionObject(value);\n\t};\n","'use strict';\n\nvar functionsHaveNames = function functionsHaveNames() {\n\treturn typeof function f() {}.name === 'string';\n};\n\nvar gOPD = Object.getOwnPropertyDescriptor;\nif (gOPD) {\n\ttry {\n\t\tgOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\tgOPD = null;\n\t}\n}\n\nfunctionsHaveNames.functionsHaveConfigurableNames = function functionsHaveConfigurableNames() {\n\tif (!functionsHaveNames() || !gOPD) {\n\t\treturn false;\n\t}\n\tvar desc = gOPD(function () {}, 'name');\n\treturn !!desc && !!desc.configurable;\n};\n\nvar $bind = Function.prototype.bind;\n\nfunctionsHaveNames.boundFunctionsHaveNames = function boundFunctionsHaveNames() {\n\treturn functionsHaveNames() && typeof $bind === 'function' && function f() {}.bind().name !== '';\n};\n\nmodule.exports = functionsHaveNames;\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBindBasic = require('call-bind-apply-helpers');\n\n/** @type {(thisArg: string, searchString: string, position?: number) => number} */\nvar $indexOf = callBindBasic([GetIntrinsic('%String.prototype.indexOf%')]);\n\n/** @type {import('.')} */\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\t/* eslint no-extra-parens: 0 */\n\n\tvar intrinsic = /** @type {(this: unknown, ...args: unknown[]) => unknown} */ (GetIntrinsic(name, !!allowMissing));\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBindBasic(/** @type {const} */ ([intrinsic]));\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar IsCallable = require('is-callable');\nvar hasOwn = require('hasown');\nvar functionsHaveNames = require('functions-have-names')();\nvar callBound = require('call-bound');\nvar $functionToString = callBound('Function.prototype.toString');\nvar $stringMatch = callBound('String.prototype.match');\nvar toStr = callBound('Object.prototype.toString');\n\nvar classRegex = /^class /;\n\nvar isClass = function isClassConstructor(fn) {\n\tif (IsCallable(fn)) {\n\t\treturn false;\n\t}\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\ttry {\n\t\tvar match = $stringMatch($functionToString(fn), classRegex);\n\t\treturn !!match;\n\t} catch (e) {}\n\treturn false;\n};\n\nvar regex = /\\s*function\\s+([^(\\s]*)\\s*/;\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar objectClass = '[object Object]';\nvar ddaClass = '[object HTMLAllCollection]';\n\nvar functionProto = Function.prototype;\n\nvar isDDA = function isDocumentDotAll() {\n\treturn false;\n};\nif (typeof document === 'object') {\n\t// Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n\tvar all = document.all;\n\tif (toStr(all) === toStr(document.all)) {\n\t\tisDDA = function isDocumentDotAll(value) {\n\t\t\t/* globals document: false */\n\t\t\t// in IE 6-8, typeof document.all is \"object\" and it's truthy\n\t\t\tif ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n\t\t\t\ttry {\n\t\t\t\t\tvar str = toStr(value);\n\t\t\t\t\t// IE 6-8 uses `objectClass`\n\t\t\t\t\treturn (str === ddaClass || str === objectClass) && value('') == null; // eslint-disable-line eqeqeq\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\t}\n}\n\nmodule.exports = function getName() {\n\tif (isDDA(this) || (!isClass(this) && !IsCallable(this))) {\n\t\tthrow new TypeError('Function.prototype.name sham getter called on non-function');\n\t}\n\tif (functionsHaveNames && hasOwn(this, 'name')) {\n\t\treturn this.name;\n\t}\n\tif (this === functionProto) {\n\t\treturn '';\n\t}\n\tvar str = $functionToString(this);\n\tvar match = $stringMatch(str, regex);\n\tvar name = match && match[1];\n\treturn name;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = function getPolyfill() {\n\treturn implementation;\n};\n","'use strict';\n\nvar supportsDescriptors = require('define-properties').supportsDescriptors;\nvar functionsHaveNames = require('functions-have-names')();\nvar getPolyfill = require('./polyfill');\nvar defineProperty = Object.defineProperty;\nvar TypeErr = TypeError;\n\nmodule.exports = function shimName() {\n\tvar polyfill = getPolyfill();\n\tif (functionsHaveNames) {\n\t\treturn polyfill;\n\t}\n\tif (!supportsDescriptors) {\n\t\tthrow new TypeErr('Shimming Function.prototype.name support requires ES5 property descriptor support.');\n\t}\n\tvar functionProto = Function.prototype;\n\tdefineProperty(functionProto, 'name', {\n\t\tconfigurable: true,\n\t\tenumerable: false,\n\t\tget: function () {\n\t\t\tvar name = polyfill.call(this);\n\t\t\tif (this !== functionProto) {\n\t\t\t\tdefineProperty(this, 'name', {\n\t\t\t\t\tconfigurable: true,\n\t\t\t\t\tenumerable: false,\n\t\t\t\t\tvalue: name,\n\t\t\t\t\twritable: false\n\t\t\t\t});\n\t\t\t}\n\t\t\treturn name;\n\t\t}\n\t});\n\treturn polyfill;\n};\n","'use strict';\n\nvar define = require('define-properties');\nvar callBind = require('call-bind');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\n\nvar bound = callBind(implementation);\n\ndefine(bound, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = bound;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getComponentName;\n\nvar _functionPrototype = _interopRequireDefault(require(\"function.prototype.name\"));\n\nvar _reactIs = require(\"react-is\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction getComponentName(Component) {\n if (typeof Component === 'string') {\n return Component;\n }\n\n if (typeof Component === 'function') {\n return Component.displayName || (0, _functionPrototype[\"default\"])(Component);\n }\n\n if ((0, _reactIs.isForwardRef)({\n type: Component,\n $$typeof: _reactIs.Element\n })) {\n return Component.displayName;\n }\n\n if ((0, _reactIs.isMemo)(Component)) {\n return getComponentName(Component.type);\n }\n\n return null;\n}\n//# sourceMappingURL=getComponentName.js.map","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","'use strict';\n\nvar isArray = require('isarray');\n\n// TODO: inline, semver-major\n\n/** @type {(x: unknown) => x is object} */\nmodule.exports = function isPlainObject(x) {\n\treturn x && typeof x === 'object' && !isArray(x);\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _isPlainObject = _interopRequireDefault(require(\"prop-types-exact/build/helpers/isPlainObject\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nvar _default = _isPlainObject[\"default\"];\nexports[\"default\"] = _default;\n//# sourceMappingURL=isPlainObject.js.map","'use strict';\n\n// modified from https://github.com/es-shims/es6-shim\nvar objectKeys = require('object-keys');\nvar hasSymbols = require('has-symbols/shams')();\nvar callBound = require('call-bound');\nvar $Object = require('es-object-atoms');\nvar $push = callBound('Array.prototype.push');\nvar $propIsEnumerable = callBound('Object.prototype.propertyIsEnumerable');\nvar originalGetSymbols = hasSymbols ? $Object.getOwnPropertySymbols : null;\n\n// eslint-disable-next-line no-unused-vars\nmodule.exports = function assign(target, source1) {\n\tif (target == null) { throw new TypeError('target must be an object'); }\n\tvar to = $Object(target); // step 1\n\tif (arguments.length === 1) {\n\t\treturn to; // step 2\n\t}\n\tfor (var s = 1; s < arguments.length; ++s) {\n\t\tvar from = $Object(arguments[s]); // step 3.a.i\n\n\t\t// step 3.a.ii:\n\t\tvar keys = objectKeys(from);\n\t\tvar getSymbols = hasSymbols && ($Object.getOwnPropertySymbols || originalGetSymbols);\n\t\tif (getSymbols) {\n\t\t\tvar syms = getSymbols(from);\n\t\t\tfor (var j = 0; j < syms.length; ++j) {\n\t\t\t\tvar key = syms[j];\n\t\t\t\tif ($propIsEnumerable(from, key)) {\n\t\t\t\t\t$push(keys, key);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// step 3.a.iii:\n\t\tfor (var i = 0; i < keys.length; ++i) {\n\t\t\tvar nextKey = keys[i];\n\t\t\tif ($propIsEnumerable(from, nextKey)) { // step 3.a.iii.2\n\t\t\t\tvar propValue = from[nextKey]; // step 3.a.iii.2.a\n\t\t\t\tto[nextKey] = propValue; // step 3.a.iii.2.b\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to; // step 4\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nvar lacksProperEnumerationOrder = function () {\n\tif (!Object.assign) {\n\t\treturn false;\n\t}\n\t/*\n\t * v8, specifically in node 4.x, has a bug with incorrect property enumeration order\n\t * note: this does not detect the bug unless there's 20 characters\n\t */\n\tvar str = 'abcdefghijklmnopqrst';\n\tvar letters = str.split('');\n\tvar map = {};\n\tfor (var i = 0; i < letters.length; ++i) {\n\t\tmap[letters[i]] = letters[i];\n\t}\n\tvar obj = Object.assign({}, map);\n\tvar actual = '';\n\tfor (var k in obj) {\n\t\tactual += k;\n\t}\n\treturn str !== actual;\n};\n\nvar assignHasPendingExceptions = function () {\n\tif (!Object.assign || !Object.preventExtensions) {\n\t\treturn false;\n\t}\n\t/*\n\t * Firefox 37 still has \"pending exception\" logic in its Object.assign implementation,\n\t * which is 72% slower than our shim, and Firefox 40's native implementation.\n\t */\n\tvar thrower = Object.preventExtensions({ 1: 2 });\n\ttry {\n\t\tObject.assign(thrower, 'xy');\n\t} catch (e) {\n\t\treturn thrower[1] === 'y';\n\t}\n\treturn false;\n};\n\nmodule.exports = function getPolyfill() {\n\tif (!Object.assign) {\n\t\treturn implementation;\n\t}\n\tif (lacksProperEnumerationOrder()) {\n\t\treturn implementation;\n\t}\n\tif (assignHasPendingExceptions()) {\n\t\treturn implementation;\n\t}\n\treturn Object.assign;\n};\n","'use strict';\n\nvar define = require('define-properties');\nvar getPolyfill = require('./polyfill');\n\nmodule.exports = function shimAssign() {\n\tvar polyfill = getPolyfill();\n\tdefine(\n\t\tObject,\n\t\t{ assign: polyfill },\n\t\t{ assign: function () { return Object.assign !== polyfill; } }\n\t);\n\treturn polyfill;\n};\n","'use strict';\n\nvar defineProperties = require('define-properties');\nvar callBind = require('call-bind');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\n\nvar polyfill = callBind.apply(getPolyfill());\n// eslint-disable-next-line no-unused-vars\nvar bound = function assign(target, source1) {\n\treturn polyfill(Object, arguments);\n};\n\ndefineProperties(bound, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = bound;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = wrapValidator;\n\nvar _object = _interopRequireDefault(require(\"object.assign\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction wrapValidator(validator, typeName) {\n var typeChecker = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n return (0, _object[\"default\"])(validator.bind(), {\n typeName: typeName,\n typeChecker: typeChecker,\n isRequired: (0, _object[\"default\"])(validator.isRequired.bind(), {\n typeName: typeName,\n typeChecker: typeChecker,\n typeRequired: true\n })\n });\n}\n//# sourceMappingURL=wrapValidator.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = require(\"react\");\n\nvar _isPlainObject = _interopRequireDefault(require(\"./helpers/isPlainObject\"));\n\nvar _wrapValidator = _interopRequireDefault(require(\"./helpers/wrapValidator\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nvar isPrototypeOf = Object.prototype.isPrototypeOf;\n\nfunction isNewRef(prop) {\n if (!(0, _isPlainObject[\"default\"])(prop)) {\n return false;\n }\n\n var ownProperties = Object.keys(prop);\n return ownProperties.length === 1 && ownProperties[0] === 'current';\n}\n\nfunction isCallbackRef(prop) {\n return typeof prop === 'function' && !isPrototypeOf.call(_react.Component, prop) && (!_react.PureComponent || !isPrototypeOf.call(_react.PureComponent, prop));\n}\n\nfunction requiredRef(props, propName, componentName) {\n var propValue = props[propName];\n\n if (isCallbackRef(propValue) || isNewRef(propValue)) {\n return null;\n }\n\n return new TypeError(\"\".concat(propName, \" in \").concat(componentName, \" must be a ref\"));\n}\n\nfunction ref(props, propName, componentName) {\n var propValue = props[propName];\n\n if (propValue == null) {\n return null;\n }\n\n for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {\n rest[_key - 3] = arguments[_key];\n }\n\n return requiredRef.apply(void 0, [props, propName, componentName].concat(rest));\n}\n\nref.isRequired = requiredRef;\n\nvar _default = function _default() {\n return (0, _wrapValidator[\"default\"])(ref, 'ref');\n};\n\nexports[\"default\"] = _default;\n//# sourceMappingURL=ref.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\nvar EMPTY_STYLES = {};\n\nvar EMPTY_STYLES_FN = function EMPTY_STYLES_FN() {\n return EMPTY_STYLES;\n};\n\nvar _default = EMPTY_STYLES_FN;\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.perfStart = perfStart;\nexports.perfEnd = perfEnd;\nexports[\"default\"] = withPerf;\n\nfunction perfStart(startMark) {\n if (typeof performance !== 'undefined' && performance.mark !== undefined && typeof performance.clearMarks === 'function' && startMark) {\n performance.clearMarks(startMark);\n performance.mark(startMark);\n }\n}\n\nfunction perfEnd(startMark, endMark, measureName) {\n if (typeof performance !== 'undefined' && performance.mark !== undefined && typeof performance.clearMarks === 'function') {\n performance.clearMarks(endMark);\n performance.mark(endMark);\n performance.measure(measureName, startMark, endMark);\n performance.clearMarks(measureName);\n }\n}\n\nfunction withPerf(methodName) {\n var startMark = \"react-with-styles.\".concat(methodName, \".start\");\n var endMark = \"react-with-styles.\".concat(methodName, \".end\");\n var measureName = \"\\uD83D\\uDC69\\u200D\\uD83C\\uDFA8 [\".concat(methodName, \"]\");\n return function (fn) {\n return function () {\n if (process.env.NODE_ENV !== 'production') {\n perfStart(startMark);\n }\n\n var result = fn.apply(void 0, arguments);\n\n if (process.env.NODE_ENV !== 'production') {\n perfEnd(startMark, endMark, measureName);\n }\n\n return result;\n };\n };\n}","'use strict';\n\nvar isMergeableObject = function isMergeableObject(value) {\n\treturn isNonNullObject(value)\n\t\t&& !isSpecial(value)\n};\n\nfunction isNonNullObject(value) {\n\treturn !!value && typeof value === 'object'\n}\n\nfunction isSpecial(value) {\n\tvar stringValue = Object.prototype.toString.call(value);\n\n\treturn stringValue === '[object RegExp]'\n\t\t|| stringValue === '[object Date]'\n\t\t|| isReactElement(value)\n}\n\n// see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25\nvar canUseSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;\n\nfunction isReactElement(value) {\n\treturn value.$$typeof === REACT_ELEMENT_TYPE\n}\n\nfunction emptyTarget(val) {\n return Array.isArray(val) ? [] : {}\n}\n\nfunction cloneIfNecessary(value, optionsArgument) {\n var clone = optionsArgument && optionsArgument.clone === true;\n return (clone && isMergeableObject(value)) ? deepmerge(emptyTarget(value), value, optionsArgument) : value\n}\n\nfunction defaultArrayMerge(target, source, optionsArgument) {\n var destination = target.slice();\n source.forEach(function(e, i) {\n if (typeof destination[i] === 'undefined') {\n destination[i] = cloneIfNecessary(e, optionsArgument);\n } else if (isMergeableObject(e)) {\n destination[i] = deepmerge(target[i], e, optionsArgument);\n } else if (target.indexOf(e) === -1) {\n destination.push(cloneIfNecessary(e, optionsArgument));\n }\n });\n return destination\n}\n\nfunction mergeObject(target, source, optionsArgument) {\n var destination = {};\n if (isMergeableObject(target)) {\n Object.keys(target).forEach(function(key) {\n destination[key] = cloneIfNecessary(target[key], optionsArgument);\n });\n }\n Object.keys(source).forEach(function(key) {\n if (!isMergeableObject(source[key]) || !target[key]) {\n destination[key] = cloneIfNecessary(source[key], optionsArgument);\n } else {\n destination[key] = deepmerge(target[key], source[key], optionsArgument);\n }\n });\n return destination\n}\n\nfunction deepmerge(target, source, optionsArgument) {\n var sourceIsArray = Array.isArray(source);\n var targetIsArray = Array.isArray(target);\n var options = optionsArgument || { arrayMerge: defaultArrayMerge };\n var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;\n\n if (!sourceAndTargetTypesMatch) {\n return cloneIfNecessary(source, optionsArgument)\n } else if (sourceIsArray) {\n var arrayMerge = options.arrayMerge || defaultArrayMerge;\n return arrayMerge(target, source, optionsArgument)\n } else {\n return mergeObject(target, source, optionsArgument)\n }\n}\n\ndeepmerge.all = function deepmergeAll(array, optionsArgument) {\n if (!Array.isArray(array) || array.length < 2) {\n throw new Error('first argument should be an array with at least two elements')\n }\n\n // we are sure there are at least 2 values, so it is safe to have no initial value\n return array.reduce(function(prev, next) {\n return deepmerge(prev, next, optionsArgument)\n })\n};\n\nvar deepmerge_1 = deepmerge;\n\nmodule.exports = deepmerge_1;\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar CHANNEL = exports.CHANNEL = '__direction__';\n\nvar DIRECTIONS = exports.DIRECTIONS = {\n LTR: 'ltr',\n RTL: 'rtl'\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nexports['default'] = _propTypes2['default'].shape({\n getState: _propTypes2['default'].func,\n setState: _propTypes2['default'].func,\n subscribe: _propTypes2['default'].func\n});","'use strict';\n\nvar $TypeError = require('es-errors/type');\n\n/** @type {import('./RequireObjectCoercible')} */\nmodule.exports = function RequireObjectCoercible(value) {\n\tif (value == null) {\n\t\tthrow new $TypeError((arguments.length > 0 && arguments[1]) || ('Cannot call method on ' + value));\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar RequireObjectCoercible = require('es-object-atoms/RequireObjectCoercible');\nvar callBound = require('call-bound');\n\nvar $isEnumerable = callBound('Object.prototype.propertyIsEnumerable');\n\nmodule.exports = function values(O) {\n\tvar obj = RequireObjectCoercible(O);\n\tvar vals = [];\n\tfor (var key in obj) {\n\t\tif ($isEnumerable(obj, key)) { // checks own-ness as well\n\t\t\tvals[vals.length] = obj[key];\n\t\t}\n\t}\n\treturn vals;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = function getPolyfill() {\n\treturn typeof Object.values === 'function' ? Object.values : implementation;\n};\n","'use strict';\n\nvar getPolyfill = require('./polyfill');\nvar define = require('define-properties');\n\nmodule.exports = function shimValues() {\n\tvar polyfill = getPolyfill();\n\tdefine(Object, { values: polyfill }, {\n\t\tvalues: function testValues() {\n\t\t\treturn Object.values !== polyfill;\n\t\t}\n\t});\n\treturn polyfill;\n};\n","'use strict';\n\nvar define = require('define-properties');\nvar callBind = require('call-bind');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\n\nvar polyfill = callBind(getPolyfill(), Object);\n\ndefine(polyfill, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = polyfill;\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _object = require('object.values');\n\nvar _object2 = _interopRequireDefault(_object);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _constants = require('../constants');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nexports['default'] = _propTypes2['default'].oneOf((0, _object2['default'])(_constants.DIRECTIONS));","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.withDirectionPropTypes = exports.DIRECTIONS = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nexports['default'] = withDirection;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _hoistNonReactStatics = require('hoist-non-react-statics');\n\nvar _hoistNonReactStatics2 = _interopRequireDefault(_hoistNonReactStatics);\n\nvar _deepmerge = require('deepmerge');\n\nvar _deepmerge2 = _interopRequireDefault(_deepmerge);\n\nvar _getComponentName = require('airbnb-prop-types/build/helpers/getComponentName');\n\nvar _getComponentName2 = _interopRequireDefault(_getComponentName);\n\nvar _constants = require('./constants');\n\nvar _brcast = require('./proptypes/brcast');\n\nvar _brcast2 = _interopRequireDefault(_brcast);\n\nvar _direction = require('./proptypes/direction');\n\nvar _direction2 = _interopRequireDefault(_direction);\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\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; } /* eslint-disable react/forbid-foreign-prop-types */\n// This higher-order component consumes a string from React context that is\n// provided by the DirectionProvider component.\n// We can use this to conditionally switch layout/direction for right-to-left layouts.\n\nvar contextTypes = _defineProperty({}, _constants.CHANNEL, _brcast2['default']);\n\nexports.DIRECTIONS = _constants.DIRECTIONS;\n\n// set a default direction so that a component wrapped with this HOC can be\n// used even without a DirectionProvider ancestor in its react tree.\n\nvar defaultDirection = _constants.DIRECTIONS.LTR;\n\n// export for convenience, in order for components to spread these onto their propTypes\nvar withDirectionPropTypes = exports.withDirectionPropTypes = {\n direction: _direction2['default'].isRequired\n};\n\nfunction withDirection(WrappedComponent) {\n var WithDirection = function (_React$Component) {\n _inherits(WithDirection, _React$Component);\n\n function WithDirection(props, context) {\n _classCallCheck(this, WithDirection);\n\n var _this = _possibleConstructorReturn(this, (WithDirection.__proto__ || Object.getPrototypeOf(WithDirection)).call(this, props, context));\n\n _this.state = {\n direction: context[_constants.CHANNEL] ? context[_constants.CHANNEL].getState() : defaultDirection\n };\n return _this;\n }\n\n _createClass(WithDirection, [{\n key: 'componentDidMount',\n value: function () {\n function componentDidMount() {\n var _this2 = this;\n\n if (this.context[_constants.CHANNEL]) {\n // subscribe to future direction changes\n this.channelUnsubscribe = this.context[_constants.CHANNEL].subscribe(function (direction) {\n _this2.setState({ direction: direction });\n });\n }\n }\n\n return componentDidMount;\n }()\n }, {\n key: 'componentWillUnmount',\n value: function () {\n function componentWillUnmount() {\n if (this.channelUnsubscribe) {\n this.channelUnsubscribe();\n }\n }\n\n return componentWillUnmount;\n }()\n }, {\n key: 'render',\n value: function () {\n function render() {\n var direction = this.state.direction;\n\n\n return _react2['default'].createElement(WrappedComponent, _extends({}, this.props, {\n direction: direction\n }));\n }\n\n return render;\n }()\n }]);\n\n return WithDirection;\n }(_react2['default'].Component);\n\n var wrappedComponentName = (0, _getComponentName2['default'])(WrappedComponent) || 'Component';\n\n WithDirection.WrappedComponent = WrappedComponent;\n WithDirection.contextTypes = contextTypes;\n WithDirection.displayName = 'withDirection(' + String(wrappedComponentName) + ')';\n if (WrappedComponent.propTypes) {\n WithDirection.propTypes = (0, _deepmerge2['default'])({}, WrappedComponent.propTypes);\n delete WithDirection.propTypes.direction;\n }\n if (WrappedComponent.defaultProps) {\n WithDirection.defaultProps = (0, _deepmerge2['default'])({}, WrappedComponent.defaultProps);\n }\n\n return (0, _hoistNonReactStatics2['default'])(WithDirection, WrappedComponent);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"DIRECTIONS\", {\n enumerable: true,\n get: function get() {\n return _reactWithDirection.DIRECTIONS;\n }\n});\nexports[\"default\"] = void 0;\n\nvar _react = require(\"react\");\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactWithDirection = require(\"react-with-direction\");\n\nfunction detectAndCreateContext(defaultValue) {\n if (_react.createContext) {\n return /*#__PURE__*/(0, _react.createContext)(defaultValue);\n }\n\n return {\n Provider: function Provider() {\n throw new ReferenceError('WithStylesContext requires React 16.3 or later');\n },\n Consumer: function Consumer() {\n throw new ReferenceError('WithStylesContext requires React 16.3 or later');\n }\n };\n}\n\nvar WithStylesContext = detectAndCreateContext({\n stylesInterface: null,\n stylesTheme: null,\n direction: null\n});\nWithStylesContext.Provider.propTypes = {\n stylesInterface: _propTypes[\"default\"].object,\n // eslint-disable-line react/forbid-prop-types\n stylesTheme: _propTypes[\"default\"].object,\n // eslint-disable-line react/forbid-prop-types\n direction: _propTypes[\"default\"].oneOf([_reactWithDirection.DIRECTIONS.LTR, _reactWithDirection.DIRECTIONS.RTL])\n};\nvar _default = WithStylesContext;\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports._getInterface = _getInterface;\nexports._getTheme = get;\nexports[\"default\"] = void 0;\nvar styleInterface;\nvar styleTheme;\nvar START_MARK = 'react-with-styles.resolve.start';\nvar END_MARK = 'react-with-styles.resolve.end';\nvar MEASURE_MARK = \"\\uD83D\\uDC69\\u200D\\uD83C\\uDFA8 [resolve]\";\n\nfunction registerTheme(theme) {\n styleTheme = theme;\n}\n\nfunction registerInterface(interfaceToRegister) {\n styleInterface = interfaceToRegister;\n}\n\nfunction create(makeFromTheme, createWithDirection) {\n var styles = createWithDirection(makeFromTheme(styleTheme));\n return function () {\n return styles;\n };\n}\n\nfunction createLTR(makeFromTheme) {\n return create(makeFromTheme, styleInterface.createLTR || styleInterface.create);\n}\n\nfunction createRTL(makeFromTheme) {\n return create(makeFromTheme, styleInterface.createRTL || styleInterface.create);\n}\n\nfunction get() {\n return styleTheme;\n}\n\nfunction resolve() {\n if (process.env.NODE_ENV !== 'production' && typeof performance !== 'undefined' && performance.mark !== undefined && typeof performance.clearMarks === 'function') {\n performance.clearMarks(START_MARK);\n performance.mark(START_MARK);\n }\n\n for (var _len = arguments.length, styles = new Array(_len), _key = 0; _key < _len; _key++) {\n styles[_key] = arguments[_key];\n }\n\n var result = styleInterface.resolve(styles);\n\n if (process.env.NODE_ENV !== 'production' && typeof performance !== 'undefined' && performance.mark !== undefined && typeof performance.clearMarks === 'function') {\n performance.clearMarks(END_MARK);\n performance.mark(END_MARK);\n performance.measure(MEASURE_MARK, START_MARK, END_MARK);\n performance.clearMarks(MEASURE_MARK);\n }\n\n return result;\n}\n\nfunction resolveLTR() {\n for (var _len2 = arguments.length, styles = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n styles[_key2] = arguments[_key2];\n }\n\n if (styleInterface.resolveLTR) {\n return styleInterface.resolveLTR(styles);\n }\n\n return resolve(styles);\n}\n\nfunction resolveRTL() {\n for (var _len3 = arguments.length, styles = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n styles[_key3] = arguments[_key3];\n }\n\n if (styleInterface.resolveRTL) {\n return styleInterface.resolveRTL(styles);\n }\n\n return resolve(styles);\n}\n\nfunction flush() {\n if (styleInterface.flush) {\n styleInterface.flush();\n }\n} // Exported until we deprecate this API completely\n// eslint-disable-next-line no-underscore-dangle\n\n\nfunction _getInterface() {\n return styleInterface;\n} // Exported until we deprecate this API completely\n\n\nvar _default = {\n registerTheme: registerTheme,\n registerInterface: registerInterface,\n create: createLTR,\n createLTR: createLTR,\n createRTL: createRTL,\n get: get,\n resolve: resolveLTR,\n resolveLTR: resolveLTR,\n resolveRTL: resolveRTL,\n flush: flush\n};\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.withStylesPropTypes = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar withStylesPropTypes = {\n styles: _propTypes[\"default\"].object.isRequired,\n theme: _propTypes[\"default\"].object.isRequired,\n css: _propTypes[\"default\"].func.isRequired\n};\nexports.withStylesPropTypes = withStylesPropTypes;\nvar _default = withStylesPropTypes;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.withStyles = withStyles;\nObject.defineProperty(exports, \"withStylesPropTypes\", {\n enumerable: true,\n get: function get() {\n return _withStylesPropTypes.withStylesPropTypes;\n }\n});\nexports.css = exports[\"default\"] = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _hoistNonReactStatics = _interopRequireDefault(require(\"hoist-non-react-statics\"));\n\nvar _getComponentName = _interopRequireDefault(require(\"airbnb-prop-types/build/helpers/getComponentName\"));\n\nvar _ref3 = _interopRequireDefault(require(\"airbnb-prop-types/build/ref\"));\n\nvar _emptyStylesFn = _interopRequireDefault(require(\"./utils/emptyStylesFn\"));\n\nvar _perf = _interopRequireDefault(require(\"./utils/perf\"));\n\nvar _WithStylesContext = _interopRequireWildcard(require(\"./WithStylesContext\"));\n\nvar _ThemedStyleSheet = _interopRequireWildcard(require(\"./ThemedStyleSheet\"));\n\nvar _withStylesPropTypes = require(\"./withStylesPropTypes\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\n/**\n * A higher order function that returns a higher order class component that injects\n * CSS-in-JS props derived from the react-with-styles theme, interface, and\n * direction provided through the WithStylesContext provider.\n *\n * The function should be used as follows:\n * `withStyles((theme) => styles, options)(Component)`\n *\n * Options can be used to rename the injected props, memoize the component, and flush\n * the styles to the styles tag (or whatever the interface implements as flush) before\n * rendering.\n *\n * @export\n * @param {Function|null|undefined} [stylesFn=EMPTY_STYLES_FN]\n * @param {Object} [{\n * stylesPropName = 'styles',\n * themePropName = 'theme',\n * cssPropName = 'css',\n * flushBefore = false,\n * pureComponent = false,\n * }={}]\n * @returns a higher order component that wraps the provided component and injects\n * the react-with-styles css, styles, and theme props.\n */\nfunction withStyles() {\n var stylesFn = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _emptyStylesFn[\"default\"];\n\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$stylesPropName = _ref.stylesPropName,\n stylesPropName = _ref$stylesPropName === void 0 ? 'styles' : _ref$stylesPropName,\n _ref$themePropName = _ref.themePropName,\n themePropName = _ref$themePropName === void 0 ? 'theme' : _ref$themePropName,\n _ref$cssPropName = _ref.cssPropName,\n cssPropName = _ref$cssPropName === void 0 ? 'css' : _ref$cssPropName,\n _ref$flushBefore = _ref.flushBefore,\n flushBefore = _ref$flushBefore === void 0 ? false : _ref$flushBefore,\n _ref$pureComponent = _ref.pureComponent,\n pureComponent = _ref$pureComponent === void 0 ? false : _ref$pureComponent;\n\n stylesFn = stylesFn || _emptyStylesFn[\"default\"];\n var BaseClass = pureComponent ? _react[\"default\"].PureComponent : _react[\"default\"].Component;\n /** Cache for storing the result of stylesFn(theme) for all themes. */\n\n var stylesFnResultCacheMap = typeof WeakMap === 'undefined' ? new Map() : new WeakMap();\n\n function getOrCreateStylesFnResultCache(theme) {\n // Get and store the result in the stylesFnResultsCache for the component\n // -- not the instance -- so we only apply the theme to the stylesFn\n // once per theme for this component.\n var cachedResultForTheme = stylesFnResultCacheMap.get(theme);\n var stylesFnResult = cachedResultForTheme || stylesFn(theme) || {};\n stylesFnResultCacheMap.set(theme, stylesFnResult); // cache the result of stylesFn(theme)\n\n return stylesFnResult;\n }\n /**\n * Cache for storing the results of computations:\n * `WeakMap>`\n * Falling back to `Map` whenever `WeakMap` is not supported\n */\n\n\n var withStylesCache = typeof WeakMap === 'undefined' ? new Map() : new WeakMap();\n\n function getComponentCache(theme, component, direction) {\n var themeCache = withStylesCache.get(theme);\n\n if (!themeCache) {\n return null;\n }\n\n var componentCache = themeCache.get(component);\n\n if (!componentCache) {\n return null;\n }\n\n return componentCache[direction];\n }\n\n function updateComponentCache(theme, component, direction, results) {\n var themeCache = withStylesCache.get(theme);\n\n if (!themeCache) {\n themeCache = typeof WeakMap === 'undefined' ? new Map() : new WeakMap();\n withStylesCache.set(theme, themeCache);\n }\n\n var componentCache = themeCache.get(component);\n\n if (!componentCache) {\n componentCache = {\n ltr: {},\n rtl: {}\n };\n themeCache.set(component, componentCache);\n }\n\n componentCache[direction] = results;\n }\n /** Derive the create function from the interface and direction */\n\n\n function makeCreateFn(direction, stylesInterface) {\n var directionSelector = direction === _WithStylesContext.DIRECTIONS.RTL ? 'RTL' : 'LTR';\n var create = stylesInterface[\"create\".concat(directionSelector)] || stylesInterface.create;\n var original = create;\n\n if (process.env.NODE_ENV !== 'production') {\n create = (0, _perf[\"default\"])('create')(create);\n }\n\n return {\n create: create,\n original: original\n };\n }\n /** Derive the resolve function from the interface and direction */\n\n\n function makeResolveFn(direction, stylesInterface) {\n var directionSelector = direction === _WithStylesContext.DIRECTIONS.RTL ? 'RTL' : 'LTR';\n var resolve = stylesInterface[\"resolve\".concat(directionSelector)] || stylesInterface.resolve;\n var original = resolve;\n\n if (process.env.NODE_ENV !== 'production') {\n resolve = (0, _perf[\"default\"])('resolve')(resolve);\n }\n\n return {\n resolve: resolve,\n original: original\n };\n } // The function that wraps the provided component in a wrapper\n // component that injects the withStyles props\n\n\n return function withStylesHOC(WrappedComponent) {\n var wrappedComponentName = (0, _getComponentName[\"default\"])(WrappedComponent); // The wrapper component that injects the withStyles props\n\n var WithStyles = /*#__PURE__*/function (_BaseClass) {\n (0, _inheritsLoose2[\"default\"])(WithStyles, _BaseClass);\n\n function WithStyles() {\n return _BaseClass.apply(this, arguments) || this;\n }\n\n var _proto = WithStyles.prototype;\n\n _proto.getCurrentInterface = function getCurrentInterface() {\n // Fallback to the singleton implementation\n return this.context && this.context.stylesInterface || (0, _ThemedStyleSheet._getInterface)();\n };\n\n _proto.getCurrentTheme = function getCurrentTheme() {\n // Fallback to the singleton implementation\n return this.context && this.context.stylesTheme || (0, _ThemedStyleSheet._getTheme)();\n };\n\n _proto.getCurrentDirection = function getCurrentDirection() {\n return this.context && this.context.direction || _WithStylesContext.DIRECTIONS.LTR;\n };\n\n _proto.getProps = function getProps() {\n // Get the styles interface, theme, and direction from context\n var stylesInterface = this.getCurrentInterface();\n var theme = this.getCurrentTheme();\n var direction = this.getCurrentDirection(); // Use a cache to store the interface methods and created styles by direction.\n // This way, if the theme and the interface don't change, we do not recalculate\n // styles or any other interface derivations. They are effectively only calculated\n // once per direction, until the theme or interface change.\n // Assume: always an object.\n\n var componentCache = getComponentCache(theme, WithStyles, direction); // Determine what's changed\n\n var interfaceChanged = !componentCache || !componentCache.stylesInterface || stylesInterface && componentCache.stylesInterface !== stylesInterface;\n var themeChanged = !componentCache || componentCache.theme !== theme; // If the interface and theme haven't changed for this direction,\n // we return the cached props immediately.\n\n if (!interfaceChanged && !themeChanged) {\n return componentCache.props;\n } // If the theme or the interface changed, then there are some values\n // we need to recalculate. We avoid recalculating the ones we already\n // calculated in the past if the objects they're derived from have not\n // changed.\n\n\n var createFn = interfaceChanged && makeCreateFn(direction, stylesInterface) || componentCache.create;\n var resolveFn = interfaceChanged && makeResolveFn(direction, stylesInterface) || componentCache.resolve;\n var create = createFn.create;\n var resolve = resolveFn.resolve; // Determine if create or resolve functions have changed, which will then\n // determine if we need to create new styles or css props\n\n var createChanged = !componentCache || !componentCache.create || createFn.original !== componentCache.create.original;\n var resolveChanged = !componentCache || !componentCache.resolve || resolveFn.original !== componentCache.resolve.original; // Derive the css function prop: recalculate it if resolve changed\n\n var css = resolveChanged && function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return resolve(args);\n } || componentCache.props.css; // Get or calculate the themed styles from the stylesFn:\n // Uses a separate cache at the component level, not at the instance level,\n // to only apply the theme to the stylesFn once per component class per theme.\n\n\n var stylesFnResult = getOrCreateStylesFnResultCache(theme); // Derive the styles prop: recalculate it if create changed, or stylesFnResult changed\n\n var styles = (createChanged || stylesFnResult !== componentCache.stylesFnResult) && create(stylesFnResult) || componentCache.props.styles; // Put the new props together\n\n var props = {\n css: css,\n styles: styles,\n theme: theme\n }; // Update the cache with all the new values\n\n updateComponentCache(theme, WithStyles, direction, {\n stylesInterface: stylesInterface,\n theme: theme,\n create: createFn,\n resolve: resolveFn,\n stylesFnResult: stylesFnResult,\n props: props\n });\n return props;\n };\n\n _proto.flush = function flush() {\n var stylesInterface = this.getCurrentInterface();\n\n if (stylesInterface && stylesInterface.flush) {\n stylesInterface.flush();\n }\n };\n\n _proto.render = function render() {\n var _ref2;\n\n // We only want to re-render if the theme, stylesInterface, or direction change.\n // These values are in context so we're listening for their updates.\n // this.getProps() derives the props from the theme, stylesInterface, and direction in\n // context, and memoizes them on the instance per direction.\n var _this$getProps = this.getProps(),\n theme = _this$getProps.theme,\n styles = _this$getProps.styles,\n css = _this$getProps.css; // Flush if specified\n\n\n if (flushBefore) {\n this.flush();\n }\n\n var _this$props = this.props,\n forwardedRef = _this$props.forwardedRef,\n rest = (0, _objectWithoutProperties2[\"default\"])(_this$props, [\"forwardedRef\"]);\n return /*#__PURE__*/_react[\"default\"].createElement(WrappedComponent // TODO: remove conditional once breaking change to only support React 16.3+\n // ref: https://github.com/airbnb/react-with-styles/pull/240#discussion_r533497857\n , (0, _extends2[\"default\"])({\n ref: typeof _react[\"default\"].forwardRef === 'undefined' ? undefined : forwardedRef\n }, typeof _react[\"default\"].forwardRef === 'undefined' ? this.props : rest, (_ref2 = {}, (0, _defineProperty2[\"default\"])(_ref2, themePropName, theme), (0, _defineProperty2[\"default\"])(_ref2, stylesPropName, styles), (0, _defineProperty2[\"default\"])(_ref2, cssPropName, css), _ref2)));\n };\n\n return WithStyles;\n }(BaseClass); // TODO: remove conditional once breaking change to only support React 16.3+\n // ref: https://github.com/airbnb/react-with-styles/pull/240#discussion_r533497857\n\n\n if (typeof _react[\"default\"].forwardRef !== 'undefined') {\n WithStyles.propTypes = {\n forwardedRef: (0, _ref3[\"default\"])()\n };\n } // TODO: remove conditional once breaking change to only support React 16.3+\n // ref: https://github.com/airbnb/react-with-styles/pull/240#discussion_r533497857\n\n\n var ForwardedWithStyles = typeof _react[\"default\"].forwardRef === 'undefined' ? WithStyles : /*#__PURE__*/_react[\"default\"].forwardRef(function (props, forwardedRef) {\n return /*#__PURE__*/_react[\"default\"].createElement(WithStyles, (0, _extends2[\"default\"])({}, props, {\n forwardedRef: forwardedRef\n }));\n }); // Copy the wrapped component's prop types and default props on WithStyles\n\n if (WrappedComponent.propTypes) {\n ForwardedWithStyles.propTypes = _objectSpread({}, WrappedComponent.propTypes);\n delete ForwardedWithStyles.propTypes[stylesPropName];\n delete ForwardedWithStyles.propTypes[themePropName];\n delete ForwardedWithStyles.propTypes[cssPropName];\n }\n\n if (WrappedComponent.defaultProps) {\n ForwardedWithStyles.defaultProps = _objectSpread({}, WrappedComponent.defaultProps);\n }\n\n WithStyles.contextType = _WithStylesContext[\"default\"];\n ForwardedWithStyles.WrappedComponent = WrappedComponent;\n ForwardedWithStyles.displayName = \"withStyles(\".concat(wrappedComponentName, \")\");\n return (0, _hoistNonReactStatics[\"default\"])(ForwardedWithStyles, WrappedComponent);\n };\n}\n\nvar _default = withStyles;\n/**\n * Deprecated: Do not use directly. Please wrap your component in `withStyles` and use the `css`\n * prop injected via props instead.\n */\n\nexports[\"default\"] = _default;\nvar css = _ThemedStyleSheet[\"default\"].resolveLTR;\nexports.css = css;","// Generated by CoffeeScript 1.12.2\n(function() {\n var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n module.exports = function() {\n return performance.now();\n };\n } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n module.exports = function() {\n return (getNanoSeconds() - nodeLoadTime) / 1e6;\n };\n hrtime = process.hrtime;\n getNanoSeconds = function() {\n var hr;\n hr = hrtime();\n return hr[0] * 1e9 + hr[1];\n };\n moduleLoadTime = getNanoSeconds();\n upTime = process.uptime() * 1e9;\n nodeLoadTime = moduleLoadTime - upTime;\n } else if (Date.now) {\n module.exports = function() {\n return Date.now() - loadTime;\n };\n loadTime = Date.now();\n } else {\n module.exports = function() {\n return new Date().getTime() - loadTime;\n };\n loadTime = new Date().getTime();\n }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","var now = require('performance-now')\n , root = typeof window === 'undefined' ? global : window\n , vendors = ['moz', 'webkit']\n , suffix = 'AnimationFrame'\n , raf = root['request' + suffix]\n , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n raf = root[vendors[i] + 'Request' + suffix]\n caf = root[vendors[i] + 'Cancel' + suffix]\n || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n var last = 0\n , id = 0\n , queue = []\n , frameDuration = 1000 / 60\n\n raf = function(callback) {\n if(queue.length === 0) {\n var _now = now()\n , next = Math.max(0, frameDuration - (_now - last))\n last = next + _now\n setTimeout(function() {\n var cp = queue.slice(0)\n // Clear queue here to prevent\n // callbacks from appending listeners\n // to the current frame's queue\n queue.length = 0\n for(var i = 0; i < cp.length; i++) {\n if(!cp[i].cancelled) {\n try{\n cp[i].callback(last)\n } catch(e) {\n setTimeout(function() { throw e }, 0)\n }\n }\n }\n }, Math.round(next))\n }\n queue.push({\n handle: ++id,\n callback: callback,\n cancelled: false\n })\n return id\n }\n\n caf = function(handle) {\n for(var i = 0; i < queue.length; i++) {\n if(queue[i].handle === handle) {\n queue[i].cancelled = true\n }\n }\n }\n}\n\nmodule.exports = function(fn) {\n // Wrap in a new function to prevent\n // `cancel` potentially being assigned\n // to the native rAF function\n return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function(object) {\n if (!object) {\n object = root;\n }\n object.requestAnimationFrame = raf\n object.cancelAnimationFrame = caf\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.CalendarDayPhrases = exports.DayPickerNavigationPhrases = exports.DayPickerKeyboardShortcutsPhrases = exports.DayPickerPhrases = exports.SingleDatePickerInputPhrases = exports.SingleDatePickerPhrases = exports.DateRangePickerInputPhrases = exports.DateRangePickerPhrases = exports[\"default\"] = void 0;\nvar calendarLabel = 'Calendar';\nvar roleDescription = 'datepicker';\nvar closeDatePicker = 'Close';\nvar focusStartDate = 'Interact with the calendar and add the check-in date for your trip.';\nvar clearDate = 'Clear Date';\nvar clearDates = 'Clear Dates';\nvar jumpToPrevMonth = 'Move backward to switch to the previous month.';\nvar jumpToNextMonth = 'Move forward to switch to the next month.';\nvar keyboardShortcuts = 'Keyboard Shortcuts';\nvar showKeyboardShortcutsPanel = 'Open the keyboard shortcuts panel.';\nvar hideKeyboardShortcutsPanel = 'Close the shortcuts panel.';\nvar openThisPanel = 'Open this panel.';\nvar enterKey = 'Enter key';\nvar leftArrowRightArrow = 'Right and left arrow keys';\nvar upArrowDownArrow = 'up and down arrow keys';\nvar pageUpPageDown = 'page up and page down keys';\nvar homeEnd = 'Home and end keys';\nvar escape = 'Escape key';\nvar questionMark = 'Question mark';\nvar selectFocusedDate = 'Select the date in focus.';\nvar moveFocusByOneDay = 'Move backward (left) and forward (right) by one day.';\nvar moveFocusByOneWeek = 'Move backward (up) and forward (down) by one week.';\nvar moveFocusByOneMonth = 'Switch months.';\nvar moveFocustoStartAndEndOfWeek = 'Go to the first or last day of a week.';\nvar returnFocusToInput = 'Return to the date input field.';\nvar keyboardForwardNavigationInstructions = 'Navigate forward to interact with the calendar and select a date. Press the question mark key to get the keyboard shortcuts for changing dates.';\nvar keyboardBackwardNavigationInstructions = 'Navigate backward to interact with the calendar and select a date. Press the question mark key to get the keyboard shortcuts for changing dates.';\n\nvar chooseAvailableStartDate = function chooseAvailableStartDate(_ref) {\n var date = _ref.date;\n return \"Choose \".concat(date, \" as your check-in date. It\\u2019s available.\");\n};\n\nvar chooseAvailableEndDate = function chooseAvailableEndDate(_ref2) {\n var date = _ref2.date;\n return \"Choose \".concat(date, \" as your check-out date. It\\u2019s available.\");\n};\n\nvar chooseAvailableDate = function chooseAvailableDate(_ref3) {\n var date = _ref3.date;\n return date;\n};\n\nvar dateIsUnavailable = function dateIsUnavailable(_ref4) {\n var date = _ref4.date;\n return \"Not available. \".concat(date);\n};\n\nvar dateIsSelected = function dateIsSelected(_ref5) {\n var date = _ref5.date;\n return \"Selected. \".concat(date);\n};\n\nvar dateIsSelectedAsStartDate = function dateIsSelectedAsStartDate(_ref6) {\n var date = _ref6.date;\n return \"Selected as start date. \".concat(date);\n};\n\nvar dateIsSelectedAsEndDate = function dateIsSelectedAsEndDate(_ref7) {\n var date = _ref7.date;\n return \"Selected as end date. \".concat(date);\n};\n\nvar _default = {\n calendarLabel: calendarLabel,\n roleDescription: roleDescription,\n closeDatePicker: closeDatePicker,\n focusStartDate: focusStartDate,\n clearDate: clearDate,\n clearDates: clearDates,\n jumpToPrevMonth: jumpToPrevMonth,\n jumpToNextMonth: jumpToNextMonth,\n keyboardShortcuts: keyboardShortcuts,\n showKeyboardShortcutsPanel: showKeyboardShortcutsPanel,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n openThisPanel: openThisPanel,\n enterKey: enterKey,\n leftArrowRightArrow: leftArrowRightArrow,\n upArrowDownArrow: upArrowDownArrow,\n pageUpPageDown: pageUpPageDown,\n homeEnd: homeEnd,\n escape: escape,\n questionMark: questionMark,\n selectFocusedDate: selectFocusedDate,\n moveFocusByOneDay: moveFocusByOneDay,\n moveFocusByOneWeek: moveFocusByOneWeek,\n moveFocusByOneMonth: moveFocusByOneMonth,\n moveFocustoStartAndEndOfWeek: moveFocustoStartAndEndOfWeek,\n returnFocusToInput: returnFocusToInput,\n keyboardForwardNavigationInstructions: keyboardForwardNavigationInstructions,\n keyboardBackwardNavigationInstructions: keyboardBackwardNavigationInstructions,\n chooseAvailableStartDate: chooseAvailableStartDate,\n chooseAvailableEndDate: chooseAvailableEndDate,\n dateIsUnavailable: dateIsUnavailable,\n dateIsSelected: dateIsSelected,\n dateIsSelectedAsStartDate: dateIsSelectedAsStartDate,\n dateIsSelectedAsEndDate: dateIsSelectedAsEndDate\n};\nexports[\"default\"] = _default;\nvar DateRangePickerPhrases = {\n calendarLabel: calendarLabel,\n roleDescription: roleDescription,\n closeDatePicker: closeDatePicker,\n clearDates: clearDates,\n focusStartDate: focusStartDate,\n jumpToPrevMonth: jumpToPrevMonth,\n jumpToNextMonth: jumpToNextMonth,\n keyboardShortcuts: keyboardShortcuts,\n showKeyboardShortcutsPanel: showKeyboardShortcutsPanel,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n openThisPanel: openThisPanel,\n enterKey: enterKey,\n leftArrowRightArrow: leftArrowRightArrow,\n upArrowDownArrow: upArrowDownArrow,\n pageUpPageDown: pageUpPageDown,\n homeEnd: homeEnd,\n escape: escape,\n questionMark: questionMark,\n selectFocusedDate: selectFocusedDate,\n moveFocusByOneDay: moveFocusByOneDay,\n moveFocusByOneWeek: moveFocusByOneWeek,\n moveFocusByOneMonth: moveFocusByOneMonth,\n moveFocustoStartAndEndOfWeek: moveFocustoStartAndEndOfWeek,\n returnFocusToInput: returnFocusToInput,\n keyboardForwardNavigationInstructions: keyboardForwardNavigationInstructions,\n keyboardBackwardNavigationInstructions: keyboardBackwardNavigationInstructions,\n chooseAvailableStartDate: chooseAvailableStartDate,\n chooseAvailableEndDate: chooseAvailableEndDate,\n dateIsUnavailable: dateIsUnavailable,\n dateIsSelected: dateIsSelected,\n dateIsSelectedAsStartDate: dateIsSelectedAsStartDate,\n dateIsSelectedAsEndDate: dateIsSelectedAsEndDate\n};\nexports.DateRangePickerPhrases = DateRangePickerPhrases;\nvar DateRangePickerInputPhrases = {\n focusStartDate: focusStartDate,\n clearDates: clearDates,\n keyboardForwardNavigationInstructions: keyboardForwardNavigationInstructions,\n keyboardBackwardNavigationInstructions: keyboardBackwardNavigationInstructions\n};\nexports.DateRangePickerInputPhrases = DateRangePickerInputPhrases;\nvar SingleDatePickerPhrases = {\n calendarLabel: calendarLabel,\n roleDescription: roleDescription,\n closeDatePicker: closeDatePicker,\n clearDate: clearDate,\n jumpToPrevMonth: jumpToPrevMonth,\n jumpToNextMonth: jumpToNextMonth,\n keyboardShortcuts: keyboardShortcuts,\n showKeyboardShortcutsPanel: showKeyboardShortcutsPanel,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n openThisPanel: openThisPanel,\n enterKey: enterKey,\n leftArrowRightArrow: leftArrowRightArrow,\n upArrowDownArrow: upArrowDownArrow,\n pageUpPageDown: pageUpPageDown,\n homeEnd: homeEnd,\n escape: escape,\n questionMark: questionMark,\n selectFocusedDate: selectFocusedDate,\n moveFocusByOneDay: moveFocusByOneDay,\n moveFocusByOneWeek: moveFocusByOneWeek,\n moveFocusByOneMonth: moveFocusByOneMonth,\n moveFocustoStartAndEndOfWeek: moveFocustoStartAndEndOfWeek,\n returnFocusToInput: returnFocusToInput,\n keyboardForwardNavigationInstructions: keyboardForwardNavigationInstructions,\n keyboardBackwardNavigationInstructions: keyboardBackwardNavigationInstructions,\n chooseAvailableDate: chooseAvailableDate,\n dateIsUnavailable: dateIsUnavailable,\n dateIsSelected: dateIsSelected\n};\nexports.SingleDatePickerPhrases = SingleDatePickerPhrases;\nvar SingleDatePickerInputPhrases = {\n clearDate: clearDate,\n keyboardForwardNavigationInstructions: keyboardForwardNavigationInstructions,\n keyboardBackwardNavigationInstructions: keyboardBackwardNavigationInstructions\n};\nexports.SingleDatePickerInputPhrases = SingleDatePickerInputPhrases;\nvar DayPickerPhrases = {\n calendarLabel: calendarLabel,\n roleDescription: roleDescription,\n jumpToPrevMonth: jumpToPrevMonth,\n jumpToNextMonth: jumpToNextMonth,\n keyboardShortcuts: keyboardShortcuts,\n showKeyboardShortcutsPanel: showKeyboardShortcutsPanel,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n openThisPanel: openThisPanel,\n enterKey: enterKey,\n leftArrowRightArrow: leftArrowRightArrow,\n upArrowDownArrow: upArrowDownArrow,\n pageUpPageDown: pageUpPageDown,\n homeEnd: homeEnd,\n escape: escape,\n questionMark: questionMark,\n selectFocusedDate: selectFocusedDate,\n moveFocusByOneDay: moveFocusByOneDay,\n moveFocusByOneWeek: moveFocusByOneWeek,\n moveFocusByOneMonth: moveFocusByOneMonth,\n moveFocustoStartAndEndOfWeek: moveFocustoStartAndEndOfWeek,\n returnFocusToInput: returnFocusToInput,\n chooseAvailableStartDate: chooseAvailableStartDate,\n chooseAvailableEndDate: chooseAvailableEndDate,\n chooseAvailableDate: chooseAvailableDate,\n dateIsUnavailable: dateIsUnavailable,\n dateIsSelected: dateIsSelected,\n dateIsSelectedAsStartDate: dateIsSelectedAsStartDate,\n dateIsSelectedAsEndDate: dateIsSelectedAsEndDate\n};\nexports.DayPickerPhrases = DayPickerPhrases;\nvar DayPickerKeyboardShortcutsPhrases = {\n keyboardShortcuts: keyboardShortcuts,\n showKeyboardShortcutsPanel: showKeyboardShortcutsPanel,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n openThisPanel: openThisPanel,\n enterKey: enterKey,\n leftArrowRightArrow: leftArrowRightArrow,\n upArrowDownArrow: upArrowDownArrow,\n pageUpPageDown: pageUpPageDown,\n homeEnd: homeEnd,\n escape: escape,\n questionMark: questionMark,\n selectFocusedDate: selectFocusedDate,\n moveFocusByOneDay: moveFocusByOneDay,\n moveFocusByOneWeek: moveFocusByOneWeek,\n moveFocusByOneMonth: moveFocusByOneMonth,\n moveFocustoStartAndEndOfWeek: moveFocustoStartAndEndOfWeek,\n returnFocusToInput: returnFocusToInput\n};\nexports.DayPickerKeyboardShortcutsPhrases = DayPickerKeyboardShortcutsPhrases;\nvar DayPickerNavigationPhrases = {\n jumpToPrevMonth: jumpToPrevMonth,\n jumpToNextMonth: jumpToNextMonth\n};\nexports.DayPickerNavigationPhrases = DayPickerNavigationPhrases;\nvar CalendarDayPhrases = {\n chooseAvailableDate: chooseAvailableDate,\n dateIsUnavailable: dateIsUnavailable,\n dateIsSelected: dateIsSelected,\n dateIsSelectedAsStartDate: dateIsSelectedAsStartDate,\n dateIsSelectedAsEndDate: dateIsSelectedAsEndDate\n};\nexports.CalendarDayPhrases = CalendarDayPhrases;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getPhrasePropTypes;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction getPhrasePropTypes(defaultPhrases) {\n return Object.keys(defaultPhrases).reduce(function (phrases, key) {\n return _objectSpread({}, phrases, (0, _defineProperty2[\"default\"])({}, key, _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].string, _propTypes[\"default\"].func, _propTypes[\"default\"].node])));\n }, {});\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getPhrase;\n\nfunction getPhrase(phrase, args) {\n if (typeof phrase === 'string') return phrase;\n\n if (typeof phrase === 'function') {\n return phrase(args);\n }\n\n return '';\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.MODIFIER_KEY_NAMES = exports.DEFAULT_VERTICAL_SPACING = exports.FANG_HEIGHT_PX = exports.FANG_WIDTH_PX = exports.WEEKDAYS = exports.BLOCKED_MODIFIER = exports.DAY_SIZE = exports.OPEN_UP = exports.OPEN_DOWN = exports.ANCHOR_RIGHT = exports.ANCHOR_LEFT = exports.INFO_POSITION_AFTER = exports.INFO_POSITION_BEFORE = exports.INFO_POSITION_BOTTOM = exports.INFO_POSITION_TOP = exports.ICON_AFTER_POSITION = exports.ICON_BEFORE_POSITION = exports.NAV_POSITION_TOP = exports.NAV_POSITION_BOTTOM = exports.VERTICAL_SCROLLABLE = exports.VERTICAL_ORIENTATION = exports.HORIZONTAL_ORIENTATION = exports.END_DATE = exports.START_DATE = exports.ISO_MONTH_FORMAT = exports.ISO_FORMAT = exports.DISPLAY_FORMAT = void 0;\nvar DISPLAY_FORMAT = 'L';\nexports.DISPLAY_FORMAT = DISPLAY_FORMAT;\nvar ISO_FORMAT = 'YYYY-MM-DD';\nexports.ISO_FORMAT = ISO_FORMAT;\nvar ISO_MONTH_FORMAT = 'YYYY-MM'; // TODO delete this line of dead code on next breaking change\n\nexports.ISO_MONTH_FORMAT = ISO_MONTH_FORMAT;\nvar START_DATE = 'startDate';\nexports.START_DATE = START_DATE;\nvar END_DATE = 'endDate';\nexports.END_DATE = END_DATE;\nvar HORIZONTAL_ORIENTATION = 'horizontal';\nexports.HORIZONTAL_ORIENTATION = HORIZONTAL_ORIENTATION;\nvar VERTICAL_ORIENTATION = 'vertical';\nexports.VERTICAL_ORIENTATION = VERTICAL_ORIENTATION;\nvar VERTICAL_SCROLLABLE = 'verticalScrollable';\nexports.VERTICAL_SCROLLABLE = VERTICAL_SCROLLABLE;\nvar NAV_POSITION_BOTTOM = 'navPositionBottom';\nexports.NAV_POSITION_BOTTOM = NAV_POSITION_BOTTOM;\nvar NAV_POSITION_TOP = 'navPositionTop';\nexports.NAV_POSITION_TOP = NAV_POSITION_TOP;\nvar ICON_BEFORE_POSITION = 'before';\nexports.ICON_BEFORE_POSITION = ICON_BEFORE_POSITION;\nvar ICON_AFTER_POSITION = 'after';\nexports.ICON_AFTER_POSITION = ICON_AFTER_POSITION;\nvar INFO_POSITION_TOP = 'top';\nexports.INFO_POSITION_TOP = INFO_POSITION_TOP;\nvar INFO_POSITION_BOTTOM = 'bottom';\nexports.INFO_POSITION_BOTTOM = INFO_POSITION_BOTTOM;\nvar INFO_POSITION_BEFORE = 'before';\nexports.INFO_POSITION_BEFORE = INFO_POSITION_BEFORE;\nvar INFO_POSITION_AFTER = 'after';\nexports.INFO_POSITION_AFTER = INFO_POSITION_AFTER;\nvar ANCHOR_LEFT = 'left';\nexports.ANCHOR_LEFT = ANCHOR_LEFT;\nvar ANCHOR_RIGHT = 'right';\nexports.ANCHOR_RIGHT = ANCHOR_RIGHT;\nvar OPEN_DOWN = 'down';\nexports.OPEN_DOWN = OPEN_DOWN;\nvar OPEN_UP = 'up';\nexports.OPEN_UP = OPEN_UP;\nvar DAY_SIZE = 39;\nexports.DAY_SIZE = DAY_SIZE;\nvar BLOCKED_MODIFIER = 'blocked';\nexports.BLOCKED_MODIFIER = BLOCKED_MODIFIER;\nvar WEEKDAYS = [0, 1, 2, 3, 4, 5, 6];\nexports.WEEKDAYS = WEEKDAYS;\nvar FANG_WIDTH_PX = 20;\nexports.FANG_WIDTH_PX = FANG_WIDTH_PX;\nvar FANG_HEIGHT_PX = 10;\nexports.FANG_HEIGHT_PX = FANG_HEIGHT_PX;\nvar DEFAULT_VERTICAL_SPACING = 22;\nexports.DEFAULT_VERTICAL_SPACING = DEFAULT_VERTICAL_SPACING;\nvar MODIFIER_KEY_NAMES = new Set(['Shift', 'Control', 'Alt', 'Meta']);\nexports.MODIFIER_KEY_NAMES = MODIFIER_KEY_NAMES;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getCalendarDaySettings;\n\nvar _getPhrase = _interopRequireDefault(require(\"./getPhrase\"));\n\nvar _constants = require(\"../constants\");\n\nfunction isSelected(modifiers) {\n return modifiers.has('selected') || modifiers.has('selected-span') || modifiers.has('selected-start') || modifiers.has('selected-end');\n}\n\nfunction shouldUseDefaultCursor(modifiers) {\n return modifiers.has('blocked-minimum-nights') || modifiers.has('blocked-calendar') || modifiers.has('blocked-out-of-range');\n}\n\nfunction isHoveredSpan(modifiers) {\n if (isSelected(modifiers)) return false;\n return modifiers.has('hovered-span') || modifiers.has('after-hovered-start') || modifiers.has('before-hovered-end');\n}\n\nfunction getAriaLabel(phrases, modifiers, day, ariaLabelFormat) {\n var chooseAvailableDate = phrases.chooseAvailableDate,\n dateIsUnavailable = phrases.dateIsUnavailable,\n dateIsSelected = phrases.dateIsSelected,\n dateIsSelectedAsStartDate = phrases.dateIsSelectedAsStartDate,\n dateIsSelectedAsEndDate = phrases.dateIsSelectedAsEndDate;\n var formattedDate = {\n date: day.format(ariaLabelFormat)\n };\n\n if (modifiers.has('selected-start') && dateIsSelectedAsStartDate) {\n return (0, _getPhrase[\"default\"])(dateIsSelectedAsStartDate, formattedDate);\n }\n\n if (modifiers.has('selected-end') && dateIsSelectedAsEndDate) {\n return (0, _getPhrase[\"default\"])(dateIsSelectedAsEndDate, formattedDate);\n }\n\n if (isSelected(modifiers) && dateIsSelected) {\n return (0, _getPhrase[\"default\"])(dateIsSelected, formattedDate);\n }\n\n if (modifiers.has(_constants.BLOCKED_MODIFIER)) {\n return (0, _getPhrase[\"default\"])(dateIsUnavailable, formattedDate);\n }\n\n return (0, _getPhrase[\"default\"])(chooseAvailableDate, formattedDate);\n}\n\nfunction getCalendarDaySettings(day, ariaLabelFormat, daySize, modifiers, phrases) {\n return {\n ariaLabel: getAriaLabel(phrases, modifiers, day, ariaLabelFormat),\n hoveredSpan: isHoveredSpan(modifiers),\n isOutsideRange: modifiers.has('blocked-out-of-range'),\n selected: isSelected(modifiers),\n useDefaultCursor: shouldUseDefaultCursor(modifiers),\n daySizeStyles: {\n width: daySize,\n height: daySize - 1\n }\n };\n}","function _arrayLikeToArray(r, a) {\n (null == a || a > r.length) && (a = r.length);\n for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];\n return n;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _arrayWithoutHoles(r) {\n if (Array.isArray(r)) return arrayLikeToArray(r);\n}\nmodule.exports = _arrayWithoutHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArray(r) {\n if (\"undefined\" != typeof Symbol && null != r[Symbol.iterator] || null != r[\"@@iterator\"]) return Array.from(r);\n}\nmodule.exports = _iterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(r, a) {\n if (r) {\n if (\"string\" == typeof r) return arrayLikeToArray(r, a);\n var t = {}.toString.call(r).slice(8, -1);\n return \"Object\" === t && r.constructor && (t = r.constructor.name), \"Map\" === t || \"Set\" === t ? Array.from(r) : \"Arguments\" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? arrayLikeToArray(r, a) : void 0;\n }\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableSpread, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithoutHoles = require(\"./arrayWithoutHoles.js\");\nvar iterableToArray = require(\"./iterableToArray.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableSpread = require(\"./nonIterableSpread.js\");\nfunction _toConsumableArray(r) {\n return arrayWithoutHoles(r) || iterableToArray(r) || unsupportedIterableToArray(r) || nonIterableSpread();\n}\nmodule.exports = _toConsumableArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _default = (0, _airbnbPropTypes.and)([_propTypes[\"default\"].instanceOf(Set), function modifiers(props, propName) {\n for (var _len = arguments.length, rest = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n rest[_key - 2] = arguments[_key];\n }\n\n var propValue = props[propName];\n var firstError;\n (0, _toConsumableArray2[\"default\"])(propValue).some(function (v, i) {\n var _PropTypes$string;\n\n var fakePropName = \"\".concat(propName, \": index \").concat(i);\n firstError = (_PropTypes$string = _propTypes[\"default\"].string).isRequired.apply(_PropTypes$string, [(0, _defineProperty2[\"default\"])({}, fakePropName, v), fakePropName].concat(rest));\n return firstError != null;\n });\n return firstError == null ? null : firstError;\n}], 'Modifiers (Set of Strings)');\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.PureCalendarDay = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _raf = _interopRequireDefault(require(\"raf\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _getCalendarDaySettings = _interopRequireDefault(require(\"../utils/getCalendarDaySettings\"));\n\nvar _ModifiersShape = _interopRequireDefault(require(\"../shapes/ModifiersShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n day: _reactMomentProptypes[\"default\"].momentObj,\n daySize: _airbnbPropTypes.nonNegativeInteger,\n isOutsideDay: _propTypes[\"default\"].bool,\n modifiers: _ModifiersShape[\"default\"],\n isFocused: _propTypes[\"default\"].bool,\n tabIndex: _propTypes[\"default\"].oneOf([0, -1]),\n onDayClick: _propTypes[\"default\"].func,\n onDayMouseEnter: _propTypes[\"default\"].func,\n onDayMouseLeave: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n ariaLabelFormat: _propTypes[\"default\"].string,\n // internationalization\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.CalendarDayPhrases))\n})) : {};\nvar defaultProps = {\n day: (0, _moment[\"default\"])(),\n daySize: _constants.DAY_SIZE,\n isOutsideDay: false,\n modifiers: new Set(),\n isFocused: false,\n tabIndex: -1,\n onDayClick: function onDayClick() {},\n onDayMouseEnter: function onDayMouseEnter() {},\n onDayMouseLeave: function onDayMouseLeave() {},\n renderDayContents: null,\n ariaLabelFormat: 'dddd, LL',\n // internationalization\n phrases: _defaultPhrases.CalendarDayPhrases\n};\n\nvar CalendarDay =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(CalendarDay, _ref);\n var _proto = CalendarDay.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function CalendarDay() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _ref.call.apply(_ref, [this].concat(args)) || this;\n _this.setButtonRef = _this.setButtonRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var _this2 = this;\n\n var _this$props = this.props,\n isFocused = _this$props.isFocused,\n tabIndex = _this$props.tabIndex;\n\n if (tabIndex === 0) {\n if (isFocused || tabIndex !== prevProps.tabIndex) {\n (0, _raf[\"default\"])(function () {\n if (_this2.buttonRef) {\n _this2.buttonRef.focus();\n }\n });\n }\n }\n };\n\n _proto.onDayClick = function onDayClick(day, e) {\n var onDayClick = this.props.onDayClick;\n onDayClick(day, e);\n };\n\n _proto.onDayMouseEnter = function onDayMouseEnter(day, e) {\n var onDayMouseEnter = this.props.onDayMouseEnter;\n onDayMouseEnter(day, e);\n };\n\n _proto.onDayMouseLeave = function onDayMouseLeave(day, e) {\n var onDayMouseLeave = this.props.onDayMouseLeave;\n onDayMouseLeave(day, e);\n };\n\n _proto.onKeyDown = function onKeyDown(day, e) {\n var onDayClick = this.props.onDayClick;\n var key = e.key;\n\n if (key === 'Enter' || key === ' ') {\n onDayClick(day, e);\n }\n };\n\n _proto.setButtonRef = function setButtonRef(ref) {\n this.buttonRef = ref;\n };\n\n _proto.render = function render() {\n var _this3 = this;\n\n var _this$props2 = this.props,\n day = _this$props2.day,\n ariaLabelFormat = _this$props2.ariaLabelFormat,\n daySize = _this$props2.daySize,\n isOutsideDay = _this$props2.isOutsideDay,\n modifiers = _this$props2.modifiers,\n renderDayContents = _this$props2.renderDayContents,\n tabIndex = _this$props2.tabIndex,\n styles = _this$props2.styles,\n phrases = _this$props2.phrases;\n if (!day) return _react[\"default\"].createElement(\"td\", null);\n\n var _getCalendarDaySettin = (0, _getCalendarDaySettings[\"default\"])(day, ariaLabelFormat, daySize, modifiers, phrases),\n daySizeStyles = _getCalendarDaySettin.daySizeStyles,\n useDefaultCursor = _getCalendarDaySettin.useDefaultCursor,\n selected = _getCalendarDaySettin.selected,\n hoveredSpan = _getCalendarDaySettin.hoveredSpan,\n isOutsideRange = _getCalendarDaySettin.isOutsideRange,\n ariaLabel = _getCalendarDaySettin.ariaLabel;\n\n return _react[\"default\"].createElement(\"td\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.CalendarDay, useDefaultCursor && styles.CalendarDay__defaultCursor, styles.CalendarDay__default, isOutsideDay && styles.CalendarDay__outside, modifiers.has('today') && styles.CalendarDay__today, modifiers.has('first-day-of-week') && styles.CalendarDay__firstDayOfWeek, modifiers.has('last-day-of-week') && styles.CalendarDay__lastDayOfWeek, modifiers.has('hovered-offset') && styles.CalendarDay__hovered_offset, modifiers.has('hovered-start-first-possible-end') && styles.CalendarDay__hovered_start_first_possible_end, modifiers.has('hovered-start-blocked-minimum-nights') && styles.CalendarDay__hovered_start_blocked_min_nights, modifiers.has('highlighted-calendar') && styles.CalendarDay__highlighted_calendar, modifiers.has('blocked-minimum-nights') && styles.CalendarDay__blocked_minimum_nights, modifiers.has('blocked-calendar') && styles.CalendarDay__blocked_calendar, hoveredSpan && styles.CalendarDay__hovered_span, modifiers.has('after-hovered-start') && styles.CalendarDay__after_hovered_start, modifiers.has('selected-span') && styles.CalendarDay__selected_span, modifiers.has('selected-start') && styles.CalendarDay__selected_start, modifiers.has('selected-end') && styles.CalendarDay__selected_end, selected && !modifiers.has('selected-span') && styles.CalendarDay__selected, modifiers.has('before-hovered-end') && styles.CalendarDay__before_hovered_end, modifiers.has('no-selected-start-before-selected-end') && styles.CalendarDay__no_selected_start_before_selected_end, modifiers.has('selected-start-in-hovered-span') && styles.CalendarDay__selected_start_in_hovered_span, modifiers.has('selected-end-in-hovered-span') && styles.CalendarDay__selected_end_in_hovered_span, modifiers.has('selected-start-no-selected-end') && styles.CalendarDay__selected_start_no_selected_end, modifiers.has('selected-end-no-selected-start') && styles.CalendarDay__selected_end_no_selected_start, isOutsideRange && styles.CalendarDay__blocked_out_of_range, daySizeStyles), {\n role: \"button\" // eslint-disable-line jsx-a11y/no-noninteractive-element-to-interactive-role\n ,\n ref: this.setButtonRef,\n \"aria-disabled\": modifiers.has('blocked'),\n \"aria-label\": ariaLabel,\n onMouseEnter: function onMouseEnter(e) {\n _this3.onDayMouseEnter(day, e);\n },\n onMouseLeave: function onMouseLeave(e) {\n _this3.onDayMouseLeave(day, e);\n },\n onMouseUp: function onMouseUp(e) {\n e.currentTarget.blur();\n },\n onClick: function onClick(e) {\n _this3.onDayClick(day, e);\n },\n onKeyDown: function onKeyDown(e) {\n _this3.onKeyDown(day, e);\n },\n tabIndex: tabIndex\n }), renderDayContents ? renderDayContents(day, modifiers) : day.format('D'));\n };\n\n return CalendarDay;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports.PureCalendarDay = CalendarDay;\nCalendarDay.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nCalendarDay.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n color = _ref2$reactDates.color,\n font = _ref2$reactDates.font;\n return {\n CalendarDay: {\n boxSizing: 'border-box',\n cursor: 'pointer',\n fontSize: font.size,\n textAlign: 'center',\n ':active': {\n outline: 0\n }\n },\n CalendarDay__defaultCursor: {\n cursor: 'default'\n },\n CalendarDay__default: {\n border: \"1px solid \".concat(color.core.borderLight),\n color: color.text,\n background: color.background,\n ':hover': {\n background: color.core.borderLight,\n border: \"1px solid \".concat(color.core.borderLight),\n color: 'inherit'\n }\n },\n CalendarDay__hovered_offset: {\n background: color.core.borderBright,\n border: \"1px double \".concat(color.core.borderLight),\n color: 'inherit'\n },\n CalendarDay__outside: {\n border: 0,\n background: color.outside.backgroundColor,\n color: color.outside.color,\n ':hover': {\n border: 0\n }\n },\n CalendarDay__blocked_minimum_nights: {\n background: color.minimumNights.backgroundColor,\n border: \"1px solid \".concat(color.minimumNights.borderColor),\n color: color.minimumNights.color,\n ':hover': {\n background: color.minimumNights.backgroundColor_hover,\n color: color.minimumNights.color_active\n },\n ':active': {\n background: color.minimumNights.backgroundColor_active,\n color: color.minimumNights.color_active\n }\n },\n CalendarDay__highlighted_calendar: {\n background: color.highlighted.backgroundColor,\n color: color.highlighted.color,\n ':hover': {\n background: color.highlighted.backgroundColor_hover,\n color: color.highlighted.color_active\n },\n ':active': {\n background: color.highlighted.backgroundColor_active,\n color: color.highlighted.color_active\n }\n },\n CalendarDay__selected_span: {\n background: color.selectedSpan.backgroundColor,\n border: \"1px double \".concat(color.selectedSpan.borderColor),\n color: color.selectedSpan.color,\n ':hover': {\n background: color.selectedSpan.backgroundColor_hover,\n border: \"1px double \".concat(color.selectedSpan.borderColor),\n color: color.selectedSpan.color_active\n },\n ':active': {\n background: color.selectedSpan.backgroundColor_active,\n border: \"1px double \".concat(color.selectedSpan.borderColor),\n color: color.selectedSpan.color_active\n }\n },\n CalendarDay__selected: {\n background: color.selected.backgroundColor,\n border: \"1px double \".concat(color.selected.borderColor),\n color: color.selected.color,\n ':hover': {\n background: color.selected.backgroundColor_hover,\n border: \"1px double \".concat(color.selected.borderColor),\n color: color.selected.color_active\n },\n ':active': {\n background: color.selected.backgroundColor_active,\n border: \"1px double \".concat(color.selected.borderColor),\n color: color.selected.color_active\n }\n },\n CalendarDay__hovered_span: {\n background: color.hoveredSpan.backgroundColor,\n border: \"1px double \".concat(color.hoveredSpan.borderColor),\n color: color.hoveredSpan.color,\n ':hover': {\n background: color.hoveredSpan.backgroundColor_hover,\n border: \"1px double \".concat(color.hoveredSpan.borderColor),\n color: color.hoveredSpan.color_active\n },\n ':active': {\n background: color.hoveredSpan.backgroundColor_active,\n border: \"1px double \".concat(color.hoveredSpan.borderColor),\n color: color.hoveredSpan.color_active\n }\n },\n CalendarDay__blocked_calendar: {\n background: color.blocked_calendar.backgroundColor,\n border: \"1px solid \".concat(color.blocked_calendar.borderColor),\n color: color.blocked_calendar.color,\n ':hover': {\n background: color.blocked_calendar.backgroundColor_hover,\n border: \"1px solid \".concat(color.blocked_calendar.borderColor),\n color: color.blocked_calendar.color_active\n },\n ':active': {\n background: color.blocked_calendar.backgroundColor_active,\n border: \"1px solid \".concat(color.blocked_calendar.borderColor),\n color: color.blocked_calendar.color_active\n }\n },\n CalendarDay__blocked_out_of_range: {\n background: color.blocked_out_of_range.backgroundColor,\n border: \"1px solid \".concat(color.blocked_out_of_range.borderColor),\n color: color.blocked_out_of_range.color,\n ':hover': {\n background: color.blocked_out_of_range.backgroundColor_hover,\n border: \"1px solid \".concat(color.blocked_out_of_range.borderColor),\n color: color.blocked_out_of_range.color_active\n },\n ':active': {\n background: color.blocked_out_of_range.backgroundColor_active,\n border: \"1px solid \".concat(color.blocked_out_of_range.borderColor),\n color: color.blocked_out_of_range.color_active\n }\n },\n CalendarDay__hovered_start_first_possible_end: {\n background: color.core.borderLighter,\n border: \"1px double \".concat(color.core.borderLighter)\n },\n CalendarDay__hovered_start_blocked_min_nights: {\n background: color.core.borderLighter,\n border: \"1px double \".concat(color.core.borderLight)\n },\n CalendarDay__selected_start: {},\n CalendarDay__selected_end: {},\n CalendarDay__today: {},\n CalendarDay__firstDayOfWeek: {},\n CalendarDay__lastDayOfWeek: {},\n CalendarDay__after_hovered_start: {},\n CalendarDay__before_hovered_end: {},\n CalendarDay__no_selected_start_before_selected_end: {},\n CalendarDay__selected_start_in_hovered_span: {},\n CalendarDay__selected_end_in_hovered_span: {},\n CalendarDay__selected_start_no_selected_end: {},\n CalendarDay__selected_end_no_selected_start: {}\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(CalendarDay);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = CalendarWeek;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)({\n children: _propTypes[\"default\"].node.isRequired\n}) : {};\n\nfunction CalendarWeek(_ref) {\n var children = _ref.children;\n return _react[\"default\"].createElement(\"tr\", null, children);\n}\n\nCalendarWeek.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = calculateDimension;\n\nfunction calculateDimension(el, axis) {\n var borderBox = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n var withMargin = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n\n if (!el) {\n return 0;\n }\n\n var axisStart = axis === 'width' ? 'Left' : 'Top';\n var axisEnd = axis === 'width' ? 'Right' : 'Bottom'; // Only read styles if we need to\n\n var style = !borderBox || withMargin ? window.getComputedStyle(el) : null; // Offset includes border and padding\n\n var offsetWidth = el.offsetWidth,\n offsetHeight = el.offsetHeight;\n var size = axis === 'width' ? offsetWidth : offsetHeight; // Get the inner size\n\n if (!borderBox) {\n size -= parseFloat(style[\"padding\".concat(axisStart)]) + parseFloat(style[\"padding\".concat(axisEnd)]) + parseFloat(style[\"border\".concat(axisStart, \"Width\")]) + parseFloat(style[\"border\".concat(axisEnd, \"Width\")]);\n } // Apply margin\n\n\n if (withMargin) {\n size += parseFloat(style[\"margin\".concat(axisStart)]) + parseFloat(style[\"margin\".concat(axisEnd)]);\n }\n\n return size;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getCalendarMonthWeeks;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _constants = require(\"../constants\");\n\nfunction getCalendarMonthWeeks(month, enableOutsideDays) {\n var firstDayOfWeek = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _moment[\"default\"].localeData().firstDayOfWeek();\n\n if (!_moment[\"default\"].isMoment(month) || !month.isValid()) {\n throw new TypeError('`month` must be a valid moment object');\n }\n\n if (_constants.WEEKDAYS.indexOf(firstDayOfWeek) === -1) {\n throw new TypeError('`firstDayOfWeek` must be an integer between 0 and 6');\n } // set utc offset to get correct dates in future (when timezone changes)\n\n\n var firstOfMonth = month.clone().startOf('month').hour(12);\n var lastOfMonth = month.clone().endOf('month').hour(12); // calculate the exact first and last days to fill the entire matrix\n // (considering days outside month)\n\n var prevDays = (firstOfMonth.day() + 7 - firstDayOfWeek) % 7;\n var nextDays = (firstDayOfWeek + 6 - lastOfMonth.day()) % 7;\n var firstDay = firstOfMonth.clone().subtract(prevDays, 'day');\n var lastDay = lastOfMonth.clone().add(nextDays, 'day');\n var totalDays = lastDay.diff(firstDay, 'days') + 1;\n var currentDay = firstDay.clone();\n var weeksInMonth = [];\n\n for (var i = 0; i < totalDays; i += 1) {\n if (i % 7 === 0) {\n weeksInMonth.push([]);\n }\n\n var day = null;\n\n if (i >= prevDays && i < totalDays - nextDays || enableOutsideDays) {\n day = currentDay.clone();\n }\n\n weeksInMonth[weeksInMonth.length - 1].push(day);\n currentDay.add(1, 'day');\n }\n\n return weeksInMonth;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isSameDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nfunction isSameDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false; // Compare least significant, most likely to change units first\n // Moment's isSame clones moment inputs and is a tad slow\n\n return a.date() === b.date() && a.month() === b.month() && a.year() === b.year();\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = toMomentObject;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _constants = require(\"../constants\");\n\nfunction toMomentObject(dateString, customFormat) {\n var dateFormats = customFormat ? [customFormat, _constants.DISPLAY_FORMAT, _constants.ISO_FORMAT] : [_constants.DISPLAY_FORMAT, _constants.ISO_FORMAT];\n var date = (0, _moment[\"default\"])(dateString, dateFormats, true);\n return date.isValid() ? date.hour(12) : null;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = toISODateString;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _toMomentObject = _interopRequireDefault(require(\"./toMomentObject\"));\n\nfunction toISODateString(date, currentFormat) {\n var dateObj = _moment[\"default\"].isMoment(date) ? date : (0, _toMomentObject[\"default\"])(date, currentFormat);\n if (!dateObj) return null; // Template strings compiled in strict mode uses concat, which is slow. Since\n // this code is in a hot path and we want it to be as fast as possible, we\n // want to use old-fashioned +.\n // eslint-disable-next-line prefer-template\n\n return dateObj.year() + '-' + String(dateObj.month() + 1).padStart(2, '0') + '-' + String(dateObj.date()).padStart(2, '0');\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.HORIZONTAL_ORIENTATION, _constants.VERTICAL_ORIENTATION, _constants.VERTICAL_SCROLLABLE]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf(_constants.WEEKDAYS);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _CalendarWeek = _interopRequireDefault(require(\"./CalendarWeek\"));\n\nvar _CalendarDay = _interopRequireDefault(require(\"./CalendarDay\"));\n\nvar _calculateDimension = _interopRequireDefault(require(\"../utils/calculateDimension\"));\n\nvar _getCalendarMonthWeeks = _interopRequireDefault(require(\"../utils/getCalendarMonthWeeks\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"../utils/isSameDay\"));\n\nvar _toISODateString = _interopRequireDefault(require(\"../utils/toISODateString\"));\n\nvar _ModifiersShape = _interopRequireDefault(require(\"../shapes/ModifiersShape\"));\n\nvar _ScrollableOrientationShape = _interopRequireDefault(require(\"../shapes/ScrollableOrientationShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"../shapes/DayOfWeekShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n month: _reactMomentProptypes[\"default\"].momentObj,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n isVisible: _propTypes[\"default\"].bool,\n enableOutsideDays: _propTypes[\"default\"].bool,\n modifiers: _propTypes[\"default\"].objectOf(_ModifiersShape[\"default\"]),\n orientation: _ScrollableOrientationShape[\"default\"],\n daySize: _airbnbPropTypes.nonNegativeInteger,\n onDayClick: _propTypes[\"default\"].func,\n onDayMouseEnter: _propTypes[\"default\"].func,\n onDayMouseLeave: _propTypes[\"default\"].func,\n onMonthSelect: _propTypes[\"default\"].func,\n onYearSelect: _propTypes[\"default\"].func,\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n setMonthTitleHeight: _propTypes[\"default\"].func,\n verticalBorderSpacing: _airbnbPropTypes.nonNegativeInteger,\n focusedDate: _reactMomentProptypes[\"default\"].momentObj,\n // indicates focusable day\n isFocused: _propTypes[\"default\"].bool,\n // indicates whether or not to move focus to focusable day\n // i18n\n monthFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.CalendarDayPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string\n})) : {};\nvar defaultProps = {\n month: (0, _moment[\"default\"])(),\n horizontalMonthPadding: 13,\n isVisible: true,\n enableOutsideDays: false,\n modifiers: {},\n orientation: _constants.HORIZONTAL_ORIENTATION,\n daySize: _constants.DAY_SIZE,\n onDayClick: function onDayClick() {},\n onDayMouseEnter: function onDayMouseEnter() {},\n onDayMouseLeave: function onDayMouseLeave() {},\n onMonthSelect: function onMonthSelect() {},\n onYearSelect: function onYearSelect() {},\n renderMonthText: null,\n renderCalendarDay: function renderCalendarDay(props) {\n return _react[\"default\"].createElement(_CalendarDay[\"default\"], props);\n },\n renderDayContents: null,\n renderMonthElement: null,\n firstDayOfWeek: null,\n setMonthTitleHeight: null,\n focusedDate: null,\n isFocused: false,\n // i18n\n monthFormat: 'MMMM YYYY',\n // english locale\n phrases: _defaultPhrases.CalendarDayPhrases,\n dayAriaLabelFormat: undefined,\n verticalBorderSpacing: undefined\n};\n\nvar CalendarMonth =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(CalendarMonth, _ref);\n var _proto = CalendarMonth.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function CalendarMonth(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.state = {\n weeks: (0, _getCalendarMonthWeeks[\"default\"])(props.month, props.enableOutsideDays, props.firstDayOfWeek == null ? _moment[\"default\"].localeData().firstDayOfWeek() : props.firstDayOfWeek)\n };\n _this.setCaptionRef = _this.setCaptionRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setMonthTitleHeight = _this.setMonthTitleHeight.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentDidMount = function componentDidMount() {\n this.setMonthTitleHeightTimeout = setTimeout(this.setMonthTitleHeight, 0);\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var month = nextProps.month,\n enableOutsideDays = nextProps.enableOutsideDays,\n firstDayOfWeek = nextProps.firstDayOfWeek;\n var _this$props = this.props,\n prevMonth = _this$props.month,\n prevEnableOutsideDays = _this$props.enableOutsideDays,\n prevFirstDayOfWeek = _this$props.firstDayOfWeek;\n\n if (!month.isSame(prevMonth) || enableOutsideDays !== prevEnableOutsideDays || firstDayOfWeek !== prevFirstDayOfWeek) {\n this.setState({\n weeks: (0, _getCalendarMonthWeeks[\"default\"])(month, enableOutsideDays, firstDayOfWeek == null ? _moment[\"default\"].localeData().firstDayOfWeek() : firstDayOfWeek)\n });\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this.setMonthTitleHeightTimeout) {\n clearTimeout(this.setMonthTitleHeightTimeout);\n }\n };\n\n _proto.setMonthTitleHeight = function setMonthTitleHeight() {\n var setMonthTitleHeight = this.props.setMonthTitleHeight;\n\n if (setMonthTitleHeight) {\n var captionHeight = (0, _calculateDimension[\"default\"])(this.captionRef, 'height', true, true);\n setMonthTitleHeight(captionHeight);\n }\n };\n\n _proto.setCaptionRef = function setCaptionRef(ref) {\n this.captionRef = ref;\n };\n\n _proto.render = function render() {\n var _this$props2 = this.props,\n dayAriaLabelFormat = _this$props2.dayAriaLabelFormat,\n daySize = _this$props2.daySize,\n focusedDate = _this$props2.focusedDate,\n horizontalMonthPadding = _this$props2.horizontalMonthPadding,\n isFocused = _this$props2.isFocused,\n isVisible = _this$props2.isVisible,\n modifiers = _this$props2.modifiers,\n month = _this$props2.month,\n monthFormat = _this$props2.monthFormat,\n onDayClick = _this$props2.onDayClick,\n onDayMouseEnter = _this$props2.onDayMouseEnter,\n onDayMouseLeave = _this$props2.onDayMouseLeave,\n onMonthSelect = _this$props2.onMonthSelect,\n onYearSelect = _this$props2.onYearSelect,\n orientation = _this$props2.orientation,\n phrases = _this$props2.phrases,\n renderCalendarDay = _this$props2.renderCalendarDay,\n renderDayContents = _this$props2.renderDayContents,\n renderMonthElement = _this$props2.renderMonthElement,\n renderMonthText = _this$props2.renderMonthText,\n styles = _this$props2.styles,\n verticalBorderSpacing = _this$props2.verticalBorderSpacing;\n var weeks = this.state.weeks;\n var monthTitle = renderMonthText ? renderMonthText(month) : month.format(monthFormat);\n var verticalScrollable = orientation === _constants.VERTICAL_SCROLLABLE;\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.CalendarMonth, {\n padding: \"0 \".concat(horizontalMonthPadding, \"px\")\n }), {\n \"data-visible\": isVisible\n }), _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n ref: this.setCaptionRef\n }, (0, _reactWithStyles.css)(styles.CalendarMonth_caption, verticalScrollable && styles.CalendarMonth_caption__verticalScrollable)), renderMonthElement ? renderMonthElement({\n month: month,\n onMonthSelect: onMonthSelect,\n onYearSelect: onYearSelect,\n isVisible: isVisible\n }) : _react[\"default\"].createElement(\"strong\", null, monthTitle)), _react[\"default\"].createElement(\"table\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(!verticalBorderSpacing && styles.CalendarMonth_table, verticalBorderSpacing && styles.CalendarMonth_verticalSpacing, verticalBorderSpacing && {\n borderSpacing: \"0px \".concat(verticalBorderSpacing, \"px\")\n }), {\n role: \"presentation\"\n }), _react[\"default\"].createElement(\"tbody\", null, weeks.map(function (week, i) {\n return _react[\"default\"].createElement(_CalendarWeek[\"default\"], {\n key: i\n }, week.map(function (day, dayOfWeek) {\n return renderCalendarDay({\n key: dayOfWeek,\n day: day,\n daySize: daySize,\n isOutsideDay: !day || day.month() !== month.month(),\n tabIndex: isVisible && (0, _isSameDay[\"default\"])(day, focusedDate) ? 0 : -1,\n isFocused: isFocused,\n onDayMouseEnter: onDayMouseEnter,\n onDayMouseLeave: onDayMouseLeave,\n onDayClick: onDayClick,\n renderDayContents: renderDayContents,\n phrases: phrases,\n modifiers: modifiers[(0, _toISODateString[\"default\"])(day)],\n ariaLabelFormat: dayAriaLabelFormat\n });\n }));\n }))));\n };\n\n return CalendarMonth;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nCalendarMonth.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nCalendarMonth.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n color = _ref2$reactDates.color,\n font = _ref2$reactDates.font,\n spacing = _ref2$reactDates.spacing;\n return {\n CalendarMonth: {\n background: color.background,\n textAlign: 'center',\n verticalAlign: 'top',\n userSelect: 'none'\n },\n CalendarMonth_table: {\n borderCollapse: 'collapse',\n borderSpacing: 0\n },\n CalendarMonth_verticalSpacing: {\n borderCollapse: 'separate'\n },\n CalendarMonth_caption: {\n color: color.text,\n fontSize: font.captionSize,\n textAlign: 'center',\n paddingTop: spacing.captionPaddingTop,\n paddingBottom: spacing.captionPaddingBottom,\n captionSide: 'initial'\n },\n CalendarMonth_caption__verticalScrollable: {\n paddingTop: 12,\n paddingBottom: 7\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(CalendarMonth);\n\nexports[\"default\"] = _default;","var CAN_USE_DOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\n// Adapted from Modernizr\n// https://github.com/Modernizr/Modernizr/blob/acb3f0d9/feature-detects/dom/passiveeventlisteners.js#L26-L37\nfunction testPassiveEventListeners() {\n if (!CAN_USE_DOM) {\n return false;\n }\n\n if (!window.addEventListener || !window.removeEventListener || !Object.defineProperty) {\n return false;\n }\n\n var supportsPassiveOption = false;\n try {\n var opts = Object.defineProperty({}, 'passive', {\n // eslint-disable-next-line getter-return\n get: function () {\n function get() {\n supportsPassiveOption = true;\n }\n\n return get;\n }()\n });\n var noop = function noop() {};\n window.addEventListener('testPassiveEventSupport', noop, opts);\n window.removeEventListener('testPassiveEventSupport', noop, opts);\n } catch (e) {\n // do nothing\n }\n\n return supportsPassiveOption;\n}\n\nvar memoized = void 0;\n\nfunction canUsePassiveEventListeners() {\n if (memoized === undefined) {\n memoized = testPassiveEventListeners();\n }\n return memoized;\n}\n\nfunction normalizeEventOptions(eventOptions) {\n if (!eventOptions) {\n return undefined;\n }\n\n if (!canUsePassiveEventListeners()) {\n // If the browser does not support the passive option, then it is expecting\n // a boolean for the options argument to specify whether it should use\n // capture or not. In more modern browsers, this is passed via the `capture`\n // option, so let's just hoist that value up.\n return !!eventOptions.capture;\n }\n\n return eventOptions;\n}\n\n/* eslint-disable no-bitwise */\n\n/**\n * Generate a unique key for any set of event options\n */\nfunction eventOptionsKey(normalizedEventOptions) {\n if (!normalizedEventOptions) {\n return 0;\n }\n\n // If the browser does not support passive event listeners, the normalized\n // event options will be a boolean.\n if (normalizedEventOptions === true) {\n return 100;\n }\n\n // At this point, the browser supports passive event listeners, so we expect\n // the event options to be an object with possible properties of capture,\n // passive, and once.\n //\n // We want to consistently return the same value, regardless of the order of\n // these properties, so let's use binary maths to assign each property to a\n // bit, and then add those together (with an offset to account for the\n // booleans at the beginning of this function).\n var capture = normalizedEventOptions.capture << 0;\n var passive = normalizedEventOptions.passive << 1;\n var once = normalizedEventOptions.once << 2;\n return capture + passive + once;\n}\n\nfunction ensureCanMutateNextEventHandlers(eventHandlers) {\n if (eventHandlers.handlers === eventHandlers.nextHandlers) {\n // eslint-disable-next-line no-param-reassign\n eventHandlers.nextHandlers = eventHandlers.handlers.slice();\n }\n}\n\nfunction TargetEventHandlers(target) {\n this.target = target;\n this.events = {};\n}\n\nTargetEventHandlers.prototype.getEventHandlers = function () {\n function getEventHandlers(eventName, options) {\n var key = String(eventName) + ' ' + String(eventOptionsKey(options));\n\n if (!this.events[key]) {\n this.events[key] = {\n handlers: [],\n handleEvent: undefined\n };\n this.events[key].nextHandlers = this.events[key].handlers;\n }\n\n return this.events[key];\n }\n\n return getEventHandlers;\n}();\n\nTargetEventHandlers.prototype.handleEvent = function () {\n function handleEvent(eventName, options, event) {\n var eventHandlers = this.getEventHandlers(eventName, options);\n eventHandlers.handlers = eventHandlers.nextHandlers;\n eventHandlers.handlers.forEach(function (handler) {\n if (handler) {\n // We need to check for presence here because a handler function may\n // cause later handlers to get removed. This can happen if you for\n // instance have a waypoint that unmounts another waypoint as part of an\n // onEnter/onLeave handler.\n handler(event);\n }\n });\n }\n\n return handleEvent;\n}();\n\nTargetEventHandlers.prototype.add = function () {\n function add(eventName, listener, options) {\n var _this = this;\n\n // options has already been normalized at this point.\n var eventHandlers = this.getEventHandlers(eventName, options);\n\n ensureCanMutateNextEventHandlers(eventHandlers);\n\n if (eventHandlers.nextHandlers.length === 0) {\n eventHandlers.handleEvent = this.handleEvent.bind(this, eventName, options);\n\n this.target.addEventListener(eventName, eventHandlers.handleEvent, options);\n }\n\n eventHandlers.nextHandlers.push(listener);\n\n var isSubscribed = true;\n var unsubscribe = function () {\n function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n\n isSubscribed = false;\n\n ensureCanMutateNextEventHandlers(eventHandlers);\n var index = eventHandlers.nextHandlers.indexOf(listener);\n eventHandlers.nextHandlers.splice(index, 1);\n\n if (eventHandlers.nextHandlers.length === 0) {\n // All event handlers have been removed, so we want to remove the event\n // listener from the target node.\n\n if (_this.target) {\n // There can be a race condition where the target may no longer exist\n // when this function is called, e.g. when a React component is\n // unmounting. Guarding against this prevents the following error:\n //\n // Cannot read property 'removeEventListener' of undefined\n _this.target.removeEventListener(eventName, eventHandlers.handleEvent, options);\n }\n\n eventHandlers.handleEvent = undefined;\n }\n }\n\n return unsubscribe;\n }();\n return unsubscribe;\n }\n\n return add;\n}();\n\nvar EVENT_HANDLERS_KEY = '__consolidated_events_handlers__';\n\n// eslint-disable-next-line import/prefer-default-export\nfunction addEventListener(target, eventName, listener, options) {\n if (!target[EVENT_HANDLERS_KEY]) {\n // eslint-disable-next-line no-param-reassign\n target[EVENT_HANDLERS_KEY] = new TargetEventHandlers(target);\n }\n var normalizedEventOptions = normalizeEventOptions(options);\n return target[EVENT_HANDLERS_KEY].add(eventName, listener, normalizedEventOptions);\n}\n\nexport { addEventListener };\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = noflip;\nvar NOFLIP = '/* @noflip */'; // Appends a noflip comment to a style rule in order to prevent it from being automatically\n// flipped in RTL contexts. This should be used only in situations where the style must remain\n// unflipped regardless of direction context. See: https://github.com/kentcdodds/rtl-css-js#usage\n\nfunction noflip(value) {\n if (typeof value === 'number') return \"\".concat(value, \"px \").concat(NOFLIP);\n if (typeof value === 'string') return \"\".concat(value, \" \").concat(NOFLIP);\n throw new TypeError('noflip expects a string or a number');\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isTransitionEndSupported;\n\nfunction isTransitionEndSupported() {\n return !!(typeof window !== 'undefined' && 'TransitionEvent' in window);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getTransformStyles;\n\nfunction getTransformStyles(transformValue) {\n return {\n transform: transformValue,\n msTransform: transformValue,\n MozTransform: transformValue,\n WebkitTransform: transformValue\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getCalendarMonthWidth;\n\nfunction getCalendarMonthWidth(daySize) {\n var calendarMonthPadding = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return 7 * daySize + 2 * calendarMonthPadding + 1;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = toISOMonthString;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _toMomentObject = _interopRequireDefault(require(\"./toMomentObject\"));\n\nfunction toISOMonthString(date, currentFormat) {\n var dateObj = _moment[\"default\"].isMoment(date) ? date : (0, _toMomentObject[\"default\"])(date, currentFormat);\n if (!dateObj) return null; // Template strings compiled in strict mode uses concat, which is slow. Since\n // this code is in a hot path and we want it to be as fast as possible, we\n // want to use old-fashioned +.\n // eslint-disable-next-line prefer-template\n\n return dateObj.year() + '-' + String(dateObj.month() + 1).padStart(2, '0');\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isSameMonth;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nfunction isSameMonth(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false; // Compare least significant, most likely to change units first\n // Moment's isSame clones moment inputs and is a tad slow\n\n return a.month() === b.month() && a.year() === b.year();\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isPrevMonth;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isSameMonth = _interopRequireDefault(require(\"./isSameMonth\"));\n\nfunction isPrevMonth(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n return (0, _isSameMonth[\"default\"])(a.clone().subtract(1, 'month'), b);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isNextMonth;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isSameMonth = _interopRequireDefault(require(\"./isSameMonth\"));\n\nfunction isNextMonth(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n return (0, _isSameMonth[\"default\"])(a.clone().add(1, 'month'), b);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _consolidatedEvents = require(\"consolidated-events\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _CalendarMonth = _interopRequireDefault(require(\"./CalendarMonth\"));\n\nvar _isTransitionEndSupported = _interopRequireDefault(require(\"../utils/isTransitionEndSupported\"));\n\nvar _getTransformStyles = _interopRequireDefault(require(\"../utils/getTransformStyles\"));\n\nvar _getCalendarMonthWidth = _interopRequireDefault(require(\"../utils/getCalendarMonthWidth\"));\n\nvar _toISOMonthString = _interopRequireDefault(require(\"../utils/toISOMonthString\"));\n\nvar _isPrevMonth = _interopRequireDefault(require(\"../utils/isPrevMonth\"));\n\nvar _isNextMonth = _interopRequireDefault(require(\"../utils/isNextMonth\"));\n\nvar _ModifiersShape = _interopRequireDefault(require(\"../shapes/ModifiersShape\"));\n\nvar _ScrollableOrientationShape = _interopRequireDefault(require(\"../shapes/ScrollableOrientationShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"../shapes/DayOfWeekShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n enableOutsideDays: _propTypes[\"default\"].bool,\n firstVisibleMonthIndex: _propTypes[\"default\"].number,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n initialMonth: _reactMomentProptypes[\"default\"].momentObj,\n isAnimating: _propTypes[\"default\"].bool,\n numberOfMonths: _propTypes[\"default\"].number,\n modifiers: _propTypes[\"default\"].objectOf(_propTypes[\"default\"].objectOf(_ModifiersShape[\"default\"])),\n orientation: _ScrollableOrientationShape[\"default\"],\n onDayClick: _propTypes[\"default\"].func,\n onDayMouseEnter: _propTypes[\"default\"].func,\n onDayMouseLeave: _propTypes[\"default\"].func,\n onMonthTransitionEnd: _propTypes[\"default\"].func,\n onMonthChange: _propTypes[\"default\"].func,\n onYearChange: _propTypes[\"default\"].func,\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n translationValue: _propTypes[\"default\"].number,\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n daySize: _airbnbPropTypes.nonNegativeInteger,\n focusedDate: _reactMomentProptypes[\"default\"].momentObj,\n // indicates focusable day\n isFocused: _propTypes[\"default\"].bool,\n // indicates whether or not to move focus to focusable day\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n setMonthTitleHeight: _propTypes[\"default\"].func,\n isRTL: _propTypes[\"default\"].bool,\n transitionDuration: _airbnbPropTypes.nonNegativeInteger,\n verticalBorderSpacing: _airbnbPropTypes.nonNegativeInteger,\n // i18n\n monthFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.CalendarDayPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string\n})) : {};\nvar defaultProps = {\n enableOutsideDays: false,\n firstVisibleMonthIndex: 0,\n horizontalMonthPadding: 13,\n initialMonth: (0, _moment[\"default\"])(),\n isAnimating: false,\n numberOfMonths: 1,\n modifiers: {},\n orientation: _constants.HORIZONTAL_ORIENTATION,\n onDayClick: function onDayClick() {},\n onDayMouseEnter: function onDayMouseEnter() {},\n onDayMouseLeave: function onDayMouseLeave() {},\n onMonthChange: function onMonthChange() {},\n onYearChange: function onYearChange() {},\n onMonthTransitionEnd: function onMonthTransitionEnd() {},\n renderMonthText: null,\n renderCalendarDay: undefined,\n renderDayContents: null,\n translationValue: null,\n renderMonthElement: null,\n daySize: _constants.DAY_SIZE,\n focusedDate: null,\n isFocused: false,\n firstDayOfWeek: null,\n setMonthTitleHeight: null,\n isRTL: false,\n transitionDuration: 200,\n verticalBorderSpacing: undefined,\n // i18n\n monthFormat: 'MMMM YYYY',\n // english locale\n phrases: _defaultPhrases.CalendarDayPhrases,\n dayAriaLabelFormat: undefined\n};\n\nfunction getMonths(initialMonth, numberOfMonths, withoutTransitionMonths) {\n var month = initialMonth.clone();\n if (!withoutTransitionMonths) month = month.subtract(1, 'month');\n var months = [];\n\n for (var i = 0; i < (withoutTransitionMonths ? numberOfMonths : numberOfMonths + 2); i += 1) {\n months.push(month);\n month = month.clone().add(1, 'month');\n }\n\n return months;\n}\n\nvar CalendarMonthGrid =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(CalendarMonthGrid, _ref);\n var _proto = CalendarMonthGrid.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function CalendarMonthGrid(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n var withoutTransitionMonths = props.orientation === _constants.VERTICAL_SCROLLABLE;\n _this.state = {\n months: getMonths(props.initialMonth, props.numberOfMonths, withoutTransitionMonths)\n };\n _this.isTransitionEndSupported = (0, _isTransitionEndSupported[\"default\"])();\n _this.onTransitionEnd = _this.onTransitionEnd.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setContainerRef = _this.setContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.locale = _moment[\"default\"].locale();\n _this.onMonthSelect = _this.onMonthSelect.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onYearSelect = _this.onYearSelect.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentDidMount = function componentDidMount() {\n this.removeEventListener = (0, _consolidatedEvents.addEventListener)(this.container, 'transitionend', this.onTransitionEnd);\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var _this2 = this;\n\n var initialMonth = nextProps.initialMonth,\n numberOfMonths = nextProps.numberOfMonths,\n orientation = nextProps.orientation;\n var months = this.state.months;\n var _this$props = this.props,\n prevInitialMonth = _this$props.initialMonth,\n prevNumberOfMonths = _this$props.numberOfMonths;\n var hasMonthChanged = !prevInitialMonth.isSame(initialMonth, 'month');\n var hasNumberOfMonthsChanged = prevNumberOfMonths !== numberOfMonths;\n var newMonths = months;\n\n if (hasMonthChanged && !hasNumberOfMonthsChanged) {\n if ((0, _isNextMonth[\"default\"])(prevInitialMonth, initialMonth)) {\n newMonths = months.slice(1);\n newMonths.push(months[months.length - 1].clone().add(1, 'month'));\n } else if ((0, _isPrevMonth[\"default\"])(prevInitialMonth, initialMonth)) {\n newMonths = months.slice(0, months.length - 1);\n newMonths.unshift(months[0].clone().subtract(1, 'month'));\n } else {\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n newMonths = getMonths(initialMonth, numberOfMonths, withoutTransitionMonths);\n }\n }\n\n if (hasNumberOfMonthsChanged) {\n var _withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n\n newMonths = getMonths(initialMonth, numberOfMonths, _withoutTransitionMonths);\n }\n\n var momentLocale = _moment[\"default\"].locale();\n\n if (this.locale !== momentLocale) {\n this.locale = momentLocale;\n newMonths = newMonths.map(function (m) {\n return m.locale(_this2.locale);\n });\n }\n\n this.setState({\n months: newMonths\n });\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n var _this$props2 = this.props,\n isAnimating = _this$props2.isAnimating,\n transitionDuration = _this$props2.transitionDuration,\n onMonthTransitionEnd = _this$props2.onMonthTransitionEnd; // For IE9, immediately call onMonthTransitionEnd instead of\n // waiting for the animation to complete. Similarly, if transitionDuration\n // is set to 0, also immediately invoke the onMonthTransitionEnd callback\n\n if ((!this.isTransitionEndSupported || !transitionDuration) && isAnimating) {\n onMonthTransitionEnd();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this.removeEventListener) this.removeEventListener();\n };\n\n _proto.onTransitionEnd = function onTransitionEnd() {\n var onMonthTransitionEnd = this.props.onMonthTransitionEnd;\n onMonthTransitionEnd();\n };\n\n _proto.onMonthSelect = function onMonthSelect(currentMonth, newMonthVal) {\n var newMonth = currentMonth.clone();\n var _this$props3 = this.props,\n onMonthChange = _this$props3.onMonthChange,\n orientation = _this$props3.orientation;\n var months = this.state.months;\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var initialMonthSubtraction = months.indexOf(currentMonth);\n\n if (!withoutTransitionMonths) {\n initialMonthSubtraction -= 1;\n }\n\n newMonth.set('month', newMonthVal).subtract(initialMonthSubtraction, 'months');\n onMonthChange(newMonth);\n };\n\n _proto.onYearSelect = function onYearSelect(currentMonth, newYearVal) {\n var newMonth = currentMonth.clone();\n var _this$props4 = this.props,\n onYearChange = _this$props4.onYearChange,\n orientation = _this$props4.orientation;\n var months = this.state.months;\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var initialMonthSubtraction = months.indexOf(currentMonth);\n\n if (!withoutTransitionMonths) {\n initialMonthSubtraction -= 1;\n }\n\n newMonth.set('year', newYearVal).subtract(initialMonthSubtraction, 'months');\n onYearChange(newMonth);\n };\n\n _proto.setContainerRef = function setContainerRef(ref) {\n this.container = ref;\n };\n\n _proto.render = function render() {\n var _this3 = this;\n\n var _this$props5 = this.props,\n enableOutsideDays = _this$props5.enableOutsideDays,\n firstVisibleMonthIndex = _this$props5.firstVisibleMonthIndex,\n horizontalMonthPadding = _this$props5.horizontalMonthPadding,\n isAnimating = _this$props5.isAnimating,\n modifiers = _this$props5.modifiers,\n numberOfMonths = _this$props5.numberOfMonths,\n monthFormat = _this$props5.monthFormat,\n orientation = _this$props5.orientation,\n translationValue = _this$props5.translationValue,\n daySize = _this$props5.daySize,\n onDayMouseEnter = _this$props5.onDayMouseEnter,\n onDayMouseLeave = _this$props5.onDayMouseLeave,\n onDayClick = _this$props5.onDayClick,\n renderMonthText = _this$props5.renderMonthText,\n renderCalendarDay = _this$props5.renderCalendarDay,\n renderDayContents = _this$props5.renderDayContents,\n renderMonthElement = _this$props5.renderMonthElement,\n onMonthTransitionEnd = _this$props5.onMonthTransitionEnd,\n firstDayOfWeek = _this$props5.firstDayOfWeek,\n focusedDate = _this$props5.focusedDate,\n isFocused = _this$props5.isFocused,\n isRTL = _this$props5.isRTL,\n styles = _this$props5.styles,\n phrases = _this$props5.phrases,\n dayAriaLabelFormat = _this$props5.dayAriaLabelFormat,\n transitionDuration = _this$props5.transitionDuration,\n verticalBorderSpacing = _this$props5.verticalBorderSpacing,\n setMonthTitleHeight = _this$props5.setMonthTitleHeight;\n var months = this.state.months;\n var isVertical = orientation === _constants.VERTICAL_ORIENTATION;\n var isVerticalScrollable = orientation === _constants.VERTICAL_SCROLLABLE;\n var isHorizontal = orientation === _constants.HORIZONTAL_ORIENTATION;\n var calendarMonthWidth = (0, _getCalendarMonthWidth[\"default\"])(daySize, horizontalMonthPadding);\n var width = isVertical || isVerticalScrollable ? calendarMonthWidth : (numberOfMonths + 2) * calendarMonthWidth;\n var transformType = isVertical || isVerticalScrollable ? 'translateY' : 'translateX';\n var transformValue = \"\".concat(transformType, \"(\").concat(translationValue, \"px)\");\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.CalendarMonthGrid, isHorizontal && styles.CalendarMonthGrid__horizontal, isVertical && styles.CalendarMonthGrid__vertical, isVerticalScrollable && styles.CalendarMonthGrid__vertical_scrollable, isAnimating && styles.CalendarMonthGrid__animating, isAnimating && transitionDuration && {\n transition: \"transform \".concat(transitionDuration, \"ms ease-in-out\")\n }, _objectSpread({}, (0, _getTransformStyles[\"default\"])(transformValue), {\n width: width\n })), {\n ref: this.setContainerRef,\n onTransitionEnd: onMonthTransitionEnd\n }), months.map(function (month, i) {\n var isVisible = i >= firstVisibleMonthIndex && i < firstVisibleMonthIndex + numberOfMonths;\n var hideForAnimation = i === 0 && !isVisible;\n var showForAnimation = i === 0 && isAnimating && isVisible;\n var monthString = (0, _toISOMonthString[\"default\"])(month);\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n key: monthString\n }, (0, _reactWithStyles.css)(isHorizontal && styles.CalendarMonthGrid_month__horizontal, hideForAnimation && styles.CalendarMonthGrid_month__hideForAnimation, showForAnimation && !isVertical && !isRTL && {\n position: 'absolute',\n left: -calendarMonthWidth\n }, showForAnimation && !isVertical && isRTL && {\n position: 'absolute',\n right: 0\n }, showForAnimation && isVertical && {\n position: 'absolute',\n top: -translationValue\n }, !isVisible && !isAnimating && styles.CalendarMonthGrid_month__hidden)), _react[\"default\"].createElement(_CalendarMonth[\"default\"], {\n month: month,\n isVisible: isVisible,\n enableOutsideDays: enableOutsideDays,\n modifiers: modifiers[monthString],\n monthFormat: monthFormat,\n orientation: orientation,\n onDayMouseEnter: onDayMouseEnter,\n onDayMouseLeave: onDayMouseLeave,\n onDayClick: onDayClick,\n onMonthSelect: _this3.onMonthSelect,\n onYearSelect: _this3.onYearSelect,\n renderMonthText: renderMonthText,\n renderCalendarDay: renderCalendarDay,\n renderDayContents: renderDayContents,\n renderMonthElement: renderMonthElement,\n firstDayOfWeek: firstDayOfWeek,\n daySize: daySize,\n focusedDate: isVisible ? focusedDate : null,\n isFocused: isFocused,\n phrases: phrases,\n setMonthTitleHeight: setMonthTitleHeight,\n dayAriaLabelFormat: dayAriaLabelFormat,\n verticalBorderSpacing: verticalBorderSpacing,\n horizontalMonthPadding: horizontalMonthPadding\n }));\n }));\n };\n\n return CalendarMonthGrid;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nCalendarMonthGrid.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nCalendarMonthGrid.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n color = _ref2$reactDates.color,\n spacing = _ref2$reactDates.spacing,\n zIndex = _ref2$reactDates.zIndex;\n return {\n CalendarMonthGrid: {\n background: color.background,\n textAlign: (0, _noflip[\"default\"])('left'),\n zIndex: zIndex\n },\n CalendarMonthGrid__animating: {\n zIndex: zIndex + 1\n },\n CalendarMonthGrid__horizontal: {\n position: 'absolute',\n left: (0, _noflip[\"default\"])(spacing.dayPickerHorizontalPadding)\n },\n CalendarMonthGrid__vertical: {\n margin: '0 auto'\n },\n CalendarMonthGrid__vertical_scrollable: {\n margin: '0 auto'\n },\n CalendarMonthGrid_month__horizontal: {\n display: 'inline-block',\n verticalAlign: 'top',\n minHeight: '100%'\n },\n CalendarMonthGrid_month__hideForAnimation: {\n position: 'absolute',\n zIndex: zIndex - 1,\n opacity: 0,\n pointerEvents: 'none'\n },\n CalendarMonthGrid_month__hidden: {\n visibility: 'hidden'\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(CalendarMonthGrid);\n\nexports[\"default\"] = _default;","export var canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);","var _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\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport { canUseDOM } from './utils';\n\nvar Portal = function (_React$Component) {\n _inherits(Portal, _React$Component);\n\n function Portal() {\n _classCallCheck(this, Portal);\n\n return _possibleConstructorReturn(this, (Portal.__proto__ || Object.getPrototypeOf(Portal)).apply(this, arguments));\n }\n\n _createClass(Portal, [{\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this.defaultNode) {\n document.body.removeChild(this.defaultNode);\n }\n this.defaultNode = null;\n }\n }, {\n key: 'render',\n value: function render() {\n if (!canUseDOM) {\n return null;\n }\n if (!this.props.node && !this.defaultNode) {\n this.defaultNode = document.createElement('div');\n document.body.appendChild(this.defaultNode);\n }\n return ReactDOM.createPortal(this.props.children, this.props.node || this.defaultNode);\n }\n }]);\n\n return Portal;\n}(React.Component);\n\nPortal.propTypes = {\n children: PropTypes.node.isRequired,\n node: PropTypes.any\n};\n\nexport default Portal;","var _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// This file is a fallback for a consumer who is not yet on React 16\n// as createPortal was introduced in React 16\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\n\nvar Portal = function (_React$Component) {\n _inherits(Portal, _React$Component);\n\n function Portal() {\n _classCallCheck(this, Portal);\n\n return _possibleConstructorReturn(this, (Portal.__proto__ || Object.getPrototypeOf(Portal)).apply(this, arguments));\n }\n\n _createClass(Portal, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n this.renderPortal();\n }\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(props) {\n this.renderPortal();\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n ReactDOM.unmountComponentAtNode(this.defaultNode || this.props.node);\n if (this.defaultNode) {\n document.body.removeChild(this.defaultNode);\n }\n this.defaultNode = null;\n this.portal = null;\n }\n }, {\n key: 'renderPortal',\n value: function renderPortal(props) {\n if (!this.props.node && !this.defaultNode) {\n this.defaultNode = document.createElement('div');\n document.body.appendChild(this.defaultNode);\n }\n\n var children = this.props.children;\n // https://gist.github.com/jimfb/d99e0678e9da715ccf6454961ef04d1b\n if (typeof this.props.children.type === 'function') {\n children = React.cloneElement(this.props.children);\n }\n\n this.portal = ReactDOM.unstable_renderSubtreeIntoContainer(this, children, this.props.node || this.defaultNode);\n }\n }, {\n key: 'render',\n value: function render() {\n return null;\n }\n }]);\n\n return Portal;\n}(React.Component);\n\nexport default Portal;\n\n\nPortal.propTypes = {\n children: PropTypes.node.isRequired,\n node: PropTypes.any\n};","import ReactDOM from 'react-dom';\n\nimport Portalv4 from './Portal';\nimport LegacyPortal from './LegacyPortal';\n\nvar Portal = void 0;\n\nif (ReactDOM.createPortal) {\n Portal = Portalv4;\n} else {\n Portal = LegacyPortal;\n}\n\nexport default Portal;","var _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\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Portal from './PortalCompat';\n\nvar KEYCODES = {\n ESCAPE: 27\n};\n\nvar PortalWithState = function (_React$Component) {\n _inherits(PortalWithState, _React$Component);\n\n function PortalWithState(props) {\n _classCallCheck(this, PortalWithState);\n\n var _this = _possibleConstructorReturn(this, (PortalWithState.__proto__ || Object.getPrototypeOf(PortalWithState)).call(this, props));\n\n _this.portalNode = null;\n _this.state = { active: !!props.defaultOpen };\n _this.openPortal = _this.openPortal.bind(_this);\n _this.closePortal = _this.closePortal.bind(_this);\n _this.wrapWithPortal = _this.wrapWithPortal.bind(_this);\n _this.handleOutsideMouseClick = _this.handleOutsideMouseClick.bind(_this);\n _this.handleKeydown = _this.handleKeydown.bind(_this);\n return _this;\n }\n\n _createClass(PortalWithState, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n if (this.props.closeOnEsc) {\n document.addEventListener('keydown', this.handleKeydown);\n }\n if (this.props.closeOnOutsideClick) {\n document.addEventListener('click', this.handleOutsideMouseClick);\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this.props.closeOnEsc) {\n document.removeEventListener('keydown', this.handleKeydown);\n }\n if (this.props.closeOnOutsideClick) {\n document.removeEventListener('click', this.handleOutsideMouseClick);\n }\n }\n }, {\n key: 'openPortal',\n value: function openPortal(e) {\n if (this.state.active) {\n return;\n }\n if (e && e.nativeEvent) {\n e.nativeEvent.stopImmediatePropagation();\n }\n this.setState({ active: true }, this.props.onOpen);\n }\n }, {\n key: 'closePortal',\n value: function closePortal() {\n if (!this.state.active) {\n return;\n }\n this.setState({ active: false }, this.props.onClose);\n }\n }, {\n key: 'wrapWithPortal',\n value: function wrapWithPortal(children) {\n var _this2 = this;\n\n if (!this.state.active) {\n return null;\n }\n return React.createElement(\n Portal,\n {\n node: this.props.node,\n key: 'react-portal',\n ref: function ref(portalNode) {\n return _this2.portalNode = portalNode;\n }\n },\n children\n );\n }\n }, {\n key: 'handleOutsideMouseClick',\n value: function handleOutsideMouseClick(e) {\n if (!this.state.active) {\n return;\n }\n var root = this.portalNode && (this.portalNode.props.node || this.portalNode.defaultNode);\n if (!root || root.contains(e.target) || e.button && e.button !== 0) {\n return;\n }\n this.closePortal();\n }\n }, {\n key: 'handleKeydown',\n value: function handleKeydown(e) {\n if (e.keyCode === KEYCODES.ESCAPE && this.state.active) {\n this.closePortal();\n }\n }\n }, {\n key: 'render',\n value: function render() {\n return this.props.children({\n openPortal: this.openPortal,\n closePortal: this.closePortal,\n portal: this.wrapWithPortal,\n isOpen: this.state.active\n });\n }\n }]);\n\n return PortalWithState;\n}(React.Component);\n\nPortalWithState.propTypes = {\n children: PropTypes.func.isRequired,\n defaultOpen: PropTypes.bool,\n node: PropTypes.any,\n closeOnEsc: PropTypes.bool,\n closeOnOutsideClick: PropTypes.bool,\n onOpen: PropTypes.func,\n onClose: PropTypes.func\n};\n\nPortalWithState.defaultProps = {\n onOpen: function onOpen() {},\n onClose: function onClose() {}\n};\n\nexport default PortalWithState;","Object.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports['default'] = isTouchDevice;\nfunction isTouchDevice() {\n return !!(typeof window !== 'undefined' && ('ontouchstart' in window || window.DocumentTouch && typeof document !== 'undefined' && document instanceof window.DocumentTouch)) || !!(typeof navigator !== 'undefined' && (navigator.maxTouchPoints || navigator.msMaxTouchPoints));\n}\nmodule.exports = exports['default'];","'use strict';\n\nmodule.exports = function contains(other) {\n\tif (arguments.length < 1) {\n\t\tthrow new TypeError('1 argument is required');\n\t}\n\tif (typeof other !== 'object') {\n\t\tthrow new TypeError('Argument 1 (”other“) to Node.contains must be an instance of Node');\n\t}\n\n\tvar node = other;\n\tdo {\n\t\tif (this === node) {\n\t\t\treturn true;\n\t\t}\n\t\tif (node) {\n\t\t\tnode = node.parentNode;\n\t\t}\n\t} while (node);\n\n\treturn false;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = function getPolyfill() {\n\tif (typeof document !== 'undefined') {\n\t\tif (document.contains) {\n\t\t\treturn document.contains;\n\t\t}\n\t\tif (document.body && document.body.contains) {\n\t\t\ttry {\n\t\t\t\tif (typeof document.body.contains.call(document, '') === 'boolean') {\n\t\t\t\t\treturn document.body.contains;\n\t\t\t\t}\n\t\t\t} catch (e) { /**/ }\n\t\t}\n\t}\n\treturn implementation;\n};\n","'use strict';\n\nvar define = require('define-properties');\nvar getPolyfill = require('./polyfill');\n\nmodule.exports = function shimContains() {\n\tvar polyfill = getPolyfill();\n\tif (typeof document !== 'undefined') {\n\t\tdefine(\n\t\t\tdocument,\n\t\t\t{ contains: polyfill },\n\t\t\t{ contains: function () { return document.contains !== polyfill; } }\n\t\t);\n\t\tif (typeof Element !== 'undefined') {\n\t\t\tdefine(\n\t\t\t\tElement.prototype,\n\t\t\t\t{ contains: polyfill },\n\t\t\t\t{ contains: function () { return Element.prototype.contains !== polyfill; } }\n\t\t\t);\n\t\t}\n\t}\n\treturn polyfill;\n};\n","'use strict';\n\nvar define = require('define-properties');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar polyfill = getPolyfill();\nvar shim = require('./shim');\n\nvar boundContains = function contains(node, other) {\n\treturn polyfill.apply(node, [other]);\n};\n\ndefine(boundContains, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = boundContains;\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\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\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _airbnbPropTypes = require('airbnb-prop-types');\n\nvar _consolidatedEvents = require('consolidated-events');\n\nvar _object = require('object.values');\n\nvar _object2 = _interopRequireDefault(_object);\n\nvar _document = require('document.contains');\n\nvar _document2 = _interopRequireDefault(_document);\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 DISPLAY = {\n BLOCK: 'block',\n FLEX: 'flex',\n INLINE: 'inline',\n INLINE_BLOCK: 'inline-block',\n CONTENTS: 'contents'\n};\n\nvar propTypes = (0, _airbnbPropTypes.forbidExtraProps)({\n children: _propTypes2['default'].node.isRequired,\n onOutsideClick: _propTypes2['default'].func.isRequired,\n disabled: _propTypes2['default'].bool,\n useCapture: _propTypes2['default'].bool,\n display: _propTypes2['default'].oneOf((0, _object2['default'])(DISPLAY))\n});\n\nvar defaultProps = {\n disabled: false,\n\n // `useCapture` is set to true by default so that a `stopPropagation` in the\n // children will not prevent all outside click handlers from firing - maja\n useCapture: true,\n display: DISPLAY.BLOCK\n};\n\nvar OutsideClickHandler = function (_React$Component) {\n _inherits(OutsideClickHandler, _React$Component);\n\n function OutsideClickHandler() {\n var _ref;\n\n _classCallCheck(this, OutsideClickHandler);\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var _this = _possibleConstructorReturn(this, (_ref = OutsideClickHandler.__proto__ || Object.getPrototypeOf(OutsideClickHandler)).call.apply(_ref, [this].concat(args)));\n\n _this.onMouseDown = _this.onMouseDown.bind(_this);\n _this.onMouseUp = _this.onMouseUp.bind(_this);\n _this.setChildNodeRef = _this.setChildNodeRef.bind(_this);\n return _this;\n }\n\n _createClass(OutsideClickHandler, [{\n key: 'componentDidMount',\n value: function () {\n function componentDidMount() {\n var _props = this.props,\n disabled = _props.disabled,\n useCapture = _props.useCapture;\n\n\n if (!disabled) this.addMouseDownEventListener(useCapture);\n }\n\n return componentDidMount;\n }()\n }, {\n key: 'componentDidUpdate',\n value: function () {\n function componentDidUpdate(_ref2) {\n var prevDisabled = _ref2.disabled;\n var _props2 = this.props,\n disabled = _props2.disabled,\n useCapture = _props2.useCapture;\n\n if (prevDisabled !== disabled) {\n if (disabled) {\n this.removeEventListeners();\n } else {\n this.addMouseDownEventListener(useCapture);\n }\n }\n }\n\n return componentDidUpdate;\n }()\n }, {\n key: 'componentWillUnmount',\n value: function () {\n function componentWillUnmount() {\n this.removeEventListeners();\n }\n\n return componentWillUnmount;\n }()\n\n // Use mousedown/mouseup to enforce that clicks remain outside the root's\n // descendant tree, even when dragged. This should also get triggered on\n // touch devices.\n\n }, {\n key: 'onMouseDown',\n value: function () {\n function onMouseDown(e) {\n var useCapture = this.props.useCapture;\n\n\n var isDescendantOfRoot = this.childNode && (0, _document2['default'])(this.childNode, e.target);\n if (!isDescendantOfRoot) {\n if (this.removeMouseUp) {\n this.removeMouseUp();\n this.removeMouseUp = null;\n }\n this.removeMouseUp = (0, _consolidatedEvents.addEventListener)(document, 'mouseup', this.onMouseUp, { capture: useCapture });\n }\n }\n\n return onMouseDown;\n }()\n\n // Use mousedown/mouseup to enforce that clicks remain outside the root's\n // descendant tree, even when dragged. This should also get triggered on\n // touch devices.\n\n }, {\n key: 'onMouseUp',\n value: function () {\n function onMouseUp(e) {\n var onOutsideClick = this.props.onOutsideClick;\n\n\n var isDescendantOfRoot = this.childNode && (0, _document2['default'])(this.childNode, e.target);\n if (this.removeMouseUp) {\n this.removeMouseUp();\n this.removeMouseUp = null;\n }\n\n if (!isDescendantOfRoot) {\n onOutsideClick(e);\n }\n }\n\n return onMouseUp;\n }()\n }, {\n key: 'setChildNodeRef',\n value: function () {\n function setChildNodeRef(ref) {\n this.childNode = ref;\n }\n\n return setChildNodeRef;\n }()\n }, {\n key: 'addMouseDownEventListener',\n value: function () {\n function addMouseDownEventListener(useCapture) {\n this.removeMouseDown = (0, _consolidatedEvents.addEventListener)(document, 'mousedown', this.onMouseDown, { capture: useCapture });\n }\n\n return addMouseDownEventListener;\n }()\n }, {\n key: 'removeEventListeners',\n value: function () {\n function removeEventListeners() {\n if (this.removeMouseDown) this.removeMouseDown();\n if (this.removeMouseUp) this.removeMouseUp();\n }\n\n return removeEventListeners;\n }()\n }, {\n key: 'render',\n value: function () {\n function render() {\n var _props3 = this.props,\n children = _props3.children,\n display = _props3.display;\n\n\n return _react2['default'].createElement(\n 'div',\n {\n ref: this.setChildNodeRef,\n style: display !== DISPLAY.BLOCK && (0, _object2['default'])(DISPLAY).includes(display) ? { display: display } : undefined\n },\n children\n );\n }\n\n return render;\n }()\n }]);\n\n return OutsideClickHandler;\n}(_react2['default'].Component);\n\nexports['default'] = OutsideClickHandler;\n\n\nOutsideClickHandler.propTypes = propTypes;\nOutsideClickHandler.defaultProps = defaultProps;","// eslint-disable-next-line import/no-unresolved\nmodule.exports = require('./build/OutsideClickHandler');\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.START_DATE, _constants.END_DATE]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.ICON_BEFORE_POSITION, _constants.ICON_AFTER_POSITION]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.HORIZONTAL_ORIENTATION, _constants.VERTICAL_ORIENTATION]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].bool, _propTypes[\"default\"].oneOf([_constants.START_DATE, _constants.END_DATE])]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.ANCHOR_LEFT, _constants.ANCHOR_RIGHT]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.OPEN_DOWN, _constants.OPEN_UP]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.INFO_POSITION_TOP, _constants.INFO_POSITION_BOTTOM, _constants.INFO_POSITION_BEFORE, _constants.INFO_POSITION_AFTER]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _constants = require(\"../constants\");\n\nvar _default = _propTypes[\"default\"].oneOf([_constants.NAV_POSITION_BOTTOM, _constants.NAV_POSITION_TOP]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _FocusedInputShape = _interopRequireDefault(require(\"./FocusedInputShape\"));\n\nvar _IconPositionShape = _interopRequireDefault(require(\"./IconPositionShape\"));\n\nvar _OrientationShape = _interopRequireDefault(require(\"./OrientationShape\"));\n\nvar _DisabledShape = _interopRequireDefault(require(\"./DisabledShape\"));\n\nvar _AnchorDirectionShape = _interopRequireDefault(require(\"./AnchorDirectionShape\"));\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"./OpenDirectionShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"./DayOfWeekShape\"));\n\nvar _CalendarInfoPositionShape = _interopRequireDefault(require(\"./CalendarInfoPositionShape\"));\n\nvar _NavPositionShape = _interopRequireDefault(require(\"./NavPositionShape\"));\n\nvar _default = {\n // required props for a functional interactive DateRangePicker\n startDate: _reactMomentProptypes[\"default\"].momentObj,\n endDate: _reactMomentProptypes[\"default\"].momentObj,\n onDatesChange: _propTypes[\"default\"].func.isRequired,\n focusedInput: _FocusedInputShape[\"default\"],\n onFocusChange: _propTypes[\"default\"].func.isRequired,\n onClose: _propTypes[\"default\"].func,\n // input related props\n startDateId: _propTypes[\"default\"].string.isRequired,\n startDatePlaceholderText: _propTypes[\"default\"].string,\n startDateOffset: _propTypes[\"default\"].func,\n endDateOffset: _propTypes[\"default\"].func,\n endDateId: _propTypes[\"default\"].string.isRequired,\n endDatePlaceholderText: _propTypes[\"default\"].string,\n startDateAriaLabel: _propTypes[\"default\"].string,\n endDateAriaLabel: _propTypes[\"default\"].string,\n disabled: _DisabledShape[\"default\"],\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n screenReaderInputMessage: _propTypes[\"default\"].string,\n showClearDates: _propTypes[\"default\"].bool,\n showDefaultInputIcon: _propTypes[\"default\"].bool,\n inputIconPosition: _IconPositionShape[\"default\"],\n customInputIcon: _propTypes[\"default\"].node,\n customArrowIcon: _propTypes[\"default\"].node,\n customCloseIcon: _propTypes[\"default\"].node,\n noBorder: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n small: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n keepFocusOnInput: _propTypes[\"default\"].bool,\n // calendar presentation and interaction related props\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderWeekHeaderElement: _propTypes[\"default\"].func,\n orientation: _OrientationShape[\"default\"],\n anchorDirection: _AnchorDirectionShape[\"default\"],\n openDirection: _OpenDirectionShape[\"default\"],\n horizontalMargin: _propTypes[\"default\"].number,\n withPortal: _propTypes[\"default\"].bool,\n withFullScreenPortal: _propTypes[\"default\"].bool,\n appendToBody: _propTypes[\"default\"].bool,\n disableScroll: _propTypes[\"default\"].bool,\n daySize: _airbnbPropTypes.nonNegativeInteger,\n isRTL: _propTypes[\"default\"].bool,\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n initialVisibleMonth: _propTypes[\"default\"].func,\n numberOfMonths: _propTypes[\"default\"].number,\n keepOpenOnDateSelect: _propTypes[\"default\"].bool,\n reopenPickerOnClearDates: _propTypes[\"default\"].bool,\n renderCalendarInfo: _propTypes[\"default\"].func,\n calendarInfoPosition: _CalendarInfoPositionShape[\"default\"],\n hideKeyboardShortcutsPanel: _propTypes[\"default\"].bool,\n verticalHeight: _airbnbPropTypes.nonNegativeInteger,\n transitionDuration: _airbnbPropTypes.nonNegativeInteger,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n // navigation related props\n dayPickerNavigationInlineStyles: _propTypes[\"default\"].object,\n navPosition: _NavPositionShape[\"default\"],\n navPrev: _propTypes[\"default\"].node,\n navNext: _propTypes[\"default\"].node,\n renderNavPrevButton: _propTypes[\"default\"].func,\n renderNavNextButton: _propTypes[\"default\"].func,\n onPrevMonthClick: _propTypes[\"default\"].func,\n onNextMonthClick: _propTypes[\"default\"].func,\n // day presentation and interaction related props\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n minimumNights: _propTypes[\"default\"].number,\n minDate: _reactMomentProptypes[\"default\"].momentObj,\n maxDate: _reactMomentProptypes[\"default\"].momentObj,\n enableOutsideDays: _propTypes[\"default\"].bool,\n isDayBlocked: _propTypes[\"default\"].func,\n isOutsideRange: _propTypes[\"default\"].func,\n isDayHighlighted: _propTypes[\"default\"].func,\n // internationalization props\n displayFormat: _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].string, _propTypes[\"default\"].func]),\n monthFormat: _propTypes[\"default\"].string,\n weekDayFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DateRangePickerPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string\n};\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getResponsiveContainerStyles;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _constants = require(\"../constants\");\n\nfunction getResponsiveContainerStyles(anchorDirection, currentOffset, containerEdge, margin) {\n var windowWidth = typeof window !== 'undefined' ? window.innerWidth : 0;\n var calculatedOffset = anchorDirection === _constants.ANCHOR_LEFT ? windowWidth - containerEdge : containerEdge;\n var calculatedMargin = margin || 0;\n return (0, _defineProperty2[\"default\"])({}, anchorDirection, Math.min(currentOffset + calculatedOffset - calculatedMargin, 0));\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getDetachedContainerStyles;\n\nvar _constants = require(\"../constants\");\n\n/**\n * Calculate and return a CSS transform style to position a detached element\n * next to a reference element. The open and anchor direction indicate wether\n * it should be positioned above/below and/or to the left/right of the\n * reference element.\n *\n * Assuming r(0,0), r(1,1), d(0,0), d(1,1) for the bottom-left and top-right\n * corners of the reference and detached elements, respectively:\n * - openDirection = DOWN, anchorDirection = LEFT => d(0,1) == r(0,1)\n * - openDirection = UP, anchorDirection = LEFT => d(0,0) == r(0,0)\n * - openDirection = DOWN, anchorDirection = RIGHT => d(1,1) == r(1,1)\n * - openDirection = UP, anchorDirection = RIGHT => d(1,0) == r(1,0)\n *\n * By using a CSS transform, we allow to further position it using\n * top/bottom CSS properties for the anchor gutter.\n *\n * @param {string} openDirection The vertical positioning of the popup\n * @param {string} anchorDirection The horizontal position of the popup\n * @param {HTMLElement} referenceEl The reference element\n */\nfunction getDetachedContainerStyles(openDirection, anchorDirection, referenceEl) {\n var referenceRect = referenceEl.getBoundingClientRect();\n var offsetX = referenceRect.left;\n var offsetY = referenceRect.top;\n\n if (openDirection === _constants.OPEN_UP) {\n offsetY = -(window.innerHeight - referenceRect.bottom);\n }\n\n if (anchorDirection === _constants.ANCHOR_RIGHT) {\n offsetX = -(window.innerWidth - referenceRect.right);\n }\n\n return {\n transform: \"translate3d(\".concat(Math.round(offsetX), \"px, \").concat(Math.round(offsetY), \"px, 0)\")\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getInputHeight;\n\n/* eslint-disable camelcase */\nfunction getPadding(vertical, top, bottom) {\n var isTopDefined = typeof top === 'number';\n var isBottomDefined = typeof bottom === 'number';\n var isVerticalDefined = typeof vertical === 'number';\n\n if (isTopDefined && isBottomDefined) {\n return top + bottom;\n }\n\n if (isTopDefined && isVerticalDefined) {\n return top + vertical;\n }\n\n if (isTopDefined) {\n return top;\n }\n\n if (isBottomDefined && isVerticalDefined) {\n return bottom + vertical;\n }\n\n if (isBottomDefined) {\n return bottom;\n }\n\n if (isVerticalDefined) {\n return 2 * vertical;\n }\n\n return 0;\n}\n\nfunction getInputHeight(_ref, small) {\n var _ref$font$input = _ref.font.input,\n lineHeight = _ref$font$input.lineHeight,\n lineHeight_small = _ref$font$input.lineHeight_small,\n _ref$spacing = _ref.spacing,\n inputPadding = _ref$spacing.inputPadding,\n displayTextPaddingVertical = _ref$spacing.displayTextPaddingVertical,\n displayTextPaddingTop = _ref$spacing.displayTextPaddingTop,\n displayTextPaddingBottom = _ref$spacing.displayTextPaddingBottom,\n displayTextPaddingVertical_small = _ref$spacing.displayTextPaddingVertical_small,\n displayTextPaddingTop_small = _ref$spacing.displayTextPaddingTop_small,\n displayTextPaddingBottom_small = _ref$spacing.displayTextPaddingBottom_small;\n var calcLineHeight = small ? lineHeight_small : lineHeight;\n var padding = small ? getPadding(displayTextPaddingVertical_small, displayTextPaddingTop_small, displayTextPaddingBottom_small) : getPadding(displayTextPaddingVertical, displayTextPaddingTop, displayTextPaddingBottom);\n return parseInt(calcLineHeight, 10) + 2 * inputPadding + padding;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isBeforeDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nfunction isBeforeDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n var aYear = a.year();\n var aMonth = a.month();\n var bYear = b.year();\n var bMonth = b.month();\n var isSameYear = aYear === bYear;\n var isSameMonth = aMonth === bMonth;\n if (isSameYear && isSameMonth) return a.date() < b.date();\n if (isSameYear) return aMonth < bMonth;\n return aYear < bYear;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isInclusivelyAfterDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isBeforeDay = _interopRequireDefault(require(\"./isBeforeDay\"));\n\nfunction isInclusivelyAfterDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n return !(0, _isBeforeDay[\"default\"])(a, b);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getScrollParent = getScrollParent;\nexports.getScrollAncestorsOverflowY = getScrollAncestorsOverflowY;\nexports[\"default\"] = disableScroll;\n\nvar getScrollingRoot = function getScrollingRoot() {\n return document.scrollingElement || document.documentElement;\n};\n/**\n * Recursively finds the scroll parent of a node. The scroll parrent of a node\n * is the closest node that is scrollable. A node is scrollable if:\n * - it is allowed to scroll via CSS ('overflow-y' not visible or hidden);\n * - and its children/content are \"bigger\" than the node's box height.\n *\n * The root of the document always scrolls by default.\n *\n * @param {HTMLElement} node Any DOM element.\n * @return {HTMLElement} The scroll parent element.\n */\n\n\nfunction getScrollParent(node) {\n var parent = node.parentElement;\n if (parent == null) return getScrollingRoot();\n\n var _window$getComputedSt = window.getComputedStyle(parent),\n overflowY = _window$getComputedSt.overflowY;\n\n var canScroll = overflowY !== 'visible' && overflowY !== 'hidden';\n\n if (canScroll && parent.scrollHeight > parent.clientHeight) {\n return parent;\n }\n\n return getScrollParent(parent);\n}\n/**\n * Recursively traverses the tree upwards from the given node, capturing all\n * ancestor nodes that scroll along with their current 'overflow-y' CSS\n * property.\n *\n * @param {HTMLElement} node Any DOM element.\n * @param {Map} [acc] Accumulator map.\n * @return {Map} Map of ancestors with their 'overflow-y' value.\n */\n\n\nfunction getScrollAncestorsOverflowY(node) {\n var acc = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Map();\n var scrollingRoot = getScrollingRoot();\n var scrollParent = getScrollParent(node);\n acc.set(scrollParent, scrollParent.style.overflowY);\n if (scrollParent === scrollingRoot) return acc;\n return getScrollAncestorsOverflowY(scrollParent, acc);\n}\n/**\n * Disabling the scroll on a node involves finding all the scrollable ancestors\n * and set their 'overflow-y' CSS property to 'hidden'. When all ancestors have\n * 'overflow-y: hidden' (up to the document element) there is no scroll\n * container, thus all the scroll outside of the node is disabled. In order to\n * enable scroll again, we store the previous value of the 'overflow-y' for\n * every ancestor in a closure and reset it back.\n *\n * @param {HTMLElement} node Any DOM element.\n */\n\n\nfunction disableScroll(node) {\n var scrollAncestorsOverflowY = getScrollAncestorsOverflowY(node);\n\n var toggle = function toggle(on) {\n return scrollAncestorsOverflowY.forEach(function (overflowY, ancestor) {\n ancestor.style.setProperty('overflow-y', on ? 'hidden' : overflowY);\n });\n };\n\n toggle(true);\n return function () {\n return toggle(false);\n };\n}","var root = require('./_root');\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\nmodule.exports = now;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nmodule.exports = trimmedEndIndex;\n","var trimmedEndIndex = require('./_trimmedEndIndex');\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nmodule.exports = baseTrim;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or 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 a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var baseTrim = require('./_baseTrim'),\n isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","var isObject = require('./isObject'),\n now = require('./now'),\n toNumber = require('./toNumber');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\nmodule.exports = debounce;\n","var debounce = require('./debounce'),\n isObject = require('./isObject');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\nfunction throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n}\n\nmodule.exports = throttle;\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _throttle = _interopRequireDefault(require(\"lodash/throttle\"));\n\nvar _isTouchDevice = _interopRequireDefault(require(\"is-touch-device\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _getInputHeight = _interopRequireDefault(require(\"../utils/getInputHeight\"));\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"../shapes/OpenDirectionShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar FANG_PATH_TOP = \"M0,\".concat(_constants.FANG_HEIGHT_PX, \" \").concat(_constants.FANG_WIDTH_PX, \",\").concat(_constants.FANG_HEIGHT_PX, \" \").concat(_constants.FANG_WIDTH_PX / 2, \",0z\");\nvar FANG_STROKE_TOP = \"M0,\".concat(_constants.FANG_HEIGHT_PX, \" \").concat(_constants.FANG_WIDTH_PX / 2, \",0 \").concat(_constants.FANG_WIDTH_PX, \",\").concat(_constants.FANG_HEIGHT_PX);\nvar FANG_PATH_BOTTOM = \"M0,0 \".concat(_constants.FANG_WIDTH_PX, \",0 \").concat(_constants.FANG_WIDTH_PX / 2, \",\").concat(_constants.FANG_HEIGHT_PX, \"z\");\nvar FANG_STROKE_BOTTOM = \"M0,0 \".concat(_constants.FANG_WIDTH_PX / 2, \",\").concat(_constants.FANG_HEIGHT_PX, \" \").concat(_constants.FANG_WIDTH_PX, \",0\");\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n id: _propTypes[\"default\"].string.isRequired,\n placeholder: _propTypes[\"default\"].string,\n displayValue: _propTypes[\"default\"].string,\n ariaLabel: _propTypes[\"default\"].string,\n screenReaderMessage: _propTypes[\"default\"].string,\n focused: _propTypes[\"default\"].bool,\n disabled: _propTypes[\"default\"].bool,\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n openDirection: _OpenDirectionShape[\"default\"],\n showCaret: _propTypes[\"default\"].bool,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n small: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n onChange: _propTypes[\"default\"].func,\n onFocus: _propTypes[\"default\"].func,\n onKeyDownShiftTab: _propTypes[\"default\"].func,\n onKeyDownTab: _propTypes[\"default\"].func,\n onKeyDownArrowDown: _propTypes[\"default\"].func,\n onKeyDownQuestionMark: _propTypes[\"default\"].func,\n // accessibility\n isFocused: _propTypes[\"default\"].bool // describes actual DOM focus\n\n})) : {};\nvar defaultProps = {\n placeholder: 'Select Date',\n displayValue: '',\n ariaLabel: undefined,\n screenReaderMessage: '',\n focused: false,\n disabled: false,\n required: false,\n readOnly: null,\n openDirection: _constants.OPEN_DOWN,\n showCaret: false,\n verticalSpacing: _constants.DEFAULT_VERTICAL_SPACING,\n small: false,\n block: false,\n regular: false,\n onChange: function onChange() {},\n onFocus: function onFocus() {},\n onKeyDownShiftTab: function onKeyDownShiftTab() {},\n onKeyDownTab: function onKeyDownTab() {},\n onKeyDownArrowDown: function onKeyDownArrowDown() {},\n onKeyDownQuestionMark: function onKeyDownQuestionMark() {},\n // accessibility\n isFocused: false\n};\n\nvar DateInput =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DateInput, _ref);\n var _proto = DateInput.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DateInput(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.state = {\n dateString: '',\n isTouchDevice: false\n };\n _this.onChange = _this.onChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onKeyDown = _this.onKeyDown.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setInputRef = _this.setInputRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.throttledKeyDown = (0, _throttle[\"default\"])(_this.onFinalKeyDown, 300, {\n trailing: false\n });\n return _this;\n }\n\n _proto.componentDidMount = function componentDidMount() {\n this.setState({\n isTouchDevice: (0, _isTouchDevice[\"default\"])()\n });\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var dateString = this.state.dateString;\n\n if (dateString && nextProps.displayValue) {\n this.setState({\n dateString: ''\n });\n }\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var _this$props = this.props,\n focused = _this$props.focused,\n isFocused = _this$props.isFocused;\n if (prevProps.focused === focused && prevProps.isFocused === isFocused) return;\n\n if (focused && isFocused) {\n this.inputRef.focus();\n }\n };\n\n _proto.onChange = function onChange(e) {\n var _this$props2 = this.props,\n onChange = _this$props2.onChange,\n onKeyDownQuestionMark = _this$props2.onKeyDownQuestionMark;\n var dateString = e.target.value; // In Safari, onKeyDown does not consistently fire ahead of onChange. As a result, we need to\n // special case the `?` key so that it always triggers the appropriate callback, instead of\n // modifying the input value\n\n if (dateString[dateString.length - 1] === '?') {\n onKeyDownQuestionMark(e);\n } else {\n this.setState({\n dateString: dateString\n }, function () {\n return onChange(dateString);\n });\n }\n };\n\n _proto.onKeyDown = function onKeyDown(e) {\n e.stopPropagation();\n\n if (!_constants.MODIFIER_KEY_NAMES.has(e.key)) {\n this.throttledKeyDown(e);\n }\n };\n\n _proto.onFinalKeyDown = function onFinalKeyDown(e) {\n var _this$props3 = this.props,\n onKeyDownShiftTab = _this$props3.onKeyDownShiftTab,\n onKeyDownTab = _this$props3.onKeyDownTab,\n onKeyDownArrowDown = _this$props3.onKeyDownArrowDown,\n onKeyDownQuestionMark = _this$props3.onKeyDownQuestionMark;\n var key = e.key;\n\n if (key === 'Tab') {\n if (e.shiftKey) {\n onKeyDownShiftTab(e);\n } else {\n onKeyDownTab(e);\n }\n } else if (key === 'ArrowDown') {\n onKeyDownArrowDown(e);\n } else if (key === '?') {\n e.preventDefault();\n onKeyDownQuestionMark(e);\n }\n };\n\n _proto.setInputRef = function setInputRef(ref) {\n this.inputRef = ref;\n };\n\n _proto.render = function render() {\n var _this$state = this.state,\n dateString = _this$state.dateString,\n isTouch = _this$state.isTouchDevice;\n var _this$props4 = this.props,\n id = _this$props4.id,\n placeholder = _this$props4.placeholder,\n ariaLabel = _this$props4.ariaLabel,\n displayValue = _this$props4.displayValue,\n screenReaderMessage = _this$props4.screenReaderMessage,\n focused = _this$props4.focused,\n showCaret = _this$props4.showCaret,\n onFocus = _this$props4.onFocus,\n disabled = _this$props4.disabled,\n required = _this$props4.required,\n readOnly = _this$props4.readOnly,\n openDirection = _this$props4.openDirection,\n verticalSpacing = _this$props4.verticalSpacing,\n small = _this$props4.small,\n regular = _this$props4.regular,\n block = _this$props4.block,\n styles = _this$props4.styles,\n reactDates = _this$props4.theme.reactDates;\n var value = dateString || displayValue || '';\n var screenReaderMessageId = \"DateInput__screen-reader-message-\".concat(id);\n var withFang = showCaret && focused;\n var inputHeight = (0, _getInputHeight[\"default\"])(reactDates, small);\n return _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.DateInput, small && styles.DateInput__small, block && styles.DateInput__block, withFang && styles.DateInput__withFang, disabled && styles.DateInput__disabled, withFang && openDirection === _constants.OPEN_DOWN && styles.DateInput__openDown, withFang && openDirection === _constants.OPEN_UP && styles.DateInput__openUp), _react[\"default\"].createElement(\"input\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateInput_input, small && styles.DateInput_input__small, regular && styles.DateInput_input__regular, readOnly && styles.DateInput_input__readOnly, focused && styles.DateInput_input__focused, disabled && styles.DateInput_input__disabled), {\n \"aria-label\": ariaLabel === undefined ? placeholder : ariaLabel,\n type: \"text\",\n id: id,\n name: id,\n ref: this.setInputRef,\n value: value,\n onChange: this.onChange,\n onKeyDown: this.onKeyDown,\n onFocus: onFocus,\n placeholder: placeholder,\n autoComplete: \"off\",\n disabled: disabled,\n readOnly: typeof readOnly === 'boolean' ? readOnly : isTouch,\n required: required,\n \"aria-describedby\": screenReaderMessage && screenReaderMessageId\n })), withFang && _react[\"default\"].createElement(\"svg\", (0, _extends2[\"default\"])({\n role: \"presentation\",\n focusable: \"false\"\n }, (0, _reactWithStyles.css)(styles.DateInput_fang, openDirection === _constants.OPEN_DOWN && {\n top: inputHeight + verticalSpacing - _constants.FANG_HEIGHT_PX - 1\n }, openDirection === _constants.OPEN_UP && {\n bottom: inputHeight + verticalSpacing - _constants.FANG_HEIGHT_PX - 1\n })), _react[\"default\"].createElement(\"path\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateInput_fangShape), {\n d: openDirection === _constants.OPEN_DOWN ? FANG_PATH_TOP : FANG_PATH_BOTTOM\n })), _react[\"default\"].createElement(\"path\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateInput_fangStroke), {\n d: openDirection === _constants.OPEN_DOWN ? FANG_STROKE_TOP : FANG_STROKE_BOTTOM\n }))), screenReaderMessage && _react[\"default\"].createElement(\"p\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateInput_screenReaderMessage), {\n id: screenReaderMessageId\n }), screenReaderMessage));\n };\n\n return DateInput;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nDateInput.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDateInput.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n border = _ref2$reactDates.border,\n color = _ref2$reactDates.color,\n sizing = _ref2$reactDates.sizing,\n spacing = _ref2$reactDates.spacing,\n font = _ref2$reactDates.font,\n zIndex = _ref2$reactDates.zIndex;\n return {\n DateInput: {\n margin: 0,\n padding: spacing.inputPadding,\n background: color.background,\n position: 'relative',\n display: 'inline-block',\n width: sizing.inputWidth,\n verticalAlign: 'middle'\n },\n DateInput__small: {\n width: sizing.inputWidth_small\n },\n DateInput__block: {\n width: '100%'\n },\n DateInput__disabled: {\n background: color.disabled,\n color: color.textDisabled\n },\n DateInput_input: {\n fontWeight: font.input.weight,\n fontSize: font.input.size,\n lineHeight: font.input.lineHeight,\n color: color.text,\n backgroundColor: color.background,\n width: '100%',\n padding: \"\".concat(spacing.displayTextPaddingVertical, \"px \").concat(spacing.displayTextPaddingHorizontal, \"px\"),\n paddingTop: spacing.displayTextPaddingTop,\n paddingBottom: spacing.displayTextPaddingBottom,\n paddingLeft: (0, _noflip[\"default\"])(spacing.displayTextPaddingLeft),\n paddingRight: (0, _noflip[\"default\"])(spacing.displayTextPaddingRight),\n border: border.input.border,\n borderTop: border.input.borderTop,\n borderRight: (0, _noflip[\"default\"])(border.input.borderRight),\n borderBottom: border.input.borderBottom,\n borderLeft: (0, _noflip[\"default\"])(border.input.borderLeft),\n borderRadius: border.input.borderRadius\n },\n DateInput_input__small: {\n fontSize: font.input.size_small,\n lineHeight: font.input.lineHeight_small,\n letterSpacing: font.input.letterSpacing_small,\n padding: \"\".concat(spacing.displayTextPaddingVertical_small, \"px \").concat(spacing.displayTextPaddingHorizontal_small, \"px\"),\n paddingTop: spacing.displayTextPaddingTop_small,\n paddingBottom: spacing.displayTextPaddingBottom_small,\n paddingLeft: (0, _noflip[\"default\"])(spacing.displayTextPaddingLeft_small),\n paddingRight: (0, _noflip[\"default\"])(spacing.displayTextPaddingRight_small)\n },\n DateInput_input__regular: {\n fontWeight: 'auto'\n },\n DateInput_input__readOnly: {\n userSelect: 'none'\n },\n DateInput_input__focused: {\n outline: border.input.outlineFocused,\n background: color.backgroundFocused,\n border: border.input.borderFocused,\n borderTop: border.input.borderTopFocused,\n borderRight: (0, _noflip[\"default\"])(border.input.borderRightFocused),\n borderBottom: border.input.borderBottomFocused,\n borderLeft: (0, _noflip[\"default\"])(border.input.borderLeftFocused)\n },\n DateInput_input__disabled: {\n background: color.disabled,\n fontStyle: font.input.styleDisabled\n },\n DateInput_screenReaderMessage: {\n border: 0,\n clip: 'rect(0, 0, 0, 0)',\n height: 1,\n margin: -1,\n overflow: 'hidden',\n padding: 0,\n position: 'absolute',\n width: 1\n },\n DateInput_fang: {\n position: 'absolute',\n width: _constants.FANG_WIDTH_PX,\n height: _constants.FANG_HEIGHT_PX,\n left: 22,\n // TODO: should be noflip wrapped and handled by an isRTL prop\n zIndex: zIndex + 2\n },\n DateInput_fangShape: {\n fill: color.background\n },\n DateInput_fangStroke: {\n stroke: color.core.border,\n fill: 'transparent'\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(DateInput);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar RightArrow = function RightArrow(props) {\n return _react[\"default\"].createElement(\"svg\", props, _react[\"default\"].createElement(\"path\", {\n d: \"M694 242l249 250c12 11 12 21 1 32L694 773c-5 5-10 7-16 7s-11-2-16-7c-11-11-11-21 0-32l210-210H68c-13 0-23-10-23-23s10-23 23-23h806L662 275c-21-22 11-54 32-33z\"\n }));\n};\n\nRightArrow.defaultProps = {\n focusable: \"false\",\n viewBox: \"0 0 1000 1000\"\n};\nvar _default = RightArrow;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar LeftArrow = function LeftArrow(props) {\n return _react[\"default\"].createElement(\"svg\", props, _react[\"default\"].createElement(\"path\", {\n d: \"M336 275L126 485h806c13 0 23 10 23 23s-10 23-23 23H126l210 210c11 11 11 21 0 32-5 5-10 7-16 7s-11-2-16-7L55 524c-11-11-11-21 0-32l249-249c21-22 53 10 32 32z\"\n }));\n};\n\nLeftArrow.defaultProps = {\n focusable: \"false\",\n viewBox: \"0 0 1000 1000\"\n};\nvar _default = LeftArrow;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar CloseButton = function CloseButton(props) {\n return _react[\"default\"].createElement(\"svg\", props, _react[\"default\"].createElement(\"path\", {\n fillRule: \"evenodd\",\n d: \"M11.53.47a.75.75 0 0 0-1.061 0l-4.47 4.47L1.529.47A.75.75 0 1 0 .468 1.531l4.47 4.47-4.47 4.47a.75.75 0 1 0 1.061 1.061l4.47-4.47 4.47 4.47a.75.75 0 1 0 1.061-1.061l-4.47-4.47 4.47-4.47a.75.75 0 0 0 0-1.061z\"\n }));\n};\n\nCloseButton.defaultProps = {\n focusable: \"false\",\n viewBox: \"0 0 12 12\"\n};\nvar _default = CloseButton;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar CalendarIcon = function CalendarIcon(props) {\n return _react[\"default\"].createElement(\"svg\", props, _react[\"default\"].createElement(\"path\", {\n d: \"m107 1393h241v-241h-241zm295 0h268v-241h-268zm-295-295h241v-268h-241zm295 0h268v-268h-268zm-295-321h241v-241h-241zm616 616h268v-241h-268zm-321-616h268v-241h-268zm643 616h241v-241h-241zm-322-295h268v-268h-268zm-294-723v-241c0-7-3-14-8-19-6-5-12-8-19-8h-54c-7 0-13 3-19 8-5 5-8 12-8 19v241c0 7 3 14 8 19 6 5 12 8 19 8h54c7 0 13-3 19-8 5-5 8-12 8-19zm616 723h241v-268h-241zm-322-321h268v-241h-268zm322 0h241v-241h-241zm27-402v-241c0-7-3-14-8-19-6-5-12-8-19-8h-54c-7 0-13 3-19 8-5 5-8 12-8 19v241c0 7 3 14 8 19 6 5 12 8 19 8h54c7 0 13-3 19-8 5-5 8-12 8-19zm321-54v1072c0 29-11 54-32 75s-46 32-75 32h-1179c-29 0-54-11-75-32s-32-46-32-75v-1072c0-29 11-54 32-75s46-32 75-32h107v-80c0-37 13-68 40-95s57-39 94-39h54c37 0 68 13 95 39 26 26 39 58 39 95v80h321v-80c0-37 13-69 40-95 26-26 57-39 94-39h54c37 0 68 13 94 39s40 58 40 95v80h107c29 0 54 11 75 32s32 46 32 75z\"\n }));\n};\n\nCalendarIcon.defaultProps = {\n focusable: \"false\",\n viewBox: \"0 0 1393.1 1500\"\n};\nvar _default = CalendarIcon;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"../shapes/OpenDirectionShape\"));\n\nvar _DateInput = _interopRequireDefault(require(\"./DateInput\"));\n\nvar _IconPositionShape = _interopRequireDefault(require(\"../shapes/IconPositionShape\"));\n\nvar _DisabledShape = _interopRequireDefault(require(\"../shapes/DisabledShape\"));\n\nvar _RightArrow = _interopRequireDefault(require(\"./RightArrow\"));\n\nvar _LeftArrow = _interopRequireDefault(require(\"./LeftArrow\"));\n\nvar _CloseButton = _interopRequireDefault(require(\"./CloseButton\"));\n\nvar _CalendarIcon = _interopRequireDefault(require(\"./CalendarIcon\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n children: _propTypes[\"default\"].node,\n startDateId: _propTypes[\"default\"].string,\n startDatePlaceholderText: _propTypes[\"default\"].string,\n startDateAriaLabel: _propTypes[\"default\"].string,\n screenReaderMessage: _propTypes[\"default\"].string,\n endDateId: _propTypes[\"default\"].string,\n endDatePlaceholderText: _propTypes[\"default\"].string,\n endDateAriaLabel: _propTypes[\"default\"].string,\n onStartDateFocus: _propTypes[\"default\"].func,\n onEndDateFocus: _propTypes[\"default\"].func,\n onStartDateChange: _propTypes[\"default\"].func,\n onEndDateChange: _propTypes[\"default\"].func,\n onStartDateShiftTab: _propTypes[\"default\"].func,\n onEndDateTab: _propTypes[\"default\"].func,\n onClearDates: _propTypes[\"default\"].func,\n onKeyDownArrowDown: _propTypes[\"default\"].func,\n onKeyDownQuestionMark: _propTypes[\"default\"].func,\n startDate: _propTypes[\"default\"].string,\n endDate: _propTypes[\"default\"].string,\n isStartDateFocused: _propTypes[\"default\"].bool,\n isEndDateFocused: _propTypes[\"default\"].bool,\n showClearDates: _propTypes[\"default\"].bool,\n disabled: _DisabledShape[\"default\"],\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n openDirection: _OpenDirectionShape[\"default\"],\n showCaret: _propTypes[\"default\"].bool,\n showDefaultInputIcon: _propTypes[\"default\"].bool,\n inputIconPosition: _IconPositionShape[\"default\"],\n customInputIcon: _propTypes[\"default\"].node,\n customArrowIcon: _propTypes[\"default\"].node,\n customCloseIcon: _propTypes[\"default\"].node,\n noBorder: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n small: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n // accessibility\n isFocused: _propTypes[\"default\"].bool,\n // describes actual DOM focus\n // i18n\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DateRangePickerInputPhrases)),\n isRTL: _propTypes[\"default\"].bool\n})) : {};\nvar defaultProps = {\n children: null,\n startDateId: _constants.START_DATE,\n endDateId: _constants.END_DATE,\n startDatePlaceholderText: 'Start Date',\n endDatePlaceholderText: 'End Date',\n startDateAriaLabel: undefined,\n endDateAriaLabel: undefined,\n screenReaderMessage: '',\n onStartDateFocus: function onStartDateFocus() {},\n onEndDateFocus: function onEndDateFocus() {},\n onStartDateChange: function onStartDateChange() {},\n onEndDateChange: function onEndDateChange() {},\n onStartDateShiftTab: function onStartDateShiftTab() {},\n onEndDateTab: function onEndDateTab() {},\n onClearDates: function onClearDates() {},\n onKeyDownArrowDown: function onKeyDownArrowDown() {},\n onKeyDownQuestionMark: function onKeyDownQuestionMark() {},\n startDate: '',\n endDate: '',\n isStartDateFocused: false,\n isEndDateFocused: false,\n showClearDates: false,\n disabled: false,\n required: false,\n readOnly: false,\n openDirection: _constants.OPEN_DOWN,\n showCaret: false,\n showDefaultInputIcon: false,\n inputIconPosition: _constants.ICON_BEFORE_POSITION,\n customInputIcon: null,\n customArrowIcon: null,\n customCloseIcon: null,\n noBorder: false,\n block: false,\n small: false,\n regular: false,\n verticalSpacing: undefined,\n // accessibility\n isFocused: false,\n // i18n\n phrases: _defaultPhrases.DateRangePickerInputPhrases,\n isRTL: false\n};\n\nfunction DateRangePickerInput(_ref) {\n var children = _ref.children,\n startDate = _ref.startDate,\n startDateId = _ref.startDateId,\n startDatePlaceholderText = _ref.startDatePlaceholderText,\n screenReaderMessage = _ref.screenReaderMessage,\n isStartDateFocused = _ref.isStartDateFocused,\n onStartDateChange = _ref.onStartDateChange,\n onStartDateFocus = _ref.onStartDateFocus,\n onStartDateShiftTab = _ref.onStartDateShiftTab,\n startDateAriaLabel = _ref.startDateAriaLabel,\n endDate = _ref.endDate,\n endDateId = _ref.endDateId,\n endDatePlaceholderText = _ref.endDatePlaceholderText,\n isEndDateFocused = _ref.isEndDateFocused,\n onEndDateChange = _ref.onEndDateChange,\n onEndDateFocus = _ref.onEndDateFocus,\n onEndDateTab = _ref.onEndDateTab,\n endDateAriaLabel = _ref.endDateAriaLabel,\n onKeyDownArrowDown = _ref.onKeyDownArrowDown,\n onKeyDownQuestionMark = _ref.onKeyDownQuestionMark,\n onClearDates = _ref.onClearDates,\n showClearDates = _ref.showClearDates,\n disabled = _ref.disabled,\n required = _ref.required,\n readOnly = _ref.readOnly,\n showCaret = _ref.showCaret,\n openDirection = _ref.openDirection,\n showDefaultInputIcon = _ref.showDefaultInputIcon,\n inputIconPosition = _ref.inputIconPosition,\n customInputIcon = _ref.customInputIcon,\n customArrowIcon = _ref.customArrowIcon,\n customCloseIcon = _ref.customCloseIcon,\n isFocused = _ref.isFocused,\n phrases = _ref.phrases,\n isRTL = _ref.isRTL,\n noBorder = _ref.noBorder,\n block = _ref.block,\n verticalSpacing = _ref.verticalSpacing,\n small = _ref.small,\n regular = _ref.regular,\n styles = _ref.styles;\n\n var calendarIcon = customInputIcon || _react[\"default\"].createElement(_CalendarIcon[\"default\"], (0, _reactWithStyles.css)(styles.DateRangePickerInput_calendarIcon_svg));\n\n var arrowIcon = customArrowIcon || _react[\"default\"].createElement(_RightArrow[\"default\"], (0, _reactWithStyles.css)(styles.DateRangePickerInput_arrow_svg));\n\n if (isRTL) arrowIcon = _react[\"default\"].createElement(_LeftArrow[\"default\"], (0, _reactWithStyles.css)(styles.DateRangePickerInput_arrow_svg));\n if (small) arrowIcon = '-';\n\n var closeIcon = customCloseIcon || _react[\"default\"].createElement(_CloseButton[\"default\"], (0, _reactWithStyles.css)(styles.DateRangePickerInput_clearDates_svg, small && styles.DateRangePickerInput_clearDates_svg__small));\n\n var screenReaderStartDateText = screenReaderMessage || phrases.keyboardForwardNavigationInstructions;\n var screenReaderEndDateText = screenReaderMessage || phrases.keyboardBackwardNavigationInstructions;\n\n var inputIcon = (showDefaultInputIcon || customInputIcon !== null) && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateRangePickerInput_calendarIcon), {\n type: \"button\",\n disabled: disabled,\n \"aria-label\": phrases.focusStartDate,\n onClick: onKeyDownArrowDown\n }), calendarIcon);\n\n var startDateDisabled = disabled === _constants.START_DATE || disabled === true;\n var endDateDisabled = disabled === _constants.END_DATE || disabled === true;\n return _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.DateRangePickerInput, disabled && styles.DateRangePickerInput__disabled, isRTL && styles.DateRangePickerInput__rtl, !noBorder && styles.DateRangePickerInput__withBorder, block && styles.DateRangePickerInput__block, showClearDates && styles.DateRangePickerInput__showClearDates), inputIconPosition === _constants.ICON_BEFORE_POSITION && inputIcon, _react[\"default\"].createElement(_DateInput[\"default\"], {\n id: startDateId,\n placeholder: startDatePlaceholderText,\n ariaLabel: startDateAriaLabel,\n displayValue: startDate,\n screenReaderMessage: screenReaderStartDateText,\n focused: isStartDateFocused,\n isFocused: isFocused,\n disabled: startDateDisabled,\n required: required,\n readOnly: readOnly,\n showCaret: showCaret,\n openDirection: openDirection,\n onChange: onStartDateChange,\n onFocus: onStartDateFocus,\n onKeyDownShiftTab: onStartDateShiftTab,\n onKeyDownArrowDown: onKeyDownArrowDown,\n onKeyDownQuestionMark: onKeyDownQuestionMark,\n verticalSpacing: verticalSpacing,\n small: small,\n regular: regular\n }), children, _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateRangePickerInput_arrow), {\n \"aria-hidden\": \"true\",\n role: \"presentation\"\n }), arrowIcon), _react[\"default\"].createElement(_DateInput[\"default\"], {\n id: endDateId,\n placeholder: endDatePlaceholderText,\n ariaLabel: endDateAriaLabel,\n displayValue: endDate,\n screenReaderMessage: screenReaderEndDateText,\n focused: isEndDateFocused,\n isFocused: isFocused,\n disabled: endDateDisabled,\n required: required,\n readOnly: readOnly,\n showCaret: showCaret,\n openDirection: openDirection,\n onChange: onEndDateChange,\n onFocus: onEndDateFocus,\n onKeyDownArrowDown: onKeyDownArrowDown,\n onKeyDownQuestionMark: onKeyDownQuestionMark,\n onKeyDownTab: onEndDateTab,\n verticalSpacing: verticalSpacing,\n small: small,\n regular: regular\n }), showClearDates && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({\n type: \"button\",\n \"aria-label\": phrases.clearDates\n }, (0, _reactWithStyles.css)(styles.DateRangePickerInput_clearDates, small && styles.DateRangePickerInput_clearDates__small, !customCloseIcon && styles.DateRangePickerInput_clearDates_default, !(startDate || endDate) && styles.DateRangePickerInput_clearDates__hide), {\n onClick: onClearDates,\n disabled: disabled\n }), closeIcon), inputIconPosition === _constants.ICON_AFTER_POSITION && inputIcon);\n}\n\nDateRangePickerInput.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDateRangePickerInput.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n border = _ref2$reactDates.border,\n color = _ref2$reactDates.color,\n sizing = _ref2$reactDates.sizing;\n return {\n DateRangePickerInput: {\n backgroundColor: color.background,\n display: 'inline-block'\n },\n DateRangePickerInput__disabled: {\n background: color.disabled\n },\n DateRangePickerInput__withBorder: {\n borderColor: color.border,\n borderWidth: border.pickerInput.borderWidth,\n borderStyle: border.pickerInput.borderStyle,\n borderRadius: border.pickerInput.borderRadius\n },\n DateRangePickerInput__rtl: {\n direction: (0, _noflip[\"default\"])('rtl')\n },\n DateRangePickerInput__block: {\n display: 'block'\n },\n DateRangePickerInput__showClearDates: {\n paddingRight: 30 // TODO: should be noflip wrapped and handled by an isRTL prop\n\n },\n DateRangePickerInput_arrow: {\n display: 'inline-block',\n verticalAlign: 'middle',\n color: color.text\n },\n DateRangePickerInput_arrow_svg: {\n verticalAlign: 'middle',\n fill: color.text,\n height: sizing.arrowWidth,\n width: sizing.arrowWidth\n },\n DateRangePickerInput_clearDates: {\n background: 'none',\n border: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n cursor: 'pointer',\n padding: 10,\n margin: '0 10px 0 5px',\n // TODO: should be noflip wrapped and handled by an isRTL prop\n position: 'absolute',\n right: 0,\n // TODO: should be noflip wrapped and handled by an isRTL prop\n top: '50%',\n transform: 'translateY(-50%)'\n },\n DateRangePickerInput_clearDates__small: {\n padding: 6\n },\n DateRangePickerInput_clearDates_default: {\n ':focus': {\n background: color.core.border,\n borderRadius: '50%'\n },\n ':hover': {\n background: color.core.border,\n borderRadius: '50%'\n }\n },\n DateRangePickerInput_clearDates__hide: {\n visibility: 'hidden'\n },\n DateRangePickerInput_clearDates_svg: {\n fill: color.core.grayLight,\n height: 12,\n width: 15,\n verticalAlign: 'middle'\n },\n DateRangePickerInput_clearDates_svg__small: {\n height: 9\n },\n DateRangePickerInput_calendarIcon: {\n background: 'none',\n border: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n cursor: 'pointer',\n display: 'inline-block',\n verticalAlign: 'middle',\n padding: 10,\n margin: '0 5px 0 10px' // TODO: should be noflip wrapped and handled by an isRTL prop\n\n },\n DateRangePickerInput_calendarIcon_svg: {\n fill: color.core.grayLight,\n height: 15,\n width: 14,\n verticalAlign: 'middle'\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(DateRangePickerInput);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = toLocalizedDateString;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _toMomentObject = _interopRequireDefault(require(\"./toMomentObject\"));\n\nvar _constants = require(\"../constants\");\n\nfunction toLocalizedDateString(date, currentFormat) {\n var dateObj = _moment[\"default\"].isMoment(date) ? date : (0, _toMomentObject[\"default\"])(date, currentFormat);\n if (!dateObj) return null;\n return dateObj.format(_constants.DISPLAY_FORMAT);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"../shapes/OpenDirectionShape\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _DateRangePickerInput = _interopRequireDefault(require(\"./DateRangePickerInput\"));\n\nvar _IconPositionShape = _interopRequireDefault(require(\"../shapes/IconPositionShape\"));\n\nvar _DisabledShape = _interopRequireDefault(require(\"../shapes/DisabledShape\"));\n\nvar _toMomentObject = _interopRequireDefault(require(\"../utils/toMomentObject\"));\n\nvar _toLocalizedDateString = _interopRequireDefault(require(\"../utils/toLocalizedDateString\"));\n\nvar _isInclusivelyAfterDay = _interopRequireDefault(require(\"../utils/isInclusivelyAfterDay\"));\n\nvar _isBeforeDay = _interopRequireDefault(require(\"../utils/isBeforeDay\"));\n\nvar _constants = require(\"../constants\");\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)({\n children: _propTypes[\"default\"].node,\n startDate: _reactMomentProptypes[\"default\"].momentObj,\n startDateId: _propTypes[\"default\"].string,\n startDatePlaceholderText: _propTypes[\"default\"].string,\n isStartDateFocused: _propTypes[\"default\"].bool,\n startDateAriaLabel: _propTypes[\"default\"].string,\n endDate: _reactMomentProptypes[\"default\"].momentObj,\n endDateId: _propTypes[\"default\"].string,\n endDatePlaceholderText: _propTypes[\"default\"].string,\n isEndDateFocused: _propTypes[\"default\"].bool,\n endDateAriaLabel: _propTypes[\"default\"].string,\n screenReaderMessage: _propTypes[\"default\"].string,\n showClearDates: _propTypes[\"default\"].bool,\n showCaret: _propTypes[\"default\"].bool,\n showDefaultInputIcon: _propTypes[\"default\"].bool,\n inputIconPosition: _IconPositionShape[\"default\"],\n disabled: _DisabledShape[\"default\"],\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n openDirection: _OpenDirectionShape[\"default\"],\n noBorder: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n small: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n keepOpenOnDateSelect: _propTypes[\"default\"].bool,\n reopenPickerOnClearDates: _propTypes[\"default\"].bool,\n withFullScreenPortal: _propTypes[\"default\"].bool,\n minimumNights: _airbnbPropTypes.nonNegativeInteger,\n isOutsideRange: _propTypes[\"default\"].func,\n displayFormat: _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].string, _propTypes[\"default\"].func]),\n onFocusChange: _propTypes[\"default\"].func,\n onClose: _propTypes[\"default\"].func,\n onDatesChange: _propTypes[\"default\"].func,\n onKeyDownArrowDown: _propTypes[\"default\"].func,\n onKeyDownQuestionMark: _propTypes[\"default\"].func,\n customInputIcon: _propTypes[\"default\"].node,\n customArrowIcon: _propTypes[\"default\"].node,\n customCloseIcon: _propTypes[\"default\"].node,\n // accessibility\n isFocused: _propTypes[\"default\"].bool,\n // i18n\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DateRangePickerInputPhrases)),\n isRTL: _propTypes[\"default\"].bool\n}) : {};\nvar defaultProps = {\n children: null,\n startDate: null,\n startDateId: _constants.START_DATE,\n startDatePlaceholderText: 'Start Date',\n isStartDateFocused: false,\n startDateAriaLabel: undefined,\n endDate: null,\n endDateId: _constants.END_DATE,\n endDatePlaceholderText: 'End Date',\n isEndDateFocused: false,\n endDateAriaLabel: undefined,\n screenReaderMessage: '',\n showClearDates: false,\n showCaret: false,\n showDefaultInputIcon: false,\n inputIconPosition: _constants.ICON_BEFORE_POSITION,\n disabled: false,\n required: false,\n readOnly: false,\n openDirection: _constants.OPEN_DOWN,\n noBorder: false,\n block: false,\n small: false,\n regular: false,\n verticalSpacing: undefined,\n keepOpenOnDateSelect: false,\n reopenPickerOnClearDates: false,\n withFullScreenPortal: false,\n minimumNights: 1,\n isOutsideRange: function isOutsideRange(day) {\n return !(0, _isInclusivelyAfterDay[\"default\"])(day, (0, _moment[\"default\"])());\n },\n displayFormat: function displayFormat() {\n return _moment[\"default\"].localeData().longDateFormat('L');\n },\n onFocusChange: function onFocusChange() {},\n onClose: function onClose() {},\n onDatesChange: function onDatesChange() {},\n onKeyDownArrowDown: function onKeyDownArrowDown() {},\n onKeyDownQuestionMark: function onKeyDownQuestionMark() {},\n customInputIcon: null,\n customArrowIcon: null,\n customCloseIcon: null,\n // accessibility\n isFocused: false,\n // i18n\n phrases: _defaultPhrases.DateRangePickerInputPhrases,\n isRTL: false\n};\n\nvar DateRangePickerInputController =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DateRangePickerInputController, _ref);\n var _proto = DateRangePickerInputController.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DateRangePickerInputController(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.onClearFocus = _this.onClearFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onStartDateChange = _this.onStartDateChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onStartDateFocus = _this.onStartDateFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onEndDateChange = _this.onEndDateChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onEndDateFocus = _this.onEndDateFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.clearDates = _this.clearDates.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.onClearFocus = function onClearFocus() {\n var _this$props = this.props,\n onFocusChange = _this$props.onFocusChange,\n onClose = _this$props.onClose,\n startDate = _this$props.startDate,\n endDate = _this$props.endDate;\n onFocusChange(null);\n onClose({\n startDate: startDate,\n endDate: endDate\n });\n };\n\n _proto.onEndDateChange = function onEndDateChange(endDateString) {\n var _this$props2 = this.props,\n startDate = _this$props2.startDate,\n isOutsideRange = _this$props2.isOutsideRange,\n minimumNights = _this$props2.minimumNights,\n keepOpenOnDateSelect = _this$props2.keepOpenOnDateSelect,\n onDatesChange = _this$props2.onDatesChange;\n var endDate = (0, _toMomentObject[\"default\"])(endDateString, this.getDisplayFormat());\n var isEndDateValid = endDate && !isOutsideRange(endDate) && !(startDate && (0, _isBeforeDay[\"default\"])(endDate, startDate.clone().add(minimumNights, 'days')));\n\n if (isEndDateValid) {\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n if (!keepOpenOnDateSelect) this.onClearFocus();\n } else {\n onDatesChange({\n startDate: startDate,\n endDate: null\n });\n }\n };\n\n _proto.onEndDateFocus = function onEndDateFocus() {\n var _this$props3 = this.props,\n startDate = _this$props3.startDate,\n onFocusChange = _this$props3.onFocusChange,\n withFullScreenPortal = _this$props3.withFullScreenPortal,\n disabled = _this$props3.disabled;\n\n if (!startDate && withFullScreenPortal && (!disabled || disabled === _constants.END_DATE)) {\n // When the datepicker is full screen, we never want to focus the end date first\n // because there's no indication that that is the case once the datepicker is open and it\n // might confuse the user\n onFocusChange(_constants.START_DATE);\n } else if (!disabled || disabled === _constants.START_DATE) {\n onFocusChange(_constants.END_DATE);\n }\n };\n\n _proto.onStartDateChange = function onStartDateChange(startDateString) {\n var endDate = this.props.endDate;\n var _this$props4 = this.props,\n isOutsideRange = _this$props4.isOutsideRange,\n minimumNights = _this$props4.minimumNights,\n onDatesChange = _this$props4.onDatesChange,\n onFocusChange = _this$props4.onFocusChange,\n disabled = _this$props4.disabled;\n var startDate = (0, _toMomentObject[\"default\"])(startDateString, this.getDisplayFormat());\n var isEndDateBeforeStartDate = startDate && (0, _isBeforeDay[\"default\"])(endDate, startDate.clone().add(minimumNights, 'days'));\n var isStartDateValid = startDate && !isOutsideRange(startDate) && !(disabled === _constants.END_DATE && isEndDateBeforeStartDate);\n\n if (isStartDateValid) {\n if (isEndDateBeforeStartDate) {\n endDate = null;\n }\n\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n onFocusChange(_constants.END_DATE);\n } else {\n onDatesChange({\n startDate: null,\n endDate: endDate\n });\n }\n };\n\n _proto.onStartDateFocus = function onStartDateFocus() {\n var _this$props5 = this.props,\n disabled = _this$props5.disabled,\n onFocusChange = _this$props5.onFocusChange;\n\n if (!disabled || disabled === _constants.END_DATE) {\n onFocusChange(_constants.START_DATE);\n }\n };\n\n _proto.getDisplayFormat = function getDisplayFormat() {\n var displayFormat = this.props.displayFormat;\n return typeof displayFormat === 'string' ? displayFormat : displayFormat();\n };\n\n _proto.getDateString = function getDateString(date) {\n var displayFormat = this.getDisplayFormat();\n\n if (date && displayFormat) {\n return date && date.format(displayFormat);\n }\n\n return (0, _toLocalizedDateString[\"default\"])(date);\n };\n\n _proto.clearDates = function clearDates() {\n var _this$props6 = this.props,\n onDatesChange = _this$props6.onDatesChange,\n reopenPickerOnClearDates = _this$props6.reopenPickerOnClearDates,\n onFocusChange = _this$props6.onFocusChange;\n onDatesChange({\n startDate: null,\n endDate: null\n });\n\n if (reopenPickerOnClearDates) {\n onFocusChange(_constants.START_DATE);\n }\n };\n\n _proto.render = function render() {\n var _this$props7 = this.props,\n children = _this$props7.children,\n startDate = _this$props7.startDate,\n startDateId = _this$props7.startDateId,\n startDatePlaceholderText = _this$props7.startDatePlaceholderText,\n isStartDateFocused = _this$props7.isStartDateFocused,\n startDateAriaLabel = _this$props7.startDateAriaLabel,\n endDate = _this$props7.endDate,\n endDateId = _this$props7.endDateId,\n endDatePlaceholderText = _this$props7.endDatePlaceholderText,\n endDateAriaLabel = _this$props7.endDateAriaLabel,\n isEndDateFocused = _this$props7.isEndDateFocused,\n screenReaderMessage = _this$props7.screenReaderMessage,\n showClearDates = _this$props7.showClearDates,\n showCaret = _this$props7.showCaret,\n showDefaultInputIcon = _this$props7.showDefaultInputIcon,\n inputIconPosition = _this$props7.inputIconPosition,\n customInputIcon = _this$props7.customInputIcon,\n customArrowIcon = _this$props7.customArrowIcon,\n customCloseIcon = _this$props7.customCloseIcon,\n disabled = _this$props7.disabled,\n required = _this$props7.required,\n readOnly = _this$props7.readOnly,\n openDirection = _this$props7.openDirection,\n isFocused = _this$props7.isFocused,\n phrases = _this$props7.phrases,\n onKeyDownArrowDown = _this$props7.onKeyDownArrowDown,\n onKeyDownQuestionMark = _this$props7.onKeyDownQuestionMark,\n isRTL = _this$props7.isRTL,\n noBorder = _this$props7.noBorder,\n block = _this$props7.block,\n small = _this$props7.small,\n regular = _this$props7.regular,\n verticalSpacing = _this$props7.verticalSpacing;\n var startDateString = this.getDateString(startDate);\n var endDateString = this.getDateString(endDate);\n return _react[\"default\"].createElement(_DateRangePickerInput[\"default\"], {\n startDate: startDateString,\n startDateId: startDateId,\n startDatePlaceholderText: startDatePlaceholderText,\n isStartDateFocused: isStartDateFocused,\n startDateAriaLabel: startDateAriaLabel,\n endDate: endDateString,\n endDateId: endDateId,\n endDatePlaceholderText: endDatePlaceholderText,\n isEndDateFocused: isEndDateFocused,\n endDateAriaLabel: endDateAriaLabel,\n isFocused: isFocused,\n disabled: disabled,\n required: required,\n readOnly: readOnly,\n openDirection: openDirection,\n showCaret: showCaret,\n showDefaultInputIcon: showDefaultInputIcon,\n inputIconPosition: inputIconPosition,\n customInputIcon: customInputIcon,\n customArrowIcon: customArrowIcon,\n customCloseIcon: customCloseIcon,\n phrases: phrases,\n onStartDateChange: this.onStartDateChange,\n onStartDateFocus: this.onStartDateFocus,\n onStartDateShiftTab: this.onClearFocus,\n onEndDateChange: this.onEndDateChange,\n onEndDateFocus: this.onEndDateFocus,\n showClearDates: showClearDates,\n onClearDates: this.clearDates,\n screenReaderMessage: screenReaderMessage,\n onKeyDownArrowDown: onKeyDownArrowDown,\n onKeyDownQuestionMark: onKeyDownQuestionMark,\n isRTL: isRTL,\n noBorder: noBorder,\n block: block,\n small: small,\n regular: regular,\n verticalSpacing: verticalSpacing\n }, children);\n };\n\n return DateRangePickerInputController;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports[\"default\"] = DateRangePickerInputController;\nDateRangePickerInputController.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDateRangePickerInputController.defaultProps = defaultProps;","function _arrayWithHoles(r) {\n if (Array.isArray(r)) return r;\n}\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(r, l) {\n var t = null == r ? null : \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"];\n if (null != t) {\n var e,\n n,\n i,\n u,\n a = [],\n f = !0,\n o = !1;\n try {\n if (i = (t = t.call(r)).next, 0 === l) {\n if (Object(t) !== t) return;\n f = !1;\n } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);\n } catch (r) {\n o = !0, n = r;\n } finally {\n try {\n if (!f && null != t[\"return\"] && (u = t[\"return\"](), Object(u) !== u)) return;\n } finally {\n if (o) throw n;\n }\n }\n return a;\n }\n}\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableRest = require(\"./nonIterableRest.js\");\nfunction _slicedToArray(r, e) {\n return arrayWithHoles(r) || iterableToArrayLimit(r, e) || unsupportedIterableToArray(r, e) || nonIterableRest();\n}\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isNextDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"./isSameDay\"));\n\nfunction isNextDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n var nextDay = (0, _moment[\"default\"])(a).add(1, 'day');\n return (0, _isSameDay[\"default\"])(nextDay, b);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isAfterDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isBeforeDay = _interopRequireDefault(require(\"./isBeforeDay\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"./isSameDay\"));\n\nfunction isAfterDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n return !(0, _isBeforeDay[\"default\"])(a, b) && !(0, _isSameDay[\"default\"])(a, b);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isPreviousDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"./isSameDay\"));\n\nfunction isPreviousDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n var dayBefore = (0, _moment[\"default\"])(a).subtract(1, 'day');\n return (0, _isSameDay[\"default\"])(dayBefore, b);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getVisibleDays;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _toISOMonthString = _interopRequireDefault(require(\"./toISOMonthString\"));\n\nfunction getVisibleDays(month, numberOfMonths, enableOutsideDays, withoutTransitionMonths) {\n if (!_moment[\"default\"].isMoment(month)) return {};\n var visibleDaysByMonth = {};\n var currentMonth = withoutTransitionMonths ? month.clone() : month.clone().subtract(1, 'month');\n\n for (var i = 0; i < (withoutTransitionMonths ? numberOfMonths : numberOfMonths + 2); i += 1) {\n var visibleDays = []; // set utc offset to get correct dates in future (when timezone changes)\n\n var baseDate = currentMonth.clone();\n var firstOfMonth = baseDate.clone().startOf('month').hour(12);\n var lastOfMonth = baseDate.clone().endOf('month').hour(12);\n var currentDay = firstOfMonth.clone(); // days belonging to the previous month\n\n if (enableOutsideDays) {\n for (var j = 0; j < currentDay.weekday(); j += 1) {\n var prevDay = currentDay.clone().subtract(j + 1, 'day');\n visibleDays.unshift(prevDay);\n }\n }\n\n while (currentDay < lastOfMonth) {\n visibleDays.push(currentDay.clone());\n currentDay.add(1, 'day');\n }\n\n if (enableOutsideDays) {\n // weekday() returns the index of the day of the week according to the locale\n // this means if the week starts on Monday, weekday() will return 0 for a Monday date, not 1\n if (currentDay.weekday() !== 0) {\n // days belonging to the next month\n for (var k = currentDay.weekday(), count = 0; k < 7; k += 1, count += 1) {\n var nextDay = currentDay.clone().add(count, 'day');\n visibleDays.push(nextDay);\n }\n }\n }\n\n visibleDaysByMonth[(0, _toISOMonthString[\"default\"])(currentMonth)] = visibleDays;\n currentMonth = currentMonth.clone().add(1, 'month');\n }\n\n return visibleDaysByMonth;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isDayVisible;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isBeforeDay = _interopRequireDefault(require(\"./isBeforeDay\"));\n\nvar _isAfterDay = _interopRequireDefault(require(\"./isAfterDay\"));\n\nvar _toISOMonthString = _interopRequireDefault(require(\"./toISOMonthString\"));\n\nvar startCacheOutsideDays = new Map();\nvar endCacheOutsideDays = new Map();\nvar startCacheInsideDays = new Map();\nvar endCacheInsideDays = new Map();\n\nfunction isDayVisible(day, month, numberOfMonths, enableOutsideDays) {\n if (!_moment[\"default\"].isMoment(day)) return false; // Cloning is a little expensive, so we want to do it as little as possible.\n\n var startKey = (0, _toISOMonthString[\"default\"])(month); // eslint-disable-next-line prefer-template\n\n var endKey = startKey + '+' + numberOfMonths;\n\n if (enableOutsideDays) {\n if (!startCacheOutsideDays.has(startKey)) {\n startCacheOutsideDays.set(startKey, month.clone().startOf('month').startOf('week'));\n }\n\n if ((0, _isBeforeDay[\"default\"])(day, startCacheOutsideDays.get(startKey))) return false;\n\n if (!endCacheOutsideDays.has(endKey)) {\n endCacheOutsideDays.set(endKey, month.clone().endOf('week').add(numberOfMonths - 1, 'months').endOf('month').endOf('week'));\n }\n\n return !(0, _isAfterDay[\"default\"])(day, endCacheOutsideDays.get(endKey));\n } // !enableOutsideDays\n\n\n if (!startCacheInsideDays.has(startKey)) {\n startCacheInsideDays.set(startKey, month.clone().startOf('month'));\n }\n\n if ((0, _isBeforeDay[\"default\"])(day, startCacheInsideDays.get(startKey))) return false;\n\n if (!endCacheInsideDays.has(endKey)) {\n endCacheInsideDays.set(endKey, month.clone().add(numberOfMonths - 1, 'months').endOf('month'));\n }\n\n return !(0, _isAfterDay[\"default\"])(day, endCacheInsideDays.get(endKey));\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getSelectedDateOffset;\n\nvar defaultModifier = function defaultModifier(day) {\n return day;\n};\n\nfunction getSelectedDateOffset(fn, day) {\n var modifier = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : defaultModifier;\n if (!fn) return day;\n return modifier(fn(day.clone()));\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getPreviousMonthMemoLast;\nvar getPreviousMonthMemoKey;\nvar getPreviousMonthMemoValue;\n\nfunction getPreviousMonthMemoLast(month) {\n if (month !== getPreviousMonthMemoKey) {\n getPreviousMonthMemoKey = month;\n getPreviousMonthMemoValue = month.clone().subtract(1, 'month');\n }\n\n return getPreviousMonthMemoValue;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.addModifier = addModifier;\nexports.deleteModifier = deleteModifier;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _isDayVisible = _interopRequireDefault(require(\"./isDayVisible\"));\n\nvar _toISODateString = _interopRequireDefault(require(\"./toISODateString\"));\n\nvar _toISOMonthString = _interopRequireDefault(require(\"./toISOMonthString\"));\n\nvar _getPreviousMonthMemoLast = _interopRequireDefault(require(\"./getPreviousMonthMemoLast\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction addModifier(updatedDays, day, modifier, props, state) {\n var numberOfVisibleMonths = props.numberOfMonths,\n enableOutsideDays = props.enableOutsideDays,\n orientation = props.orientation;\n var firstVisibleMonth = state.currentMonth,\n visibleDays = state.visibleDays;\n var currentMonth = firstVisibleMonth;\n var numberOfMonths = numberOfVisibleMonths;\n\n if (orientation === _constants.VERTICAL_SCROLLABLE) {\n numberOfMonths = Object.keys(visibleDays).length;\n } else {\n currentMonth = (0, _getPreviousMonthMemoLast[\"default\"])(currentMonth);\n numberOfMonths += 2;\n }\n\n if (!day || !(0, _isDayVisible[\"default\"])(day, currentMonth, numberOfMonths, enableOutsideDays)) {\n return updatedDays;\n }\n\n var iso = (0, _toISODateString[\"default\"])(day);\n\n var updatedDaysAfterAddition = _objectSpread({}, updatedDays);\n\n if (enableOutsideDays) {\n var monthsToUpdate = Object.keys(visibleDays).filter(function (monthKey) {\n return Object.keys(visibleDays[monthKey]).indexOf(iso) > -1;\n });\n updatedDaysAfterAddition = monthsToUpdate.reduce(function (acc, monthIso) {\n var month = updatedDays[monthIso] || visibleDays[monthIso];\n\n if (!month[iso] || !month[iso].has(modifier)) {\n var modifiers = new Set(month[iso]);\n modifiers.add(modifier);\n acc[monthIso] = _objectSpread({}, month, (0, _defineProperty2[\"default\"])({}, iso, modifiers));\n }\n\n return acc;\n }, updatedDaysAfterAddition);\n } else {\n var monthIso = (0, _toISOMonthString[\"default\"])(day);\n var month = updatedDays[monthIso] || visibleDays[monthIso] || {};\n\n if (!month[iso] || !month[iso].has(modifier)) {\n var modifiers = new Set(month[iso]);\n modifiers.add(modifier);\n updatedDaysAfterAddition[monthIso] = _objectSpread({}, month, (0, _defineProperty2[\"default\"])({}, iso, modifiers));\n }\n }\n\n return updatedDaysAfterAddition;\n}\n\nfunction deleteModifier(updatedDays, day, modifier, props, state) {\n var numberOfVisibleMonths = props.numberOfMonths,\n enableOutsideDays = props.enableOutsideDays,\n orientation = props.orientation;\n var firstVisibleMonth = state.currentMonth,\n visibleDays = state.visibleDays;\n var currentMonth = firstVisibleMonth;\n var numberOfMonths = numberOfVisibleMonths;\n\n if (orientation === _constants.VERTICAL_SCROLLABLE) {\n numberOfMonths = Object.keys(visibleDays).length;\n } else {\n currentMonth = (0, _getPreviousMonthMemoLast[\"default\"])(currentMonth);\n numberOfMonths += 2;\n }\n\n if (!day || !(0, _isDayVisible[\"default\"])(day, currentMonth, numberOfMonths, enableOutsideDays)) {\n return updatedDays;\n }\n\n var iso = (0, _toISODateString[\"default\"])(day);\n\n var updatedDaysAfterDeletion = _objectSpread({}, updatedDays);\n\n if (enableOutsideDays) {\n var monthsToUpdate = Object.keys(visibleDays).filter(function (monthKey) {\n return Object.keys(visibleDays[monthKey]).indexOf(iso) > -1;\n });\n updatedDaysAfterDeletion = monthsToUpdate.reduce(function (acc, monthIso) {\n var month = updatedDays[monthIso] || visibleDays[monthIso];\n\n if (month[iso] && month[iso].has(modifier)) {\n var modifiers = new Set(month[iso]);\n modifiers[\"delete\"](modifier);\n acc[monthIso] = _objectSpread({}, month, (0, _defineProperty2[\"default\"])({}, iso, modifiers));\n }\n\n return acc;\n }, updatedDaysAfterDeletion);\n } else {\n var monthIso = (0, _toISOMonthString[\"default\"])(day);\n var month = updatedDays[monthIso] || visibleDays[monthIso] || {};\n\n if (month[iso] && month[iso].has(modifier)) {\n var modifiers = new Set(month[iso]);\n modifiers[\"delete\"](modifier);\n updatedDaysAfterDeletion[monthIso] = _objectSpread({}, month, (0, _defineProperty2[\"default\"])({}, iso, modifiers));\n }\n }\n\n return updatedDaysAfterDeletion;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar ChevronUp = function ChevronUp(props) {\n return _react[\"default\"].createElement(\"svg\", props, _react[\"default\"].createElement(\"path\", {\n d: \"M32 713l453-453c11-11 21-11 32 0l453 453c5 5 7 10 7 16 0 13-10 23-22 23-7 0-12-2-16-7L501 309 64 745c-4 5-9 7-15 7-7 0-12-2-17-7-9-11-9-21 0-32z\"\n }));\n};\n\nChevronUp.defaultProps = {\n focusable: \"false\",\n viewBox: \"0 0 1000 1000\"\n};\nvar _default = ChevronUp;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar ChevronDown = function ChevronDown(props) {\n return _react[\"default\"].createElement(\"svg\", props, _react[\"default\"].createElement(\"path\", {\n d: \"M968 289L514 741c-11 11-21 11-32 0L29 289c-4-5-6-11-6-16 0-13 10-23 23-23 6 0 11 2 15 7l437 436 438-436c4-5 9-7 16-7 6 0 11 2 16 7 9 10 9 21 0 32z\"\n }));\n};\n\nChevronDown.defaultProps = {\n focusable: \"false\",\n viewBox: \"0 0 1000 1000\"\n};\nvar _default = ChevronDown;\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _LeftArrow = _interopRequireDefault(require(\"./LeftArrow\"));\n\nvar _RightArrow = _interopRequireDefault(require(\"./RightArrow\"));\n\nvar _ChevronUp = _interopRequireDefault(require(\"./ChevronUp\"));\n\nvar _ChevronDown = _interopRequireDefault(require(\"./ChevronDown\"));\n\nvar _NavPositionShape = _interopRequireDefault(require(\"../shapes/NavPositionShape\"));\n\nvar _ScrollableOrientationShape = _interopRequireDefault(require(\"../shapes/ScrollableOrientationShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n disablePrev: _propTypes[\"default\"].bool,\n disableNext: _propTypes[\"default\"].bool,\n inlineStyles: _propTypes[\"default\"].object,\n isRTL: _propTypes[\"default\"].bool,\n navPosition: _NavPositionShape[\"default\"],\n navPrev: _propTypes[\"default\"].node,\n navNext: _propTypes[\"default\"].node,\n orientation: _ScrollableOrientationShape[\"default\"],\n onPrevMonthClick: _propTypes[\"default\"].func,\n onNextMonthClick: _propTypes[\"default\"].func,\n // internationalization\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DayPickerNavigationPhrases)),\n renderNavPrevButton: _propTypes[\"default\"].func,\n renderNavNextButton: _propTypes[\"default\"].func,\n showNavPrevButton: _propTypes[\"default\"].bool,\n showNavNextButton: _propTypes[\"default\"].bool\n})) : {};\nvar defaultProps = {\n disablePrev: false,\n disableNext: false,\n inlineStyles: null,\n isRTL: false,\n navPosition: _constants.NAV_POSITION_TOP,\n navPrev: null,\n navNext: null,\n orientation: _constants.HORIZONTAL_ORIENTATION,\n onPrevMonthClick: function onPrevMonthClick() {},\n onNextMonthClick: function onNextMonthClick() {},\n // internationalization\n phrases: _defaultPhrases.DayPickerNavigationPhrases,\n renderNavPrevButton: null,\n renderNavNextButton: null,\n showNavPrevButton: true,\n showNavNextButton: true\n};\n\nvar DayPickerNavigation =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DayPickerNavigation, _ref);\n\n function DayPickerNavigation() {\n return _ref.apply(this, arguments) || this;\n }\n\n var _proto = DayPickerNavigation.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n inlineStyles = _this$props.inlineStyles,\n isRTL = _this$props.isRTL,\n disablePrev = _this$props.disablePrev,\n disableNext = _this$props.disableNext,\n navPosition = _this$props.navPosition,\n navPrev = _this$props.navPrev,\n navNext = _this$props.navNext,\n onPrevMonthClick = _this$props.onPrevMonthClick,\n onNextMonthClick = _this$props.onNextMonthClick,\n orientation = _this$props.orientation,\n phrases = _this$props.phrases,\n renderNavPrevButton = _this$props.renderNavPrevButton,\n renderNavNextButton = _this$props.renderNavNextButton,\n showNavPrevButton = _this$props.showNavPrevButton,\n showNavNextButton = _this$props.showNavNextButton,\n styles = _this$props.styles;\n\n if (!showNavNextButton && !showNavPrevButton) {\n return null;\n }\n\n var isHorizontal = orientation === _constants.HORIZONTAL_ORIENTATION;\n var isVertical = orientation !== _constants.HORIZONTAL_ORIENTATION;\n var isVerticalScrollable = orientation === _constants.VERTICAL_SCROLLABLE;\n var isBottomNavPosition = navPosition === _constants.NAV_POSITION_BOTTOM;\n var hasInlineStyles = !!inlineStyles;\n var navPrevIcon = navPrev;\n var navNextIcon = navNext;\n var isDefaultNavPrev = false;\n var isDefaultNavNext = false;\n var navPrevTabIndex = {};\n var navNextTabIndex = {};\n\n if (!navPrevIcon && !renderNavPrevButton && showNavPrevButton) {\n navPrevTabIndex = {\n tabIndex: '0'\n };\n isDefaultNavPrev = true;\n var Icon = isVertical ? _ChevronUp[\"default\"] : _LeftArrow[\"default\"];\n\n if (isRTL && !isVertical) {\n Icon = _RightArrow[\"default\"];\n }\n\n navPrevIcon = _react[\"default\"].createElement(Icon, (0, _reactWithStyles.css)(isHorizontal && styles.DayPickerNavigation_svg__horizontal, isVertical && styles.DayPickerNavigation_svg__vertical, disablePrev && styles.DayPickerNavigation_svg__disabled));\n }\n\n if (!navNextIcon && !renderNavNextButton && showNavNextButton) {\n navNextTabIndex = {\n tabIndex: '0'\n };\n isDefaultNavNext = true;\n\n var _Icon = isVertical ? _ChevronDown[\"default\"] : _RightArrow[\"default\"];\n\n if (isRTL && !isVertical) {\n _Icon = _LeftArrow[\"default\"];\n }\n\n navNextIcon = _react[\"default\"].createElement(_Icon, (0, _reactWithStyles.css)(isHorizontal && styles.DayPickerNavigation_svg__horizontal, isVertical && styles.DayPickerNavigation_svg__vertical, disableNext && styles.DayPickerNavigation_svg__disabled));\n }\n\n var isDefaultNav = isDefaultNavNext || isDefaultNavPrev;\n return _react[\"default\"].createElement(\"div\", _reactWithStyles.css.apply(void 0, [styles.DayPickerNavigation, isHorizontal && styles.DayPickerNavigation__horizontal].concat((0, _toConsumableArray2[\"default\"])(isVertical ? [styles.DayPickerNavigation__vertical, isDefaultNav && styles.DayPickerNavigation__verticalDefault] : []), (0, _toConsumableArray2[\"default\"])(isVerticalScrollable ? [styles.DayPickerNavigation__verticalScrollable, isDefaultNav && styles.DayPickerNavigation__verticalScrollableDefault, showNavPrevButton && styles.DayPickerNavigation__verticalScrollable_prevNav] : []), (0, _toConsumableArray2[\"default\"])(isBottomNavPosition ? [styles.DayPickerNavigation__bottom, isDefaultNav && styles.DayPickerNavigation__bottomDefault] : []), [hasInlineStyles && inlineStyles])), showNavPrevButton && (renderNavPrevButton ? renderNavPrevButton({\n ariaLabel: phrases.jumpToPrevMonth,\n disabled: disablePrev,\n onClick: disablePrev ? undefined : onPrevMonthClick,\n onKeyUp: disablePrev ? undefined : function (e) {\n var key = e.key;\n\n if (key === 'Enter' || key === ' ') {\n onPrevMonthClick(e);\n }\n },\n onMouseUp: disablePrev ? undefined : function (e) {\n e.currentTarget.blur();\n }\n }) : _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n // eslint-disable-line jsx-a11y/interactive-supports-focus\n role: \"button\"\n }, navPrevTabIndex, _reactWithStyles.css.apply(void 0, [styles.DayPickerNavigation_button, isDefaultNavPrev && styles.DayPickerNavigation_button__default, disablePrev && styles.DayPickerNavigation_button__disabled].concat((0, _toConsumableArray2[\"default\"])(isHorizontal ? [styles.DayPickerNavigation_button__horizontal].concat((0, _toConsumableArray2[\"default\"])(isDefaultNavPrev ? [styles.DayPickerNavigation_button__horizontalDefault, isBottomNavPosition && styles.DayPickerNavigation_bottomButton__horizontalDefault, !isRTL && styles.DayPickerNavigation_leftButton__horizontalDefault, isRTL && styles.DayPickerNavigation_rightButton__horizontalDefault] : [])) : []), (0, _toConsumableArray2[\"default\"])(isVertical ? [styles.DayPickerNavigation_button__vertical].concat((0, _toConsumableArray2[\"default\"])(isDefaultNavPrev ? [styles.DayPickerNavigation_button__verticalDefault, styles.DayPickerNavigation_prevButton__verticalDefault, isVerticalScrollable && styles.DayPickerNavigation_prevButton__verticalScrollableDefault] : [])) : []))), {\n \"aria-disabled\": disablePrev ? true : undefined,\n \"aria-label\": phrases.jumpToPrevMonth,\n onClick: disablePrev ? undefined : onPrevMonthClick,\n onKeyUp: disablePrev ? undefined : function (e) {\n var key = e.key;\n\n if (key === 'Enter' || key === ' ') {\n onPrevMonthClick(e);\n }\n },\n onMouseUp: disablePrev ? undefined : function (e) {\n e.currentTarget.blur();\n }\n }), navPrevIcon)), showNavNextButton && (renderNavNextButton ? renderNavNextButton({\n ariaLabel: phrases.jumpToNextMonth,\n disabled: disableNext,\n onClick: disableNext ? undefined : onNextMonthClick,\n onKeyUp: disableNext ? undefined : function (e) {\n var key = e.key;\n\n if (key === 'Enter' || key === ' ') {\n onNextMonthClick(e);\n }\n },\n onMouseUp: disableNext ? undefined : function (e) {\n e.currentTarget.blur();\n }\n }) : _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n // eslint-disable-line jsx-a11y/interactive-supports-focus\n role: \"button\"\n }, navNextTabIndex, _reactWithStyles.css.apply(void 0, [styles.DayPickerNavigation_button, isDefaultNavNext && styles.DayPickerNavigation_button__default, disableNext && styles.DayPickerNavigation_button__disabled].concat((0, _toConsumableArray2[\"default\"])(isHorizontal ? [styles.DayPickerNavigation_button__horizontal].concat((0, _toConsumableArray2[\"default\"])(isDefaultNavNext ? [styles.DayPickerNavigation_button__horizontalDefault, isBottomNavPosition && styles.DayPickerNavigation_bottomButton__horizontalDefault, isRTL && styles.DayPickerNavigation_leftButton__horizontalDefault, !isRTL && styles.DayPickerNavigation_rightButton__horizontalDefault] : [])) : []), (0, _toConsumableArray2[\"default\"])(isVertical ? [styles.DayPickerNavigation_button__vertical].concat((0, _toConsumableArray2[\"default\"])(isDefaultNavNext ? [styles.DayPickerNavigation_button__verticalDefault, styles.DayPickerNavigation_nextButton__verticalDefault, isVerticalScrollable && styles.DayPickerNavigation_nextButton__verticalScrollableDefault] : [])) : []))), {\n \"aria-disabled\": disableNext ? true : undefined,\n \"aria-label\": phrases.jumpToNextMonth,\n onClick: disableNext ? undefined : onNextMonthClick,\n onKeyUp: disableNext ? undefined : function (e) {\n var key = e.key;\n\n if (key === 'Enter' || key === ' ') {\n onNextMonthClick(e);\n }\n },\n onMouseUp: disableNext ? undefined : function (e) {\n e.currentTarget.blur();\n }\n }), navNextIcon)));\n };\n\n return DayPickerNavigation;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nDayPickerNavigation.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDayPickerNavigation.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n color = _ref2$reactDates.color,\n zIndex = _ref2$reactDates.zIndex;\n return {\n DayPickerNavigation: {\n position: 'relative',\n zIndex: zIndex + 2\n },\n DayPickerNavigation__horizontal: {\n height: 0\n },\n DayPickerNavigation__vertical: {},\n DayPickerNavigation__verticalScrollable: {},\n DayPickerNavigation__verticalScrollable_prevNav: {\n zIndex: zIndex + 1 // zIndex + 2 causes the button to show on top of the day of week headers\n\n },\n DayPickerNavigation__verticalDefault: {\n position: 'absolute',\n width: '100%',\n height: 52,\n bottom: 0,\n left: (0, _noflip[\"default\"])(0)\n },\n DayPickerNavigation__verticalScrollableDefault: {\n position: 'relative'\n },\n DayPickerNavigation__bottom: {\n height: 'auto'\n },\n DayPickerNavigation__bottomDefault: {\n display: 'flex',\n justifyContent: 'space-between'\n },\n DayPickerNavigation_button: {\n cursor: 'pointer',\n userSelect: 'none',\n border: 0,\n padding: 0,\n margin: 0\n },\n DayPickerNavigation_button__default: {\n border: \"1px solid \".concat(color.core.borderLight),\n backgroundColor: color.background,\n color: color.placeholderText,\n ':focus': {\n border: \"1px solid \".concat(color.core.borderMedium)\n },\n ':hover': {\n border: \"1px solid \".concat(color.core.borderMedium)\n },\n ':active': {\n background: color.backgroundDark\n }\n },\n DayPickerNavigation_button__disabled: {\n cursor: 'default',\n border: \"1px solid \".concat(color.disabled),\n ':focus': {\n border: \"1px solid \".concat(color.disabled)\n },\n ':hover': {\n border: \"1px solid \".concat(color.disabled)\n },\n ':active': {\n background: 'none'\n }\n },\n DayPickerNavigation_button__horizontal: {},\n DayPickerNavigation_button__horizontalDefault: {\n position: 'absolute',\n top: 18,\n lineHeight: 0.78,\n borderRadius: 3,\n padding: '6px 9px'\n },\n DayPickerNavigation_bottomButton__horizontalDefault: {\n position: 'static',\n marginLeft: 22,\n marginRight: 22,\n marginBottom: 30,\n marginTop: -10\n },\n DayPickerNavigation_leftButton__horizontalDefault: {\n left: (0, _noflip[\"default\"])(22)\n },\n DayPickerNavigation_rightButton__horizontalDefault: {\n right: (0, _noflip[\"default\"])(22)\n },\n DayPickerNavigation_button__vertical: {},\n DayPickerNavigation_button__verticalDefault: {\n padding: 5,\n background: color.background,\n boxShadow: (0, _noflip[\"default\"])('0 0 5px 2px rgba(0, 0, 0, 0.1)'),\n position: 'relative',\n display: 'inline-block',\n textAlign: 'center',\n height: '100%',\n width: '50%'\n },\n DayPickerNavigation_prevButton__verticalDefault: {},\n DayPickerNavigation_nextButton__verticalDefault: {\n borderLeft: (0, _noflip[\"default\"])(0)\n },\n DayPickerNavigation_nextButton__verticalScrollableDefault: {\n width: '100%'\n },\n DayPickerNavigation_prevButton__verticalScrollableDefault: {\n width: '100%'\n },\n DayPickerNavigation_svg__horizontal: {\n height: 19,\n width: 19,\n fill: color.core.grayLight,\n display: 'block'\n },\n DayPickerNavigation_svg__vertical: {\n height: 42,\n width: 42,\n fill: color.text\n },\n DayPickerNavigation_svg__disabled: {\n fill: color.disabled\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(DayPickerNavigation);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n unicode: _propTypes[\"default\"].string.isRequired,\n label: _propTypes[\"default\"].string.isRequired,\n action: _propTypes[\"default\"].string.isRequired,\n block: _propTypes[\"default\"].bool\n})) : {};\nvar defaultProps = {\n block: false\n};\n\nfunction KeyboardShortcutRow(_ref) {\n var unicode = _ref.unicode,\n label = _ref.label,\n action = _ref.action,\n block = _ref.block,\n styles = _ref.styles;\n return _react[\"default\"].createElement(\"li\", (0, _reactWithStyles.css)(styles.KeyboardShortcutRow, block && styles.KeyboardShortcutRow__block), _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.KeyboardShortcutRow_keyContainer, block && styles.KeyboardShortcutRow_keyContainer__block), _react[\"default\"].createElement(\"span\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.KeyboardShortcutRow_key), {\n role: \"img\",\n \"aria-label\": \"\".concat(label, \",\") // add comma so screen readers will pause before reading action\n\n }), unicode)), _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.KeyboardShortcutRow_action), action));\n}\n\nKeyboardShortcutRow.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nKeyboardShortcutRow.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var color = _ref2.reactDates.color;\n return {\n KeyboardShortcutRow: {\n listStyle: 'none',\n margin: '6px 0'\n },\n KeyboardShortcutRow__block: {\n marginBottom: 16\n },\n KeyboardShortcutRow_keyContainer: {\n display: 'inline-block',\n whiteSpace: 'nowrap',\n textAlign: 'right',\n // is not handled by isRTL\n marginRight: 6 // is not handled by isRTL\n\n },\n KeyboardShortcutRow_keyContainer__block: {\n textAlign: 'left',\n // is not handled by isRTL\n display: 'inline'\n },\n KeyboardShortcutRow_key: {\n fontFamily: 'monospace',\n fontSize: 12,\n textTransform: 'uppercase',\n background: color.core.grayLightest,\n padding: '2px 6px'\n },\n KeyboardShortcutRow_action: {\n display: 'inline',\n wordBreak: 'break-word',\n marginLeft: 8 // is not handled by isRTL\n\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(KeyboardShortcutRow);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.BOTTOM_RIGHT = exports.TOP_RIGHT = exports.TOP_LEFT = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _KeyboardShortcutRow = _interopRequireDefault(require(\"./KeyboardShortcutRow\"));\n\nvar _CloseButton = _interopRequireDefault(require(\"./CloseButton\"));\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar TOP_LEFT = 'top-left';\nexports.TOP_LEFT = TOP_LEFT;\nvar TOP_RIGHT = 'top-right';\nexports.TOP_RIGHT = TOP_RIGHT;\nvar BOTTOM_RIGHT = 'bottom-right';\nexports.BOTTOM_RIGHT = BOTTOM_RIGHT;\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n block: _propTypes[\"default\"].bool,\n // TODO: rename button location to be direction-agnostic\n buttonLocation: _propTypes[\"default\"].oneOf([TOP_LEFT, TOP_RIGHT, BOTTOM_RIGHT]),\n showKeyboardShortcutsPanel: _propTypes[\"default\"].bool,\n openKeyboardShortcutsPanel: _propTypes[\"default\"].func,\n closeKeyboardShortcutsPanel: _propTypes[\"default\"].func,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DayPickerKeyboardShortcutsPhrases)),\n renderKeyboardShortcutsButton: _propTypes[\"default\"].func,\n renderKeyboardShortcutsPanel: _propTypes[\"default\"].func\n})) : {};\nvar defaultProps = {\n block: false,\n buttonLocation: BOTTOM_RIGHT,\n showKeyboardShortcutsPanel: false,\n openKeyboardShortcutsPanel: function openKeyboardShortcutsPanel() {},\n closeKeyboardShortcutsPanel: function closeKeyboardShortcutsPanel() {},\n phrases: _defaultPhrases.DayPickerKeyboardShortcutsPhrases,\n renderKeyboardShortcutsButton: undefined,\n renderKeyboardShortcutsPanel: undefined\n};\n\nfunction getKeyboardShortcuts(phrases) {\n return [{\n unicode: '↵',\n label: phrases.enterKey,\n action: phrases.selectFocusedDate\n }, {\n unicode: '←/→',\n label: phrases.leftArrowRightArrow,\n action: phrases.moveFocusByOneDay\n }, {\n unicode: '↑/↓',\n label: phrases.upArrowDownArrow,\n action: phrases.moveFocusByOneWeek\n }, {\n unicode: 'PgUp/PgDn',\n label: phrases.pageUpPageDown,\n action: phrases.moveFocusByOneMonth\n }, {\n unicode: 'Home/End',\n label: phrases.homeEnd,\n action: phrases.moveFocustoStartAndEndOfWeek\n }, {\n unicode: 'Esc',\n label: phrases.escape,\n action: phrases.returnFocusToInput\n }, {\n unicode: '?',\n label: phrases.questionMark,\n action: phrases.openThisPanel\n }];\n}\n\nvar DayPickerKeyboardShortcuts =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DayPickerKeyboardShortcuts, _ref);\n var _proto = DayPickerKeyboardShortcuts.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DayPickerKeyboardShortcuts() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _ref.call.apply(_ref, [this].concat(args)) || this;\n var phrases = _this.props.phrases;\n _this.keyboardShortcuts = getKeyboardShortcuts(phrases);\n _this.onShowKeyboardShortcutsButtonClick = _this.onShowKeyboardShortcutsButtonClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setShowKeyboardShortcutsButtonRef = _this.setShowKeyboardShortcutsButtonRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setHideKeyboardShortcutsButtonRef = _this.setHideKeyboardShortcutsButtonRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.handleFocus = _this.handleFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onKeyDown = _this.onKeyDown.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var phrases = this.props.phrases;\n\n if (nextProps.phrases !== phrases) {\n this.keyboardShortcuts = getKeyboardShortcuts(nextProps.phrases);\n }\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n this.handleFocus();\n };\n\n _proto.onKeyDown = function onKeyDown(e) {\n e.stopPropagation();\n var closeKeyboardShortcutsPanel = this.props.closeKeyboardShortcutsPanel; // Because the close button is the only focusable element inside of the panel, this\n // amounts to a very basic focus trap. The user can exit the panel by \"pressing\" the\n // close button or hitting escape\n\n switch (e.key) {\n case 'Escape':\n closeKeyboardShortcutsPanel();\n break;\n // do nothing - this allows the up and down arrows continue their\n // default behavior of scrolling the content of the Keyboard Shortcuts Panel\n // which is needed when only a single month is shown for instance.\n\n case 'ArrowUp':\n case 'ArrowDown':\n break;\n // completely block the rest of the keys that have functionality outside of this panel\n\n case 'Tab':\n case 'Home':\n case 'End':\n case 'PageUp':\n case 'PageDown':\n case 'ArrowLeft':\n case 'ArrowRight':\n e.preventDefault();\n break;\n\n default:\n break;\n }\n };\n\n _proto.onShowKeyboardShortcutsButtonClick = function onShowKeyboardShortcutsButtonClick() {\n var _this2 = this;\n\n var openKeyboardShortcutsPanel = this.props.openKeyboardShortcutsPanel; // we want to return focus to this button after closing the keyboard shortcuts panel\n\n openKeyboardShortcutsPanel(function () {\n _this2.showKeyboardShortcutsButton.focus();\n });\n };\n\n _proto.setShowKeyboardShortcutsButtonRef = function setShowKeyboardShortcutsButtonRef(ref) {\n this.showKeyboardShortcutsButton = ref;\n };\n\n _proto.setHideKeyboardShortcutsButtonRef = function setHideKeyboardShortcutsButtonRef(ref) {\n this.hideKeyboardShortcutsButton = ref;\n };\n\n _proto.handleFocus = function handleFocus() {\n if (this.hideKeyboardShortcutsButton) {\n // automatically move focus into the dialog by moving\n // to the only interactive element, the hide button\n this.hideKeyboardShortcutsButton.focus();\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n block = _this$props.block,\n buttonLocation = _this$props.buttonLocation,\n showKeyboardShortcutsPanel = _this$props.showKeyboardShortcutsPanel,\n closeKeyboardShortcutsPanel = _this$props.closeKeyboardShortcutsPanel,\n styles = _this$props.styles,\n phrases = _this$props.phrases,\n renderKeyboardShortcutsButton = _this$props.renderKeyboardShortcutsButton,\n renderKeyboardShortcutsPanel = _this$props.renderKeyboardShortcutsPanel;\n var toggleButtonText = showKeyboardShortcutsPanel ? phrases.hideKeyboardShortcutsPanel : phrases.showKeyboardShortcutsPanel;\n var bottomRight = buttonLocation === BOTTOM_RIGHT;\n var topRight = buttonLocation === TOP_RIGHT;\n var topLeft = buttonLocation === TOP_LEFT;\n return _react[\"default\"].createElement(\"div\", null, renderKeyboardShortcutsButton && renderKeyboardShortcutsButton({\n // passing in context-specific props\n ref: this.setShowKeyboardShortcutsButtonRef,\n onClick: this.onShowKeyboardShortcutsButtonClick,\n ariaLabel: toggleButtonText\n }), !renderKeyboardShortcutsButton && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({\n ref: this.setShowKeyboardShortcutsButtonRef\n }, (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_buttonReset, styles.DayPickerKeyboardShortcuts_show, bottomRight && styles.DayPickerKeyboardShortcuts_show__bottomRight, topRight && styles.DayPickerKeyboardShortcuts_show__topRight, topLeft && styles.DayPickerKeyboardShortcuts_show__topLeft), {\n type: \"button\",\n \"aria-label\": toggleButtonText,\n onClick: this.onShowKeyboardShortcutsButtonClick,\n onMouseUp: function onMouseUp(e) {\n e.currentTarget.blur();\n }\n }), _react[\"default\"].createElement(\"span\", (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_showSpan, bottomRight && styles.DayPickerKeyboardShortcuts_showSpan__bottomRight, topRight && styles.DayPickerKeyboardShortcuts_showSpan__topRight, topLeft && styles.DayPickerKeyboardShortcuts_showSpan__topLeft), \"?\")), showKeyboardShortcutsPanel && (renderKeyboardShortcutsPanel ? renderKeyboardShortcutsPanel({\n closeButtonAriaLabel: phrases.hideKeyboardShortcutsPanel,\n keyboardShortcuts: this.keyboardShortcuts,\n onCloseButtonClick: closeKeyboardShortcutsPanel,\n onKeyDown: this.onKeyDown,\n title: phrases.keyboardShortcuts\n }) : _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_panel), {\n role: \"dialog\",\n \"aria-labelledby\": \"DayPickerKeyboardShortcuts_title\",\n \"aria-describedby\": \"DayPickerKeyboardShortcuts_description\"\n }), _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_title), {\n id: \"DayPickerKeyboardShortcuts_title\"\n }), phrases.keyboardShortcuts), _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({\n ref: this.setHideKeyboardShortcutsButtonRef\n }, (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_buttonReset, styles.DayPickerKeyboardShortcuts_close), {\n type: \"button\",\n tabIndex: \"0\",\n \"aria-label\": phrases.hideKeyboardShortcutsPanel,\n onClick: closeKeyboardShortcutsPanel,\n onKeyDown: this.onKeyDown\n }), _react[\"default\"].createElement(_CloseButton[\"default\"], (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_closeSvg))), _react[\"default\"].createElement(\"ul\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPickerKeyboardShortcuts_list), {\n id: \"DayPickerKeyboardShortcuts_description\"\n }), this.keyboardShortcuts.map(function (_ref2) {\n var unicode = _ref2.unicode,\n label = _ref2.label,\n action = _ref2.action;\n return _react[\"default\"].createElement(_KeyboardShortcutRow[\"default\"], {\n key: label,\n unicode: unicode,\n label: label,\n action: action,\n block: block\n });\n })))));\n };\n\n return DayPickerKeyboardShortcuts;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nDayPickerKeyboardShortcuts.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDayPickerKeyboardShortcuts.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref3) {\n var _ref3$reactDates = _ref3.reactDates,\n color = _ref3$reactDates.color,\n font = _ref3$reactDates.font,\n zIndex = _ref3$reactDates.zIndex;\n return {\n DayPickerKeyboardShortcuts_buttonReset: {\n background: 'none',\n border: 0,\n borderRadius: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n padding: 0,\n cursor: 'pointer',\n fontSize: font.size,\n ':active': {\n outline: 'none'\n }\n },\n DayPickerKeyboardShortcuts_show: {\n width: 33,\n height: 26,\n position: 'absolute',\n zIndex: zIndex + 2,\n '::before': {\n content: '\"\"',\n display: 'block',\n position: 'absolute'\n }\n },\n DayPickerKeyboardShortcuts_show__bottomRight: {\n bottom: 0,\n right: 0,\n '::before': {\n borderTop: '26px solid transparent',\n borderRight: \"33px solid \".concat(color.core.primary),\n bottom: 0,\n right: 0\n },\n ':hover::before': {\n borderRight: \"33px solid \".concat(color.core.primary_dark)\n }\n },\n DayPickerKeyboardShortcuts_show__topRight: {\n top: 0,\n right: 0,\n '::before': {\n borderBottom: '26px solid transparent',\n borderRight: \"33px solid \".concat(color.core.primary),\n top: 0,\n right: 0\n },\n ':hover::before': {\n borderRight: \"33px solid \".concat(color.core.primary_dark)\n }\n },\n DayPickerKeyboardShortcuts_show__topLeft: {\n top: 0,\n left: 0,\n '::before': {\n borderBottom: '26px solid transparent',\n borderLeft: \"33px solid \".concat(color.core.primary),\n top: 0,\n left: 0\n },\n ':hover::before': {\n borderLeft: \"33px solid \".concat(color.core.primary_dark)\n }\n },\n DayPickerKeyboardShortcuts_showSpan: {\n color: color.core.white,\n position: 'absolute'\n },\n DayPickerKeyboardShortcuts_showSpan__bottomRight: {\n bottom: 0,\n right: 5\n },\n DayPickerKeyboardShortcuts_showSpan__topRight: {\n top: 1,\n right: 5\n },\n DayPickerKeyboardShortcuts_showSpan__topLeft: {\n top: 1,\n left: 5\n },\n DayPickerKeyboardShortcuts_panel: {\n overflow: 'auto',\n background: color.background,\n border: \"1px solid \".concat(color.core.border),\n borderRadius: 2,\n position: 'absolute',\n top: 0,\n bottom: 0,\n right: 0,\n left: 0,\n zIndex: zIndex + 2,\n padding: 22,\n margin: 33,\n textAlign: 'left' // TODO: investigate use of text-align throughout the library\n\n },\n DayPickerKeyboardShortcuts_title: {\n fontSize: 16,\n fontWeight: 'bold',\n margin: 0\n },\n DayPickerKeyboardShortcuts_list: {\n listStyle: 'none',\n padding: 0,\n fontSize: font.size\n },\n DayPickerKeyboardShortcuts_close: {\n position: 'absolute',\n right: 22,\n top: 22,\n zIndex: zIndex + 2,\n ':active': {\n outline: 'none'\n }\n },\n DayPickerKeyboardShortcuts_closeSvg: {\n height: 15,\n width: 15,\n fill: color.core.grayLighter,\n ':hover': {\n fill: color.core.grayLight\n },\n ':focus': {\n fill: color.core.grayLight\n }\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(DayPickerKeyboardShortcuts);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getNumberOfCalendarMonthWeeks;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nfunction getBlankDaysBeforeFirstDay(firstDayOfMonth, firstDayOfWeek) {\n var weekDayDiff = firstDayOfMonth.day() - firstDayOfWeek;\n return (weekDayDiff + 7) % 7;\n}\n\nfunction getNumberOfCalendarMonthWeeks(month) {\n var firstDayOfWeek = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _moment[\"default\"].localeData().firstDayOfWeek();\n var firstDayOfMonth = month.clone().startOf('month');\n var numBlankDays = getBlankDaysBeforeFirstDay(firstDayOfMonth, firstDayOfWeek);\n return Math.ceil((numBlankDays + month.daysInMonth()) / 7);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getActiveElement;\n\nfunction getActiveElement() {\n return typeof document !== 'undefined' && document.activeElement;\n}","\"use strict\";\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.PureDayPicker = exports.defaultProps = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _throttle = _interopRequireDefault(require(\"lodash/throttle\"));\n\nvar _isTouchDevice = _interopRequireDefault(require(\"is-touch-device\"));\n\nvar _reactOutsideClickHandler = _interopRequireDefault(require(\"react-outside-click-handler\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _CalendarMonthGrid = _interopRequireDefault(require(\"./CalendarMonthGrid\"));\n\nvar _DayPickerNavigation = _interopRequireDefault(require(\"./DayPickerNavigation\"));\n\nvar _DayPickerKeyboardShortcuts = _interopRequireWildcard(require(\"./DayPickerKeyboardShortcuts\"));\n\nvar _getNumberOfCalendarMonthWeeks = _interopRequireDefault(require(\"../utils/getNumberOfCalendarMonthWeeks\"));\n\nvar _getCalendarMonthWidth = _interopRequireDefault(require(\"../utils/getCalendarMonthWidth\"));\n\nvar _calculateDimension = _interopRequireDefault(require(\"../utils/calculateDimension\"));\n\nvar _getActiveElement = _interopRequireDefault(require(\"../utils/getActiveElement\"));\n\nvar _isDayVisible = _interopRequireDefault(require(\"../utils/isDayVisible\"));\n\nvar _isSameMonth = _interopRequireDefault(require(\"../utils/isSameMonth\"));\n\nvar _ModifiersShape = _interopRequireDefault(require(\"../shapes/ModifiersShape\"));\n\nvar _NavPositionShape = _interopRequireDefault(require(\"../shapes/NavPositionShape\"));\n\nvar _ScrollableOrientationShape = _interopRequireDefault(require(\"../shapes/ScrollableOrientationShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"../shapes/DayOfWeekShape\"));\n\nvar _CalendarInfoPositionShape = _interopRequireDefault(require(\"../shapes/CalendarInfoPositionShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar MONTH_PADDING = 23;\nvar PREV_TRANSITION = 'prev';\nvar NEXT_TRANSITION = 'next';\nvar MONTH_SELECTION_TRANSITION = 'month_selection';\nvar YEAR_SELECTION_TRANSITION = 'year_selection';\nvar PREV_NAV = 'prev_nav';\nvar NEXT_NAV = 'next_nav';\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n // calendar presentation props\n enableOutsideDays: _propTypes[\"default\"].bool,\n numberOfMonths: _propTypes[\"default\"].number,\n orientation: _ScrollableOrientationShape[\"default\"],\n withPortal: _propTypes[\"default\"].bool,\n onOutsideClick: _propTypes[\"default\"].func,\n hidden: _propTypes[\"default\"].bool,\n initialVisibleMonth: _propTypes[\"default\"].func,\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n renderCalendarInfo: _propTypes[\"default\"].func,\n calendarInfoPosition: _CalendarInfoPositionShape[\"default\"],\n hideKeyboardShortcutsPanel: _propTypes[\"default\"].bool,\n daySize: _airbnbPropTypes.nonNegativeInteger,\n isRTL: _propTypes[\"default\"].bool,\n verticalHeight: _airbnbPropTypes.nonNegativeInteger,\n noBorder: _propTypes[\"default\"].bool,\n transitionDuration: _airbnbPropTypes.nonNegativeInteger,\n verticalBorderSpacing: _airbnbPropTypes.nonNegativeInteger,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n renderKeyboardShortcutsButton: _propTypes[\"default\"].func,\n renderKeyboardShortcutsPanel: _propTypes[\"default\"].func,\n // navigation props\n dayPickerNavigationInlineStyles: _propTypes[\"default\"].object,\n disablePrev: _propTypes[\"default\"].bool,\n disableNext: _propTypes[\"default\"].bool,\n navPosition: _NavPositionShape[\"default\"],\n navPrev: _propTypes[\"default\"].node,\n navNext: _propTypes[\"default\"].node,\n renderNavPrevButton: _propTypes[\"default\"].func,\n renderNavNextButton: _propTypes[\"default\"].func,\n noNavButtons: _propTypes[\"default\"].bool,\n noNavNextButton: _propTypes[\"default\"].bool,\n noNavPrevButton: _propTypes[\"default\"].bool,\n onPrevMonthClick: _propTypes[\"default\"].func,\n onNextMonthClick: _propTypes[\"default\"].func,\n onMonthChange: _propTypes[\"default\"].func,\n onYearChange: _propTypes[\"default\"].func,\n onGetNextScrollableMonths: _propTypes[\"default\"].func,\n // VERTICAL_SCROLLABLE daypickers only\n onGetPrevScrollableMonths: _propTypes[\"default\"].func,\n // VERTICAL_SCROLLABLE daypickers only\n // month props\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderWeekHeaderElement: _propTypes[\"default\"].func,\n // day props\n modifiers: _propTypes[\"default\"].objectOf(_propTypes[\"default\"].objectOf(_ModifiersShape[\"default\"])),\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n onDayClick: _propTypes[\"default\"].func,\n onDayMouseEnter: _propTypes[\"default\"].func,\n onDayMouseLeave: _propTypes[\"default\"].func,\n // accessibility props\n isFocused: _propTypes[\"default\"].bool,\n getFirstFocusableDay: _propTypes[\"default\"].func,\n onBlur: _propTypes[\"default\"].func,\n showKeyboardShortcuts: _propTypes[\"default\"].bool,\n onTab: _propTypes[\"default\"].func,\n onShiftTab: _propTypes[\"default\"].func,\n // internationalization\n monthFormat: _propTypes[\"default\"].string,\n weekDayFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DayPickerPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string\n})) : {};\nvar defaultProps = {\n // calendar presentation props\n enableOutsideDays: false,\n numberOfMonths: 2,\n orientation: _constants.HORIZONTAL_ORIENTATION,\n withPortal: false,\n onOutsideClick: function onOutsideClick() {},\n hidden: false,\n initialVisibleMonth: function initialVisibleMonth() {\n return (0, _moment[\"default\"])();\n },\n firstDayOfWeek: null,\n renderCalendarInfo: null,\n calendarInfoPosition: _constants.INFO_POSITION_BOTTOM,\n hideKeyboardShortcutsPanel: false,\n daySize: _constants.DAY_SIZE,\n isRTL: false,\n verticalHeight: null,\n noBorder: false,\n transitionDuration: undefined,\n verticalBorderSpacing: undefined,\n horizontalMonthPadding: 13,\n renderKeyboardShortcutsButton: undefined,\n renderKeyboardShortcutsPanel: undefined,\n // navigation props\n dayPickerNavigationInlineStyles: null,\n disablePrev: false,\n disableNext: false,\n navPosition: _constants.NAV_POSITION_TOP,\n navPrev: null,\n navNext: null,\n renderNavPrevButton: null,\n renderNavNextButton: null,\n noNavButtons: false,\n noNavNextButton: false,\n noNavPrevButton: false,\n onPrevMonthClick: function onPrevMonthClick() {},\n onNextMonthClick: function onNextMonthClick() {},\n onMonthChange: function onMonthChange() {},\n onYearChange: function onYearChange() {},\n onGetNextScrollableMonths: function onGetNextScrollableMonths() {},\n onGetPrevScrollableMonths: function onGetPrevScrollableMonths() {},\n // month props\n renderMonthText: null,\n renderMonthElement: null,\n renderWeekHeaderElement: null,\n // day props\n modifiers: {},\n renderCalendarDay: undefined,\n renderDayContents: null,\n onDayClick: function onDayClick() {},\n onDayMouseEnter: function onDayMouseEnter() {},\n onDayMouseLeave: function onDayMouseLeave() {},\n // accessibility props\n isFocused: false,\n getFirstFocusableDay: null,\n onBlur: function onBlur() {},\n showKeyboardShortcuts: false,\n onTab: function onTab() {},\n onShiftTab: function onShiftTab() {},\n // internationalization\n monthFormat: 'MMMM YYYY',\n weekDayFormat: 'dd',\n phrases: _defaultPhrases.DayPickerPhrases,\n dayAriaLabelFormat: undefined\n};\nexports.defaultProps = defaultProps;\n\nvar DayPicker =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DayPicker, _ref);\n var _proto = DayPicker.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DayPicker(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n var currentMonth = props.hidden ? (0, _moment[\"default\"])() : props.initialVisibleMonth();\n var focusedDate = currentMonth.clone().startOf('month');\n\n if (props.getFirstFocusableDay) {\n focusedDate = props.getFirstFocusableDay(currentMonth);\n }\n\n var horizontalMonthPadding = props.horizontalMonthPadding;\n var translationValue = props.isRTL && _this.isHorizontal() ? -(0, _getCalendarMonthWidth[\"default\"])(props.daySize, horizontalMonthPadding) : 0;\n _this.hasSetInitialVisibleMonth = !props.hidden;\n _this.state = {\n currentMonthScrollTop: null,\n currentMonth: currentMonth,\n monthTransition: null,\n translationValue: translationValue,\n scrollableMonthMultiple: 1,\n calendarMonthWidth: (0, _getCalendarMonthWidth[\"default\"])(props.daySize, horizontalMonthPadding),\n focusedDate: !props.hidden || props.isFocused ? focusedDate : null,\n nextFocusedDate: null,\n showKeyboardShortcuts: props.showKeyboardShortcuts,\n onKeyboardShortcutsPanelClose: function onKeyboardShortcutsPanelClose() {},\n isTouchDevice: (0, _isTouchDevice[\"default\"])(),\n withMouseInteractions: true,\n calendarInfoWidth: 0,\n monthTitleHeight: null,\n hasSetHeight: false\n };\n\n _this.setCalendarMonthWeeks(currentMonth);\n\n _this.calendarMonthGridHeight = 0;\n _this.setCalendarInfoWidthTimeout = null;\n _this.setCalendarMonthGridHeightTimeout = null;\n _this.onKeyDown = _this.onKeyDown.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.throttledKeyDown = (0, _throttle[\"default\"])(_this.onFinalKeyDown, 200, {\n trailing: false\n });\n _this.onPrevMonthClick = _this.onPrevMonthClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onPrevMonthTransition = _this.onPrevMonthTransition.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onNextMonthClick = _this.onNextMonthClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onNextMonthTransition = _this.onNextMonthTransition.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onMonthChange = _this.onMonthChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onYearChange = _this.onYearChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.getNextScrollableMonths = _this.getNextScrollableMonths.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.getPrevScrollableMonths = _this.getPrevScrollableMonths.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.updateStateAfterMonthTransition = _this.updateStateAfterMonthTransition.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.openKeyboardShortcutsPanel = _this.openKeyboardShortcutsPanel.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.closeKeyboardShortcutsPanel = _this.closeKeyboardShortcutsPanel.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setCalendarInfoRef = _this.setCalendarInfoRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setContainerRef = _this.setContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setTransitionContainerRef = _this.setTransitionContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setMonthTitleHeight = _this.setMonthTitleHeight.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentDidMount = function componentDidMount() {\n var orientation = this.props.orientation;\n var currentMonth = this.state.currentMonth;\n var calendarInfoWidth = this.calendarInfo ? (0, _calculateDimension[\"default\"])(this.calendarInfo, 'width', true, true) : 0;\n var currentMonthScrollTop = this.transitionContainer && orientation === _constants.VERTICAL_SCROLLABLE ? this.transitionContainer.scrollHeight - this.transitionContainer.scrollTop : null;\n this.setState({\n isTouchDevice: (0, _isTouchDevice[\"default\"])(),\n calendarInfoWidth: calendarInfoWidth,\n currentMonthScrollTop: currentMonthScrollTop\n });\n this.setCalendarMonthWeeks(currentMonth);\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps, nextState) {\n var hidden = nextProps.hidden,\n isFocused = nextProps.isFocused,\n showKeyboardShortcuts = nextProps.showKeyboardShortcuts,\n onBlur = nextProps.onBlur,\n orientation = nextProps.orientation,\n renderMonthText = nextProps.renderMonthText,\n horizontalMonthPadding = nextProps.horizontalMonthPadding;\n var currentMonth = this.state.currentMonth;\n var nextCurrentMonth = nextState.currentMonth;\n\n if (!hidden) {\n if (!this.hasSetInitialVisibleMonth) {\n this.hasSetInitialVisibleMonth = true;\n this.setState({\n currentMonth: nextProps.initialVisibleMonth()\n });\n }\n }\n\n var _this$props = this.props,\n daySize = _this$props.daySize,\n prevIsFocused = _this$props.isFocused,\n prevRenderMonthText = _this$props.renderMonthText;\n\n if (nextProps.daySize !== daySize) {\n this.setState({\n calendarMonthWidth: (0, _getCalendarMonthWidth[\"default\"])(nextProps.daySize, horizontalMonthPadding)\n });\n }\n\n if (isFocused !== prevIsFocused) {\n if (isFocused) {\n var focusedDate = this.getFocusedDay(currentMonth);\n var onKeyboardShortcutsPanelClose = this.state.onKeyboardShortcutsPanelClose;\n\n if (nextProps.showKeyboardShortcuts) {\n // the ? shortcut came from the input and we should return input there once it is close\n onKeyboardShortcutsPanelClose = onBlur;\n }\n\n this.setState({\n showKeyboardShortcuts: showKeyboardShortcuts,\n onKeyboardShortcutsPanelClose: onKeyboardShortcutsPanelClose,\n focusedDate: focusedDate,\n withMouseInteractions: false\n });\n } else {\n this.setState({\n focusedDate: null\n });\n }\n }\n\n if (renderMonthText !== prevRenderMonthText) {\n this.setState({\n monthTitleHeight: null\n });\n } // Capture the scroll position so when previous months are rendered above the current month\n // we can adjust scroll after the component has updated and the previous current month\n // stays in view.\n\n\n if (orientation === _constants.VERTICAL_SCROLLABLE && this.transitionContainer && !(0, _isSameMonth[\"default\"])(currentMonth, nextCurrentMonth)) {\n this.setState({\n currentMonthScrollTop: this.transitionContainer.scrollHeight - this.transitionContainer.scrollTop\n });\n }\n };\n\n _proto.componentWillUpdate = function componentWillUpdate() {\n var _this2 = this;\n\n var transitionDuration = this.props.transitionDuration; // Calculating the dimensions trigger a DOM repaint which\n // breaks the CSS transition.\n // The setTimeout will wait until the transition ends.\n\n if (this.calendarInfo) {\n this.setCalendarInfoWidthTimeout = setTimeout(function () {\n var calendarInfoWidth = _this2.state.calendarInfoWidth;\n var calendarInfoPanelWidth = (0, _calculateDimension[\"default\"])(_this2.calendarInfo, 'width', true, true);\n\n if (calendarInfoWidth !== calendarInfoPanelWidth) {\n _this2.setState({\n calendarInfoWidth: calendarInfoPanelWidth\n });\n }\n }, transitionDuration);\n }\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n var _this$props2 = this.props,\n orientation = _this$props2.orientation,\n daySize = _this$props2.daySize,\n isFocused = _this$props2.isFocused,\n numberOfMonths = _this$props2.numberOfMonths;\n var _this$state = this.state,\n currentMonth = _this$state.currentMonth,\n currentMonthScrollTop = _this$state.currentMonthScrollTop,\n focusedDate = _this$state.focusedDate,\n monthTitleHeight = _this$state.monthTitleHeight;\n\n if (this.isHorizontal() && (orientation !== prevProps.orientation || daySize !== prevProps.daySize)) {\n var visibleCalendarWeeks = this.calendarMonthWeeks.slice(1, numberOfMonths + 1);\n var calendarMonthWeeksHeight = Math.max.apply(Math, [0].concat((0, _toConsumableArray2[\"default\"])(visibleCalendarWeeks))) * (daySize - 1);\n var newMonthHeight = monthTitleHeight + calendarMonthWeeksHeight + 1;\n this.adjustDayPickerHeight(newMonthHeight);\n }\n\n if (!prevProps.isFocused && isFocused && !focusedDate) {\n this.container.focus();\n } // If orientation is VERTICAL_SCROLLABLE and currentMonth has changed adjust scrollTop so the\n // new months rendered above the current month don't push the current month out of view.\n\n\n if (orientation === _constants.VERTICAL_SCROLLABLE && !(0, _isSameMonth[\"default\"])(prevState.currentMonth, currentMonth) && currentMonthScrollTop && this.transitionContainer) {\n this.transitionContainer.scrollTop = this.transitionContainer.scrollHeight - currentMonthScrollTop;\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n clearTimeout(this.setCalendarInfoWidthTimeout);\n clearTimeout(this.setCalendarMonthGridHeightTimeout);\n };\n\n _proto.onKeyDown = function onKeyDown(e) {\n e.stopPropagation();\n\n if (!_constants.MODIFIER_KEY_NAMES.has(e.key)) {\n this.throttledKeyDown(e);\n }\n };\n\n _proto.onFinalKeyDown = function onFinalKeyDown(e) {\n this.setState({\n withMouseInteractions: false\n });\n var _this$props3 = this.props,\n onBlur = _this$props3.onBlur,\n onTab = _this$props3.onTab,\n onShiftTab = _this$props3.onShiftTab,\n isRTL = _this$props3.isRTL;\n var _this$state2 = this.state,\n focusedDate = _this$state2.focusedDate,\n showKeyboardShortcuts = _this$state2.showKeyboardShortcuts;\n if (!focusedDate) return;\n var newFocusedDate = focusedDate.clone();\n var didTransitionMonth = false; // focus might be anywhere when the keyboard shortcuts panel is opened so we want to\n // return it to wherever it was before when the panel was opened\n\n var activeElement = (0, _getActiveElement[\"default\"])();\n\n var onKeyboardShortcutsPanelClose = function onKeyboardShortcutsPanelClose() {\n if (activeElement) activeElement.focus();\n };\n\n switch (e.key) {\n case 'ArrowUp':\n e.preventDefault();\n newFocusedDate.subtract(1, 'week');\n didTransitionMonth = this.maybeTransitionPrevMonth(newFocusedDate);\n break;\n\n case 'ArrowLeft':\n e.preventDefault();\n\n if (isRTL) {\n newFocusedDate.add(1, 'day');\n } else {\n newFocusedDate.subtract(1, 'day');\n }\n\n didTransitionMonth = this.maybeTransitionPrevMonth(newFocusedDate);\n break;\n\n case 'Home':\n e.preventDefault();\n newFocusedDate.startOf('week');\n didTransitionMonth = this.maybeTransitionPrevMonth(newFocusedDate);\n break;\n\n case 'PageUp':\n e.preventDefault();\n newFocusedDate.subtract(1, 'month');\n didTransitionMonth = this.maybeTransitionPrevMonth(newFocusedDate);\n break;\n\n case 'ArrowDown':\n e.preventDefault();\n newFocusedDate.add(1, 'week');\n didTransitionMonth = this.maybeTransitionNextMonth(newFocusedDate);\n break;\n\n case 'ArrowRight':\n e.preventDefault();\n\n if (isRTL) {\n newFocusedDate.subtract(1, 'day');\n } else {\n newFocusedDate.add(1, 'day');\n }\n\n didTransitionMonth = this.maybeTransitionNextMonth(newFocusedDate);\n break;\n\n case 'End':\n e.preventDefault();\n newFocusedDate.endOf('week');\n didTransitionMonth = this.maybeTransitionNextMonth(newFocusedDate);\n break;\n\n case 'PageDown':\n e.preventDefault();\n newFocusedDate.add(1, 'month');\n didTransitionMonth = this.maybeTransitionNextMonth(newFocusedDate);\n break;\n\n case '?':\n this.openKeyboardShortcutsPanel(onKeyboardShortcutsPanelClose);\n break;\n\n case 'Escape':\n if (showKeyboardShortcuts) {\n this.closeKeyboardShortcutsPanel();\n } else {\n onBlur(e);\n }\n\n break;\n\n case 'Tab':\n if (e.shiftKey) {\n onShiftTab();\n } else {\n onTab(e);\n }\n\n break;\n\n default:\n break;\n } // If there was a month transition, do not update the focused date until the transition has\n // completed. Otherwise, attempting to focus on a DOM node may interrupt the CSS animation. If\n // didTransitionMonth is true, the focusedDate gets updated in #updateStateAfterMonthTransition\n\n\n if (!didTransitionMonth) {\n this.setState({\n focusedDate: newFocusedDate\n });\n }\n };\n\n _proto.onPrevMonthClick = function onPrevMonthClick(e) {\n if (e) e.preventDefault();\n this.onPrevMonthTransition();\n };\n\n _proto.onPrevMonthTransition = function onPrevMonthTransition(nextFocusedDate) {\n var _this$props4 = this.props,\n daySize = _this$props4.daySize,\n isRTL = _this$props4.isRTL,\n numberOfMonths = _this$props4.numberOfMonths;\n var _this$state3 = this.state,\n calendarMonthWidth = _this$state3.calendarMonthWidth,\n monthTitleHeight = _this$state3.monthTitleHeight;\n var translationValue;\n\n if (this.isVertical()) {\n var calendarMonthWeeksHeight = this.calendarMonthWeeks[0] * (daySize - 1);\n translationValue = monthTitleHeight + calendarMonthWeeksHeight + 1;\n } else if (this.isHorizontal()) {\n translationValue = calendarMonthWidth;\n\n if (isRTL) {\n translationValue = -2 * calendarMonthWidth;\n }\n\n var visibleCalendarWeeks = this.calendarMonthWeeks.slice(0, numberOfMonths);\n\n var _calendarMonthWeeksHeight = Math.max.apply(Math, [0].concat((0, _toConsumableArray2[\"default\"])(visibleCalendarWeeks))) * (daySize - 1);\n\n var newMonthHeight = monthTitleHeight + _calendarMonthWeeksHeight + 1;\n this.adjustDayPickerHeight(newMonthHeight);\n }\n\n this.setState({\n monthTransition: PREV_TRANSITION,\n translationValue: translationValue,\n focusedDate: null,\n nextFocusedDate: nextFocusedDate\n });\n };\n\n _proto.onMonthChange = function onMonthChange(currentMonth) {\n this.setCalendarMonthWeeks(currentMonth);\n this.calculateAndSetDayPickerHeight(); // Translation value is a hack to force an invisible transition that\n // properly rerenders the CalendarMonthGrid\n\n this.setState({\n monthTransition: MONTH_SELECTION_TRANSITION,\n translationValue: 0.00001,\n focusedDate: null,\n nextFocusedDate: currentMonth,\n currentMonth: currentMonth\n });\n };\n\n _proto.onYearChange = function onYearChange(currentMonth) {\n this.setCalendarMonthWeeks(currentMonth);\n this.calculateAndSetDayPickerHeight(); // Translation value is a hack to force an invisible transition that\n // properly rerenders the CalendarMonthGrid\n\n this.setState({\n monthTransition: YEAR_SELECTION_TRANSITION,\n translationValue: 0.0001,\n focusedDate: null,\n nextFocusedDate: currentMonth,\n currentMonth: currentMonth\n });\n };\n\n _proto.onNextMonthClick = function onNextMonthClick(e) {\n if (e) e.preventDefault();\n this.onNextMonthTransition();\n };\n\n _proto.onNextMonthTransition = function onNextMonthTransition(nextFocusedDate) {\n var _this$props5 = this.props,\n isRTL = _this$props5.isRTL,\n numberOfMonths = _this$props5.numberOfMonths,\n daySize = _this$props5.daySize;\n var _this$state4 = this.state,\n calendarMonthWidth = _this$state4.calendarMonthWidth,\n monthTitleHeight = _this$state4.monthTitleHeight;\n var translationValue;\n\n if (this.isVertical()) {\n var firstVisibleMonthWeeks = this.calendarMonthWeeks[1];\n var calendarMonthWeeksHeight = firstVisibleMonthWeeks * (daySize - 1);\n translationValue = -(monthTitleHeight + calendarMonthWeeksHeight + 1);\n }\n\n if (this.isHorizontal()) {\n translationValue = -calendarMonthWidth;\n\n if (isRTL) {\n translationValue = 0;\n }\n\n var visibleCalendarWeeks = this.calendarMonthWeeks.slice(2, numberOfMonths + 2);\n\n var _calendarMonthWeeksHeight2 = Math.max.apply(Math, [0].concat((0, _toConsumableArray2[\"default\"])(visibleCalendarWeeks))) * (daySize - 1);\n\n var newMonthHeight = monthTitleHeight + _calendarMonthWeeksHeight2 + 1;\n this.adjustDayPickerHeight(newMonthHeight);\n }\n\n this.setState({\n monthTransition: NEXT_TRANSITION,\n translationValue: translationValue,\n focusedDate: null,\n nextFocusedDate: nextFocusedDate\n });\n };\n\n _proto.getFirstDayOfWeek = function getFirstDayOfWeek() {\n var firstDayOfWeek = this.props.firstDayOfWeek;\n\n if (firstDayOfWeek == null) {\n return _moment[\"default\"].localeData().firstDayOfWeek();\n }\n\n return firstDayOfWeek;\n };\n\n _proto.getWeekHeaders = function getWeekHeaders() {\n var weekDayFormat = this.props.weekDayFormat;\n var currentMonth = this.state.currentMonth;\n var firstDayOfWeek = this.getFirstDayOfWeek();\n var weekHeaders = [];\n\n for (var i = 0; i < 7; i += 1) {\n weekHeaders.push(currentMonth.clone().day((i + firstDayOfWeek) % 7).format(weekDayFormat));\n }\n\n return weekHeaders;\n };\n\n _proto.getFirstVisibleIndex = function getFirstVisibleIndex() {\n var orientation = this.props.orientation;\n var monthTransition = this.state.monthTransition;\n if (orientation === _constants.VERTICAL_SCROLLABLE) return 0;\n var firstVisibleMonthIndex = 1;\n\n if (monthTransition === PREV_TRANSITION) {\n firstVisibleMonthIndex -= 1;\n } else if (monthTransition === NEXT_TRANSITION) {\n firstVisibleMonthIndex += 1;\n }\n\n return firstVisibleMonthIndex;\n };\n\n _proto.getFocusedDay = function getFocusedDay(newMonth) {\n var _this$props6 = this.props,\n getFirstFocusableDay = _this$props6.getFirstFocusableDay,\n numberOfMonths = _this$props6.numberOfMonths;\n var focusedDate;\n\n if (getFirstFocusableDay) {\n focusedDate = getFirstFocusableDay(newMonth);\n }\n\n if (newMonth && (!focusedDate || !(0, _isDayVisible[\"default\"])(focusedDate, newMonth, numberOfMonths))) {\n focusedDate = newMonth.clone().startOf('month');\n }\n\n return focusedDate;\n };\n\n _proto.setMonthTitleHeight = function setMonthTitleHeight(monthTitleHeight) {\n var _this3 = this;\n\n this.setState({\n monthTitleHeight: monthTitleHeight\n }, function () {\n _this3.calculateAndSetDayPickerHeight();\n });\n };\n\n _proto.setCalendarMonthWeeks = function setCalendarMonthWeeks(currentMonth) {\n var numberOfMonths = this.props.numberOfMonths;\n this.calendarMonthWeeks = [];\n var month = currentMonth.clone().subtract(1, 'months');\n var firstDayOfWeek = this.getFirstDayOfWeek();\n\n for (var i = 0; i < numberOfMonths + 2; i += 1) {\n var numberOfWeeks = (0, _getNumberOfCalendarMonthWeeks[\"default\"])(month, firstDayOfWeek);\n this.calendarMonthWeeks.push(numberOfWeeks);\n month = month.add(1, 'months');\n }\n };\n\n _proto.setContainerRef = function setContainerRef(ref) {\n this.container = ref;\n };\n\n _proto.setCalendarInfoRef = function setCalendarInfoRef(ref) {\n this.calendarInfo = ref;\n };\n\n _proto.setTransitionContainerRef = function setTransitionContainerRef(ref) {\n this.transitionContainer = ref;\n };\n\n _proto.getNextScrollableMonths = function getNextScrollableMonths(e) {\n var onGetNextScrollableMonths = this.props.onGetNextScrollableMonths;\n if (e) e.preventDefault();\n if (onGetNextScrollableMonths) onGetNextScrollableMonths(e);\n this.setState(function (_ref2) {\n var scrollableMonthMultiple = _ref2.scrollableMonthMultiple;\n return {\n scrollableMonthMultiple: scrollableMonthMultiple + 1\n };\n });\n };\n\n _proto.getPrevScrollableMonths = function getPrevScrollableMonths(e) {\n var _this$props7 = this.props,\n numberOfMonths = _this$props7.numberOfMonths,\n onGetPrevScrollableMonths = _this$props7.onGetPrevScrollableMonths;\n if (e) e.preventDefault();\n if (onGetPrevScrollableMonths) onGetPrevScrollableMonths(e);\n this.setState(function (_ref3) {\n var currentMonth = _ref3.currentMonth,\n scrollableMonthMultiple = _ref3.scrollableMonthMultiple;\n return {\n currentMonth: currentMonth.clone().subtract(numberOfMonths, 'month'),\n scrollableMonthMultiple: scrollableMonthMultiple + 1\n };\n });\n };\n\n _proto.maybeTransitionNextMonth = function maybeTransitionNextMonth(newFocusedDate) {\n var numberOfMonths = this.props.numberOfMonths;\n var _this$state5 = this.state,\n currentMonth = _this$state5.currentMonth,\n focusedDate = _this$state5.focusedDate;\n var newFocusedDateMonth = newFocusedDate.month();\n var focusedDateMonth = focusedDate.month();\n var isNewFocusedDateVisible = (0, _isDayVisible[\"default\"])(newFocusedDate, currentMonth, numberOfMonths);\n\n if (newFocusedDateMonth !== focusedDateMonth && !isNewFocusedDateVisible) {\n this.onNextMonthTransition(newFocusedDate);\n return true;\n }\n\n return false;\n };\n\n _proto.maybeTransitionPrevMonth = function maybeTransitionPrevMonth(newFocusedDate) {\n var numberOfMonths = this.props.numberOfMonths;\n var _this$state6 = this.state,\n currentMonth = _this$state6.currentMonth,\n focusedDate = _this$state6.focusedDate;\n var newFocusedDateMonth = newFocusedDate.month();\n var focusedDateMonth = focusedDate.month();\n var isNewFocusedDateVisible = (0, _isDayVisible[\"default\"])(newFocusedDate, currentMonth, numberOfMonths);\n\n if (newFocusedDateMonth !== focusedDateMonth && !isNewFocusedDateVisible) {\n this.onPrevMonthTransition(newFocusedDate);\n return true;\n }\n\n return false;\n };\n\n _proto.isHorizontal = function isHorizontal() {\n var orientation = this.props.orientation;\n return orientation === _constants.HORIZONTAL_ORIENTATION;\n };\n\n _proto.isVertical = function isVertical() {\n var orientation = this.props.orientation;\n return orientation === _constants.VERTICAL_ORIENTATION || orientation === _constants.VERTICAL_SCROLLABLE;\n };\n\n _proto.updateStateAfterMonthTransition = function updateStateAfterMonthTransition() {\n var _this4 = this;\n\n var _this$props8 = this.props,\n onPrevMonthClick = _this$props8.onPrevMonthClick,\n onNextMonthClick = _this$props8.onNextMonthClick,\n numberOfMonths = _this$props8.numberOfMonths,\n onMonthChange = _this$props8.onMonthChange,\n onYearChange = _this$props8.onYearChange,\n isRTL = _this$props8.isRTL;\n var _this$state7 = this.state,\n currentMonth = _this$state7.currentMonth,\n monthTransition = _this$state7.monthTransition,\n focusedDate = _this$state7.focusedDate,\n nextFocusedDate = _this$state7.nextFocusedDate,\n withMouseInteractions = _this$state7.withMouseInteractions,\n calendarMonthWidth = _this$state7.calendarMonthWidth;\n if (!monthTransition) return;\n var newMonth = currentMonth.clone();\n var firstDayOfWeek = this.getFirstDayOfWeek();\n\n if (monthTransition === PREV_TRANSITION) {\n newMonth.subtract(1, 'month');\n if (onPrevMonthClick) onPrevMonthClick(newMonth);\n var newInvisibleMonth = newMonth.clone().subtract(1, 'month');\n var numberOfWeeks = (0, _getNumberOfCalendarMonthWeeks[\"default\"])(newInvisibleMonth, firstDayOfWeek);\n this.calendarMonthWeeks = [numberOfWeeks].concat((0, _toConsumableArray2[\"default\"])(this.calendarMonthWeeks.slice(0, -1)));\n } else if (monthTransition === NEXT_TRANSITION) {\n newMonth.add(1, 'month');\n if (onNextMonthClick) onNextMonthClick(newMonth);\n\n var _newInvisibleMonth = newMonth.clone().add(numberOfMonths, 'month');\n\n var _numberOfWeeks = (0, _getNumberOfCalendarMonthWeeks[\"default\"])(_newInvisibleMonth, firstDayOfWeek);\n\n this.calendarMonthWeeks = [].concat((0, _toConsumableArray2[\"default\"])(this.calendarMonthWeeks.slice(1)), [_numberOfWeeks]);\n } else if (monthTransition === MONTH_SELECTION_TRANSITION) {\n if (onMonthChange) onMonthChange(newMonth);\n } else if (monthTransition === YEAR_SELECTION_TRANSITION) {\n if (onYearChange) onYearChange(newMonth);\n }\n\n var newFocusedDate = null;\n\n if (nextFocusedDate) {\n newFocusedDate = nextFocusedDate;\n } else if (!focusedDate && !withMouseInteractions) {\n newFocusedDate = this.getFocusedDay(newMonth);\n }\n\n this.setState({\n currentMonth: newMonth,\n monthTransition: null,\n translationValue: isRTL && this.isHorizontal() ? -calendarMonthWidth : 0,\n nextFocusedDate: null,\n focusedDate: newFocusedDate\n }, function () {\n // we don't want to focus on the relevant calendar day after a month transition\n // if the user is navigating around using a mouse\n if (withMouseInteractions) {\n var activeElement = (0, _getActiveElement[\"default\"])();\n\n if (activeElement && activeElement !== document.body && _this4.container.contains(activeElement) && activeElement.blur) {\n activeElement.blur();\n }\n }\n });\n };\n\n _proto.adjustDayPickerHeight = function adjustDayPickerHeight(newMonthHeight) {\n var _this5 = this;\n\n var monthHeight = newMonthHeight + MONTH_PADDING;\n\n if (monthHeight !== this.calendarMonthGridHeight) {\n this.transitionContainer.style.height = \"\".concat(monthHeight, \"px\");\n\n if (!this.calendarMonthGridHeight) {\n this.setCalendarMonthGridHeightTimeout = setTimeout(function () {\n _this5.setState({\n hasSetHeight: true\n });\n }, 0);\n }\n\n this.calendarMonthGridHeight = monthHeight;\n }\n };\n\n _proto.calculateAndSetDayPickerHeight = function calculateAndSetDayPickerHeight() {\n var _this$props9 = this.props,\n daySize = _this$props9.daySize,\n numberOfMonths = _this$props9.numberOfMonths;\n var monthTitleHeight = this.state.monthTitleHeight;\n var visibleCalendarWeeks = this.calendarMonthWeeks.slice(1, numberOfMonths + 1);\n var calendarMonthWeeksHeight = Math.max.apply(Math, [0].concat((0, _toConsumableArray2[\"default\"])(visibleCalendarWeeks))) * (daySize - 1);\n var newMonthHeight = monthTitleHeight + calendarMonthWeeksHeight + 1;\n\n if (this.isHorizontal()) {\n this.adjustDayPickerHeight(newMonthHeight);\n }\n };\n\n _proto.openKeyboardShortcutsPanel = function openKeyboardShortcutsPanel(onCloseCallBack) {\n this.setState({\n showKeyboardShortcuts: true,\n onKeyboardShortcutsPanelClose: onCloseCallBack\n });\n };\n\n _proto.closeKeyboardShortcutsPanel = function closeKeyboardShortcutsPanel() {\n var onKeyboardShortcutsPanelClose = this.state.onKeyboardShortcutsPanelClose;\n\n if (onKeyboardShortcutsPanelClose) {\n onKeyboardShortcutsPanelClose();\n }\n\n this.setState({\n onKeyboardShortcutsPanelClose: null,\n showKeyboardShortcuts: false\n });\n };\n\n _proto.renderNavigation = function renderNavigation(navDirection) {\n var _this$props10 = this.props,\n dayPickerNavigationInlineStyles = _this$props10.dayPickerNavigationInlineStyles,\n disablePrev = _this$props10.disablePrev,\n disableNext = _this$props10.disableNext,\n navPosition = _this$props10.navPosition,\n navPrev = _this$props10.navPrev,\n navNext = _this$props10.navNext,\n noNavButtons = _this$props10.noNavButtons,\n noNavNextButton = _this$props10.noNavNextButton,\n noNavPrevButton = _this$props10.noNavPrevButton,\n orientation = _this$props10.orientation,\n phrases = _this$props10.phrases,\n renderNavPrevButton = _this$props10.renderNavPrevButton,\n renderNavNextButton = _this$props10.renderNavNextButton,\n isRTL = _this$props10.isRTL;\n\n if (noNavButtons) {\n return null;\n }\n\n var onPrevMonthClick = orientation === _constants.VERTICAL_SCROLLABLE ? this.getPrevScrollableMonths : this.onPrevMonthClick;\n var onNextMonthClick = orientation === _constants.VERTICAL_SCROLLABLE ? this.getNextScrollableMonths : this.onNextMonthClick;\n return _react[\"default\"].createElement(_DayPickerNavigation[\"default\"], {\n disablePrev: disablePrev,\n disableNext: disableNext,\n inlineStyles: dayPickerNavigationInlineStyles,\n onPrevMonthClick: onPrevMonthClick,\n onNextMonthClick: onNextMonthClick,\n navPosition: navPosition,\n navPrev: navPrev,\n navNext: navNext,\n renderNavPrevButton: renderNavPrevButton,\n renderNavNextButton: renderNavNextButton,\n orientation: orientation,\n phrases: phrases,\n isRTL: isRTL,\n showNavNextButton: !(noNavNextButton || orientation === _constants.VERTICAL_SCROLLABLE && navDirection === PREV_NAV),\n showNavPrevButton: !(noNavPrevButton || orientation === _constants.VERTICAL_SCROLLABLE && navDirection === NEXT_NAV)\n });\n };\n\n _proto.renderWeekHeader = function renderWeekHeader(index) {\n var _this$props11 = this.props,\n daySize = _this$props11.daySize,\n horizontalMonthPadding = _this$props11.horizontalMonthPadding,\n orientation = _this$props11.orientation,\n renderWeekHeaderElement = _this$props11.renderWeekHeaderElement,\n styles = _this$props11.styles;\n var calendarMonthWidth = this.state.calendarMonthWidth;\n var verticalScrollable = orientation === _constants.VERTICAL_SCROLLABLE;\n var horizontalStyle = {\n left: index * calendarMonthWidth\n };\n var verticalStyle = {\n marginLeft: -calendarMonthWidth / 2\n };\n var weekHeaderStyle = {}; // no styles applied to the vertical-scrollable orientation\n\n if (this.isHorizontal()) {\n weekHeaderStyle = horizontalStyle;\n } else if (this.isVertical() && !verticalScrollable) {\n weekHeaderStyle = verticalStyle;\n }\n\n var weekHeaders = this.getWeekHeaders();\n var header = weekHeaders.map(function (day) {\n return _react[\"default\"].createElement(\"li\", (0, _extends2[\"default\"])({\n key: day\n }, (0, _reactWithStyles.css)(styles.DayPicker_weekHeader_li, {\n width: daySize\n })), renderWeekHeaderElement ? renderWeekHeaderElement(day) : _react[\"default\"].createElement(\"small\", null, day));\n });\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPicker_weekHeader, this.isVertical() && styles.DayPicker_weekHeader__vertical, verticalScrollable && styles.DayPicker_weekHeader__verticalScrollable, weekHeaderStyle, {\n padding: \"0 \".concat(horizontalMonthPadding, \"px\")\n }), {\n key: \"week-\".concat(index)\n }), _react[\"default\"].createElement(\"ul\", (0, _reactWithStyles.css)(styles.DayPicker_weekHeader_ul), header));\n };\n\n _proto.render = function render() {\n var _this6 = this;\n\n var _this$state8 = this.state,\n calendarMonthWidth = _this$state8.calendarMonthWidth,\n currentMonth = _this$state8.currentMonth,\n monthTransition = _this$state8.monthTransition,\n translationValue = _this$state8.translationValue,\n scrollableMonthMultiple = _this$state8.scrollableMonthMultiple,\n focusedDate = _this$state8.focusedDate,\n showKeyboardShortcuts = _this$state8.showKeyboardShortcuts,\n isTouch = _this$state8.isTouchDevice,\n hasSetHeight = _this$state8.hasSetHeight,\n calendarInfoWidth = _this$state8.calendarInfoWidth,\n monthTitleHeight = _this$state8.monthTitleHeight;\n var _this$props12 = this.props,\n enableOutsideDays = _this$props12.enableOutsideDays,\n numberOfMonths = _this$props12.numberOfMonths,\n orientation = _this$props12.orientation,\n modifiers = _this$props12.modifiers,\n withPortal = _this$props12.withPortal,\n onDayClick = _this$props12.onDayClick,\n onDayMouseEnter = _this$props12.onDayMouseEnter,\n onDayMouseLeave = _this$props12.onDayMouseLeave,\n firstDayOfWeek = _this$props12.firstDayOfWeek,\n renderMonthText = _this$props12.renderMonthText,\n renderCalendarDay = _this$props12.renderCalendarDay,\n renderDayContents = _this$props12.renderDayContents,\n renderCalendarInfo = _this$props12.renderCalendarInfo,\n renderMonthElement = _this$props12.renderMonthElement,\n renderKeyboardShortcutsButton = _this$props12.renderKeyboardShortcutsButton,\n renderKeyboardShortcutsPanel = _this$props12.renderKeyboardShortcutsPanel,\n calendarInfoPosition = _this$props12.calendarInfoPosition,\n hideKeyboardShortcutsPanel = _this$props12.hideKeyboardShortcutsPanel,\n onOutsideClick = _this$props12.onOutsideClick,\n monthFormat = _this$props12.monthFormat,\n daySize = _this$props12.daySize,\n isFocused = _this$props12.isFocused,\n isRTL = _this$props12.isRTL,\n styles = _this$props12.styles,\n theme = _this$props12.theme,\n phrases = _this$props12.phrases,\n verticalHeight = _this$props12.verticalHeight,\n dayAriaLabelFormat = _this$props12.dayAriaLabelFormat,\n noBorder = _this$props12.noBorder,\n transitionDuration = _this$props12.transitionDuration,\n verticalBorderSpacing = _this$props12.verticalBorderSpacing,\n horizontalMonthPadding = _this$props12.horizontalMonthPadding,\n navPosition = _this$props12.navPosition;\n var dayPickerHorizontalPadding = theme.reactDates.spacing.dayPickerHorizontalPadding;\n var isHorizontal = this.isHorizontal();\n var numOfWeekHeaders = this.isVertical() ? 1 : numberOfMonths;\n var weekHeaders = [];\n\n for (var i = 0; i < numOfWeekHeaders; i += 1) {\n weekHeaders.push(this.renderWeekHeader(i));\n }\n\n var verticalScrollable = orientation === _constants.VERTICAL_SCROLLABLE;\n var height;\n\n if (isHorizontal) {\n height = this.calendarMonthGridHeight;\n } else if (this.isVertical() && !verticalScrollable && !withPortal) {\n // If the user doesn't set a desired height,\n // we default back to this kind of made-up value that generally looks good\n height = verticalHeight || 1.75 * calendarMonthWidth;\n }\n\n var isCalendarMonthGridAnimating = monthTransition !== null;\n var shouldFocusDate = !isCalendarMonthGridAnimating && isFocused;\n var keyboardShortcutButtonLocation = _DayPickerKeyboardShortcuts.BOTTOM_RIGHT;\n\n if (this.isVertical()) {\n keyboardShortcutButtonLocation = withPortal ? _DayPickerKeyboardShortcuts.TOP_LEFT : _DayPickerKeyboardShortcuts.TOP_RIGHT;\n }\n\n var shouldAnimateHeight = isHorizontal && hasSetHeight;\n var calendarInfoPositionTop = calendarInfoPosition === _constants.INFO_POSITION_TOP;\n var calendarInfoPositionBottom = calendarInfoPosition === _constants.INFO_POSITION_BOTTOM;\n var calendarInfoPositionBefore = calendarInfoPosition === _constants.INFO_POSITION_BEFORE;\n var calendarInfoPositionAfter = calendarInfoPosition === _constants.INFO_POSITION_AFTER;\n var calendarInfoIsInline = calendarInfoPositionBefore || calendarInfoPositionAfter;\n\n var calendarInfo = renderCalendarInfo && _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n ref: this.setCalendarInfoRef\n }, (0, _reactWithStyles.css)(calendarInfoIsInline && styles.DayPicker_calendarInfo__horizontal)), renderCalendarInfo());\n\n var calendarInfoPanelWidth = renderCalendarInfo && calendarInfoIsInline ? calendarInfoWidth : 0;\n var firstVisibleMonthIndex = this.getFirstVisibleIndex();\n var wrapperHorizontalWidth = calendarMonthWidth * numberOfMonths + 2 * dayPickerHorizontalPadding; // Adding `1px` because of whitespace between 2 inline-block\n\n var fullHorizontalWidth = wrapperHorizontalWidth + calendarInfoPanelWidth + 1;\n var transitionContainerStyle = {\n width: isHorizontal && wrapperHorizontalWidth,\n height: height\n };\n var dayPickerWrapperStyle = {\n width: isHorizontal && wrapperHorizontalWidth\n };\n var dayPickerStyle = {\n width: isHorizontal && fullHorizontalWidth,\n // These values are to center the datepicker (approximately) on the page\n marginLeft: isHorizontal && withPortal ? -fullHorizontalWidth / 2 : null,\n marginTop: isHorizontal && withPortal ? -calendarMonthWidth / 2 : null\n };\n return _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.DayPicker, isHorizontal && styles.DayPicker__horizontal, verticalScrollable && styles.DayPicker__verticalScrollable, isHorizontal && withPortal && styles.DayPicker_portal__horizontal, this.isVertical() && withPortal && styles.DayPicker_portal__vertical, dayPickerStyle, !monthTitleHeight && styles.DayPicker__hidden, !noBorder && styles.DayPicker__withBorder), _react[\"default\"].createElement(_reactOutsideClickHandler[\"default\"], {\n onOutsideClick: onOutsideClick\n }, (calendarInfoPositionTop || calendarInfoPositionBefore) && calendarInfo, _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(dayPickerWrapperStyle, calendarInfoIsInline && isHorizontal && styles.DayPicker_wrapper__horizontal), _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPicker_weekHeaders, isHorizontal && styles.DayPicker_weekHeaders__horizontal), {\n \"aria-hidden\": \"true\",\n role: \"presentation\"\n }), weekHeaders), _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPicker_focusRegion), {\n ref: this.setContainerRef,\n onClick: function onClick(e) {\n e.stopPropagation();\n },\n onKeyDown: this.onKeyDown,\n onMouseUp: function onMouseUp() {\n _this6.setState({\n withMouseInteractions: true\n });\n },\n tabIndex: -1,\n role: \"application\",\n \"aria-roledescription\": phrases.roleDescription,\n \"aria-label\": phrases.calendarLabel\n }), !verticalScrollable && navPosition === _constants.NAV_POSITION_TOP && this.renderNavigation(), _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DayPicker_transitionContainer, shouldAnimateHeight && styles.DayPicker_transitionContainer__horizontal, this.isVertical() && styles.DayPicker_transitionContainer__vertical, verticalScrollable && styles.DayPicker_transitionContainer__verticalScrollable, transitionContainerStyle), {\n ref: this.setTransitionContainerRef\n }), verticalScrollable && this.renderNavigation(PREV_NAV), _react[\"default\"].createElement(_CalendarMonthGrid[\"default\"], {\n setMonthTitleHeight: !monthTitleHeight ? this.setMonthTitleHeight : undefined,\n translationValue: translationValue,\n enableOutsideDays: enableOutsideDays,\n firstVisibleMonthIndex: firstVisibleMonthIndex,\n initialMonth: currentMonth,\n isAnimating: isCalendarMonthGridAnimating,\n modifiers: modifiers,\n orientation: orientation,\n numberOfMonths: numberOfMonths * scrollableMonthMultiple,\n onDayClick: onDayClick,\n onDayMouseEnter: onDayMouseEnter,\n onDayMouseLeave: onDayMouseLeave,\n onMonthChange: this.onMonthChange,\n onYearChange: this.onYearChange,\n renderMonthText: renderMonthText,\n renderCalendarDay: renderCalendarDay,\n renderDayContents: renderDayContents,\n renderMonthElement: renderMonthElement,\n onMonthTransitionEnd: this.updateStateAfterMonthTransition,\n monthFormat: monthFormat,\n daySize: daySize,\n firstDayOfWeek: firstDayOfWeek,\n isFocused: shouldFocusDate,\n focusedDate: focusedDate,\n phrases: phrases,\n isRTL: isRTL,\n dayAriaLabelFormat: dayAriaLabelFormat,\n transitionDuration: transitionDuration,\n verticalBorderSpacing: verticalBorderSpacing,\n horizontalMonthPadding: horizontalMonthPadding\n }), verticalScrollable && this.renderNavigation(NEXT_NAV)), !verticalScrollable && navPosition === _constants.NAV_POSITION_BOTTOM && this.renderNavigation(), !isTouch && !hideKeyboardShortcutsPanel && _react[\"default\"].createElement(_DayPickerKeyboardShortcuts[\"default\"], {\n block: this.isVertical() && !withPortal,\n buttonLocation: keyboardShortcutButtonLocation,\n showKeyboardShortcutsPanel: showKeyboardShortcuts,\n openKeyboardShortcutsPanel: this.openKeyboardShortcutsPanel,\n closeKeyboardShortcutsPanel: this.closeKeyboardShortcutsPanel,\n phrases: phrases,\n renderKeyboardShortcutsButton: renderKeyboardShortcutsButton,\n renderKeyboardShortcutsPanel: renderKeyboardShortcutsPanel\n }))), (calendarInfoPositionBottom || calendarInfoPositionAfter) && calendarInfo));\n };\n\n return DayPicker;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports.PureDayPicker = DayPicker;\nDayPicker.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDayPicker.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref4) {\n var _ref4$reactDates = _ref4.reactDates,\n color = _ref4$reactDates.color,\n font = _ref4$reactDates.font,\n noScrollBarOnVerticalScrollable = _ref4$reactDates.noScrollBarOnVerticalScrollable,\n spacing = _ref4$reactDates.spacing,\n zIndex = _ref4$reactDates.zIndex;\n return {\n DayPicker: {\n background: color.background,\n position: 'relative',\n textAlign: (0, _noflip[\"default\"])('left')\n },\n DayPicker__horizontal: {\n background: color.background\n },\n DayPicker__verticalScrollable: {\n height: '100%'\n },\n DayPicker__hidden: {\n visibility: 'hidden'\n },\n DayPicker__withBorder: {\n boxShadow: (0, _noflip[\"default\"])('0 2px 6px rgba(0, 0, 0, 0.05), 0 0 0 1px rgba(0, 0, 0, 0.07)'),\n borderRadius: 3\n },\n DayPicker_portal__horizontal: {\n boxShadow: 'none',\n position: 'absolute',\n left: (0, _noflip[\"default\"])('50%'),\n top: '50%'\n },\n DayPicker_portal__vertical: {\n position: 'initial'\n },\n DayPicker_focusRegion: {\n outline: 'none'\n },\n DayPicker_calendarInfo__horizontal: {\n display: 'inline-block',\n verticalAlign: 'top'\n },\n DayPicker_wrapper__horizontal: {\n display: 'inline-block',\n verticalAlign: 'top'\n },\n DayPicker_weekHeaders: {\n position: 'relative'\n },\n DayPicker_weekHeaders__horizontal: {\n marginLeft: (0, _noflip[\"default\"])(spacing.dayPickerHorizontalPadding)\n },\n DayPicker_weekHeader: {\n color: color.placeholderText,\n position: 'absolute',\n top: 62,\n zIndex: zIndex + 2,\n textAlign: (0, _noflip[\"default\"])('left')\n },\n DayPicker_weekHeader__vertical: {\n left: (0, _noflip[\"default\"])('50%')\n },\n DayPicker_weekHeader__verticalScrollable: {\n top: 0,\n display: 'table-row',\n borderBottom: \"1px solid \".concat(color.core.border),\n background: color.background,\n marginLeft: (0, _noflip[\"default\"])(0),\n left: (0, _noflip[\"default\"])(0),\n width: '100%',\n textAlign: 'center'\n },\n DayPicker_weekHeader_ul: {\n listStyle: 'none',\n margin: '1px 0',\n paddingLeft: (0, _noflip[\"default\"])(0),\n paddingRight: (0, _noflip[\"default\"])(0),\n fontSize: font.size\n },\n DayPicker_weekHeader_li: {\n display: 'inline-block',\n textAlign: 'center'\n },\n DayPicker_transitionContainer: {\n position: 'relative',\n overflow: 'hidden',\n borderRadius: 3\n },\n DayPicker_transitionContainer__horizontal: {\n transition: 'height 0.2s ease-in-out'\n },\n DayPicker_transitionContainer__vertical: {\n width: '100%'\n },\n DayPicker_transitionContainer__verticalScrollable: _objectSpread({\n paddingTop: 20,\n height: '100%',\n position: 'absolute',\n top: 0,\n bottom: 0,\n right: (0, _noflip[\"default\"])(0),\n left: (0, _noflip[\"default\"])(0),\n overflowY: 'scroll'\n }, noScrollBarOnVerticalScrollable && {\n '-webkitOverflowScrolling': 'touch',\n '::-webkit-scrollbar': {\n '-webkit-appearance': 'none',\n display: 'none'\n }\n })\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(DayPicker);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getPooledMoment;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar momentPool = new Map();\n\nfunction getPooledMoment(dayString) {\n if (!momentPool.has(dayString)) {\n momentPool.set(dayString, (0, _moment[\"default\"])(dayString));\n }\n\n return momentPool.get(dayString);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _object = _interopRequireDefault(require(\"object.values\"));\n\nvar _isTouchDevice = _interopRequireDefault(require(\"is-touch-device\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _isInclusivelyAfterDay = _interopRequireDefault(require(\"../utils/isInclusivelyAfterDay\"));\n\nvar _isNextDay = _interopRequireDefault(require(\"../utils/isNextDay\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"../utils/isSameDay\"));\n\nvar _isAfterDay = _interopRequireDefault(require(\"../utils/isAfterDay\"));\n\nvar _isBeforeDay = _interopRequireDefault(require(\"../utils/isBeforeDay\"));\n\nvar _isPreviousDay = _interopRequireDefault(require(\"../utils/isPreviousDay\"));\n\nvar _getVisibleDays = _interopRequireDefault(require(\"../utils/getVisibleDays\"));\n\nvar _isDayVisible = _interopRequireDefault(require(\"../utils/isDayVisible\"));\n\nvar _getSelectedDateOffset = _interopRequireDefault(require(\"../utils/getSelectedDateOffset\"));\n\nvar _toISODateString = _interopRequireDefault(require(\"../utils/toISODateString\"));\n\nvar _modifiers = require(\"../utils/modifiers\");\n\nvar _DisabledShape = _interopRequireDefault(require(\"../shapes/DisabledShape\"));\n\nvar _FocusedInputShape = _interopRequireDefault(require(\"../shapes/FocusedInputShape\"));\n\nvar _ScrollableOrientationShape = _interopRequireDefault(require(\"../shapes/ScrollableOrientationShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"../shapes/DayOfWeekShape\"));\n\nvar _CalendarInfoPositionShape = _interopRequireDefault(require(\"../shapes/CalendarInfoPositionShape\"));\n\nvar _NavPositionShape = _interopRequireDefault(require(\"../shapes/NavPositionShape\"));\n\nvar _constants = require(\"../constants\");\n\nvar _DayPicker = _interopRequireDefault(require(\"./DayPicker\"));\n\nvar _getPooledMoment = _interopRequireDefault(require(\"../utils/getPooledMoment\"));\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)({\n startDate: _reactMomentProptypes[\"default\"].momentObj,\n endDate: _reactMomentProptypes[\"default\"].momentObj,\n onDatesChange: _propTypes[\"default\"].func,\n startDateOffset: _propTypes[\"default\"].func,\n endDateOffset: _propTypes[\"default\"].func,\n minDate: _reactMomentProptypes[\"default\"].momentObj,\n maxDate: _reactMomentProptypes[\"default\"].momentObj,\n focusedInput: _FocusedInputShape[\"default\"],\n onFocusChange: _propTypes[\"default\"].func,\n onClose: _propTypes[\"default\"].func,\n keepOpenOnDateSelect: _propTypes[\"default\"].bool,\n minimumNights: _propTypes[\"default\"].number,\n disabled: _DisabledShape[\"default\"],\n isOutsideRange: _propTypes[\"default\"].func,\n isDayBlocked: _propTypes[\"default\"].func,\n isDayHighlighted: _propTypes[\"default\"].func,\n getMinNightsForHoverDate: _propTypes[\"default\"].func,\n daysViolatingMinNightsCanBeClicked: _propTypes[\"default\"].bool,\n // DayPicker props\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderWeekHeaderElement: _propTypes[\"default\"].func,\n enableOutsideDays: _propTypes[\"default\"].bool,\n numberOfMonths: _propTypes[\"default\"].number,\n orientation: _ScrollableOrientationShape[\"default\"],\n withPortal: _propTypes[\"default\"].bool,\n initialVisibleMonth: _propTypes[\"default\"].func,\n hideKeyboardShortcutsPanel: _propTypes[\"default\"].bool,\n daySize: _airbnbPropTypes.nonNegativeInteger,\n noBorder: _propTypes[\"default\"].bool,\n verticalBorderSpacing: _airbnbPropTypes.nonNegativeInteger,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n dayPickerNavigationInlineStyles: _propTypes[\"default\"].object,\n navPosition: _NavPositionShape[\"default\"],\n navPrev: _propTypes[\"default\"].node,\n navNext: _propTypes[\"default\"].node,\n renderNavPrevButton: _propTypes[\"default\"].func,\n renderNavNextButton: _propTypes[\"default\"].func,\n noNavButtons: _propTypes[\"default\"].bool,\n noNavNextButton: _propTypes[\"default\"].bool,\n noNavPrevButton: _propTypes[\"default\"].bool,\n onPrevMonthClick: _propTypes[\"default\"].func,\n onNextMonthClick: _propTypes[\"default\"].func,\n onOutsideClick: _propTypes[\"default\"].func,\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n renderCalendarInfo: _propTypes[\"default\"].func,\n renderKeyboardShortcutsButton: _propTypes[\"default\"].func,\n renderKeyboardShortcutsPanel: _propTypes[\"default\"].func,\n calendarInfoPosition: _CalendarInfoPositionShape[\"default\"],\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n verticalHeight: _airbnbPropTypes.nonNegativeInteger,\n transitionDuration: _airbnbPropTypes.nonNegativeInteger,\n // accessibility\n onBlur: _propTypes[\"default\"].func,\n isFocused: _propTypes[\"default\"].bool,\n showKeyboardShortcuts: _propTypes[\"default\"].bool,\n onTab: _propTypes[\"default\"].func,\n onShiftTab: _propTypes[\"default\"].func,\n // i18n\n monthFormat: _propTypes[\"default\"].string,\n weekDayFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DayPickerPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string,\n isRTL: _propTypes[\"default\"].bool\n}) : {};\nvar defaultProps = {\n startDate: undefined,\n // TODO: use null\n endDate: undefined,\n // TODO: use null\n minDate: null,\n maxDate: null,\n onDatesChange: function onDatesChange() {},\n startDateOffset: undefined,\n endDateOffset: undefined,\n focusedInput: null,\n onFocusChange: function onFocusChange() {},\n onClose: function onClose() {},\n keepOpenOnDateSelect: false,\n minimumNights: 1,\n disabled: false,\n isOutsideRange: function isOutsideRange() {},\n isDayBlocked: function isDayBlocked() {},\n isDayHighlighted: function isDayHighlighted() {},\n getMinNightsForHoverDate: function getMinNightsForHoverDate() {},\n daysViolatingMinNightsCanBeClicked: false,\n // DayPicker props\n renderMonthText: null,\n renderWeekHeaderElement: null,\n enableOutsideDays: false,\n numberOfMonths: 1,\n orientation: _constants.HORIZONTAL_ORIENTATION,\n withPortal: false,\n hideKeyboardShortcutsPanel: false,\n initialVisibleMonth: null,\n daySize: _constants.DAY_SIZE,\n dayPickerNavigationInlineStyles: null,\n navPosition: _constants.NAV_POSITION_TOP,\n navPrev: null,\n navNext: null,\n renderNavPrevButton: null,\n renderNavNextButton: null,\n noNavButtons: false,\n noNavNextButton: false,\n noNavPrevButton: false,\n onPrevMonthClick: function onPrevMonthClick() {},\n onNextMonthClick: function onNextMonthClick() {},\n onOutsideClick: function onOutsideClick() {},\n renderCalendarDay: undefined,\n renderDayContents: null,\n renderCalendarInfo: null,\n renderMonthElement: null,\n renderKeyboardShortcutsButton: undefined,\n renderKeyboardShortcutsPanel: undefined,\n calendarInfoPosition: _constants.INFO_POSITION_BOTTOM,\n firstDayOfWeek: null,\n verticalHeight: null,\n noBorder: false,\n transitionDuration: undefined,\n verticalBorderSpacing: undefined,\n horizontalMonthPadding: 13,\n // accessibility\n onBlur: function onBlur() {},\n isFocused: false,\n showKeyboardShortcuts: false,\n onTab: function onTab() {},\n onShiftTab: function onShiftTab() {},\n // i18n\n monthFormat: 'MMMM YYYY',\n weekDayFormat: 'dd',\n phrases: _defaultPhrases.DayPickerPhrases,\n dayAriaLabelFormat: undefined,\n isRTL: false\n};\n\nvar getChooseAvailableDatePhrase = function getChooseAvailableDatePhrase(phrases, focusedInput) {\n if (focusedInput === _constants.START_DATE) {\n return phrases.chooseAvailableStartDate;\n }\n\n if (focusedInput === _constants.END_DATE) {\n return phrases.chooseAvailableEndDate;\n }\n\n return phrases.chooseAvailableDate;\n};\n\nvar DayPickerRangeController =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DayPickerRangeController, _ref);\n var _proto = DayPickerRangeController.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DayPickerRangeController(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.isTouchDevice = (0, _isTouchDevice[\"default\"])();\n _this.today = (0, _moment[\"default\"])();\n _this.modifiers = {\n today: function today(day) {\n return _this.isToday(day);\n },\n blocked: function blocked(day) {\n return _this.isBlocked(day);\n },\n 'blocked-calendar': function blockedCalendar(day) {\n return props.isDayBlocked(day);\n },\n 'blocked-out-of-range': function blockedOutOfRange(day) {\n return props.isOutsideRange(day);\n },\n 'highlighted-calendar': function highlightedCalendar(day) {\n return props.isDayHighlighted(day);\n },\n valid: function valid(day) {\n return !_this.isBlocked(day);\n },\n 'selected-start': function selectedStart(day) {\n return _this.isStartDate(day);\n },\n 'selected-end': function selectedEnd(day) {\n return _this.isEndDate(day);\n },\n 'blocked-minimum-nights': function blockedMinimumNights(day) {\n return _this.doesNotMeetMinimumNights(day);\n },\n 'selected-span': function selectedSpan(day) {\n return _this.isInSelectedSpan(day);\n },\n 'last-in-range': function lastInRange(day) {\n return _this.isLastInRange(day);\n },\n hovered: function hovered(day) {\n return _this.isHovered(day);\n },\n 'hovered-span': function hoveredSpan(day) {\n return _this.isInHoveredSpan(day);\n },\n 'hovered-offset': function hoveredOffset(day) {\n return _this.isInHoveredSpan(day);\n },\n 'after-hovered-start': function afterHoveredStart(day) {\n return _this.isDayAfterHoveredStartDate(day);\n },\n 'first-day-of-week': function firstDayOfWeek(day) {\n return _this.isFirstDayOfWeek(day);\n },\n 'last-day-of-week': function lastDayOfWeek(day) {\n return _this.isLastDayOfWeek(day);\n },\n 'hovered-start-first-possible-end': function hoveredStartFirstPossibleEnd(day, hoverDate) {\n return _this.isFirstPossibleEndDateForHoveredStartDate(day, hoverDate);\n },\n 'hovered-start-blocked-minimum-nights': function hoveredStartBlockedMinimumNights(day, hoverDate) {\n return _this.doesNotMeetMinNightsForHoveredStartDate(day, hoverDate);\n },\n 'before-hovered-end': function beforeHoveredEnd(day) {\n return _this.isDayBeforeHoveredEndDate(day);\n },\n 'no-selected-start-before-selected-end': function noSelectedStartBeforeSelectedEnd(day) {\n return _this.beforeSelectedEnd(day) && !props.startDate;\n },\n 'selected-start-in-hovered-span': function selectedStartInHoveredSpan(day, hoverDate) {\n return _this.isStartDate(day) && (0, _isAfterDay[\"default\"])(hoverDate, day);\n },\n 'selected-start-no-selected-end': function selectedStartNoSelectedEnd(day) {\n return _this.isStartDate(day) && !props.endDate;\n },\n 'selected-end-no-selected-start': function selectedEndNoSelectedStart(day) {\n return _this.isEndDate(day) && !props.startDate;\n }\n };\n\n var _this$getStateForNewM = _this.getStateForNewMonth(props),\n currentMonth = _this$getStateForNewM.currentMonth,\n visibleDays = _this$getStateForNewM.visibleDays; // initialize phrases\n // set the appropriate CalendarDay phrase based on focusedInput\n\n\n var chooseAvailableDate = getChooseAvailableDatePhrase(props.phrases, props.focusedInput);\n _this.state = {\n hoverDate: null,\n currentMonth: currentMonth,\n phrases: _objectSpread({}, props.phrases, {\n chooseAvailableDate: chooseAvailableDate\n }),\n visibleDays: visibleDays,\n disablePrev: _this.shouldDisableMonthNavigation(props.minDate, currentMonth),\n disableNext: _this.shouldDisableMonthNavigation(props.maxDate, currentMonth)\n };\n _this.onDayClick = _this.onDayClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayMouseEnter = _this.onDayMouseEnter.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayMouseLeave = _this.onDayMouseLeave.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onPrevMonthClick = _this.onPrevMonthClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onNextMonthClick = _this.onNextMonthClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onMonthChange = _this.onMonthChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onYearChange = _this.onYearChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onGetNextScrollableMonths = _this.onGetNextScrollableMonths.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onGetPrevScrollableMonths = _this.onGetPrevScrollableMonths.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.getFirstFocusableDay = _this.getFirstFocusableDay.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var _this2 = this;\n\n var startDate = nextProps.startDate,\n endDate = nextProps.endDate,\n focusedInput = nextProps.focusedInput,\n getMinNightsForHoverDate = nextProps.getMinNightsForHoverDate,\n minimumNights = nextProps.minimumNights,\n isOutsideRange = nextProps.isOutsideRange,\n isDayBlocked = nextProps.isDayBlocked,\n isDayHighlighted = nextProps.isDayHighlighted,\n phrases = nextProps.phrases,\n initialVisibleMonth = nextProps.initialVisibleMonth,\n numberOfMonths = nextProps.numberOfMonths,\n enableOutsideDays = nextProps.enableOutsideDays;\n var _this$props = this.props,\n prevStartDate = _this$props.startDate,\n prevEndDate = _this$props.endDate,\n prevFocusedInput = _this$props.focusedInput,\n prevMinimumNights = _this$props.minimumNights,\n prevIsOutsideRange = _this$props.isOutsideRange,\n prevIsDayBlocked = _this$props.isDayBlocked,\n prevIsDayHighlighted = _this$props.isDayHighlighted,\n prevPhrases = _this$props.phrases,\n prevInitialVisibleMonth = _this$props.initialVisibleMonth,\n prevNumberOfMonths = _this$props.numberOfMonths,\n prevEnableOutsideDays = _this$props.enableOutsideDays;\n var hoverDate = this.state.hoverDate;\n var visibleDays = this.state.visibleDays;\n var recomputeOutsideRange = false;\n var recomputeDayBlocked = false;\n var recomputeDayHighlighted = false;\n\n if (isOutsideRange !== prevIsOutsideRange) {\n this.modifiers['blocked-out-of-range'] = function (day) {\n return isOutsideRange(day);\n };\n\n recomputeOutsideRange = true;\n }\n\n if (isDayBlocked !== prevIsDayBlocked) {\n this.modifiers['blocked-calendar'] = function (day) {\n return isDayBlocked(day);\n };\n\n recomputeDayBlocked = true;\n }\n\n if (isDayHighlighted !== prevIsDayHighlighted) {\n this.modifiers['highlighted-calendar'] = function (day) {\n return isDayHighlighted(day);\n };\n\n recomputeDayHighlighted = true;\n }\n\n var recomputePropModifiers = recomputeOutsideRange || recomputeDayBlocked || recomputeDayHighlighted;\n var didStartDateChange = startDate !== prevStartDate;\n var didEndDateChange = endDate !== prevEndDate;\n var didFocusChange = focusedInput !== prevFocusedInput;\n\n if (numberOfMonths !== prevNumberOfMonths || enableOutsideDays !== prevEnableOutsideDays || initialVisibleMonth !== prevInitialVisibleMonth && !prevFocusedInput && didFocusChange) {\n var newMonthState = this.getStateForNewMonth(nextProps);\n var currentMonth = newMonthState.currentMonth;\n visibleDays = newMonthState.visibleDays;\n this.setState({\n currentMonth: currentMonth,\n visibleDays: visibleDays\n });\n }\n\n var modifiers = {};\n\n if (didStartDateChange) {\n modifiers = this.deleteModifier(modifiers, prevStartDate, 'selected-start');\n modifiers = this.addModifier(modifiers, startDate, 'selected-start');\n\n if (prevStartDate) {\n var startSpan = prevStartDate.clone().add(1, 'day');\n var endSpan = prevStartDate.clone().add(prevMinimumNights + 1, 'days');\n modifiers = this.deleteModifierFromRange(modifiers, startSpan, endSpan, 'after-hovered-start');\n\n if (!endDate || !prevEndDate) {\n modifiers = this.deleteModifier(modifiers, prevStartDate, 'selected-start-no-selected-end');\n }\n }\n\n if (!prevStartDate && endDate && startDate) {\n modifiers = this.deleteModifier(modifiers, endDate, 'selected-end-no-selected-start');\n modifiers = this.deleteModifier(modifiers, endDate, 'selected-end-in-hovered-span');\n (0, _object[\"default\"])(visibleDays).forEach(function (days) {\n Object.keys(days).forEach(function (day) {\n var momentObj = (0, _moment[\"default\"])(day);\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'no-selected-start-before-selected-end');\n });\n });\n }\n }\n\n if (didEndDateChange) {\n modifiers = this.deleteModifier(modifiers, prevEndDate, 'selected-end');\n modifiers = this.addModifier(modifiers, endDate, 'selected-end');\n\n if (prevEndDate && (!startDate || !prevStartDate)) {\n modifiers = this.deleteModifier(modifiers, prevEndDate, 'selected-end-no-selected-start');\n }\n }\n\n if (didStartDateChange || didEndDateChange) {\n if (prevStartDate && prevEndDate) {\n modifiers = this.deleteModifierFromRange(modifiers, prevStartDate, prevEndDate.clone().add(1, 'day'), 'selected-span');\n }\n\n if (startDate && endDate) {\n modifiers = this.deleteModifierFromRange(modifiers, startDate, endDate.clone().add(1, 'day'), 'hovered-span');\n modifiers = this.addModifierToRange(modifiers, startDate.clone().add(1, 'day'), endDate, 'selected-span');\n }\n\n if (startDate && !endDate) {\n modifiers = this.addModifier(modifiers, startDate, 'selected-start-no-selected-end');\n }\n\n if (endDate && !startDate) {\n modifiers = this.addModifier(modifiers, endDate, 'selected-end-no-selected-start');\n }\n\n if (!startDate && endDate) {\n (0, _object[\"default\"])(visibleDays).forEach(function (days) {\n Object.keys(days).forEach(function (day) {\n var momentObj = (0, _moment[\"default\"])(day);\n\n if ((0, _isBeforeDay[\"default\"])(momentObj, endDate)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'no-selected-start-before-selected-end');\n }\n });\n });\n }\n }\n\n if (!this.isTouchDevice && didStartDateChange && startDate && !endDate) {\n var _startSpan = startDate.clone().add(1, 'day');\n\n var _endSpan = startDate.clone().add(minimumNights + 1, 'days');\n\n modifiers = this.addModifierToRange(modifiers, _startSpan, _endSpan, 'after-hovered-start');\n }\n\n if (!this.isTouchDevice && didEndDateChange && !startDate && endDate) {\n var _startSpan2 = endDate.clone().subtract(minimumNights, 'days');\n\n var _endSpan2 = endDate.clone();\n\n modifiers = this.addModifierToRange(modifiers, _startSpan2, _endSpan2, 'before-hovered-end');\n }\n\n if (prevMinimumNights > 0) {\n if (didFocusChange || didStartDateChange || minimumNights !== prevMinimumNights) {\n var _startSpan3 = prevStartDate || this.today;\n\n modifiers = this.deleteModifierFromRange(modifiers, _startSpan3, _startSpan3.clone().add(prevMinimumNights, 'days'), 'blocked-minimum-nights');\n modifiers = this.deleteModifierFromRange(modifiers, _startSpan3, _startSpan3.clone().add(prevMinimumNights, 'days'), 'blocked');\n }\n }\n\n if (didFocusChange || recomputePropModifiers) {\n (0, _object[\"default\"])(visibleDays).forEach(function (days) {\n Object.keys(days).forEach(function (day) {\n var momentObj = (0, _getPooledMoment[\"default\"])(day);\n var isBlocked = false;\n\n if (didFocusChange || recomputeOutsideRange) {\n if (isOutsideRange(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'blocked-out-of-range');\n isBlocked = true;\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'blocked-out-of-range');\n }\n }\n\n if (didFocusChange || recomputeDayBlocked) {\n if (isDayBlocked(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'blocked-calendar');\n isBlocked = true;\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'blocked-calendar');\n }\n }\n\n if (isBlocked) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'blocked');\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'blocked');\n }\n\n if (didFocusChange || recomputeDayHighlighted) {\n if (isDayHighlighted(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'highlighted-calendar');\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'highlighted-calendar');\n }\n }\n });\n });\n }\n\n if (!this.isTouchDevice && didFocusChange && hoverDate && !this.isBlocked(hoverDate)) {\n var minNightsForHoverDate = getMinNightsForHoverDate(hoverDate);\n\n if (minNightsForHoverDate > 0 && focusedInput === _constants.END_DATE) {\n modifiers = this.deleteModifierFromRange(modifiers, hoverDate.clone().add(1, 'days'), hoverDate.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-blocked-minimum-nights');\n modifiers = this.deleteModifier(modifiers, hoverDate.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-first-possible-end');\n }\n\n if (minNightsForHoverDate > 0 && focusedInput === _constants.START_DATE) {\n modifiers = this.addModifierToRange(modifiers, hoverDate.clone().add(1, 'days'), hoverDate.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-blocked-minimum-nights');\n modifiers = this.addModifier(modifiers, hoverDate.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-first-possible-end');\n }\n }\n\n if (minimumNights > 0 && startDate && focusedInput === _constants.END_DATE) {\n modifiers = this.addModifierToRange(modifiers, startDate, startDate.clone().add(minimumNights, 'days'), 'blocked-minimum-nights');\n modifiers = this.addModifierToRange(modifiers, startDate, startDate.clone().add(minimumNights, 'days'), 'blocked');\n }\n\n var today = (0, _moment[\"default\"])();\n\n if (!(0, _isSameDay[\"default\"])(this.today, today)) {\n modifiers = this.deleteModifier(modifiers, this.today, 'today');\n modifiers = this.addModifier(modifiers, today, 'today');\n this.today = today;\n }\n\n if (Object.keys(modifiers).length > 0) {\n this.setState({\n visibleDays: _objectSpread({}, visibleDays, {}, modifiers)\n });\n }\n\n if (didFocusChange || phrases !== prevPhrases) {\n // set the appropriate CalendarDay phrase based on focusedInput\n var chooseAvailableDate = getChooseAvailableDatePhrase(phrases, focusedInput);\n this.setState({\n phrases: _objectSpread({}, phrases, {\n chooseAvailableDate: chooseAvailableDate\n })\n });\n }\n };\n\n _proto.onDayClick = function onDayClick(day, e) {\n var _this$props2 = this.props,\n keepOpenOnDateSelect = _this$props2.keepOpenOnDateSelect,\n minimumNights = _this$props2.minimumNights,\n onBlur = _this$props2.onBlur,\n focusedInput = _this$props2.focusedInput,\n onFocusChange = _this$props2.onFocusChange,\n onClose = _this$props2.onClose,\n onDatesChange = _this$props2.onDatesChange,\n startDateOffset = _this$props2.startDateOffset,\n endDateOffset = _this$props2.endDateOffset,\n disabled = _this$props2.disabled,\n daysViolatingMinNightsCanBeClicked = _this$props2.daysViolatingMinNightsCanBeClicked;\n if (e) e.preventDefault();\n if (this.isBlocked(day, !daysViolatingMinNightsCanBeClicked)) return;\n var _this$props3 = this.props,\n startDate = _this$props3.startDate,\n endDate = _this$props3.endDate;\n\n if (startDateOffset || endDateOffset) {\n startDate = (0, _getSelectedDateOffset[\"default\"])(startDateOffset, day);\n endDate = (0, _getSelectedDateOffset[\"default\"])(endDateOffset, day);\n\n if (this.isBlocked(startDate) || this.isBlocked(endDate)) {\n return;\n }\n\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n\n if (!keepOpenOnDateSelect) {\n onFocusChange(null);\n onClose({\n startDate: startDate,\n endDate: endDate\n });\n }\n } else if (focusedInput === _constants.START_DATE) {\n var lastAllowedStartDate = endDate && endDate.clone().subtract(minimumNights, 'days');\n var isStartDateAfterEndDate = (0, _isBeforeDay[\"default\"])(lastAllowedStartDate, day) || (0, _isAfterDay[\"default\"])(startDate, endDate);\n var isEndDateDisabled = disabled === _constants.END_DATE;\n\n if (!isEndDateDisabled || !isStartDateAfterEndDate) {\n startDate = day;\n\n if (isStartDateAfterEndDate) {\n endDate = null;\n }\n }\n\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n\n if (isEndDateDisabled && !isStartDateAfterEndDate) {\n onFocusChange(null);\n onClose({\n startDate: startDate,\n endDate: endDate\n });\n } else if (!isEndDateDisabled) {\n onFocusChange(_constants.END_DATE);\n }\n } else if (focusedInput === _constants.END_DATE) {\n var firstAllowedEndDate = startDate && startDate.clone().add(minimumNights, 'days');\n\n if (!startDate) {\n endDate = day;\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n onFocusChange(_constants.START_DATE);\n } else if ((0, _isInclusivelyAfterDay[\"default\"])(day, firstAllowedEndDate)) {\n endDate = day;\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n\n if (!keepOpenOnDateSelect) {\n onFocusChange(null);\n onClose({\n startDate: startDate,\n endDate: endDate\n });\n }\n } else if (daysViolatingMinNightsCanBeClicked && this.doesNotMeetMinimumNights(day)) {\n endDate = day;\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n } else if (disabled !== _constants.START_DATE) {\n startDate = day;\n endDate = null;\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n } else {\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n }\n } else {\n onDatesChange({\n startDate: startDate,\n endDate: endDate\n });\n }\n\n onBlur();\n };\n\n _proto.onDayMouseEnter = function onDayMouseEnter(day) {\n /* eslint react/destructuring-assignment: 1 */\n if (this.isTouchDevice) return;\n var _this$props4 = this.props,\n startDate = _this$props4.startDate,\n endDate = _this$props4.endDate,\n focusedInput = _this$props4.focusedInput,\n getMinNightsForHoverDate = _this$props4.getMinNightsForHoverDate,\n minimumNights = _this$props4.minimumNights,\n startDateOffset = _this$props4.startDateOffset,\n endDateOffset = _this$props4.endDateOffset;\n var _this$state = this.state,\n hoverDate = _this$state.hoverDate,\n visibleDays = _this$state.visibleDays,\n dateOffset = _this$state.dateOffset;\n var nextDateOffset = null;\n\n if (focusedInput) {\n var hasOffset = startDateOffset || endDateOffset;\n var modifiers = {};\n\n if (hasOffset) {\n var start = (0, _getSelectedDateOffset[\"default\"])(startDateOffset, day);\n var end = (0, _getSelectedDateOffset[\"default\"])(endDateOffset, day, function (rangeDay) {\n return rangeDay.add(1, 'day');\n });\n nextDateOffset = {\n start: start,\n end: end\n }; // eslint-disable-next-line react/destructuring-assignment\n\n if (dateOffset && dateOffset.start && dateOffset.end) {\n modifiers = this.deleteModifierFromRange(modifiers, dateOffset.start, dateOffset.end, 'hovered-offset');\n }\n\n modifiers = this.addModifierToRange(modifiers, start, end, 'hovered-offset');\n }\n\n if (!hasOffset) {\n modifiers = this.deleteModifier(modifiers, hoverDate, 'hovered');\n modifiers = this.addModifier(modifiers, day, 'hovered');\n\n if (startDate && !endDate && focusedInput === _constants.END_DATE) {\n if ((0, _isAfterDay[\"default\"])(hoverDate, startDate)) {\n var endSpan = hoverDate.clone().add(1, 'day');\n modifiers = this.deleteModifierFromRange(modifiers, startDate, endSpan, 'hovered-span');\n }\n\n if ((0, _isBeforeDay[\"default\"])(day, startDate) || (0, _isSameDay[\"default\"])(day, startDate)) {\n modifiers = this.deleteModifier(modifiers, startDate, 'selected-start-in-hovered-span');\n }\n\n if (!this.isBlocked(day) && (0, _isAfterDay[\"default\"])(day, startDate)) {\n var _endSpan3 = day.clone().add(1, 'day');\n\n modifiers = this.addModifierToRange(modifiers, startDate, _endSpan3, 'hovered-span');\n modifiers = this.addModifier(modifiers, startDate, 'selected-start-in-hovered-span');\n }\n }\n\n if (!startDate && endDate && focusedInput === _constants.START_DATE) {\n if ((0, _isBeforeDay[\"default\"])(hoverDate, endDate)) {\n modifiers = this.deleteModifierFromRange(modifiers, hoverDate, endDate, 'hovered-span');\n }\n\n if ((0, _isAfterDay[\"default\"])(day, endDate) || (0, _isSameDay[\"default\"])(day, endDate)) {\n modifiers = this.deleteModifier(modifiers, endDate, 'selected-end-in-hovered-span');\n }\n\n if (!this.isBlocked(day) && (0, _isBeforeDay[\"default\"])(day, endDate)) {\n modifiers = this.addModifierToRange(modifiers, day, endDate, 'hovered-span');\n modifiers = this.addModifier(modifiers, endDate, 'selected-end-in-hovered-span');\n }\n }\n\n if (startDate) {\n var startSpan = startDate.clone().add(1, 'day');\n\n var _endSpan4 = startDate.clone().add(minimumNights + 1, 'days');\n\n modifiers = this.deleteModifierFromRange(modifiers, startSpan, _endSpan4, 'after-hovered-start');\n\n if ((0, _isSameDay[\"default\"])(day, startDate)) {\n var newStartSpan = startDate.clone().add(1, 'day');\n var newEndSpan = startDate.clone().add(minimumNights + 1, 'days');\n modifiers = this.addModifierToRange(modifiers, newStartSpan, newEndSpan, 'after-hovered-start');\n }\n }\n\n if (endDate) {\n var _startSpan4 = endDate.clone().subtract(minimumNights, 'days');\n\n modifiers = this.deleteModifierFromRange(modifiers, _startSpan4, endDate, 'before-hovered-end');\n\n if ((0, _isSameDay[\"default\"])(day, endDate)) {\n var _newStartSpan = endDate.clone().subtract(minimumNights, 'days');\n\n modifiers = this.addModifierToRange(modifiers, _newStartSpan, endDate, 'before-hovered-end');\n }\n }\n\n if (hoverDate && !this.isBlocked(hoverDate)) {\n var minNightsForPrevHoverDate = getMinNightsForHoverDate(hoverDate);\n\n if (minNightsForPrevHoverDate > 0 && focusedInput === _constants.START_DATE) {\n modifiers = this.deleteModifierFromRange(modifiers, hoverDate.clone().add(1, 'days'), hoverDate.clone().add(minNightsForPrevHoverDate, 'days'), 'hovered-start-blocked-minimum-nights');\n modifiers = this.deleteModifier(modifiers, hoverDate.clone().add(minNightsForPrevHoverDate, 'days'), 'hovered-start-first-possible-end');\n }\n }\n\n if (!this.isBlocked(day)) {\n var minNightsForHoverDate = getMinNightsForHoverDate(day);\n\n if (minNightsForHoverDate > 0 && focusedInput === _constants.START_DATE) {\n modifiers = this.addModifierToRange(modifiers, day.clone().add(1, 'days'), day.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-blocked-minimum-nights');\n modifiers = this.addModifier(modifiers, day.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-first-possible-end');\n }\n }\n }\n\n this.setState({\n hoverDate: day,\n dateOffset: nextDateOffset,\n visibleDays: _objectSpread({}, visibleDays, {}, modifiers)\n });\n }\n };\n\n _proto.onDayMouseLeave = function onDayMouseLeave(day) {\n var _this$props5 = this.props,\n startDate = _this$props5.startDate,\n endDate = _this$props5.endDate,\n focusedInput = _this$props5.focusedInput,\n getMinNightsForHoverDate = _this$props5.getMinNightsForHoverDate,\n minimumNights = _this$props5.minimumNights;\n var _this$state2 = this.state,\n hoverDate = _this$state2.hoverDate,\n visibleDays = _this$state2.visibleDays,\n dateOffset = _this$state2.dateOffset;\n if (this.isTouchDevice || !hoverDate) return;\n var modifiers = {};\n modifiers = this.deleteModifier(modifiers, hoverDate, 'hovered');\n\n if (dateOffset) {\n modifiers = this.deleteModifierFromRange(modifiers, dateOffset.start, dateOffset.end, 'hovered-offset');\n }\n\n if (startDate && !endDate) {\n if ((0, _isAfterDay[\"default\"])(hoverDate, startDate)) {\n var endSpan = hoverDate.clone().add(1, 'day');\n modifiers = this.deleteModifierFromRange(modifiers, startDate, endSpan, 'hovered-span');\n }\n\n if ((0, _isAfterDay[\"default\"])(day, startDate)) {\n modifiers = this.deleteModifier(modifiers, startDate, 'selected-start-in-hovered-span');\n }\n }\n\n if (!startDate && endDate) {\n if ((0, _isAfterDay[\"default\"])(endDate, hoverDate)) {\n modifiers = this.deleteModifierFromRange(modifiers, hoverDate, endDate, 'hovered-span');\n }\n\n if ((0, _isBeforeDay[\"default\"])(day, endDate)) {\n modifiers = this.deleteModifier(modifiers, endDate, 'selected-end-in-hovered-span');\n }\n }\n\n if (startDate && (0, _isSameDay[\"default\"])(day, startDate)) {\n var startSpan = startDate.clone().add(1, 'day');\n\n var _endSpan5 = startDate.clone().add(minimumNights + 1, 'days');\n\n modifiers = this.deleteModifierFromRange(modifiers, startSpan, _endSpan5, 'after-hovered-start');\n }\n\n if (endDate && (0, _isSameDay[\"default\"])(day, endDate)) {\n var _startSpan5 = endDate.clone().subtract(minimumNights, 'days');\n\n modifiers = this.deleteModifierFromRange(modifiers, _startSpan5, endDate, 'before-hovered-end');\n }\n\n if (!this.isBlocked(hoverDate)) {\n var minNightsForHoverDate = getMinNightsForHoverDate(hoverDate);\n\n if (minNightsForHoverDate > 0 && focusedInput === _constants.START_DATE) {\n modifiers = this.deleteModifierFromRange(modifiers, hoverDate.clone().add(1, 'days'), hoverDate.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-blocked-minimum-nights');\n modifiers = this.deleteModifier(modifiers, hoverDate.clone().add(minNightsForHoverDate, 'days'), 'hovered-start-first-possible-end');\n }\n }\n\n this.setState({\n hoverDate: null,\n visibleDays: _objectSpread({}, visibleDays, {}, modifiers)\n });\n };\n\n _proto.onPrevMonthClick = function onPrevMonthClick() {\n var _this$props6 = this.props,\n enableOutsideDays = _this$props6.enableOutsideDays,\n maxDate = _this$props6.maxDate,\n minDate = _this$props6.minDate,\n numberOfMonths = _this$props6.numberOfMonths,\n onPrevMonthClick = _this$props6.onPrevMonthClick;\n var _this$state3 = this.state,\n currentMonth = _this$state3.currentMonth,\n visibleDays = _this$state3.visibleDays;\n var newVisibleDays = {};\n Object.keys(visibleDays).sort().slice(0, numberOfMonths + 1).forEach(function (month) {\n newVisibleDays[month] = visibleDays[month];\n });\n var prevMonth = currentMonth.clone().subtract(2, 'months');\n var prevMonthVisibleDays = (0, _getVisibleDays[\"default\"])(prevMonth, 1, enableOutsideDays, true);\n var newCurrentMonth = currentMonth.clone().subtract(1, 'month');\n this.setState({\n currentMonth: newCurrentMonth,\n disablePrev: this.shouldDisableMonthNavigation(minDate, newCurrentMonth),\n disableNext: this.shouldDisableMonthNavigation(maxDate, newCurrentMonth),\n visibleDays: _objectSpread({}, newVisibleDays, {}, this.getModifiers(prevMonthVisibleDays))\n }, function () {\n onPrevMonthClick(newCurrentMonth.clone());\n });\n };\n\n _proto.onNextMonthClick = function onNextMonthClick() {\n var _this$props7 = this.props,\n enableOutsideDays = _this$props7.enableOutsideDays,\n maxDate = _this$props7.maxDate,\n minDate = _this$props7.minDate,\n numberOfMonths = _this$props7.numberOfMonths,\n onNextMonthClick = _this$props7.onNextMonthClick;\n var _this$state4 = this.state,\n currentMonth = _this$state4.currentMonth,\n visibleDays = _this$state4.visibleDays;\n var newVisibleDays = {};\n Object.keys(visibleDays).sort().slice(1).forEach(function (month) {\n newVisibleDays[month] = visibleDays[month];\n });\n var nextMonth = currentMonth.clone().add(numberOfMonths + 1, 'month');\n var nextMonthVisibleDays = (0, _getVisibleDays[\"default\"])(nextMonth, 1, enableOutsideDays, true);\n var newCurrentMonth = currentMonth.clone().add(1, 'month');\n this.setState({\n currentMonth: newCurrentMonth,\n disablePrev: this.shouldDisableMonthNavigation(minDate, newCurrentMonth),\n disableNext: this.shouldDisableMonthNavigation(maxDate, newCurrentMonth),\n visibleDays: _objectSpread({}, newVisibleDays, {}, this.getModifiers(nextMonthVisibleDays))\n }, function () {\n onNextMonthClick(newCurrentMonth.clone());\n });\n };\n\n _proto.onMonthChange = function onMonthChange(newMonth) {\n var _this$props8 = this.props,\n numberOfMonths = _this$props8.numberOfMonths,\n enableOutsideDays = _this$props8.enableOutsideDays,\n orientation = _this$props8.orientation;\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(newMonth, numberOfMonths, enableOutsideDays, withoutTransitionMonths);\n this.setState({\n currentMonth: newMonth.clone(),\n visibleDays: this.getModifiers(newVisibleDays)\n });\n };\n\n _proto.onYearChange = function onYearChange(newMonth) {\n var _this$props9 = this.props,\n numberOfMonths = _this$props9.numberOfMonths,\n enableOutsideDays = _this$props9.enableOutsideDays,\n orientation = _this$props9.orientation;\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(newMonth, numberOfMonths, enableOutsideDays, withoutTransitionMonths);\n this.setState({\n currentMonth: newMonth.clone(),\n visibleDays: this.getModifiers(newVisibleDays)\n });\n };\n\n _proto.onGetNextScrollableMonths = function onGetNextScrollableMonths() {\n var _this$props10 = this.props,\n numberOfMonths = _this$props10.numberOfMonths,\n enableOutsideDays = _this$props10.enableOutsideDays;\n var _this$state5 = this.state,\n currentMonth = _this$state5.currentMonth,\n visibleDays = _this$state5.visibleDays;\n var numberOfVisibleMonths = Object.keys(visibleDays).length;\n var nextMonth = currentMonth.clone().add(numberOfVisibleMonths, 'month');\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(nextMonth, numberOfMonths, enableOutsideDays, true);\n this.setState({\n visibleDays: _objectSpread({}, visibleDays, {}, this.getModifiers(newVisibleDays))\n });\n };\n\n _proto.onGetPrevScrollableMonths = function onGetPrevScrollableMonths() {\n var _this$props11 = this.props,\n numberOfMonths = _this$props11.numberOfMonths,\n enableOutsideDays = _this$props11.enableOutsideDays;\n var _this$state6 = this.state,\n currentMonth = _this$state6.currentMonth,\n visibleDays = _this$state6.visibleDays;\n var firstPreviousMonth = currentMonth.clone().subtract(numberOfMonths, 'month');\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(firstPreviousMonth, numberOfMonths, enableOutsideDays, true);\n this.setState({\n currentMonth: firstPreviousMonth.clone(),\n visibleDays: _objectSpread({}, visibleDays, {}, this.getModifiers(newVisibleDays))\n });\n };\n\n _proto.getFirstFocusableDay = function getFirstFocusableDay(newMonth) {\n var _this3 = this;\n\n var _this$props12 = this.props,\n startDate = _this$props12.startDate,\n endDate = _this$props12.endDate,\n focusedInput = _this$props12.focusedInput,\n minimumNights = _this$props12.minimumNights,\n numberOfMonths = _this$props12.numberOfMonths;\n var focusedDate = newMonth.clone().startOf('month');\n\n if (focusedInput === _constants.START_DATE && startDate) {\n focusedDate = startDate.clone();\n } else if (focusedInput === _constants.END_DATE && !endDate && startDate) {\n focusedDate = startDate.clone().add(minimumNights, 'days');\n } else if (focusedInput === _constants.END_DATE && endDate) {\n focusedDate = endDate.clone();\n }\n\n if (this.isBlocked(focusedDate)) {\n var days = [];\n var lastVisibleDay = newMonth.clone().add(numberOfMonths - 1, 'months').endOf('month');\n var currentDay = focusedDate.clone();\n\n while (!(0, _isAfterDay[\"default\"])(currentDay, lastVisibleDay)) {\n currentDay = currentDay.clone().add(1, 'day');\n days.push(currentDay);\n }\n\n var viableDays = days.filter(function (day) {\n return !_this3.isBlocked(day);\n });\n\n if (viableDays.length > 0) {\n var _viableDays = (0, _slicedToArray2[\"default\"])(viableDays, 1);\n\n focusedDate = _viableDays[0];\n }\n }\n\n return focusedDate;\n };\n\n _proto.getModifiers = function getModifiers(visibleDays) {\n var _this4 = this;\n\n var modifiers = {};\n Object.keys(visibleDays).forEach(function (month) {\n modifiers[month] = {};\n visibleDays[month].forEach(function (day) {\n modifiers[month][(0, _toISODateString[\"default\"])(day)] = _this4.getModifiersForDay(day);\n });\n });\n return modifiers;\n };\n\n _proto.getModifiersForDay = function getModifiersForDay(day) {\n var _this5 = this;\n\n return new Set(Object.keys(this.modifiers).filter(function (modifier) {\n return _this5.modifiers[modifier](day);\n }));\n };\n\n _proto.getStateForNewMonth = function getStateForNewMonth(nextProps) {\n var _this6 = this;\n\n var initialVisibleMonth = nextProps.initialVisibleMonth,\n numberOfMonths = nextProps.numberOfMonths,\n enableOutsideDays = nextProps.enableOutsideDays,\n orientation = nextProps.orientation,\n startDate = nextProps.startDate;\n var initialVisibleMonthThunk = initialVisibleMonth || (startDate ? function () {\n return startDate;\n } : function () {\n return _this6.today;\n });\n var currentMonth = initialVisibleMonthThunk();\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var visibleDays = this.getModifiers((0, _getVisibleDays[\"default\"])(currentMonth, numberOfMonths, enableOutsideDays, withoutTransitionMonths));\n return {\n currentMonth: currentMonth,\n visibleDays: visibleDays\n };\n };\n\n _proto.shouldDisableMonthNavigation = function shouldDisableMonthNavigation(date, visibleMonth) {\n if (!date) return false;\n var _this$props13 = this.props,\n numberOfMonths = _this$props13.numberOfMonths,\n enableOutsideDays = _this$props13.enableOutsideDays;\n return (0, _isDayVisible[\"default\"])(date, visibleMonth, numberOfMonths, enableOutsideDays);\n };\n\n _proto.addModifier = function addModifier(updatedDays, day, modifier) {\n return (0, _modifiers.addModifier)(updatedDays, day, modifier, this.props, this.state);\n };\n\n _proto.addModifierToRange = function addModifierToRange(updatedDays, start, end, modifier) {\n var days = updatedDays;\n var spanStart = start.clone();\n\n while ((0, _isBeforeDay[\"default\"])(spanStart, end)) {\n days = this.addModifier(days, spanStart, modifier);\n spanStart = spanStart.clone().add(1, 'day');\n }\n\n return days;\n };\n\n _proto.deleteModifier = function deleteModifier(updatedDays, day, modifier) {\n return (0, _modifiers.deleteModifier)(updatedDays, day, modifier, this.props, this.state);\n };\n\n _proto.deleteModifierFromRange = function deleteModifierFromRange(updatedDays, start, end, modifier) {\n var days = updatedDays;\n var spanStart = start.clone();\n\n while ((0, _isBeforeDay[\"default\"])(spanStart, end)) {\n days = this.deleteModifier(days, spanStart, modifier);\n spanStart = spanStart.clone().add(1, 'day');\n }\n\n return days;\n };\n\n _proto.doesNotMeetMinimumNights = function doesNotMeetMinimumNights(day) {\n var _this$props14 = this.props,\n startDate = _this$props14.startDate,\n isOutsideRange = _this$props14.isOutsideRange,\n focusedInput = _this$props14.focusedInput,\n minimumNights = _this$props14.minimumNights;\n if (focusedInput !== _constants.END_DATE) return false;\n\n if (startDate) {\n var dayDiff = day.diff(startDate.clone().startOf('day').hour(12), 'days');\n return dayDiff < minimumNights && dayDiff >= 0;\n }\n\n return isOutsideRange((0, _moment[\"default\"])(day).subtract(minimumNights, 'days'));\n };\n\n _proto.doesNotMeetMinNightsForHoveredStartDate = function doesNotMeetMinNightsForHoveredStartDate(day, hoverDate) {\n var _this$props15 = this.props,\n focusedInput = _this$props15.focusedInput,\n getMinNightsForHoverDate = _this$props15.getMinNightsForHoverDate;\n if (focusedInput !== _constants.END_DATE) return false;\n\n if (hoverDate && !this.isBlocked(hoverDate)) {\n var minNights = getMinNightsForHoverDate(hoverDate);\n var dayDiff = day.diff(hoverDate.clone().startOf('day').hour(12), 'days');\n return dayDiff < minNights && dayDiff >= 0;\n }\n\n return false;\n };\n\n _proto.isDayAfterHoveredStartDate = function isDayAfterHoveredStartDate(day) {\n var _this$props16 = this.props,\n startDate = _this$props16.startDate,\n endDate = _this$props16.endDate,\n minimumNights = _this$props16.minimumNights;\n\n var _ref2 = this.state || {},\n hoverDate = _ref2.hoverDate;\n\n return !!startDate && !endDate && !this.isBlocked(day) && (0, _isNextDay[\"default\"])(hoverDate, day) && minimumNights > 0 && (0, _isSameDay[\"default\"])(hoverDate, startDate);\n };\n\n _proto.isEndDate = function isEndDate(day) {\n var endDate = this.props.endDate;\n return (0, _isSameDay[\"default\"])(day, endDate);\n };\n\n _proto.isHovered = function isHovered(day) {\n var _ref3 = this.state || {},\n hoverDate = _ref3.hoverDate;\n\n var focusedInput = this.props.focusedInput;\n return !!focusedInput && (0, _isSameDay[\"default\"])(day, hoverDate);\n };\n\n _proto.isInHoveredSpan = function isInHoveredSpan(day) {\n var _this$props17 = this.props,\n startDate = _this$props17.startDate,\n endDate = _this$props17.endDate;\n\n var _ref4 = this.state || {},\n hoverDate = _ref4.hoverDate;\n\n var isForwardRange = !!startDate && !endDate && (day.isBetween(startDate, hoverDate) || (0, _isSameDay[\"default\"])(hoverDate, day));\n var isBackwardRange = !!endDate && !startDate && (day.isBetween(hoverDate, endDate) || (0, _isSameDay[\"default\"])(hoverDate, day));\n var isValidDayHovered = hoverDate && !this.isBlocked(hoverDate);\n return (isForwardRange || isBackwardRange) && isValidDayHovered;\n };\n\n _proto.isInSelectedSpan = function isInSelectedSpan(day) {\n var _this$props18 = this.props,\n startDate = _this$props18.startDate,\n endDate = _this$props18.endDate;\n return day.isBetween(startDate, endDate, 'days');\n };\n\n _proto.isLastInRange = function isLastInRange(day) {\n var endDate = this.props.endDate;\n return this.isInSelectedSpan(day) && (0, _isNextDay[\"default\"])(day, endDate);\n };\n\n _proto.isStartDate = function isStartDate(day) {\n var startDate = this.props.startDate;\n return (0, _isSameDay[\"default\"])(day, startDate);\n };\n\n _proto.isBlocked = function isBlocked(day) {\n var blockDaysViolatingMinNights = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n var _this$props19 = this.props,\n isDayBlocked = _this$props19.isDayBlocked,\n isOutsideRange = _this$props19.isOutsideRange;\n return isDayBlocked(day) || isOutsideRange(day) || blockDaysViolatingMinNights && this.doesNotMeetMinimumNights(day);\n };\n\n _proto.isToday = function isToday(day) {\n return (0, _isSameDay[\"default\"])(day, this.today);\n };\n\n _proto.isFirstDayOfWeek = function isFirstDayOfWeek(day) {\n var firstDayOfWeek = this.props.firstDayOfWeek;\n return day.day() === (firstDayOfWeek || _moment[\"default\"].localeData().firstDayOfWeek());\n };\n\n _proto.isLastDayOfWeek = function isLastDayOfWeek(day) {\n var firstDayOfWeek = this.props.firstDayOfWeek;\n return day.day() === ((firstDayOfWeek || _moment[\"default\"].localeData().firstDayOfWeek()) + 6) % 7;\n };\n\n _proto.isFirstPossibleEndDateForHoveredStartDate = function isFirstPossibleEndDateForHoveredStartDate(day, hoverDate) {\n var _this$props20 = this.props,\n focusedInput = _this$props20.focusedInput,\n getMinNightsForHoverDate = _this$props20.getMinNightsForHoverDate;\n if (focusedInput !== _constants.END_DATE || !hoverDate || this.isBlocked(hoverDate)) return false;\n var minNights = getMinNightsForHoverDate(hoverDate);\n var firstAvailableEndDate = hoverDate.clone().add(minNights, 'days');\n return (0, _isSameDay[\"default\"])(day, firstAvailableEndDate);\n };\n\n _proto.beforeSelectedEnd = function beforeSelectedEnd(day) {\n var endDate = this.props.endDate;\n return (0, _isBeforeDay[\"default\"])(day, endDate);\n };\n\n _proto.isDayBeforeHoveredEndDate = function isDayBeforeHoveredEndDate(day) {\n var _this$props21 = this.props,\n startDate = _this$props21.startDate,\n endDate = _this$props21.endDate,\n minimumNights = _this$props21.minimumNights;\n\n var _ref5 = this.state || {},\n hoverDate = _ref5.hoverDate;\n\n return !!endDate && !startDate && !this.isBlocked(day) && (0, _isPreviousDay[\"default\"])(hoverDate, day) && minimumNights > 0 && (0, _isSameDay[\"default\"])(hoverDate, endDate);\n };\n\n _proto.render = function render() {\n var _this$props22 = this.props,\n numberOfMonths = _this$props22.numberOfMonths,\n orientation = _this$props22.orientation,\n monthFormat = _this$props22.monthFormat,\n renderMonthText = _this$props22.renderMonthText,\n renderWeekHeaderElement = _this$props22.renderWeekHeaderElement,\n dayPickerNavigationInlineStyles = _this$props22.dayPickerNavigationInlineStyles,\n navPosition = _this$props22.navPosition,\n navPrev = _this$props22.navPrev,\n navNext = _this$props22.navNext,\n renderNavPrevButton = _this$props22.renderNavPrevButton,\n renderNavNextButton = _this$props22.renderNavNextButton,\n noNavButtons = _this$props22.noNavButtons,\n noNavNextButton = _this$props22.noNavNextButton,\n noNavPrevButton = _this$props22.noNavPrevButton,\n onOutsideClick = _this$props22.onOutsideClick,\n withPortal = _this$props22.withPortal,\n enableOutsideDays = _this$props22.enableOutsideDays,\n firstDayOfWeek = _this$props22.firstDayOfWeek,\n renderKeyboardShortcutsButton = _this$props22.renderKeyboardShortcutsButton,\n renderKeyboardShortcutsPanel = _this$props22.renderKeyboardShortcutsPanel,\n hideKeyboardShortcutsPanel = _this$props22.hideKeyboardShortcutsPanel,\n daySize = _this$props22.daySize,\n focusedInput = _this$props22.focusedInput,\n renderCalendarDay = _this$props22.renderCalendarDay,\n renderDayContents = _this$props22.renderDayContents,\n renderCalendarInfo = _this$props22.renderCalendarInfo,\n renderMonthElement = _this$props22.renderMonthElement,\n calendarInfoPosition = _this$props22.calendarInfoPosition,\n onBlur = _this$props22.onBlur,\n onShiftTab = _this$props22.onShiftTab,\n onTab = _this$props22.onTab,\n isFocused = _this$props22.isFocused,\n showKeyboardShortcuts = _this$props22.showKeyboardShortcuts,\n isRTL = _this$props22.isRTL,\n weekDayFormat = _this$props22.weekDayFormat,\n dayAriaLabelFormat = _this$props22.dayAriaLabelFormat,\n verticalHeight = _this$props22.verticalHeight,\n noBorder = _this$props22.noBorder,\n transitionDuration = _this$props22.transitionDuration,\n verticalBorderSpacing = _this$props22.verticalBorderSpacing,\n horizontalMonthPadding = _this$props22.horizontalMonthPadding;\n var _this$state7 = this.state,\n currentMonth = _this$state7.currentMonth,\n phrases = _this$state7.phrases,\n visibleDays = _this$state7.visibleDays,\n disablePrev = _this$state7.disablePrev,\n disableNext = _this$state7.disableNext;\n return _react[\"default\"].createElement(_DayPicker[\"default\"], {\n orientation: orientation,\n enableOutsideDays: enableOutsideDays,\n modifiers: visibleDays,\n numberOfMonths: numberOfMonths,\n onDayClick: this.onDayClick,\n onDayMouseEnter: this.onDayMouseEnter,\n onDayMouseLeave: this.onDayMouseLeave,\n onPrevMonthClick: this.onPrevMonthClick,\n onNextMonthClick: this.onNextMonthClick,\n onMonthChange: this.onMonthChange,\n onTab: onTab,\n onShiftTab: onShiftTab,\n onYearChange: this.onYearChange,\n onGetNextScrollableMonths: this.onGetNextScrollableMonths,\n onGetPrevScrollableMonths: this.onGetPrevScrollableMonths,\n monthFormat: monthFormat,\n renderMonthText: renderMonthText,\n renderWeekHeaderElement: renderWeekHeaderElement,\n withPortal: withPortal,\n hidden: !focusedInput,\n initialVisibleMonth: function initialVisibleMonth() {\n return currentMonth;\n },\n daySize: daySize,\n onOutsideClick: onOutsideClick,\n disablePrev: disablePrev,\n disableNext: disableNext,\n dayPickerNavigationInlineStyles: dayPickerNavigationInlineStyles,\n navPosition: navPosition,\n navPrev: navPrev,\n navNext: navNext,\n renderNavPrevButton: renderNavPrevButton,\n renderNavNextButton: renderNavNextButton,\n noNavButtons: noNavButtons,\n noNavPrevButton: noNavPrevButton,\n noNavNextButton: noNavNextButton,\n renderCalendarDay: renderCalendarDay,\n renderDayContents: renderDayContents,\n renderCalendarInfo: renderCalendarInfo,\n renderMonthElement: renderMonthElement,\n renderKeyboardShortcutsButton: renderKeyboardShortcutsButton,\n renderKeyboardShortcutsPanel: renderKeyboardShortcutsPanel,\n calendarInfoPosition: calendarInfoPosition,\n firstDayOfWeek: firstDayOfWeek,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n isFocused: isFocused,\n getFirstFocusableDay: this.getFirstFocusableDay,\n onBlur: onBlur,\n showKeyboardShortcuts: showKeyboardShortcuts,\n phrases: phrases,\n isRTL: isRTL,\n weekDayFormat: weekDayFormat,\n dayAriaLabelFormat: dayAriaLabelFormat,\n verticalHeight: verticalHeight,\n verticalBorderSpacing: verticalBorderSpacing,\n noBorder: noBorder,\n transitionDuration: transitionDuration,\n horizontalMonthPadding: horizontalMonthPadding\n });\n };\n\n return DayPickerRangeController;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports[\"default\"] = DayPickerRangeController;\nDayPickerRangeController.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDayPickerRangeController.defaultProps = defaultProps;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.PureDateRangePicker = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _reactPortal = require(\"react-portal\");\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _consolidatedEvents = require(\"consolidated-events\");\n\nvar _isTouchDevice = _interopRequireDefault(require(\"is-touch-device\"));\n\nvar _reactOutsideClickHandler = _interopRequireDefault(require(\"react-outside-click-handler\"));\n\nvar _DateRangePickerShape = _interopRequireDefault(require(\"../shapes/DateRangePickerShape\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getResponsiveContainerStyles = _interopRequireDefault(require(\"../utils/getResponsiveContainerStyles\"));\n\nvar _getDetachedContainerStyles = _interopRequireDefault(require(\"../utils/getDetachedContainerStyles\"));\n\nvar _getInputHeight = _interopRequireDefault(require(\"../utils/getInputHeight\"));\n\nvar _isInclusivelyAfterDay = _interopRequireDefault(require(\"../utils/isInclusivelyAfterDay\"));\n\nvar _disableScroll2 = _interopRequireDefault(require(\"../utils/disableScroll\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _DateRangePickerInputController = _interopRequireDefault(require(\"./DateRangePickerInputController\"));\n\nvar _DayPickerRangeController = _interopRequireDefault(require(\"./DayPickerRangeController\"));\n\nvar _CloseButton = _interopRequireDefault(require(\"./CloseButton\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {}, _DateRangePickerShape[\"default\"])) : {};\nvar defaultProps = {\n // required props for a functional interactive DateRangePicker\n startDate: null,\n endDate: null,\n focusedInput: null,\n // input related props\n startDatePlaceholderText: 'Start Date',\n endDatePlaceholderText: 'End Date',\n startDateAriaLabel: undefined,\n endDateAriaLabel: undefined,\n startDateOffset: undefined,\n endDateOffset: undefined,\n disabled: false,\n required: false,\n readOnly: false,\n screenReaderInputMessage: '',\n showClearDates: false,\n showDefaultInputIcon: false,\n inputIconPosition: _constants.ICON_BEFORE_POSITION,\n customInputIcon: null,\n customArrowIcon: null,\n customCloseIcon: null,\n noBorder: false,\n block: false,\n small: false,\n regular: false,\n keepFocusOnInput: false,\n // calendar presentation and interaction related props\n renderMonthText: null,\n renderWeekHeaderElement: null,\n orientation: _constants.HORIZONTAL_ORIENTATION,\n anchorDirection: _constants.ANCHOR_LEFT,\n openDirection: _constants.OPEN_DOWN,\n horizontalMargin: 0,\n withPortal: false,\n withFullScreenPortal: false,\n appendToBody: false,\n disableScroll: false,\n initialVisibleMonth: null,\n numberOfMonths: 2,\n keepOpenOnDateSelect: false,\n reopenPickerOnClearDates: false,\n renderCalendarInfo: null,\n calendarInfoPosition: _constants.INFO_POSITION_BOTTOM,\n hideKeyboardShortcutsPanel: false,\n daySize: _constants.DAY_SIZE,\n isRTL: false,\n firstDayOfWeek: null,\n verticalHeight: null,\n transitionDuration: undefined,\n verticalSpacing: _constants.DEFAULT_VERTICAL_SPACING,\n horizontalMonthPadding: undefined,\n // navigation related props\n dayPickerNavigationInlineStyles: null,\n navPosition: _constants.NAV_POSITION_TOP,\n navPrev: null,\n navNext: null,\n renderNavPrevButton: null,\n renderNavNextButton: null,\n onPrevMonthClick: function onPrevMonthClick() {},\n onNextMonthClick: function onNextMonthClick() {},\n onClose: function onClose() {},\n // day presentation and interaction related props\n renderCalendarDay: undefined,\n renderDayContents: null,\n renderMonthElement: null,\n minimumNights: 1,\n enableOutsideDays: false,\n isDayBlocked: function isDayBlocked() {\n return false;\n },\n isOutsideRange: function isOutsideRange(day) {\n return !(0, _isInclusivelyAfterDay[\"default\"])(day, (0, _moment[\"default\"])());\n },\n isDayHighlighted: function isDayHighlighted() {\n return false;\n },\n minDate: undefined,\n maxDate: undefined,\n // internationalization\n displayFormat: function displayFormat() {\n return _moment[\"default\"].localeData().longDateFormat('L');\n },\n monthFormat: 'MMMM YYYY',\n weekDayFormat: 'dd',\n phrases: _defaultPhrases.DateRangePickerPhrases,\n dayAriaLabelFormat: undefined\n};\n\nvar DateRangePicker =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DateRangePicker, _ref);\n var _proto = DateRangePicker.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DateRangePicker(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.state = {\n dayPickerContainerStyles: {},\n isDateRangePickerInputFocused: false,\n isDayPickerFocused: false,\n showKeyboardShortcuts: false\n };\n _this.isTouchDevice = false;\n _this.onOutsideClick = _this.onOutsideClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDateRangePickerInputFocus = _this.onDateRangePickerInputFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayPickerFocus = _this.onDayPickerFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayPickerFocusOut = _this.onDayPickerFocusOut.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayPickerBlur = _this.onDayPickerBlur.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.showKeyboardShortcutsPanel = _this.showKeyboardShortcutsPanel.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.responsivizePickerPosition = _this.responsivizePickerPosition.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.disableScroll = _this.disableScroll.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setDayPickerContainerRef = _this.setDayPickerContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setContainerRef = _this.setContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentDidMount = function componentDidMount() {\n this.removeEventListener = (0, _consolidatedEvents.addEventListener)(window, 'resize', this.responsivizePickerPosition, {\n passive: true\n });\n this.responsivizePickerPosition();\n this.disableScroll();\n var focusedInput = this.props.focusedInput;\n\n if (focusedInput) {\n this.setState({\n isDateRangePickerInputFocused: true\n });\n }\n\n this.isTouchDevice = (0, _isTouchDevice[\"default\"])();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var focusedInput = this.props.focusedInput;\n\n if (!prevProps.focusedInput && focusedInput && this.isOpened()) {\n // The date picker just changed from being closed to being open.\n this.responsivizePickerPosition();\n this.disableScroll();\n } else if (prevProps.focusedInput && !focusedInput && !this.isOpened()) {\n // The date picker just changed from being open to being closed.\n if (this.enableScroll) this.enableScroll();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.removeDayPickerEventListeners();\n if (this.removeEventListener) this.removeEventListener();\n if (this.enableScroll) this.enableScroll();\n };\n\n _proto.onOutsideClick = function onOutsideClick(event) {\n var _this$props = this.props,\n onFocusChange = _this$props.onFocusChange,\n onClose = _this$props.onClose,\n startDate = _this$props.startDate,\n endDate = _this$props.endDate,\n appendToBody = _this$props.appendToBody;\n if (!this.isOpened()) return;\n if (appendToBody && this.dayPickerContainer.contains(event.target)) return;\n this.setState({\n isDateRangePickerInputFocused: false,\n isDayPickerFocused: false,\n showKeyboardShortcuts: false\n });\n onFocusChange(null);\n onClose({\n startDate: startDate,\n endDate: endDate\n });\n };\n\n _proto.onDateRangePickerInputFocus = function onDateRangePickerInputFocus(focusedInput) {\n var _this$props2 = this.props,\n onFocusChange = _this$props2.onFocusChange,\n readOnly = _this$props2.readOnly,\n withPortal = _this$props2.withPortal,\n withFullScreenPortal = _this$props2.withFullScreenPortal,\n keepFocusOnInput = _this$props2.keepFocusOnInput;\n\n if (focusedInput) {\n var withAnyPortal = withPortal || withFullScreenPortal;\n var moveFocusToDayPicker = withAnyPortal || readOnly && !keepFocusOnInput || this.isTouchDevice && !keepFocusOnInput;\n\n if (moveFocusToDayPicker) {\n this.onDayPickerFocus();\n } else {\n this.onDayPickerBlur();\n }\n }\n\n onFocusChange(focusedInput);\n };\n\n _proto.onDayPickerFocus = function onDayPickerFocus() {\n var _this$props3 = this.props,\n focusedInput = _this$props3.focusedInput,\n onFocusChange = _this$props3.onFocusChange;\n if (!focusedInput) onFocusChange(_constants.START_DATE);\n this.setState({\n isDateRangePickerInputFocused: false,\n isDayPickerFocused: true,\n showKeyboardShortcuts: false\n });\n };\n\n _proto.onDayPickerFocusOut = function onDayPickerFocusOut(event) {\n // In cases where **relatedTarget** is not null, it points to the right\n // element here. However, in cases where it is null (such as clicking on a\n // specific day) or it is **document.body** (IE11), the appropriate value is **event.target**.\n //\n // We handle both situations here by using the ` || ` operator to fallback\n // to *event.target** when **relatedTarget** is not provided.\n var relatedTarget = event.relatedTarget === document.body ? event.target : event.relatedTarget || event.target;\n if (this.dayPickerContainer.contains(relatedTarget)) return;\n this.onOutsideClick(event);\n };\n\n _proto.onDayPickerBlur = function onDayPickerBlur() {\n this.setState({\n isDateRangePickerInputFocused: true,\n isDayPickerFocused: false,\n showKeyboardShortcuts: false\n });\n };\n\n _proto.setDayPickerContainerRef = function setDayPickerContainerRef(ref) {\n if (ref === this.dayPickerContainer) return;\n if (this.dayPickerContainer) this.removeDayPickerEventListeners();\n this.dayPickerContainer = ref;\n if (!ref) return;\n this.addDayPickerEventListeners();\n };\n\n _proto.setContainerRef = function setContainerRef(ref) {\n this.container = ref;\n };\n\n _proto.addDayPickerEventListeners = function addDayPickerEventListeners() {\n // NOTE: We are using a manual event listener here, because React doesn't\n // provide FocusOut, while blur and keydown don't provide the information\n // needed in order to know whether we have left focus or not.\n //\n // For reference, this issue is further described here:\n // - https://github.com/facebook/react/issues/6410\n this.removeDayPickerFocusOut = (0, _consolidatedEvents.addEventListener)(this.dayPickerContainer, 'focusout', this.onDayPickerFocusOut);\n };\n\n _proto.removeDayPickerEventListeners = function removeDayPickerEventListeners() {\n if (this.removeDayPickerFocusOut) this.removeDayPickerFocusOut();\n };\n\n _proto.isOpened = function isOpened() {\n var focusedInput = this.props.focusedInput;\n return focusedInput === _constants.START_DATE || focusedInput === _constants.END_DATE;\n };\n\n _proto.disableScroll = function disableScroll() {\n var _this$props4 = this.props,\n appendToBody = _this$props4.appendToBody,\n propDisableScroll = _this$props4.disableScroll;\n if (!appendToBody && !propDisableScroll) return;\n if (!this.isOpened()) return; // Disable scroll for every ancestor of this DateRangePicker up to the\n // document level. This ensures the input and the picker never move. Other\n // sibling elements or the picker itself can scroll.\n\n this.enableScroll = (0, _disableScroll2[\"default\"])(this.container);\n };\n\n _proto.responsivizePickerPosition = function responsivizePickerPosition() {\n // It's possible the portal props have been changed in response to window resizes\n // So let's ensure we reset this back to the base state each time\n var dayPickerContainerStyles = this.state.dayPickerContainerStyles;\n\n if (Object.keys(dayPickerContainerStyles).length > 0) {\n this.setState({\n dayPickerContainerStyles: {}\n });\n }\n\n if (!this.isOpened()) {\n return;\n }\n\n var _this$props5 = this.props,\n openDirection = _this$props5.openDirection,\n anchorDirection = _this$props5.anchorDirection,\n horizontalMargin = _this$props5.horizontalMargin,\n withPortal = _this$props5.withPortal,\n withFullScreenPortal = _this$props5.withFullScreenPortal,\n appendToBody = _this$props5.appendToBody;\n var isAnchoredLeft = anchorDirection === _constants.ANCHOR_LEFT;\n\n if (!withPortal && !withFullScreenPortal) {\n var containerRect = this.dayPickerContainer.getBoundingClientRect();\n var currentOffset = dayPickerContainerStyles[anchorDirection] || 0;\n var containerEdge = isAnchoredLeft ? containerRect[_constants.ANCHOR_RIGHT] : containerRect[_constants.ANCHOR_LEFT];\n this.setState({\n dayPickerContainerStyles: _objectSpread({}, (0, _getResponsiveContainerStyles[\"default\"])(anchorDirection, currentOffset, containerEdge, horizontalMargin), {}, appendToBody && (0, _getDetachedContainerStyles[\"default\"])(openDirection, anchorDirection, this.container))\n });\n }\n };\n\n _proto.showKeyboardShortcutsPanel = function showKeyboardShortcutsPanel() {\n this.setState({\n isDateRangePickerInputFocused: false,\n isDayPickerFocused: true,\n showKeyboardShortcuts: true\n });\n };\n\n _proto.maybeRenderDayPickerWithPortal = function maybeRenderDayPickerWithPortal() {\n var _this$props6 = this.props,\n withPortal = _this$props6.withPortal,\n withFullScreenPortal = _this$props6.withFullScreenPortal,\n appendToBody = _this$props6.appendToBody;\n\n if (!this.isOpened()) {\n return null;\n }\n\n if (withPortal || withFullScreenPortal || appendToBody) {\n return _react[\"default\"].createElement(_reactPortal.Portal, null, this.renderDayPicker());\n }\n\n return this.renderDayPicker();\n };\n\n _proto.renderDayPicker = function renderDayPicker() {\n var _this$props7 = this.props,\n anchorDirection = _this$props7.anchorDirection,\n openDirection = _this$props7.openDirection,\n isDayBlocked = _this$props7.isDayBlocked,\n isDayHighlighted = _this$props7.isDayHighlighted,\n isOutsideRange = _this$props7.isOutsideRange,\n numberOfMonths = _this$props7.numberOfMonths,\n orientation = _this$props7.orientation,\n monthFormat = _this$props7.monthFormat,\n renderMonthText = _this$props7.renderMonthText,\n renderWeekHeaderElement = _this$props7.renderWeekHeaderElement,\n dayPickerNavigationInlineStyles = _this$props7.dayPickerNavigationInlineStyles,\n navPosition = _this$props7.navPosition,\n navPrev = _this$props7.navPrev,\n navNext = _this$props7.navNext,\n renderNavPrevButton = _this$props7.renderNavPrevButton,\n renderNavNextButton = _this$props7.renderNavNextButton,\n onPrevMonthClick = _this$props7.onPrevMonthClick,\n onNextMonthClick = _this$props7.onNextMonthClick,\n onDatesChange = _this$props7.onDatesChange,\n onFocusChange = _this$props7.onFocusChange,\n withPortal = _this$props7.withPortal,\n withFullScreenPortal = _this$props7.withFullScreenPortal,\n daySize = _this$props7.daySize,\n enableOutsideDays = _this$props7.enableOutsideDays,\n focusedInput = _this$props7.focusedInput,\n startDate = _this$props7.startDate,\n startDateOffset = _this$props7.startDateOffset,\n endDate = _this$props7.endDate,\n endDateOffset = _this$props7.endDateOffset,\n minDate = _this$props7.minDate,\n maxDate = _this$props7.maxDate,\n minimumNights = _this$props7.minimumNights,\n keepOpenOnDateSelect = _this$props7.keepOpenOnDateSelect,\n renderCalendarDay = _this$props7.renderCalendarDay,\n renderDayContents = _this$props7.renderDayContents,\n renderCalendarInfo = _this$props7.renderCalendarInfo,\n renderMonthElement = _this$props7.renderMonthElement,\n calendarInfoPosition = _this$props7.calendarInfoPosition,\n firstDayOfWeek = _this$props7.firstDayOfWeek,\n initialVisibleMonth = _this$props7.initialVisibleMonth,\n hideKeyboardShortcutsPanel = _this$props7.hideKeyboardShortcutsPanel,\n customCloseIcon = _this$props7.customCloseIcon,\n onClose = _this$props7.onClose,\n phrases = _this$props7.phrases,\n dayAriaLabelFormat = _this$props7.dayAriaLabelFormat,\n isRTL = _this$props7.isRTL,\n weekDayFormat = _this$props7.weekDayFormat,\n styles = _this$props7.styles,\n verticalHeight = _this$props7.verticalHeight,\n transitionDuration = _this$props7.transitionDuration,\n verticalSpacing = _this$props7.verticalSpacing,\n horizontalMonthPadding = _this$props7.horizontalMonthPadding,\n small = _this$props7.small,\n disabled = _this$props7.disabled,\n reactDates = _this$props7.theme.reactDates;\n var _this$state = this.state,\n dayPickerContainerStyles = _this$state.dayPickerContainerStyles,\n isDayPickerFocused = _this$state.isDayPickerFocused,\n showKeyboardShortcuts = _this$state.showKeyboardShortcuts;\n var onOutsideClick = !withFullScreenPortal && withPortal ? this.onOutsideClick : undefined;\n\n var initialVisibleMonthThunk = initialVisibleMonth || function () {\n return startDate || endDate || (0, _moment[\"default\"])();\n };\n\n var closeIcon = customCloseIcon || _react[\"default\"].createElement(_CloseButton[\"default\"], (0, _reactWithStyles.css)(styles.DateRangePicker_closeButton_svg));\n\n var inputHeight = (0, _getInputHeight[\"default\"])(reactDates, small);\n var withAnyPortal = withPortal || withFullScreenPortal;\n /* eslint-disable jsx-a11y/no-static-element-interactions */\n\n /* eslint-disable jsx-a11y/click-events-have-key-events */\n\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n ref: this.setDayPickerContainerRef\n }, (0, _reactWithStyles.css)(styles.DateRangePicker_picker, anchorDirection === _constants.ANCHOR_LEFT && styles.DateRangePicker_picker__directionLeft, anchorDirection === _constants.ANCHOR_RIGHT && styles.DateRangePicker_picker__directionRight, orientation === _constants.HORIZONTAL_ORIENTATION && styles.DateRangePicker_picker__horizontal, orientation === _constants.VERTICAL_ORIENTATION && styles.DateRangePicker_picker__vertical, !withAnyPortal && openDirection === _constants.OPEN_DOWN && {\n top: inputHeight + verticalSpacing\n }, !withAnyPortal && openDirection === _constants.OPEN_UP && {\n bottom: inputHeight + verticalSpacing\n }, withAnyPortal && styles.DateRangePicker_picker__portal, withFullScreenPortal && styles.DateRangePicker_picker__fullScreenPortal, isRTL && styles.DateRangePicker_picker__rtl, dayPickerContainerStyles), {\n onClick: onOutsideClick\n }), _react[\"default\"].createElement(_DayPickerRangeController[\"default\"], {\n orientation: orientation,\n enableOutsideDays: enableOutsideDays,\n numberOfMonths: numberOfMonths,\n onPrevMonthClick: onPrevMonthClick,\n onNextMonthClick: onNextMonthClick,\n onDatesChange: onDatesChange,\n onFocusChange: onFocusChange,\n onClose: onClose,\n focusedInput: focusedInput,\n startDate: startDate,\n startDateOffset: startDateOffset,\n endDate: endDate,\n endDateOffset: endDateOffset,\n minDate: minDate,\n maxDate: maxDate,\n monthFormat: monthFormat,\n renderMonthText: renderMonthText,\n renderWeekHeaderElement: renderWeekHeaderElement,\n withPortal: withAnyPortal,\n daySize: daySize,\n initialVisibleMonth: initialVisibleMonthThunk,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n dayPickerNavigationInlineStyles: dayPickerNavigationInlineStyles,\n navPosition: navPosition,\n navPrev: navPrev,\n navNext: navNext,\n renderNavPrevButton: renderNavPrevButton,\n renderNavNextButton: renderNavNextButton,\n minimumNights: minimumNights,\n isOutsideRange: isOutsideRange,\n isDayHighlighted: isDayHighlighted,\n isDayBlocked: isDayBlocked,\n keepOpenOnDateSelect: keepOpenOnDateSelect,\n renderCalendarDay: renderCalendarDay,\n renderDayContents: renderDayContents,\n renderCalendarInfo: renderCalendarInfo,\n renderMonthElement: renderMonthElement,\n calendarInfoPosition: calendarInfoPosition,\n isFocused: isDayPickerFocused,\n showKeyboardShortcuts: showKeyboardShortcuts,\n onBlur: this.onDayPickerBlur,\n phrases: phrases,\n dayAriaLabelFormat: dayAriaLabelFormat,\n isRTL: isRTL,\n firstDayOfWeek: firstDayOfWeek,\n weekDayFormat: weekDayFormat,\n verticalHeight: verticalHeight,\n transitionDuration: transitionDuration,\n disabled: disabled,\n horizontalMonthPadding: horizontalMonthPadding\n }), withFullScreenPortal && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.DateRangePicker_closeButton), {\n type: \"button\",\n onClick: this.onOutsideClick,\n \"aria-label\": phrases.closeDatePicker\n }), closeIcon));\n /* eslint-enable jsx-a11y/no-static-element-interactions */\n\n /* eslint-enable jsx-a11y/click-events-have-key-events */\n };\n\n _proto.render = function render() {\n var _this$props8 = this.props,\n startDate = _this$props8.startDate,\n startDateId = _this$props8.startDateId,\n startDatePlaceholderText = _this$props8.startDatePlaceholderText,\n startDateAriaLabel = _this$props8.startDateAriaLabel,\n endDate = _this$props8.endDate,\n endDateId = _this$props8.endDateId,\n endDatePlaceholderText = _this$props8.endDatePlaceholderText,\n endDateAriaLabel = _this$props8.endDateAriaLabel,\n focusedInput = _this$props8.focusedInput,\n screenReaderInputMessage = _this$props8.screenReaderInputMessage,\n showClearDates = _this$props8.showClearDates,\n showDefaultInputIcon = _this$props8.showDefaultInputIcon,\n inputIconPosition = _this$props8.inputIconPosition,\n customInputIcon = _this$props8.customInputIcon,\n customArrowIcon = _this$props8.customArrowIcon,\n customCloseIcon = _this$props8.customCloseIcon,\n disabled = _this$props8.disabled,\n required = _this$props8.required,\n readOnly = _this$props8.readOnly,\n openDirection = _this$props8.openDirection,\n phrases = _this$props8.phrases,\n isOutsideRange = _this$props8.isOutsideRange,\n minimumNights = _this$props8.minimumNights,\n withPortal = _this$props8.withPortal,\n withFullScreenPortal = _this$props8.withFullScreenPortal,\n displayFormat = _this$props8.displayFormat,\n reopenPickerOnClearDates = _this$props8.reopenPickerOnClearDates,\n keepOpenOnDateSelect = _this$props8.keepOpenOnDateSelect,\n onDatesChange = _this$props8.onDatesChange,\n onClose = _this$props8.onClose,\n isRTL = _this$props8.isRTL,\n noBorder = _this$props8.noBorder,\n block = _this$props8.block,\n verticalSpacing = _this$props8.verticalSpacing,\n small = _this$props8.small,\n regular = _this$props8.regular,\n styles = _this$props8.styles;\n var isDateRangePickerInputFocused = this.state.isDateRangePickerInputFocused;\n var enableOutsideClick = !withPortal && !withFullScreenPortal;\n var hideFang = verticalSpacing < _constants.FANG_HEIGHT_PX;\n\n var input = _react[\"default\"].createElement(_DateRangePickerInputController[\"default\"], {\n startDate: startDate,\n startDateId: startDateId,\n startDatePlaceholderText: startDatePlaceholderText,\n isStartDateFocused: focusedInput === _constants.START_DATE,\n startDateAriaLabel: startDateAriaLabel,\n endDate: endDate,\n endDateId: endDateId,\n endDatePlaceholderText: endDatePlaceholderText,\n isEndDateFocused: focusedInput === _constants.END_DATE,\n endDateAriaLabel: endDateAriaLabel,\n displayFormat: displayFormat,\n showClearDates: showClearDates,\n showCaret: !withPortal && !withFullScreenPortal && !hideFang,\n showDefaultInputIcon: showDefaultInputIcon,\n inputIconPosition: inputIconPosition,\n customInputIcon: customInputIcon,\n customArrowIcon: customArrowIcon,\n customCloseIcon: customCloseIcon,\n disabled: disabled,\n required: required,\n readOnly: readOnly,\n openDirection: openDirection,\n reopenPickerOnClearDates: reopenPickerOnClearDates,\n keepOpenOnDateSelect: keepOpenOnDateSelect,\n isOutsideRange: isOutsideRange,\n minimumNights: minimumNights,\n withFullScreenPortal: withFullScreenPortal,\n onDatesChange: onDatesChange,\n onFocusChange: this.onDateRangePickerInputFocus,\n onKeyDownArrowDown: this.onDayPickerFocus,\n onKeyDownQuestionMark: this.showKeyboardShortcutsPanel,\n onClose: onClose,\n phrases: phrases,\n screenReaderMessage: screenReaderInputMessage,\n isFocused: isDateRangePickerInputFocused,\n isRTL: isRTL,\n noBorder: noBorder,\n block: block,\n small: small,\n regular: regular,\n verticalSpacing: verticalSpacing\n }, this.maybeRenderDayPickerWithPortal());\n\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n ref: this.setContainerRef\n }, (0, _reactWithStyles.css)(styles.DateRangePicker, block && styles.DateRangePicker__block)), enableOutsideClick && _react[\"default\"].createElement(_reactOutsideClickHandler[\"default\"], {\n onOutsideClick: this.onOutsideClick\n }, input), enableOutsideClick || input);\n };\n\n return DateRangePicker;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports.PureDateRangePicker = DateRangePicker;\nDateRangePicker.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDateRangePicker.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n color = _ref2$reactDates.color,\n zIndex = _ref2$reactDates.zIndex;\n return {\n DateRangePicker: {\n position: 'relative',\n display: 'inline-block'\n },\n DateRangePicker__block: {\n display: 'block'\n },\n DateRangePicker_picker: {\n zIndex: zIndex + 1,\n backgroundColor: color.background,\n position: 'absolute'\n },\n DateRangePicker_picker__rtl: {\n direction: (0, _noflip[\"default\"])('rtl')\n },\n DateRangePicker_picker__directionLeft: {\n left: (0, _noflip[\"default\"])(0)\n },\n DateRangePicker_picker__directionRight: {\n right: (0, _noflip[\"default\"])(0)\n },\n DateRangePicker_picker__portal: {\n backgroundColor: 'rgba(0, 0, 0, 0.3)',\n position: 'fixed',\n top: 0,\n left: (0, _noflip[\"default\"])(0),\n height: '100%',\n width: '100%'\n },\n DateRangePicker_picker__fullScreenPortal: {\n backgroundColor: color.background\n },\n DateRangePicker_closeButton: {\n background: 'none',\n border: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n cursor: 'pointer',\n position: 'absolute',\n top: 0,\n right: (0, _noflip[\"default\"])(0),\n padding: 15,\n zIndex: zIndex + 2,\n ':hover': {\n color: \"darken(\".concat(color.core.grayLighter, \", 10%)\"),\n textDecoration: 'none'\n },\n ':focus': {\n color: \"darken(\".concat(color.core.grayLighter, \", 10%)\"),\n textDecoration: 'none'\n }\n },\n DateRangePicker_closeButton_svg: {\n height: 15,\n width: 15,\n fill: color.core.grayLighter\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(DateRangePicker);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _object = _interopRequireDefault(require(\"object.values\"));\n\nvar _isTouchDevice = _interopRequireDefault(require(\"is-touch-device\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"../utils/isSameDay\"));\n\nvar _isAfterDay = _interopRequireDefault(require(\"../utils/isAfterDay\"));\n\nvar _getVisibleDays = _interopRequireDefault(require(\"../utils/getVisibleDays\"));\n\nvar _toISODateString = _interopRequireDefault(require(\"../utils/toISODateString\"));\n\nvar _modifiers = require(\"../utils/modifiers\");\n\nvar _ScrollableOrientationShape = _interopRequireDefault(require(\"../shapes/ScrollableOrientationShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"../shapes/DayOfWeekShape\"));\n\nvar _CalendarInfoPositionShape = _interopRequireDefault(require(\"../shapes/CalendarInfoPositionShape\"));\n\nvar _NavPositionShape = _interopRequireDefault(require(\"../shapes/NavPositionShape\"));\n\nvar _constants = require(\"../constants\");\n\nvar _DayPicker = _interopRequireDefault(require(\"./DayPicker\"));\n\nvar _getPooledMoment = _interopRequireDefault(require(\"../utils/getPooledMoment\"));\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)({\n date: _reactMomentProptypes[\"default\"].momentObj,\n onDateChange: _propTypes[\"default\"].func,\n focused: _propTypes[\"default\"].bool,\n onFocusChange: _propTypes[\"default\"].func,\n onClose: _propTypes[\"default\"].func,\n keepOpenOnDateSelect: _propTypes[\"default\"].bool,\n isOutsideRange: _propTypes[\"default\"].func,\n isDayBlocked: _propTypes[\"default\"].func,\n isDayHighlighted: _propTypes[\"default\"].func,\n // DayPicker props\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderWeekHeaderElement: _propTypes[\"default\"].func,\n enableOutsideDays: _propTypes[\"default\"].bool,\n numberOfMonths: _propTypes[\"default\"].number,\n orientation: _ScrollableOrientationShape[\"default\"],\n withPortal: _propTypes[\"default\"].bool,\n initialVisibleMonth: _propTypes[\"default\"].func,\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n hideKeyboardShortcutsPanel: _propTypes[\"default\"].bool,\n daySize: _airbnbPropTypes.nonNegativeInteger,\n verticalHeight: _airbnbPropTypes.nonNegativeInteger,\n noBorder: _propTypes[\"default\"].bool,\n verticalBorderSpacing: _airbnbPropTypes.nonNegativeInteger,\n transitionDuration: _airbnbPropTypes.nonNegativeInteger,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n dayPickerNavigationInlineStyles: _propTypes[\"default\"].object,\n navPosition: _NavPositionShape[\"default\"],\n navPrev: _propTypes[\"default\"].node,\n navNext: _propTypes[\"default\"].node,\n renderNavPrevButton: _propTypes[\"default\"].func,\n renderNavNextButton: _propTypes[\"default\"].func,\n noNavButtons: _propTypes[\"default\"].bool,\n noNavNextButton: _propTypes[\"default\"].bool,\n noNavPrevButton: _propTypes[\"default\"].bool,\n onPrevMonthClick: _propTypes[\"default\"].func,\n onNextMonthClick: _propTypes[\"default\"].func,\n onOutsideClick: _propTypes[\"default\"].func,\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n renderCalendarInfo: _propTypes[\"default\"].func,\n calendarInfoPosition: _CalendarInfoPositionShape[\"default\"],\n // accessibility\n onBlur: _propTypes[\"default\"].func,\n isFocused: _propTypes[\"default\"].bool,\n showKeyboardShortcuts: _propTypes[\"default\"].bool,\n onTab: _propTypes[\"default\"].func,\n onShiftTab: _propTypes[\"default\"].func,\n // i18n\n monthFormat: _propTypes[\"default\"].string,\n weekDayFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.DayPickerPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string,\n isRTL: _propTypes[\"default\"].bool\n}) : {};\nvar defaultProps = {\n date: undefined,\n // TODO: use null\n onDateChange: function onDateChange() {},\n focused: false,\n onFocusChange: function onFocusChange() {},\n onClose: function onClose() {},\n keepOpenOnDateSelect: false,\n isOutsideRange: function isOutsideRange() {},\n isDayBlocked: function isDayBlocked() {},\n isDayHighlighted: function isDayHighlighted() {},\n // DayPicker props\n renderMonthText: null,\n renderWeekHeaderElement: null,\n enableOutsideDays: false,\n numberOfMonths: 1,\n orientation: _constants.HORIZONTAL_ORIENTATION,\n withPortal: false,\n hideKeyboardShortcutsPanel: false,\n initialVisibleMonth: null,\n firstDayOfWeek: null,\n daySize: _constants.DAY_SIZE,\n verticalHeight: null,\n noBorder: false,\n verticalBorderSpacing: undefined,\n transitionDuration: undefined,\n horizontalMonthPadding: 13,\n dayPickerNavigationInlineStyles: null,\n navPosition: _constants.NAV_POSITION_TOP,\n navPrev: null,\n navNext: null,\n renderNavPrevButton: null,\n renderNavNextButton: null,\n noNavButtons: false,\n noNavNextButton: false,\n noNavPrevButton: false,\n onPrevMonthClick: function onPrevMonthClick() {},\n onNextMonthClick: function onNextMonthClick() {},\n onOutsideClick: function onOutsideClick() {},\n renderCalendarDay: undefined,\n renderDayContents: null,\n renderCalendarInfo: null,\n renderMonthElement: null,\n calendarInfoPosition: _constants.INFO_POSITION_BOTTOM,\n // accessibility\n onBlur: function onBlur() {},\n isFocused: false,\n showKeyboardShortcuts: false,\n onTab: function onTab() {},\n onShiftTab: function onShiftTab() {},\n // i18n\n monthFormat: 'MMMM YYYY',\n weekDayFormat: 'dd',\n phrases: _defaultPhrases.DayPickerPhrases,\n dayAriaLabelFormat: undefined,\n isRTL: false\n};\n\nvar DayPickerSingleDateController =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(DayPickerSingleDateController, _ref);\n var _proto = DayPickerSingleDateController.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function DayPickerSingleDateController(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.isTouchDevice = false;\n _this.today = (0, _moment[\"default\"])();\n _this.modifiers = {\n today: function today(day) {\n return _this.isToday(day);\n },\n blocked: function blocked(day) {\n return _this.isBlocked(day);\n },\n 'blocked-calendar': function blockedCalendar(day) {\n return props.isDayBlocked(day);\n },\n 'blocked-out-of-range': function blockedOutOfRange(day) {\n return props.isOutsideRange(day);\n },\n 'highlighted-calendar': function highlightedCalendar(day) {\n return props.isDayHighlighted(day);\n },\n valid: function valid(day) {\n return !_this.isBlocked(day);\n },\n hovered: function hovered(day) {\n return _this.isHovered(day);\n },\n selected: function selected(day) {\n return _this.isSelected(day);\n },\n 'first-day-of-week': function firstDayOfWeek(day) {\n return _this.isFirstDayOfWeek(day);\n },\n 'last-day-of-week': function lastDayOfWeek(day) {\n return _this.isLastDayOfWeek(day);\n }\n };\n\n var _this$getStateForNewM = _this.getStateForNewMonth(props),\n currentMonth = _this$getStateForNewM.currentMonth,\n visibleDays = _this$getStateForNewM.visibleDays;\n\n _this.state = {\n hoverDate: null,\n currentMonth: currentMonth,\n visibleDays: visibleDays\n };\n _this.onDayMouseEnter = _this.onDayMouseEnter.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayMouseLeave = _this.onDayMouseLeave.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayClick = _this.onDayClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onPrevMonthClick = _this.onPrevMonthClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onNextMonthClick = _this.onNextMonthClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onMonthChange = _this.onMonthChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onYearChange = _this.onYearChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onGetNextScrollableMonths = _this.onGetNextScrollableMonths.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onGetPrevScrollableMonths = _this.onGetPrevScrollableMonths.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.getFirstFocusableDay = _this.getFirstFocusableDay.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.componentDidMount = function componentDidMount() {\n this.isTouchDevice = (0, _isTouchDevice[\"default\"])();\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var _this2 = this;\n\n var date = nextProps.date,\n focused = nextProps.focused,\n isOutsideRange = nextProps.isOutsideRange,\n isDayBlocked = nextProps.isDayBlocked,\n isDayHighlighted = nextProps.isDayHighlighted,\n initialVisibleMonth = nextProps.initialVisibleMonth,\n numberOfMonths = nextProps.numberOfMonths,\n enableOutsideDays = nextProps.enableOutsideDays;\n var _this$props = this.props,\n prevIsOutsideRange = _this$props.isOutsideRange,\n prevIsDayBlocked = _this$props.isDayBlocked,\n prevIsDayHighlighted = _this$props.isDayHighlighted,\n prevNumberOfMonths = _this$props.numberOfMonths,\n prevEnableOutsideDays = _this$props.enableOutsideDays,\n prevInitialVisibleMonth = _this$props.initialVisibleMonth,\n prevFocused = _this$props.focused,\n prevDate = _this$props.date;\n var visibleDays = this.state.visibleDays;\n var recomputeOutsideRange = false;\n var recomputeDayBlocked = false;\n var recomputeDayHighlighted = false;\n\n if (isOutsideRange !== prevIsOutsideRange) {\n this.modifiers['blocked-out-of-range'] = function (day) {\n return isOutsideRange(day);\n };\n\n recomputeOutsideRange = true;\n }\n\n if (isDayBlocked !== prevIsDayBlocked) {\n this.modifiers['blocked-calendar'] = function (day) {\n return isDayBlocked(day);\n };\n\n recomputeDayBlocked = true;\n }\n\n if (isDayHighlighted !== prevIsDayHighlighted) {\n this.modifiers['highlighted-calendar'] = function (day) {\n return isDayHighlighted(day);\n };\n\n recomputeDayHighlighted = true;\n }\n\n var recomputePropModifiers = recomputeOutsideRange || recomputeDayBlocked || recomputeDayHighlighted;\n\n if (numberOfMonths !== prevNumberOfMonths || enableOutsideDays !== prevEnableOutsideDays || initialVisibleMonth !== prevInitialVisibleMonth && !prevFocused && focused) {\n var newMonthState = this.getStateForNewMonth(nextProps);\n var currentMonth = newMonthState.currentMonth;\n visibleDays = newMonthState.visibleDays;\n this.setState({\n currentMonth: currentMonth,\n visibleDays: visibleDays\n });\n }\n\n var didDateChange = date !== prevDate;\n var didFocusChange = focused !== prevFocused;\n var modifiers = {};\n\n if (didDateChange) {\n modifiers = this.deleteModifier(modifiers, prevDate, 'selected');\n modifiers = this.addModifier(modifiers, date, 'selected');\n }\n\n if (didFocusChange || recomputePropModifiers) {\n (0, _object[\"default\"])(visibleDays).forEach(function (days) {\n Object.keys(days).forEach(function (day) {\n var momentObj = (0, _getPooledMoment[\"default\"])(day);\n\n if (_this2.isBlocked(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'blocked');\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'blocked');\n }\n\n if (didFocusChange || recomputeOutsideRange) {\n if (isOutsideRange(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'blocked-out-of-range');\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'blocked-out-of-range');\n }\n }\n\n if (didFocusChange || recomputeDayBlocked) {\n if (isDayBlocked(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'blocked-calendar');\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'blocked-calendar');\n }\n }\n\n if (didFocusChange || recomputeDayHighlighted) {\n if (isDayHighlighted(momentObj)) {\n modifiers = _this2.addModifier(modifiers, momentObj, 'highlighted-calendar');\n } else {\n modifiers = _this2.deleteModifier(modifiers, momentObj, 'highlighted-calendar');\n }\n }\n });\n });\n }\n\n var today = (0, _moment[\"default\"])();\n\n if (!(0, _isSameDay[\"default\"])(this.today, today)) {\n modifiers = this.deleteModifier(modifiers, this.today, 'today');\n modifiers = this.addModifier(modifiers, today, 'today');\n this.today = today;\n }\n\n if (Object.keys(modifiers).length > 0) {\n this.setState({\n visibleDays: _objectSpread({}, visibleDays, {}, modifiers)\n });\n }\n };\n\n _proto.componentWillUpdate = function componentWillUpdate() {\n this.today = (0, _moment[\"default\"])();\n };\n\n _proto.onDayClick = function onDayClick(day, e) {\n if (e) e.preventDefault();\n if (this.isBlocked(day)) return;\n var _this$props2 = this.props,\n onDateChange = _this$props2.onDateChange,\n keepOpenOnDateSelect = _this$props2.keepOpenOnDateSelect,\n onFocusChange = _this$props2.onFocusChange,\n onClose = _this$props2.onClose;\n onDateChange(day);\n\n if (!keepOpenOnDateSelect) {\n onFocusChange({\n focused: false\n });\n onClose({\n date: day\n });\n }\n };\n\n _proto.onDayMouseEnter = function onDayMouseEnter(day) {\n if (this.isTouchDevice) return;\n var _this$state = this.state,\n hoverDate = _this$state.hoverDate,\n visibleDays = _this$state.visibleDays;\n var modifiers = this.deleteModifier({}, hoverDate, 'hovered');\n modifiers = this.addModifier(modifiers, day, 'hovered');\n this.setState({\n hoverDate: day,\n visibleDays: _objectSpread({}, visibleDays, {}, modifiers)\n });\n };\n\n _proto.onDayMouseLeave = function onDayMouseLeave() {\n var _this$state2 = this.state,\n hoverDate = _this$state2.hoverDate,\n visibleDays = _this$state2.visibleDays;\n if (this.isTouchDevice || !hoverDate) return;\n var modifiers = this.deleteModifier({}, hoverDate, 'hovered');\n this.setState({\n hoverDate: null,\n visibleDays: _objectSpread({}, visibleDays, {}, modifiers)\n });\n };\n\n _proto.onPrevMonthClick = function onPrevMonthClick() {\n var _this$props3 = this.props,\n onPrevMonthClick = _this$props3.onPrevMonthClick,\n numberOfMonths = _this$props3.numberOfMonths,\n enableOutsideDays = _this$props3.enableOutsideDays;\n var _this$state3 = this.state,\n currentMonth = _this$state3.currentMonth,\n visibleDays = _this$state3.visibleDays;\n var newVisibleDays = {};\n Object.keys(visibleDays).sort().slice(0, numberOfMonths + 1).forEach(function (month) {\n newVisibleDays[month] = visibleDays[month];\n });\n var prevMonth = currentMonth.clone().subtract(1, 'month');\n var prevMonthVisibleDays = (0, _getVisibleDays[\"default\"])(prevMonth, 1, enableOutsideDays);\n this.setState({\n currentMonth: prevMonth,\n visibleDays: _objectSpread({}, newVisibleDays, {}, this.getModifiers(prevMonthVisibleDays))\n }, function () {\n onPrevMonthClick(prevMonth.clone());\n });\n };\n\n _proto.onNextMonthClick = function onNextMonthClick() {\n var _this$props4 = this.props,\n onNextMonthClick = _this$props4.onNextMonthClick,\n numberOfMonths = _this$props4.numberOfMonths,\n enableOutsideDays = _this$props4.enableOutsideDays;\n var _this$state4 = this.state,\n currentMonth = _this$state4.currentMonth,\n visibleDays = _this$state4.visibleDays;\n var newVisibleDays = {};\n Object.keys(visibleDays).sort().slice(1).forEach(function (month) {\n newVisibleDays[month] = visibleDays[month];\n });\n var nextMonth = currentMonth.clone().add(numberOfMonths, 'month');\n var nextMonthVisibleDays = (0, _getVisibleDays[\"default\"])(nextMonth, 1, enableOutsideDays);\n var newCurrentMonth = currentMonth.clone().add(1, 'month');\n this.setState({\n currentMonth: newCurrentMonth,\n visibleDays: _objectSpread({}, newVisibleDays, {}, this.getModifiers(nextMonthVisibleDays))\n }, function () {\n onNextMonthClick(newCurrentMonth.clone());\n });\n };\n\n _proto.onMonthChange = function onMonthChange(newMonth) {\n var _this$props5 = this.props,\n numberOfMonths = _this$props5.numberOfMonths,\n enableOutsideDays = _this$props5.enableOutsideDays,\n orientation = _this$props5.orientation;\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(newMonth, numberOfMonths, enableOutsideDays, withoutTransitionMonths);\n this.setState({\n currentMonth: newMonth.clone(),\n visibleDays: this.getModifiers(newVisibleDays)\n });\n };\n\n _proto.onYearChange = function onYearChange(newMonth) {\n var _this$props6 = this.props,\n numberOfMonths = _this$props6.numberOfMonths,\n enableOutsideDays = _this$props6.enableOutsideDays,\n orientation = _this$props6.orientation;\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(newMonth, numberOfMonths, enableOutsideDays, withoutTransitionMonths);\n this.setState({\n currentMonth: newMonth.clone(),\n visibleDays: this.getModifiers(newVisibleDays)\n });\n };\n\n _proto.onGetNextScrollableMonths = function onGetNextScrollableMonths() {\n var _this$props7 = this.props,\n numberOfMonths = _this$props7.numberOfMonths,\n enableOutsideDays = _this$props7.enableOutsideDays;\n var _this$state5 = this.state,\n currentMonth = _this$state5.currentMonth,\n visibleDays = _this$state5.visibleDays;\n var numberOfVisibleMonths = Object.keys(visibleDays).length;\n var nextMonth = currentMonth.clone().add(numberOfVisibleMonths, 'month');\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(nextMonth, numberOfMonths, enableOutsideDays, true);\n this.setState({\n visibleDays: _objectSpread({}, visibleDays, {}, this.getModifiers(newVisibleDays))\n });\n };\n\n _proto.onGetPrevScrollableMonths = function onGetPrevScrollableMonths() {\n var _this$props8 = this.props,\n numberOfMonths = _this$props8.numberOfMonths,\n enableOutsideDays = _this$props8.enableOutsideDays;\n var _this$state6 = this.state,\n currentMonth = _this$state6.currentMonth,\n visibleDays = _this$state6.visibleDays;\n var firstPreviousMonth = currentMonth.clone().subtract(numberOfMonths, 'month');\n var newVisibleDays = (0, _getVisibleDays[\"default\"])(firstPreviousMonth, numberOfMonths, enableOutsideDays, true);\n this.setState({\n currentMonth: firstPreviousMonth.clone(),\n visibleDays: _objectSpread({}, visibleDays, {}, this.getModifiers(newVisibleDays))\n });\n };\n\n _proto.getFirstFocusableDay = function getFirstFocusableDay(newMonth) {\n var _this3 = this;\n\n var _this$props9 = this.props,\n date = _this$props9.date,\n numberOfMonths = _this$props9.numberOfMonths;\n var focusedDate = newMonth.clone().startOf('month');\n\n if (date) {\n focusedDate = date.clone();\n }\n\n if (this.isBlocked(focusedDate)) {\n var days = [];\n var lastVisibleDay = newMonth.clone().add(numberOfMonths - 1, 'months').endOf('month');\n var currentDay = focusedDate.clone();\n\n while (!(0, _isAfterDay[\"default\"])(currentDay, lastVisibleDay)) {\n currentDay = currentDay.clone().add(1, 'day');\n days.push(currentDay);\n }\n\n var viableDays = days.filter(function (day) {\n return !_this3.isBlocked(day) && (0, _isAfterDay[\"default\"])(day, focusedDate);\n });\n\n if (viableDays.length > 0) {\n var _viableDays = (0, _slicedToArray2[\"default\"])(viableDays, 1);\n\n focusedDate = _viableDays[0];\n }\n }\n\n return focusedDate;\n };\n\n _proto.getModifiers = function getModifiers(visibleDays) {\n var _this4 = this;\n\n var modifiers = {};\n Object.keys(visibleDays).forEach(function (month) {\n modifiers[month] = {};\n visibleDays[month].forEach(function (day) {\n modifiers[month][(0, _toISODateString[\"default\"])(day)] = _this4.getModifiersForDay(day);\n });\n });\n return modifiers;\n };\n\n _proto.getModifiersForDay = function getModifiersForDay(day) {\n var _this5 = this;\n\n return new Set(Object.keys(this.modifiers).filter(function (modifier) {\n return _this5.modifiers[modifier](day);\n }));\n };\n\n _proto.getStateForNewMonth = function getStateForNewMonth(nextProps) {\n var _this6 = this;\n\n var initialVisibleMonth = nextProps.initialVisibleMonth,\n date = nextProps.date,\n numberOfMonths = nextProps.numberOfMonths,\n orientation = nextProps.orientation,\n enableOutsideDays = nextProps.enableOutsideDays;\n var initialVisibleMonthThunk = initialVisibleMonth || (date ? function () {\n return date;\n } : function () {\n return _this6.today;\n });\n var currentMonth = initialVisibleMonthThunk();\n var withoutTransitionMonths = orientation === _constants.VERTICAL_SCROLLABLE;\n var visibleDays = this.getModifiers((0, _getVisibleDays[\"default\"])(currentMonth, numberOfMonths, enableOutsideDays, withoutTransitionMonths));\n return {\n currentMonth: currentMonth,\n visibleDays: visibleDays\n };\n };\n\n _proto.addModifier = function addModifier(updatedDays, day, modifier) {\n return (0, _modifiers.addModifier)(updatedDays, day, modifier, this.props, this.state);\n };\n\n _proto.deleteModifier = function deleteModifier(updatedDays, day, modifier) {\n return (0, _modifiers.deleteModifier)(updatedDays, day, modifier, this.props, this.state);\n };\n\n _proto.isBlocked = function isBlocked(day) {\n var _this$props10 = this.props,\n isDayBlocked = _this$props10.isDayBlocked,\n isOutsideRange = _this$props10.isOutsideRange;\n return isDayBlocked(day) || isOutsideRange(day);\n };\n\n _proto.isHovered = function isHovered(day) {\n var _ref2 = this.state || {},\n hoverDate = _ref2.hoverDate;\n\n return (0, _isSameDay[\"default\"])(day, hoverDate);\n };\n\n _proto.isSelected = function isSelected(day) {\n var date = this.props.date;\n return (0, _isSameDay[\"default\"])(day, date);\n };\n\n _proto.isToday = function isToday(day) {\n return (0, _isSameDay[\"default\"])(day, this.today);\n };\n\n _proto.isFirstDayOfWeek = function isFirstDayOfWeek(day) {\n var firstDayOfWeek = this.props.firstDayOfWeek;\n return day.day() === (firstDayOfWeek || _moment[\"default\"].localeData().firstDayOfWeek());\n };\n\n _proto.isLastDayOfWeek = function isLastDayOfWeek(day) {\n var firstDayOfWeek = this.props.firstDayOfWeek;\n return day.day() === ((firstDayOfWeek || _moment[\"default\"].localeData().firstDayOfWeek()) + 6) % 7;\n };\n\n _proto.render = function render() {\n var _this$props11 = this.props,\n numberOfMonths = _this$props11.numberOfMonths,\n orientation = _this$props11.orientation,\n monthFormat = _this$props11.monthFormat,\n renderMonthText = _this$props11.renderMonthText,\n renderWeekHeaderElement = _this$props11.renderWeekHeaderElement,\n dayPickerNavigationInlineStyles = _this$props11.dayPickerNavigationInlineStyles,\n navPosition = _this$props11.navPosition,\n navPrev = _this$props11.navPrev,\n navNext = _this$props11.navNext,\n renderNavPrevButton = _this$props11.renderNavPrevButton,\n renderNavNextButton = _this$props11.renderNavNextButton,\n noNavButtons = _this$props11.noNavButtons,\n noNavPrevButton = _this$props11.noNavPrevButton,\n noNavNextButton = _this$props11.noNavNextButton,\n onOutsideClick = _this$props11.onOutsideClick,\n onShiftTab = _this$props11.onShiftTab,\n onTab = _this$props11.onTab,\n withPortal = _this$props11.withPortal,\n focused = _this$props11.focused,\n enableOutsideDays = _this$props11.enableOutsideDays,\n hideKeyboardShortcutsPanel = _this$props11.hideKeyboardShortcutsPanel,\n daySize = _this$props11.daySize,\n firstDayOfWeek = _this$props11.firstDayOfWeek,\n renderCalendarDay = _this$props11.renderCalendarDay,\n renderDayContents = _this$props11.renderDayContents,\n renderCalendarInfo = _this$props11.renderCalendarInfo,\n renderMonthElement = _this$props11.renderMonthElement,\n calendarInfoPosition = _this$props11.calendarInfoPosition,\n isFocused = _this$props11.isFocused,\n isRTL = _this$props11.isRTL,\n phrases = _this$props11.phrases,\n dayAriaLabelFormat = _this$props11.dayAriaLabelFormat,\n onBlur = _this$props11.onBlur,\n showKeyboardShortcuts = _this$props11.showKeyboardShortcuts,\n weekDayFormat = _this$props11.weekDayFormat,\n verticalHeight = _this$props11.verticalHeight,\n noBorder = _this$props11.noBorder,\n transitionDuration = _this$props11.transitionDuration,\n verticalBorderSpacing = _this$props11.verticalBorderSpacing,\n horizontalMonthPadding = _this$props11.horizontalMonthPadding;\n var _this$state7 = this.state,\n currentMonth = _this$state7.currentMonth,\n visibleDays = _this$state7.visibleDays;\n return _react[\"default\"].createElement(_DayPicker[\"default\"], {\n orientation: orientation,\n enableOutsideDays: enableOutsideDays,\n modifiers: visibleDays,\n numberOfMonths: numberOfMonths,\n onDayClick: this.onDayClick,\n onDayMouseEnter: this.onDayMouseEnter,\n onDayMouseLeave: this.onDayMouseLeave,\n onPrevMonthClick: this.onPrevMonthClick,\n onNextMonthClick: this.onNextMonthClick,\n onMonthChange: this.onMonthChange,\n onYearChange: this.onYearChange,\n onGetNextScrollableMonths: this.onGetNextScrollableMonths,\n onGetPrevScrollableMonths: this.onGetPrevScrollableMonths,\n monthFormat: monthFormat,\n withPortal: withPortal,\n hidden: !focused,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n initialVisibleMonth: function initialVisibleMonth() {\n return currentMonth;\n },\n firstDayOfWeek: firstDayOfWeek,\n onOutsideClick: onOutsideClick,\n dayPickerNavigationInlineStyles: dayPickerNavigationInlineStyles,\n navPosition: navPosition,\n navPrev: navPrev,\n navNext: navNext,\n renderNavPrevButton: renderNavPrevButton,\n renderNavNextButton: renderNavNextButton,\n noNavButtons: noNavButtons,\n noNavNextButton: noNavNextButton,\n noNavPrevButton: noNavPrevButton,\n renderMonthText: renderMonthText,\n renderWeekHeaderElement: renderWeekHeaderElement,\n renderCalendarDay: renderCalendarDay,\n renderDayContents: renderDayContents,\n renderCalendarInfo: renderCalendarInfo,\n renderMonthElement: renderMonthElement,\n calendarInfoPosition: calendarInfoPosition,\n isFocused: isFocused,\n getFirstFocusableDay: this.getFirstFocusableDay,\n onBlur: onBlur,\n onTab: onTab,\n onShiftTab: onShiftTab,\n phrases: phrases,\n daySize: daySize,\n isRTL: isRTL,\n showKeyboardShortcuts: showKeyboardShortcuts,\n weekDayFormat: weekDayFormat,\n dayAriaLabelFormat: dayAriaLabelFormat,\n verticalHeight: verticalHeight,\n noBorder: noBorder,\n transitionDuration: transitionDuration,\n verticalBorderSpacing: verticalBorderSpacing,\n horizontalMonthPadding: horizontalMonthPadding\n });\n };\n\n return DayPickerSingleDateController;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports[\"default\"] = DayPickerSingleDateController;\nDayPickerSingleDateController.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nDayPickerSingleDateController.defaultProps = defaultProps;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _IconPositionShape = _interopRequireDefault(require(\"./IconPositionShape\"));\n\nvar _OrientationShape = _interopRequireDefault(require(\"./OrientationShape\"));\n\nvar _AnchorDirectionShape = _interopRequireDefault(require(\"./AnchorDirectionShape\"));\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"./OpenDirectionShape\"));\n\nvar _DayOfWeekShape = _interopRequireDefault(require(\"./DayOfWeekShape\"));\n\nvar _CalendarInfoPositionShape = _interopRequireDefault(require(\"./CalendarInfoPositionShape\"));\n\nvar _NavPositionShape = _interopRequireDefault(require(\"./NavPositionShape\"));\n\nvar _default = {\n // required props for a functional interactive SingleDatePicker\n date: _reactMomentProptypes[\"default\"].momentObj,\n onDateChange: _propTypes[\"default\"].func.isRequired,\n focused: _propTypes[\"default\"].bool,\n onFocusChange: _propTypes[\"default\"].func.isRequired,\n // input related props\n id: _propTypes[\"default\"].string.isRequired,\n placeholder: _propTypes[\"default\"].string,\n ariaLabel: _propTypes[\"default\"].string,\n disabled: _propTypes[\"default\"].bool,\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n screenReaderInputMessage: _propTypes[\"default\"].string,\n showClearDate: _propTypes[\"default\"].bool,\n customCloseIcon: _propTypes[\"default\"].node,\n showDefaultInputIcon: _propTypes[\"default\"].bool,\n inputIconPosition: _IconPositionShape[\"default\"],\n customInputIcon: _propTypes[\"default\"].node,\n noBorder: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n small: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n keepFocusOnInput: _propTypes[\"default\"].bool,\n // calendar presentation and interaction related props\n renderMonthText: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderMonthElement: (0, _airbnbPropTypes.mutuallyExclusiveProps)(_propTypes[\"default\"].func, 'renderMonthText', 'renderMonthElement'),\n renderWeekHeaderElement: _propTypes[\"default\"].func,\n orientation: _OrientationShape[\"default\"],\n anchorDirection: _AnchorDirectionShape[\"default\"],\n openDirection: _OpenDirectionShape[\"default\"],\n horizontalMargin: _propTypes[\"default\"].number,\n withPortal: _propTypes[\"default\"].bool,\n withFullScreenPortal: _propTypes[\"default\"].bool,\n appendToBody: _propTypes[\"default\"].bool,\n disableScroll: _propTypes[\"default\"].bool,\n initialVisibleMonth: _propTypes[\"default\"].func,\n firstDayOfWeek: _DayOfWeekShape[\"default\"],\n numberOfMonths: _propTypes[\"default\"].number,\n keepOpenOnDateSelect: _propTypes[\"default\"].bool,\n reopenPickerOnClearDate: _propTypes[\"default\"].bool,\n renderCalendarInfo: _propTypes[\"default\"].func,\n calendarInfoPosition: _CalendarInfoPositionShape[\"default\"],\n hideKeyboardShortcutsPanel: _propTypes[\"default\"].bool,\n daySize: _airbnbPropTypes.nonNegativeInteger,\n isRTL: _propTypes[\"default\"].bool,\n verticalHeight: _airbnbPropTypes.nonNegativeInteger,\n transitionDuration: _airbnbPropTypes.nonNegativeInteger,\n horizontalMonthPadding: _airbnbPropTypes.nonNegativeInteger,\n // navigation related props\n dayPickerNavigationInlineStyles: _propTypes[\"default\"].object,\n navPosition: _NavPositionShape[\"default\"],\n navPrev: _propTypes[\"default\"].node,\n navNext: _propTypes[\"default\"].node,\n renderNavPrevButton: _propTypes[\"default\"].func,\n renderNavNextButton: _propTypes[\"default\"].func,\n onPrevMonthClick: _propTypes[\"default\"].func,\n onNextMonthClick: _propTypes[\"default\"].func,\n onClose: _propTypes[\"default\"].func,\n // day presentation and interaction related props\n renderCalendarDay: _propTypes[\"default\"].func,\n renderDayContents: _propTypes[\"default\"].func,\n enableOutsideDays: _propTypes[\"default\"].bool,\n isDayBlocked: _propTypes[\"default\"].func,\n isOutsideRange: _propTypes[\"default\"].func,\n isDayHighlighted: _propTypes[\"default\"].func,\n // internationalization props\n displayFormat: _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].string, _propTypes[\"default\"].func]),\n monthFormat: _propTypes[\"default\"].string,\n weekDayFormat: _propTypes[\"default\"].string,\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.SingleDatePickerPhrases)),\n dayAriaLabelFormat: _propTypes[\"default\"].string\n};\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _DateInput = _interopRequireDefault(require(\"./DateInput\"));\n\nvar _IconPositionShape = _interopRequireDefault(require(\"../shapes/IconPositionShape\"));\n\nvar _CloseButton = _interopRequireDefault(require(\"./CloseButton\"));\n\nvar _CalendarIcon = _interopRequireDefault(require(\"./CalendarIcon\"));\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"../shapes/OpenDirectionShape\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {\n id: _propTypes[\"default\"].string.isRequired,\n children: _propTypes[\"default\"].node,\n placeholder: _propTypes[\"default\"].string,\n ariaLabel: _propTypes[\"default\"].string,\n displayValue: _propTypes[\"default\"].string,\n screenReaderMessage: _propTypes[\"default\"].string,\n focused: _propTypes[\"default\"].bool,\n isFocused: _propTypes[\"default\"].bool,\n // describes actual DOM focus\n disabled: _propTypes[\"default\"].bool,\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n openDirection: _OpenDirectionShape[\"default\"],\n showCaret: _propTypes[\"default\"].bool,\n showClearDate: _propTypes[\"default\"].bool,\n customCloseIcon: _propTypes[\"default\"].node,\n showDefaultInputIcon: _propTypes[\"default\"].bool,\n inputIconPosition: _IconPositionShape[\"default\"],\n customInputIcon: _propTypes[\"default\"].node,\n isRTL: _propTypes[\"default\"].bool,\n noBorder: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n small: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n onChange: _propTypes[\"default\"].func,\n onClearDate: _propTypes[\"default\"].func,\n onFocus: _propTypes[\"default\"].func,\n onKeyDownShiftTab: _propTypes[\"default\"].func,\n onKeyDownTab: _propTypes[\"default\"].func,\n onKeyDownArrowDown: _propTypes[\"default\"].func,\n onKeyDownQuestionMark: _propTypes[\"default\"].func,\n // i18n\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.SingleDatePickerInputPhrases))\n})) : {};\nvar defaultProps = {\n children: null,\n placeholder: 'Select Date',\n ariaLabel: undefined,\n displayValue: '',\n screenReaderMessage: '',\n focused: false,\n isFocused: false,\n disabled: false,\n required: false,\n readOnly: false,\n openDirection: _constants.OPEN_DOWN,\n showCaret: false,\n showClearDate: false,\n showDefaultInputIcon: false,\n inputIconPosition: _constants.ICON_BEFORE_POSITION,\n customCloseIcon: null,\n customInputIcon: null,\n isRTL: false,\n noBorder: false,\n block: false,\n small: false,\n regular: false,\n verticalSpacing: undefined,\n onChange: function onChange() {},\n onClearDate: function onClearDate() {},\n onFocus: function onFocus() {},\n onKeyDownShiftTab: function onKeyDownShiftTab() {},\n onKeyDownTab: function onKeyDownTab() {},\n onKeyDownArrowDown: function onKeyDownArrowDown() {},\n onKeyDownQuestionMark: function onKeyDownQuestionMark() {},\n // i18n\n phrases: _defaultPhrases.SingleDatePickerInputPhrases\n};\n\nfunction SingleDatePickerInput(_ref) {\n var id = _ref.id,\n children = _ref.children,\n placeholder = _ref.placeholder,\n ariaLabel = _ref.ariaLabel,\n displayValue = _ref.displayValue,\n focused = _ref.focused,\n isFocused = _ref.isFocused,\n disabled = _ref.disabled,\n required = _ref.required,\n readOnly = _ref.readOnly,\n showCaret = _ref.showCaret,\n showClearDate = _ref.showClearDate,\n showDefaultInputIcon = _ref.showDefaultInputIcon,\n inputIconPosition = _ref.inputIconPosition,\n phrases = _ref.phrases,\n onClearDate = _ref.onClearDate,\n onChange = _ref.onChange,\n onFocus = _ref.onFocus,\n onKeyDownShiftTab = _ref.onKeyDownShiftTab,\n onKeyDownTab = _ref.onKeyDownTab,\n onKeyDownArrowDown = _ref.onKeyDownArrowDown,\n onKeyDownQuestionMark = _ref.onKeyDownQuestionMark,\n screenReaderMessage = _ref.screenReaderMessage,\n customCloseIcon = _ref.customCloseIcon,\n customInputIcon = _ref.customInputIcon,\n openDirection = _ref.openDirection,\n isRTL = _ref.isRTL,\n noBorder = _ref.noBorder,\n block = _ref.block,\n small = _ref.small,\n regular = _ref.regular,\n verticalSpacing = _ref.verticalSpacing,\n styles = _ref.styles;\n\n var calendarIcon = customInputIcon || _react[\"default\"].createElement(_CalendarIcon[\"default\"], (0, _reactWithStyles.css)(styles.SingleDatePickerInput_calendarIcon_svg));\n\n var closeIcon = customCloseIcon || _react[\"default\"].createElement(_CloseButton[\"default\"], (0, _reactWithStyles.css)(styles.SingleDatePickerInput_clearDate_svg, small && styles.SingleDatePickerInput_clearDate_svg__small));\n\n var screenReaderText = screenReaderMessage || phrases.keyboardForwardNavigationInstructions;\n\n var inputIcon = (showDefaultInputIcon || customInputIcon !== null) && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.SingleDatePickerInput_calendarIcon), {\n type: \"button\",\n disabled: disabled,\n \"aria-label\": phrases.focusStartDate,\n onClick: onFocus\n }), calendarIcon);\n\n return _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.SingleDatePickerInput, disabled && styles.SingleDatePickerInput__disabled, isRTL && styles.SingleDatePickerInput__rtl, !noBorder && styles.SingleDatePickerInput__withBorder, block && styles.SingleDatePickerInput__block, showClearDate && styles.SingleDatePickerInput__showClearDate), inputIconPosition === _constants.ICON_BEFORE_POSITION && inputIcon, _react[\"default\"].createElement(_DateInput[\"default\"], {\n id: id,\n placeholder: placeholder,\n ariaLabel: ariaLabel,\n displayValue: displayValue,\n screenReaderMessage: screenReaderText,\n focused: focused,\n isFocused: isFocused,\n disabled: disabled,\n required: required,\n readOnly: readOnly,\n showCaret: showCaret,\n onChange: onChange,\n onFocus: onFocus,\n onKeyDownShiftTab: onKeyDownShiftTab,\n onKeyDownTab: onKeyDownTab,\n onKeyDownArrowDown: onKeyDownArrowDown,\n onKeyDownQuestionMark: onKeyDownQuestionMark,\n openDirection: openDirection,\n verticalSpacing: verticalSpacing,\n small: small,\n regular: regular,\n block: block\n }), children, showClearDate && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.SingleDatePickerInput_clearDate, small && styles.SingleDatePickerInput_clearDate__small, !customCloseIcon && styles.SingleDatePickerInput_clearDate__default, !displayValue && styles.SingleDatePickerInput_clearDate__hide), {\n type: \"button\",\n \"aria-label\": phrases.clearDate,\n disabled: disabled,\n onClick: onClearDate\n }), closeIcon), inputIconPosition === _constants.ICON_AFTER_POSITION && inputIcon);\n}\n\nSingleDatePickerInput.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nSingleDatePickerInput.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref2) {\n var _ref2$reactDates = _ref2.reactDates,\n border = _ref2$reactDates.border,\n color = _ref2$reactDates.color;\n return {\n SingleDatePickerInput: {\n display: 'inline-block',\n backgroundColor: color.background\n },\n SingleDatePickerInput__withBorder: {\n borderColor: color.border,\n borderWidth: border.pickerInput.borderWidth,\n borderStyle: border.pickerInput.borderStyle,\n borderRadius: border.pickerInput.borderRadius\n },\n SingleDatePickerInput__rtl: {\n direction: (0, _noflip[\"default\"])('rtl')\n },\n SingleDatePickerInput__disabled: {\n backgroundColor: color.disabled\n },\n SingleDatePickerInput__block: {\n display: 'block'\n },\n SingleDatePickerInput__showClearDate: {\n paddingRight: 30 // TODO: should be noflip wrapped and handled by an isRTL prop\n\n },\n SingleDatePickerInput_clearDate: {\n background: 'none',\n border: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n cursor: 'pointer',\n padding: 10,\n margin: '0 10px 0 5px',\n // TODO: should be noflip wrapped and handled by an isRTL prop\n position: 'absolute',\n right: 0,\n // TODO: should be noflip wrapped and handled by an isRTL prop\n top: '50%',\n transform: 'translateY(-50%)'\n },\n SingleDatePickerInput_clearDate__default: {\n ':focus': {\n background: color.core.border,\n borderRadius: '50%'\n },\n ':hover': {\n background: color.core.border,\n borderRadius: '50%'\n }\n },\n SingleDatePickerInput_clearDate__small: {\n padding: 6\n },\n SingleDatePickerInput_clearDate__hide: {\n visibility: 'hidden'\n },\n SingleDatePickerInput_clearDate_svg: {\n fill: color.core.grayLight,\n height: 12,\n width: 15,\n verticalAlign: 'middle'\n },\n SingleDatePickerInput_clearDate_svg__small: {\n height: 9\n },\n SingleDatePickerInput_calendarIcon: {\n background: 'none',\n border: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n cursor: 'pointer',\n display: 'inline-block',\n verticalAlign: 'middle',\n padding: 10,\n margin: '0 5px 0 10px' // TODO: should be noflip wrapped and handled by an isRTL prop\n\n },\n SingleDatePickerInput_calendarIcon_svg: {\n fill: color.core.grayLight,\n height: 15,\n width: 14,\n verticalAlign: 'middle'\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(SingleDatePickerInput);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _reactMomentProptypes = _interopRequireDefault(require(\"react-moment-proptypes\"));\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _OpenDirectionShape = _interopRequireDefault(require(\"../shapes/OpenDirectionShape\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getPhrasePropTypes = _interopRequireDefault(require(\"../utils/getPhrasePropTypes\"));\n\nvar _SingleDatePickerInput = _interopRequireDefault(require(\"./SingleDatePickerInput\"));\n\nvar _IconPositionShape = _interopRequireDefault(require(\"../shapes/IconPositionShape\"));\n\nvar _DisabledShape = _interopRequireDefault(require(\"../shapes/DisabledShape\"));\n\nvar _toMomentObject = _interopRequireDefault(require(\"../utils/toMomentObject\"));\n\nvar _toLocalizedDateString = _interopRequireDefault(require(\"../utils/toLocalizedDateString\"));\n\nvar _isInclusivelyAfterDay = _interopRequireDefault(require(\"../utils/isInclusivelyAfterDay\"));\n\nvar _constants = require(\"../constants\");\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)({\n children: _propTypes[\"default\"].node,\n date: _reactMomentProptypes[\"default\"].momentObj,\n onDateChange: _propTypes[\"default\"].func.isRequired,\n focused: _propTypes[\"default\"].bool,\n onFocusChange: _propTypes[\"default\"].func.isRequired,\n id: _propTypes[\"default\"].string.isRequired,\n placeholder: _propTypes[\"default\"].string,\n ariaLabel: _propTypes[\"default\"].string,\n screenReaderMessage: _propTypes[\"default\"].string,\n showClearDate: _propTypes[\"default\"].bool,\n showCaret: _propTypes[\"default\"].bool,\n showDefaultInputIcon: _propTypes[\"default\"].bool,\n inputIconPosition: _IconPositionShape[\"default\"],\n disabled: _DisabledShape[\"default\"],\n required: _propTypes[\"default\"].bool,\n readOnly: _propTypes[\"default\"].bool,\n openDirection: _OpenDirectionShape[\"default\"],\n noBorder: _propTypes[\"default\"].bool,\n block: _propTypes[\"default\"].bool,\n small: _propTypes[\"default\"].bool,\n regular: _propTypes[\"default\"].bool,\n verticalSpacing: _airbnbPropTypes.nonNegativeInteger,\n keepOpenOnDateSelect: _propTypes[\"default\"].bool,\n reopenPickerOnClearDate: _propTypes[\"default\"].bool,\n isOutsideRange: _propTypes[\"default\"].func,\n displayFormat: _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].string, _propTypes[\"default\"].func]),\n onClose: _propTypes[\"default\"].func,\n onKeyDownArrowDown: _propTypes[\"default\"].func,\n onKeyDownQuestionMark: _propTypes[\"default\"].func,\n customInputIcon: _propTypes[\"default\"].node,\n customCloseIcon: _propTypes[\"default\"].node,\n // accessibility\n isFocused: _propTypes[\"default\"].bool,\n // i18n\n phrases: _propTypes[\"default\"].shape((0, _getPhrasePropTypes[\"default\"])(_defaultPhrases.SingleDatePickerInputPhrases)),\n isRTL: _propTypes[\"default\"].bool\n}) : {};\nvar defaultProps = {\n children: null,\n date: null,\n focused: false,\n placeholder: '',\n ariaLabel: undefined,\n screenReaderMessage: 'Date',\n showClearDate: false,\n showCaret: false,\n showDefaultInputIcon: false,\n inputIconPosition: _constants.ICON_BEFORE_POSITION,\n disabled: false,\n required: false,\n readOnly: false,\n openDirection: _constants.OPEN_DOWN,\n noBorder: false,\n block: false,\n small: false,\n regular: false,\n verticalSpacing: undefined,\n keepOpenOnDateSelect: false,\n reopenPickerOnClearDate: false,\n isOutsideRange: function isOutsideRange(day) {\n return !(0, _isInclusivelyAfterDay[\"default\"])(day, (0, _moment[\"default\"])());\n },\n displayFormat: function displayFormat() {\n return _moment[\"default\"].localeData().longDateFormat('L');\n },\n onClose: function onClose() {},\n onKeyDownArrowDown: function onKeyDownArrowDown() {},\n onKeyDownQuestionMark: function onKeyDownQuestionMark() {},\n customInputIcon: null,\n customCloseIcon: null,\n // accessibility\n isFocused: false,\n // i18n\n phrases: _defaultPhrases.SingleDatePickerInputPhrases,\n isRTL: false\n};\n\nvar SingleDatePickerInputController =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(SingleDatePickerInputController, _ref);\n var _proto = SingleDatePickerInputController.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function SingleDatePickerInputController(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.onChange = _this.onChange.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onFocus = _this.onFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onClearFocus = _this.onClearFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.clearDate = _this.clearDate.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n\n _proto.onChange = function onChange(dateString) {\n var _this$props = this.props,\n isOutsideRange = _this$props.isOutsideRange,\n keepOpenOnDateSelect = _this$props.keepOpenOnDateSelect,\n onDateChange = _this$props.onDateChange,\n onFocusChange = _this$props.onFocusChange,\n onClose = _this$props.onClose;\n var newDate = (0, _toMomentObject[\"default\"])(dateString, this.getDisplayFormat());\n var isValid = newDate && !isOutsideRange(newDate);\n\n if (isValid) {\n onDateChange(newDate);\n\n if (!keepOpenOnDateSelect) {\n onFocusChange({\n focused: false\n });\n onClose({\n date: newDate\n });\n }\n } else {\n onDateChange(null);\n }\n };\n\n _proto.onFocus = function onFocus() {\n var _this$props2 = this.props,\n onFocusChange = _this$props2.onFocusChange,\n disabled = _this$props2.disabled;\n\n if (!disabled) {\n onFocusChange({\n focused: true\n });\n }\n };\n\n _proto.onClearFocus = function onClearFocus() {\n var _this$props3 = this.props,\n focused = _this$props3.focused,\n onFocusChange = _this$props3.onFocusChange,\n onClose = _this$props3.onClose,\n date = _this$props3.date;\n if (!focused) return;\n onFocusChange({\n focused: false\n });\n onClose({\n date: date\n });\n };\n\n _proto.getDisplayFormat = function getDisplayFormat() {\n var displayFormat = this.props.displayFormat;\n return typeof displayFormat === 'string' ? displayFormat : displayFormat();\n };\n\n _proto.getDateString = function getDateString(date) {\n var displayFormat = this.getDisplayFormat();\n\n if (date && displayFormat) {\n return date && date.format(displayFormat);\n }\n\n return (0, _toLocalizedDateString[\"default\"])(date);\n };\n\n _proto.clearDate = function clearDate() {\n var _this$props4 = this.props,\n onDateChange = _this$props4.onDateChange,\n reopenPickerOnClearDate = _this$props4.reopenPickerOnClearDate,\n onFocusChange = _this$props4.onFocusChange;\n onDateChange(null);\n\n if (reopenPickerOnClearDate) {\n onFocusChange({\n focused: true\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props5 = this.props,\n children = _this$props5.children,\n id = _this$props5.id,\n placeholder = _this$props5.placeholder,\n ariaLabel = _this$props5.ariaLabel,\n disabled = _this$props5.disabled,\n focused = _this$props5.focused,\n isFocused = _this$props5.isFocused,\n required = _this$props5.required,\n readOnly = _this$props5.readOnly,\n openDirection = _this$props5.openDirection,\n showClearDate = _this$props5.showClearDate,\n showCaret = _this$props5.showCaret,\n showDefaultInputIcon = _this$props5.showDefaultInputIcon,\n inputIconPosition = _this$props5.inputIconPosition,\n customCloseIcon = _this$props5.customCloseIcon,\n customInputIcon = _this$props5.customInputIcon,\n date = _this$props5.date,\n phrases = _this$props5.phrases,\n onKeyDownArrowDown = _this$props5.onKeyDownArrowDown,\n onKeyDownQuestionMark = _this$props5.onKeyDownQuestionMark,\n screenReaderMessage = _this$props5.screenReaderMessage,\n isRTL = _this$props5.isRTL,\n noBorder = _this$props5.noBorder,\n block = _this$props5.block,\n small = _this$props5.small,\n regular = _this$props5.regular,\n verticalSpacing = _this$props5.verticalSpacing;\n var displayValue = this.getDateString(date);\n return _react[\"default\"].createElement(_SingleDatePickerInput[\"default\"], {\n id: id,\n placeholder: placeholder,\n ariaLabel: ariaLabel,\n focused: focused,\n isFocused: isFocused,\n disabled: disabled,\n required: required,\n readOnly: readOnly,\n openDirection: openDirection,\n showCaret: showCaret,\n onClearDate: this.clearDate,\n showClearDate: showClearDate,\n showDefaultInputIcon: showDefaultInputIcon,\n inputIconPosition: inputIconPosition,\n customCloseIcon: customCloseIcon,\n customInputIcon: customInputIcon,\n displayValue: displayValue,\n onChange: this.onChange,\n onFocus: this.onFocus,\n onKeyDownShiftTab: this.onClearFocus,\n onKeyDownArrowDown: onKeyDownArrowDown,\n onKeyDownQuestionMark: onKeyDownQuestionMark,\n screenReaderMessage: screenReaderMessage,\n phrases: phrases,\n isRTL: isRTL,\n noBorder: noBorder,\n block: block,\n small: small,\n regular: regular,\n verticalSpacing: verticalSpacing\n }, children);\n };\n\n return SingleDatePickerInputController;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports[\"default\"] = SingleDatePickerInputController;\nSingleDatePickerInputController.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nSingleDatePickerInputController.defaultProps = defaultProps;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.PureSingleDatePicker = void 0;\n\nvar _enzymeShallowEqual = _interopRequireDefault(require(\"enzyme-shallow-equal\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _reactWithStyles = require(\"react-with-styles\");\n\nvar _reactPortal = require(\"react-portal\");\n\nvar _airbnbPropTypes = require(\"airbnb-prop-types\");\n\nvar _consolidatedEvents = require(\"consolidated-events\");\n\nvar _isTouchDevice = _interopRequireDefault(require(\"is-touch-device\"));\n\nvar _reactOutsideClickHandler = _interopRequireDefault(require(\"react-outside-click-handler\"));\n\nvar _SingleDatePickerShape = _interopRequireDefault(require(\"../shapes/SingleDatePickerShape\"));\n\nvar _defaultPhrases = require(\"../defaultPhrases\");\n\nvar _getResponsiveContainerStyles = _interopRequireDefault(require(\"../utils/getResponsiveContainerStyles\"));\n\nvar _getDetachedContainerStyles = _interopRequireDefault(require(\"../utils/getDetachedContainerStyles\"));\n\nvar _getInputHeight = _interopRequireDefault(require(\"../utils/getInputHeight\"));\n\nvar _isInclusivelyAfterDay = _interopRequireDefault(require(\"../utils/isInclusivelyAfterDay\"));\n\nvar _disableScroll2 = _interopRequireDefault(require(\"../utils/disableScroll\"));\n\nvar _noflip = _interopRequireDefault(require(\"../utils/noflip\"));\n\nvar _SingleDatePickerInputController = _interopRequireDefault(require(\"./SingleDatePickerInputController\"));\n\nvar _DayPickerSingleDateController = _interopRequireDefault(require(\"./DayPickerSingleDateController\"));\n\nvar _CloseButton = _interopRequireDefault(require(\"./CloseButton\"));\n\nvar _constants = require(\"../constants\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar propTypes = process.env.NODE_ENV !== \"production\" ? (0, _airbnbPropTypes.forbidExtraProps)(_objectSpread({}, _reactWithStyles.withStylesPropTypes, {}, _SingleDatePickerShape[\"default\"])) : {};\nvar defaultProps = {\n // required props for a functional interactive SingleDatePicker\n date: null,\n focused: false,\n // input related props\n id: 'date',\n placeholder: 'Date',\n ariaLabel: undefined,\n disabled: false,\n required: false,\n readOnly: false,\n screenReaderInputMessage: '',\n showClearDate: false,\n showDefaultInputIcon: false,\n inputIconPosition: _constants.ICON_BEFORE_POSITION,\n customInputIcon: null,\n customCloseIcon: null,\n noBorder: false,\n block: false,\n small: false,\n regular: false,\n verticalSpacing: _constants.DEFAULT_VERTICAL_SPACING,\n keepFocusOnInput: false,\n // calendar presentation and interaction related props\n orientation: _constants.HORIZONTAL_ORIENTATION,\n anchorDirection: _constants.ANCHOR_LEFT,\n openDirection: _constants.OPEN_DOWN,\n horizontalMargin: 0,\n withPortal: false,\n withFullScreenPortal: false,\n appendToBody: false,\n disableScroll: false,\n initialVisibleMonth: null,\n firstDayOfWeek: null,\n numberOfMonths: 2,\n keepOpenOnDateSelect: false,\n reopenPickerOnClearDate: false,\n renderCalendarInfo: null,\n calendarInfoPosition: _constants.INFO_POSITION_BOTTOM,\n hideKeyboardShortcutsPanel: false,\n daySize: _constants.DAY_SIZE,\n isRTL: false,\n verticalHeight: null,\n transitionDuration: undefined,\n horizontalMonthPadding: 13,\n // navigation related props\n dayPickerNavigationInlineStyles: null,\n navPosition: _constants.NAV_POSITION_TOP,\n navPrev: null,\n navNext: null,\n renderNavPrevButton: null,\n renderNavNextButton: null,\n onPrevMonthClick: function onPrevMonthClick() {},\n onNextMonthClick: function onNextMonthClick() {},\n onClose: function onClose() {},\n // month presentation and interaction related props\n renderMonthText: null,\n renderWeekHeaderElement: null,\n // day presentation and interaction related props\n renderCalendarDay: undefined,\n renderDayContents: null,\n renderMonthElement: null,\n enableOutsideDays: false,\n isDayBlocked: function isDayBlocked() {\n return false;\n },\n isOutsideRange: function isOutsideRange(day) {\n return !(0, _isInclusivelyAfterDay[\"default\"])(day, (0, _moment[\"default\"])());\n },\n isDayHighlighted: function isDayHighlighted() {},\n // internationalization props\n displayFormat: function displayFormat() {\n return _moment[\"default\"].localeData().longDateFormat('L');\n },\n monthFormat: 'MMMM YYYY',\n weekDayFormat: 'dd',\n phrases: _defaultPhrases.SingleDatePickerPhrases,\n dayAriaLabelFormat: undefined\n};\n\nvar SingleDatePicker =\n/*#__PURE__*/\nfunction (_ref) {\n (0, _inheritsLoose2[\"default\"])(SingleDatePicker, _ref);\n var _proto = SingleDatePicker.prototype;\n\n _proto[!_react[\"default\"].PureComponent && \"shouldComponentUpdate\"] = function (nextProps, nextState) {\n return !(0, _enzymeShallowEqual[\"default\"])(this.props, nextProps) || !(0, _enzymeShallowEqual[\"default\"])(this.state, nextState);\n };\n\n function SingleDatePicker(props) {\n var _this;\n\n _this = _ref.call(this, props) || this;\n _this.isTouchDevice = false;\n _this.state = {\n dayPickerContainerStyles: {},\n isDayPickerFocused: false,\n isInputFocused: false,\n showKeyboardShortcuts: false\n };\n _this.onFocusOut = _this.onFocusOut.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onOutsideClick = _this.onOutsideClick.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onInputFocus = _this.onInputFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayPickerFocus = _this.onDayPickerFocus.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.onDayPickerBlur = _this.onDayPickerBlur.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.showKeyboardShortcutsPanel = _this.showKeyboardShortcutsPanel.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.responsivizePickerPosition = _this.responsivizePickerPosition.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.disableScroll = _this.disableScroll.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setDayPickerContainerRef = _this.setDayPickerContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n _this.setContainerRef = _this.setContainerRef.bind((0, _assertThisInitialized2[\"default\"])(_this));\n return _this;\n }\n /* istanbul ignore next */\n\n\n _proto.componentDidMount = function componentDidMount() {\n this.removeResizeEventListener = (0, _consolidatedEvents.addEventListener)(window, 'resize', this.responsivizePickerPosition, {\n passive: true\n });\n this.responsivizePickerPosition();\n this.disableScroll();\n var focused = this.props.focused;\n\n if (focused) {\n this.setState({\n isInputFocused: true\n });\n }\n\n this.isTouchDevice = (0, _isTouchDevice[\"default\"])();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var focused = this.props.focused;\n\n if (!prevProps.focused && focused) {\n this.responsivizePickerPosition();\n this.disableScroll();\n } else if (prevProps.focused && !focused) {\n if (this.enableScroll) this.enableScroll();\n }\n }\n /* istanbul ignore next */\n ;\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this.removeResizeEventListener) this.removeResizeEventListener();\n if (this.removeFocusOutEventListener) this.removeFocusOutEventListener();\n if (this.enableScroll) this.enableScroll();\n };\n\n _proto.onOutsideClick = function onOutsideClick(event) {\n var _this$props = this.props,\n focused = _this$props.focused,\n onFocusChange = _this$props.onFocusChange,\n onClose = _this$props.onClose,\n date = _this$props.date,\n appendToBody = _this$props.appendToBody;\n if (!focused) return;\n if (appendToBody && this.dayPickerContainer.contains(event.target)) return;\n this.setState({\n isInputFocused: false,\n isDayPickerFocused: false,\n showKeyboardShortcuts: false\n });\n onFocusChange({\n focused: false\n });\n onClose({\n date: date\n });\n };\n\n _proto.onInputFocus = function onInputFocus(_ref2) {\n var focused = _ref2.focused;\n var _this$props2 = this.props,\n onFocusChange = _this$props2.onFocusChange,\n readOnly = _this$props2.readOnly,\n withPortal = _this$props2.withPortal,\n withFullScreenPortal = _this$props2.withFullScreenPortal,\n keepFocusOnInput = _this$props2.keepFocusOnInput;\n\n if (focused) {\n var withAnyPortal = withPortal || withFullScreenPortal;\n var moveFocusToDayPicker = withAnyPortal || readOnly && !keepFocusOnInput || this.isTouchDevice && !keepFocusOnInput;\n\n if (moveFocusToDayPicker) {\n this.onDayPickerFocus();\n } else {\n this.onDayPickerBlur();\n }\n }\n\n onFocusChange({\n focused: focused\n });\n };\n\n _proto.onDayPickerFocus = function onDayPickerFocus() {\n this.setState({\n isInputFocused: false,\n isDayPickerFocused: true,\n showKeyboardShortcuts: false\n });\n };\n\n _proto.onDayPickerBlur = function onDayPickerBlur() {\n this.setState({\n isInputFocused: true,\n isDayPickerFocused: false,\n showKeyboardShortcuts: false\n });\n };\n\n _proto.onFocusOut = function onFocusOut(e) {\n var onFocusChange = this.props.onFocusChange; // In cases where **relatedTarget** is not null, it points to the right\n // element here. However, in cases where it is null (such as clicking on a\n // specific day) or it is **document.body** (IE11), the appropriate value is **event.target**.\n //\n // We handle both situations here by using the ` || ` operator to fallback\n // to *event.target** when **relatedTarget** is not provided.\n\n var relatedTarget = e.relatedTarget === document.body ? e.target : e.relatedTarget || e.target;\n if (this.dayPickerContainer.contains(relatedTarget)) return;\n onFocusChange({\n focused: false\n });\n };\n\n _proto.setDayPickerContainerRef = function setDayPickerContainerRef(ref) {\n if (ref === this.dayPickerContainer) return;\n this.removeEventListeners();\n this.dayPickerContainer = ref;\n if (!ref) return;\n this.addEventListeners();\n };\n\n _proto.setContainerRef = function setContainerRef(ref) {\n this.container = ref;\n };\n\n _proto.addEventListeners = function addEventListeners() {\n // We manually set event because React has not implemented onFocusIn/onFocusOut.\n // Keep an eye on https://github.com/facebook/react/issues/6410 for updates\n // We use \"blur w/ useCapture param\" vs \"onfocusout\" for FF browser support\n this.removeFocusOutEventListener = (0, _consolidatedEvents.addEventListener)(this.dayPickerContainer, 'focusout', this.onFocusOut);\n };\n\n _proto.removeEventListeners = function removeEventListeners() {\n if (this.removeFocusOutEventListener) this.removeFocusOutEventListener();\n };\n\n _proto.disableScroll = function disableScroll() {\n var _this$props3 = this.props,\n appendToBody = _this$props3.appendToBody,\n propDisableScroll = _this$props3.disableScroll,\n focused = _this$props3.focused;\n if (!appendToBody && !propDisableScroll) return;\n if (!focused) return; // Disable scroll for every ancestor of this up to the\n // document level. This ensures the input and the picker never move. Other\n // sibling elements or the picker itself can scroll.\n\n this.enableScroll = (0, _disableScroll2[\"default\"])(this.container);\n }\n /* istanbul ignore next */\n ;\n\n _proto.responsivizePickerPosition = function responsivizePickerPosition() {\n // It's possible the portal props have been changed in response to window resizes\n // So let's ensure we reset this back to the base state each time\n this.setState({\n dayPickerContainerStyles: {}\n });\n var _this$props4 = this.props,\n openDirection = _this$props4.openDirection,\n anchorDirection = _this$props4.anchorDirection,\n horizontalMargin = _this$props4.horizontalMargin,\n withPortal = _this$props4.withPortal,\n withFullScreenPortal = _this$props4.withFullScreenPortal,\n appendToBody = _this$props4.appendToBody,\n focused = _this$props4.focused;\n var dayPickerContainerStyles = this.state.dayPickerContainerStyles;\n\n if (!focused) {\n return;\n }\n\n var isAnchoredLeft = anchorDirection === _constants.ANCHOR_LEFT;\n\n if (!withPortal && !withFullScreenPortal) {\n var containerRect = this.dayPickerContainer.getBoundingClientRect();\n var currentOffset = dayPickerContainerStyles[anchorDirection] || 0;\n var containerEdge = isAnchoredLeft ? containerRect[_constants.ANCHOR_RIGHT] : containerRect[_constants.ANCHOR_LEFT];\n this.setState({\n dayPickerContainerStyles: _objectSpread({}, (0, _getResponsiveContainerStyles[\"default\"])(anchorDirection, currentOffset, containerEdge, horizontalMargin), {}, appendToBody && (0, _getDetachedContainerStyles[\"default\"])(openDirection, anchorDirection, this.container))\n });\n }\n };\n\n _proto.showKeyboardShortcutsPanel = function showKeyboardShortcutsPanel() {\n this.setState({\n isInputFocused: false,\n isDayPickerFocused: true,\n showKeyboardShortcuts: true\n });\n };\n\n _proto.maybeRenderDayPickerWithPortal = function maybeRenderDayPickerWithPortal() {\n var _this$props5 = this.props,\n focused = _this$props5.focused,\n withPortal = _this$props5.withPortal,\n withFullScreenPortal = _this$props5.withFullScreenPortal,\n appendToBody = _this$props5.appendToBody;\n\n if (!focused) {\n return null;\n }\n\n if (withPortal || withFullScreenPortal || appendToBody) {\n return _react[\"default\"].createElement(_reactPortal.Portal, null, this.renderDayPicker());\n }\n\n return this.renderDayPicker();\n };\n\n _proto.renderDayPicker = function renderDayPicker() {\n var _this$props6 = this.props,\n anchorDirection = _this$props6.anchorDirection,\n openDirection = _this$props6.openDirection,\n onDateChange = _this$props6.onDateChange,\n date = _this$props6.date,\n onFocusChange = _this$props6.onFocusChange,\n focused = _this$props6.focused,\n enableOutsideDays = _this$props6.enableOutsideDays,\n numberOfMonths = _this$props6.numberOfMonths,\n orientation = _this$props6.orientation,\n monthFormat = _this$props6.monthFormat,\n dayPickerNavigationInlineStyles = _this$props6.dayPickerNavigationInlineStyles,\n navPosition = _this$props6.navPosition,\n navPrev = _this$props6.navPrev,\n navNext = _this$props6.navNext,\n renderNavPrevButton = _this$props6.renderNavPrevButton,\n renderNavNextButton = _this$props6.renderNavNextButton,\n onPrevMonthClick = _this$props6.onPrevMonthClick,\n onNextMonthClick = _this$props6.onNextMonthClick,\n onClose = _this$props6.onClose,\n withPortal = _this$props6.withPortal,\n withFullScreenPortal = _this$props6.withFullScreenPortal,\n keepOpenOnDateSelect = _this$props6.keepOpenOnDateSelect,\n initialVisibleMonth = _this$props6.initialVisibleMonth,\n renderMonthText = _this$props6.renderMonthText,\n renderWeekHeaderElement = _this$props6.renderWeekHeaderElement,\n renderCalendarDay = _this$props6.renderCalendarDay,\n renderDayContents = _this$props6.renderDayContents,\n renderCalendarInfo = _this$props6.renderCalendarInfo,\n renderMonthElement = _this$props6.renderMonthElement,\n calendarInfoPosition = _this$props6.calendarInfoPosition,\n hideKeyboardShortcutsPanel = _this$props6.hideKeyboardShortcutsPanel,\n firstDayOfWeek = _this$props6.firstDayOfWeek,\n customCloseIcon = _this$props6.customCloseIcon,\n phrases = _this$props6.phrases,\n dayAriaLabelFormat = _this$props6.dayAriaLabelFormat,\n daySize = _this$props6.daySize,\n isRTL = _this$props6.isRTL,\n isOutsideRange = _this$props6.isOutsideRange,\n isDayBlocked = _this$props6.isDayBlocked,\n isDayHighlighted = _this$props6.isDayHighlighted,\n weekDayFormat = _this$props6.weekDayFormat,\n styles = _this$props6.styles,\n verticalHeight = _this$props6.verticalHeight,\n transitionDuration = _this$props6.transitionDuration,\n verticalSpacing = _this$props6.verticalSpacing,\n horizontalMonthPadding = _this$props6.horizontalMonthPadding,\n small = _this$props6.small,\n reactDates = _this$props6.theme.reactDates;\n var _this$state = this.state,\n dayPickerContainerStyles = _this$state.dayPickerContainerStyles,\n isDayPickerFocused = _this$state.isDayPickerFocused,\n showKeyboardShortcuts = _this$state.showKeyboardShortcuts;\n var onOutsideClick = !withFullScreenPortal && withPortal ? this.onOutsideClick : undefined;\n\n var closeIcon = customCloseIcon || _react[\"default\"].createElement(_CloseButton[\"default\"], null);\n\n var inputHeight = (0, _getInputHeight[\"default\"])(reactDates, small);\n var withAnyPortal = withPortal || withFullScreenPortal;\n /* eslint-disable jsx-a11y/no-static-element-interactions */\n\n /* eslint-disable jsx-a11y/click-events-have-key-events */\n\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n ref: this.setDayPickerContainerRef\n }, (0, _reactWithStyles.css)(styles.SingleDatePicker_picker, anchorDirection === _constants.ANCHOR_LEFT && styles.SingleDatePicker_picker__directionLeft, anchorDirection === _constants.ANCHOR_RIGHT && styles.SingleDatePicker_picker__directionRight, openDirection === _constants.OPEN_DOWN && styles.SingleDatePicker_picker__openDown, openDirection === _constants.OPEN_UP && styles.SingleDatePicker_picker__openUp, !withAnyPortal && openDirection === _constants.OPEN_DOWN && {\n top: inputHeight + verticalSpacing\n }, !withAnyPortal && openDirection === _constants.OPEN_UP && {\n bottom: inputHeight + verticalSpacing\n }, orientation === _constants.HORIZONTAL_ORIENTATION && styles.SingleDatePicker_picker__horizontal, orientation === _constants.VERTICAL_ORIENTATION && styles.SingleDatePicker_picker__vertical, withAnyPortal && styles.SingleDatePicker_picker__portal, withFullScreenPortal && styles.SingleDatePicker_picker__fullScreenPortal, isRTL && styles.SingleDatePicker_picker__rtl, dayPickerContainerStyles), {\n onClick: onOutsideClick\n }), _react[\"default\"].createElement(_DayPickerSingleDateController[\"default\"], {\n date: date,\n onDateChange: onDateChange,\n onFocusChange: onFocusChange,\n orientation: orientation,\n enableOutsideDays: enableOutsideDays,\n numberOfMonths: numberOfMonths,\n monthFormat: monthFormat,\n withPortal: withAnyPortal,\n focused: focused,\n keepOpenOnDateSelect: keepOpenOnDateSelect,\n hideKeyboardShortcutsPanel: hideKeyboardShortcutsPanel,\n initialVisibleMonth: initialVisibleMonth,\n dayPickerNavigationInlineStyles: dayPickerNavigationInlineStyles,\n navPosition: navPosition,\n navPrev: navPrev,\n navNext: navNext,\n renderNavPrevButton: renderNavPrevButton,\n renderNavNextButton: renderNavNextButton,\n onPrevMonthClick: onPrevMonthClick,\n onNextMonthClick: onNextMonthClick,\n onClose: onClose,\n renderMonthText: renderMonthText,\n renderWeekHeaderElement: renderWeekHeaderElement,\n renderCalendarDay: renderCalendarDay,\n renderDayContents: renderDayContents,\n renderCalendarInfo: renderCalendarInfo,\n renderMonthElement: renderMonthElement,\n calendarInfoPosition: calendarInfoPosition,\n isFocused: isDayPickerFocused,\n showKeyboardShortcuts: showKeyboardShortcuts,\n onBlur: this.onDayPickerBlur,\n phrases: phrases,\n dayAriaLabelFormat: dayAriaLabelFormat,\n daySize: daySize,\n isRTL: isRTL,\n isOutsideRange: isOutsideRange,\n isDayBlocked: isDayBlocked,\n isDayHighlighted: isDayHighlighted,\n firstDayOfWeek: firstDayOfWeek,\n weekDayFormat: weekDayFormat,\n verticalHeight: verticalHeight,\n transitionDuration: transitionDuration,\n horizontalMonthPadding: horizontalMonthPadding\n }), withFullScreenPortal && _react[\"default\"].createElement(\"button\", (0, _extends2[\"default\"])({}, (0, _reactWithStyles.css)(styles.SingleDatePicker_closeButton), {\n \"aria-label\": phrases.closeDatePicker,\n type: \"button\",\n onClick: this.onOutsideClick\n }), _react[\"default\"].createElement(\"div\", (0, _reactWithStyles.css)(styles.SingleDatePicker_closeButton_svg), closeIcon)));\n /* eslint-enable jsx-a11y/no-static-element-interactions */\n\n /* eslint-enable jsx-a11y/click-events-have-key-events */\n };\n\n _proto.render = function render() {\n var _this$props7 = this.props,\n id = _this$props7.id,\n placeholder = _this$props7.placeholder,\n ariaLabel = _this$props7.ariaLabel,\n disabled = _this$props7.disabled,\n focused = _this$props7.focused,\n required = _this$props7.required,\n readOnly = _this$props7.readOnly,\n openDirection = _this$props7.openDirection,\n showClearDate = _this$props7.showClearDate,\n showDefaultInputIcon = _this$props7.showDefaultInputIcon,\n inputIconPosition = _this$props7.inputIconPosition,\n customCloseIcon = _this$props7.customCloseIcon,\n customInputIcon = _this$props7.customInputIcon,\n date = _this$props7.date,\n onDateChange = _this$props7.onDateChange,\n displayFormat = _this$props7.displayFormat,\n phrases = _this$props7.phrases,\n withPortal = _this$props7.withPortal,\n withFullScreenPortal = _this$props7.withFullScreenPortal,\n screenReaderInputMessage = _this$props7.screenReaderInputMessage,\n isRTL = _this$props7.isRTL,\n noBorder = _this$props7.noBorder,\n block = _this$props7.block,\n small = _this$props7.small,\n regular = _this$props7.regular,\n verticalSpacing = _this$props7.verticalSpacing,\n reopenPickerOnClearDate = _this$props7.reopenPickerOnClearDate,\n keepOpenOnDateSelect = _this$props7.keepOpenOnDateSelect,\n styles = _this$props7.styles,\n isOutsideRange = _this$props7.isOutsideRange;\n var isInputFocused = this.state.isInputFocused;\n var enableOutsideClick = !withPortal && !withFullScreenPortal;\n var hideFang = verticalSpacing < _constants.FANG_HEIGHT_PX;\n\n var input = _react[\"default\"].createElement(_SingleDatePickerInputController[\"default\"], {\n id: id,\n placeholder: placeholder,\n ariaLabel: ariaLabel,\n focused: focused,\n isFocused: isInputFocused,\n disabled: disabled,\n required: required,\n readOnly: readOnly,\n openDirection: openDirection,\n showCaret: !withPortal && !withFullScreenPortal && !hideFang,\n showClearDate: showClearDate,\n showDefaultInputIcon: showDefaultInputIcon,\n inputIconPosition: inputIconPosition,\n isOutsideRange: isOutsideRange,\n customCloseIcon: customCloseIcon,\n customInputIcon: customInputIcon,\n date: date,\n onDateChange: onDateChange,\n displayFormat: displayFormat,\n onFocusChange: this.onInputFocus,\n onKeyDownArrowDown: this.onDayPickerFocus,\n onKeyDownQuestionMark: this.showKeyboardShortcutsPanel,\n screenReaderMessage: screenReaderInputMessage,\n phrases: phrases,\n isRTL: isRTL,\n noBorder: noBorder,\n block: block,\n small: small,\n regular: regular,\n verticalSpacing: verticalSpacing,\n reopenPickerOnClearDate: reopenPickerOnClearDate,\n keepOpenOnDateSelect: keepOpenOnDateSelect\n }, this.maybeRenderDayPickerWithPortal());\n\n return _react[\"default\"].createElement(\"div\", (0, _extends2[\"default\"])({\n ref: this.setContainerRef\n }, (0, _reactWithStyles.css)(styles.SingleDatePicker, block && styles.SingleDatePicker__block)), enableOutsideClick && _react[\"default\"].createElement(_reactOutsideClickHandler[\"default\"], {\n onOutsideClick: this.onOutsideClick\n }, input), enableOutsideClick || input);\n };\n\n return SingleDatePicker;\n}(_react[\"default\"].PureComponent || _react[\"default\"].Component);\n\nexports.PureSingleDatePicker = SingleDatePicker;\nSingleDatePicker.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nSingleDatePicker.defaultProps = defaultProps;\n\nvar _default = (0, _reactWithStyles.withStyles)(function (_ref3) {\n var _ref3$reactDates = _ref3.reactDates,\n color = _ref3$reactDates.color,\n zIndex = _ref3$reactDates.zIndex;\n return {\n SingleDatePicker: {\n position: 'relative',\n display: 'inline-block'\n },\n SingleDatePicker__block: {\n display: 'block'\n },\n SingleDatePicker_picker: {\n zIndex: zIndex + 1,\n backgroundColor: color.background,\n position: 'absolute'\n },\n SingleDatePicker_picker__rtl: {\n direction: (0, _noflip[\"default\"])('rtl')\n },\n SingleDatePicker_picker__directionLeft: {\n left: (0, _noflip[\"default\"])(0)\n },\n SingleDatePicker_picker__directionRight: {\n right: (0, _noflip[\"default\"])(0)\n },\n SingleDatePicker_picker__portal: {\n backgroundColor: 'rgba(0, 0, 0, 0.3)',\n position: 'fixed',\n top: 0,\n left: (0, _noflip[\"default\"])(0),\n height: '100%',\n width: '100%'\n },\n SingleDatePicker_picker__fullScreenPortal: {\n backgroundColor: color.background\n },\n SingleDatePicker_closeButton: {\n background: 'none',\n border: 0,\n color: 'inherit',\n font: 'inherit',\n lineHeight: 'normal',\n overflow: 'visible',\n cursor: 'pointer',\n position: 'absolute',\n top: 0,\n right: (0, _noflip[\"default\"])(0),\n padding: 15,\n zIndex: zIndex + 2,\n ':hover': {\n color: \"darken(\".concat(color.core.grayLighter, \", 10%)\"),\n textDecoration: 'none'\n },\n ':focus': {\n color: \"darken(\".concat(color.core.grayLighter, \", 10%)\"),\n textDecoration: 'none'\n }\n },\n SingleDatePicker_closeButton_svg: {\n height: 15,\n width: 15,\n fill: color.core.grayLighter\n }\n };\n}, {\n pureComponent: typeof _react[\"default\"].PureComponent !== 'undefined'\n})(SingleDatePicker);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isInclusivelyBeforeDay;\n\nvar _moment = _interopRequireDefault(require(\"moment\"));\n\nvar _isAfterDay = _interopRequireDefault(require(\"./isAfterDay\"));\n\nfunction isInclusivelyBeforeDay(a, b) {\n if (!_moment[\"default\"].isMoment(a) || !_moment[\"default\"].isMoment(b)) return false;\n return !(0, _isAfterDay[\"default\"])(a, b);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"CalendarDay\", {\n enumerable: true,\n get: function get() {\n return _CalendarDay[\"default\"];\n }\n});\nObject.defineProperty(exports, \"CalendarMonth\", {\n enumerable: true,\n get: function get() {\n return _CalendarMonth[\"default\"];\n }\n});\nObject.defineProperty(exports, \"CalendarMonthGrid\", {\n enumerable: true,\n get: function get() {\n return _CalendarMonthGrid[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DateRangePicker\", {\n enumerable: true,\n get: function get() {\n return _DateRangePicker[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DateRangePickerInput\", {\n enumerable: true,\n get: function get() {\n return _DateRangePickerInput[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DateRangePickerInputController\", {\n enumerable: true,\n get: function get() {\n return _DateRangePickerInputController[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DateRangePickerShape\", {\n enumerable: true,\n get: function get() {\n return _DateRangePickerShape[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DayPicker\", {\n enumerable: true,\n get: function get() {\n return _DayPicker[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DayPickerRangeController\", {\n enumerable: true,\n get: function get() {\n return _DayPickerRangeController[\"default\"];\n }\n});\nObject.defineProperty(exports, \"DayPickerSingleDateController\", {\n enumerable: true,\n get: function get() {\n return _DayPickerSingleDateController[\"default\"];\n }\n});\nObject.defineProperty(exports, \"SingleDatePicker\", {\n enumerable: true,\n get: function get() {\n return _SingleDatePicker[\"default\"];\n }\n});\nObject.defineProperty(exports, \"SingleDatePickerInput\", {\n enumerable: true,\n get: function get() {\n return _SingleDatePickerInput[\"default\"];\n }\n});\nObject.defineProperty(exports, \"SingleDatePickerShape\", {\n enumerable: true,\n get: function get() {\n return _SingleDatePickerShape[\"default\"];\n }\n});\nObject.defineProperty(exports, \"isInclusivelyAfterDay\", {\n enumerable: true,\n get: function get() {\n return _isInclusivelyAfterDay[\"default\"];\n }\n});\nObject.defineProperty(exports, \"isInclusivelyBeforeDay\", {\n enumerable: true,\n get: function get() {\n return _isInclusivelyBeforeDay[\"default\"];\n }\n});\nObject.defineProperty(exports, \"isNextDay\", {\n enumerable: true,\n get: function get() {\n return _isNextDay[\"default\"];\n }\n});\nObject.defineProperty(exports, \"isSameDay\", {\n enumerable: true,\n get: function get() {\n return _isSameDay[\"default\"];\n }\n});\nObject.defineProperty(exports, \"toISODateString\", {\n enumerable: true,\n get: function get() {\n return _toISODateString[\"default\"];\n }\n});\nObject.defineProperty(exports, \"toLocalizedDateString\", {\n enumerable: true,\n get: function get() {\n return _toLocalizedDateString[\"default\"];\n }\n});\nObject.defineProperty(exports, \"toMomentObject\", {\n enumerable: true,\n get: function get() {\n return _toMomentObject[\"default\"];\n }\n});\n\nvar _CalendarDay = _interopRequireDefault(require(\"./components/CalendarDay\"));\n\nvar _CalendarMonth = _interopRequireDefault(require(\"./components/CalendarMonth\"));\n\nvar _CalendarMonthGrid = _interopRequireDefault(require(\"./components/CalendarMonthGrid\"));\n\nvar _DateRangePicker = _interopRequireDefault(require(\"./components/DateRangePicker\"));\n\nvar _DateRangePickerInput = _interopRequireDefault(require(\"./components/DateRangePickerInput\"));\n\nvar _DateRangePickerInputController = _interopRequireDefault(require(\"./components/DateRangePickerInputController\"));\n\nvar _DateRangePickerShape = _interopRequireDefault(require(\"./shapes/DateRangePickerShape\"));\n\nvar _DayPicker = _interopRequireDefault(require(\"./components/DayPicker\"));\n\nvar _DayPickerRangeController = _interopRequireDefault(require(\"./components/DayPickerRangeController\"));\n\nvar _DayPickerSingleDateController = _interopRequireDefault(require(\"./components/DayPickerSingleDateController\"));\n\nvar _SingleDatePicker = _interopRequireDefault(require(\"./components/SingleDatePicker\"));\n\nvar _SingleDatePickerInput = _interopRequireDefault(require(\"./components/SingleDatePickerInput\"));\n\nvar _SingleDatePickerShape = _interopRequireDefault(require(\"./shapes/SingleDatePickerShape\"));\n\nvar _isInclusivelyAfterDay = _interopRequireDefault(require(\"./utils/isInclusivelyAfterDay\"));\n\nvar _isInclusivelyBeforeDay = _interopRequireDefault(require(\"./utils/isInclusivelyBeforeDay\"));\n\nvar _isNextDay = _interopRequireDefault(require(\"./utils/isNextDay\"));\n\nvar _isSameDay = _interopRequireDefault(require(\"./utils/isSameDay\"));\n\nvar _toISODateString = _interopRequireDefault(require(\"./utils/toISODateString\"));\n\nvar _toLocalizedDateString = _interopRequireDefault(require(\"./utils/toLocalizedDateString\"));\n\nvar _toMomentObject = _interopRequireDefault(require(\"./utils/toMomentObject\"));","// eslint-disable-next-line import/no-unresolved\nmodule.exports = require('./lib');\n","import SiteProps from \"./SiteProps\"\nimport { DateTime } from \"luxon\"\nexport enum APPLICABLE_AT {\n ANYTIME = \"anytime\",\n IN_DATE_RANGE = \"in_date_range\",\n FROM_DATE = \"from_date\",\n UNTIL_DATE = \"until_date\",\n}\n\ntype ApplicableAt = APPLICABLE_AT\n\nexport const ADDON_KIND = {\n NORMAL: \"normal\",\n BOOLEAN: \"boolean\",\n ALWAYS_APPLIED: \"always-applied\",\n ALWAYS_APPLIED_RECURRING: \"always-applied-recurring\",\n HIDDEN: \"hidden\",\n}\n\ntype AddOnKind = (typeof ADDON_KIND)[keyof typeof ADDON_KIND]\n\nexport default interface IAddOn {\n id: string\n slug: string\n label: string\n description: string\n sort: number\n amount_in_cents: number\n kind: AddOnKind\n camping_style_id?: string\n camp_id?: string\n available_sites: SiteProps[]\n addable_camping_style_id: string | null\n is_bookable: boolean\n is_applied_nightly: boolean\n inventory_quantity: number\n sku: string\n applicable_at: ApplicableAt\n valid_from?: DateTime | null\n valid_until?: DateTime | null\n}\n","import React, { Component, ErrorInfo, ReactNode } from \"react\"\nimport Button from \"./ui/Button\"\nimport * as Sentry from \"@sentry/react\"\nimport { captureMessage } from \"@sentry/core/build/types/exports\"\nimport { ArrowPathIcon } from \"@heroicons/react/20/solid\"\n\ninterface Props {\n children: ReactNode\n ctaLabel?: string\n description?: string\n ctaOnClick?: () => void\n}\n\ninterface State {\n hasError: boolean\n error: Error | undefined\n errorMessage: string | undefined\n}\n\nclass ErrorBoundary extends Component {\n public state: State = {\n hasError: false,\n error: undefined,\n errorMessage: undefined,\n }\n\n public static getDerivedStateFromError(err: Error): State {\n return { hasError: true, error: err, errorMessage: err.message }\n }\n\n public componentDidCatch(error: Error, errorInfo: ErrorInfo) {\n console.error('Uncaught error:', error, errorInfo)\n Sentry.withScope((scope) => {\n scope.setExtras({ errorInfo, errorMessage: error.message })\n scope.setTag(\"parkType\", \"app-breaking\")\n Sentry.captureException(error)\n })\n }\n\n public refreshPage() {\n window.location.reload()\n }\n\n public render() {\n if (this.state.hasError) {\n return (\n
\n
\n

🏕️😓

\n

Uh-oh! We've encountered an error

\n

\n {this.props.description ? this.props.description : \"Please refresh the page.\"} If you run into this issue again, please notify us at{' '}\n \n support@poweredbypark.com\n \n

\n }>\n {this.props.ctaLabel ? this.props.ctaLabel : \"Refresh\"}\n \n
\n
\n )\n }\n\n return this.props.children\n }\n}\n\nexport default ErrorBoundary\n","import React from 'react'\nimport { ModalContext } from './ModalContext'\n\n\nexport const ModalProvider = ({\n onClose,\n children\n}) => {\n return (\n \n { children }\n \n )\n}","import React, { useEffect } from \"react\"\nimport ReactDOM from \"react-dom\"\nimport { XMarkIcon } from \"@heroicons/react/24/outline\"\nimport classNames from \"../../utils/classNames\"\nimport ErrorBoundary from \"../ErrorBoundary\"\nimport { ModalProvider } from \"~/contexts/admin/ModalProvider\"\n\ninterface ComponentProps {\n children?: React.ReactNode\n open: boolean\n onClose: () => void\n className?: string\n maxWidth?: string\n isDynamicWidth?: boolean\n customPadding?: string\n closeClassNames?: string\n isXMarkHidden?: boolean\n width?: string\n}\n\nexport default function Modal(props: ComponentProps) {\n useEffect(() => {\n const handleEscapeKey = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n props.onClose()\n }\n }\n\n if (props.open) {\n document.addEventListener(\"keydown\", handleEscapeKey)\n }\n\n return () => {\n document.removeEventListener(\"keydown\", handleEscapeKey)\n }\n }, [props.open, props.onClose])\n if (!props.open) return null\n\n const modalContent = (\n window.location.reload()}\n >\n \n <>\n
\n
\n
\n e.stopPropagation()}\n style={{ border: \"none\", outline: \"none\", position: \"relative\" }}\n >\n {!props.isXMarkHidden && (\n
\n \n Close\n \n \n
\n )}\n {props.children}\n \n
\n
\n \n \n \n )\n\n return ReactDOM.createPortal(modalContent, document.body)\n}\n","import React, { useContext, useEffect, useRef, useState } from \"react\"\nimport { createPortal } from \"react-dom\"\nimport { useDebouncedCallback } from \"use-debounce\"\nimport api from \"../../../api2\"\nimport { SiteProps } from \"../../../interfaces\"\nimport { AdminContext } from \"../../../contexts/AdminContext\"\nimport { Option } from \"../../ui/SelectInput\"\nimport IAddOn, { ADDON_KIND } from \"../../../interfaces/IAddOn\"\nimport { Combobox } from \"@headlessui/react\"\nimport { ChevronUpDownIcon } from \"@heroicons/react/24/outline\"\nimport classNames from \"../../../utils/classNames\"\nimport ILineItem from \"../../../interfaces/ILineItem\"\nimport { LINE_ITEM_KINDS } from \"../../../constants/line_item_kinds\"\nimport Modal from \"~/components/ui/Modal\"\nimport { CampingStyleProps } from \"~/interfaces\"\n\nconst mapProductToOption = (product: IAddOn): Option => ({\n label: product.label,\n value: product.id,\n})\n\ninterface ComponentProps {\n site: SiteProps\n disabledProductIds?: string[]\n onChange: (product: IAddOn) => void\n createNewItem: (name: string, id?: string) => void\n selectedId?: string\n lineItem: Partial\n campingStyleId?: string\n}\n\nconst ProductDropdown = ({\n site,\n onChange,\n disabledProductIds,\n createNewItem,\n selectedId,\n lineItem,\n}: ComponentProps) => {\n const { camp } = useContext(AdminContext)\n const [isOpen, setIsOpen] = useState(false)\n const [products, setProducts] = useState([])\n const [filteredProducts, setFilteredProducts] = useState([])\n const [selectedOption, setSelectedOption] = useState(selectedId)\n const [inputValue, setInputValue] = useState(lineItem.label)\n const [isEnterPressed, setIsEnterPressed] = useState(false)\n const triggerRef = useRef(null)\n const inputRef = useRef(null)\n\n useEffect(() => {\n setIsOpen(false)\n }, [selectedOption])\n\n useEffect(() => {\n fetchProducts()\n }, [])\n\n useEffect(() => {\n setInputValue(lineItem.label)\n }, [lineItem])\n\n useEffect(() => {\n if (selectedId) setSelectedOption(selectedId)\n }, [selectedId])\n\n const changeSelectedOption = (newOptionId: string) => {\n if (newOptionId) {\n const product = products.find((p) => p.id === newOptionId)\n if (product) {\n onChange(product)\n } else {\n setSelectedOption(\"\")\n createNewItem(newOptionId, lineItem.add_on_id)\n }\n }\n setSelectedOption(newOptionId)\n }\n\n const fetchProducts = useDebouncedCallback(async () => {\n api.Products.forCamp(camp.id, { siteIds: [site.id] })\n .then(({ products: p }) => {\n const filteredProducts = p.filter((product: IAddOn) =>\n [ADDON_KIND.NORMAL, ADDON_KIND.BOOLEAN].includes(product.kind),\n )\n setProducts(filteredProducts)\n })\n .catch((err) => {\n console.error(err)\n })\n }, 100)\n\n const filterProducts = (query: string) => {\n if (!query) {\n setFilteredProducts(products)\n } else {\n setFilteredProducts(products.filter((p) => p.label.toLowerCase().includes(query.toLowerCase())))\n }\n }\n\n const onSelect = (value: string) => {\n changeSelectedOption(value)\n setInputValue(products.find((p) => p.id === value)?.label || value || \"\")\n }\n\n const getDropdownStyle = () => {\n if (triggerRef.current) {\n const rect = triggerRef.current.getBoundingClientRect()\n return {\n position: \"absolute\",\n top: rect.bottom + window.scrollY,\n left: rect.left + window.scrollX,\n width: rect.width,\n zIndex: 9999,\n }\n }\n return {}\n }\n\n return (\n <>\n \n {({ open }) => (\n <>\n
\n \n {\n const value = e.target.value\n setInputValue(value)\n filterProducts(value)\n setIsEnterPressed(false)\n }}\n value={inputValue}\n displayValue={(id: string) =>\n lineItem?.add_on_id?.length && lineItem?.add_on_id !== \"change-me\"\n ? (lineItem.label as string)\n : (inputValue as string)\n }\n onClick={() => {\n filterProducts(\"\")\n setIsEnterPressed(false)\n }}\n onFocus={() => {\n setIsEnterPressed(false)\n }}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" && !filteredProducts.length) {\n createNewItem(inputValue, lineItem.add_on_id)\n setIsEnterPressed(true)\n e.preventDefault()\n }\n }}\n onBlur={() => {\n if (inputValue.trim() && !filteredProducts.length && !isEnterPressed) {\n createNewItem(inputValue, lineItem.add_on_id)\n }\n }}\n ref={inputRef}\n />\n
\n \n
\n \n {filteredProducts.length > 0 &&\n open &&\n !isEnterPressed &&\n createPortal(\n \n {inputValue.length > 0 &&\n (!selectedOption?.length || inputValue !== products.find((p) => p.id === selectedOption)?.label) ? (\n \n classNames(\n \"relative select-none py-2 px-3 ghostinspector-new-reservation-site-li\",\n disabledProductIds?.includes(inputValue) ? \"opacity-50\" : \"cursor-pointer\",\n selected ? \"bg-green-50\" : active ? \"bg-green-600 text-white\" : \"text-gray-900\",\n )\n }\n >\n {inputValue}\n \n ) : null}\n {filteredProducts.map(mapProductToOption).map((option, index) => (\n \n classNames(\n \"relative select-none py-2 px-3 ghostinspector-new-reservation-site-li\",\n disabledProductIds?.includes(option.value) ? \"opacity-50\" : \"cursor-pointer\",\n selected ? \"bg-green-50\" : active ? \"bg-green-600 text-white\" : \"text-gray-900\",\n )\n }\n >\n {({ active, selected }) => (\n
\n
\n \n {option.label}\n \n
\n
\n )}\n \n ))}\n ,\n document.body,\n )}\n
\n \n )}\n \n
\n {\n const value = e.target.value\n setInputValue(value)\n filterProducts(value)\n }}\n value={lineItem?.add_on_id?.length && lineItem?.add_on_id !== \"change-me\" ? lineItem.label : inputValue}\n onClick={() => {\n filterProducts(\"\")\n setIsOpen(true)\n }}\n ref={inputRef}\n />\n setIsOpen(false)} className=\"hide-product-modal\">\n {\n const value = e.target.value\n setInputValue(value)\n filterProducts(value)\n setIsEnterPressed(false)\n }}\n value={inputValue}\n displayValue={(id: string) =>\n lineItem?.add_on_id?.length && lineItem?.add_on_id !== \"change-me\" ? lineItem.label : inputValue\n }\n onClick={() => {\n filterProducts(\"\")\n setIsOpen(true)\n }}\n onFocus={() => {\n setIsEnterPressed(false)\n }}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" && !filteredProducts.length) {\n changeSelectedOption(inputValue)\n setIsEnterPressed(true)\n }\n }}\n ref={inputRef}\n />\n {filteredProducts.length > 0 && (\n \n {inputValue.length > 0 &&\n (!selectedOption?.length || inputValue !== products.find((p) => p.id === selectedOption)?.label) ? (\n onSelect(inputValue)}\n >\n {inputValue}\n
\n ) : null}\n {filteredProducts.map(mapProductToOption).map((option) => (\n !disabledProductIds?.includes(option.value) && onSelect(option.value)}\n className={classNames(\n \"relative select-none py-2 px-3 ghostinspector-new-reservation-site-li hover:bg-green-600 hover:text-white\",\n disabledProductIds?.includes(option.value) ? \"opacity-50\" : \"cursor-pointer\",\n )}\n >\n
\n
\n \n {option.label}\n \n
\n
\n
\n ))}\n \n )}\n \n \n \n )\n}\n\nexport default ProductDropdown\n","export const currencySymbol = (currency: string): string => {\n try {\n const formatter = new Intl.NumberFormat(undefined, { style: 'currency', currency, currencyDisplay: 'narrowSymbol' });\n const parts = formatter.formatToParts(0);\n const symbol = parts.find(part => part.type === 'currency')?.value;\n return symbol || '$';\n } catch {\n return '$';\n }\n};","import { CampProps, SiteProps } from \"../../../../../interfaces\"\nimport { IFormData, ILineItemField } from \"../../EditInvoice\"\nimport React, { useEffect, useState } from \"react\"\nimport useAdminForm from \"../../../../../hooks/useAdminForm\"\nimport { LINE_ITEM_KINDS, lineItemKind } from \"~/constants/line_item_kinds\"\nimport { formatMoney } from \"~/utils/formatMoney\"\nimport Form from \"../../../../ui/Admin/Form\"\nimport { ArrowPathRoundedSquareIcon } from \"@heroicons/react/24/outline\"\nimport classNames from \"../../../../../utils/classNames\"\nimport { TrashIcon } from \"@heroicons/react/24/solid\"\nimport IAddOn from \"../../../../../interfaces/IAddOn\"\nimport ProductDropdown from \"../../../Products/ProductDropdown\"\nimport { currencySymbol } from \"~/utils/currencySymbol\"\n\ninterface LineItemRowProps {\n camp: CampProps\n item: ILineItemField\n index: number\n isPreview: boolean\n site: SiteProps\n isRecurring: boolean\n}\n\nconst LineItemRow = ({ camp, item, index, isPreview, site, isRecurring }: LineItemRowProps) => {\n const [showTooltip, setShowTooltip] = useState(false)\n const { resource, watch, setValue, isChanged } = useAdminForm()\n const items = watch(\"items\")\n const totalPrice = watch(`items.${index}.total_amount`)\n const unitPrice = watch(`items.${index}.unit_amount`)\n const occurrences = watch(`items.${index}.occurrences`)\n const quantity = watch(`items.${index}.quantity`)\n const label = watch(`items.${index}.label`)\n const kind = watch(`items.${index}.kind`)\n const is_updating_series = watch(`items.${index}.is_updating_series`)\n\n const onChangeProduct = (product: IAddOn) => {\n setValue(`items.${index}.label`, product.label)\n setValue(`items.${index}.unit_amount`, product.amount_in_cents / 100)\n setValue(`items.${index}.add_on_id`, product.id)\n setValue(`items.${index}.quantity`, 1)\n setValue(`items.${index}.total_amount`, product.amount_in_cents / 100)\n setValue(`items.${index}.kind`, LINE_ITEM_KINDS.BASIC)\n }\n\n const onCreateProduct = (label: string) => {\n setValue(`items.${index}.label`, label)\n setValue(`items.${index}.kind`, LINE_ITEM_KINDS.CUSTOM)\n\n setValue(`items.${index}.add_on_id`, \"\")\n }\n\n const isItemDeletable = () => {\n const unremovableKinds = [\n LINE_ITEM_KINDS.HOLIDAY_RATE,\n \"weekend_rate\",\n \"additional_adults\",\n \"additional_kids\",\n \"additional_pets\",\n ] as lineItemKind[]\n if (unremovableKinds.includes(item.kind)) return false\n return !item.reservation_id\n }\n\n useEffect(() => {\n const watchedItem = watch(`items.${index}`) as ILineItemField\n if (item?.reservation_id || watchedItem?.reservation_id) {\n return\n }\n\n setValue(`items.${index}.total_amount`, unitPrice * quantity)\n }, [unitPrice, quantity])\n\n useEffect(() => {\n if (item?.reservation_id) {\n const isReservationLineItem = !item.add_on_id && item.kind === \"basic\" && !item.parent_line_item_id\n const hasOccurrences = !!item.occurrences && item.occurrence_unit !== \"months\" && !isReservationLineItem\n let newTotal = item.total_amount / item.quantity\n\n if (hasOccurrences) newTotal = newTotal / item.occurrences\n\n setValue(`items.${index}.unit_amount`, newTotal)\n }\n }, [totalPrice])\n\n const onDeleteItem = () => {\n setValue(\n \"items\",\n items.filter((_, i) => i !== index),\n )\n }\n\n const onUpdateIsUpdatingSeries = () => {\n setValue(`items.${index}.is_updating_series`, !item.is_updating_series)\n }\n\n const quantityForMobile = resource.is_displaying_occurrences ? items[index].occurrences : items[index].quantity\n\n if (\n item.is_hidden ||\n (item.unit_amount = 0 && isPreview)\n ) {\n return <>\n }\n\n if (isPreview) {\n return (\n
\n
\n {label}\n
\n
{formatMoney(unitPrice, camp?.currency)}
\n {resource.is_displaying_occurrences && (\n
{occurrences || \"-\"}
\n )}\n
{quantity || \"-\"}
\n
\n
{totalPrice ? formatMoney(totalPrice, camp?.currency) : \"-\"}
\n
\n {quantityForMobile > 1 ? `(${quantityForMobile} * ${items[index].unit_amount}$)` : <>}\n
\n
\n
\n )\n } else {\n if (item) {\n const isLabelReadOnly = item.kind === LINE_ITEM_KINDS.ELECTRIC\n const isUnitPriceReadOnly = !!item.reservation_id\n const isQuantityReadOnly = !!item.reservation_id\n const isTotalReadOnly = !item.reservation_id\n\n const isRowChanged =\n isChanged(`items.${index}.total_amount`) ||\n isChanged(`items.${index}.unit_amount`) ||\n isChanged(`items.${index}.occurrences`) ||\n isChanged(`items.${index}.quantity`) ||\n isChanged(`items.${index}.label`) ||\n isChanged(`items.${index}.kind`)\n\n return (\n
\n {isLabelReadOnly ? (\n \n {watch(`items.${index}.label`)}\n
\n ) : item.reservation_id?.length ? (\n \n ) : (\n
\n li.add_on_id)}\n onChange={onChangeProduct}\n createNewItem={onCreateProduct}\n selectedId={watch(`items.${index}`).add_on_id}\n lineItem={watch(`items.${index}`)}\n menuPosition=\"fixed\"\n />\n
\n )}\n \n {resource.is_displaying_occurrences && (\n \n )}\n \n \n
\n {!item.reservation_id &&\n [LINE_ITEM_KINDS.CUSTOM, LINE_ITEM_KINDS.BASIC].includes(item.kind) &&\n isRecurring && (\n
\n setShowTooltip(true)}\n onMouseLeave={() => setShowTooltip(false)}\n className={classNames(\n \"transition-colors duration-100 rounded-md p-2\",\n (is_updating_series && \"bg-green-600\") || \"\",\n (!isRowChanged && \"opacity-30 pointer-events-none\") || \"\",\n )}\n >\n \n \n {showTooltip && (\n \n
\n

\n {isRowChanged\n ? is_updating_series\n ? \"Applying changes to future recurrences\"\n : \"Apply changes to future recurrences\"\n : \"No changes to apply to future recurrences of this reservation\"}\n

\n
\n
\n )}\n
\n )}\n\n {isItemDeletable() && }\n \n \n )\n } else return <>\n }\n}\n\nexport default LineItemRow\n","import React from \"react\";\nimport {IFormData, ILineItemField} from \"../../EditInvoice\";\nimport LineItemRow from \"./LineItemRow\";\nimport { SiteProps } from \"../../../../../interfaces\";\nimport { CampProps } from \"~/interfaces\";\n\n\ninterface LineItemsTableProps {\n resource: IFormData\n items: ILineItemField[]\n isForPrint: boolean\n isPreview: boolean\n site: SiteProps\n isRecurring: boolean\n camp: CampProps\n}\n\nconst LineItemsTable = ({ resource, items, isForPrint, isPreview, site, isRecurring, camp }: LineItemsTableProps) => {\n return (\n \n
\n
\n
Item
\n
Price
\n {resource.is_displaying_occurrences &&
Nights
}\n
Quantity
\n
Amount
\n
\n {items?.filter((item) => !item.is_hidden).length === 0 && (\n
\n No Line items. Apply electric fees or add a new item.\n
\n )}\n {items?.map((item, index) => (\n \n ))}\n
\n \n )\n}\n\nexport default LineItemsTable;","import {IFormData, ILineItemField} from \"../../EditInvoice\";\nimport React, {useContext} from \"react\";\nimport {AdminContext} from \"../../../../../contexts/AdminContext\";\nimport classNames from \"../../../../../utils/classNames\";\nimport LineItemRow from \"./LineItemRow\";\nimport { SiteProps } from \"../../../../../interfaces\";\n\n\ninterface MobileLineItemsTableProps {\n resource: IFormData\n items: ILineItemField[]\n isForPrint: boolean\n isPreview: boolean\n site: SiteProps\n}\n\nconst MobileLineItemsTable = ({ resource, items, isForPrint, isPreview, site }: MobileLineItemsTableProps) => {\n const { camp } = useContext(AdminContext)\n\n if (isForPrint) {\n return <>\n }\n\n return (\n \n
\n \n
Item
\n {!isPreview &&
Price
}\n {!isPreview && resource.is_displaying_occurrences &&
Nights
}\n {!isPreview &&
Quantity
}\n
Amount
\n
\n {items?.map((item, index) => (\n \n ))}\n \n \n )\n}\n\nexport default MobileLineItemsTable;","import React, { Fragment, useEffect, useMemo, useRef, useState } from \"react\"\nimport classNames from \"../../../utils/classNames\"\nimport { Menu } from \"@headlessui/react\"\nimport { isMobile } from \"react-device-detect\"\nimport { Transition } from \"semantic-ui-react\"\nimport { createPortal } from \"react-dom\"\n\nexport interface DropdownOption {\n icon?: any // TODO: component definition\n label: string | JSX.Element\n onClick?: (e: React.MouseEvent) => void\n disabled?: boolean\n}\n\ninterface ComponentProps {\n stopPropagation?: boolean\n children: React.ReactNode\n options: Array\n autoWidth?: boolean\n preventCloseOnClick?: boolean\n isMenuFixed?: boolean\n disabled?: boolean\n placement?: \"right\" | \"left\"\n verticalPlacement?: \"top\" | \"bottom\"\n zIndex?: string\n dataTestId?: string\n minWidth?: number\n}\n\nconst DropdownButton = (props: ComponentProps) => {\n return (\n <>\n {props.isMenuFixed ? (\n <>\n \n \n ) : (\n \n )}\n \n )\n}\n\ninterface AbsoluteMenuProps {\n options: DropdownOption[]\n children\n disabled\n autoWidth\n placement\n minWidth?: number\n}\n\nconst AbsoluteMenu = ({ options, children, disabled, autoWidth, placement, minWidth = 200 }: AbsoluteMenuProps) => {\n const [open, setOpen] = useState(false)\n const [dropdownStyles, setDropdownStyles] = useState({})\n const buttonRef = useRef(null)\n const containerRef = useRef(null)\n const menuRef = useRef(null)\n\n useEffect(() => {\n if (buttonRef.current) {\n const contentWidth = autoWidth ? buttonRef.current.offsetWidth : minWidth\n const dropdownWidth = Math.max(minWidth, contentWidth)\n\n const buttonRect = buttonRef.current?.getBoundingClientRect()\n\n let styles: React.CSSProperties = {\n top: buttonRect.height + 10,\n width: dropdownWidth,\n right: !placement || placement === \"right\" ? 0 : undefined,\n left: placement === \"left\" ? 0 : undefined,\n }\n\n setDropdownStyles(styles)\n }\n }, [autoWidth, open])\n\n return (\n \n
\n setOpen(true)}\n className={classNames(\n disabled ? \"pointer-events-none opacity-30\" : \"cursor-pointer\",\n \"inline-flex justify-center focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75\",\n )}\n >\n {children}\n \n
\n \n {\n setOpen(false)\n }}\n ref={menuRef}\n id=\"item_menu\"\n style={dropdownStyles}\n className={classNames(\n \"absolute z-50 top-2 border-gray-300 rounded-lg bg-white shadow-lg ring-1 ring-gray-200 ring-opacity-50 focus:outline-none p-0.5\",\n )}\n >\n <>\n {options.map((option, index) => (\n \n {option.label === \"_divider_\" ? (\n
\n ) : (\n \n {option.icon && (\n \n \n \n )}\n {option.label}\n
\n )}\n
\n ))}\n \n \n \n
\n )\n}\n\ninterface FixedMenuOption {\n label: string\n onClick?: (e: React.MouseEvent) => void\n disabled?: boolean\n icon?: React.ComponentType>\n}\n\ninterface FixedMenuProps {\n options: FixedMenuOption[]\n preventCloseOnClick?: boolean\n children: React.ReactNode\n disabled?: boolean\n autoWidth?: boolean\n placement?: \"left\" | \"right\"\n verticalPlacement?: \"top\" | \"bottom\"\n zIndex?: string\n dataTestId?: string\n minWidth?: number\n}\n\nconst FixedMenu = ({\n options,\n preventCloseOnClick,\n children,\n disabled,\n autoWidth = true,\n placement,\n verticalPlacement,\n zIndex,\n dataTestId,\n minWidth = 50,\n}: FixedMenuProps) => {\n const [open, setOpen] = useState(false)\n const [dropdownStyles, setDropdownStyles] = useState({})\n const buttonRef = useRef(null)\n const containerRef = useRef(null)\n const portalRef = useRef(null)\n const [originalWidth, setOriginalWidth] = useState(null)\n\n useEffect(() => {\n if (open && buttonRef.current && portalRef.current) {\n const updatePosition = () => {\n if (!buttonRef.current || !portalRef.current || !containerRef.current) return\n\n if (originalWidth === null && autoWidth) {\n setOriginalWidth(containerRef.current.offsetWidth)\n }\n\n const contentWidth = autoWidth ? originalWidth || containerRef.current.offsetWidth : minWidth\n\n const dropdownWidth = Math.max(minWidth, contentWidth)\n\n const buttonRect = buttonRef.current.getBoundingClientRect()\n const menuRect = portalRef.current.getBoundingClientRect()\n let isBottomPlacement = true\n if (verticalPlacement) {\n isBottomPlacement = verticalPlacement === \"bottom\"\n } else {\n if (\n menuRect.height !== undefined &&\n buttonRect.top + buttonRect.height + 10 + menuRect.height > window.innerHeight\n ) {\n isBottomPlacement = false\n }\n }\n\n const styles = {\n top: isBottomPlacement ? buttonRect.top + buttonRect.height + 10 : buttonRect.top - menuRect.height - 10,\n width: dropdownWidth,\n left:\n !placement || placement === \"right\"\n ? buttonRect.left - dropdownWidth + buttonRect.width\n : placement === \"left\"\n ? buttonRect.left\n : undefined,\n zIndex: 1000\n }\n\n setDropdownStyles(styles)\n }\n updatePosition()\n window.addEventListener(\"scroll\", updatePosition, true)\n window.addEventListener(\"resize\", updatePosition)\n return () => {\n window.removeEventListener(\"scroll\", updatePosition, true)\n window.removeEventListener(\"resize\", updatePosition)\n }\n }\n }, [autoWidth, open, placement, verticalPlacement])\n\n useEffect(() => {\n const handleClickOutside = (e: MouseEvent) => {\n if (!containerRef.current?.contains(e.target as Node) && !portalRef.current?.contains(e.target as Node)) {\n setOpen(false)\n }\n }\n document.addEventListener(\"mousedown\", handleClickOutside)\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside)\n }\n }, [])\n\n const handleToggle = () => {\n setOpen((prev) => !prev)\n }\n\n const handleOptionClick = (\n e: React.MouseEvent,\n onClick?: (e: React.MouseEvent) => void,\n ) => {\n if (preventCloseOnClick) {\n e.preventDefault()\n e.stopPropagation()\n } else {\n setOpen(false)\n }\n if (onClick) onClick(e)\n }\n\n return (\n
\n \n {children}\n \n {open &&\n createPortal(\n \n
\n {options.map((option, index) =>\n option.label === \"_divider_\" ? (\n
\n ) : (\n handleOptionClick(e, option.onClick)}\n className={classNames(\n option.disabled\n ? \"text-gray-300 pointer-events-none\"\n : \"hover:bg-gray-100 text-muted hover:cursor-pointer transition-colors duration-75\",\n \"group flex w-full items-center rounded-md px-2 py-2 whitespace-nowrap transition-colors\",\n )}\n >\n {option.icon && (\n \n \n \n )}\n {option.label}\n
\n ),\n )}\n
\n
,\n document.body,\n )}\n \n )\n}\n\nexport default DropdownButton\n","import { Switch } from \"@headlessui/react\"\nimport React from \"react\"\nimport classNames from \"../../utils/classNames\"\n\ninterface ComponentProps {\n checked: boolean\n onChange: (v: boolean) => void\n name?: string\n label?: string\n description?: string\n disabled?: boolean\n labelClassName?: string\n dataTestId?: string\n}\n\nconst Toggle = ({\n checked,\n onChange,\n name,\n label,\n description,\n disabled,\n labelClassName,\n dataTestId,\n}: ComponentProps) => {\n return (\n \n {label && (\n \n \n {label}\n \n {description && (\n \n {description}\n \n )}\n \n )}\n \n \n \n \n )\n}\n\nexport default Toggle\n","import React, { ReactNode, useEffect, useRef, useState } from \"react\"\nimport { createPortal } from \"react-dom\"\n\ninterface HoverTipProps {\n children: ReactNode\n content: ReactNode\n placement?: \"top\" | \"right\" | \"bottom\" | \"left\"\n className?: string\n tipClassName?: string\n delay?: number\n maxWidth?: string\n dark?: boolean\n onlyOnClick?: boolean\n}\n\nconst PortalHoverTip: React.FC = ({\n children,\n content,\n placement = \"top\",\n className = \"\",\n tipClassName = \"\",\n delay = 100,\n maxWidth = \"15rem\",\n dark = true,\n onlyOnClick = false,\n}) => {\n const [isOpen, setIsOpen] = useState(false)\n const [position, setPosition] = useState({ top: 0, left: 0 })\n const triggerRef = useRef(null)\n const tooltipRef = useRef(null)\n const timeoutRef = useRef | null>(null)\n\n const updatePosition = () => {\n if (!triggerRef.current) return\n\n const triggerRect = triggerRef.current.getBoundingClientRect()\n const scrollTop = window.scrollY || document.documentElement.scrollTop\n const scrollLeft = window.scrollX || document.documentElement.scrollLeft\n\n const offset = 8\n\n let top = 0\n let left = 0\n\n switch (placement) {\n case \"top\":\n top = triggerRect.top + scrollTop - offset\n left = triggerRect.left + scrollLeft + triggerRect.width / 2\n break\n case \"right\":\n top = triggerRect.top + scrollTop + triggerRect.height / 2\n left = triggerRect.right + scrollLeft + offset\n break\n case \"bottom\":\n top = triggerRect.bottom + scrollTop + offset\n left = triggerRect.left + scrollLeft + triggerRect.width / 2\n break\n case \"left\":\n top = triggerRect.top + scrollTop + triggerRect.height / 2\n left = triggerRect.left + scrollLeft - offset\n break\n }\n\n setPosition({ top, left })\n }\n\n useEffect(() => {\n if (isOpen) {\n updatePosition()\n\n window.addEventListener(\"scroll\", updatePosition, true)\n window.addEventListener(\"resize\", updatePosition)\n\n return () => {\n window.removeEventListener(\"scroll\", updatePosition, true)\n window.removeEventListener(\"resize\", updatePosition)\n }\n }\n }, [isOpen])\n\n const handleMouseEnter = () => {\n if (onlyOnClick) return\n\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n\n timeoutRef.current = setTimeout(() => {\n setIsOpen(true)\n }, delay)\n }\n\n const handleMouseLeave = () => {\n if (onlyOnClick) return\n\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n\n timeoutRef.current = setTimeout(() => {\n setIsOpen(false)\n }, delay)\n }\n\n const handleClick = () => {\n if (onlyOnClick) {\n setIsOpen(!isOpen)\n }\n }\n\n useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n }\n }, [])\n\n const getTooltipStyles = (): React.CSSProperties => {\n const baseStyles: React.CSSProperties = {\n position: \"absolute\",\n zIndex: 9999,\n maxWidth,\n pointerEvents: \"none\",\n }\n\n if (placement === \"top\") {\n return {\n ...baseStyles,\n bottom: window.innerHeight - position.top,\n left: position.left,\n transform: \"translateX(-50%)\",\n }\n } else if (placement === \"right\") {\n return {\n ...baseStyles,\n top: position.top,\n left: position.left,\n transform: \"translateY(-50%)\",\n }\n } else if (placement === \"bottom\") {\n return {\n ...baseStyles,\n top: position.top,\n left: position.left,\n transform: \"translateX(-50%)\",\n }\n } else {\n return {\n ...baseStyles,\n top: position.top,\n right: window.innerWidth - position.left,\n transform: \"translateY(-50%)\",\n }\n }\n }\n\n const getArrowStyles = (): React.CSSProperties => {\n const baseStyles: React.CSSProperties = {\n position: \"absolute\",\n width: \"8px\",\n height: \"8px\",\n background: dark ? \"#1f2937\" : \"white\",\n transform: \"rotate(45deg)\",\n }\n\n if (placement === \"top\") {\n return { ...baseStyles, bottom: \"-4px\", left: \"50%\", marginLeft: \"-4px\" }\n } else if (placement === \"right\") {\n return { ...baseStyles, left: \"-4px\", top: \"50%\", marginTop: \"-4px\" }\n } else if (placement === \"bottom\") {\n return { ...baseStyles, top: \"-4px\", left: \"50%\", marginLeft: \"-4px\" }\n } else {\n return { ...baseStyles, right: \"-4px\", top: \"50%\", marginTop: \"-4px\" }\n }\n }\n\n const tipClasses = `py-2 px-3 rounded-md shadow-md text-sm leading-6 ${\n dark ? \"bg-gray-800 text-white\" : \"bg-white text-gray-800 border border-gray-200\"\n } ${tipClassName}`\n\n const canUseDOM = typeof window !== \"undefined\" && !!document.body\n\n return (\n <>\n \n {children}\n \n\n {isOpen &&\n content &&\n canUseDOM &&\n createPortal(\n \n
\n {content}\n
\n
\n
,\n document.body,\n )}\n \n )\n}\n\nexport default PortalHoverTip\n","import React, { useContext, useMemo } from \"react\"\nimport { AdminContext } from \"~/contexts/AdminContext\"\nimport { Cog6ToothIcon } from \"@heroicons/react/20/solid\"\nimport DropdownButton, { DropdownOption } from \"~/components/ui/Admin/DropdownButton\"\nimport Toggle from \"~/components/ui/Toggle\"\nimport { CampingStyleProps, NewReservationProps } from \"~/interfaces\"\nimport ePaymentType, { PaymentType } from \"~/enums/ePaymentType\"\nimport classNames from \"~/utils/classNames\"\nimport PortalHoverTip from \"~/components/ui/PortalHoverTip\"\n\nexport type ToggleFeesTypes = Pick<\n NewReservationProps,\n | \"is_tax_enabled\"\n | \"is_credit_card_fee_enabled\"\n | \"is_weekend_fee_enabled\"\n | \"is_holiday_rate_enabled\"\n | \"is_pets_fee_enabled\"\n | \"is_passenger_fees_enabled\"\n>\n\nexport type OptionKeys = \"taxRate\" | \"petsFee\" | \"holidayRate\" | \"weekendFee\" | \"passengerFee\" | \"creditCard\"\n\ninterface FeesAndTaxesSettingsProps {\n enabledFees: Partial> | undefined\n options: OptionKeys[]\n setValue: (key: keyof ToggleFeesTypes, value: boolean) => void\n campingStyle: CampingStyleProps | undefined\n isGroup?: boolean\n isStore?: boolean\n isLongTermElectric?: boolean\n isPartiallyPaid?: boolean\n paymentMethod?: PaymentType\n className?: string\n isAcceptingDeposit?: boolean\n isInvoice?: boolean\n}\n\nconst FeesAndTaxesSettings = ({\n enabledFees,\n options,\n setValue,\n campingStyle,\n isGroup,\n isStore,\n isLongTermElectric,\n isPartiallyPaid,\n paymentMethod,\n className,\n isAcceptingDeposit,\n isInvoice\n}: FeesAndTaxesSettingsProps) => {\n const { camp } = useContext(AdminContext)\n\n if (!enabledFees) return \n const optionConfig: Record<\n OptionKeys,\n {\n label: string\n key: keyof ToggleFeesTypes\n isAvailable: boolean | undefined\n disabled?: boolean\n tooltip?: string\n }\n > = {\n taxRate: {\n label: \"Add tax\",\n key: \"is_tax_enabled\",\n isAvailable: !!(campingStyle?.tax_rate ?? (isStore ? camp?.tax_rate || camp?.store_tax_rate : camp?.tax_rate)),\n disabled: isPartiallyPaid || isLongTermElectric,\n tooltip: isPartiallyPaid ? \"Changing tax options is disabled for partial payments\"\n : isAcceptingDeposit ? \"Tax will be applied at time of full payment\"\n : \"\",\n },\n creditCard: {\n label: \"Add credit card fee\",\n key: \"is_credit_card_fee_enabled\",\n isAvailable: !!campingStyle?.credit_card_rate,\n disabled: (paymentMethod && paymentMethod === ePaymentType.LINK) || isInvoice,\n tooltip: (paymentMethod && paymentMethod === ePaymentType.LINK)\n ? \"Credit card processing fees are applied at the time of payment based on the payment method\"\n : isInvoice\n ? \"Credit Card fees are now applied automatically at checkout if a guest pays online.\"\n : \"\",\n },\n holidayRate: {\n label: \"Add holiday rate\",\n key: \"is_holiday_rate_enabled\",\n isAvailable: !!(campingStyle?.holiday_fee_in_cents ?? camp.holiday_fee_in_cents),\n },\n weekendFee: {\n label: \"Add weekend fee\",\n key: \"is_weekend_fee_enabled\",\n isAvailable: !!(campingStyle?.weekend_fee_in_cents ?? camp.weekend_fee_in_cents),\n },\n passengerFee: {\n label: \"Add passenger fee\",\n key: \"is_passenger_fees_enabled\",\n isAvailable: !isGroup,\n },\n petsFee: {\n label: \"Add pets fee\",\n key: \"is_pets_fee_enabled\",\n isAvailable: !isGroup,\n },\n }\n\n const buildDropdownOptions = (): DropdownOption[] => {\n return options\n .filter((key) => optionConfig[key].isAvailable)\n .map((key) => {\n const config = optionConfig[key]\n const tooltip = config.tooltip || \"\"\n return {\n label: (\n \n \n
{config.label}
\n {\n if (!config.disabled) setValue(config.key, value)\n }}\n />\n \n
\n ),\n onClick: () => {\n if (!config.disabled) setValue(config.key, !enabledFees[config.key])\n },\n }\n })\n }\n\n const dropdownOptions = buildDropdownOptions()\n const enabledFeesCount = useMemo(() => {\n return options\n .filter((optionKey) => optionConfig[optionKey].isAvailable)\n .filter((optionKey) => !!enabledFees[optionConfig[optionKey].key]).length\n }, [options, optionConfig, enabledFees])\n\n return (\n
\n {dropdownOptions.length > 1 ? (\n \n
\n Fees & taxes \n {!!enabledFeesCount && (\n \n {enabledFeesCount}\n \n )}\n
\n \n ) : (\n dropdownOptions.map((option, index) => (\n e.stopPropagation()}\n >\n {option.label}\n
\n ))\n )}\n \n )\n}\n\nexport default FeesAndTaxesSettings\n\nconst FeesAndTaxesSkeleton = () => {\n return (\n
\n
\n
\n
\n
\n
\n \n
\n
\n )\n}\n","import React, { useEffect, useState } from \"react\"\nimport FeesAndTaxesSettings, {\n OptionKeys,\n ToggleFeesTypes,\n} from \"../../Reservations/NewReservationModal/FeesAndTaxesSettings\"\nimport Spinner from \"~/components/ui/Spinner\"\nimport IOrder from \"~/interfaces/IOrder\"\nimport IOrderPreview from \"~/interfaces/IOrderPreview\"\nimport { CampingStyleProps } from \"~/interfaces\"\nimport ePaymentType, { PaymentType } from \"~/enums/ePaymentType\"\n\ninterface SetTaxFeesProps {\n order: IOrder | IOrderPreview\n campingStyle: CampingStyleProps | undefined\n onUpdateFees?: (fees: Partial>) => void\n isStore?: boolean\n defaultTaxFeeEnabled?: boolean\n defaultCreditCardFeeEnabled?: boolean\n isLongTermElectric?: boolean\n paymentMethod?: PaymentType\n isInvoice?: boolean\n}\n\ninterface SetTaxFeesReturn {\n taxFeeEnabled: boolean\n creditCardFeeEnabled: boolean\n setTaxFeeEnabled: React.Dispatch>\n setCreditCardFeeEnabled: React.Dispatch>\n TaxToggle: React.ReactElement\n}\n\nconst useSetTaxFees = ({\n order,\n campingStyle,\n onUpdateFees,\n isStore,\n defaultTaxFeeEnabled,\n defaultCreditCardFeeEnabled,\n isLongTermElectric,\n paymentMethod,\n isInvoice\n}: SetTaxFeesProps): SetTaxFeesReturn => {\n const [creditCardFeeEnabled, setCreditCardFeeEnabled] = React.useState(!!defaultCreditCardFeeEnabled)\n const [taxFeeEnabled, setTaxFeeEnabled] = useState(!!defaultTaxFeeEnabled || (isLongTermElectric ?? false))\n const [enabledFees, setEnabledFees] = useState>>()\n const isPartialPayment = !!(order?.paid_total_in_cents && order?.paid_total_in_cents > 0)\n\n useEffect(() => {\n setTaxFeeEnabled(\n !!defaultTaxFeeEnabled || order?.line_items?.some((item) => item.tax_rate > 0) || (isLongTermElectric ?? false),\n )\n setCreditCardFeeEnabled(!!defaultCreditCardFeeEnabled || order?.credit_card_rate > 0)\n }, [])\n\n useEffect(() => {\n setEnabledFees((prevState) => ({\n ...prevState,\n [\"is_credit_card_fee_enabled\"]: creditCardFeeEnabled,\n [\"is_tax_enabled\"]: taxFeeEnabled,\n }))\n\n if (onUpdateFees) {\n onUpdateFees({\n is_credit_card_fee_enabled: creditCardFeeEnabled,\n is_tax_enabled: taxFeeEnabled,\n })\n }\n }, [creditCardFeeEnabled, taxFeeEnabled])\n\n const switchEnabledFees = (key: keyof ToggleFeesTypes, value: boolean) => {\n const newEnabledFees = { ...enabledFees }\n newEnabledFees[key] = value\n setEnabledFees(newEnabledFees)\n\n if (key === \"is_credit_card_fee_enabled\") {\n setCreditCardFeeEnabled(value)\n } else if (key === \"is_tax_enabled\") {\n setTaxFeeEnabled(value)\n }\n }\n\n const dropdownOptions: Array = [\"taxRate\", \"creditCard\"]\n\n useEffect(() => {\n if (\n paymentMethod &&\n [ePaymentType.CARD_READER, ePaymentType.CARD_INPUT, ePaymentType.LINK].includes(paymentMethod)\n ) {\n setCreditCardFeeEnabled(true)\n } else {\n setCreditCardFeeEnabled(false)\n }\n }, [paymentMethod])\n\n return {\n taxFeeEnabled,\n creditCardFeeEnabled,\n setTaxFeeEnabled,\n setCreditCardFeeEnabled,\n TaxToggle: !order ? (\n \n ) : (\n switchEnabledFees(key, value)}\n campingStyle={campingStyle}\n isGroup={false}\n isStore={isStore}\n isLongTermElectric={isLongTermElectric}\n isPartiallyPaid={isPartialPayment}\n paymentMethod={paymentMethod}\n isInvoice={isInvoice}\n />\n ),\n }\n}\n\nexport default useSetTaxFees\n","import eSendingModeCookieName from \"~/enums/eSendingModeCookieName\"\n\nconst cookieSendingModeInvoice = eSendingModeCookieName.INVOICE\n\n\nexport { cookieSendingModeInvoice }\n","//! moment.js\n//! version : 2.30.1\n//! authors : Tim Wood, Iskren Chernev, Moment.js contributors\n//! license : MIT\n//! momentjs.com\n\n;(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n global.moment = factory()\n}(this, (function () { 'use strict';\n\n var hookCallback;\n\n function hooks() {\n return hookCallback.apply(null, arguments);\n }\n\n // This is done to register the method called with moment()\n // without creating circular dependencies.\n function setHookCallback(callback) {\n hookCallback = callback;\n }\n\n function isArray(input) {\n return (\n input instanceof Array ||\n Object.prototype.toString.call(input) === '[object Array]'\n );\n }\n\n function isObject(input) {\n // IE8 will treat undefined and null as object if it wasn't for\n // input != null\n return (\n input != null &&\n Object.prototype.toString.call(input) === '[object Object]'\n );\n }\n\n function hasOwnProp(a, b) {\n return Object.prototype.hasOwnProperty.call(a, b);\n }\n\n function isObjectEmpty(obj) {\n if (Object.getOwnPropertyNames) {\n return Object.getOwnPropertyNames(obj).length === 0;\n } else {\n var k;\n for (k in obj) {\n if (hasOwnProp(obj, k)) {\n return false;\n }\n }\n return true;\n }\n }\n\n function isUndefined(input) {\n return input === void 0;\n }\n\n function isNumber(input) {\n return (\n typeof input === 'number' ||\n Object.prototype.toString.call(input) === '[object Number]'\n );\n }\n\n function isDate(input) {\n return (\n input instanceof Date ||\n Object.prototype.toString.call(input) === '[object Date]'\n );\n }\n\n function map(arr, fn) {\n var res = [],\n i,\n arrLen = arr.length;\n for (i = 0; i < arrLen; ++i) {\n res.push(fn(arr[i], i));\n }\n return res;\n }\n\n function extend(a, b) {\n for (var i in b) {\n if (hasOwnProp(b, i)) {\n a[i] = b[i];\n }\n }\n\n if (hasOwnProp(b, 'toString')) {\n a.toString = b.toString;\n }\n\n if (hasOwnProp(b, 'valueOf')) {\n a.valueOf = b.valueOf;\n }\n\n return a;\n }\n\n function createUTC(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, true).utc();\n }\n\n function defaultParsingFlags() {\n // We need to deep clone this object.\n return {\n empty: false,\n unusedTokens: [],\n unusedInput: [],\n overflow: -2,\n charsLeftOver: 0,\n nullInput: false,\n invalidEra: null,\n invalidMonth: null,\n invalidFormat: false,\n userInvalidated: false,\n iso: false,\n parsedDateParts: [],\n era: null,\n meridiem: null,\n rfc2822: false,\n weekdayMismatch: false,\n };\n }\n\n function getParsingFlags(m) {\n if (m._pf == null) {\n m._pf = defaultParsingFlags();\n }\n return m._pf;\n }\n\n var some;\n if (Array.prototype.some) {\n some = Array.prototype.some;\n } else {\n some = function (fun) {\n var t = Object(this),\n len = t.length >>> 0,\n i;\n\n for (i = 0; i < len; i++) {\n if (i in t && fun.call(this, t[i], i, t)) {\n return true;\n }\n }\n\n return false;\n };\n }\n\n function isValid(m) {\n var flags = null,\n parsedParts = false,\n isNowValid = m._d && !isNaN(m._d.getTime());\n if (isNowValid) {\n flags = getParsingFlags(m);\n parsedParts = some.call(flags.parsedDateParts, function (i) {\n return i != null;\n });\n isNowValid =\n flags.overflow < 0 &&\n !flags.empty &&\n !flags.invalidEra &&\n !flags.invalidMonth &&\n !flags.invalidWeekday &&\n !flags.weekdayMismatch &&\n !flags.nullInput &&\n !flags.invalidFormat &&\n !flags.userInvalidated &&\n (!flags.meridiem || (flags.meridiem && parsedParts));\n if (m._strict) {\n isNowValid =\n isNowValid &&\n flags.charsLeftOver === 0 &&\n flags.unusedTokens.length === 0 &&\n flags.bigHour === undefined;\n }\n }\n if (Object.isFrozen == null || !Object.isFrozen(m)) {\n m._isValid = isNowValid;\n } else {\n return isNowValid;\n }\n return m._isValid;\n }\n\n function createInvalid(flags) {\n var m = createUTC(NaN);\n if (flags != null) {\n extend(getParsingFlags(m), flags);\n } else {\n getParsingFlags(m).userInvalidated = true;\n }\n\n return m;\n }\n\n // Plugins that add properties should also add the key here (null value),\n // so we can properly clone ourselves.\n var momentProperties = (hooks.momentProperties = []),\n updateInProgress = false;\n\n function copyConfig(to, from) {\n var i,\n prop,\n val,\n momentPropertiesLen = momentProperties.length;\n\n if (!isUndefined(from._isAMomentObject)) {\n to._isAMomentObject = from._isAMomentObject;\n }\n if (!isUndefined(from._i)) {\n to._i = from._i;\n }\n if (!isUndefined(from._f)) {\n to._f = from._f;\n }\n if (!isUndefined(from._l)) {\n to._l = from._l;\n }\n if (!isUndefined(from._strict)) {\n to._strict = from._strict;\n }\n if (!isUndefined(from._tzm)) {\n to._tzm = from._tzm;\n }\n if (!isUndefined(from._isUTC)) {\n to._isUTC = from._isUTC;\n }\n if (!isUndefined(from._offset)) {\n to._offset = from._offset;\n }\n if (!isUndefined(from._pf)) {\n to._pf = getParsingFlags(from);\n }\n if (!isUndefined(from._locale)) {\n to._locale = from._locale;\n }\n\n if (momentPropertiesLen > 0) {\n for (i = 0; i < momentPropertiesLen; i++) {\n prop = momentProperties[i];\n val = from[prop];\n if (!isUndefined(val)) {\n to[prop] = val;\n }\n }\n }\n\n return to;\n }\n\n // Moment prototype object\n function Moment(config) {\n copyConfig(this, config);\n this._d = new Date(config._d != null ? config._d.getTime() : NaN);\n if (!this.isValid()) {\n this._d = new Date(NaN);\n }\n // Prevent infinite loop in case updateOffset creates new moment\n // objects.\n if (updateInProgress === false) {\n updateInProgress = true;\n hooks.updateOffset(this);\n updateInProgress = false;\n }\n }\n\n function isMoment(obj) {\n return (\n obj instanceof Moment || (obj != null && obj._isAMomentObject != null)\n );\n }\n\n function warn(msg) {\n if (\n hooks.suppressDeprecationWarnings === false &&\n typeof console !== 'undefined' &&\n console.warn\n ) {\n console.warn('Deprecation warning: ' + msg);\n }\n }\n\n function deprecate(msg, fn) {\n var firstTime = true;\n\n return extend(function () {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(null, msg);\n }\n if (firstTime) {\n var args = [],\n arg,\n i,\n key,\n argLen = arguments.length;\n for (i = 0; i < argLen; i++) {\n arg = '';\n if (typeof arguments[i] === 'object') {\n arg += '\\n[' + i + '] ';\n for (key in arguments[0]) {\n if (hasOwnProp(arguments[0], key)) {\n arg += key + ': ' + arguments[0][key] + ', ';\n }\n }\n arg = arg.slice(0, -2); // Remove trailing comma and space\n } else {\n arg = arguments[i];\n }\n args.push(arg);\n }\n warn(\n msg +\n '\\nArguments: ' +\n Array.prototype.slice.call(args).join('') +\n '\\n' +\n new Error().stack\n );\n firstTime = false;\n }\n return fn.apply(this, arguments);\n }, fn);\n }\n\n var deprecations = {};\n\n function deprecateSimple(name, msg) {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(name, msg);\n }\n if (!deprecations[name]) {\n warn(msg);\n deprecations[name] = true;\n }\n }\n\n hooks.suppressDeprecationWarnings = false;\n hooks.deprecationHandler = null;\n\n function isFunction(input) {\n return (\n (typeof Function !== 'undefined' && input instanceof Function) ||\n Object.prototype.toString.call(input) === '[object Function]'\n );\n }\n\n function set(config) {\n var prop, i;\n for (i in config) {\n if (hasOwnProp(config, i)) {\n prop = config[i];\n if (isFunction(prop)) {\n this[i] = prop;\n } else {\n this['_' + i] = prop;\n }\n }\n }\n this._config = config;\n // Lenient ordinal parsing accepts just a number in addition to\n // number + (possibly) stuff coming from _dayOfMonthOrdinalParse.\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n this._dayOfMonthOrdinalParseLenient = new RegExp(\n (this._dayOfMonthOrdinalParse.source || this._ordinalParse.source) +\n '|' +\n /\\d{1,2}/.source\n );\n }\n\n function mergeConfigs(parentConfig, childConfig) {\n var res = extend({}, parentConfig),\n prop;\n for (prop in childConfig) {\n if (hasOwnProp(childConfig, prop)) {\n if (isObject(parentConfig[prop]) && isObject(childConfig[prop])) {\n res[prop] = {};\n extend(res[prop], parentConfig[prop]);\n extend(res[prop], childConfig[prop]);\n } else if (childConfig[prop] != null) {\n res[prop] = childConfig[prop];\n } else {\n delete res[prop];\n }\n }\n }\n for (prop in parentConfig) {\n if (\n hasOwnProp(parentConfig, prop) &&\n !hasOwnProp(childConfig, prop) &&\n isObject(parentConfig[prop])\n ) {\n // make sure changes to properties don't modify parent config\n res[prop] = extend({}, res[prop]);\n }\n }\n return res;\n }\n\n function Locale(config) {\n if (config != null) {\n this.set(config);\n }\n }\n\n var keys;\n\n if (Object.keys) {\n keys = Object.keys;\n } else {\n keys = function (obj) {\n var i,\n res = [];\n for (i in obj) {\n if (hasOwnProp(obj, i)) {\n res.push(i);\n }\n }\n return res;\n };\n }\n\n var defaultCalendar = {\n sameDay: '[Today at] LT',\n nextDay: '[Tomorrow at] LT',\n nextWeek: 'dddd [at] LT',\n lastDay: '[Yesterday at] LT',\n lastWeek: '[Last] dddd [at] LT',\n sameElse: 'L',\n };\n\n function calendar(key, mom, now) {\n var output = this._calendar[key] || this._calendar['sameElse'];\n return isFunction(output) ? output.call(mom, now) : output;\n }\n\n function zeroFill(number, targetLength, forceSign) {\n var absNumber = '' + Math.abs(number),\n zerosToFill = targetLength - absNumber.length,\n sign = number >= 0;\n return (\n (sign ? (forceSign ? '+' : '') : '-') +\n Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) +\n absNumber\n );\n }\n\n var formattingTokens =\n /(\\[[^\\[]*\\])|(\\\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|N{1,5}|YYYYYY|YYYYY|YYYY|YY|y{2,4}|yo?|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,\n localFormattingTokens = /(\\[[^\\[]*\\])|(\\\\)?(LTS|LT|LL?L?L?|l{1,4})/g,\n formatFunctions = {},\n formatTokenFunctions = {};\n\n // token: 'M'\n // padded: ['MM', 2]\n // ordinal: 'Mo'\n // callback: function () { this.month() + 1 }\n function addFormatToken(token, padded, ordinal, callback) {\n var func = callback;\n if (typeof callback === 'string') {\n func = function () {\n return this[callback]();\n };\n }\n if (token) {\n formatTokenFunctions[token] = func;\n }\n if (padded) {\n formatTokenFunctions[padded[0]] = function () {\n return zeroFill(func.apply(this, arguments), padded[1], padded[2]);\n };\n }\n if (ordinal) {\n formatTokenFunctions[ordinal] = function () {\n return this.localeData().ordinal(\n func.apply(this, arguments),\n token\n );\n };\n }\n }\n\n function removeFormattingTokens(input) {\n if (input.match(/\\[[\\s\\S]/)) {\n return input.replace(/^\\[|\\]$/g, '');\n }\n return input.replace(/\\\\/g, '');\n }\n\n function makeFormatFunction(format) {\n var array = format.match(formattingTokens),\n i,\n length;\n\n for (i = 0, length = array.length; i < length; i++) {\n if (formatTokenFunctions[array[i]]) {\n array[i] = formatTokenFunctions[array[i]];\n } else {\n array[i] = removeFormattingTokens(array[i]);\n }\n }\n\n return function (mom) {\n var output = '',\n i;\n for (i = 0; i < length; i++) {\n output += isFunction(array[i])\n ? array[i].call(mom, format)\n : array[i];\n }\n return output;\n };\n }\n\n // format date using native date object\n function formatMoment(m, format) {\n if (!m.isValid()) {\n return m.localeData().invalidDate();\n }\n\n format = expandFormat(format, m.localeData());\n formatFunctions[format] =\n formatFunctions[format] || makeFormatFunction(format);\n\n return formatFunctions[format](m);\n }\n\n function expandFormat(format, locale) {\n var i = 5;\n\n function replaceLongDateFormatTokens(input) {\n return locale.longDateFormat(input) || input;\n }\n\n localFormattingTokens.lastIndex = 0;\n while (i >= 0 && localFormattingTokens.test(format)) {\n format = format.replace(\n localFormattingTokens,\n replaceLongDateFormatTokens\n );\n localFormattingTokens.lastIndex = 0;\n i -= 1;\n }\n\n return format;\n }\n\n var defaultLongDateFormat = {\n LTS: 'h:mm:ss A',\n LT: 'h:mm A',\n L: 'MM/DD/YYYY',\n LL: 'MMMM D, YYYY',\n LLL: 'MMMM D, YYYY h:mm A',\n LLLL: 'dddd, MMMM D, YYYY h:mm A',\n };\n\n function longDateFormat(key) {\n var format = this._longDateFormat[key],\n formatUpper = this._longDateFormat[key.toUpperCase()];\n\n if (format || !formatUpper) {\n return format;\n }\n\n this._longDateFormat[key] = formatUpper\n .match(formattingTokens)\n .map(function (tok) {\n if (\n tok === 'MMMM' ||\n tok === 'MM' ||\n tok === 'DD' ||\n tok === 'dddd'\n ) {\n return tok.slice(1);\n }\n return tok;\n })\n .join('');\n\n return this._longDateFormat[key];\n }\n\n var defaultInvalidDate = 'Invalid date';\n\n function invalidDate() {\n return this._invalidDate;\n }\n\n var defaultOrdinal = '%d',\n defaultDayOfMonthOrdinalParse = /\\d{1,2}/;\n\n function ordinal(number) {\n return this._ordinal.replace('%d', number);\n }\n\n var defaultRelativeTime = {\n future: 'in %s',\n past: '%s ago',\n s: 'a few seconds',\n ss: '%d seconds',\n m: 'a minute',\n mm: '%d minutes',\n h: 'an hour',\n hh: '%d hours',\n d: 'a day',\n dd: '%d days',\n w: 'a week',\n ww: '%d weeks',\n M: 'a month',\n MM: '%d months',\n y: 'a year',\n yy: '%d years',\n };\n\n function relativeTime(number, withoutSuffix, string, isFuture) {\n var output = this._relativeTime[string];\n return isFunction(output)\n ? output(number, withoutSuffix, string, isFuture)\n : output.replace(/%d/i, number);\n }\n\n function pastFuture(diff, output) {\n var format = this._relativeTime[diff > 0 ? 'future' : 'past'];\n return isFunction(format) ? format(output) : format.replace(/%s/i, output);\n }\n\n var aliases = {\n D: 'date',\n dates: 'date',\n date: 'date',\n d: 'day',\n days: 'day',\n day: 'day',\n e: 'weekday',\n weekdays: 'weekday',\n weekday: 'weekday',\n E: 'isoWeekday',\n isoweekdays: 'isoWeekday',\n isoweekday: 'isoWeekday',\n DDD: 'dayOfYear',\n dayofyears: 'dayOfYear',\n dayofyear: 'dayOfYear',\n h: 'hour',\n hours: 'hour',\n hour: 'hour',\n ms: 'millisecond',\n milliseconds: 'millisecond',\n millisecond: 'millisecond',\n m: 'minute',\n minutes: 'minute',\n minute: 'minute',\n M: 'month',\n months: 'month',\n month: 'month',\n Q: 'quarter',\n quarters: 'quarter',\n quarter: 'quarter',\n s: 'second',\n seconds: 'second',\n second: 'second',\n gg: 'weekYear',\n weekyears: 'weekYear',\n weekyear: 'weekYear',\n GG: 'isoWeekYear',\n isoweekyears: 'isoWeekYear',\n isoweekyear: 'isoWeekYear',\n w: 'week',\n weeks: 'week',\n week: 'week',\n W: 'isoWeek',\n isoweeks: 'isoWeek',\n isoweek: 'isoWeek',\n y: 'year',\n years: 'year',\n year: 'year',\n };\n\n function normalizeUnits(units) {\n return typeof units === 'string'\n ? aliases[units] || aliases[units.toLowerCase()]\n : undefined;\n }\n\n function normalizeObjectUnits(inputObject) {\n var normalizedInput = {},\n normalizedProp,\n prop;\n\n for (prop in inputObject) {\n if (hasOwnProp(inputObject, prop)) {\n normalizedProp = normalizeUnits(prop);\n if (normalizedProp) {\n normalizedInput[normalizedProp] = inputObject[prop];\n }\n }\n }\n\n return normalizedInput;\n }\n\n var priorities = {\n date: 9,\n day: 11,\n weekday: 11,\n isoWeekday: 11,\n dayOfYear: 4,\n hour: 13,\n millisecond: 16,\n minute: 14,\n month: 8,\n quarter: 7,\n second: 15,\n weekYear: 1,\n isoWeekYear: 1,\n week: 5,\n isoWeek: 5,\n year: 1,\n };\n\n function getPrioritizedUnits(unitsObj) {\n var units = [],\n u;\n for (u in unitsObj) {\n if (hasOwnProp(unitsObj, u)) {\n units.push({ unit: u, priority: priorities[u] });\n }\n }\n units.sort(function (a, b) {\n return a.priority - b.priority;\n });\n return units;\n }\n\n var match1 = /\\d/, // 0 - 9\n match2 = /\\d\\d/, // 00 - 99\n match3 = /\\d{3}/, // 000 - 999\n match4 = /\\d{4}/, // 0000 - 9999\n match6 = /[+-]?\\d{6}/, // -999999 - 999999\n match1to2 = /\\d\\d?/, // 0 - 99\n match3to4 = /\\d\\d\\d\\d?/, // 999 - 9999\n match5to6 = /\\d\\d\\d\\d\\d\\d?/, // 99999 - 999999\n match1to3 = /\\d{1,3}/, // 0 - 999\n match1to4 = /\\d{1,4}/, // 0 - 9999\n match1to6 = /[+-]?\\d{1,6}/, // -999999 - 999999\n matchUnsigned = /\\d+/, // 0 - inf\n matchSigned = /[+-]?\\d+/, // -inf - inf\n matchOffset = /Z|[+-]\\d\\d:?\\d\\d/gi, // +00:00 -00:00 +0000 -0000 or Z\n matchShortOffset = /Z|[+-]\\d\\d(?::?\\d\\d)?/gi, // +00 -00 +00:00 -00:00 +0000 -0000 or Z\n matchTimestamp = /[+-]?\\d+(\\.\\d{1,3})?/, // 123456789 123456789.123\n // any word (or two) characters or numbers including two/three word month in arabic.\n // includes scottish gaelic two word and hyphenated months\n matchWord =\n /[0-9]{0,256}['a-z\\u00A0-\\u05FF\\u0700-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFF07\\uFF10-\\uFFEF]{1,256}|[\\u0600-\\u06FF\\/]{1,256}(\\s*?[\\u0600-\\u06FF]{1,256}){1,2}/i,\n match1to2NoLeadingZero = /^[1-9]\\d?/, // 1-99\n match1to2HasZero = /^([1-9]\\d|\\d)/, // 0-99\n regexes;\n\n regexes = {};\n\n function addRegexToken(token, regex, strictRegex) {\n regexes[token] = isFunction(regex)\n ? regex\n : function (isStrict, localeData) {\n return isStrict && strictRegex ? strictRegex : regex;\n };\n }\n\n function getParseRegexForToken(token, config) {\n if (!hasOwnProp(regexes, token)) {\n return new RegExp(unescapeFormat(token));\n }\n\n return regexes[token](config._strict, config._locale);\n }\n\n // Code from http://stackoverflow.com/questions/3561493/is-there-a-regexp-escape-function-in-javascript\n function unescapeFormat(s) {\n return regexEscape(\n s\n .replace('\\\\', '')\n .replace(\n /\\\\(\\[)|\\\\(\\])|\\[([^\\]\\[]*)\\]|\\\\(.)/g,\n function (matched, p1, p2, p3, p4) {\n return p1 || p2 || p3 || p4;\n }\n )\n );\n }\n\n function regexEscape(s) {\n return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&');\n }\n\n function absFloor(number) {\n if (number < 0) {\n // -0 -> 0\n return Math.ceil(number) || 0;\n } else {\n return Math.floor(number);\n }\n }\n\n function toInt(argumentForCoercion) {\n var coercedNumber = +argumentForCoercion,\n value = 0;\n\n if (coercedNumber !== 0 && isFinite(coercedNumber)) {\n value = absFloor(coercedNumber);\n }\n\n return value;\n }\n\n var tokens = {};\n\n function addParseToken(token, callback) {\n var i,\n func = callback,\n tokenLen;\n if (typeof token === 'string') {\n token = [token];\n }\n if (isNumber(callback)) {\n func = function (input, array) {\n array[callback] = toInt(input);\n };\n }\n tokenLen = token.length;\n for (i = 0; i < tokenLen; i++) {\n tokens[token[i]] = func;\n }\n }\n\n function addWeekParseToken(token, callback) {\n addParseToken(token, function (input, array, config, token) {\n config._w = config._w || {};\n callback(input, config._w, config, token);\n });\n }\n\n function addTimeToArrayFromToken(token, input, config) {\n if (input != null && hasOwnProp(tokens, token)) {\n tokens[token](input, config._a, config, token);\n }\n }\n\n function isLeapYear(year) {\n return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;\n }\n\n var YEAR = 0,\n MONTH = 1,\n DATE = 2,\n HOUR = 3,\n MINUTE = 4,\n SECOND = 5,\n MILLISECOND = 6,\n WEEK = 7,\n WEEKDAY = 8;\n\n // FORMATTING\n\n addFormatToken('Y', 0, 0, function () {\n var y = this.year();\n return y <= 9999 ? zeroFill(y, 4) : '+' + y;\n });\n\n addFormatToken(0, ['YY', 2], 0, function () {\n return this.year() % 100;\n });\n\n addFormatToken(0, ['YYYY', 4], 0, 'year');\n addFormatToken(0, ['YYYYY', 5], 0, 'year');\n addFormatToken(0, ['YYYYYY', 6, true], 0, 'year');\n\n // PARSING\n\n addRegexToken('Y', matchSigned);\n addRegexToken('YY', match1to2, match2);\n addRegexToken('YYYY', match1to4, match4);\n addRegexToken('YYYYY', match1to6, match6);\n addRegexToken('YYYYYY', match1to6, match6);\n\n addParseToken(['YYYYY', 'YYYYYY'], YEAR);\n addParseToken('YYYY', function (input, array) {\n array[YEAR] =\n input.length === 2 ? hooks.parseTwoDigitYear(input) : toInt(input);\n });\n addParseToken('YY', function (input, array) {\n array[YEAR] = hooks.parseTwoDigitYear(input);\n });\n addParseToken('Y', function (input, array) {\n array[YEAR] = parseInt(input, 10);\n });\n\n // HELPERS\n\n function daysInYear(year) {\n return isLeapYear(year) ? 366 : 365;\n }\n\n // HOOKS\n\n hooks.parseTwoDigitYear = function (input) {\n return toInt(input) + (toInt(input) > 68 ? 1900 : 2000);\n };\n\n // MOMENTS\n\n var getSetYear = makeGetSet('FullYear', true);\n\n function getIsLeapYear() {\n return isLeapYear(this.year());\n }\n\n function makeGetSet(unit, keepTime) {\n return function (value) {\n if (value != null) {\n set$1(this, unit, value);\n hooks.updateOffset(this, keepTime);\n return this;\n } else {\n return get(this, unit);\n }\n };\n }\n\n function get(mom, unit) {\n if (!mom.isValid()) {\n return NaN;\n }\n\n var d = mom._d,\n isUTC = mom._isUTC;\n\n switch (unit) {\n case 'Milliseconds':\n return isUTC ? d.getUTCMilliseconds() : d.getMilliseconds();\n case 'Seconds':\n return isUTC ? d.getUTCSeconds() : d.getSeconds();\n case 'Minutes':\n return isUTC ? d.getUTCMinutes() : d.getMinutes();\n case 'Hours':\n return isUTC ? d.getUTCHours() : d.getHours();\n case 'Date':\n return isUTC ? d.getUTCDate() : d.getDate();\n case 'Day':\n return isUTC ? d.getUTCDay() : d.getDay();\n case 'Month':\n return isUTC ? d.getUTCMonth() : d.getMonth();\n case 'FullYear':\n return isUTC ? d.getUTCFullYear() : d.getFullYear();\n default:\n return NaN; // Just in case\n }\n }\n\n function set$1(mom, unit, value) {\n var d, isUTC, year, month, date;\n\n if (!mom.isValid() || isNaN(value)) {\n return;\n }\n\n d = mom._d;\n isUTC = mom._isUTC;\n\n switch (unit) {\n case 'Milliseconds':\n return void (isUTC\n ? d.setUTCMilliseconds(value)\n : d.setMilliseconds(value));\n case 'Seconds':\n return void (isUTC ? d.setUTCSeconds(value) : d.setSeconds(value));\n case 'Minutes':\n return void (isUTC ? d.setUTCMinutes(value) : d.setMinutes(value));\n case 'Hours':\n return void (isUTC ? d.setUTCHours(value) : d.setHours(value));\n case 'Date':\n return void (isUTC ? d.setUTCDate(value) : d.setDate(value));\n // case 'Day': // Not real\n // return void (isUTC ? d.setUTCDay(value) : d.setDay(value));\n // case 'Month': // Not used because we need to pass two variables\n // return void (isUTC ? d.setUTCMonth(value) : d.setMonth(value));\n case 'FullYear':\n break; // See below ...\n default:\n return; // Just in case\n }\n\n year = value;\n month = mom.month();\n date = mom.date();\n date = date === 29 && month === 1 && !isLeapYear(year) ? 28 : date;\n void (isUTC\n ? d.setUTCFullYear(year, month, date)\n : d.setFullYear(year, month, date));\n }\n\n // MOMENTS\n\n function stringGet(units) {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units]();\n }\n return this;\n }\n\n function stringSet(units, value) {\n if (typeof units === 'object') {\n units = normalizeObjectUnits(units);\n var prioritized = getPrioritizedUnits(units),\n i,\n prioritizedLen = prioritized.length;\n for (i = 0; i < prioritizedLen; i++) {\n this[prioritized[i].unit](units[prioritized[i].unit]);\n }\n } else {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units](value);\n }\n }\n return this;\n }\n\n function mod(n, x) {\n return ((n % x) + x) % x;\n }\n\n var indexOf;\n\n if (Array.prototype.indexOf) {\n indexOf = Array.prototype.indexOf;\n } else {\n indexOf = function (o) {\n // I know\n var i;\n for (i = 0; i < this.length; ++i) {\n if (this[i] === o) {\n return i;\n }\n }\n return -1;\n };\n }\n\n function daysInMonth(year, month) {\n if (isNaN(year) || isNaN(month)) {\n return NaN;\n }\n var modMonth = mod(month, 12);\n year += (month - modMonth) / 12;\n return modMonth === 1\n ? isLeapYear(year)\n ? 29\n : 28\n : 31 - ((modMonth % 7) % 2);\n }\n\n // FORMATTING\n\n addFormatToken('M', ['MM', 2], 'Mo', function () {\n return this.month() + 1;\n });\n\n addFormatToken('MMM', 0, 0, function (format) {\n return this.localeData().monthsShort(this, format);\n });\n\n addFormatToken('MMMM', 0, 0, function (format) {\n return this.localeData().months(this, format);\n });\n\n // PARSING\n\n addRegexToken('M', match1to2, match1to2NoLeadingZero);\n addRegexToken('MM', match1to2, match2);\n addRegexToken('MMM', function (isStrict, locale) {\n return locale.monthsShortRegex(isStrict);\n });\n addRegexToken('MMMM', function (isStrict, locale) {\n return locale.monthsRegex(isStrict);\n });\n\n addParseToken(['M', 'MM'], function (input, array) {\n array[MONTH] = toInt(input) - 1;\n });\n\n addParseToken(['MMM', 'MMMM'], function (input, array, config, token) {\n var month = config._locale.monthsParse(input, token, config._strict);\n // if we didn't find a month name, mark the date as invalid.\n if (month != null) {\n array[MONTH] = month;\n } else {\n getParsingFlags(config).invalidMonth = input;\n }\n });\n\n // LOCALES\n\n var defaultLocaleMonths =\n 'January_February_March_April_May_June_July_August_September_October_November_December'.split(\n '_'\n ),\n defaultLocaleMonthsShort =\n 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_'),\n MONTHS_IN_FORMAT = /D[oD]?(\\[[^\\[\\]]*\\]|\\s)+MMMM?/,\n defaultMonthsShortRegex = matchWord,\n defaultMonthsRegex = matchWord;\n\n function localeMonths(m, format) {\n if (!m) {\n return isArray(this._months)\n ? this._months\n : this._months['standalone'];\n }\n return isArray(this._months)\n ? this._months[m.month()]\n : this._months[\n (this._months.isFormat || MONTHS_IN_FORMAT).test(format)\n ? 'format'\n : 'standalone'\n ][m.month()];\n }\n\n function localeMonthsShort(m, format) {\n if (!m) {\n return isArray(this._monthsShort)\n ? this._monthsShort\n : this._monthsShort['standalone'];\n }\n return isArray(this._monthsShort)\n ? this._monthsShort[m.month()]\n : this._monthsShort[\n MONTHS_IN_FORMAT.test(format) ? 'format' : 'standalone'\n ][m.month()];\n }\n\n function handleStrictParse(monthName, format, strict) {\n var i,\n ii,\n mom,\n llc = monthName.toLocaleLowerCase();\n if (!this._monthsParse) {\n // this is not used\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n for (i = 0; i < 12; ++i) {\n mom = createUTC([2000, i]);\n this._shortMonthsParse[i] = this.monthsShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._longMonthsParse[i] = this.months(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n }\n\n function localeMonthsParse(monthName, format, strict) {\n var i, mom, regex;\n\n if (this._monthsParseExact) {\n return handleStrictParse.call(this, monthName, format, strict);\n }\n\n if (!this._monthsParse) {\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n }\n\n // TODO: add sorting\n // Sorting makes sure if one month (or abbr) is a prefix of another\n // see sorting in computeMonthsParse\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n if (strict && !this._longMonthsParse[i]) {\n this._longMonthsParse[i] = new RegExp(\n '^' + this.months(mom, '').replace('.', '') + '$',\n 'i'\n );\n this._shortMonthsParse[i] = new RegExp(\n '^' + this.monthsShort(mom, '').replace('.', '') + '$',\n 'i'\n );\n }\n if (!strict && !this._monthsParse[i]) {\n regex =\n '^' + this.months(mom, '') + '|^' + this.monthsShort(mom, '');\n this._monthsParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'MMMM' &&\n this._longMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'MMM' &&\n this._shortMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (!strict && this._monthsParse[i].test(monthName)) {\n return i;\n }\n }\n }\n\n // MOMENTS\n\n function setMonth(mom, value) {\n if (!mom.isValid()) {\n // No op\n return mom;\n }\n\n if (typeof value === 'string') {\n if (/^\\d+$/.test(value)) {\n value = toInt(value);\n } else {\n value = mom.localeData().monthsParse(value);\n // TODO: Another silent failure?\n if (!isNumber(value)) {\n return mom;\n }\n }\n }\n\n var month = value,\n date = mom.date();\n\n date = date < 29 ? date : Math.min(date, daysInMonth(mom.year(), month));\n void (mom._isUTC\n ? mom._d.setUTCMonth(month, date)\n : mom._d.setMonth(month, date));\n return mom;\n }\n\n function getSetMonth(value) {\n if (value != null) {\n setMonth(this, value);\n hooks.updateOffset(this, true);\n return this;\n } else {\n return get(this, 'Month');\n }\n }\n\n function getDaysInMonth() {\n return daysInMonth(this.year(), this.month());\n }\n\n function monthsShortRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsShortStrictRegex;\n } else {\n return this._monthsShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsShortRegex')) {\n this._monthsShortRegex = defaultMonthsShortRegex;\n }\n return this._monthsShortStrictRegex && isStrict\n ? this._monthsShortStrictRegex\n : this._monthsShortRegex;\n }\n }\n\n function monthsRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsStrictRegex;\n } else {\n return this._monthsRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsRegex')) {\n this._monthsRegex = defaultMonthsRegex;\n }\n return this._monthsStrictRegex && isStrict\n ? this._monthsStrictRegex\n : this._monthsRegex;\n }\n }\n\n function computeMonthsParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n shortP,\n longP;\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n shortP = regexEscape(this.monthsShort(mom, ''));\n longP = regexEscape(this.months(mom, ''));\n shortPieces.push(shortP);\n longPieces.push(longP);\n mixedPieces.push(longP);\n mixedPieces.push(shortP);\n }\n // Sorting makes sure if one month (or abbr) is a prefix of another it\n // will match the longer piece.\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._monthsRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._monthsShortRegex = this._monthsRegex;\n this._monthsStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._monthsShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n }\n\n function createDate(y, m, d, h, M, s, ms) {\n // can't just apply() to create a date:\n // https://stackoverflow.com/q/181348\n var date;\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n date = new Date(y + 400, m, d, h, M, s, ms);\n if (isFinite(date.getFullYear())) {\n date.setFullYear(y);\n }\n } else {\n date = new Date(y, m, d, h, M, s, ms);\n }\n\n return date;\n }\n\n function createUTCDate(y) {\n var date, args;\n // the Date.UTC function remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n args = Array.prototype.slice.call(arguments);\n // preserve leap years using a full 400 year cycle, then reset\n args[0] = y + 400;\n date = new Date(Date.UTC.apply(null, args));\n if (isFinite(date.getUTCFullYear())) {\n date.setUTCFullYear(y);\n }\n } else {\n date = new Date(Date.UTC.apply(null, arguments));\n }\n\n return date;\n }\n\n // start-of-first-week - start-of-year\n function firstWeekOffset(year, dow, doy) {\n var // first-week day -- which january is always in the first week (4 for iso, 1 for other)\n fwd = 7 + dow - doy,\n // first-week day local weekday -- which local weekday is fwd\n fwdlw = (7 + createUTCDate(year, 0, fwd).getUTCDay() - dow) % 7;\n\n return -fwdlw + fwd - 1;\n }\n\n // https://en.wikipedia.org/wiki/ISO_week_date#Calculating_a_date_given_the_year.2C_week_number_and_weekday\n function dayOfYearFromWeeks(year, week, weekday, dow, doy) {\n var localWeekday = (7 + weekday - dow) % 7,\n weekOffset = firstWeekOffset(year, dow, doy),\n dayOfYear = 1 + 7 * (week - 1) + localWeekday + weekOffset,\n resYear,\n resDayOfYear;\n\n if (dayOfYear <= 0) {\n resYear = year - 1;\n resDayOfYear = daysInYear(resYear) + dayOfYear;\n } else if (dayOfYear > daysInYear(year)) {\n resYear = year + 1;\n resDayOfYear = dayOfYear - daysInYear(year);\n } else {\n resYear = year;\n resDayOfYear = dayOfYear;\n }\n\n return {\n year: resYear,\n dayOfYear: resDayOfYear,\n };\n }\n\n function weekOfYear(mom, dow, doy) {\n var weekOffset = firstWeekOffset(mom.year(), dow, doy),\n week = Math.floor((mom.dayOfYear() - weekOffset - 1) / 7) + 1,\n resWeek,\n resYear;\n\n if (week < 1) {\n resYear = mom.year() - 1;\n resWeek = week + weeksInYear(resYear, dow, doy);\n } else if (week > weeksInYear(mom.year(), dow, doy)) {\n resWeek = week - weeksInYear(mom.year(), dow, doy);\n resYear = mom.year() + 1;\n } else {\n resYear = mom.year();\n resWeek = week;\n }\n\n return {\n week: resWeek,\n year: resYear,\n };\n }\n\n function weeksInYear(year, dow, doy) {\n var weekOffset = firstWeekOffset(year, dow, doy),\n weekOffsetNext = firstWeekOffset(year + 1, dow, doy);\n return (daysInYear(year) - weekOffset + weekOffsetNext) / 7;\n }\n\n // FORMATTING\n\n addFormatToken('w', ['ww', 2], 'wo', 'week');\n addFormatToken('W', ['WW', 2], 'Wo', 'isoWeek');\n\n // PARSING\n\n addRegexToken('w', match1to2, match1to2NoLeadingZero);\n addRegexToken('ww', match1to2, match2);\n addRegexToken('W', match1to2, match1to2NoLeadingZero);\n addRegexToken('WW', match1to2, match2);\n\n addWeekParseToken(\n ['w', 'ww', 'W', 'WW'],\n function (input, week, config, token) {\n week[token.substr(0, 1)] = toInt(input);\n }\n );\n\n // HELPERS\n\n // LOCALES\n\n function localeWeek(mom) {\n return weekOfYear(mom, this._week.dow, this._week.doy).week;\n }\n\n var defaultLocaleWeek = {\n dow: 0, // Sunday is the first day of the week.\n doy: 6, // The week that contains Jan 6th is the first week of the year.\n };\n\n function localeFirstDayOfWeek() {\n return this._week.dow;\n }\n\n function localeFirstDayOfYear() {\n return this._week.doy;\n }\n\n // MOMENTS\n\n function getSetWeek(input) {\n var week = this.localeData().week(this);\n return input == null ? week : this.add((input - week) * 7, 'd');\n }\n\n function getSetISOWeek(input) {\n var week = weekOfYear(this, 1, 4).week;\n return input == null ? week : this.add((input - week) * 7, 'd');\n }\n\n // FORMATTING\n\n addFormatToken('d', 0, 'do', 'day');\n\n addFormatToken('dd', 0, 0, function (format) {\n return this.localeData().weekdaysMin(this, format);\n });\n\n addFormatToken('ddd', 0, 0, function (format) {\n return this.localeData().weekdaysShort(this, format);\n });\n\n addFormatToken('dddd', 0, 0, function (format) {\n return this.localeData().weekdays(this, format);\n });\n\n addFormatToken('e', 0, 0, 'weekday');\n addFormatToken('E', 0, 0, 'isoWeekday');\n\n // PARSING\n\n addRegexToken('d', match1to2);\n addRegexToken('e', match1to2);\n addRegexToken('E', match1to2);\n addRegexToken('dd', function (isStrict, locale) {\n return locale.weekdaysMinRegex(isStrict);\n });\n addRegexToken('ddd', function (isStrict, locale) {\n return locale.weekdaysShortRegex(isStrict);\n });\n addRegexToken('dddd', function (isStrict, locale) {\n return locale.weekdaysRegex(isStrict);\n });\n\n addWeekParseToken(['dd', 'ddd', 'dddd'], function (input, week, config, token) {\n var weekday = config._locale.weekdaysParse(input, token, config._strict);\n // if we didn't get a weekday name, mark the date as invalid\n if (weekday != null) {\n week.d = weekday;\n } else {\n getParsingFlags(config).invalidWeekday = input;\n }\n });\n\n addWeekParseToken(['d', 'e', 'E'], function (input, week, config, token) {\n week[token] = toInt(input);\n });\n\n // HELPERS\n\n function parseWeekday(input, locale) {\n if (typeof input !== 'string') {\n return input;\n }\n\n if (!isNaN(input)) {\n return parseInt(input, 10);\n }\n\n input = locale.weekdaysParse(input);\n if (typeof input === 'number') {\n return input;\n }\n\n return null;\n }\n\n function parseIsoWeekday(input, locale) {\n if (typeof input === 'string') {\n return locale.weekdaysParse(input) % 7 || 7;\n }\n return isNaN(input) ? null : input;\n }\n\n // LOCALES\n function shiftWeekdays(ws, n) {\n return ws.slice(n, 7).concat(ws.slice(0, n));\n }\n\n var defaultLocaleWeekdays =\n 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_'),\n defaultLocaleWeekdaysShort = 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_'),\n defaultLocaleWeekdaysMin = 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_'),\n defaultWeekdaysRegex = matchWord,\n defaultWeekdaysShortRegex = matchWord,\n defaultWeekdaysMinRegex = matchWord;\n\n function localeWeekdays(m, format) {\n var weekdays = isArray(this._weekdays)\n ? this._weekdays\n : this._weekdays[\n m && m !== true && this._weekdays.isFormat.test(format)\n ? 'format'\n : 'standalone'\n ];\n return m === true\n ? shiftWeekdays(weekdays, this._week.dow)\n : m\n ? weekdays[m.day()]\n : weekdays;\n }\n\n function localeWeekdaysShort(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysShort, this._week.dow)\n : m\n ? this._weekdaysShort[m.day()]\n : this._weekdaysShort;\n }\n\n function localeWeekdaysMin(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysMin, this._week.dow)\n : m\n ? this._weekdaysMin[m.day()]\n : this._weekdaysMin;\n }\n\n function handleStrictParse$1(weekdayName, format, strict) {\n var i,\n ii,\n mom,\n llc = weekdayName.toLocaleLowerCase();\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._minWeekdaysParse = [];\n\n for (i = 0; i < 7; ++i) {\n mom = createUTC([2000, 1]).day(i);\n this._minWeekdaysParse[i] = this.weekdaysMin(\n mom,\n ''\n ).toLocaleLowerCase();\n this._shortWeekdaysParse[i] = this.weekdaysShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._weekdaysParse[i] = this.weekdays(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n }\n\n function localeWeekdaysParse(weekdayName, format, strict) {\n var i, mom, regex;\n\n if (this._weekdaysParseExact) {\n return handleStrictParse$1.call(this, weekdayName, format, strict);\n }\n\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._minWeekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._fullWeekdaysParse = [];\n }\n\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n\n mom = createUTC([2000, 1]).day(i);\n if (strict && !this._fullWeekdaysParse[i]) {\n this._fullWeekdaysParse[i] = new RegExp(\n '^' + this.weekdays(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._shortWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysShort(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._minWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysMin(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n }\n if (!this._weekdaysParse[i]) {\n regex =\n '^' +\n this.weekdays(mom, '') +\n '|^' +\n this.weekdaysShort(mom, '') +\n '|^' +\n this.weekdaysMin(mom, '');\n this._weekdaysParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'dddd' &&\n this._fullWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'ddd' &&\n this._shortWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'dd' &&\n this._minWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (!strict && this._weekdaysParse[i].test(weekdayName)) {\n return i;\n }\n }\n }\n\n // MOMENTS\n\n function getSetDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n var day = get(this, 'Day');\n if (input != null) {\n input = parseWeekday(input, this.localeData());\n return this.add(input - day, 'd');\n } else {\n return day;\n }\n }\n\n function getSetLocaleDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7;\n return input == null ? weekday : this.add(input - weekday, 'd');\n }\n\n function getSetISODayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n // behaves the same as moment#day except\n // as a getter, returns 7 instead of 0 (1-7 range instead of 0-6)\n // as a setter, sunday should belong to the previous week.\n\n if (input != null) {\n var weekday = parseIsoWeekday(input, this.localeData());\n return this.day(this.day() % 7 ? weekday : weekday - 7);\n } else {\n return this.day() || 7;\n }\n }\n\n function weekdaysRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysStrictRegex;\n } else {\n return this._weekdaysRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n this._weekdaysRegex = defaultWeekdaysRegex;\n }\n return this._weekdaysStrictRegex && isStrict\n ? this._weekdaysStrictRegex\n : this._weekdaysRegex;\n }\n }\n\n function weekdaysShortRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysShortStrictRegex;\n } else {\n return this._weekdaysShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysShortRegex')) {\n this._weekdaysShortRegex = defaultWeekdaysShortRegex;\n }\n return this._weekdaysShortStrictRegex && isStrict\n ? this._weekdaysShortStrictRegex\n : this._weekdaysShortRegex;\n }\n }\n\n function weekdaysMinRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysMinStrictRegex;\n } else {\n return this._weekdaysMinRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysMinRegex')) {\n this._weekdaysMinRegex = defaultWeekdaysMinRegex;\n }\n return this._weekdaysMinStrictRegex && isStrict\n ? this._weekdaysMinStrictRegex\n : this._weekdaysMinRegex;\n }\n }\n\n function computeWeekdaysParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var minPieces = [],\n shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n minp,\n shortp,\n longp;\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, 1]).day(i);\n minp = regexEscape(this.weekdaysMin(mom, ''));\n shortp = regexEscape(this.weekdaysShort(mom, ''));\n longp = regexEscape(this.weekdays(mom, ''));\n minPieces.push(minp);\n shortPieces.push(shortp);\n longPieces.push(longp);\n mixedPieces.push(minp);\n mixedPieces.push(shortp);\n mixedPieces.push(longp);\n }\n // Sorting makes sure if one weekday (or abbr) is a prefix of another it\n // will match the longer piece.\n minPieces.sort(cmpLenRev);\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._weekdaysRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._weekdaysShortRegex = this._weekdaysRegex;\n this._weekdaysMinRegex = this._weekdaysRegex;\n\n this._weekdaysStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysMinStrictRegex = new RegExp(\n '^(' + minPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n function hFormat() {\n return this.hours() % 12 || 12;\n }\n\n function kFormat() {\n return this.hours() || 24;\n }\n\n addFormatToken('H', ['HH', 2], 0, 'hour');\n addFormatToken('h', ['hh', 2], 0, hFormat);\n addFormatToken('k', ['kk', 2], 0, kFormat);\n\n addFormatToken('hmm', 0, 0, function () {\n return '' + hFormat.apply(this) + zeroFill(this.minutes(), 2);\n });\n\n addFormatToken('hmmss', 0, 0, function () {\n return (\n '' +\n hFormat.apply(this) +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n });\n\n addFormatToken('Hmm', 0, 0, function () {\n return '' + this.hours() + zeroFill(this.minutes(), 2);\n });\n\n addFormatToken('Hmmss', 0, 0, function () {\n return (\n '' +\n this.hours() +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n });\n\n function meridiem(token, lowercase) {\n addFormatToken(token, 0, 0, function () {\n return this.localeData().meridiem(\n this.hours(),\n this.minutes(),\n lowercase\n );\n });\n }\n\n meridiem('a', true);\n meridiem('A', false);\n\n // PARSING\n\n function matchMeridiem(isStrict, locale) {\n return locale._meridiemParse;\n }\n\n addRegexToken('a', matchMeridiem);\n addRegexToken('A', matchMeridiem);\n addRegexToken('H', match1to2, match1to2HasZero);\n addRegexToken('h', match1to2, match1to2NoLeadingZero);\n addRegexToken('k', match1to2, match1to2NoLeadingZero);\n addRegexToken('HH', match1to2, match2);\n addRegexToken('hh', match1to2, match2);\n addRegexToken('kk', match1to2, match2);\n\n addRegexToken('hmm', match3to4);\n addRegexToken('hmmss', match5to6);\n addRegexToken('Hmm', match3to4);\n addRegexToken('Hmmss', match5to6);\n\n addParseToken(['H', 'HH'], HOUR);\n addParseToken(['k', 'kk'], function (input, array, config) {\n var kInput = toInt(input);\n array[HOUR] = kInput === 24 ? 0 : kInput;\n });\n addParseToken(['a', 'A'], function (input, array, config) {\n config._isPm = config._locale.isPM(input);\n config._meridiem = input;\n });\n addParseToken(['h', 'hh'], function (input, array, config) {\n array[HOUR] = toInt(input);\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('Hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n });\n addParseToken('Hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n });\n\n // LOCALES\n\n function localeIsPM(input) {\n // IE8 Quirks Mode & IE7 Standards Mode do not allow accessing strings like arrays\n // Using charAt should be more compatible.\n return (input + '').toLowerCase().charAt(0) === 'p';\n }\n\n var defaultLocaleMeridiemParse = /[ap]\\.?m?\\.?/i,\n // Setting the hour should keep the time, because the user explicitly\n // specified which hour they want. So trying to maintain the same hour (in\n // a new timezone) makes sense. Adding/subtracting hours does not follow\n // this rule.\n getSetHour = makeGetSet('Hours', true);\n\n function localeMeridiem(hours, minutes, isLower) {\n if (hours > 11) {\n return isLower ? 'pm' : 'PM';\n } else {\n return isLower ? 'am' : 'AM';\n }\n }\n\n var baseConfig = {\n calendar: defaultCalendar,\n longDateFormat: defaultLongDateFormat,\n invalidDate: defaultInvalidDate,\n ordinal: defaultOrdinal,\n dayOfMonthOrdinalParse: defaultDayOfMonthOrdinalParse,\n relativeTime: defaultRelativeTime,\n\n months: defaultLocaleMonths,\n monthsShort: defaultLocaleMonthsShort,\n\n week: defaultLocaleWeek,\n\n weekdays: defaultLocaleWeekdays,\n weekdaysMin: defaultLocaleWeekdaysMin,\n weekdaysShort: defaultLocaleWeekdaysShort,\n\n meridiemParse: defaultLocaleMeridiemParse,\n };\n\n // internal storage for locale config files\n var locales = {},\n localeFamilies = {},\n globalLocale;\n\n function commonPrefix(arr1, arr2) {\n var i,\n minl = Math.min(arr1.length, arr2.length);\n for (i = 0; i < minl; i += 1) {\n if (arr1[i] !== arr2[i]) {\n return i;\n }\n }\n return minl;\n }\n\n function normalizeLocale(key) {\n return key ? key.toLowerCase().replace('_', '-') : key;\n }\n\n // pick the locale from the array\n // try ['en-au', 'en-gb'] as 'en-au', 'en-gb', 'en', as in move through the list trying each\n // substring from most specific to least, but move to the next array item if it's a more specific variant than the current root\n function chooseLocale(names) {\n var i = 0,\n j,\n next,\n locale,\n split;\n\n while (i < names.length) {\n split = normalizeLocale(names[i]).split('-');\n j = split.length;\n next = normalizeLocale(names[i + 1]);\n next = next ? next.split('-') : null;\n while (j > 0) {\n locale = loadLocale(split.slice(0, j).join('-'));\n if (locale) {\n return locale;\n }\n if (\n next &&\n next.length >= j &&\n commonPrefix(split, next) >= j - 1\n ) {\n //the next array item is better than a shallower substring of this one\n break;\n }\n j--;\n }\n i++;\n }\n return globalLocale;\n }\n\n function isLocaleNameSane(name) {\n // Prevent names that look like filesystem paths, i.e contain '/' or '\\'\n // Ensure name is available and function returns boolean\n return !!(name && name.match('^[^/\\\\\\\\]*$'));\n }\n\n function loadLocale(name) {\n var oldLocale = null,\n aliasedRequire;\n // TODO: Find a better way to register and load all the locales in Node\n if (\n locales[name] === undefined &&\n typeof module !== 'undefined' &&\n module &&\n module.exports &&\n isLocaleNameSane(name)\n ) {\n try {\n oldLocale = globalLocale._abbr;\n aliasedRequire = require;\n aliasedRequire('./locale/' + name);\n getSetGlobalLocale(oldLocale);\n } catch (e) {\n // mark as not found to avoid repeating expensive file require call causing high CPU\n // when trying to find en-US, en_US, en-us for every format call\n locales[name] = null; // null means not found\n }\n }\n return locales[name];\n }\n\n // This function will load locale and then set the global locale. If\n // no arguments are passed in, it will simply return the current global\n // locale key.\n function getSetGlobalLocale(key, values) {\n var data;\n if (key) {\n if (isUndefined(values)) {\n data = getLocale(key);\n } else {\n data = defineLocale(key, values);\n }\n\n if (data) {\n // moment.duration._locale = moment._locale = data;\n globalLocale = data;\n } else {\n if (typeof console !== 'undefined' && console.warn) {\n //warn user if arguments are passed but the locale could not be set\n console.warn(\n 'Locale ' + key + ' not found. Did you forget to load it?'\n );\n }\n }\n }\n\n return globalLocale._abbr;\n }\n\n function defineLocale(name, config) {\n if (config !== null) {\n var locale,\n parentConfig = baseConfig;\n config.abbr = name;\n if (locales[name] != null) {\n deprecateSimple(\n 'defineLocaleOverride',\n 'use moment.updateLocale(localeName, config) to change ' +\n 'an existing locale. moment.defineLocale(localeName, ' +\n 'config) should only be used for creating a new locale ' +\n 'See http://momentjs.com/guides/#/warnings/define-locale/ for more info.'\n );\n parentConfig = locales[name]._config;\n } else if (config.parentLocale != null) {\n if (locales[config.parentLocale] != null) {\n parentConfig = locales[config.parentLocale]._config;\n } else {\n locale = loadLocale(config.parentLocale);\n if (locale != null) {\n parentConfig = locale._config;\n } else {\n if (!localeFamilies[config.parentLocale]) {\n localeFamilies[config.parentLocale] = [];\n }\n localeFamilies[config.parentLocale].push({\n name: name,\n config: config,\n });\n return null;\n }\n }\n }\n locales[name] = new Locale(mergeConfigs(parentConfig, config));\n\n if (localeFamilies[name]) {\n localeFamilies[name].forEach(function (x) {\n defineLocale(x.name, x.config);\n });\n }\n\n // backwards compat for now: also set the locale\n // make sure we set the locale AFTER all child locales have been\n // created, so we won't end up with the child locale set.\n getSetGlobalLocale(name);\n\n return locales[name];\n } else {\n // useful for testing\n delete locales[name];\n return null;\n }\n }\n\n function updateLocale(name, config) {\n if (config != null) {\n var locale,\n tmpLocale,\n parentConfig = baseConfig;\n\n if (locales[name] != null && locales[name].parentLocale != null) {\n // Update existing child locale in-place to avoid memory-leaks\n locales[name].set(mergeConfigs(locales[name]._config, config));\n } else {\n // MERGE\n tmpLocale = loadLocale(name);\n if (tmpLocale != null) {\n parentConfig = tmpLocale._config;\n }\n config = mergeConfigs(parentConfig, config);\n if (tmpLocale == null) {\n // updateLocale is called for creating a new locale\n // Set abbr so it will have a name (getters return\n // undefined otherwise).\n config.abbr = name;\n }\n locale = new Locale(config);\n locale.parentLocale = locales[name];\n locales[name] = locale;\n }\n\n // backwards compat for now: also set the locale\n getSetGlobalLocale(name);\n } else {\n // pass null for config to unupdate, useful for tests\n if (locales[name] != null) {\n if (locales[name].parentLocale != null) {\n locales[name] = locales[name].parentLocale;\n if (name === getSetGlobalLocale()) {\n getSetGlobalLocale(name);\n }\n } else if (locales[name] != null) {\n delete locales[name];\n }\n }\n }\n return locales[name];\n }\n\n // returns locale data\n function getLocale(key) {\n var locale;\n\n if (key && key._locale && key._locale._abbr) {\n key = key._locale._abbr;\n }\n\n if (!key) {\n return globalLocale;\n }\n\n if (!isArray(key)) {\n //short-circuit everything else\n locale = loadLocale(key);\n if (locale) {\n return locale;\n }\n key = [key];\n }\n\n return chooseLocale(key);\n }\n\n function listLocales() {\n return keys(locales);\n }\n\n function checkOverflow(m) {\n var overflow,\n a = m._a;\n\n if (a && getParsingFlags(m).overflow === -2) {\n overflow =\n a[MONTH] < 0 || a[MONTH] > 11\n ? MONTH\n : a[DATE] < 1 || a[DATE] > daysInMonth(a[YEAR], a[MONTH])\n ? DATE\n : a[HOUR] < 0 ||\n a[HOUR] > 24 ||\n (a[HOUR] === 24 &&\n (a[MINUTE] !== 0 ||\n a[SECOND] !== 0 ||\n a[MILLISECOND] !== 0))\n ? HOUR\n : a[MINUTE] < 0 || a[MINUTE] > 59\n ? MINUTE\n : a[SECOND] < 0 || a[SECOND] > 59\n ? SECOND\n : a[MILLISECOND] < 0 || a[MILLISECOND] > 999\n ? MILLISECOND\n : -1;\n\n if (\n getParsingFlags(m)._overflowDayOfYear &&\n (overflow < YEAR || overflow > DATE)\n ) {\n overflow = DATE;\n }\n if (getParsingFlags(m)._overflowWeeks && overflow === -1) {\n overflow = WEEK;\n }\n if (getParsingFlags(m)._overflowWeekday && overflow === -1) {\n overflow = WEEKDAY;\n }\n\n getParsingFlags(m).overflow = overflow;\n }\n\n return m;\n }\n\n // iso 8601 regex\n // 0000-00-00 0000-W00 or 0000-W00-0 + T + 00 or 00:00 or 00:00:00 or 00:00:00.000 + +00:00 or +0000 or +00)\n var extendedIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})-(?:\\d\\d-\\d\\d|W\\d\\d-\\d|W\\d\\d|\\d\\d\\d|\\d\\d))(?:(T| )(\\d\\d(?::\\d\\d(?::\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n basicIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})(?:\\d\\d\\d\\d|W\\d\\d\\d|W\\d\\d|\\d\\d\\d|\\d\\d|))(?:(T| )(\\d\\d(?:\\d\\d(?:\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n tzRegex = /Z|[+-]\\d\\d(?::?\\d\\d)?/,\n isoDates = [\n ['YYYYYY-MM-DD', /[+-]\\d{6}-\\d\\d-\\d\\d/],\n ['YYYY-MM-DD', /\\d{4}-\\d\\d-\\d\\d/],\n ['GGGG-[W]WW-E', /\\d{4}-W\\d\\d-\\d/],\n ['GGGG-[W]WW', /\\d{4}-W\\d\\d/, false],\n ['YYYY-DDD', /\\d{4}-\\d{3}/],\n ['YYYY-MM', /\\d{4}-\\d\\d/, false],\n ['YYYYYYMMDD', /[+-]\\d{10}/],\n ['YYYYMMDD', /\\d{8}/],\n ['GGGG[W]WWE', /\\d{4}W\\d{3}/],\n ['GGGG[W]WW', /\\d{4}W\\d{2}/, false],\n ['YYYYDDD', /\\d{7}/],\n ['YYYYMM', /\\d{6}/, false],\n ['YYYY', /\\d{4}/, false],\n ],\n // iso time formats and regexes\n isoTimes = [\n ['HH:mm:ss.SSSS', /\\d\\d:\\d\\d:\\d\\d\\.\\d+/],\n ['HH:mm:ss,SSSS', /\\d\\d:\\d\\d:\\d\\d,\\d+/],\n ['HH:mm:ss', /\\d\\d:\\d\\d:\\d\\d/],\n ['HH:mm', /\\d\\d:\\d\\d/],\n ['HHmmss.SSSS', /\\d\\d\\d\\d\\d\\d\\.\\d+/],\n ['HHmmss,SSSS', /\\d\\d\\d\\d\\d\\d,\\d+/],\n ['HHmmss', /\\d\\d\\d\\d\\d\\d/],\n ['HHmm', /\\d\\d\\d\\d/],\n ['HH', /\\d\\d/],\n ],\n aspNetJsonRegex = /^\\/?Date\\((-?\\d+)/i,\n // RFC 2822 regex: For details see https://tools.ietf.org/html/rfc2822#section-3.3\n rfc2822 =\n /^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\\s)?(\\d{1,2})\\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\\s(\\d{2,4})\\s(\\d\\d):(\\d\\d)(?::(\\d\\d))?\\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\\d{4}))$/,\n obsOffsets = {\n UT: 0,\n GMT: 0,\n EDT: -4 * 60,\n EST: -5 * 60,\n CDT: -5 * 60,\n CST: -6 * 60,\n MDT: -6 * 60,\n MST: -7 * 60,\n PDT: -7 * 60,\n PST: -8 * 60,\n };\n\n // date from iso format\n function configFromISO(config) {\n var i,\n l,\n string = config._i,\n match = extendedIsoRegex.exec(string) || basicIsoRegex.exec(string),\n allowTime,\n dateFormat,\n timeFormat,\n tzFormat,\n isoDatesLen = isoDates.length,\n isoTimesLen = isoTimes.length;\n\n if (match) {\n getParsingFlags(config).iso = true;\n for (i = 0, l = isoDatesLen; i < l; i++) {\n if (isoDates[i][1].exec(match[1])) {\n dateFormat = isoDates[i][0];\n allowTime = isoDates[i][2] !== false;\n break;\n }\n }\n if (dateFormat == null) {\n config._isValid = false;\n return;\n }\n if (match[3]) {\n for (i = 0, l = isoTimesLen; i < l; i++) {\n if (isoTimes[i][1].exec(match[3])) {\n // match[2] should be 'T' or space\n timeFormat = (match[2] || ' ') + isoTimes[i][0];\n break;\n }\n }\n if (timeFormat == null) {\n config._isValid = false;\n return;\n }\n }\n if (!allowTime && timeFormat != null) {\n config._isValid = false;\n return;\n }\n if (match[4]) {\n if (tzRegex.exec(match[4])) {\n tzFormat = 'Z';\n } else {\n config._isValid = false;\n return;\n }\n }\n config._f = dateFormat + (timeFormat || '') + (tzFormat || '');\n configFromStringAndFormat(config);\n } else {\n config._isValid = false;\n }\n }\n\n function extractFromRFC2822Strings(\n yearStr,\n monthStr,\n dayStr,\n hourStr,\n minuteStr,\n secondStr\n ) {\n var result = [\n untruncateYear(yearStr),\n defaultLocaleMonthsShort.indexOf(monthStr),\n parseInt(dayStr, 10),\n parseInt(hourStr, 10),\n parseInt(minuteStr, 10),\n ];\n\n if (secondStr) {\n result.push(parseInt(secondStr, 10));\n }\n\n return result;\n }\n\n function untruncateYear(yearStr) {\n var year = parseInt(yearStr, 10);\n if (year <= 49) {\n return 2000 + year;\n } else if (year <= 999) {\n return 1900 + year;\n }\n return year;\n }\n\n function preprocessRFC2822(s) {\n // Remove comments and folding whitespace and replace multiple-spaces with a single space\n return s\n .replace(/\\([^()]*\\)|[\\n\\t]/g, ' ')\n .replace(/(\\s\\s+)/g, ' ')\n .replace(/^\\s\\s*/, '')\n .replace(/\\s\\s*$/, '');\n }\n\n function checkWeekday(weekdayStr, parsedInput, config) {\n if (weekdayStr) {\n // TODO: Replace the vanilla JS Date object with an independent day-of-week check.\n var weekdayProvided = defaultLocaleWeekdaysShort.indexOf(weekdayStr),\n weekdayActual = new Date(\n parsedInput[0],\n parsedInput[1],\n parsedInput[2]\n ).getDay();\n if (weekdayProvided !== weekdayActual) {\n getParsingFlags(config).weekdayMismatch = true;\n config._isValid = false;\n return false;\n }\n }\n return true;\n }\n\n function calculateOffset(obsOffset, militaryOffset, numOffset) {\n if (obsOffset) {\n return obsOffsets[obsOffset];\n } else if (militaryOffset) {\n // the only allowed military tz is Z\n return 0;\n } else {\n var hm = parseInt(numOffset, 10),\n m = hm % 100,\n h = (hm - m) / 100;\n return h * 60 + m;\n }\n }\n\n // date and time from ref 2822 format\n function configFromRFC2822(config) {\n var match = rfc2822.exec(preprocessRFC2822(config._i)),\n parsedArray;\n if (match) {\n parsedArray = extractFromRFC2822Strings(\n match[4],\n match[3],\n match[2],\n match[5],\n match[6],\n match[7]\n );\n if (!checkWeekday(match[1], parsedArray, config)) {\n return;\n }\n\n config._a = parsedArray;\n config._tzm = calculateOffset(match[8], match[9], match[10]);\n\n config._d = createUTCDate.apply(null, config._a);\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n\n getParsingFlags(config).rfc2822 = true;\n } else {\n config._isValid = false;\n }\n }\n\n // date from 1) ASP.NET, 2) ISO, 3) RFC 2822 formats, or 4) optional fallback if parsing isn't strict\n function configFromString(config) {\n var matched = aspNetJsonRegex.exec(config._i);\n if (matched !== null) {\n config._d = new Date(+matched[1]);\n return;\n }\n\n configFromISO(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n configFromRFC2822(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n if (config._strict) {\n config._isValid = false;\n } else {\n // Final attempt, use Input Fallback\n hooks.createFromInputFallback(config);\n }\n }\n\n hooks.createFromInputFallback = deprecate(\n 'value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), ' +\n 'which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are ' +\n 'discouraged. Please refer to http://momentjs.com/guides/#/warnings/js-date/ for more info.',\n function (config) {\n config._d = new Date(config._i + (config._useUTC ? ' UTC' : ''));\n }\n );\n\n // Pick the first defined of two or three arguments.\n function defaults(a, b, c) {\n if (a != null) {\n return a;\n }\n if (b != null) {\n return b;\n }\n return c;\n }\n\n function currentDateArray(config) {\n // hooks is actually the exported moment object\n var nowValue = new Date(hooks.now());\n if (config._useUTC) {\n return [\n nowValue.getUTCFullYear(),\n nowValue.getUTCMonth(),\n nowValue.getUTCDate(),\n ];\n }\n return [nowValue.getFullYear(), nowValue.getMonth(), nowValue.getDate()];\n }\n\n // convert an array to a date.\n // the array should mirror the parameters below\n // note: all values past the year are optional and will default to the lowest possible value.\n // [year, month, day , hour, minute, second, millisecond]\n function configFromArray(config) {\n var i,\n date,\n input = [],\n currentDate,\n expectedWeekday,\n yearToUse;\n\n if (config._d) {\n return;\n }\n\n currentDate = currentDateArray(config);\n\n //compute day of the year from weeks and weekdays\n if (config._w && config._a[DATE] == null && config._a[MONTH] == null) {\n dayOfYearFromWeekInfo(config);\n }\n\n //if the day of the year is set, figure out what it is\n if (config._dayOfYear != null) {\n yearToUse = defaults(config._a[YEAR], currentDate[YEAR]);\n\n if (\n config._dayOfYear > daysInYear(yearToUse) ||\n config._dayOfYear === 0\n ) {\n getParsingFlags(config)._overflowDayOfYear = true;\n }\n\n date = createUTCDate(yearToUse, 0, config._dayOfYear);\n config._a[MONTH] = date.getUTCMonth();\n config._a[DATE] = date.getUTCDate();\n }\n\n // Default to current date.\n // * if no year, month, day of month are given, default to today\n // * if day of month is given, default month and year\n // * if month is given, default only year\n // * if year is given, don't default anything\n for (i = 0; i < 3 && config._a[i] == null; ++i) {\n config._a[i] = input[i] = currentDate[i];\n }\n\n // Zero out whatever was not defaulted, including time\n for (; i < 7; i++) {\n config._a[i] = input[i] =\n config._a[i] == null ? (i === 2 ? 1 : 0) : config._a[i];\n }\n\n // Check for 24:00:00.000\n if (\n config._a[HOUR] === 24 &&\n config._a[MINUTE] === 0 &&\n config._a[SECOND] === 0 &&\n config._a[MILLISECOND] === 0\n ) {\n config._nextDay = true;\n config._a[HOUR] = 0;\n }\n\n config._d = (config._useUTC ? createUTCDate : createDate).apply(\n null,\n input\n );\n expectedWeekday = config._useUTC\n ? config._d.getUTCDay()\n : config._d.getDay();\n\n // Apply timezone offset from input. The actual utcOffset can be changed\n // with parseZone.\n if (config._tzm != null) {\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n }\n\n if (config._nextDay) {\n config._a[HOUR] = 24;\n }\n\n // check for mismatching day of week\n if (\n config._w &&\n typeof config._w.d !== 'undefined' &&\n config._w.d !== expectedWeekday\n ) {\n getParsingFlags(config).weekdayMismatch = true;\n }\n }\n\n function dayOfYearFromWeekInfo(config) {\n var w, weekYear, week, weekday, dow, doy, temp, weekdayOverflow, curWeek;\n\n w = config._w;\n if (w.GG != null || w.W != null || w.E != null) {\n dow = 1;\n doy = 4;\n\n // TODO: We need to take the current isoWeekYear, but that depends on\n // how we interpret now (local, utc, fixed offset). So create\n // a now version of current config (take local/utc/offset flags, and\n // create now).\n weekYear = defaults(\n w.GG,\n config._a[YEAR],\n weekOfYear(createLocal(), 1, 4).year\n );\n week = defaults(w.W, 1);\n weekday = defaults(w.E, 1);\n if (weekday < 1 || weekday > 7) {\n weekdayOverflow = true;\n }\n } else {\n dow = config._locale._week.dow;\n doy = config._locale._week.doy;\n\n curWeek = weekOfYear(createLocal(), dow, doy);\n\n weekYear = defaults(w.gg, config._a[YEAR], curWeek.year);\n\n // Default to current week.\n week = defaults(w.w, curWeek.week);\n\n if (w.d != null) {\n // weekday -- low day numbers are considered next week\n weekday = w.d;\n if (weekday < 0 || weekday > 6) {\n weekdayOverflow = true;\n }\n } else if (w.e != null) {\n // local weekday -- counting starts from beginning of week\n weekday = w.e + dow;\n if (w.e < 0 || w.e > 6) {\n weekdayOverflow = true;\n }\n } else {\n // default to beginning of week\n weekday = dow;\n }\n }\n if (week < 1 || week > weeksInYear(weekYear, dow, doy)) {\n getParsingFlags(config)._overflowWeeks = true;\n } else if (weekdayOverflow != null) {\n getParsingFlags(config)._overflowWeekday = true;\n } else {\n temp = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy);\n config._a[YEAR] = temp.year;\n config._dayOfYear = temp.dayOfYear;\n }\n }\n\n // constant that refers to the ISO standard\n hooks.ISO_8601 = function () {};\n\n // constant that refers to the RFC 2822 form\n hooks.RFC_2822 = function () {};\n\n // date from string and format string\n function configFromStringAndFormat(config) {\n // TODO: Move this to another part of the creation flow to prevent circular deps\n if (config._f === hooks.ISO_8601) {\n configFromISO(config);\n return;\n }\n if (config._f === hooks.RFC_2822) {\n configFromRFC2822(config);\n return;\n }\n config._a = [];\n getParsingFlags(config).empty = true;\n\n // This array is used to make a Date, either with `new Date` or `Date.UTC`\n var string = '' + config._i,\n i,\n parsedInput,\n tokens,\n token,\n skipped,\n stringLength = string.length,\n totalParsedInputLength = 0,\n era,\n tokenLen;\n\n tokens =\n expandFormat(config._f, config._locale).match(formattingTokens) || [];\n tokenLen = tokens.length;\n for (i = 0; i < tokenLen; i++) {\n token = tokens[i];\n parsedInput = (string.match(getParseRegexForToken(token, config)) ||\n [])[0];\n if (parsedInput) {\n skipped = string.substr(0, string.indexOf(parsedInput));\n if (skipped.length > 0) {\n getParsingFlags(config).unusedInput.push(skipped);\n }\n string = string.slice(\n string.indexOf(parsedInput) + parsedInput.length\n );\n totalParsedInputLength += parsedInput.length;\n }\n // don't parse if it's not a known token\n if (formatTokenFunctions[token]) {\n if (parsedInput) {\n getParsingFlags(config).empty = false;\n } else {\n getParsingFlags(config).unusedTokens.push(token);\n }\n addTimeToArrayFromToken(token, parsedInput, config);\n } else if (config._strict && !parsedInput) {\n getParsingFlags(config).unusedTokens.push(token);\n }\n }\n\n // add remaining unparsed input length to the string\n getParsingFlags(config).charsLeftOver =\n stringLength - totalParsedInputLength;\n if (string.length > 0) {\n getParsingFlags(config).unusedInput.push(string);\n }\n\n // clear _12h flag if hour is <= 12\n if (\n config._a[HOUR] <= 12 &&\n getParsingFlags(config).bigHour === true &&\n config._a[HOUR] > 0\n ) {\n getParsingFlags(config).bigHour = undefined;\n }\n\n getParsingFlags(config).parsedDateParts = config._a.slice(0);\n getParsingFlags(config).meridiem = config._meridiem;\n // handle meridiem\n config._a[HOUR] = meridiemFixWrap(\n config._locale,\n config._a[HOUR],\n config._meridiem\n );\n\n // handle era\n era = getParsingFlags(config).era;\n if (era !== null) {\n config._a[YEAR] = config._locale.erasConvertYear(era, config._a[YEAR]);\n }\n\n configFromArray(config);\n checkOverflow(config);\n }\n\n function meridiemFixWrap(locale, hour, meridiem) {\n var isPm;\n\n if (meridiem == null) {\n // nothing to do\n return hour;\n }\n if (locale.meridiemHour != null) {\n return locale.meridiemHour(hour, meridiem);\n } else if (locale.isPM != null) {\n // Fallback\n isPm = locale.isPM(meridiem);\n if (isPm && hour < 12) {\n hour += 12;\n }\n if (!isPm && hour === 12) {\n hour = 0;\n }\n return hour;\n } else {\n // this is not supposed to happen\n return hour;\n }\n }\n\n // date from string and array of format strings\n function configFromStringAndArray(config) {\n var tempConfig,\n bestMoment,\n scoreToBeat,\n i,\n currentScore,\n validFormatFound,\n bestFormatIsValid = false,\n configfLen = config._f.length;\n\n if (configfLen === 0) {\n getParsingFlags(config).invalidFormat = true;\n config._d = new Date(NaN);\n return;\n }\n\n for (i = 0; i < configfLen; i++) {\n currentScore = 0;\n validFormatFound = false;\n tempConfig = copyConfig({}, config);\n if (config._useUTC != null) {\n tempConfig._useUTC = config._useUTC;\n }\n tempConfig._f = config._f[i];\n configFromStringAndFormat(tempConfig);\n\n if (isValid(tempConfig)) {\n validFormatFound = true;\n }\n\n // if there is any input that was not parsed add a penalty for that format\n currentScore += getParsingFlags(tempConfig).charsLeftOver;\n\n //or tokens\n currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10;\n\n getParsingFlags(tempConfig).score = currentScore;\n\n if (!bestFormatIsValid) {\n if (\n scoreToBeat == null ||\n currentScore < scoreToBeat ||\n validFormatFound\n ) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n if (validFormatFound) {\n bestFormatIsValid = true;\n }\n }\n } else {\n if (currentScore < scoreToBeat) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n }\n }\n }\n\n extend(config, bestMoment || tempConfig);\n }\n\n function configFromObject(config) {\n if (config._d) {\n return;\n }\n\n var i = normalizeObjectUnits(config._i),\n dayOrDate = i.day === undefined ? i.date : i.day;\n config._a = map(\n [i.year, i.month, dayOrDate, i.hour, i.minute, i.second, i.millisecond],\n function (obj) {\n return obj && parseInt(obj, 10);\n }\n );\n\n configFromArray(config);\n }\n\n function createFromConfig(config) {\n var res = new Moment(checkOverflow(prepareConfig(config)));\n if (res._nextDay) {\n // Adding is smart enough around DST\n res.add(1, 'd');\n res._nextDay = undefined;\n }\n\n return res;\n }\n\n function prepareConfig(config) {\n var input = config._i,\n format = config._f;\n\n config._locale = config._locale || getLocale(config._l);\n\n if (input === null || (format === undefined && input === '')) {\n return createInvalid({ nullInput: true });\n }\n\n if (typeof input === 'string') {\n config._i = input = config._locale.preparse(input);\n }\n\n if (isMoment(input)) {\n return new Moment(checkOverflow(input));\n } else if (isDate(input)) {\n config._d = input;\n } else if (isArray(format)) {\n configFromStringAndArray(config);\n } else if (format) {\n configFromStringAndFormat(config);\n } else {\n configFromInput(config);\n }\n\n if (!isValid(config)) {\n config._d = null;\n }\n\n return config;\n }\n\n function configFromInput(config) {\n var input = config._i;\n if (isUndefined(input)) {\n config._d = new Date(hooks.now());\n } else if (isDate(input)) {\n config._d = new Date(input.valueOf());\n } else if (typeof input === 'string') {\n configFromString(config);\n } else if (isArray(input)) {\n config._a = map(input.slice(0), function (obj) {\n return parseInt(obj, 10);\n });\n configFromArray(config);\n } else if (isObject(input)) {\n configFromObject(config);\n } else if (isNumber(input)) {\n // from milliseconds\n config._d = new Date(input);\n } else {\n hooks.createFromInputFallback(config);\n }\n }\n\n function createLocalOrUTC(input, format, locale, strict, isUTC) {\n var c = {};\n\n if (format === true || format === false) {\n strict = format;\n format = undefined;\n }\n\n if (locale === true || locale === false) {\n strict = locale;\n locale = undefined;\n }\n\n if (\n (isObject(input) && isObjectEmpty(input)) ||\n (isArray(input) && input.length === 0)\n ) {\n input = undefined;\n }\n // object construction must be done this way.\n // https://github.com/moment/moment/issues/1423\n c._isAMomentObject = true;\n c._useUTC = c._isUTC = isUTC;\n c._l = locale;\n c._i = input;\n c._f = format;\n c._strict = strict;\n\n return createFromConfig(c);\n }\n\n function createLocal(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, false);\n }\n\n var prototypeMin = deprecate(\n 'moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other < this ? this : other;\n } else {\n return createInvalid();\n }\n }\n ),\n prototypeMax = deprecate(\n 'moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other > this ? this : other;\n } else {\n return createInvalid();\n }\n }\n );\n\n // Pick a moment m from moments so that m[fn](other) is true for all\n // other. This relies on the function fn to be transitive.\n //\n // moments should either be an array of moment objects or an array, whose\n // first element is an array of moment objects.\n function pickBy(fn, moments) {\n var res, i;\n if (moments.length === 1 && isArray(moments[0])) {\n moments = moments[0];\n }\n if (!moments.length) {\n return createLocal();\n }\n res = moments[0];\n for (i = 1; i < moments.length; ++i) {\n if (!moments[i].isValid() || moments[i][fn](res)) {\n res = moments[i];\n }\n }\n return res;\n }\n\n // TODO: Use [].sort instead?\n function min() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isBefore', args);\n }\n\n function max() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isAfter', args);\n }\n\n var now = function () {\n return Date.now ? Date.now() : +new Date();\n };\n\n var ordering = [\n 'year',\n 'quarter',\n 'month',\n 'week',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'millisecond',\n ];\n\n function isDurationValid(m) {\n var key,\n unitHasDecimal = false,\n i,\n orderLen = ordering.length;\n for (key in m) {\n if (\n hasOwnProp(m, key) &&\n !(\n indexOf.call(ordering, key) !== -1 &&\n (m[key] == null || !isNaN(m[key]))\n )\n ) {\n return false;\n }\n }\n\n for (i = 0; i < orderLen; ++i) {\n if (m[ordering[i]]) {\n if (unitHasDecimal) {\n return false; // only allow non-integers for smallest unit\n }\n if (parseFloat(m[ordering[i]]) !== toInt(m[ordering[i]])) {\n unitHasDecimal = true;\n }\n }\n }\n\n return true;\n }\n\n function isValid$1() {\n return this._isValid;\n }\n\n function createInvalid$1() {\n return createDuration(NaN);\n }\n\n function Duration(duration) {\n var normalizedInput = normalizeObjectUnits(duration),\n years = normalizedInput.year || 0,\n quarters = normalizedInput.quarter || 0,\n months = normalizedInput.month || 0,\n weeks = normalizedInput.week || normalizedInput.isoWeek || 0,\n days = normalizedInput.day || 0,\n hours = normalizedInput.hour || 0,\n minutes = normalizedInput.minute || 0,\n seconds = normalizedInput.second || 0,\n milliseconds = normalizedInput.millisecond || 0;\n\n this._isValid = isDurationValid(normalizedInput);\n\n // representation for dateAddRemove\n this._milliseconds =\n +milliseconds +\n seconds * 1e3 + // 1000\n minutes * 6e4 + // 1000 * 60\n hours * 1000 * 60 * 60; //using 1000 * 60 * 60 instead of 36e5 to avoid floating point rounding errors https://github.com/moment/moment/issues/2978\n // Because of dateAddRemove treats 24 hours as different from a\n // day when working around DST, we need to store them separately\n this._days = +days + weeks * 7;\n // It is impossible to translate months into days without knowing\n // which months you are are talking about, so we have to store\n // it separately.\n this._months = +months + quarters * 3 + years * 12;\n\n this._data = {};\n\n this._locale = getLocale();\n\n this._bubble();\n }\n\n function isDuration(obj) {\n return obj instanceof Duration;\n }\n\n function absRound(number) {\n if (number < 0) {\n return Math.round(-1 * number) * -1;\n } else {\n return Math.round(number);\n }\n }\n\n // compare two arrays, return the number of differences\n function compareArrays(array1, array2, dontConvert) {\n var len = Math.min(array1.length, array2.length),\n lengthDiff = Math.abs(array1.length - array2.length),\n diffs = 0,\n i;\n for (i = 0; i < len; i++) {\n if (\n (dontConvert && array1[i] !== array2[i]) ||\n (!dontConvert && toInt(array1[i]) !== toInt(array2[i]))\n ) {\n diffs++;\n }\n }\n return diffs + lengthDiff;\n }\n\n // FORMATTING\n\n function offset(token, separator) {\n addFormatToken(token, 0, 0, function () {\n var offset = this.utcOffset(),\n sign = '+';\n if (offset < 0) {\n offset = -offset;\n sign = '-';\n }\n return (\n sign +\n zeroFill(~~(offset / 60), 2) +\n separator +\n zeroFill(~~offset % 60, 2)\n );\n });\n }\n\n offset('Z', ':');\n offset('ZZ', '');\n\n // PARSING\n\n addRegexToken('Z', matchShortOffset);\n addRegexToken('ZZ', matchShortOffset);\n addParseToken(['Z', 'ZZ'], function (input, array, config) {\n config._useUTC = true;\n config._tzm = offsetFromString(matchShortOffset, input);\n });\n\n // HELPERS\n\n // timezone chunker\n // '+10:00' > ['10', '00']\n // '-1530' > ['-15', '30']\n var chunkOffset = /([\\+\\-]|\\d\\d)/gi;\n\n function offsetFromString(matcher, string) {\n var matches = (string || '').match(matcher),\n chunk,\n parts,\n minutes;\n\n if (matches === null) {\n return null;\n }\n\n chunk = matches[matches.length - 1] || [];\n parts = (chunk + '').match(chunkOffset) || ['-', 0, 0];\n minutes = +(parts[1] * 60) + toInt(parts[2]);\n\n return minutes === 0 ? 0 : parts[0] === '+' ? minutes : -minutes;\n }\n\n // Return a moment from input, that is local/utc/zone equivalent to model.\n function cloneWithOffset(input, model) {\n var res, diff;\n if (model._isUTC) {\n res = model.clone();\n diff =\n (isMoment(input) || isDate(input)\n ? input.valueOf()\n : createLocal(input).valueOf()) - res.valueOf();\n // Use low-level api, because this fn is low-level api.\n res._d.setTime(res._d.valueOf() + diff);\n hooks.updateOffset(res, false);\n return res;\n } else {\n return createLocal(input).local();\n }\n }\n\n function getDateOffset(m) {\n // On Firefox.24 Date#getTimezoneOffset returns a floating point.\n // https://github.com/moment/moment/pull/1871\n return -Math.round(m._d.getTimezoneOffset());\n }\n\n // HOOKS\n\n // This function will be called whenever a moment is mutated.\n // It is intended to keep the offset in sync with the timezone.\n hooks.updateOffset = function () {};\n\n // MOMENTS\n\n // keepLocalTime = true means only change the timezone, without\n // affecting the local hour. So 5:31:26 +0300 --[utcOffset(2, true)]-->\n // 5:31:26 +0200 It is possible that 5:31:26 doesn't exist with offset\n // +0200, so we adjust the time as needed, to be valid.\n //\n // Keeping the time actually adds/subtracts (one hour)\n // from the actual represented time. That is why we call updateOffset\n // a second time. In case it wants us to change the offset again\n // _changeInProgress == true case, then we have to adjust, because\n // there is no such time in the given timezone.\n function getSetOffset(input, keepLocalTime, keepMinutes) {\n var offset = this._offset || 0,\n localAdjust;\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n if (input != null) {\n if (typeof input === 'string') {\n input = offsetFromString(matchShortOffset, input);\n if (input === null) {\n return this;\n }\n } else if (Math.abs(input) < 16 && !keepMinutes) {\n input = input * 60;\n }\n if (!this._isUTC && keepLocalTime) {\n localAdjust = getDateOffset(this);\n }\n this._offset = input;\n this._isUTC = true;\n if (localAdjust != null) {\n this.add(localAdjust, 'm');\n }\n if (offset !== input) {\n if (!keepLocalTime || this._changeInProgress) {\n addSubtract(\n this,\n createDuration(input - offset, 'm'),\n 1,\n false\n );\n } else if (!this._changeInProgress) {\n this._changeInProgress = true;\n hooks.updateOffset(this, true);\n this._changeInProgress = null;\n }\n }\n return this;\n } else {\n return this._isUTC ? offset : getDateOffset(this);\n }\n }\n\n function getSetZone(input, keepLocalTime) {\n if (input != null) {\n if (typeof input !== 'string') {\n input = -input;\n }\n\n this.utcOffset(input, keepLocalTime);\n\n return this;\n } else {\n return -this.utcOffset();\n }\n }\n\n function setOffsetToUTC(keepLocalTime) {\n return this.utcOffset(0, keepLocalTime);\n }\n\n function setOffsetToLocal(keepLocalTime) {\n if (this._isUTC) {\n this.utcOffset(0, keepLocalTime);\n this._isUTC = false;\n\n if (keepLocalTime) {\n this.subtract(getDateOffset(this), 'm');\n }\n }\n return this;\n }\n\n function setOffsetToParsedOffset() {\n if (this._tzm != null) {\n this.utcOffset(this._tzm, false, true);\n } else if (typeof this._i === 'string') {\n var tZone = offsetFromString(matchOffset, this._i);\n if (tZone != null) {\n this.utcOffset(tZone);\n } else {\n this.utcOffset(0, true);\n }\n }\n return this;\n }\n\n function hasAlignedHourOffset(input) {\n if (!this.isValid()) {\n return false;\n }\n input = input ? createLocal(input).utcOffset() : 0;\n\n return (this.utcOffset() - input) % 60 === 0;\n }\n\n function isDaylightSavingTime() {\n return (\n this.utcOffset() > this.clone().month(0).utcOffset() ||\n this.utcOffset() > this.clone().month(5).utcOffset()\n );\n }\n\n function isDaylightSavingTimeShifted() {\n if (!isUndefined(this._isDSTShifted)) {\n return this._isDSTShifted;\n }\n\n var c = {},\n other;\n\n copyConfig(c, this);\n c = prepareConfig(c);\n\n if (c._a) {\n other = c._isUTC ? createUTC(c._a) : createLocal(c._a);\n this._isDSTShifted =\n this.isValid() && compareArrays(c._a, other.toArray()) > 0;\n } else {\n this._isDSTShifted = false;\n }\n\n return this._isDSTShifted;\n }\n\n function isLocal() {\n return this.isValid() ? !this._isUTC : false;\n }\n\n function isUtcOffset() {\n return this.isValid() ? this._isUTC : false;\n }\n\n function isUtc() {\n return this.isValid() ? this._isUTC && this._offset === 0 : false;\n }\n\n // ASP.NET json date format regex\n var aspNetRegex = /^(-|\\+)?(?:(\\d*)[. ])?(\\d+):(\\d+)(?::(\\d+)(\\.\\d*)?)?$/,\n // from http://docs.closure-library.googlecode.com/git/closure_goog_date_date.js.source.html\n // somewhat more in line with 4.4.3.2 2004 spec, but allows decimal anywhere\n // and further modified to allow for strings containing both week and day\n isoRegex =\n /^(-|\\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;\n\n function createDuration(input, key) {\n var duration = input,\n // matching against regexp is expensive, do it on demand\n match = null,\n sign,\n ret,\n diffRes;\n\n if (isDuration(input)) {\n duration = {\n ms: input._milliseconds,\n d: input._days,\n M: input._months,\n };\n } else if (isNumber(input) || !isNaN(+input)) {\n duration = {};\n if (key) {\n duration[key] = +input;\n } else {\n duration.milliseconds = +input;\n }\n } else if ((match = aspNetRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: 0,\n d: toInt(match[DATE]) * sign,\n h: toInt(match[HOUR]) * sign,\n m: toInt(match[MINUTE]) * sign,\n s: toInt(match[SECOND]) * sign,\n ms: toInt(absRound(match[MILLISECOND] * 1000)) * sign, // the millisecond decimal point is included in the match\n };\n } else if ((match = isoRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: parseIso(match[2], sign),\n M: parseIso(match[3], sign),\n w: parseIso(match[4], sign),\n d: parseIso(match[5], sign),\n h: parseIso(match[6], sign),\n m: parseIso(match[7], sign),\n s: parseIso(match[8], sign),\n };\n } else if (duration == null) {\n // checks for null or undefined\n duration = {};\n } else if (\n typeof duration === 'object' &&\n ('from' in duration || 'to' in duration)\n ) {\n diffRes = momentsDifference(\n createLocal(duration.from),\n createLocal(duration.to)\n );\n\n duration = {};\n duration.ms = diffRes.milliseconds;\n duration.M = diffRes.months;\n }\n\n ret = new Duration(duration);\n\n if (isDuration(input) && hasOwnProp(input, '_locale')) {\n ret._locale = input._locale;\n }\n\n if (isDuration(input) && hasOwnProp(input, '_isValid')) {\n ret._isValid = input._isValid;\n }\n\n return ret;\n }\n\n createDuration.fn = Duration.prototype;\n createDuration.invalid = createInvalid$1;\n\n function parseIso(inp, sign) {\n // We'd normally use ~~inp for this, but unfortunately it also\n // converts floats to ints.\n // inp may be undefined, so careful calling replace on it.\n var res = inp && parseFloat(inp.replace(',', '.'));\n // apply sign while we're at it\n return (isNaN(res) ? 0 : res) * sign;\n }\n\n function positiveMomentsDifference(base, other) {\n var res = {};\n\n res.months =\n other.month() - base.month() + (other.year() - base.year()) * 12;\n if (base.clone().add(res.months, 'M').isAfter(other)) {\n --res.months;\n }\n\n res.milliseconds = +other - +base.clone().add(res.months, 'M');\n\n return res;\n }\n\n function momentsDifference(base, other) {\n var res;\n if (!(base.isValid() && other.isValid())) {\n return { milliseconds: 0, months: 0 };\n }\n\n other = cloneWithOffset(other, base);\n if (base.isBefore(other)) {\n res = positiveMomentsDifference(base, other);\n } else {\n res = positiveMomentsDifference(other, base);\n res.milliseconds = -res.milliseconds;\n res.months = -res.months;\n }\n\n return res;\n }\n\n // TODO: remove 'name' arg after deprecation is removed\n function createAdder(direction, name) {\n return function (val, period) {\n var dur, tmp;\n //invert the arguments, but complain about it\n if (period !== null && !isNaN(+period)) {\n deprecateSimple(\n name,\n 'moment().' +\n name +\n '(period, number) is deprecated. Please use moment().' +\n name +\n '(number, period). ' +\n 'See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info.'\n );\n tmp = val;\n val = period;\n period = tmp;\n }\n\n dur = createDuration(val, period);\n addSubtract(this, dur, direction);\n return this;\n };\n }\n\n function addSubtract(mom, duration, isAdding, updateOffset) {\n var milliseconds = duration._milliseconds,\n days = absRound(duration._days),\n months = absRound(duration._months);\n\n if (!mom.isValid()) {\n // No op\n return;\n }\n\n updateOffset = updateOffset == null ? true : updateOffset;\n\n if (months) {\n setMonth(mom, get(mom, 'Month') + months * isAdding);\n }\n if (days) {\n set$1(mom, 'Date', get(mom, 'Date') + days * isAdding);\n }\n if (milliseconds) {\n mom._d.setTime(mom._d.valueOf() + milliseconds * isAdding);\n }\n if (updateOffset) {\n hooks.updateOffset(mom, days || months);\n }\n }\n\n var add = createAdder(1, 'add'),\n subtract = createAdder(-1, 'subtract');\n\n function isString(input) {\n return typeof input === 'string' || input instanceof String;\n }\n\n // type MomentInput = Moment | Date | string | number | (number | string)[] | MomentInputObject | void; // null | undefined\n function isMomentInput(input) {\n return (\n isMoment(input) ||\n isDate(input) ||\n isString(input) ||\n isNumber(input) ||\n isNumberOrStringArray(input) ||\n isMomentInputObject(input) ||\n input === null ||\n input === undefined\n );\n }\n\n function isMomentInputObject(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'years',\n 'year',\n 'y',\n 'months',\n 'month',\n 'M',\n 'days',\n 'day',\n 'd',\n 'dates',\n 'date',\n 'D',\n 'hours',\n 'hour',\n 'h',\n 'minutes',\n 'minute',\n 'm',\n 'seconds',\n 'second',\n 's',\n 'milliseconds',\n 'millisecond',\n 'ms',\n ],\n i,\n property,\n propertyLen = properties.length;\n\n for (i = 0; i < propertyLen; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n }\n\n function isNumberOrStringArray(input) {\n var arrayTest = isArray(input),\n dataTypeTest = false;\n if (arrayTest) {\n dataTypeTest =\n input.filter(function (item) {\n return !isNumber(item) && isString(input);\n }).length === 0;\n }\n return arrayTest && dataTypeTest;\n }\n\n function isCalendarSpec(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'sameDay',\n 'nextDay',\n 'lastDay',\n 'nextWeek',\n 'lastWeek',\n 'sameElse',\n ],\n i,\n property;\n\n for (i = 0; i < properties.length; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n }\n\n function getCalendarFormat(myMoment, now) {\n var diff = myMoment.diff(now, 'days', true);\n return diff < -6\n ? 'sameElse'\n : diff < -1\n ? 'lastWeek'\n : diff < 0\n ? 'lastDay'\n : diff < 1\n ? 'sameDay'\n : diff < 2\n ? 'nextDay'\n : diff < 7\n ? 'nextWeek'\n : 'sameElse';\n }\n\n function calendar$1(time, formats) {\n // Support for single parameter, formats only overload to the calendar function\n if (arguments.length === 1) {\n if (!arguments[0]) {\n time = undefined;\n formats = undefined;\n } else if (isMomentInput(arguments[0])) {\n time = arguments[0];\n formats = undefined;\n } else if (isCalendarSpec(arguments[0])) {\n formats = arguments[0];\n time = undefined;\n }\n }\n // We want to compare the start of today, vs this.\n // Getting start-of-today depends on whether we're local/utc/offset or not.\n var now = time || createLocal(),\n sod = cloneWithOffset(now, this).startOf('day'),\n format = hooks.calendarFormat(this, sod) || 'sameElse',\n output =\n formats &&\n (isFunction(formats[format])\n ? formats[format].call(this, now)\n : formats[format]);\n\n return this.format(\n output || this.localeData().calendar(format, this, createLocal(now))\n );\n }\n\n function clone() {\n return new Moment(this);\n }\n\n function isAfter(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() > localInput.valueOf();\n } else {\n return localInput.valueOf() < this.clone().startOf(units).valueOf();\n }\n }\n\n function isBefore(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() < localInput.valueOf();\n } else {\n return this.clone().endOf(units).valueOf() < localInput.valueOf();\n }\n }\n\n function isBetween(from, to, units, inclusivity) {\n var localFrom = isMoment(from) ? from : createLocal(from),\n localTo = isMoment(to) ? to : createLocal(to);\n if (!(this.isValid() && localFrom.isValid() && localTo.isValid())) {\n return false;\n }\n inclusivity = inclusivity || '()';\n return (\n (inclusivity[0] === '('\n ? this.isAfter(localFrom, units)\n : !this.isBefore(localFrom, units)) &&\n (inclusivity[1] === ')'\n ? this.isBefore(localTo, units)\n : !this.isAfter(localTo, units))\n );\n }\n\n function isSame(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input),\n inputMs;\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() === localInput.valueOf();\n } else {\n inputMs = localInput.valueOf();\n return (\n this.clone().startOf(units).valueOf() <= inputMs &&\n inputMs <= this.clone().endOf(units).valueOf()\n );\n }\n }\n\n function isSameOrAfter(input, units) {\n return this.isSame(input, units) || this.isAfter(input, units);\n }\n\n function isSameOrBefore(input, units) {\n return this.isSame(input, units) || this.isBefore(input, units);\n }\n\n function diff(input, units, asFloat) {\n var that, zoneDelta, output;\n\n if (!this.isValid()) {\n return NaN;\n }\n\n that = cloneWithOffset(input, this);\n\n if (!that.isValid()) {\n return NaN;\n }\n\n zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4;\n\n units = normalizeUnits(units);\n\n switch (units) {\n case 'year':\n output = monthDiff(this, that) / 12;\n break;\n case 'month':\n output = monthDiff(this, that);\n break;\n case 'quarter':\n output = monthDiff(this, that) / 3;\n break;\n case 'second':\n output = (this - that) / 1e3;\n break; // 1000\n case 'minute':\n output = (this - that) / 6e4;\n break; // 1000 * 60\n case 'hour':\n output = (this - that) / 36e5;\n break; // 1000 * 60 * 60\n case 'day':\n output = (this - that - zoneDelta) / 864e5;\n break; // 1000 * 60 * 60 * 24, negate dst\n case 'week':\n output = (this - that - zoneDelta) / 6048e5;\n break; // 1000 * 60 * 60 * 24 * 7, negate dst\n default:\n output = this - that;\n }\n\n return asFloat ? output : absFloor(output);\n }\n\n function monthDiff(a, b) {\n if (a.date() < b.date()) {\n // end-of-month calculations work correct when the start month has more\n // days than the end month.\n return -monthDiff(b, a);\n }\n // difference in months\n var wholeMonthDiff = (b.year() - a.year()) * 12 + (b.month() - a.month()),\n // b is in (anchor - 1 month, anchor + 1 month)\n anchor = a.clone().add(wholeMonthDiff, 'months'),\n anchor2,\n adjust;\n\n if (b - anchor < 0) {\n anchor2 = a.clone().add(wholeMonthDiff - 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor - anchor2);\n } else {\n anchor2 = a.clone().add(wholeMonthDiff + 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor2 - anchor);\n }\n\n //check for negative zero, return zero if negative zero\n return -(wholeMonthDiff + adjust) || 0;\n }\n\n hooks.defaultFormat = 'YYYY-MM-DDTHH:mm:ssZ';\n hooks.defaultFormatUtc = 'YYYY-MM-DDTHH:mm:ss[Z]';\n\n function toString() {\n return this.clone().locale('en').format('ddd MMM DD YYYY HH:mm:ss [GMT]ZZ');\n }\n\n function toISOString(keepOffset) {\n if (!this.isValid()) {\n return null;\n }\n var utc = keepOffset !== true,\n m = utc ? this.clone().utc() : this;\n if (m.year() < 0 || m.year() > 9999) {\n return formatMoment(\n m,\n utc\n ? 'YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]'\n : 'YYYYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n if (isFunction(Date.prototype.toISOString)) {\n // native implementation is ~50x faster, use it when we can\n if (utc) {\n return this.toDate().toISOString();\n } else {\n return new Date(this.valueOf() + this.utcOffset() * 60 * 1000)\n .toISOString()\n .replace('Z', formatMoment(m, 'Z'));\n }\n }\n return formatMoment(\n m,\n utc ? 'YYYY-MM-DD[T]HH:mm:ss.SSS[Z]' : 'YYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n\n /**\n * Return a human readable representation of a moment that can\n * also be evaluated to get a new moment which is the same\n *\n * @link https://nodejs.org/dist/latest/docs/api/util.html#util_custom_inspect_function_on_objects\n */\n function inspect() {\n if (!this.isValid()) {\n return 'moment.invalid(/* ' + this._i + ' */)';\n }\n var func = 'moment',\n zone = '',\n prefix,\n year,\n datetime,\n suffix;\n if (!this.isLocal()) {\n func = this.utcOffset() === 0 ? 'moment.utc' : 'moment.parseZone';\n zone = 'Z';\n }\n prefix = '[' + func + '(\"]';\n year = 0 <= this.year() && this.year() <= 9999 ? 'YYYY' : 'YYYYYY';\n datetime = '-MM-DD[T]HH:mm:ss.SSS';\n suffix = zone + '[\")]';\n\n return this.format(prefix + year + datetime + suffix);\n }\n\n function format(inputString) {\n if (!inputString) {\n inputString = this.isUtc()\n ? hooks.defaultFormatUtc\n : hooks.defaultFormat;\n }\n var output = formatMoment(this, inputString);\n return this.localeData().postformat(output);\n }\n\n function from(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ to: this, from: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n }\n\n function fromNow(withoutSuffix) {\n return this.from(createLocal(), withoutSuffix);\n }\n\n function to(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ from: this, to: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n }\n\n function toNow(withoutSuffix) {\n return this.to(createLocal(), withoutSuffix);\n }\n\n // If passed a locale key, it will set the locale for this\n // instance. Otherwise, it will return the locale configuration\n // variables for this instance.\n function locale(key) {\n var newLocaleData;\n\n if (key === undefined) {\n return this._locale._abbr;\n } else {\n newLocaleData = getLocale(key);\n if (newLocaleData != null) {\n this._locale = newLocaleData;\n }\n return this;\n }\n }\n\n var lang = deprecate(\n 'moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.',\n function (key) {\n if (key === undefined) {\n return this.localeData();\n } else {\n return this.locale(key);\n }\n }\n );\n\n function localeData() {\n return this._locale;\n }\n\n var MS_PER_SECOND = 1000,\n MS_PER_MINUTE = 60 * MS_PER_SECOND,\n MS_PER_HOUR = 60 * MS_PER_MINUTE,\n MS_PER_400_YEARS = (365 * 400 + 97) * 24 * MS_PER_HOUR;\n\n // actual modulo - handles negative numbers (for dates before 1970):\n function mod$1(dividend, divisor) {\n return ((dividend % divisor) + divisor) % divisor;\n }\n\n function localStartOfDate(y, m, d) {\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return new Date(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return new Date(y, m, d).valueOf();\n }\n }\n\n function utcStartOfDate(y, m, d) {\n // Date.UTC remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return Date.UTC(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return Date.UTC(y, m, d);\n }\n }\n\n function startOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year(), 0, 1);\n break;\n case 'quarter':\n time = startOfDate(\n this.year(),\n this.month() - (this.month() % 3),\n 1\n );\n break;\n case 'month':\n time = startOfDate(this.year(), this.month(), 1);\n break;\n case 'week':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday()\n );\n break;\n case 'isoWeek':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1)\n );\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date());\n break;\n case 'hour':\n time = this._d.valueOf();\n time -= mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n );\n break;\n case 'minute':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_MINUTE);\n break;\n case 'second':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_SECOND);\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n }\n\n function endOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year() + 1, 0, 1) - 1;\n break;\n case 'quarter':\n time =\n startOfDate(\n this.year(),\n this.month() - (this.month() % 3) + 3,\n 1\n ) - 1;\n break;\n case 'month':\n time = startOfDate(this.year(), this.month() + 1, 1) - 1;\n break;\n case 'week':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday() + 7\n ) - 1;\n break;\n case 'isoWeek':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1) + 7\n ) - 1;\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date() + 1) - 1;\n break;\n case 'hour':\n time = this._d.valueOf();\n time +=\n MS_PER_HOUR -\n mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n ) -\n 1;\n break;\n case 'minute':\n time = this._d.valueOf();\n time += MS_PER_MINUTE - mod$1(time, MS_PER_MINUTE) - 1;\n break;\n case 'second':\n time = this._d.valueOf();\n time += MS_PER_SECOND - mod$1(time, MS_PER_SECOND) - 1;\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n }\n\n function valueOf() {\n return this._d.valueOf() - (this._offset || 0) * 60000;\n }\n\n function unix() {\n return Math.floor(this.valueOf() / 1000);\n }\n\n function toDate() {\n return new Date(this.valueOf());\n }\n\n function toArray() {\n var m = this;\n return [\n m.year(),\n m.month(),\n m.date(),\n m.hour(),\n m.minute(),\n m.second(),\n m.millisecond(),\n ];\n }\n\n function toObject() {\n var m = this;\n return {\n years: m.year(),\n months: m.month(),\n date: m.date(),\n hours: m.hours(),\n minutes: m.minutes(),\n seconds: m.seconds(),\n milliseconds: m.milliseconds(),\n };\n }\n\n function toJSON() {\n // new Date(NaN).toJSON() === null\n return this.isValid() ? this.toISOString() : null;\n }\n\n function isValid$2() {\n return isValid(this);\n }\n\n function parsingFlags() {\n return extend({}, getParsingFlags(this));\n }\n\n function invalidAt() {\n return getParsingFlags(this).overflow;\n }\n\n function creationData() {\n return {\n input: this._i,\n format: this._f,\n locale: this._locale,\n isUTC: this._isUTC,\n strict: this._strict,\n };\n }\n\n addFormatToken('N', 0, 0, 'eraAbbr');\n addFormatToken('NN', 0, 0, 'eraAbbr');\n addFormatToken('NNN', 0, 0, 'eraAbbr');\n addFormatToken('NNNN', 0, 0, 'eraName');\n addFormatToken('NNNNN', 0, 0, 'eraNarrow');\n\n addFormatToken('y', ['y', 1], 'yo', 'eraYear');\n addFormatToken('y', ['yy', 2], 0, 'eraYear');\n addFormatToken('y', ['yyy', 3], 0, 'eraYear');\n addFormatToken('y', ['yyyy', 4], 0, 'eraYear');\n\n addRegexToken('N', matchEraAbbr);\n addRegexToken('NN', matchEraAbbr);\n addRegexToken('NNN', matchEraAbbr);\n addRegexToken('NNNN', matchEraName);\n addRegexToken('NNNNN', matchEraNarrow);\n\n addParseToken(\n ['N', 'NN', 'NNN', 'NNNN', 'NNNNN'],\n function (input, array, config, token) {\n var era = config._locale.erasParse(input, token, config._strict);\n if (era) {\n getParsingFlags(config).era = era;\n } else {\n getParsingFlags(config).invalidEra = input;\n }\n }\n );\n\n addRegexToken('y', matchUnsigned);\n addRegexToken('yy', matchUnsigned);\n addRegexToken('yyy', matchUnsigned);\n addRegexToken('yyyy', matchUnsigned);\n addRegexToken('yo', matchEraYearOrdinal);\n\n addParseToken(['y', 'yy', 'yyy', 'yyyy'], YEAR);\n addParseToken(['yo'], function (input, array, config, token) {\n var match;\n if (config._locale._eraYearOrdinalRegex) {\n match = input.match(config._locale._eraYearOrdinalRegex);\n }\n\n if (config._locale.eraYearOrdinalParse) {\n array[YEAR] = config._locale.eraYearOrdinalParse(input, match);\n } else {\n array[YEAR] = parseInt(input, 10);\n }\n });\n\n function localeEras(m, format) {\n var i,\n l,\n date,\n eras = this._eras || getLocale('en')._eras;\n for (i = 0, l = eras.length; i < l; ++i) {\n switch (typeof eras[i].since) {\n case 'string':\n // truncate time\n date = hooks(eras[i].since).startOf('day');\n eras[i].since = date.valueOf();\n break;\n }\n\n switch (typeof eras[i].until) {\n case 'undefined':\n eras[i].until = +Infinity;\n break;\n case 'string':\n // truncate time\n date = hooks(eras[i].until).startOf('day').valueOf();\n eras[i].until = date.valueOf();\n break;\n }\n }\n return eras;\n }\n\n function localeErasParse(eraName, format, strict) {\n var i,\n l,\n eras = this.eras(),\n name,\n abbr,\n narrow;\n eraName = eraName.toUpperCase();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n name = eras[i].name.toUpperCase();\n abbr = eras[i].abbr.toUpperCase();\n narrow = eras[i].narrow.toUpperCase();\n\n if (strict) {\n switch (format) {\n case 'N':\n case 'NN':\n case 'NNN':\n if (abbr === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNN':\n if (name === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNNN':\n if (narrow === eraName) {\n return eras[i];\n }\n break;\n }\n } else if ([name, abbr, narrow].indexOf(eraName) >= 0) {\n return eras[i];\n }\n }\n }\n\n function localeErasConvertYear(era, year) {\n var dir = era.since <= era.until ? +1 : -1;\n if (year === undefined) {\n return hooks(era.since).year();\n } else {\n return hooks(era.since).year() + (year - era.offset) * dir;\n }\n }\n\n function getEraName() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].name;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].name;\n }\n }\n\n return '';\n }\n\n function getEraNarrow() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].narrow;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].narrow;\n }\n }\n\n return '';\n }\n\n function getEraAbbr() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].abbr;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].abbr;\n }\n }\n\n return '';\n }\n\n function getEraYear() {\n var i,\n l,\n dir,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n dir = eras[i].since <= eras[i].until ? +1 : -1;\n\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (\n (eras[i].since <= val && val <= eras[i].until) ||\n (eras[i].until <= val && val <= eras[i].since)\n ) {\n return (\n (this.year() - hooks(eras[i].since).year()) * dir +\n eras[i].offset\n );\n }\n }\n\n return this.year();\n }\n\n function erasNameRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNameRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNameRegex : this._erasRegex;\n }\n\n function erasAbbrRegex(isStrict) {\n if (!hasOwnProp(this, '_erasAbbrRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasAbbrRegex : this._erasRegex;\n }\n\n function erasNarrowRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNarrowRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNarrowRegex : this._erasRegex;\n }\n\n function matchEraAbbr(isStrict, locale) {\n return locale.erasAbbrRegex(isStrict);\n }\n\n function matchEraName(isStrict, locale) {\n return locale.erasNameRegex(isStrict);\n }\n\n function matchEraNarrow(isStrict, locale) {\n return locale.erasNarrowRegex(isStrict);\n }\n\n function matchEraYearOrdinal(isStrict, locale) {\n return locale._eraYearOrdinalRegex || matchUnsigned;\n }\n\n function computeErasParse() {\n var abbrPieces = [],\n namePieces = [],\n narrowPieces = [],\n mixedPieces = [],\n i,\n l,\n erasName,\n erasAbbr,\n erasNarrow,\n eras = this.eras();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n erasName = regexEscape(eras[i].name);\n erasAbbr = regexEscape(eras[i].abbr);\n erasNarrow = regexEscape(eras[i].narrow);\n\n namePieces.push(erasName);\n abbrPieces.push(erasAbbr);\n narrowPieces.push(erasNarrow);\n mixedPieces.push(erasName);\n mixedPieces.push(erasAbbr);\n mixedPieces.push(erasNarrow);\n }\n\n this._erasRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._erasNameRegex = new RegExp('^(' + namePieces.join('|') + ')', 'i');\n this._erasAbbrRegex = new RegExp('^(' + abbrPieces.join('|') + ')', 'i');\n this._erasNarrowRegex = new RegExp(\n '^(' + narrowPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n addFormatToken(0, ['gg', 2], 0, function () {\n return this.weekYear() % 100;\n });\n\n addFormatToken(0, ['GG', 2], 0, function () {\n return this.isoWeekYear() % 100;\n });\n\n function addWeekYearFormatToken(token, getter) {\n addFormatToken(0, [token, token.length], 0, getter);\n }\n\n addWeekYearFormatToken('gggg', 'weekYear');\n addWeekYearFormatToken('ggggg', 'weekYear');\n addWeekYearFormatToken('GGGG', 'isoWeekYear');\n addWeekYearFormatToken('GGGGG', 'isoWeekYear');\n\n // ALIASES\n\n // PARSING\n\n addRegexToken('G', matchSigned);\n addRegexToken('g', matchSigned);\n addRegexToken('GG', match1to2, match2);\n addRegexToken('gg', match1to2, match2);\n addRegexToken('GGGG', match1to4, match4);\n addRegexToken('gggg', match1to4, match4);\n addRegexToken('GGGGG', match1to6, match6);\n addRegexToken('ggggg', match1to6, match6);\n\n addWeekParseToken(\n ['gggg', 'ggggg', 'GGGG', 'GGGGG'],\n function (input, week, config, token) {\n week[token.substr(0, 2)] = toInt(input);\n }\n );\n\n addWeekParseToken(['gg', 'GG'], function (input, week, config, token) {\n week[token] = hooks.parseTwoDigitYear(input);\n });\n\n // MOMENTS\n\n function getSetWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.week(),\n this.weekday() + this.localeData()._week.dow,\n this.localeData()._week.dow,\n this.localeData()._week.doy\n );\n }\n\n function getSetISOWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.isoWeek(),\n this.isoWeekday(),\n 1,\n 4\n );\n }\n\n function getISOWeeksInYear() {\n return weeksInYear(this.year(), 1, 4);\n }\n\n function getISOWeeksInISOWeekYear() {\n return weeksInYear(this.isoWeekYear(), 1, 4);\n }\n\n function getWeeksInYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy);\n }\n\n function getWeeksInWeekYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.weekYear(), weekInfo.dow, weekInfo.doy);\n }\n\n function getSetWeekYearHelper(input, week, weekday, dow, doy) {\n var weeksTarget;\n if (input == null) {\n return weekOfYear(this, dow, doy).year;\n } else {\n weeksTarget = weeksInYear(input, dow, doy);\n if (week > weeksTarget) {\n week = weeksTarget;\n }\n return setWeekAll.call(this, input, week, weekday, dow, doy);\n }\n }\n\n function setWeekAll(weekYear, week, weekday, dow, doy) {\n var dayOfYearData = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy),\n date = createUTCDate(dayOfYearData.year, 0, dayOfYearData.dayOfYear);\n\n this.year(date.getUTCFullYear());\n this.month(date.getUTCMonth());\n this.date(date.getUTCDate());\n return this;\n }\n\n // FORMATTING\n\n addFormatToken('Q', 0, 'Qo', 'quarter');\n\n // PARSING\n\n addRegexToken('Q', match1);\n addParseToken('Q', function (input, array) {\n array[MONTH] = (toInt(input) - 1) * 3;\n });\n\n // MOMENTS\n\n function getSetQuarter(input) {\n return input == null\n ? Math.ceil((this.month() + 1) / 3)\n : this.month((input - 1) * 3 + (this.month() % 3));\n }\n\n // FORMATTING\n\n addFormatToken('D', ['DD', 2], 'Do', 'date');\n\n // PARSING\n\n addRegexToken('D', match1to2, match1to2NoLeadingZero);\n addRegexToken('DD', match1to2, match2);\n addRegexToken('Do', function (isStrict, locale) {\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n return isStrict\n ? locale._dayOfMonthOrdinalParse || locale._ordinalParse\n : locale._dayOfMonthOrdinalParseLenient;\n });\n\n addParseToken(['D', 'DD'], DATE);\n addParseToken('Do', function (input, array) {\n array[DATE] = toInt(input.match(match1to2)[0]);\n });\n\n // MOMENTS\n\n var getSetDayOfMonth = makeGetSet('Date', true);\n\n // FORMATTING\n\n addFormatToken('DDD', ['DDDD', 3], 'DDDo', 'dayOfYear');\n\n // PARSING\n\n addRegexToken('DDD', match1to3);\n addRegexToken('DDDD', match3);\n addParseToken(['DDD', 'DDDD'], function (input, array, config) {\n config._dayOfYear = toInt(input);\n });\n\n // HELPERS\n\n // MOMENTS\n\n function getSetDayOfYear(input) {\n var dayOfYear =\n Math.round(\n (this.clone().startOf('day') - this.clone().startOf('year')) / 864e5\n ) + 1;\n return input == null ? dayOfYear : this.add(input - dayOfYear, 'd');\n }\n\n // FORMATTING\n\n addFormatToken('m', ['mm', 2], 0, 'minute');\n\n // PARSING\n\n addRegexToken('m', match1to2, match1to2HasZero);\n addRegexToken('mm', match1to2, match2);\n addParseToken(['m', 'mm'], MINUTE);\n\n // MOMENTS\n\n var getSetMinute = makeGetSet('Minutes', false);\n\n // FORMATTING\n\n addFormatToken('s', ['ss', 2], 0, 'second');\n\n // PARSING\n\n addRegexToken('s', match1to2, match1to2HasZero);\n addRegexToken('ss', match1to2, match2);\n addParseToken(['s', 'ss'], SECOND);\n\n // MOMENTS\n\n var getSetSecond = makeGetSet('Seconds', false);\n\n // FORMATTING\n\n addFormatToken('S', 0, 0, function () {\n return ~~(this.millisecond() / 100);\n });\n\n addFormatToken(0, ['SS', 2], 0, function () {\n return ~~(this.millisecond() / 10);\n });\n\n addFormatToken(0, ['SSS', 3], 0, 'millisecond');\n addFormatToken(0, ['SSSS', 4], 0, function () {\n return this.millisecond() * 10;\n });\n addFormatToken(0, ['SSSSS', 5], 0, function () {\n return this.millisecond() * 100;\n });\n addFormatToken(0, ['SSSSSS', 6], 0, function () {\n return this.millisecond() * 1000;\n });\n addFormatToken(0, ['SSSSSSS', 7], 0, function () {\n return this.millisecond() * 10000;\n });\n addFormatToken(0, ['SSSSSSSS', 8], 0, function () {\n return this.millisecond() * 100000;\n });\n addFormatToken(0, ['SSSSSSSSS', 9], 0, function () {\n return this.millisecond() * 1000000;\n });\n\n // PARSING\n\n addRegexToken('S', match1to3, match1);\n addRegexToken('SS', match1to3, match2);\n addRegexToken('SSS', match1to3, match3);\n\n var token, getSetMillisecond;\n for (token = 'SSSS'; token.length <= 9; token += 'S') {\n addRegexToken(token, matchUnsigned);\n }\n\n function parseMs(input, array) {\n array[MILLISECOND] = toInt(('0.' + input) * 1000);\n }\n\n for (token = 'S'; token.length <= 9; token += 'S') {\n addParseToken(token, parseMs);\n }\n\n getSetMillisecond = makeGetSet('Milliseconds', false);\n\n // FORMATTING\n\n addFormatToken('z', 0, 0, 'zoneAbbr');\n addFormatToken('zz', 0, 0, 'zoneName');\n\n // MOMENTS\n\n function getZoneAbbr() {\n return this._isUTC ? 'UTC' : '';\n }\n\n function getZoneName() {\n return this._isUTC ? 'Coordinated Universal Time' : '';\n }\n\n var proto = Moment.prototype;\n\n proto.add = add;\n proto.calendar = calendar$1;\n proto.clone = clone;\n proto.diff = diff;\n proto.endOf = endOf;\n proto.format = format;\n proto.from = from;\n proto.fromNow = fromNow;\n proto.to = to;\n proto.toNow = toNow;\n proto.get = stringGet;\n proto.invalidAt = invalidAt;\n proto.isAfter = isAfter;\n proto.isBefore = isBefore;\n proto.isBetween = isBetween;\n proto.isSame = isSame;\n proto.isSameOrAfter = isSameOrAfter;\n proto.isSameOrBefore = isSameOrBefore;\n proto.isValid = isValid$2;\n proto.lang = lang;\n proto.locale = locale;\n proto.localeData = localeData;\n proto.max = prototypeMax;\n proto.min = prototypeMin;\n proto.parsingFlags = parsingFlags;\n proto.set = stringSet;\n proto.startOf = startOf;\n proto.subtract = subtract;\n proto.toArray = toArray;\n proto.toObject = toObject;\n proto.toDate = toDate;\n proto.toISOString = toISOString;\n proto.inspect = inspect;\n if (typeof Symbol !== 'undefined' && Symbol.for != null) {\n proto[Symbol.for('nodejs.util.inspect.custom')] = function () {\n return 'Moment<' + this.format() + '>';\n };\n }\n proto.toJSON = toJSON;\n proto.toString = toString;\n proto.unix = unix;\n proto.valueOf = valueOf;\n proto.creationData = creationData;\n proto.eraName = getEraName;\n proto.eraNarrow = getEraNarrow;\n proto.eraAbbr = getEraAbbr;\n proto.eraYear = getEraYear;\n proto.year = getSetYear;\n proto.isLeapYear = getIsLeapYear;\n proto.weekYear = getSetWeekYear;\n proto.isoWeekYear = getSetISOWeekYear;\n proto.quarter = proto.quarters = getSetQuarter;\n proto.month = getSetMonth;\n proto.daysInMonth = getDaysInMonth;\n proto.week = proto.weeks = getSetWeek;\n proto.isoWeek = proto.isoWeeks = getSetISOWeek;\n proto.weeksInYear = getWeeksInYear;\n proto.weeksInWeekYear = getWeeksInWeekYear;\n proto.isoWeeksInYear = getISOWeeksInYear;\n proto.isoWeeksInISOWeekYear = getISOWeeksInISOWeekYear;\n proto.date = getSetDayOfMonth;\n proto.day = proto.days = getSetDayOfWeek;\n proto.weekday = getSetLocaleDayOfWeek;\n proto.isoWeekday = getSetISODayOfWeek;\n proto.dayOfYear = getSetDayOfYear;\n proto.hour = proto.hours = getSetHour;\n proto.minute = proto.minutes = getSetMinute;\n proto.second = proto.seconds = getSetSecond;\n proto.millisecond = proto.milliseconds = getSetMillisecond;\n proto.utcOffset = getSetOffset;\n proto.utc = setOffsetToUTC;\n proto.local = setOffsetToLocal;\n proto.parseZone = setOffsetToParsedOffset;\n proto.hasAlignedHourOffset = hasAlignedHourOffset;\n proto.isDST = isDaylightSavingTime;\n proto.isLocal = isLocal;\n proto.isUtcOffset = isUtcOffset;\n proto.isUtc = isUtc;\n proto.isUTC = isUtc;\n proto.zoneAbbr = getZoneAbbr;\n proto.zoneName = getZoneName;\n proto.dates = deprecate(\n 'dates accessor is deprecated. Use date instead.',\n getSetDayOfMonth\n );\n proto.months = deprecate(\n 'months accessor is deprecated. Use month instead',\n getSetMonth\n );\n proto.years = deprecate(\n 'years accessor is deprecated. Use year instead',\n getSetYear\n );\n proto.zone = deprecate(\n 'moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/',\n getSetZone\n );\n proto.isDSTShifted = deprecate(\n 'isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information',\n isDaylightSavingTimeShifted\n );\n\n function createUnix(input) {\n return createLocal(input * 1000);\n }\n\n function createInZone() {\n return createLocal.apply(null, arguments).parseZone();\n }\n\n function preParsePostFormat(string) {\n return string;\n }\n\n var proto$1 = Locale.prototype;\n\n proto$1.calendar = calendar;\n proto$1.longDateFormat = longDateFormat;\n proto$1.invalidDate = invalidDate;\n proto$1.ordinal = ordinal;\n proto$1.preparse = preParsePostFormat;\n proto$1.postformat = preParsePostFormat;\n proto$1.relativeTime = relativeTime;\n proto$1.pastFuture = pastFuture;\n proto$1.set = set;\n proto$1.eras = localeEras;\n proto$1.erasParse = localeErasParse;\n proto$1.erasConvertYear = localeErasConvertYear;\n proto$1.erasAbbrRegex = erasAbbrRegex;\n proto$1.erasNameRegex = erasNameRegex;\n proto$1.erasNarrowRegex = erasNarrowRegex;\n\n proto$1.months = localeMonths;\n proto$1.monthsShort = localeMonthsShort;\n proto$1.monthsParse = localeMonthsParse;\n proto$1.monthsRegex = monthsRegex;\n proto$1.monthsShortRegex = monthsShortRegex;\n proto$1.week = localeWeek;\n proto$1.firstDayOfYear = localeFirstDayOfYear;\n proto$1.firstDayOfWeek = localeFirstDayOfWeek;\n\n proto$1.weekdays = localeWeekdays;\n proto$1.weekdaysMin = localeWeekdaysMin;\n proto$1.weekdaysShort = localeWeekdaysShort;\n proto$1.weekdaysParse = localeWeekdaysParse;\n\n proto$1.weekdaysRegex = weekdaysRegex;\n proto$1.weekdaysShortRegex = weekdaysShortRegex;\n proto$1.weekdaysMinRegex = weekdaysMinRegex;\n\n proto$1.isPM = localeIsPM;\n proto$1.meridiem = localeMeridiem;\n\n function get$1(format, index, field, setter) {\n var locale = getLocale(),\n utc = createUTC().set(setter, index);\n return locale[field](utc, format);\n }\n\n function listMonthsImpl(format, index, field) {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n\n if (index != null) {\n return get$1(format, index, field, 'month');\n }\n\n var i,\n out = [];\n for (i = 0; i < 12; i++) {\n out[i] = get$1(format, i, field, 'month');\n }\n return out;\n }\n\n // ()\n // (5)\n // (fmt, 5)\n // (fmt)\n // (true)\n // (true, 5)\n // (true, fmt, 5)\n // (true, fmt)\n function listWeekdaysImpl(localeSorted, format, index, field) {\n if (typeof localeSorted === 'boolean') {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n } else {\n format = localeSorted;\n index = format;\n localeSorted = false;\n\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n }\n\n var locale = getLocale(),\n shift = localeSorted ? locale._week.dow : 0,\n i,\n out = [];\n\n if (index != null) {\n return get$1(format, (index + shift) % 7, field, 'day');\n }\n\n for (i = 0; i < 7; i++) {\n out[i] = get$1(format, (i + shift) % 7, field, 'day');\n }\n return out;\n }\n\n function listMonths(format, index) {\n return listMonthsImpl(format, index, 'months');\n }\n\n function listMonthsShort(format, index) {\n return listMonthsImpl(format, index, 'monthsShort');\n }\n\n function listWeekdays(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdays');\n }\n\n function listWeekdaysShort(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysShort');\n }\n\n function listWeekdaysMin(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysMin');\n }\n\n getSetGlobalLocale('en', {\n eras: [\n {\n since: '0001-01-01',\n until: +Infinity,\n offset: 1,\n name: 'Anno Domini',\n narrow: 'AD',\n abbr: 'AD',\n },\n {\n since: '0000-12-31',\n until: -Infinity,\n offset: 1,\n name: 'Before Christ',\n narrow: 'BC',\n abbr: 'BC',\n },\n ],\n dayOfMonthOrdinalParse: /\\d{1,2}(th|st|nd|rd)/,\n ordinal: function (number) {\n var b = number % 10,\n output =\n toInt((number % 100) / 10) === 1\n ? 'th'\n : b === 1\n ? 'st'\n : b === 2\n ? 'nd'\n : b === 3\n ? 'rd'\n : 'th';\n return number + output;\n },\n });\n\n // Side effect imports\n\n hooks.lang = deprecate(\n 'moment.lang is deprecated. Use moment.locale instead.',\n getSetGlobalLocale\n );\n hooks.langData = deprecate(\n 'moment.langData is deprecated. Use moment.localeData instead.',\n getLocale\n );\n\n var mathAbs = Math.abs;\n\n function abs() {\n var data = this._data;\n\n this._milliseconds = mathAbs(this._milliseconds);\n this._days = mathAbs(this._days);\n this._months = mathAbs(this._months);\n\n data.milliseconds = mathAbs(data.milliseconds);\n data.seconds = mathAbs(data.seconds);\n data.minutes = mathAbs(data.minutes);\n data.hours = mathAbs(data.hours);\n data.months = mathAbs(data.months);\n data.years = mathAbs(data.years);\n\n return this;\n }\n\n function addSubtract$1(duration, input, value, direction) {\n var other = createDuration(input, value);\n\n duration._milliseconds += direction * other._milliseconds;\n duration._days += direction * other._days;\n duration._months += direction * other._months;\n\n return duration._bubble();\n }\n\n // supports only 2.0-style add(1, 's') or add(duration)\n function add$1(input, value) {\n return addSubtract$1(this, input, value, 1);\n }\n\n // supports only 2.0-style subtract(1, 's') or subtract(duration)\n function subtract$1(input, value) {\n return addSubtract$1(this, input, value, -1);\n }\n\n function absCeil(number) {\n if (number < 0) {\n return Math.floor(number);\n } else {\n return Math.ceil(number);\n }\n }\n\n function bubble() {\n var milliseconds = this._milliseconds,\n days = this._days,\n months = this._months,\n data = this._data,\n seconds,\n minutes,\n hours,\n years,\n monthsFromDays;\n\n // if we have a mix of positive and negative values, bubble down first\n // check: https://github.com/moment/moment/issues/2166\n if (\n !(\n (milliseconds >= 0 && days >= 0 && months >= 0) ||\n (milliseconds <= 0 && days <= 0 && months <= 0)\n )\n ) {\n milliseconds += absCeil(monthsToDays(months) + days) * 864e5;\n days = 0;\n months = 0;\n }\n\n // The following code bubbles up values, see the tests for\n // examples of what that means.\n data.milliseconds = milliseconds % 1000;\n\n seconds = absFloor(milliseconds / 1000);\n data.seconds = seconds % 60;\n\n minutes = absFloor(seconds / 60);\n data.minutes = minutes % 60;\n\n hours = absFloor(minutes / 60);\n data.hours = hours % 24;\n\n days += absFloor(hours / 24);\n\n // convert days to months\n monthsFromDays = absFloor(daysToMonths(days));\n months += monthsFromDays;\n days -= absCeil(monthsToDays(monthsFromDays));\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n data.days = days;\n data.months = months;\n data.years = years;\n\n return this;\n }\n\n function daysToMonths(days) {\n // 400 years have 146097 days (taking into account leap year rules)\n // 400 years have 12 months === 4800\n return (days * 4800) / 146097;\n }\n\n function monthsToDays(months) {\n // the reverse of daysToMonths\n return (months * 146097) / 4800;\n }\n\n function as(units) {\n if (!this.isValid()) {\n return NaN;\n }\n var days,\n months,\n milliseconds = this._milliseconds;\n\n units = normalizeUnits(units);\n\n if (units === 'month' || units === 'quarter' || units === 'year') {\n days = this._days + milliseconds / 864e5;\n months = this._months + daysToMonths(days);\n switch (units) {\n case 'month':\n return months;\n case 'quarter':\n return months / 3;\n case 'year':\n return months / 12;\n }\n } else {\n // handle milliseconds separately because of floating point math errors (issue #1867)\n days = this._days + Math.round(monthsToDays(this._months));\n switch (units) {\n case 'week':\n return days / 7 + milliseconds / 6048e5;\n case 'day':\n return days + milliseconds / 864e5;\n case 'hour':\n return days * 24 + milliseconds / 36e5;\n case 'minute':\n return days * 1440 + milliseconds / 6e4;\n case 'second':\n return days * 86400 + milliseconds / 1000;\n // Math.floor prevents floating point math errors here\n case 'millisecond':\n return Math.floor(days * 864e5) + milliseconds;\n default:\n throw new Error('Unknown unit ' + units);\n }\n }\n }\n\n function makeAs(alias) {\n return function () {\n return this.as(alias);\n };\n }\n\n var asMilliseconds = makeAs('ms'),\n asSeconds = makeAs('s'),\n asMinutes = makeAs('m'),\n asHours = makeAs('h'),\n asDays = makeAs('d'),\n asWeeks = makeAs('w'),\n asMonths = makeAs('M'),\n asQuarters = makeAs('Q'),\n asYears = makeAs('y'),\n valueOf$1 = asMilliseconds;\n\n function clone$1() {\n return createDuration(this);\n }\n\n function get$2(units) {\n units = normalizeUnits(units);\n return this.isValid() ? this[units + 's']() : NaN;\n }\n\n function makeGetter(name) {\n return function () {\n return this.isValid() ? this._data[name] : NaN;\n };\n }\n\n var milliseconds = makeGetter('milliseconds'),\n seconds = makeGetter('seconds'),\n minutes = makeGetter('minutes'),\n hours = makeGetter('hours'),\n days = makeGetter('days'),\n months = makeGetter('months'),\n years = makeGetter('years');\n\n function weeks() {\n return absFloor(this.days() / 7);\n }\n\n var round = Math.round,\n thresholds = {\n ss: 44, // a few seconds to seconds\n s: 45, // seconds to minute\n m: 45, // minutes to hour\n h: 22, // hours to day\n d: 26, // days to month/week\n w: null, // weeks to month\n M: 11, // months to year\n };\n\n // helper function for moment.fn.from, moment.fn.fromNow, and moment.duration.fn.humanize\n function substituteTimeAgo(string, number, withoutSuffix, isFuture, locale) {\n return locale.relativeTime(number || 1, !!withoutSuffix, string, isFuture);\n }\n\n function relativeTime$1(posNegDuration, withoutSuffix, thresholds, locale) {\n var duration = createDuration(posNegDuration).abs(),\n seconds = round(duration.as('s')),\n minutes = round(duration.as('m')),\n hours = round(duration.as('h')),\n days = round(duration.as('d')),\n months = round(duration.as('M')),\n weeks = round(duration.as('w')),\n years = round(duration.as('y')),\n a =\n (seconds <= thresholds.ss && ['s', seconds]) ||\n (seconds < thresholds.s && ['ss', seconds]) ||\n (minutes <= 1 && ['m']) ||\n (minutes < thresholds.m && ['mm', minutes]) ||\n (hours <= 1 && ['h']) ||\n (hours < thresholds.h && ['hh', hours]) ||\n (days <= 1 && ['d']) ||\n (days < thresholds.d && ['dd', days]);\n\n if (thresholds.w != null) {\n a =\n a ||\n (weeks <= 1 && ['w']) ||\n (weeks < thresholds.w && ['ww', weeks]);\n }\n a = a ||\n (months <= 1 && ['M']) ||\n (months < thresholds.M && ['MM', months]) ||\n (years <= 1 && ['y']) || ['yy', years];\n\n a[2] = withoutSuffix;\n a[3] = +posNegDuration > 0;\n a[4] = locale;\n return substituteTimeAgo.apply(null, a);\n }\n\n // This function allows you to set the rounding function for relative time strings\n function getSetRelativeTimeRounding(roundingFunction) {\n if (roundingFunction === undefined) {\n return round;\n }\n if (typeof roundingFunction === 'function') {\n round = roundingFunction;\n return true;\n }\n return false;\n }\n\n // This function allows you to set a threshold for relative time strings\n function getSetRelativeTimeThreshold(threshold, limit) {\n if (thresholds[threshold] === undefined) {\n return false;\n }\n if (limit === undefined) {\n return thresholds[threshold];\n }\n thresholds[threshold] = limit;\n if (threshold === 's') {\n thresholds.ss = limit - 1;\n }\n return true;\n }\n\n function humanize(argWithSuffix, argThresholds) {\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var withSuffix = false,\n th = thresholds,\n locale,\n output;\n\n if (typeof argWithSuffix === 'object') {\n argThresholds = argWithSuffix;\n argWithSuffix = false;\n }\n if (typeof argWithSuffix === 'boolean') {\n withSuffix = argWithSuffix;\n }\n if (typeof argThresholds === 'object') {\n th = Object.assign({}, thresholds, argThresholds);\n if (argThresholds.s != null && argThresholds.ss == null) {\n th.ss = argThresholds.s - 1;\n }\n }\n\n locale = this.localeData();\n output = relativeTime$1(this, !withSuffix, th, locale);\n\n if (withSuffix) {\n output = locale.pastFuture(+this, output);\n }\n\n return locale.postformat(output);\n }\n\n var abs$1 = Math.abs;\n\n function sign(x) {\n return (x > 0) - (x < 0) || +x;\n }\n\n function toISOString$1() {\n // for ISO strings we do not use the normal bubbling rules:\n // * milliseconds bubble up until they become hours\n // * days do not bubble at all\n // * months bubble up until they become years\n // This is because there is no context-free conversion between hours and days\n // (think of clock changes)\n // and also not between days and months (28-31 days per month)\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var seconds = abs$1(this._milliseconds) / 1000,\n days = abs$1(this._days),\n months = abs$1(this._months),\n minutes,\n hours,\n years,\n s,\n total = this.asSeconds(),\n totalSign,\n ymSign,\n daysSign,\n hmsSign;\n\n if (!total) {\n // this is the same as C#'s (Noda) and python (isodate)...\n // but not other JS (goog.date)\n return 'P0D';\n }\n\n // 3600 seconds -> 60 minutes -> 1 hour\n minutes = absFloor(seconds / 60);\n hours = absFloor(minutes / 60);\n seconds %= 60;\n minutes %= 60;\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n // inspired by https://github.com/dordille/moment-isoduration/blob/master/moment.isoduration.js\n s = seconds ? seconds.toFixed(3).replace(/\\.?0+$/, '') : '';\n\n totalSign = total < 0 ? '-' : '';\n ymSign = sign(this._months) !== sign(total) ? '-' : '';\n daysSign = sign(this._days) !== sign(total) ? '-' : '';\n hmsSign = sign(this._milliseconds) !== sign(total) ? '-' : '';\n\n return (\n totalSign +\n 'P' +\n (years ? ymSign + years + 'Y' : '') +\n (months ? ymSign + months + 'M' : '') +\n (days ? daysSign + days + 'D' : '') +\n (hours || minutes || seconds ? 'T' : '') +\n (hours ? hmsSign + hours + 'H' : '') +\n (minutes ? hmsSign + minutes + 'M' : '') +\n (seconds ? hmsSign + s + 'S' : '')\n );\n }\n\n var proto$2 = Duration.prototype;\n\n proto$2.isValid = isValid$1;\n proto$2.abs = abs;\n proto$2.add = add$1;\n proto$2.subtract = subtract$1;\n proto$2.as = as;\n proto$2.asMilliseconds = asMilliseconds;\n proto$2.asSeconds = asSeconds;\n proto$2.asMinutes = asMinutes;\n proto$2.asHours = asHours;\n proto$2.asDays = asDays;\n proto$2.asWeeks = asWeeks;\n proto$2.asMonths = asMonths;\n proto$2.asQuarters = asQuarters;\n proto$2.asYears = asYears;\n proto$2.valueOf = valueOf$1;\n proto$2._bubble = bubble;\n proto$2.clone = clone$1;\n proto$2.get = get$2;\n proto$2.milliseconds = milliseconds;\n proto$2.seconds = seconds;\n proto$2.minutes = minutes;\n proto$2.hours = hours;\n proto$2.days = days;\n proto$2.weeks = weeks;\n proto$2.months = months;\n proto$2.years = years;\n proto$2.humanize = humanize;\n proto$2.toISOString = toISOString$1;\n proto$2.toString = toISOString$1;\n proto$2.toJSON = toISOString$1;\n proto$2.locale = locale;\n proto$2.localeData = localeData;\n\n proto$2.toIsoString = deprecate(\n 'toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)',\n toISOString$1\n );\n proto$2.lang = lang;\n\n // FORMATTING\n\n addFormatToken('X', 0, 0, 'unix');\n addFormatToken('x', 0, 0, 'valueOf');\n\n // PARSING\n\n addRegexToken('x', matchSigned);\n addRegexToken('X', matchTimestamp);\n addParseToken('X', function (input, array, config) {\n config._d = new Date(parseFloat(input) * 1000);\n });\n addParseToken('x', function (input, array, config) {\n config._d = new Date(toInt(input));\n });\n\n //! moment.js\n\n hooks.version = '2.30.1';\n\n setHookCallback(createLocal);\n\n hooks.fn = proto;\n hooks.min = min;\n hooks.max = max;\n hooks.now = now;\n hooks.utc = createUTC;\n hooks.unix = createUnix;\n hooks.months = listMonths;\n hooks.isDate = isDate;\n hooks.locale = getSetGlobalLocale;\n hooks.invalid = createInvalid;\n hooks.duration = createDuration;\n hooks.isMoment = isMoment;\n hooks.weekdays = listWeekdays;\n hooks.parseZone = createInZone;\n hooks.localeData = getLocale;\n hooks.isDuration = isDuration;\n hooks.monthsShort = listMonthsShort;\n hooks.weekdaysMin = listWeekdaysMin;\n hooks.defineLocale = defineLocale;\n hooks.updateLocale = updateLocale;\n hooks.locales = listLocales;\n hooks.weekdaysShort = listWeekdaysShort;\n hooks.normalizeUnits = normalizeUnits;\n hooks.relativeTimeRounding = getSetRelativeTimeRounding;\n hooks.relativeTimeThreshold = getSetRelativeTimeThreshold;\n hooks.calendarFormat = getCalendarFormat;\n hooks.prototype = proto;\n\n // currently HTML5 input type only supports 24-hour formats\n hooks.HTML5_FMT = {\n DATETIME_LOCAL: 'YYYY-MM-DDTHH:mm', // \n DATETIME_LOCAL_SECONDS: 'YYYY-MM-DDTHH:mm:ss', // \n DATETIME_LOCAL_MS: 'YYYY-MM-DDTHH:mm:ss.SSS', // \n DATE: 'YYYY-MM-DD', // \n TIME: 'HH:mm', // \n TIME_SECONDS: 'HH:mm:ss', // \n TIME_MS: 'HH:mm:ss.SSS', // \n WEEK: 'GGGG-[W]WW', // \n MONTH: 'YYYY-MM', // \n };\n\n return hooks;\n\n})));\n","import IInvoice from \"~/interfaces/IInvoice\"\nimport { CampProps, ReservationProps, SiteProps } from \"~/interfaces\"\nimport eSendingMode from \"~/enums/eSendingMode\"\nimport { LONG_TERM_RESERVATION_KINDS, longTermReservationKind, RESERVATION_KINDS } from \"~/constants\"\nimport { LINE_ITEM_KINDS } from \"~/constants/line_item_kinds\"\nimport { IFormData, ILineItemField } from \"~/components/Admin/Invoices/EditInvoice\"\nimport moment from \"moment/moment\"\nimport { cookieSendingModeInvoice } from \"../constants\"\n\nconst isDisplayingAsMonthly = (reservation: ReservationProps): boolean =>\n reservation ? moment(reservation.end_date).diff(moment(reservation.start_date), \"days\") >= 28 : false\n\nconst initializeFormDataFor = (\n invoice: IInvoice | undefined,\n site: SiteProps | undefined,\n camp: CampProps,\n isPreview: boolean,\n cookies?: any,\n): IFormData => {\n const sendingModeFromCookie =\n cookies &&\n Object.values(eSendingMode)\n .filter((item) => item !== eSendingMode.NONE)\n .includes(cookies[cookieSendingModeInvoice])\n ? cookies[cookieSendingModeInvoice]\n : false\n\n let defaultSendingMode =\n sendingModeFromCookie || invoice?.reservation?.sending_mode || camp.booking_sending_mode || eSendingMode.EMAIL\n\n if (defaultSendingMode === \"none\") {\n defaultSendingMode = eSendingMode.EMAIL\n }\n\n const isReservationRecurring = invoice?.reservation?.kind === RESERVATION_KINDS.RECURRING\n const longTermKind = invoice?.reservation?.long_term_reservation?.kind\n\n let invoiceLineItems: ILineItemField[] | undefined = invoice?.order?.line_items?.map((item) => ({\n ...item,\n quantity: item.kind === LINE_ITEM_KINDS.ELECTRIC ? item.quantity : Math.round(item.quantity),\n unit_amount: item.unit_amount_in_cents / 100.0,\n total_amount: item.total_amount_in_cents / 100.0,\n }))\n\n if (isDisplayingAsMonthly(invoice?.reservation)) {\n invoiceLineItems = invoiceLineItems?.map((item) =>\n item.reservation_id\n ? {\n ...item,\n unit_amount: item.total_amount,\n is_hidden: longTermKind === LONG_TERM_RESERVATION_KINDS.UTILITIES_ONLY && isReservationRecurring,\n }\n : item,\n )\n }\n\n const hasElectricLineItem = invoiceLineItems?.some((item) => item.kind === LINE_ITEM_KINDS.ELECTRIC)\n\n const electricKinds: longTermReservationKind[] = [\n LONG_TERM_RESERVATION_KINDS.RENT_AND_UTILITIES,\n LONG_TERM_RESERVATION_KINDS.UTILITIES_ONLY,\n ]\n\n if (isReservationRecurring && longTermKind && electricKinds.includes(longTermKind) && !hasElectricLineItem) {\n const virtualElectricQuantity =\n (invoice?.reservation?.meter_reading &&\n invoice?.reservation?.last_meter_reading &&\n invoice?.reservation?.meter_reading - invoice?.reservation?.last_meter_reading) ||\n 0\n const virtualElectricTotalAmount = virtualElectricQuantity * camp?.electricity_rate\n const newElectricLineItem: ILineItemField = {\n id: null,\n kind: LINE_ITEM_KINDS.ELECTRIC,\n label: \"Electricity\",\n unit_amount: camp.electricity_rate,\n quantity: virtualElectricQuantity,\n total_amount: virtualElectricTotalAmount,\n tax_rate: invoiceLineItems?.find((item) => item.tax_rate)?.tax_rate || 0,\n order_id: invoice?.order_id,\n add_on_id: null,\n reservation_id: null,\n parent_line_item_id: null,\n discount_id: null,\n occurrences: null,\n occurrence_unit: null,\n is_updating_series: false,\n }\n\n invoiceLineItems = [...(invoiceLineItems || []), newElectricLineItem]\n }\n\n return {\n electricity_fee: camp.electricity_rate,\n last_meter_reading: invoice?.reservation?.last_meter_reading || site?.last_meter_reading || 0,\n current_meter_reading: invoice?.reservation?.meter_reading || site?.last_meter_reading || 0,\n to_name: invoice?.order?.camper?.first_name + \" \" + invoice?.order?.camper?.last_name,\n to_email: invoice?.order?.camper?.email,\n to_phone: invoice?.order?.camper?.phone,\n to_address: invoice?.order?.camper?.address,\n memo: invoice?.memo || camp.default_invoice_memo || null,\n due_date: invoice?.due_date,\n items: invoiceLineItems?.map((item) => ({\n ...item,\n is_hidden: isPreview ? item.unit_amount == 0 : item.is_hidden,\n })),\n sending_mode: defaultSendingMode,\n is_displaying_occurrences: !isDisplayingAsMonthly(invoice?.reservation),\n }\n}\n\nexport { initializeFormDataFor }\n","import { useCallback, useEffect } from \"react\"\nimport IInvoice from \"~/interfaces/IInvoice\"\nimport Orders from \"~/api2/orders\"\nimport { IFormData, ILineItemField } from \"~/components/Admin/Invoices/EditInvoice\"\nimport { LINE_ITEM_KINDS } from \"~/constants/line_item_kinds\"\nimport useAdminForm from \"~/hooks/useAdminForm\"\nimport { isArray } from \"lodash\"\nimport { ElectricPayload } from \"~/interfaces/ElectricPrices\"\n\ninterface UseApplyElectricReturn {\n handleApplyFees: (invoice: IInvoice) => Promise\n}\n\nconst useApplyElectric = (): UseApplyElectricReturn => {\n const { setValue, watch, resource } = useAdminForm()\n const items = watch(\"items\")\n\n useEffect(() => {\n if (isArray(items)) {\n const electricItemIndex = items?.findIndex(\n (item: ILineItemField) =>\n item.kind === LINE_ITEM_KINDS.ELECTRIC && items.length === 1 && item.label === \"Electric\",\n )\n\n if (electricItemIndex !== -1) {\n const updatedItems = [...items]\n const updatedUnitAmount = Math.max(resource.current_meter_reading - resource.last_meter_reading, 0)\n\n updatedItems[electricItemIndex] = {\n ...updatedItems[electricItemIndex],\n quantity: updatedUnitAmount,\n unit_amount: updatedItems[electricItemIndex].unit_amount,\n total_amount: updatedItems[electricItemIndex].unit_amount * updatedUnitAmount,\n }\n\n setValue(\"items\", updatedItems, { shouldValidate: true })\n }\n }\n }, [resource.current_meter_reading, resource.last_meter_reading !== null])\n\n const handleApplyFees = useCallback(\n async (invoice: IInvoice) => {\n const reservation = invoice.reservation\n if (!reservation) return\n\n // Retrieve the freshest values right when the callback runs\n const currentMeterReading = watch(\"current_meter_reading\")\n const lastMeterReading = watch(\"last_meter_reading\")\n const currentItems = watch(\"items\")\n\n const postBody: ElectricPayload = !invoice.reservation?.site?.wild_energy_meter_location_id\n ? {\n site_id: reservation.site_id!,\n last_meter_reading: lastMeterReading ?? 0,\n current_meter_reading: currentMeterReading ?? 0,\n }\n : {\n site_id: reservation.site_id!,\n reservation_id: reservation.id!,\n is_syncing_readings: true,\n }\n\n try {\n const response = await Orders.createPreviewElectricPrices(postBody)\n\n const newElectricItems = response.order.preview.line_items\n\n if (response.last_meter_reading) setValue(\"last_meter_reading\", Number(response.last_meter_reading))\n if (response.current_meter_reading) setValue(\"current_meter_reading\", Number(response.current_meter_reading))\n\n const transformedNewElectricItems = newElectricItems.map((item) => ({\n ...item,\n unit_amount: Number(item.unit_amount_in_cents / 100.0),\n quantity: Number(item.quantity),\n total_amount: Number(item.total_amount_in_cents / 100.0),\n }))\n\n // Filter out any existing electric items from the current items\n const nonElectricItems = currentItems.filter((item: ILineItemField) => item.kind !== LINE_ITEM_KINDS.ELECTRIC)\n\n const updatedItems = [...nonElectricItems, ...transformedNewElectricItems] as Array\n\n setValue(\"items\", updatedItems, { shouldValidate: true })\n } catch (error) {\n console.error(\"Error applying fees:\", error)\n }\n },\n [watch, setValue],\n )\n\n return { handleApplyFees }\n}\n\nexport default useApplyElectric\n","const isValidEmail = (email: string): boolean => {\n const re: RegExp = /[^@ \\t\\r\\n]+@[^@ \\t\\r\\n]+\\.[^@ \\t\\r\\n]+/\n return re.test(email)\n}\n\nexport default isValidEmail","import eSendingMode from \"~/enums/eSendingMode\";\nimport isValidEmail from \"~/utils/isValidEmail\";\n\nconst isInvalidSendingMode = (email: string, phone: string, sendingMode: eSendingMode) =>\n (\n [eSendingMode.EMAIL, eSendingMode.EMAIL_AND_TEXT].includes(sendingMode) &&\n !isValidEmail(email)\n ) || (\n [eSendingMode.TEXT, eSendingMode.EMAIL_AND_TEXT].includes(sendingMode) &&\n !phone\n )\n\nexport default isInvalidSendingMode;","// TODO: Probably need to handle more cases here, like `es` or `fish`\nconst pluralize = (str: string, n: number) => (\n n == 1 ? str : str + 's'\n)\n\nexport default pluralize\n","import React, { useContext } from 'react'\nimport {\n CheckCircleIcon,\n LockClosedIcon,\n MinusCircleIcon,\n NoSymbolIcon,\n XCircleIcon,\n ArrowsUpDownIcon\n} from '@heroicons/react/24/solid'\nimport moment from 'moment'\nimport classNames from '../../utils/classNames'\nimport HoverTip from './HoverTip'\nimport { formatMoneyFromCents } from '../../utils/formatMoney'\nimport { AdminContext } from '../../contexts/AdminContext'\nimport { InformationCircleIcon } from '@heroicons/react/24/outline'\n\nexport const StatusDeleted = (props) => (\n
\n
\n \n Deleted {props.deleted_at && props.deleted_at}\n
\n
\n)\n\nexport const StatusUnpaid = () => {\n return (\n
\n
\n \n Unpaid\n
\n
\n )\n}\n\nexport const StatusPaid = (props?: { refundedAmountInCents?: number }) => {\n const { camp } = useContext(AdminContext)\n\n return (\n
\n
\n \n Paid\n {props.refundedAmountInCents > 0 && (\n \n Refunded\n \n \n )}\n
\n
\n )\n}\n\nexport const StatusBlocked = () => {\n return (\n
\n
\n \n Blocked\n
\n
\n )\n}\n\nexport const StatusImported = () => {\n return (\n
\n
\n \n Imported\n
\n
\n )\n}\n\nexport const StatusLocked = () => {\n return (\n
\n
\n \n Locked\n
\n
\n )\n}\n\nexport const CamperBlocked = (props) => {\n return (\n
\n
\n {props.small ? (\n <>\n \n Blocked\n \n ) : (\n <>\n \n Blocked from booking\n \n )}\n
\n
\n )\n}\n","import React from 'react'\n\nconst avatarFor = (avatar: number | string, color: string) => {\n switch (avatar) {\n case 1 || 'deer':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 2 || 'salmon':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 3 || 'bison':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 4 || 'bear':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 5 || 'eagle':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 6 || 'squirrel':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 7 || 'raccoon':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 8 || 'duck':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n case 9 || 'moose':\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n default:\n return (\n \n \n \n \n \n \n \n \n \n \n\n )\n }\n}\n\nexport default avatarFor\n","function hashStringToSeed(str) {\n let hash = 0\n for (let i = 0; i < str.length; i++) {\n const char = str.charCodeAt(i)\n // JavaScript performs bitwise operations using 32-bit signed integers.\n // We use unsigned right shift to ensure positive values.\n hash = (hash << 5) - hash + char\n hash >>>= 0 // Convert to 32bit unsigned integer\n }\n return hash\n}\n\nfunction seededRandom(seed) {\n const a = 1664525\n const c = 1013904223\n const m = 4294967296 // 2^32\n // Ensure modulo operation behaves as expected by using positive seeds\n seed = (a * seed + c) % m\n return seed / m\n}\n\nfunction generateAvatar(hashString) {\n if (!hashString || hashString.length === 0) {\n return 0\n }\n\n const seed = hashStringToSeed(hashString)\n let random = Math.floor(seededRandom(seed) * 9) + 1 // Generate number 1-9\n return random\n}\n\n// Example usage:\nconst num = generateAvatar('timgay')\nconsole.log(num) // This will output a valid number between 1 and 9\n\nexport default generateAvatar\n","function generateConsistentNaturalHexColor(key: string) {\n if (!key || key.length === 0) {\n return '#cccccc'\n }\n\n // Function to convert a single component to a hex value\n const componentToHex = (c) => {\n const hex = c.toString(16)\n return hex.length === 1 ? '0' + hex : hex\n }\n\n // Simple hashing function to convert string to hue\n const stringToHue = (str) => {\n let hash = 0\n for (let i = 0; i < str.length; i++) {\n hash = str.charCodeAt(i) + ((hash << 5) - hash)\n hash = hash & hash // Convert to 32bit integer\n }\n return Math.abs(hash % 360) // Ensure hue is between 0 and 359\n }\n\n // Convert key string to hue\n const hue = stringToHue(key)\n // Set saturation to 70% for richer colors\n const saturation = 70\n // Set lightness to 60% to avoid dark and too pale colors\n const lightness = 60\n\n // Convert HSL to RGB\n const rgb = hslToRgb(hue, saturation / 100, lightness / 100)\n\n // Convert each component to hex and concatenate them with a \"#\" prefix\n return '#' + componentToHex(rgb[0]) + componentToHex(rgb[1]) + componentToHex(rgb[2])\n}\n\nfunction hslToRgb(h, s, l) {\n let r, g, b\n const hue2rgb = (p, q, t) => {\n if (t < 0) t += 1\n if (t > 1) t -= 1\n if (t < 1 / 6) return p + (q - p) * 6 * t\n if (t < 1 / 2) return q\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6\n return p\n }\n\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s\n const p = 2 * l - q\n h /= 360 // ensure hue is scaled from 0 to 1\n\n r = hue2rgb(p, q, h + 1 / 3)\n g = hue2rgb(p, q, h)\n b = hue2rgb(p, q, h - 1 / 3)\n return [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)]\n}\n\nexport default generateConsistentNaturalHexColor\n","const formatLengthUnit = (length_unit: \"imperial\" | \"metric\" | string) => {\n if (length_unit === \"imperial\") {\n return \"ft\"\n } else if (length_unit === \"metric\") {\n return \"m\"\n } else {\n return \"\"\n }\n}\n\nexport default formatLengthUnit\n","import React, { useContext } from 'react'\nimport { ReservationProps } from '../../../../interfaces'\nimport ICamper from '../../../../interfaces/ICamper'\nimport moment from 'moment'\nimport pluralize from '../../../../utils/pluralize'\nimport { CamperBlocked } from '../../../ui/StatusBadges'\nimport { formatName } from '../../../../utils/formatName'\nimport createMarkup from '../../../../utils/createMarkup'\nimport avatarFor from '../../../../utils/avatarFor'\nimport generateAvatar from '../../../../utils/generateAvatar'\nimport generateConsistentNaturalHexColor from '../../../../utils/generateNaturalHexColor'\nimport { formatPhoneNumber } from '../../../../utils'\nimport { AdminContext } from '../../../../contexts/AdminContext'\nimport classNames from '../../../../utils/classNames'\nimport IPaymentMethods from '../../../../interfaces/IPaymentMethods'\nimport { CreditCardIcon, ExclamationTriangleIcon } from '@heroicons/react/20/solid'\nimport HoverTip from '../../../ui/HoverTip'\nimport formatLengthUnit from '~/utils/formatLengthUnit'\n\nexport const checkIsCamperEmpty = (camper: ICamper) => {\n if (!camper) return true\n\n return (\n !camper?.first_name &&\n !camper?.last_name &&\n !camper?.email &&\n !camper?.phone &&\n !camper?.address &&\n !camper?.vehicle_rig_length &&\n !camper?.vehicle_year &&\n !camper?.vehicle_color &&\n !camper?.vehicle_make &&\n !camper?.vehicle_rig_type &&\n !camper?.vehicle_electric &&\n !camper?.license_plate &&\n !camper?.default_pets_count &&\n !camper?.notes\n )\n}\n\nconst hasAdditionalVehicleInfo = (camper: ICamper) => {\n return (\n camper.additional_vehicle_make ||\n camper.additional_vehicle_year ||\n camper.additional_vehicle_color ||\n camper.additional_vehicle_license_plate\n )\n}\n\nconst hasEmergencyContactInfo = (camper: ICamper) => {\n return (\n camper.emergency_contact_name ||\n camper.emergency_contact_relationship ||\n camper.emergency_contact_email ||\n camper.emergency_contact_phone\n )\n}\n\ninterface ComponentProps {\n camper: ICamper\n setSelectedIndex?: (index: number) => void\n isBlocked?: boolean\n reservation?: ReservationProps\n isCamperLoading?: boolean\n readOnly?: boolean\n paymentMethods?: IPaymentMethods[]\n hidePaymentMethods?: boolean\n hideCardBorder?: boolean\n hideAdditionalInfo?: boolean\n hideAvatar?: boolean\n}\n\nconst ProfileCard = ({\n camper,\n reservation,\n setSelectedIndex,\n isBlocked,\n isCamperLoading,\n readOnly,\n paymentMethods,\n hidePaymentMethods = false,\n hideCardBorder = false,\n hideAdditionalInfo = false,\n hideAvatar = false,\n}: ComponentProps) => {\n const { setSelectedCamper, setCurrentPage, camp } = useContext(AdminContext)\n\n if (isCamperLoading) {\n return (\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n )\n }\n\n if (!camper || checkIsCamperEmpty(camper)) {\n return (\n
\n
No camper information to show
\n
\n )\n }\n\n const mostRecentReservation =\n reservation ||\n (camper.reservations || []).sort((a, b) => {\n const momentA = moment(a.created_at)\n const momentB = moment(b.created_at)\n\n if (momentA.isBefore(momentB)) {\n return 1\n } else if (momentA.isAfter(momentB)) {\n return -1\n } else {\n return 0\n }\n })[0]\n\n let vehicleInfo = [\n camper.vehicle_rig_length &&\n (camper.vehicle_rig_length.includes(\"ft\") || camper.vehicle_rig_length.includes(\"m\")\n ? camper.vehicle_rig_length\n : camper.vehicle_rig_length + \" \" + formatLengthUnit(camp.length_unit)),\n camper.vehicle_year && camper.vehicle_year,\n camper.vehicle_color && camper.vehicle_color,\n camper.vehicle_make && camper.vehicle_make,\n ]\n .filter((x) => x)\n .join(\" \")\n\n if (camper.vehicle_rig_type && camper.vehicle_electric) {\n vehicleInfo += \" - \" + camper.vehicle_rig_type + \", \" + camper.vehicle_electric + \"-amp\"\n } else if (camper.vehicle_rig_type) {\n vehicleInfo += \" - \" + camper.vehicle_rig_type\n } else if (camper.vehicle_electric) {\n vehicleInfo += \" - \" + camper.vehicle_electric + \"-amp\"\n }\n\n if (vehicleInfo.startsWith(\" - \")) {\n vehicleInfo = vehicleInfo.slice(3)\n }\n\n const formatPetsInfo = (petsInfo: string) => {\n if (/^\\d+$/.test(petsInfo)) {\n return petsInfo + pluralize(\" pet\", Number(petsInfo))\n } else {\n return petsInfo\n }\n }\n\n const additionalVehicleInfo = [\n camper.additional_vehicle_make && camper.additional_vehicle_make,\n camper.additional_vehicle_year && camper.additional_vehicle_year,\n camper.additional_vehicle_color && camper.additional_vehicle_color,\n ]\n .filter((x) => x)\n .join(\" \")\n\n \n const passengerInfo =\n camper.default_adults_count || camper.default_kids_count || camper.default_pets_info\n ? [\n camper?.default_adults_count &&\n camper?.default_adults_count +\n (camper?.default_kids_count\n ? pluralize(\" adult\", camper?.default_adults_count)\n : pluralize(\" passenger\", camper?.default_adults_count)),\n camper?.default_kids_count &&\n camper?.default_kids_count + (camper?.default_kids_count > 1 ? \" children\" : \" child\"),\n formatPetsInfo(camper.default_pets_info),\n ]\n .filter((x) => x)\n .join(\", \")\n : \"\"\n\n return (\n {\n if (readOnly) return\n\n setSelectedCamper(camper)\n setCurrentPage(\"guests\")\n }}\n data-testid=\"profile-card\"\n >\n {!hideAvatar && (\n
\n {avatarFor(\n generateAvatar(camper.first_name + camper.last_name || camper.email || camper.phone),\n generateConsistentNaturalHexColor(camper.first_name + camper.last_name || camper.email || camper.phone),\n )}\n
\n )}\n
\n
\n
\n
{formatName(camper)}
\n {isBlocked && }\n
{camper.email}
\n
{formatPhoneNumber(camper.phone)}
\n
{camper.address}
\n
{camper.company_name}
\n\n {!hidePaymentMethods && (\n
\n \n
\n )}\n
\n {!hidePaymentMethods && (\n
\n \n
\n )}\n
\n\n {(vehicleInfo || passengerInfo) && !hideAdditionalInfo && (\n <>\n
\n
\n
{vehicleInfo}
\n {camper.license_plate &&
License #: {camper.license_plate}
}\n {passengerInfo &&
{passengerInfo}
}\n
\n \n )}\n\n {hasAdditionalVehicleInfo(camper) && !hideAdditionalInfo && (\n <>\n
\n
\n
{additionalVehicleInfo}
\n {camper.additional_vehicle_license_plate && (\n
License #: {camper.additional_vehicle_license_plate}
\n )}\n
\n \n )}\n\n {hasEmergencyContactInfo(camper) && !hideAdditionalInfo && (\n <>\n
\n
\n
\n Emergency Contact: {camper.emergency_contact_name}\n {camper.emergency_contact_relationship && \" - \" + camper.emergency_contact_relationship}\n
\n {camper.emergency_contact_email &&
{camper.emergency_contact_email}
}\n {camper.emergency_contact_phone &&
{formatPhoneNumber(camper.emergency_contact_phone)}
}\n
\n \n )}\n\n {camper.notes && !hideAdditionalInfo && (\n <>\n
\n
\n
\n
\n \n )}\n
\n
\n )\n}\n\ninterface PaymentMethodsSectionProps {\n paymentMethods: IPaymentMethods[]\n camper: ICamper\n}\n\nconst PaymentMethodsSection = ({ paymentMethods, camper }: PaymentMethodsSectionProps) => {\n return (\n
\n {paymentMethods && paymentMethods.length > 0 ? (\n
\n
\n \n
\n {paymentMethods.length} payment {pluralize('method', paymentMethods.length)}\n
\n
\n {/* TODO: Last 4 digits of card doesn't come through */}\n {paymentMethods[0]?.last4 && (\n
\n •••• {paymentMethods[0]?.last4}\n
\n )}\n
\n ) : (\n \n
\n \n
0 payment methods
\n
\n
\n )}\n
\n )\n}\n\nexport default ProfileCard\n","import { ELECTRICS } from '../../constants'\nimport { SiteProps } from '../../interfaces'\nimport { validElectric } from '../../types'\n\n// NOTE: if we ever restrict sites in the admin view, then we'll need to update this to fetch all\n// sites for camp\nconst electricOptionsFor = (sites: SiteProps[]): { label: string; value: validElectric }[] => {\n let is15A = false\n let is20A = false\n let is30A = false\n let is50A = false\n let isNonElectric = false\n\n if (sites && sites.length > 0) {\n sites.forEach((site) => {\n if (site?.electric === ELECTRICS.E15) {\n is15A = true\n } else if (site?.electric === ELECTRICS.E20) {\n is20A = true\n } else if (site?.electric === ELECTRICS.E30) {\n is30A = true\n } else if (site?.electric === ELECTRICS.E50) {\n is50A = true\n } else if (site?.electric === ELECTRICS.SPLIT_30_50) {\n is30A = true\n is50A = true\n } else if (site?.electric === ELECTRICS.SPLIT_15_30_50) {\n is15A = true\n is30A = true\n is50A = true\n } else if (site?.electric === ELECTRICS.SPLIT_20_30_50) {\n is20A = true\n is30A = true\n is50A = true\n } else if (site?.electric === ELECTRICS.SPLIT_15_30) {\n is15A = true\n is30A = true\n } else if (site?.electric === ELECTRICS.SPLIT_20_30) {\n is20A = true\n is30A = true\n } else if (site?.electric === null || site?.electric === ELECTRICS.NONE) {\n isNonElectric = true\n }\n })\n }\n\n const ampsOptions = []\n if (is15A) ampsOptions.push(ELECTRICS.E15)\n if (is20A) ampsOptions.push(ELECTRICS.E20)\n if (is30A) ampsOptions.push(ELECTRICS.E30)\n if (is50A) ampsOptions.push(ELECTRICS.E50)\n if (isNonElectric) ampsOptions.push(ELECTRICS.NONE)\n\n const availableElectricOptions = ampsOptions.map((v) => ({\n label: v === ELECTRICS.NONE ? 'Non-electric' : `${v.replace('E', '')}-amp`,\n value: v,\n }))\n\n return [{ label: '\\u00A0', value: null }, ...availableElectricOptions]\n}\n\nexport default electricOptionsFor\n","const CAMP_SLUGS_WITH_CAMPER_COMPANY_NAME_FIELD = [\n \"acadiana-beer-garden\",\n \"the-back-yard-food-truck-park\",\n \"your-rv-park\",\n \"dapper-haus\",\n]\n\nexport default CAMP_SLUGS_WITH_CAMPER_COMPANY_NAME_FIELD","import { Combobox } from \"@headlessui/react\"\nimport React, { useContext, useState, useEffect } from \"react\"\nimport { useDebouncedCallback } from \"use-debounce\"\nimport api2 from \"../../../api2\"\nimport { AdminContext } from \"../../../contexts/AdminContext\"\nimport CamperDecorator from \"../../../decorators/CamperDecorator\"\nimport ICamper from \"../../../interfaces/ICamper\"\nimport avatarFor from \"../../../utils/avatarFor\"\nimport classNames from \"../../../utils/classNames\"\nimport generateAvatar from \"../../../utils/generateAvatar\"\nimport generateConsistentNaturalHexColor from \"../../../utils/generateNaturalHexColor\"\nimport { checkIsCamperEmpty } from \"../Campers/Camper/ProfileCard\"\nimport { XCircleIcon } from \"@heroicons/react/20/solid\"\nimport { formatName } from \"../../../utils/formatName\"\n\nconst CamperDropdown = ({\n camper,\n setCamper,\n isCamperLoading,\n}: {\n camper: ICamper\n setCamper: React.Dispatch>\n isCamperLoading: boolean\n}) => {\n const { camp } = useContext(AdminContext)\n const [inputValue, setInputValue] = useState('')\n const [campers, setCampers] = useState([])\n const [isLoading, setIsLoading] = useState(false)\n\n const fetchCampers = useDebouncedCallback(async (query) => {\n api2.Search.campers(camp.id, query, { includePaymentMethods: true })\n .then(({ campers }) => {\n setCampers(campers)\n setIsLoading(false)\n })\n .catch((err) => {\n console.error(err)\n setIsLoading(false)\n })\n }, 100)\n\n const getAvatar = (camper: ICamper) =>\n avatarFor(\n generateAvatar(camper?.first_name + camper?.last_name || camper?.email || camper?.phone),\n generateConsistentNaturalHexColor(camper?.first_name + camper?.last_name || camper?.email || camper?.phone)\n )\n\n useEffect(() => {\n if (!checkIsCamperEmpty(camper) && checkIsCamperEmpty(camper)) {\n setCamper(camper)\n }\n }, [camper])\n\n return (\n {\n if (typeof value !== 'string') {\n setCamper(value)\n const existingCamper = campers.find((c) => c.id === value.id)\n const display = formatName(existingCamper)\n setInputValue(display || '')\n }\n }}>\n {({ open }) => (\n <>\n
\n \n {\n setIsLoading(true)\n fetchCampers(e.target.value)\n setInputValue(e.target.value)\n }}\n value={inputValue}\n />\n
\n {getAvatar(camper)}\n
\n \n {\n setCamper(null)\n setInputValue('')\n }}\n />\n
\n \n {open && inputValue.length > 0 && (\n \n {campers.map((option, index) => {\n if (\n !option?.first_name?.length &&\n !option?.last_name?.length &&\n !option?.email?.length\n )\n return <>\n\n return (\n <>\n \n classNames(\n 'relative select-none py-2 px-3 ghostinspector-new-reservation-site-li cursor-pointer',\n selected\n ? 'bg-green-50'\n : active\n ? 'bg-green-600 text-white'\n : 'text-gray-900'\n )\n }>\n {({ active, selected }) => (\n
\n
\n {getAvatar(option)}\n
\n \n {option?.first_name && <>{option.first_name} }\n {option?.last_name && <>{option.last_name}  }\n {option?.email && (\n \n {option.email}\n
\n )}\n
\n
\n )}\n \n \n )\n })}\n {inputValue?.length && !camper?.id && !campers?.length ? (\n isLoading ? (\n
Loading...
\n ) : (\n
No guests found
\n )\n ) : (\n <>\n )}\n \n )}\n
\n \n )}\n \n )\n}\n\nexport default CamperDropdown","import { useQuery } from \"@tanstack/react-query\"\nimport api from \"~/api2\"\n\nimport { queryKeys } from \"~/constants/queryKeys\"\n\ntype Props = {\n reservationId?: string\n}\n\nexport const useReservation = (props: Props) => {\n return useQuery({\n queryKey: [queryKeys.ORDER, props.reservationId],\n queryFn: () => findReservation(props.reservationId),\n staleTime: 3000,\n enabled: !!props.reservationId,\n })\n}\n\nconst findReservation = async (reservationId?: string) => {\n try {\n if (!reservationId) return\n return await api.Reservations.find(reservationId)\n } catch (error) {\n console.error(\"Error fetching reservation:\", error)\n throw error\n }\n}\n","import React, { useContext, useState } from \"react\"\nimport { FormProvider } from \"~/contexts/FormContext\"\nimport ICamper from \"../../../interfaces/ICamper\"\nimport api from \"../../../api2\"\nimport useAdminForm from \"../../../hooks/useAdminForm\"\nimport Button from \"../../ui/Button\"\nimport { ModalContext } from \"~/contexts/admin/ModalContext\"\nimport Form from \"../../ui/Admin/Form\"\nimport { AdminContext } from \"~/contexts/AdminContext\"\nimport electricOptionsFor from \"../../../utils/admin/electricOptionsFor\"\nimport CamperDecorator from \"../../../decorators/CamperDecorator\"\nimport CAMP_SLUGS_WITH_CAMPER_COMPANY_NAME_FIELD from \"../../../constants/camp_slugs_with_company_name_field\"\nimport CamperDropdown from \"../Reservations/CamperDropdown\"\nimport { formatName } from \"~/utils/formatName\"\nimport ProfileCard from \"./Camper/ProfileCard\"\nimport { DateTime } from \"luxon\"\nimport { useReservation } from \"~/components/Admin/Reservations/ReservationHooks/useReservation\"\nimport { ReservationProps } from \"~/interfaces\"\n\nconst hasHappened = (dateStr: string) => {\n if (!dateStr) return false\n const date = DateTime.fromISO(dateStr)\n return date < DateTime.now()\n}\n\nexport const newCamper: ICamper = {\n id: null,\n email: null,\n first_name: null,\n last_name: null,\n phone: null,\n address: null,\n company_name: null,\n default_adults_count: null,\n default_kids_count: null,\n default_pets_info: null,\n license_plate: null,\n vehicle_year: null,\n vehicle_make: null,\n vehicle_color: null,\n vehicle_rig_type: null,\n vehicle_rig_length: null,\n vehicle_electric: null,\n pets_info: null,\n reservations: null,\n notes: null,\n blocked_at: null,\n last_stay_date: null,\n num_stays: null,\n num_nights: null,\n spent: null,\n emergency_contact_name: null,\n emergency_contact_relationship: null,\n emergency_contact_email: null,\n emergency_contact_phone: null,\n additional_vehicle_make: null,\n additional_vehicle_year: null,\n additional_vehicle_color: null,\n additional_vehicle_license_plate: null,\n}\n\nconst NewCamperModalContent = ({\n onSuccess,\n camper,\n userId,\n reservationId,\n}: {\n onSuccess: (camper: ICamper) => void\n camper?: ICamper\n userId?: string\n reservationId?: string\n}) => {\n return (\n
\n
\n
\n
{!!camper?.id ? \"Update\" : \"New\"} guest
\n
\n
\n\n \n \n \n
\n )\n}\n\nconst NewCamperForm = ({\n userId,\n reservationId,\n isUpdating,\n onSuccess,\n}: {\n userId?: string\n reservationId?: string\n isUpdating?: boolean\n onSuccess: (camper: CamperDecorator) => void\n}) => {\n const { camp, sites, showNotification, updateLocalReservations, reservationStates } = useContext(AdminContext)\n const reservation = useReservation({ reservationId: reservationId })\n const [existingCamper, setExistingCamper] = useState(null)\n const { resource: camper, reset, defaultValues, setError, clearErrors } = useAdminForm()\n const { onClose } = useContext(ModalContext)\n const [isLoading, setIsLoading] = useState(false)\n\n const updateReservationCamper = (camper: CamperDecorator) => {\n const reservation: ReservationProps = {\n ...reservationStates[reservationId].persisted,\n user: {\n ...reservationStates[reservationId].persisted.user,\n camper,\n },\n }\n\n updateLocalReservations([reservation])\n }\n\n const handleClickSave = () => {\n if (!camper.first_name && !camper.last_name && !camper.email && !camper.phone) {\n if (!camper.first_name && !camper.last_name) {\n setError(\"first_name\", { message: \"\" })\n setError(\"last_name\", { message: \"\" })\n }\n if (!camper.email) setError(\"email\", { message: \"\" })\n if (!camper.phone) setError(\"phone\", { message: \"\" })\n\n showNotification({\n type: \"error\",\n title: \"Error adding guest\",\n description: \"Please add either a name, email, or phone number\",\n dismissAfter: 3000,\n })\n return\n }\n\n clearErrors()\n setIsLoading(true)\n\n if (userId && existingCamper) {\n reservation.data?.reservation.order_id &&\n api.Orders.updateOrderCamper(reservation.data?.reservation.order_id, existingCamper.id)\n api.Users.update(userId, { camper_id: existingCamper.id } as Parameters[1])\n .then(() => {\n const decorated = new CamperDecorator(existingCamper)\n onSuccess(decorated)\n updateReservationCamper(decorated)\n setIsLoading(false)\n showNotification({\n type: \"success\",\n title: \"Guest updated\",\n description: `${decorated.formattedName} was updated successfully`,\n })\n onClose()\n })\n .catch((err) => {\n setIsLoading(false)\n showNotification({\n type: \"error\",\n title: \"Error updating guest\",\n description: err.message,\n dismissAfter: 3000,\n })\n })\n } else if (isUpdating) {\n api.Campers.update(camper.id, camper)\n .then(({ camper: persistedCamper }) => {\n onSuccess(persistedCamper)\n if (reservationStates && reservationId && reservationStates[reservationId])\n updateReservationCamper(persistedCamper)\n setIsLoading(false)\n showNotification({\n type: \"success\",\n title: \"Guest updated\",\n description: `${formatName(camper)} was updated successfully`,\n })\n onClose()\n })\n .catch((err) => {\n setIsLoading(false)\n\n if (err.errors) {\n const values = Object.entries(err.errors as Record>)\n values.forEach(([key, messages]) => {\n setError(key as keyof ICamper, { message: messages.join(\",\") })\n })\n }\n\n showNotification({\n type: \"error\",\n title: \"Error updating guest\",\n description: err.message,\n dismissAfter: 3000,\n })\n })\n } else {\n api.Campers.create(camp.id, { ...camper, user_id: userId, reservation_id: reservationId })\n .then((persistedCamper) => {\n onSuccess(persistedCamper)\n if (reservationStates && reservationId && reservationStates[reservationId])\n updateReservationCamper(persistedCamper)\n setIsLoading(false)\n showNotification({\n type: \"success\",\n title: \"Guest added\",\n description: `${persistedCamper.formattedName} was added successfully`,\n })\n onClose()\n })\n .catch((err) => {\n setIsLoading(false)\n\n if (err.errors) {\n const values = Object.entries(err.errors as Record>)\n values.forEach(([key, messages]) => {\n setError(key as keyof ICamper, { message: messages.join(\",\") })\n })\n }\n\n showNotification({\n type: \"error\",\n title: \"Error adding guest\",\n description: err.message,\n dismissAfter: 3000,\n })\n })\n }\n }\n\n const handleClickCancel = () => {\n onClose()\n }\n\n const electricOptions = electricOptionsFor(sites)\n\n return (\n
\n
\n {userId && (\n
\n
Attach existing guest
\n
\n {\n reset((value as ICamper) || defaultValues)\n setExistingCamper(value)\n }}\n />\n
\n
\n )}\n\n <>\n {!!existingCamper && (\n
\n \n
\n )}\n {!existingCamper && (\n <>\n
\n
Guest Information
\n
\n
\n \n \n
\n
\n
\n {CAMP_SLUGS_WITH_CAMPER_COMPANY_NAME_FIELD.includes(camp.slug) && (\n
\n \n
\n )}\n
\n \n
\n
\n
Vehicle info
\n
\n
\n \n \n
\n
\n \n \n
\n
\n \n \n
\n
\n \n
\n
\n
Additional Info
\n
\n \n \n )}\n \n
\n
\n
\n \n Cancel\n \n \n {!!existingCamper ? \"Attach guest\" : isUpdating ? \"Update guest\" : \"Add guest\"}\n \n
\n
\n
\n )\n}\n\nexport default NewCamperModalContent\n","import { useQuery } from \"@tanstack/react-query\"\nimport { useContext } from \"react\"\nimport api2 from \"~/api2\"\nimport { serviceRateMode } from \"~/api2/orders\"\nimport { queryKeys } from \"~/constants/queryKeys\"\n\nimport { AdminContext } from \"~/contexts/AdminContext\"\nimport { useOrder } from \"./useOrder\"\nimport IOrder from \"~/interfaces/IOrder\"\n\ntype Props = {\n orderId?: string\n campingStyleId?: string\n discount_type?: string\n serviceRate: any\n isPaid: boolean\n includedInvoice?: boolean\n enabled?: boolean\n includePayments?: boolean\n}\n\nexport const usePreviews = (props: Props) => {\n const { camp } = useContext(AdminContext)\n const order = useOrder({ orderId: props.orderId })\n\n const isEnabled = props.enabled !== false && !!camp && !!order.data?.order && !props.isPaid\n\n return useQuery({\n queryKey: [\n queryKeys.RESERVATION_PREVIEWS,\n props.orderId,\n props.campingStyleId,\n props.serviceRate,\n props.discount_type,\n props.includedInvoice,\n props.includePayments,\n ],\n queryFn: () =>\n fetchPreviews({\n order: order.data?.order,\n campId: camp.id,\n campingStyleId: props.campingStyleId,\n serviceRate: props.serviceRate,\n isPaid: props.isPaid,\n discount_type: props.discount_type,\n includedInvoice: props.includedInvoice,\n includePayments: props.includePayments,\n }),\n staleTime: 0,\n enabled: isEnabled,\n retry: 2\n })\n}\n\nconst fetchPreviews = async ({\n order,\n campId,\n campingStyleId = \"\",\n serviceRate = serviceRateMode.pos,\n isPaid,\n discount_type = \"\",\n includedInvoice = false,\n includePayments = false,\n}: {\n order?: IOrder\n campId: string\n campingStyleId?: string\n serviceRate?: any\n isPaid: boolean\n discount_type?: string\n includedInvoice?: boolean\n includePayments?: boolean\n}) => {\n if (!order || !campId) return\n\n try {\n return await api2.Orders.orderAndPreviewForNew(\n order,\n campId,\n campingStyleId,\n serviceRate,\n isPaid,\n discount_type,\n includedInvoice,\n { includeInvoice: includedInvoice, includePayments },\n )\n } catch (error) {\n console.error(\"Error fetching previews:\", error)\n throw error\n }\n}\n","var V3_URL = 'https://js.stripe.com/v3';\nvar V3_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/v3\\/?(\\?.*)?$/;\nvar EXISTING_SCRIPT_MESSAGE = 'loadStripe.setLoadParameters was called but an existing Stripe.js script already exists in the document; existing script parameters will be used';\nvar findScript = function findScript() {\n var scripts = document.querySelectorAll(\"script[src^=\\\"\".concat(V3_URL, \"\\\"]\"));\n\n for (var i = 0; i < scripts.length; i++) {\n var script = scripts[i];\n\n if (!V3_URL_REGEX.test(script.src)) {\n continue;\n }\n\n return script;\n }\n\n return null;\n};\n\nvar injectScript = function injectScript(params) {\n var queryString = params && !params.advancedFraudSignals ? '?advancedFraudSignals=false' : '';\n var script = document.createElement('script');\n script.src = \"\".concat(V3_URL).concat(queryString);\n var headOrBody = document.head || document.body;\n\n if (!headOrBody) {\n throw new Error('Expected document.body not to be null. Stripe.js requires a element.');\n }\n\n headOrBody.appendChild(script);\n return script;\n};\n\nvar registerWrapper = function registerWrapper(stripe, startTime) {\n if (!stripe || !stripe._registerWrapper) {\n return;\n }\n\n stripe._registerWrapper({\n name: 'stripe-js',\n version: \"4.6.0\",\n startTime: startTime\n });\n};\n\nvar stripePromise = null;\nvar onErrorListener = null;\nvar onLoadListener = null;\n\nvar onError = function onError(reject) {\n return function () {\n reject(new Error('Failed to load Stripe.js'));\n };\n};\n\nvar onLoad = function onLoad(resolve, reject) {\n return function () {\n if (window.Stripe) {\n resolve(window.Stripe);\n } else {\n reject(new Error('Stripe.js not available'));\n }\n };\n};\n\nvar loadScript = function loadScript(params) {\n // Ensure that we only attempt to load Stripe.js at most once\n if (stripePromise !== null) {\n return stripePromise;\n }\n\n stripePromise = new Promise(function (resolve, reject) {\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n // Resolve to null when imported server side. This makes the module\n // safe to import in an isomorphic code base.\n resolve(null);\n return;\n }\n\n if (window.Stripe && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n }\n\n if (window.Stripe) {\n resolve(window.Stripe);\n return;\n }\n\n try {\n var script = findScript();\n\n if (script && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n } else if (!script) {\n script = injectScript(params);\n } else if (script && onLoadListener !== null && onErrorListener !== null) {\n var _script$parentNode;\n\n // remove event listeners\n script.removeEventListener('load', onLoadListener);\n script.removeEventListener('error', onErrorListener); // if script exists, but we are reloading due to an error,\n // reload script to trigger 'load' event\n\n (_script$parentNode = script.parentNode) === null || _script$parentNode === void 0 ? void 0 : _script$parentNode.removeChild(script);\n script = injectScript(params);\n }\n\n onLoadListener = onLoad(resolve, reject);\n onErrorListener = onError(reject);\n script.addEventListener('load', onLoadListener);\n script.addEventListener('error', onErrorListener);\n } catch (error) {\n reject(error);\n return;\n }\n }); // Resets stripePromise on error\n\n return stripePromise[\"catch\"](function (error) {\n stripePromise = null;\n return Promise.reject(error);\n });\n};\nvar initStripe = function initStripe(maybeStripe, args, startTime) {\n if (maybeStripe === null) {\n return null;\n }\n\n var stripe = maybeStripe.apply(undefined, args);\n registerWrapper(stripe, startTime);\n return stripe;\n}; // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\nvar stripePromise$1;\nvar loadCalled = false;\n\nvar getStripePromise = function getStripePromise() {\n if (stripePromise$1) {\n return stripePromise$1;\n }\n\n stripePromise$1 = loadScript(null)[\"catch\"](function (error) {\n // clear cache on error\n stripePromise$1 = null;\n return Promise.reject(error);\n });\n return stripePromise$1;\n}; // Execute our own script injection after a tick to give users time to do their\n// own script injection.\n\n\nPromise.resolve().then(function () {\n return getStripePromise();\n})[\"catch\"](function (error) {\n if (!loadCalled) {\n console.warn(error);\n }\n});\nvar loadStripe = function loadStripe() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n loadCalled = true;\n var startTime = Date.now(); // if previous attempts are unsuccessful, will re-load script\n\n return getStripePromise().then(function (maybeStripe) {\n return initStripe(maybeStripe, args, startTime);\n });\n};\n\nexport { loadStripe };\n","import { CampProps } from \"~/interfaces\"\nimport { RESERVATION_KINDS, reservationKind } from \"~/constants/reservation_kinds\"\n\nexport const stripeOptionsFn: (\n priceDetailsTotal: number | undefined,\n camp: CampProps,\n reservationKind?: reservationKind,\n) => any = (priceDetailsTotal: number | undefined, camp: CampProps, reservationKind?: reservationKind) => {\n if (!priceDetailsTotal) return\n return {\n mode: \"payment\",\n amount: Math.round(Number(priceDetailsTotal) * 100.0),\n currency: camp.currency,\n paymentMethodTypes:\n (reservationKind && reservationKind === RESERVATION_KINDS.RECURRING && camp.recurring_payment_methods) ||\n camp.booker_payment_methods,\n appearance: {\n variables: {\n fontSizeBase: \"14px\", // Smaller base font size\n borderRadius: \"4px\", // Optional: customize border radius\n },\n rules: {\n \".Input\": {\n padding: \"8px 12px\", // Adjust input field padding\n },\n \".Input--invalid\": {\n borderColor: \"#e3342f\", // Optional: customize invalid state border\n },\n },\n },\n }\n}\n","import { useMutation, useQueryClient } from \"@tanstack/react-query\"\nimport api from \"~/api2\"\nimport { OrderPreviewParams } from \"~/api2/orders\"\nimport IOrder from \"~/interfaces/IOrder\"\nimport IOrderPreview from \"~/interfaces/IOrderPreview\"\nimport IInvoice from \"~/interfaces/IInvoice\"\n\ninterface CreateOrderPreviewResponse {\n order: { preview: IOrderPreview } & { invoice?: IInvoice }\n}\n\nexport const useCreateOrderPreview = () => {\n const queryClient = useQueryClient()\n\n return useMutation({\n mutationFn: async (params: OrderPreviewParams): Promise => {\n return api.Orders.createPreview(params)\n },\n\n onSuccess: (data, variables) => {\n queryClient.invalidateQueries({ queryKey: [\"order\", variables.order_id] })\n\n queryClient.setQueryData([\"orderPreview\", variables.order_id], data.order.preview)\n\n return data.order.preview\n },\n })\n}\n","import { useCallback, useMemo, useState } from \"react\"\nimport IInvoice from \"~/interfaces/IInvoice\"\nimport { validElectric } from \"~/types\"\nimport api from \"~/api2\"\nimport { mapLineItemToParams } from \"~/api2/orders\"\n\ninterface PriceDetails {\n loadingIntent: boolean\n upsertIntent: (paymentMethod: string) => Promise<{ id: string; clientSecret: string }>\n}\n\nconst useBuildPriceDetails = (invoice: IInvoice): PriceDetails => {\n const [loadingIntent, setIsLoadingIntent] = useState(false)\n const buildOrderDetails = useCallback(\n (paymentMethod: string) => ({\n order_id: invoice.order_id,\n camp_id: invoice.order.camp_id,\n camper_id: invoice.order.camper_id,\n camping_style_id: invoice.reservation?.site?.camping_style_id!,\n site_id: invoice.reservation?.site_id!,\n start_date: invoice.reservation?.start_date!,\n end_date: invoice.reservation?.end_date!,\n user_electric: invoice.reservation?.user?.vehicle_electric as validElectric,\n user_passengers: invoice.reservation?.passengers ?? 0 ?? 0,\n user_kid_campers: invoice.reservation?.kid_campers ?? 0,\n number_of_pets: Number(invoice.reservation?.pets_info) ?? 0,\n user_rig_year: invoice.reservation?.user?.vehicle_year,\n interval_id: invoice.reservation?.selected_booking_interval_id,\n is_service_fee_applied: true,\n is_tax_enabled: true,\n is_passenger_fees_enabled: true,\n is_pets_fee_enabled: true,\n is_holiday_rate_enabled: true,\n is_weekend_fee_enabled: true,\n is_credit_card_fee_enabled: true,\n discount_slug: invoice.order.discount_name,\n is_terminal_payment: false,\n selected_payment_method: paymentMethod,\n line_items_attributes: invoice.order.line_items.map((li) => mapLineItemToParams(li, Number(li.tax_rate) > 0)),\n }),\n [invoice],\n )\n\n const upsertIntent = async (paymentMethod: string) => {\n setIsLoadingIntent(true)\n\n const orderDetails = buildOrderDetails(paymentMethod)\n const resp = await api.Orders.createPaymentIntent({ ...orderDetails })\n\n if (!resp.payment_intent.client_secret) throw new Error(\"Missing client secret from payment intent response\")\n\n setIsLoadingIntent(false)\n return { id: resp.payment_intent.id, clientSecret: resp.payment_intent.client_secret }\n }\n\n return {\n loadingIntent,\n upsertIntent,\n }\n}\n\nexport default useBuildPriceDetails\n","var adapters = {\n logger: typeof console !== \"undefined\" ? console : undefined,\n WebSocket: typeof WebSocket !== \"undefined\" ? WebSocket : undefined\n};\n\nvar logger = {\n log(...messages) {\n if (this.enabled) {\n messages.push(Date.now());\n adapters.logger.log(\"[ActionCable]\", ...messages);\n }\n }\n};\n\nconst now = () => (new Date).getTime();\n\nconst secondsSince = time => (now() - time) / 1e3;\n\nclass ConnectionMonitor {\n constructor(connection) {\n this.visibilityDidChange = this.visibilityDidChange.bind(this);\n this.connection = connection;\n this.reconnectAttempts = 0;\n }\n start() {\n if (!this.isRunning()) {\n this.startedAt = now();\n delete this.stoppedAt;\n this.startPolling();\n addEventListener(\"visibilitychange\", this.visibilityDidChange);\n logger.log(`ConnectionMonitor started. stale threshold = ${this.constructor.staleThreshold} s`);\n }\n }\n stop() {\n if (this.isRunning()) {\n this.stoppedAt = now();\n this.stopPolling();\n removeEventListener(\"visibilitychange\", this.visibilityDidChange);\n logger.log(\"ConnectionMonitor stopped\");\n }\n }\n isRunning() {\n return this.startedAt && !this.stoppedAt;\n }\n recordMessage() {\n this.pingedAt = now();\n }\n recordConnect() {\n this.reconnectAttempts = 0;\n delete this.disconnectedAt;\n logger.log(\"ConnectionMonitor recorded connect\");\n }\n recordDisconnect() {\n this.disconnectedAt = now();\n logger.log(\"ConnectionMonitor recorded disconnect\");\n }\n startPolling() {\n this.stopPolling();\n this.poll();\n }\n stopPolling() {\n clearTimeout(this.pollTimeout);\n }\n poll() {\n this.pollTimeout = setTimeout((() => {\n this.reconnectIfStale();\n this.poll();\n }), this.getPollInterval());\n }\n getPollInterval() {\n const {staleThreshold: staleThreshold, reconnectionBackoffRate: reconnectionBackoffRate} = this.constructor;\n const backoff = Math.pow(1 + reconnectionBackoffRate, Math.min(this.reconnectAttempts, 10));\n const jitterMax = this.reconnectAttempts === 0 ? 1 : reconnectionBackoffRate;\n const jitter = jitterMax * Math.random();\n return staleThreshold * 1e3 * backoff * (1 + jitter);\n }\n reconnectIfStale() {\n if (this.connectionIsStale()) {\n logger.log(`ConnectionMonitor detected stale connection. reconnectAttempts = ${this.reconnectAttempts}, time stale = ${secondsSince(this.refreshedAt)} s, stale threshold = ${this.constructor.staleThreshold} s`);\n this.reconnectAttempts++;\n if (this.disconnectedRecently()) {\n logger.log(`ConnectionMonitor skipping reopening recent disconnect. time disconnected = ${secondsSince(this.disconnectedAt)} s`);\n } else {\n logger.log(\"ConnectionMonitor reopening\");\n this.connection.reopen();\n }\n }\n }\n get refreshedAt() {\n return this.pingedAt ? this.pingedAt : this.startedAt;\n }\n connectionIsStale() {\n return secondsSince(this.refreshedAt) > this.constructor.staleThreshold;\n }\n disconnectedRecently() {\n return this.disconnectedAt && secondsSince(this.disconnectedAt) < this.constructor.staleThreshold;\n }\n visibilityDidChange() {\n if (document.visibilityState === \"visible\") {\n setTimeout((() => {\n if (this.connectionIsStale() || !this.connection.isOpen()) {\n logger.log(`ConnectionMonitor reopening stale connection on visibilitychange. visibilityState = ${document.visibilityState}`);\n this.connection.reopen();\n }\n }), 200);\n }\n }\n}\n\nConnectionMonitor.staleThreshold = 6;\n\nConnectionMonitor.reconnectionBackoffRate = .15;\n\nvar INTERNAL = {\n message_types: {\n welcome: \"welcome\",\n disconnect: \"disconnect\",\n ping: \"ping\",\n confirmation: \"confirm_subscription\",\n rejection: \"reject_subscription\"\n },\n disconnect_reasons: {\n unauthorized: \"unauthorized\",\n invalid_request: \"invalid_request\",\n server_restart: \"server_restart\",\n remote: \"remote\"\n },\n default_mount_path: \"/cable\",\n protocols: [ \"actioncable-v1-json\", \"actioncable-unsupported\" ]\n};\n\nconst {message_types: message_types, protocols: protocols} = INTERNAL;\n\nconst supportedProtocols = protocols.slice(0, protocols.length - 1);\n\nconst indexOf = [].indexOf;\n\nclass Connection {\n constructor(consumer) {\n this.open = this.open.bind(this);\n this.consumer = consumer;\n this.subscriptions = this.consumer.subscriptions;\n this.monitor = new ConnectionMonitor(this);\n this.disconnected = true;\n }\n send(data) {\n if (this.isOpen()) {\n this.webSocket.send(JSON.stringify(data));\n return true;\n } else {\n return false;\n }\n }\n open() {\n if (this.isActive()) {\n logger.log(`Attempted to open WebSocket, but existing socket is ${this.getState()}`);\n return false;\n } else {\n const socketProtocols = [ ...protocols, ...this.consumer.subprotocols || [] ];\n logger.log(`Opening WebSocket, current state is ${this.getState()}, subprotocols: ${socketProtocols}`);\n if (this.webSocket) {\n this.uninstallEventHandlers();\n }\n this.webSocket = new adapters.WebSocket(this.consumer.url, socketProtocols);\n this.installEventHandlers();\n this.monitor.start();\n return true;\n }\n }\n close({allowReconnect: allowReconnect} = {\n allowReconnect: true\n }) {\n if (!allowReconnect) {\n this.monitor.stop();\n }\n if (this.isOpen()) {\n return this.webSocket.close();\n }\n }\n reopen() {\n logger.log(`Reopening WebSocket, current state is ${this.getState()}`);\n if (this.isActive()) {\n try {\n return this.close();\n } catch (error) {\n logger.log(\"Failed to reopen WebSocket\", error);\n } finally {\n logger.log(`Reopening WebSocket in ${this.constructor.reopenDelay}ms`);\n setTimeout(this.open, this.constructor.reopenDelay);\n }\n } else {\n return this.open();\n }\n }\n getProtocol() {\n if (this.webSocket) {\n return this.webSocket.protocol;\n }\n }\n isOpen() {\n return this.isState(\"open\");\n }\n isActive() {\n return this.isState(\"open\", \"connecting\");\n }\n triedToReconnect() {\n return this.monitor.reconnectAttempts > 0;\n }\n isProtocolSupported() {\n return indexOf.call(supportedProtocols, this.getProtocol()) >= 0;\n }\n isState(...states) {\n return indexOf.call(states, this.getState()) >= 0;\n }\n getState() {\n if (this.webSocket) {\n for (let state in adapters.WebSocket) {\n if (adapters.WebSocket[state] === this.webSocket.readyState) {\n return state.toLowerCase();\n }\n }\n }\n return null;\n }\n installEventHandlers() {\n for (let eventName in this.events) {\n const handler = this.events[eventName].bind(this);\n this.webSocket[`on${eventName}`] = handler;\n }\n }\n uninstallEventHandlers() {\n for (let eventName in this.events) {\n this.webSocket[`on${eventName}`] = function() {};\n }\n }\n}\n\nConnection.reopenDelay = 500;\n\nConnection.prototype.events = {\n message(event) {\n if (!this.isProtocolSupported()) {\n return;\n }\n const {identifier: identifier, message: message, reason: reason, reconnect: reconnect, type: type} = JSON.parse(event.data);\n this.monitor.recordMessage();\n switch (type) {\n case message_types.welcome:\n if (this.triedToReconnect()) {\n this.reconnectAttempted = true;\n }\n this.monitor.recordConnect();\n return this.subscriptions.reload();\n\n case message_types.disconnect:\n logger.log(`Disconnecting. Reason: ${reason}`);\n return this.close({\n allowReconnect: reconnect\n });\n\n case message_types.ping:\n return null;\n\n case message_types.confirmation:\n this.subscriptions.confirmSubscription(identifier);\n if (this.reconnectAttempted) {\n this.reconnectAttempted = false;\n return this.subscriptions.notify(identifier, \"connected\", {\n reconnected: true\n });\n } else {\n return this.subscriptions.notify(identifier, \"connected\", {\n reconnected: false\n });\n }\n\n case message_types.rejection:\n return this.subscriptions.reject(identifier);\n\n default:\n return this.subscriptions.notify(identifier, \"received\", message);\n }\n },\n open() {\n logger.log(`WebSocket onopen event, using '${this.getProtocol()}' subprotocol`);\n this.disconnected = false;\n if (!this.isProtocolSupported()) {\n logger.log(\"Protocol is unsupported. Stopping monitor and disconnecting.\");\n return this.close({\n allowReconnect: false\n });\n }\n },\n close(event) {\n logger.log(\"WebSocket onclose event\");\n if (this.disconnected) {\n return;\n }\n this.disconnected = true;\n this.monitor.recordDisconnect();\n return this.subscriptions.notifyAll(\"disconnected\", {\n willAttemptReconnect: this.monitor.isRunning()\n });\n },\n error() {\n logger.log(\"WebSocket onerror event\");\n }\n};\n\nconst extend = function(object, properties) {\n if (properties != null) {\n for (let key in properties) {\n const value = properties[key];\n object[key] = value;\n }\n }\n return object;\n};\n\nclass Subscription {\n constructor(consumer, params = {}, mixin) {\n this.consumer = consumer;\n this.identifier = JSON.stringify(params);\n extend(this, mixin);\n }\n perform(action, data = {}) {\n data.action = action;\n return this.send(data);\n }\n send(data) {\n return this.consumer.send({\n command: \"message\",\n identifier: this.identifier,\n data: JSON.stringify(data)\n });\n }\n unsubscribe() {\n return this.consumer.subscriptions.remove(this);\n }\n}\n\nclass SubscriptionGuarantor {\n constructor(subscriptions) {\n this.subscriptions = subscriptions;\n this.pendingSubscriptions = [];\n }\n guarantee(subscription) {\n if (this.pendingSubscriptions.indexOf(subscription) == -1) {\n logger.log(`SubscriptionGuarantor guaranteeing ${subscription.identifier}`);\n this.pendingSubscriptions.push(subscription);\n } else {\n logger.log(`SubscriptionGuarantor already guaranteeing ${subscription.identifier}`);\n }\n this.startGuaranteeing();\n }\n forget(subscription) {\n logger.log(`SubscriptionGuarantor forgetting ${subscription.identifier}`);\n this.pendingSubscriptions = this.pendingSubscriptions.filter((s => s !== subscription));\n }\n startGuaranteeing() {\n this.stopGuaranteeing();\n this.retrySubscribing();\n }\n stopGuaranteeing() {\n clearTimeout(this.retryTimeout);\n }\n retrySubscribing() {\n this.retryTimeout = setTimeout((() => {\n if (this.subscriptions && typeof this.subscriptions.subscribe === \"function\") {\n this.pendingSubscriptions.map((subscription => {\n logger.log(`SubscriptionGuarantor resubscribing ${subscription.identifier}`);\n this.subscriptions.subscribe(subscription);\n }));\n }\n }), 500);\n }\n}\n\nclass Subscriptions {\n constructor(consumer) {\n this.consumer = consumer;\n this.guarantor = new SubscriptionGuarantor(this);\n this.subscriptions = [];\n }\n create(channelName, mixin) {\n const channel = channelName;\n const params = typeof channel === \"object\" ? channel : {\n channel: channel\n };\n const subscription = new Subscription(this.consumer, params, mixin);\n return this.add(subscription);\n }\n add(subscription) {\n this.subscriptions.push(subscription);\n this.consumer.ensureActiveConnection();\n this.notify(subscription, \"initialized\");\n this.subscribe(subscription);\n return subscription;\n }\n remove(subscription) {\n this.forget(subscription);\n if (!this.findAll(subscription.identifier).length) {\n this.sendCommand(subscription, \"unsubscribe\");\n }\n return subscription;\n }\n reject(identifier) {\n return this.findAll(identifier).map((subscription => {\n this.forget(subscription);\n this.notify(subscription, \"rejected\");\n return subscription;\n }));\n }\n forget(subscription) {\n this.guarantor.forget(subscription);\n this.subscriptions = this.subscriptions.filter((s => s !== subscription));\n return subscription;\n }\n findAll(identifier) {\n return this.subscriptions.filter((s => s.identifier === identifier));\n }\n reload() {\n return this.subscriptions.map((subscription => this.subscribe(subscription)));\n }\n notifyAll(callbackName, ...args) {\n return this.subscriptions.map((subscription => this.notify(subscription, callbackName, ...args)));\n }\n notify(subscription, callbackName, ...args) {\n let subscriptions;\n if (typeof subscription === \"string\") {\n subscriptions = this.findAll(subscription);\n } else {\n subscriptions = [ subscription ];\n }\n return subscriptions.map((subscription => typeof subscription[callbackName] === \"function\" ? subscription[callbackName](...args) : undefined));\n }\n subscribe(subscription) {\n if (this.sendCommand(subscription, \"subscribe\")) {\n this.guarantor.guarantee(subscription);\n }\n }\n confirmSubscription(identifier) {\n logger.log(`Subscription confirmed ${identifier}`);\n this.findAll(identifier).map((subscription => this.guarantor.forget(subscription)));\n }\n sendCommand(subscription, command) {\n const {identifier: identifier} = subscription;\n return this.consumer.send({\n command: command,\n identifier: identifier\n });\n }\n}\n\nclass Consumer {\n constructor(url) {\n this._url = url;\n this.subscriptions = new Subscriptions(this);\n this.connection = new Connection(this);\n this.subprotocols = [];\n }\n get url() {\n return createWebSocketURL(this._url);\n }\n send(data) {\n return this.connection.send(data);\n }\n connect() {\n return this.connection.open();\n }\n disconnect() {\n return this.connection.close({\n allowReconnect: false\n });\n }\n ensureActiveConnection() {\n if (!this.connection.isActive()) {\n return this.connection.open();\n }\n }\n addSubProtocol(subprotocol) {\n this.subprotocols = [ ...this.subprotocols, subprotocol ];\n }\n}\n\nfunction createWebSocketURL(url) {\n if (typeof url === \"function\") {\n url = url();\n }\n if (url && !/^wss?:/i.test(url)) {\n const a = document.createElement(\"a\");\n a.href = url;\n a.href = a.href;\n a.protocol = a.protocol.replace(\"http\", \"ws\");\n return a.href;\n } else {\n return url;\n }\n}\n\nfunction createConsumer(url = getConfig(\"url\") || INTERNAL.default_mount_path) {\n return new Consumer(url);\n}\n\nfunction getConfig(name) {\n const element = document.head.querySelector(`meta[name='action-cable-${name}']`);\n if (element) {\n return element.getAttribute(\"content\");\n }\n}\n\nexport { Connection, ConnectionMonitor, Consumer, INTERNAL, Subscription, SubscriptionGuarantor, Subscriptions, adapters, createConsumer, createWebSocketURL, getConfig, logger };\n","// Action Cable provides the framework to deal with WebSockets in Rails.\n// You can generate new channels where WebSocket features live using the `rails generate channel` command.\n\nimport { createConsumer } from \"@rails/actioncable\"\n\nexport default createConsumer()\n","import consumer from \"./consumer\"\n\nexport default () => consumer.subscriptions.create(\"ReservationsChannel\", {\n connected() {\n // Called when the subscription is ready for use on the server\n // console.log('in original connection!')\n },\n \n disconnected() {\n // Called when the subscription has been terminated by the server\n // console.log('Connection has been disconnected!')\n },\n\n rejected() {\n // console.log('Connection has been rejected!')\n },\n\n received(data) {\n // Called when there's incoming data on the websocket for this channel\n // console.log('in original received with data', data)\n }\n})\n","import consumer from \"./consumer\"\n\nexport default () => consumer.subscriptions.create(\"LiveWebAppNotificationsChannel\", {\n connected() {\n // Called when the subscription is ready for use on the server\n // console.log('in original connection!')\n },\n \n disconnected() {\n // Called when the subscription has been terminated by the server\n // console.log('Connection has been disconnected!')\n },\n\n rejected() {\n // console.log('Connection has been rejected!')\n },\n\n received(data) {\n // Called when there's incoming data on the websocket for this channel\n // console.log('in original received with data', data)\n }\n})\n","import React, { useEffect, useState } from \"react\"\nimport IPayment from \"../interfaces/IPayment\"\nimport { ReservationProps } from \"../interfaces\"\nimport * as Sentry from \"@sentry/react\"\n\nexport type LiveWebAppNotification = {\n camp_id: string\n type: \"payment\",\n data: LiveWebAppNotificationDataForPayment\n}\n\nexport type LiveWebAppNotificationDataForPayment = {\n payment: IPayment\n reservation?: ReservationProps\n}\n\ntype Channel = {\n received: (event: any) => void\n connected: () => void\n disconnected: () => void\n rejected: () => void\n consumer: {\n connection: {\n disconnected: boolean\n }\n }\n}\n\nconst useWebsocket = (\n onReceive: (event: any) => void,\n channel: Channel,\n dep: React.DependencyList\n) => {\n const [isConnected, setIsConnected] = useState(null)\n\n useEffect(() => {\n setTimeout(() => {\n if (isConnected == null && channel.consumer.connection.disconnected) {\n setIsConnected(false)\n }\n }, 10000)\n\n if (!channel.consumer.connection.disconnected) setIsConnected(true)\n\n channel.connected = () => setIsConnected(true)\n channel.disconnected = () => setIsConnected(false)\n channel.rejected = () => setIsConnected(false)\n }, [])\n\n useEffect(() => {\n const receivedFunc = (event: any) => {\n try {\n onReceive(event)\n } catch(err) {\n console.error(err)\n Sentry.captureException(err)\n }\n }\n channel.received = receivedFunc\n }, dep)\n\n return [isConnected]\n}\n\nexport default useWebsocket\n","import React, { createContext, useContext, ReactNode, useState, useEffect, useMemo, useCallback } from \"react\"\nimport { loadStripe, Stripe, StripeElements } from \"@stripe/stripe-js\"\nimport { CampingStyleProps, CampProps } from \"~/interfaces\"\nimport { stripeOptionsFn } from \"~/constants/stripe\"\nimport IInvoice from \"~/interfaces/IInvoice\"\nimport useGoogleAnalytics from \"~/hooks/useGoogleAnalytics\"\nimport IOrder from \"~/interfaces/IOrder\"\nimport { mapLineItemToParams, serviceRateMode } from \"~/api2/orders\"\nimport { useCreateOrderPreview } from \"~/hooks/useCreateOrderPreview\"\nimport useBuildPriceDetails from \"~/components/Invoices/PublicInvoices/useBuildPriceDetails\"\nimport createSubscriptionReservationChannel from \"../channels/reservations_channel\"\nimport createSubscriptionLiveWebAppNotificationsChannel from \"../channels/live_web_app_notifications_channel\"\nimport useWebsocket from \"~/hooks/useWebsocket\"\n\nconst stripePublicKey = import.meta.env.VITE_STRIPE_PUBKEY\n\nlet stripePromise: Promise | null = null\n\ntype InvoiceStripePaymentMethodType = \"card\" | \"us_bank_account\"\n\nexport const InvoicesPaymentStep = {\n invoice: \"invoice\",\n payment: \"payment\",\n processing: \"processing\",\n}\n\ninterface PaymentElementState {\n elementType: string\n collapsed: boolean\n empty: boolean\n complete: boolean\n value: {\n type: InvoiceStripePaymentMethodType\n }\n}\n\nexport type tInvoicePaymentsStep = (typeof InvoicesPaymentStep)[keyof typeof InvoicesPaymentStep]\n\ninterface InvoicesPaymentsContextState {\n camp: CampProps | undefined\n step: tInvoicePaymentsStep\n stripePromise: Promise | null\n stripeOptions: any\n preview: IOrder | undefined\n isLoading: boolean\n paymentMethod: InvoiceStripePaymentMethodType\n paymentIntentId: string | null\n paymentSuccess: boolean\n handleClickPayOnline: () => void\n handleBackToInvoices: () => void\n handlePaymentTypeChange: (event: any) => void\n handlePayNow: (elements: StripeElements) => void\n}\n\nconst initialState: InvoicesPaymentsContextState = {\n camp: undefined,\n step: InvoicesPaymentStep.invoice,\n stripePromise: null,\n stripeOptions: {},\n preview: undefined,\n isLoading: true,\n paymentMethod: \"card\",\n paymentIntentId: null,\n paymentSuccess: false,\n handleClickPayOnline: () => {},\n handleBackToInvoices: () => {},\n handlePaymentTypeChange: () => {},\n handlePayNow: () => {},\n}\n\nconst InvoicesPaymentsContext = createContext(initialState)\n\ninterface InvoicesPaymentsProviderProps {\n invoice: IInvoice\n children: ReactNode\n camp: CampProps\n campingStyle: CampingStyleProps\n}\n\nexport const InvoicesPaymentsProvider: React.FC = ({\n children,\n camp,\n invoice,\n campingStyle,\n}) => {\n const { trackForCamp, trackForPark } = useGoogleAnalytics(camp)\n const { data, isPending, mutate } = useCreateOrderPreview()\n const [step, setStep] = useState(InvoicesPaymentStep.invoice)\n const [isProcessing, setIsProcessing] = useState(false)\n const [paymentMethod, setPaymentMethod] = useState(\"card\")\n const { upsertIntent } = useBuildPriceDetails(invoice)\n const [paymentIntentId, setPaymentIntentId] = useState(null)\n const [paymentSuccess, setPaymentSuccess] = useState(false)\n const [reservationStates, setReservationStates] = useState({})\n\n const [ReservationChannel] = useState(() => createSubscriptionReservationChannel())\n const [LiveWebAppNotificationsChannel] = useState(() => createSubscriptionLiveWebAppNotificationsChannel())\n\n const handleReservationData = useCallback(\n (received: any) => {\n if (!received?.id) return\n if (received.site?.camp_id !== camp.id) return\n\n const mReservations = { ...reservationStates }\n const reservationId = received.id\n\n if (!mReservations[reservationId]) {\n mReservations[reservationId] = { persisted: null, updated: null }\n }\n\n mReservations[reservationId].persisted = received\n mReservations[reservationId].updated = null\n\n setReservationStates(mReservations)\n },\n [camp.id, reservationStates],\n )\n\n const handleNotificationData = useCallback(\n (notification: any) => {\n if (notification.camp_id !== camp.id) return\n if (notification.type !== \"payment\") return\n\n const receivedReservation = notification.data?.reservation\n\n if (!receivedReservation || !receivedReservation.id) return\n\n const mReservations = { ...reservationStates }\n const reservationId = receivedReservation.id\n\n if (!mReservations[reservationId]) {\n mReservations[reservationId] = { persisted: null, updated: null }\n }\n\n mReservations[reservationId].persisted = receivedReservation\n mReservations[reservationId].updated = null\n\n setReservationStates(mReservations)\n },\n [camp.id, reservationStates],\n )\n\n useWebsocket(handleReservationData, ReservationChannel, [camp.id, reservationStates])\n useWebsocket(handleNotificationData, LiveWebAppNotificationsChannel, [camp.id, reservationStates])\n\n useEffect(() => {\n if (!stripePromise && camp.stripe_account_id) {\n stripePromise = loadStripe(stripePublicKey, { stripeAccount: camp.stripe_account_id })\n }\n }, [camp.stripe_account_id])\n\n useEffect(() => {\n if (!invoice?.reservation?.id) return\n if (step !== InvoicesPaymentStep.processing) return\n\n const reservationState = reservationStates[invoice.reservation.id]\n if (!reservationState?.persisted) return\n\n if (reservationState.persisted.status === \"paid\") {\n setPaymentSuccess(true)\n\n setTimeout(() => {\n setStep(InvoicesPaymentStep.invoice)\n window.location.reload()\n }, 2000)\n }\n }, [reservationStates, invoice?.reservation?.id, step])\n\n useEffect(() => {\n const urlParams = new URLSearchParams(window.location.search)\n const paymentIntent = urlParams.get(\"payment_intent\")\n const paymentStatus = urlParams.get(\"redirect_status\")\n\n if (paymentIntent) {\n setPaymentIntentId(paymentIntent)\n }\n\n if (paymentStatus === \"succeeded\" && paymentIntent) {\n setStep(InvoicesPaymentStep.processing)\n }\n }, [])\n\n const getHashIdFromUrl = () => {\n const pathParts = window.location.pathname.split(\"/\")\n const iIndex = pathParts.findIndex((part) => part === \"i\")\n\n if (iIndex !== -1 && pathParts.length > iIndex + 1) {\n return pathParts[iIndex + 1]\n }\n\n return \"\"\n }\n\n const handleClickPayOnline = () => {\n setStep(InvoicesPaymentStep.payment)\n }\n\n const stripeOptions = useMemo(\n () =>\n invoice.reservation && stripeOptionsFn(invoice.reservation?.total_owed_in_cents, camp, invoice.reservation?.kind),\n [camp, invoice.reservation],\n )\n\n const handleBackToInvoices = () => {\n setStep(InvoicesPaymentStep.invoice)\n }\n\n const handlePaymentTypeChange = useCallback(\n async (event: PaymentElementState) => {\n mutate({\n order_id: invoice.order_id,\n service_rate_mode: serviceRateMode.payment_link,\n camp_id: camp.id,\n camping_style_id: campingStyle.id,\n is_credit_card_fee_enabled: true,\n discount_slug: \"\",\n line_items_attributes: invoice.order.line_items.map((li) => mapLineItemToParams(li, Number(li.tax_rate) > 0)),\n is_service_fee_enabled: true,\n selected_payment_method: event.value.type,\n })\n setPaymentMethod(event.value.type)\n },\n [mutate, invoice.order_id, camp.id, campingStyle.id, invoice.order.line_items],\n )\n\n const handlePayNow = useCallback(\n async (elements: StripeElements) => {\n trackForCamp(\"Click Pay Now\", { camp_id: camp.id, invoice_id: invoice.id })\n trackForPark(\"Click Pay Now\", { invoice_id: invoice.id })\n setIsProcessing(true)\n\n const currentHashId = getHashIdFromUrl()\n\n try {\n if (!stripePromise) {\n console.error(\"[STRIPE] stripe not loaded\")\n return\n }\n\n const stripe = await stripePromise\n\n if (!stripe || !elements) {\n console.error(\"[STRIPE] stripe or elements not available\")\n return\n }\n\n const { clientSecret } = await upsertIntent(paymentMethod)\n\n const { error: submitError } = await elements.submit()\n if (submitError) {\n throw new Error(submitError.message)\n }\n\n const result = await stripe.confirmPayment({\n elements,\n clientSecret,\n confirmParams: {\n return_url: currentHashId && `${window.location.origin}/i/${currentHashId}`,\n },\n redirect: \"if_required\",\n })\n\n if (result.paymentIntent?.id) {\n setPaymentIntentId(result.paymentIntent.id)\n }\n\n const isPaymentInitiated = () => {\n if (!result.paymentIntent) return false\n\n if (paymentMethod === \"card\") {\n return result.paymentIntent.status === \"succeeded\"\n }\n\n if (paymentMethod === \"us_bank_account\") {\n return [\"processing\", \"requires_capture\", \"requires_confirmation\", \"succeeded\"].includes(\n result.paymentIntent.status,\n )\n }\n\n return false\n }\n\n if (isPaymentInitiated()) {\n trackForCamp(\"payment_initiated\", {\n value: data?.order?.preview,\n currency: camp.currency,\n payment_method: paymentMethod,\n payment_intent_id: result.paymentIntent?.id,\n })\n\n setStep(InvoicesPaymentStep.processing)\n setIsProcessing(false)\n } else if (result.error) {\n setIsProcessing(false)\n throw new Error(result.error.message)\n } else {\n setIsProcessing(false)\n }\n } catch (err) {\n setIsProcessing(false)\n console.error(\"[PAYMENT ERROR]\", err)\n }\n },\n [trackForCamp, camp.id, invoice.id, trackForPark, upsertIntent, paymentMethod, camp.currency, data?.order?.preview],\n )\n\n const values = {\n camp,\n step,\n stripePromise,\n stripeOptions,\n preview: data?.order?.preview,\n isLoading: isPending || isProcessing,\n paymentMethod,\n handleClickPayOnline,\n handleBackToInvoices,\n handlePaymentTypeChange,\n handlePayNow,\n paymentIntentId,\n paymentSuccess,\n }\n\n return {children}\n}\n\nexport const useInvoicesPaymentsContext = () => {\n const context = useContext(InvoicesPaymentsContext)\n\n if (context === undefined) {\n throw new Error(\"useInvoicesPaymentsContext must be used within an InvoicesPaymentsProvider\")\n }\n\n return context\n}\n","import React, { Fragment, useCallback, useContext, useEffect, useRef, useState } from \"react\"\nimport { CampProps, CampingStyleProps, ReservationProps, SiteProps } from \"../../../interfaces\"\nimport Button from \"../../ui/Button\"\nimport moment, { Moment } from \"moment\"\nimport api from \"../../../api2\"\nimport { AdminContext } from \"~/contexts/AdminContext\"\nimport { ArrowLeftIcon, CalendarIcon, PlusIcon, PrinterIcon, UserIcon } from \"@heroicons/react/24/solid\"\nimport { formatName } from \"~/utils/formatName\"\nimport PreviewInvoiceToggle from \"./PreviewInvoiceToggle\"\nimport { formatCampAddress } from \"~/utils/formatAddress\"\nimport { PAYMENT_MODES, RESERVATION_KINDS, reservationKind, STATUSES } from \"~/constants\"\nimport * as Sentry from \"@sentry/react\"\nimport Spinner from \"../../ui/Spinner\"\nimport { FormProvider } from \"~/contexts/FormContext\"\nimport useAdminForm from \"../../../hooks/useAdminForm\"\nimport Form from \"../../ui/Admin/Form\"\nimport eSendingMode from \"../../../enums/eSendingMode\"\nimport SelectInput, { Option } from \"../../ui/SelectInput\"\nimport classNames from \"../../../utils/classNames\"\nimport { useCookies } from \"react-cookie\"\nimport { sendingInvoiceOptions } from \"../../Reservations/sendingOptions\"\nimport orders, { serviceRateMode } from \"~/api2/orders\"\nimport IOrderPreview from \"../../../interfaces/IOrderPreview\"\nimport { useReactToPrint } from \"react-to-print\"\nimport { useDebouncedCallback } from \"use-debounce\"\nimport IInvoice from \"../../../interfaces/IInvoice\"\nimport ILineItem from \"../../../interfaces/ILineItem\"\nimport { INVOICE_STATUSES } from \"~/decorators/InvoiceDecorator\"\nimport DiscountProps from \"../../../interfaces/DiscountProps\"\nimport parseDateTime from \"../../../utils/parseDateTime\"\nimport createMarkup from \"../../../utils/createMarkup\"\nimport { DayPickerSingleDateController } from \"react-dates\"\nimport { Menu, Transition } from \"@headlessui/react\"\nimport LineItemsTable from \"./EditInvoice/components/LineItemsTable\"\nimport MobileLineItemsTable from \"./EditInvoice/components/MobileLineItemsTable\"\nimport useSetTaxFees from \"~/components/Admin/Invoices/hooks/useSetTaxFees\"\nimport { cookieSendingModeInvoice } from \"./constants\"\nimport { initializeFormDataFor } from \"~/components/Admin/Invoices/utils\"\nimport { BoltIcon } from \"@heroicons/react/20/solid\"\nimport useApplyElectricFees from \"~/components/Admin/Invoices/hooks/useApplyElectricFees\"\nimport OrderSummary from \"~/components/Admin/Orders/OrderSummary\"\nimport isInvalidSendingMode from \"~/components/Reservations/components/IsInvalidSendingMode\"\nimport CheckboxWithLabelForForm from \"../../ui/CheckboxWithLabelForForm\"\nimport ProfileCard, { checkIsCamperEmpty } from \"../Campers/Camper/ProfileCard\"\nimport NewCamperModalContent from \"../Campers/NewCamperModalContent\"\nimport ICamper from \"~/interfaces/ICamper\"\nimport { ToggleFeesTypes } from \"../Reservations/NewReservationModal/FeesAndTaxesSettings\"\nimport { LINE_ITEM_KINDS } from \"~/constants/line_item_kinds\"\nimport api2 from \"../../../api2\"\nimport { usePreviews } from \"../Reservations/ReservationHooks/usePreviews\"\nimport { useOrder } from \"../Reservations/ReservationHooks/useOrder\"\nimport { useInvoicesPaymentsContext } from \"~/contexts/InvoicePaymentsProvider\"\n\nexport interface ILineItemLegacy {\n id?: string\n is_description_read_only?: boolean\n is_unit_price_read_only?: boolean\n is_quantity_read_only?: boolean\n description: string\n unit_price: number\n quantity: number\n total_price: number\n}\n\nexport type ILineItemField = Omit & {\n unit_amount: number\n total_amount: number\n is_hidden?: boolean\n}\n\nexport interface IFormData {\n electricity_fee: number\n last_meter_reading: number\n current_meter_reading: number\n to_name: string\n to_email: string\n to_phone: string\n to_address: string\n memo: string\n items: ILineItemField[]\n sending_mode: eSendingMode\n is_displaying_occurrences?: boolean\n due_date: string\n is_credit_card_fee_enabled: boolean\n is_tax_fee_enabled: boolean\n credit_card_rate?: number\n}\n\ninterface ComponentProps {\n invoice: IInvoice | undefined\n setSelectedInvoice?: (invoice: IInvoice) => any\n updateLocalInvoices?: (invoices?: IInvoice[]) => void\n onSuccess?: (invoice: IInvoice) => any\n campingStyle?: CampingStyleProps\n site: SiteProps | undefined\n isProcessing?: boolean\n disabled?: boolean\n className?: string\n customerView?: boolean\n isHidingBackButton?: boolean\n camp?: CampProps\n setCamp?: (camp: CampProps) => any\n cookies?: any\n printRef?: React.MutableRefObject\n isForPrint?: boolean\n hasPageBreak?: boolean\n setIsSlideoverOpen?: (v: boolean) => void\n}\n\nconst EditInvoice = (props: ComponentProps) => {\n const { camp: adminCamp } = useContext(AdminContext)\n const camp = props.camp || adminCamp\n const campingStyles = camp.camping_styles\n const campingStyle = props.campingStyle || campingStyles?.find((cs) => props.site?.camping_style_id === cs.id)\n const [cookies] = useCookies([cookieSendingModeInvoice])\n const [resource, setResource] = useState(\n props.invoice ? initializeFormDataFor(props.invoice, props.site, camp, !!props.customerView, cookies) : null,\n )\n const campDiscounts = camp.discounts\n const campingStyleDiscounts = campingStyle?.discounts ? campingStyle?.discounts : []\n const availableDiscounts = [...campDiscounts, ...campingStyleDiscounts]\n\n useEffect(() => {\n if (props.invoice) {\n setResource(initializeFormDataFor(props.invoice, props.site, camp, !!props.customerView, cookies))\n }\n }, [props.invoice, props.site, camp, props.customerView, cookies])\n\n if (!props.invoice || !resource) {\n return (\n
\n \n

Loading invoice data...

\n
\n )\n }\n\n return (\n
\n \n \n \n
\n )\n}\n\nconst AddressField = ({\n label,\n name,\n address,\n handleNameChange,\n handleAddressChange,\n textOnly,\n className,\n}: {\n label: string\n name: string\n address: string\n handleNameChange?: any\n handleAddressChange?: any\n textOnly?: boolean\n className?: string\n}) => {\n return (\n
\n \n {textOnly ? (\n <>\n {name}\n {address}\n \n ) : (\n <>\n \n \n \n )}\n
\n )\n}\n\nconst formatDateRange = (start_date: string, end_date: string, timezone: string) => {\n const startDate = parseDateTime(start_date, timezone, { asMoment: true })\n const endDate = parseDateTime(end_date, timezone, { asMoment: true })\n\n return startDate?.isSame(moment(), \"year\") && endDate?.isSame(moment(), \"year\")\n ? `${startDate?.format(\"MMM DD\")} - ${endDate?.format(\"MMM DD\")}`\n : `${startDate?.format(\"MMM DD YYYY\")} - ${endDate?.format(\"MMM DD, YYYY\")}`\n}\n\nexport const InvoiceForm = ({\n camp,\n customerView,\n invoice,\n site,\n campingStyle,\n isHidingBackButton,\n setSelectedInvoice,\n onSuccess,\n updateLocalInvoices,\n disabled,\n isProcessing,\n availableDiscounts,\n isForPrint,\n hasPageBreak,\n}: {\n camp: CampProps\n customerView: boolean\n invoice: IInvoice\n site: SiteProps\n campingStyle: CampingStyleProps\n isHidingBackButton: boolean\n setSelectedInvoice: (invoice: IInvoice) => void\n onSuccess: (invoice: IInvoice) => any\n updateLocalInvoices: (invoices?: IInvoice[]) => void\n disabled: boolean\n isProcessing: boolean\n availableDiscounts: DiscountProps[]\n isForPrint?: boolean\n hasPageBreak?: boolean\n}) => {\n const { setValue, resource, watch, updateDefaults, reset, getValues } = useAdminForm()\n const {\n updateLocalReservations,\n showNotification,\n showPaymentModal,\n orderInvoice,\n showModal,\n setIsSlideoverOpen,\n setSelectedCamper,\n selectedCamper,\n selectedReservation,\n } = useContext(AdminContext)\n const { handleClickPayOnline } = useInvoicesPaymentsContext()\n const [cookies, setCookie] = useCookies([cookieSendingModeInvoice])\n const [camper, setCamper] = useState(selectedCamper || invoice.reservation?.user?.camper)\n const [isLoading, setIsLoading] = useState(false)\n const [isShowingCc, setIsShowingCc] = useState(false)\n const [isPreview, setIsPreview] = useState(customerView)\n const [isLoadingPayOnline, setIsLoadingPayOnline] = useState(false)\n const items = watch(\"items\")\n const previews = usePreviews({\n serviceRate: serviceRateMode.payment_link,\n isPaid: selectedReservation?.status === STATUSES.PAID,\n orderId: selectedReservation?.order_id,\n campingStyleId: selectedReservation?.selected_camping_style_id || selectedReservation?.site?.camping_style_id,\n discount_type: selectedReservation?.discount_type,\n })\n const order = useOrder({ orderId: selectedReservation?.order_id })\n\n const hasMeterLocationId = !!(\n selectedReservation?.site?.wild_energy_meter_location_id ??\n invoice?.invoice?.reservation?.site?.wild_energy_meter_location_id\n )\n\n const isInitiatedTaxFee = !!invoice?.order?.tax_fee_in_cents\n\n const isInitiatedCreditCardFee =\n !!orderInvoice?.data?.order?.credit_card_fee_in_cents ||\n !!invoice?.order?.credit_card_fee_in_cents ||\n !!invoice?.order?.credit_card_rate\n\n const isCreditCardFeeEnabled = watch(\"is_credit_card_fee_enabled\") ?? isInitiatedCreditCardFee\n const isTaxFeeEnabled = watch(\"is_tax_fee_enabled\") ?? isInitiatedTaxFee\n\n const [sendingMode, setSendingMode] = useState(\n resource.sending_mode || (cookies && cookies[cookieSendingModeInvoice]) || eSendingMode.EMAIL,\n )\n const due_date = watch(\"due_date\")\n\n const targetRef = useRef(null)\n const { handleApplyFees } = useApplyElectricFees()\n\n const handleClickSave = () => {\n updateInvoice(false)\n }\n\n const handleClickSaveAndApplyElectricFees = useCallback(async () => {\n setIsLoading(true)\n try {\n // Apply electric fees\n await handleApplyFees(invoice)\n await updateInvoice(false, true)\n } catch (error) {\n console.error(\"Error applying electric fees and saving invoice:\", error)\n showNotification({\n type: \"error\",\n title: \"Error\",\n description: \"Failed to apply electric fees and save invoice.\",\n })\n } finally {\n setIsLoading(false)\n }\n }, [invoice, handleApplyFees, showNotification])\n\n const handleClickSaveAndTakePayment = async () => {\n await updateInvoice(false)\n showPaymentModal(invoice?.order?.unpaid_total_in_cents, {\n reservation: invoice?.reservation,\n closeCallback: () => refreshInvoice(invoice?.id),\n })\n }\n\n const refreshInvoice = (id: string) => {\n console.log(\"refetching invoice\", id)\n api.Invoices.find(camp.id, id)\n .then(({ invoice: updatedInvoice }) => {\n console.log(\"updated invoice\", updatedInvoice)\n setSelectedInvoice(updatedInvoice)\n updateLocalReservations([updatedInvoice.reservation])\n })\n .catch((err) => {\n console.error(err)\n showNotification({\n type: \"error\",\n title: \"Oops\",\n description: err.message,\n })\n })\n }\n\n const handleClickSendInvoice = () => {\n updateInvoice(true)\n }\n\n const updateInvoice = async (isSendingInvoice: boolean, avoidOnSuccess?: boolean) => {\n setIsLoading(true)\n\n let mInvoice = invoice\n\n if (!invoice?.id) {\n try {\n const reservationId = items.find((item) => item.reservation_id)?.reservation_id\n const { invoice: newInvoice } = await api.Invoices.createForReservation(\n reservationId,\n isCreditCardFeeEnabled,\n isTaxFeeEnabled,\n )\n setSelectedInvoice(newInvoice)\n mInvoice = newInvoice\n } catch (err) {\n console.log(\"error creating new invoice\", err)\n Sentry.captureException(err)\n showNotification({\n type: \"error\",\n title: \"Oops\",\n description: err.message,\n })\n setIsLoading(false)\n return\n }\n }\n\n const newSendDate = isSendingInvoice ? moment() : null\n console.log(\"updating invoice\", mInvoice.id, camp.id)\n return api.Invoices.update(mInvoice.id, camp.id, {\n isSending: isSendingInvoice,\n sendingMode: sendingMode || resource.sending_mode || eSendingMode.EMAIL,\n admin_email: isShowingCc ? camp.email : null,\n sendDate: newSendDate\n ? newSendDate\n : invoice.send_date\n ? moment(parseDateTime(invoice.send_date).toJSDate())\n : null,\n dueDate: resource.due_date ? parseDateTime(resource.due_date, camp.timezone, { asMoment: true }) : null,\n recipientEmail: resource.to_email,\n recipientPhone: resource.to_phone,\n recipientName: resource.to_name,\n recipientAddress: resource.to_address,\n memo: resource.memo,\n lastMeterReading: getValues(\"last_meter_reading\"),\n meterReading: getValues(\"current_meter_reading\"),\n isCreditCardFeeEnabled: isCreditCardFeeEnabled,\n lineItemsAttributes: getValues(\"items\").map((item) => ({\n id: item.id,\n kind: item.kind === \"custom\" ? \"basic\" : item.kind,\n label: item.label,\n totalAmountInCents: item.reservation_id ? Number(item.total_amount) * 100.0 : null,\n unitAmountInCents: item.reservation_id ? null : Number(item.unit_amount) * 100.0,\n quantity: item.quantity,\n occurrences: item.occurrences,\n occurrenceUnit: item.occurrence_unit,\n isTaxFeeEnabled: isTaxFeeEnabled,\n reservationId: item.reservation_id,\n addOnId: item.add_on_id,\n isAttachedToReservation: !!item.parent_line_item_id,\n is_updating_series: item.is_updating_series,\n })),\n })\n .then(({ invoice: updatedInvoice }) => {\n orderInvoice.refetch()\n updateLocalReservations([updatedInvoice.reservation])\n updateLocalInvoiceData(updatedInvoice)\n updateLocalFormData(updatedInvoice)\n setIsLoading(false)\n if (onSuccess && !avoidOnSuccess) onSuccess(updatedInvoice)\n showNotification({\n type: \"success\",\n title: isSendingInvoice ? \"Invoice sent\" : \"Invoice updated\",\n description: isSendingInvoice\n ? `Invoice ${updatedInvoice.hash_id} has been sent`\n : `Invoice ${updatedInvoice.hash_id} has been updated`,\n })\n })\n .catch((err) => {\n console.error(err)\n setIsLoading(false)\n showNotification({\n type: \"error\",\n title: \"Oops\",\n description: err.message,\n })\n })\n .finally(() => {\n order.refetch()\n previews.refetch()\n })\n }\n\n const updateLocalInvoiceData = (updated: IInvoice) => {\n if (updateLocalInvoices) updateLocalInvoices([updated])\n if (setSelectedInvoice) setSelectedInvoice(updated)\n }\n\n const updateLocalFormData = (updated: IInvoice) => {\n const formData = initializeFormDataFor(updated, site, camp, isPreview, cookies)\n updateDefaults(formData)\n reset(formData)\n }\n\n const addItem = () => {\n setValue(\"items\", [\n ...items,\n {\n id: null,\n label: \"\",\n unit_amount: 0,\n quantity: 1,\n total_amount: 0,\n kind: LINE_ITEM_KINDS.CUSTOM,\n tax_rate: items[0]?.tax_rate,\n order_id: invoice?.order_id,\n occurrences: null,\n occurrence_unit: null,\n add_on_id: null,\n reservation_id: null,\n parent_line_item_id: null,\n discount_id: null,\n is_updating_series: false,\n },\n ])\n }\n\n const onClickEditCamper = (setIsSlideoverOpen: (v) => Boolean) => {\n setIsSlideoverOpen?.(false)\n showModal(\n {\n setCamper(updatedCamper)\n selectedReservation && setSelectedCamper?.(updatedCamper)\n updateLocalInvoices?.()\n }}\n />,\n false,\n \"max-w-4xl\",\n {\n closeCallback: () => {\n setIsSlideoverOpen?.(true)\n },\n },\n )\n }\n\n useEffect(() => {\n !(sendingMode === eSendingMode.EMAIL || sendingMode === eSendingMode.EMAIL_AND_TEXT) && setIsShowingCc(false)\n }, [sendingMode])\n\n useEffect(() => {\n if (customerView && !selectedCamper && !invoice.reservation?.user?.camper && invoice.order?.camper_id) {\n api2.Camps.findCamper(invoice.order?.camper_id).then((res) => setCamper(res.camper))\n }\n }, [])\n\n const handlePrint = useReactToPrint({\n content: () => targetRef.current,\n })\n\n const isShowingSite = campingStyle?.is_showing_site_in_notifiers\n\n const isCamperEmpty = !camper || checkIsCamperEmpty(camper)\n\n return (\n
\n {customerView ? (\n
\n ) : (\n
\n {isHidingBackButton ? (\n
\n ) : (\n }\n onClick={() => setSelectedInvoice(null)}\n dataTestId=\"back-button\"\n >\n Back\n \n )}\n
\n {(camper?.first_name || camper?.last_name) &&\n (invoice.id ? \"Invoice for \" + formatName(camper) : \"New invoice for \" + formatName(camper))}\n
\n\n setIsPreview(!isPreview)}\n >\n \n
\n
\n )}\n
\n
\n
\n \n\n {isPreview && !camper ? (\n <>\n ) : (\n
\n To\n {camper ? (\n \n ) : (\n <>\n )}\n {!customerView ? (\n onClickEditCamper(setIsSlideoverOpen)}\n dataTestId=\"edit-camper-button\"\n >\n \n
{isCamperEmpty ? \"Add\" : \"Edit\"} guest
\n \n ) : (\n <>\n )}\n
\n )}\n
\n \n \n {customerView || isForPrint ? (\n {invoice.hash_id || invoice.reservation?.hashed_id}\n ) : (\n \n {invoice.hash_id || invoice.reservation?.hashed_id}\n \n )}\n\n {((invoice?.reservation?.kind == RESERVATION_KINDS.RECURRING && invoice.send_date) ||\n invoice?.reservation?.kind != RESERVATION_KINDS.RECURRING) && (\n <>\n \n \n {invoice.reservation?.kind == RESERVATION_KINDS.RECURRING\n ? parseDateTime(invoice?.send_date)?.toFormat(`MMMM dd, yyyy`)\n : parseDateTime(invoice?.reservation?.created_at)?.toFormat(`MMMM dd, yyyy`)}\n \n \n )}\n\n {(invoice?.reservation?.kind == RESERVATION_KINDS.RECURRING ||\n invoice?.reservation?.payment_mode == PAYMENT_MODES.PAYMENT_LINK) && (\n <>\n \n {isPreview ? (\n {parseDateTime(due_date, camp.timezone)?.toFormat(`MMMM dd, yyyy`)}\n ) : (\n setValue(\"due_date\", e.format())}\n selectedDate={parseDateTime(due_date, camp.timezone, { asMoment: true })}\n />\n )}\n \n )}\n\n \n \n {formatDateRange(invoice.reservation?.start_date, invoice.reservation?.end_date)}\n \n\n {isShowingSite && (\n <>\n \n {site?.name}\n \n )}\n\n {([RESERVATION_KINDS.RECURRING, RESERVATION_KINDS.FINAL_INVOICE] as reservationKind[]).includes(\n invoice?.reservation?.kind,\n ) && (\n <>\n \n
\n \n
\n\n \n
\n \n
\n
\n {!isForPrint && !isPreview && (\n \n \n {`${(hasMeterLocationId && \"Fetch reading\") || \"Save\"} and apply electric fees`}\n \n )}\n
\n \n )}\n
\n
\n \n \n }\n className={classNames(isPreview && \"hidden\", \"mt-2 lg:mt-0\")}\n dataTestId=\"add-item-button\"\n >\n Add Item\n \n
\n
\n {isPreview ? (\n resource.memo && (\n <>\n \n \n \n )\n ) : (\n <>\n \n \n \n )}\n
\n \n
\n
\n
\n {isForPrint ? (\n <>\n ) : customerView ? (\n
\n
\n 400 ? \"large\" : \"normal\"}\n className=\"custom-500:flex ml-0 md:ml-4 flex-shrink-0 justify-self-end items-center mr-2 lg:mr-0\"\n onClick={handlePrint}\n disabled={disabled || isProcessing || isLoading}\n dataTestId=\"print-button\"\n >\n \n Print\n \n {!invoice?.reservation?.long_term_reservation_id && (\n 400 ? \"large\" : \"normal\"}\n className=\"ml-4 flex-shrink-0 justify-self-end\"\n onClick={() => (window.location.href = `${window.origin}/r/${invoice?.reservation?.hashed_id}`)}\n dataTestId=\"view-reservation-button\"\n >\n View Reservation Info\n \n )}\n {invoice?.status !== STATUSES.PAID && (\n 400 ? \"large\" : \"normal\"}\n className=\"flex-shrink-0 justify-center flex items-center w-full ml-2\"\n onClick={handleClickPayOnline}\n dataTestId=\"pay-online-button\"\n >\n {isLoadingPayOnline ? : \"Pay Online\"}\n \n )}\n
\n {invoice?.status !== STATUSES.PAID && (\n Additional processing fees applied\n )}\n
\n ) : (\n
\n
\n o.value === sendingMode)}\n setSelected={(o: Option) => {\n setCookie(cookieSendingModeInvoice, o.value)\n setSendingMode(o.value)\n setValue(\"sending_mode\", o.value)\n }}\n warningText={\n isInvalidSendingMode(\n resource.to_email || camper?.email || \"\",\n resource.to_phone || camper?.phone || \"\",\n sendingMode,\n ) && (\n
\n {sendingMode === eSendingMode.EMAIL\n ? \"Will not send without a valid email\"\n : sendingMode === eSendingMode.TEXT\n ? \"Will not send without a valid phone number\"\n : \"Will not send without a valid email & phone number\"}\n
\n )\n }\n />\n {(sendingMode === eSendingMode.EMAIL || sendingMode === eSendingMode.EMAIL_AND_TEXT) && (\n
\n \n
\n )}\n
\n
\n {\n const prevIsPreview = isPreview\n setIsPreview(true)\n handlePrint()\n setIsPreview(prevIsPreview)\n }}\n disabled={disabled || isProcessing || isLoading}\n dataTestId=\"print-button\"\n >\n \n Print\n \n \n Save\n \n \n Send now\n \n
\n
\n )}\n
\n
\n {!isForPrint && (\n \n )}\n
\n
\n )\n}\n\nconst PrintableInvoiceForm = ({ invoice, camp, site, campingStyle, availableDiscounts }) => {\n return (\n
\n null}\n onSuccess={() => null}\n updateLocalInvoices={() => null}\n disabled\n isProcessing\n isForPrint\n />\n
\n )\n}\n\nconst Total = ({\n invoice,\n site,\n camp,\n isCustomerView,\n discounts,\n campingStyle,\n}: {\n invoice: IInvoice\n site: SiteProps\n camp: CampProps\n isCustomerView?: boolean\n discounts: DiscountProps[]\n campingStyle: CampingStyleProps\n}) => {\n const { watch, setValue } = useAdminForm()\n const [preview, setPreview] = useState()\n const [isPreview, setIsPreview] = useState(false)\n const [isLoading, setIsLoading] = useState(false)\n\n const localItems = watch(\"items\")\n const isLongTermAndHasElectricTaxRate =\n invoice.reservation?.kind === RESERVATION_KINDS.RECURRING && !!camp.electric_tax_rate\n\n const { taxFeeEnabled, creditCardFeeEnabled, TaxToggle } = useSetTaxFees({\n order: invoice?.order,\n campingStyle,\n onUpdateFees: (fees: Partial>) => {\n setValue(\"is_credit_card_fee_enabled\", !!fees.is_credit_card_fee_enabled)\n setValue(\"is_tax_fee_enabled\", isLongTermAndHasElectricTaxRate || !!fees.is_tax_enabled)\n },\n isLongTermElectric: isLongTermAndHasElectricTaxRate,\n isInvoice: true,\n })\n\n const isPaid =\n (isCustomerView && invoice?.status === INVOICE_STATUSES.PAID) || (preview ?? invoice?.order)?.status === \"paid\"\n\n const debouncedPreview = useDebouncedCallback((items: ILineItemField[]) => {\n const discount = discounts?.find((d) => d.id === items?.find((li) => li.discount_id)?.discount_id)\n if (isPaid && invoice?.order) {\n api.Orders.orderAndPreviewFor(\n invoice?.order?.id,\n camp.id,\n invoice?.reservation?.selected_camping_style_id || site?.camping_style_id,\n serviceRateMode.payment_link,\n isPaid,\n discount?.slug,\n )\n .then(({ order: o, preview: p }) => {\n setPreview((o as IOrderPreview) ?? p)\n setIsPreview(false)\n setIsLoading(false)\n })\n .catch((err) => {\n console.error(err)\n setIsLoading(false)\n })\n } else {\n api.Orders.createPreview({\n order_id: invoice?.order.id,\n camp_id: camp.id,\n camping_style_id: invoice.reservation?.selected_camping_style_id || site?.camping_style_id,\n is_credit_card_fee_enabled: creditCardFeeEnabled,\n is_service_fee_enabled: true,\n service_rate_mode: serviceRateMode.payment_link,\n discount_slug: discount?.slug,\n line_items_attributes: ((items && items) || []).map((item) => ({\n id: item.id,\n kind: item.kind,\n label: item.label,\n total_amount_in_cents: item.reservation_id ? Number(item.total_amount) * 100.0 : null,\n unit_amount_in_cents: item.reservation_id ? null : Number(item.unit_amount) * 100.0,\n quantity: item.quantity,\n occurrences: item.occurrences,\n occurrence_unit: item.occurrence_unit,\n is_tax_fee_enabled: taxFeeEnabled,\n reservation_id: item.reservation_id,\n add_on_id: item.add_on_id,\n is_attached_to_reservation: !!item.parent_line_item_id,\n })),\n })\n .then(({ order }) => {\n setPreview(order.preview)\n setIsPreview(true)\n setIsLoading(false)\n })\n .catch((err) => {\n console.error(err)\n setIsLoading(false)\n })\n }\n }, 300)\n\n useEffect(() => {\n setIsLoading(true)\n debouncedPreview(localItems)\n }, [invoice, localItems?.reduce((acc, item) => acc + item.total_amount, 0), taxFeeEnabled, creditCardFeeEnabled])\n\n if (!preview) {\n return <>\n }\n\n return (\n
\n {!isCustomerView && !isPaid && (\n
\n {isLoading && }\n {TaxToggle}\n
\n )}\n \n
\n )\n}\n\ninterface DatePickerProps {\n selectedDate: moment.Moment\n setSelectedDate: (value: moment.Moment) => void\n}\n\nconst DatePicker = (props: DatePickerProps) => {\n const { camp } = useContext(AdminContext)\n\n return (\n \n
\n \n \n {props.selectedDate?.format(\"MMMM Do\")}\n \n
\n\n \n \n props.selectedDate}\n date={parseDateTime(props.selectedDate?.toISOString(), camp.timezone, { asMoment: true })}\n onDateChange={(date) => props.setSelectedDate(date)}\n isOutsideRange={(day: Moment) => false}\n focused={true}\n onFocusChange={(e) => true}\n numberOfMonths={1}\n hideKeyboardShortcutsPanel={true}\n />\n \n \n
\n )\n}\n\nexport default EditInvoice\n","import { reservationKind, reservationStatus } from \"../constants\"\nimport eSendingMode from \"../enums/eSendingMode\"\nimport { SiteProps, ReservationProps, UserProps } from \"../interfaces\"\nimport ILongTermReservation from \"../interfaces/ILongTermReservation\"\nimport { PriceDetails } from \"../utils/priceDetailsFor\"\n\nclass ReservationDecorator implements ReservationProps {\n id?: string\n lock_version?: boolean\n hashed_id?: string\n vendor_id?: string\n is_manual_charge?: boolean\n start_date?: string\n end_date?: string\n status?: reservationStatus\n discount_type?: string\n discount_membership_id?: string\n is_checked_in?: boolean\n is_checked_out?: boolean\n is_invoice_sent?: boolean\n invoice_sent_at?: string\n passengers?: number\n pets_info?: string\n kind?: reservationKind\n kid_campers?: number\n notes?: string\n invoice_memo?: string\n total?: number\n total_owed_in_cents?: number\n total_paid_in_cents?: number\n park_fee_in_cents?: number\n price_details?: PriceDetails\n is_locked?: boolean\n electricity_fee_in_cents?: number\n last_meter_reading?: number\n meter_reading?: number\n stripe_payment_link_url?: string\n stripe_payment_link_admin_url?: string\n selected_camping_style_id?: string\n sending_mode?: eSendingMode\n grouped_reservation_id?: string\n site_id?: string\n site?: SiteProps\n user_id?: string\n user?: UserProps\n long_term_reservation_id?: string\n long_term_reservation?: ILongTermReservation\n created_at?: string\n updated_at?: string\n deleted_at?: string\n\n constructor(private reservation: ReservationProps) {\n Object.assign(this, reservation)\n }\n\n get remainingOwedBeforeFeesInCents() {\n if (!this.total_owed_in_cents) return null\n\n return Number(this.totalOwedBeforeFeesInCents) - (this.total_paid_in_cents || 0)\n }\n\n get totalOwedBeforeFeesInCents() {\n if (!this.total_owed_in_cents)\n return null\n\n if (this.price_details) {\n const parkFeeInCents = this.price_details?.service_fee * 100\n const taxFeeInCents = this.price_details?.tax * 100\n const creditCardFeeInCents = this.price_details?.credit_card_fee * 100\n return this.total_owed_in_cents - parkFeeInCents - taxFeeInCents - creditCardFeeInCents\n } else {\n return this.total_owed_in_cents\n }\n }\n}\n\nexport default ReservationDecorator\n","import React, { createContext, useContext, useState } from \"react\"\nimport { ReservationProps } from \"../../interfaces\"\nimport ReservationInvoiceWrapper from \"../../components/helpers/ReservationInvoiceWrapper\"\nimport ContextMenu, { ContextMenuDivider, ContextMenuItem } from \"../../components/ui/Admin/ContextMenu\"\nimport { AdminContext } from \"../AdminContext\"\nimport api from \"../../api2\"\nimport { RESERVATION_KINDS, STATUSES, reservationStatus } from \"../../constants\"\nimport DeleteConfirmationModalContent from \"../../components/Admin/Reservations/DeleteConfirmationModalContent\"\nimport {\n CheckBadgeIcon,\n CreditCardIcon,\n CurrencyDollarIcon,\n DocumentTextIcon,\n EnvelopeIcon,\n PencilSquareIcon,\n TrashIcon,\n UserIcon,\n} from \"@heroicons/react/20/solid\"\nimport EditInvoice from \"../../components/Admin/Invoices/EditInvoice\"\nimport ReservationDecorator from \"../../decorators/ReservationDecorator\"\n\ninterface ICtxPayload {\n showContextMenu: (\n reservationState: { persisted: ReservationProps; updated?: ReservationProps },\n e: React.MouseEvent,\n ) => any\n}\n\nconst initialContext = {\n showContextMenu: null,\n}\n\nexport const ReservationContextMenuContext = createContext(initialContext)\n\nexport const ReservationContextMenuProvider = ({ children }: { children: any }) => {\n const {\n camp,\n campingStyles,\n setSelectedReservation,\n setCurrentPage,\n setSelectedCamper,\n updateLocalReservations,\n showNotification,\n showModal,\n closeModal,\n showPaymentModal,\n showMessageModal,\n } = useContext(AdminContext)\n const [reservation, setReservation] = useState()\n const [menuPosition, setMenuPosition] = useState({ x: 0, y: 0 })\n const [isOpen, setIsOpen] = useState(false)\n const [isLoading, setIsLoading] = useState(false)\n\n const onClose = () => setIsOpen(false)\n\n const showContextMenu = (\n reservationState: { persisted: ReservationProps; updated?: ReservationProps },\n e: React.MouseEvent,\n ) => {\n setReservation(reservationState.persisted)\n setMenuPosition({ x: e.clientX, y: e.clientY })\n setIsOpen(true)\n }\n\n const onClickEdit = () => {\n setSelectedReservation(reservation)\n onClose()\n }\n\n const onClickViewCamper = () => {\n // TODO: make sure camper is accessible\n setSelectedCamper(reservation?.user?.camper)\n onClose()\n }\n\n const onClickCheckin = () => {\n setIsLoading(true)\n\n let is_checked_in: boolean = false\n let is_checked_out: boolean = false\n\n if (!reservation?.is_checked_in && !reservation?.is_checked_out) {\n is_checked_in = true\n is_checked_out = false\n } else if (reservation?.is_checked_in && !reservation?.is_checked_out) {\n is_checked_in = true\n is_checked_out = true\n } else if (reservation?.is_checked_in && reservation?.is_checked_out) {\n is_checked_in = false\n is_checked_out = false\n }\n\n api.Reservations.update(reservation.id, { is_checked_in, is_checked_out })\n .then(({ reservation: updated }) => {\n updateLocalReservations([updated])\n setIsLoading(false)\n onClose()\n })\n .catch((err) => {\n setIsLoading(false)\n showNotification({\n type: \"error\",\n title: \"Could not mark as checked-in\",\n description: err.message,\n })\n })\n }\n\n const onClickEditInvoice = () => {\n showModal(\n \n {({ orderInvoice }) => (\n cs.id === reservation?.site?.camping_style_id)}\n onSuccess={(invoice) => closeModal()}\n isHidingBackButton\n />\n )}\n ,\n true,\n \"max-w-7xl\",\n )\n }\n\n const onClickMarkPaid = () => {\n setIsLoading(true)\n api.Reservations.update(reservation.id, { status: STATUSES.PAID })\n .then(({ reservation: updated }) => {\n updateLocalReservations([updated])\n setIsLoading(false)\n onClose()\n })\n .catch((err) => {\n setIsLoading(false)\n showNotification({\n type: \"error\",\n title: \"Could not mark as checked-in\",\n description: err.message,\n })\n })\n }\n\n const onClickAcceptPayment = () => {\n const decoratedReservation = new ReservationDecorator(reservation)\n showPaymentModal(decoratedReservation.remainingOwedBeforeFeesInCents, { reservation })\n onClose()\n }\n\n const onClickDelete = () => {\n if (reservation.status !== STATUSES.BLOCKED) {\n showModal()\n } else {\n setIsLoading(true)\n api.Reservations.remove(reservation.id)\n .then(({ reservations }) => {\n updateLocalReservations(reservations)\n setIsLoading(false)\n onClose()\n })\n .catch((err) => {\n setIsLoading(false)\n showNotification({\n type: \"error\",\n title: err.message,\n dismissAfter: 7000,\n })\n })\n }\n }\n\n const isNonReservation = ([STATUSES.BLOCKED, STATUSES.IMPORTED] as reservationStatus[]).includes(reservation?.status)\n const isRecurring = reservation?.kind === RESERVATION_KINDS.RECURRING\n const isUnpaid = reservation?.status === STATUSES.UNPAID\n\n return (\n \n \n \n Edit reservation\n \n\n {(!isNonReservation && (\n \n {reservation?.is_checked_out\n ? \"Remove checked status\"\n : reservation?.is_checked_in\n ? \"Mark as checked-out\"\n : \"Mark as checked-in\"}\n \n )) || <>}\n {reservation?.user?.camper && (\n <>\n \n {\n setSelectedCamper(reservation?.user?.camper)\n setCurrentPage(\"guests\")\n }}\n icon={UserIcon}\n >\n View camper\n \n \n )}\n {((reservation?.user?.camper?.email ||\n reservation?.user?.camper?.phone ||\n reservation?.user?.email ||\n reservation?.user?.phone) && (\n showMessageModal({ reservations: [reservation] })} icon={EnvelopeIcon}>\n Send message\n \n )) || <>}\n\n \n {isRecurring ? (\n \n Edit invoice\n \n ) : (\n (reservation?.status != STATUSES.BLOCKED &&\n reservation?.status != STATUSES.IMPORTED &&\n reservation?.status != STATUSES.BLOCKED_IMPORT && (\n window.open(`/i/${reservation?.hashed_id}`)} icon={DocumentTextIcon}>\n View invoice\n \n )) || <>\n )}\n\n {(isUnpaid && (\n <>\n \n Mark as paid\n \n \n Accept payment\n \n \n \n )) || <>}\n \n Delete reservation\n \n \n {children}\n \n )\n}\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAirbnb = ({\n title,\n titleId,\n ...props\n}, ref) => /* @__PURE__ */ React.createElement(\"svg\", { width: 20, height: 20, viewBox: \"0 0 20 20\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", xmlnsXlink: \"http://www.w3.org/1999/xlink\", ref, \"aria-labelledby\": titleId, ...props }, title ? /* @__PURE__ */ React.createElement(\"title\", { id: titleId }, title) : null, /* @__PURE__ */ React.createElement(\"rect\", { x: 1.34766, y: 0.597534, width: 18, height: 18, rx: 9, fill: \"white\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 1.34766, y: 0.597534, width: 18, height: 18, rx: 9, stroke: \"#FF6A86\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 5.24805, y: 3.83942, width: 10.2, height: 10.9676, fill: \"url(#pattern0)\" }), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"pattern\", { id: \"pattern0\", patternContentUnits: \"objectBoundingBox\", width: 1, height: 1 }, /* @__PURE__ */ React.createElement(\"use\", { xlinkHref: \"#image0_585_2716\", transform: \"scale(0.00114025 0.00106045)\" })), /* @__PURE__ */ React.createElement(\"image\", { id: \"image0_585_2716\", width: 877, height: 943, xlinkHref: \"data:image/png;base64,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\" })));\nconst ForwardRef = forwardRef(SvgAirbnb);\nexport default ForwardRef;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBooking = ({\n title,\n titleId,\n ...props\n}, ref) => /* @__PURE__ */ React.createElement(\"svg\", { width: 20, height: 20, viewBox: \"0 0 20 20\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", xmlnsXlink: \"http://www.w3.org/1999/xlink\", ref, \"aria-labelledby\": titleId, ...props }, title ? /* @__PURE__ */ React.createElement(\"title\", { id: titleId }, title) : null, /* @__PURE__ */ React.createElement(\"rect\", { x: 1.34766, y: 1, width: 18, height: 18, rx: 9, fill: \"white\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 1.34766, y: 1, width: 18, height: 18, rx: 9, stroke: \"#00ADF4\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 3.16309, y: 6.013, width: 14.3691, height: 7.974, fill: \"url(#pattern1)\" }), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"pattern\", { id: \"pattern1\", patternContentUnits: \"objectBoundingBox\", width: 1, height: 1 }, /* @__PURE__ */ React.createElement(\"use\", { xlinkHref: \"#image0_2801_2965\", transform: \"matrix(0.00333333 0 0 0.00600667 0 -0.401)\" })), /* @__PURE__ */ React.createElement(\"image\", { id: \"image0_2801_2965\", width: 300, height: 300, xlinkHref: \"data:image/png;base64,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DeCiezROaBVWMK5qjBsscILwcLm+Ne+H/33Z/WseZD8QLU1qCBzPuQjKNDQOcBwEi9PVwOP66uHw+J68/3KuabWvXliLQZ7PJS6hH2PXYiskIkcY4CpYBeG+wbh8dxT5d+Tyya/OGR56gKO0ZUAo6ZNPF/IdXYj+azTXXNao1O4vB6UpN37IxdUxVLpkA1XmZVbOysOmZ22k+fk+v/b8MMhsfCGouOYb8oqdkjCNKAnD5EePYZD/rHh0iPTY+et/ghkTvxyvJy+qx+HxWPB/VTXMCzfHH818TCSIf/bavcPxgx1oLKYgAWYxZXjavDplQqQHHkiKp//80dXNsH4E1xavVuo7ZbPMaQnM8maGj6TA9fOvf+SIQ7nG0fWGf5yfL6zvjav9GNBay4dm1QG0UYbrSfggt67ibjA7zluN5hEU37mJNF14t2fSo8vywCXnJv7qULIi8auraklutcTBATUp7McQj6KmeGAwH+9Ph1G4CFPQc7cX7Xmhn9uiBXIxZ9wpVycMprvXKf50YaQ1H3rzTT+dbNl73fLpNl2W92LwO5x4VqcIdI3Ak1mQsrysXwaldgifl5HrGoxMwqlkyoZnoqtXEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQUAUVAEVAEFAFFQBFQBBQBRUARUAQWBIH/B+vweqnCDe3xAAAAAElFTkSuQmCC\" })));\nconst ForwardRef = forwardRef(SvgBooking);\nexport default ForwardRef;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgHipcamp = ({\n title,\n titleId,\n ...props\n}, ref) => /* @__PURE__ */ React.createElement(\"svg\", { width: 20, height: 20, viewBox: \"0 0 20 20\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", xmlnsXlink: \"http://www.w3.org/1999/xlink\", ref, \"aria-labelledby\": titleId, ...props }, title ? /* @__PURE__ */ React.createElement(\"title\", { id: titleId }, title) : null, /* @__PURE__ */ React.createElement(\"rect\", { x: 1.34766, y: 1.4873, width: 18, height: 18, rx: 9, fill: \"white\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 1.34766, y: 1.4873, width: 18, height: 18, rx: 9, stroke: \"#FD4D5D\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 4.42285, y: 3.80359, width: 11.8489, height: 11.8489, fill: \"url(#pattern2)\" }), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"pattern\", { id: \"pattern2\", patternContentUnits: \"objectBoundingBox\", width: 1, height: 1 }, /* @__PURE__ */ React.createElement(\"use\", { xlinkHref: \"#image0_2801_2966\", transform: \"scale(0.000520834)\" })), /* @__PURE__ */ React.createElement(\"image\", { id: \"image0_2801_2966\", width: 1920, height: 1920, xlinkHref: \"data:image/png;base64,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gAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgQIECBAgAABAgSGSaAapsEYCwECBAgQIECAAAECBAgQ6KdAOXpyb+x9+5aMeWNEuTaPqyNak+f1Ucqbef7vo2r9Y7RWfhqXXfa/qz/5k9+ed40XBAgQIECAAAECBAgQIEBgRAQUgEdkogyTAAECBAgQIECAAAECBNYWKJ3OrrzqiliJj0VV3R8l7sni7pUR1f48vy+PvXmM5XHuYzlf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AgQIECBAYAwCuV3pTPT7pyPKl8YwnSkIECDQbIGqejj6S680O0nZESBAgAABAgQIECAwSgEF4FFqGosAAQIECBAgQIBAywVKRBX96gfJcKDlFNInQIDAqASq/NPaK0defHL5b+yoRjUOAQIECBAgQIAAAQKNFVAAbuzSSowAAQIECBAgQIDABggc6N0V/fJuznzrBsxuSgIECDRUoNwZJd6LXu/2hiYoLQIECBAgQIAAAQIERiigADxCTEMRIECAAAECBAgQaLNAOXBgS3Srk3ml2vfSIa9Y8yBAgACBEQl0c5wfxFLn+TI/v2lEYxqGAAECBAgQIECAAIGGCigAN3RhpUWAAAECBAgQIEBgnALL25J2tj4UnXg95902zrnNRYAAgZYI7IxSzsambV+1FXRLVlyaBAgQIECAAAECBFYpoAC8SjjdCBAgQIAAAQIECBC4SKDX2xHd8mZuUXrXRUf9SIAAAQKjFXggqupMPPvKltEOazQCBAgQIECAAAECBJokoADcpNWUCwECBAgQIECAAIGNEjhfPZdXph3K6W39vFFrYF4CBNogMDiPcyy2fvRUG5KVIwECBAgQIECAAAECqxNQAF6dm14ECBAgQIAAAQIECHwsUA699OX88fV8bodCgAABAususDOqslieP3b7us9kAgIECBAgQIAAAQIEJlJAAXgil03QBAgQIECAAAECBOohUA4c2BKd8kpe9/u9jKhbj6hEQYAAgUYLDP7WPh2dpVdLr7e50ZlKjgABAgQIECBAgACBVQkoAK+KTScCBAgQIECAAAECBLLw0I2p2SejVAup4X6UfiUIECAwLoESWyM6p+JCPF7OnXNuZ1zu5iFAgAABAgQIECAwIQL+J2FCFkqYBAgQIECAAAECBGoosC1v+XsqotxZw9iERIAAgYYLlK/k3+DX4z//O/8WexAgQIAAAQIECBAgQOAzAQXgzyz8RIAAAQIECBAgQIDAkALLV5xdqF7M5j8asotmBAgQIDB6gfmYvXDAVcCjhzUiAQIECBAgQIAAgUkWUACe5NUTOwECBAgQIECAAIGNEvj1r+/Jqc/k84aNCsG8BAgQIBA35i4M78QvPsirgT0IECBAgAABAgQIECDwDwEFYL8JBAgQIECAAAECBAisSCDv/bstSvfV7PRQPqsVddaYAAECBEYpMPgb/PXodhbK/Mkd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jgcbkZAkCBAgQIAAAQIEmi6wO6rqjdi97/4SUTU9WfkRIECAAAECBOomoABctxURDwECBAgQIEDgIoHlrZ+7m5+NEi/n4S0XveVHAgQIECBAgAABAnUVGBR9H43SPxu93mxdgxQXAQIECBAgQKCpAgrATV3Z/5+9e3+So7oSRb2yqrvVeoBeCIkx4m1sg41tDDaMX43BMkLuRhIU1gNBA6J5mIdnztwT98f+627EjRvj48FBXM+9cX8+MQ8HtifmDKDu2nd122AhJNHVXdVVmflVREF1Zu691/p2R6grV+ZOeREgQIAAAQLNEPj1747kPRPn831rMxKSBQECBAgQIECAQGsESjkdl7p/25p8JUqAAAECBAgQmBABBeAJmQhhECBAgAABAgSuFCi93kx0Vk/n9hP59nfblUB+JkCAAAECBAgQmHSBw1Gtvl1On75l0gMVHwECBAgQIECgSQJOJDZpNuVCgAABAgQINEvgUtyXz057M5Pa2azEZEOAAAECBAgQINASgW4+AvjxiKmX8uJGf9O2ZNKlSYAAAQIECIxfQAF4/HMgAgIECBAgQIDA5wT+fIKsejV33P25nTYQIECAAAECBAgQqI/AnijxXFyKb5SsBtcnbJESIECAAAECBOoroABc37kTOQECBAgQINBQgbK83InVeDLv/l1b+nmmoWlKiwABAgQIECBAoD0C90ensxS93v72pCxTAgQIECBAgMD4BBSAx2dvZAIECBAgQIDA5wTW74r49ft3RaleiSi3fe4AGwgQIECAAAECBAjUT2AqSunFpeqJ+oUuYgIECBAgQIBA/QQUgOs3ZyImQIAAAQIEmizQ683GVPVcppjPSrNEXpOnWm4ECBAgQIAAgZYJ7Mm/bl8vp0/f3rK8pUuAAAECBAgQ2HYBBeBtJzcgAQIECBAgQOA6ApfiK3+++zdmr3OUXQQIECBAgAABAgTqJrB2HvLhiKnz5fjxHXULXrwECBAgQIAAgToJKADXabbESoAAAQIECDRaoPR6eyI6f59LP7srotEzLTkCBAgQIECAQGsF9kSJ52PHjT8uy8vOS7b210DiBAgQIECAwKgF/KE1amH9EyBAgAABAgQ2IJDF326sVM9EVY7n4d0NNHEIAQIECBAgQIAAgToKfC2q/tvx/vsH6xi8mAkQIECAAAECdRBQAK7DLImRAAECBAgQ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4vhXeQfwPZdv9pkAAQIECBAgQIAAAQIECBAYucBMlHIqYvrnZWlpeuSjGYAAAQIECNREQAG4JhMlTAIECBCYUIF+96mM7Cf5tvTzhE6RsAgQIECAAAECBAgQIECg0QJHMru3439+cGujs5QcAQIECBAYQEABeAAshxIgQIAAgcsFyqlf3BudeDW35TOAvQgQIECAAAECBAgQIECAAIExCXwrpuLc+mOaxhSAYQkQIECAwCQJKABP0myIhQABAgRqI1B6vb25zNRSlOqBDNrdv7WZOYESIECAAAECBAgQIECAQAMFuhGdl+Of3v9eA3OTEgECBAgQGFhAAXhgMg0IECBAoO0C61cUX6oeS4devne23UP+BAgQIECAAAECBAgQIEBg/ALl9iidd/OC7bUlob0IECBAgECrBRSAWz39kidAgACBTQn80z/dlPf8Xsz3bZtqrxEBAgQIECBAgAABAgQIECAwbIFuVOWxWOkcL3NzU8PuXH8ECBAgQKBOAgrAdZotsRIgQIDA2AXySuL8QjlzLgP56diDEQABAgQIECBAgAABAgQIECBwucChiP6vYv/h+4vHNV3u4jMBAgQItExAAbhlEy5dAgQIENiiQH/qqxHll9nLzBZ70pwAAQIECBAgQIAAAQIECBAYrkCVdd8H8nv7y3Hswq7hdq03AgQIECBQHwEF4PrMlUgJECBAYMwCeffvnuivvhIljo45FMMTIECAAAECBAgQIECAAAEC1xY4Fbs//Ntr77aHAAECBAg0W0ABuNnzKzsCBAgQGJLA+tLPq3Eiu+vle8eQutUNAQIECBAgQIAAAQIECBAgMHyBv4mqeju/y39p+F3rkQABAgQITL6AAvDkz5EICRAgQGASBD6KO6NUb2YovjxOwnyIgQABAgQIECBAgAABAgQIXFugm6t3/TBW4lyZn7cU9LWd7CFAgACBhgooADd0YqVFgAABAsMTyCuGZ6Jbncwe15aPyucJeREgQIAAAQIECBAgQIAAAQITLrAvovNydHZ/o/guP+FTJTwCBAgQGLaAAvCwRfVHgAABAs0T6HcfyKQu5nuqecnJiAABAgQIECBAgAABAgQINFWg3Bud/ktx8uTepmYoLwIECBAgcDUBBeCrqdhGgAABAgT+IpB3/+6Nfv9X+ePdUAgQIECAAAECBAgQIECAAIFaCayd/34uqh1P1ipqwRIgQIAAgS0KKABvEVBzAgQIEGiuQJmbm4qVzunM8Kf5dvdvc6daZgQIECBAgAABAgQIECDQXIF9UfXfLifP3NHcFGVGgAABAgQ+K6AA/FkPPxEgQIAAgb8K7D/85YiymBtu+utGnwgQIECAAAECBAgQIECAAIEaCVRRqm9EtXqmLC7O1ihuoRIgQIAAgU0LKABvmk5DAgQIEGiyQC79vCeLv89njo/m27+XTZ5suREgQIAAAQIECBAgQIBA0wX2RFW9En/8z7myvOw7ftNnW34ECBAg4IS23wECBAgQIHBVgZX4bm5/Od/TV91vIwECBAgQIECAAAECBAgQIFAXgbwLOO6JqN6K9947XJegxUmAAAECBDYr4GqnzcppR4AAAQKNFSgnT+7LL4WvZYKHGpukxAgQIECAAAECBAgQIECAQPsEnogy/WT70pYxAQIECLRNQAG4bTMuXwIECBC4rkBZWpqOaqaXBz2e7+51D7aTAAECBAgQIECAAAECBAgQqJPAjnzc01tloZd3A3sRIECAAIHmCigAN3duZUaAAAECAwqUvO03/uVPD2azV/N9YMDmDidAgAABAgQIECBAgAABAgQmX+D+6FZvl15v7+SHKkICBAgQILA5AQXgzblpRYAAAQJNFFhY2BOdcjZTWysCV01MUU4ECBAgQIAAAQIECBAgQKDlAjvyecAn41L1WFledn685b8M0idAgEBTBfwD19SZlRcBAgQIDC4wteNHuRTU89nQ0s+D62lBgAABAgQIECBAgAABAgTqIVDFrXnZ95vx3ntH6xGwKAkQIECAwGACCsCDeTmaAAECBBoqUE6c259XAL+T6R1saIrSIkCAAAECBAgQIECAAAECBP4ssHZe/LEoU70yNzcFhQABAgQINE1AAbhpMyofAgQIEBhYIJ/7040dq3nnb/XIwI01IECAAAECBAgQIECAAAECBOooMJV3Ab8W+w59vY7Bi5kAAQIECFxPQAH4ejr2ESBAgEA7BC7Fd6KUC5nsDe1IWJYECBAgQIAAAQIECBAgQIBArgR2e1TVm3lh+B4aBAgQIECgSQIKwE2aTbkQIECAwMAC+SXvQH7Zu5gNv53vauAONCBAgAABAgQIECBAgAABAgTqKjCdgc/HSue0paDrOoXiJkCAAIGrCSgAX03FNgIECBBohcD60s8rncez7Hsu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CBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAaE2ARgAAAlHSURBVAIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBAgQIAAgdEJ/D+gK3CRohuJXAAAAABJRU5ErkJggg==\" })));\nconst ForwardRef = forwardRef(SvgHipcamp);\nexport default ForwardRef;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgVrbo = ({ title, titleId, ...props }, ref) => /* @__PURE__ */ React.createElement(\"svg\", { width: 19, height: 19, viewBox: \"0 0 19 19\", fill: \"none\", xmlns: \"http://www.w3.org/2000/svg\", xmlnsXlink: \"http://www.w3.org/1999/xlink\", ref, \"aria-labelledby\": titleId, ...props }, title ? /* @__PURE__ */ React.createElement(\"title\", { id: titleId }, title) : null, /* @__PURE__ */ React.createElement(\"rect\", { x: 0.5, y: 0.5, width: 18, height: 18, rx: 9, fill: \"white\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 0.5, y: 0.5, width: 18, height: 18, rx: 9, stroke: \"#457EC1\" }), /* @__PURE__ */ React.createElement(\"rect\", { x: 1.75977, y: 7.02954, width: 15.4795, height: 4.95223, fill: \"url(#pattern3)\" }), /* @__PURE__ */ React.createElement(\"defs\", null, /* @__PURE__ */ React.createElement(\"pattern\", { id: \"pattern3\", patternContentUnits: \"objectBoundingBox\", width: 1, height: 1 }, /* @__PURE__ */ React.createElement(\"use\", { xlinkHref: \"#image0_2801_2964\", transform: \"scale(0.000390625 0.001221)\" })), /* @__PURE__ */ React.createElement(\"image\", { id: \"image0_2801_2964\", width: 2560, height: 819, xlinkHref: \"data:image/png;base64,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\" })));\nconst ForwardRef = forwardRef(SvgVrbo);\nexport default ForwardRef;\n","export default \"data:image/svg+xml,%3csvg%20width='106'%20height='106'%20viewBox='0%200%20106%20106'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20fill-rule='evenodd'%20clip-rule='evenodd'%20d='M44.7535%2011.7248C42.1647%2012.9053%2039.8602%2014.629%2037.9966%2016.7789C35.1587%2016.5769%2032.3106%2016.9878%2029.6457%2017.9839C26.9807%2018.9799%2024.5612%2020.5377%2022.5515%2022.5515C20.5377%2024.5612%2018.9799%2026.9807%2017.9839%2029.6457C16.9878%2032.3106%2016.5769%2035.1587%2016.7789%2037.9966C12.5875%2041.6359%209.93751%2047.0066%209.93751%2053C9.93426%2055.8449%2010.5431%2058.6572%2011.7228%2061.2459C12.9025%2063.8347%2014.6254%2066.1394%2016.7745%2068.0034C16.5721%2070.842%2016.9829%2073.6908%2017.9789%2076.3566C18.975%2079.0223%2020.5329%2081.4426%2022.5471%2083.4529C24.5577%2085.4665%2026.978%2087.0238%2029.6438%2088.0191C32.3096%2089.0144%2035.1583%2089.4243%2037.9966%2089.2211C39.8602%2091.371%2042.1647%2093.0947%2044.7535%2094.2752C47.3423%2095.4556%2050.1548%2096.0652%2053%2096.0625C55.8452%2096.0652%2058.6577%2095.4556%2061.2465%2094.2752C63.8353%2093.0947%2066.1398%2091.371%2068.0034%2089.2211C70.8412%2089.4228%2073.6893%2089.0117%2076.3542%2088.0157C79.0192%2087.0197%2081.4386%2085.4621%2083.4485%2083.4485C85.4621%2081.4386%2087.0197%2079.0191%2088.0157%2076.3542C89.0117%2073.6893%2089.4228%2070.8413%2089.2211%2068.0034C91.371%2066.1398%2093.0947%2063.8353%2094.2752%2061.2465C95.4556%2058.6577%2096.0652%2055.8452%2096.0625%2053C96.0658%2050.1551%2095.4569%2047.3428%2094.2772%2044.7541C93.0975%2042.1653%2091.3746%2039.8607%2089.2255%2037.9966C89.4272%2035.1588%2089.0162%2032.3107%2088.0201%2029.6458C87.0241%2026.9809%2085.4665%2024.5614%2083.4529%2022.5515C81.4427%2020.5371%2079.0225%2018.979%2076.3567%2017.9829C73.6909%2016.9869%2070.842%2016.5762%2068.0034%2016.7789C64.3641%2012.5875%2058.9934%209.93751%2053%209.93751C50.1548%209.9348%2047.3423%2010.5444%2044.7535%2011.7248ZM47.4581%2038.6211C47.8589%2038.2288%2048.4127%2038%2049%2038H60.75C61.3373%2038%2061.8911%2038.2288%2062.2919%2038.6211C62.6911%2039.0118%2062.9063%2039.5313%2062.9063%2040.0625V65.9375C62.9063%2066.4687%2062.6911%2066.9882%2062.2919%2067.3789C61.8911%2067.7712%2061.3373%2068%2060.75%2068H49C48.4127%2068%2047.8589%2067.7712%2047.4581%2067.3789C47.0589%2066.9882%2046.8438%2066.4687%2046.8438%2065.9375V58.75C46.8438%2057.5074%2045.8364%2056.5%2044.5938%2056.5C43.3511%2056.5%2042.3438%2057.5074%2042.3438%2058.75V65.9375C42.3438%2067.6938%2043.0571%2069.3681%2044.3105%2070.5949C45.5623%2071.8201%2047.2501%2072.5%2049%2072.5H60.75C62.4999%2072.5%2064.1877%2071.8201%2065.4395%2070.5949C66.6929%2069.3681%2067.4063%2067.6938%2067.4063%2065.9375V40.0625C67.4063%2038.3062%2066.6929%2036.6319%2065.4395%2035.4051C64.1877%2034.1799%2062.4999%2033.5%2060.75%2033.5H49C47.2501%2033.5%2045.5623%2034.1799%2044.3105%2035.4051C43.0571%2036.6319%2042.3438%2038.3062%2042.3438%2040.0625V47.25C42.3438%2048.4926%2043.3511%2049.5%2044.5938%2049.5C45.8364%2049.5%2046.8438%2048.4926%2046.8438%2047.25V40.0625C46.8438%2039.5313%2047.0589%2039.0118%2047.4581%2038.6211ZM40.2925%2048.858C41.1806%2047.9888%2041.1959%2046.5643%2040.3268%2045.6762C39.4576%2044.7881%2038.033%2044.7728%2037.145%2045.642L31.27%2051.392C30.8375%2051.8153%2030.5938%2052.3949%2030.5938%2053C30.5938%2053.6051%2030.8375%2054.1847%2031.27%2054.608L37.145%2060.358C38.033%2061.2272%2039.4576%2061.2119%2040.3268%2060.3238C41.1959%2059.4357%2041.1806%2058.0112%2040.2925%2057.142L38.3594%2055.25H57.8125C59.0551%2055.25%2060.0625%2054.2426%2060.0625%2053C60.0625%2051.7574%2059.0551%2050.75%2057.8125%2050.75H38.3594L40.2925%2048.858Z'%20fill='%233A8860'/%3e%3c/svg%3e\"","import React, { CSSProperties, useContext, useEffect, useRef, useState } from \"react\"\nimport { CampProps, ReservationProps } from \"../../interfaces\"\nimport { STATUSES, reservationStatus } from \"~/constants\"\nimport classNames from \"../../utils/classNames\"\nimport {\n ArrowPathRoundedSquareIcon,\n EnvelopeIcon,\n GlobeAltIcon,\n NoSymbolIcon,\n CurrencyDollarIcon,\n} from \"@heroicons/react/24/outline\"\nimport { BuildingLibraryIcon, CheckBadgeIcon as CheckBadgeIconSolid } from \"@heroicons/react/24/solid\"\nimport moment from \"moment\"\nimport { Transition } from \"@headlessui/react\"\nimport { LockClosedIcon, UserGroupIcon, CreditCardIcon, DocumentTextIcon, LinkIcon } from \"@heroicons/react/20/solid\"\nimport HoverTip from \"../ui/HoverTip\"\nimport { ReservationContextMenuContext } from \"~/contexts/admin/ReservationContextMenuContext\"\nimport AirBnb from \"images/vendor_icons/Airbnb.svg?react\"\nimport Booking from \"images/vendor_icons/booking.svg?react\"\nimport Hipcamp from \"images/vendor_icons/hipcamp.svg?react\"\nimport Vrbo from \"images/vendor_icons/vrbo.svg?react\"\nimport ArrowLeftOnRectangleIconSolid from \"images/park__icon_ux__check_out.svg\"\nimport CAMP_SLUGS_WITH_CAMPER_COMPANY_NAME_FIELD from \"../../constants/camp_slugs_with_company_name_field\"\nimport { CalendarApi } from \"@fullcalendar/core\"\n\ninterface ReservationStateProps {\n persisted: ReservationProps\n updated?: ReservationProps\n}\n\ninterface ComponentProps {\n camp: CampProps\n reservations: { [reservationId: string]: ReservationStateProps } | undefined\n eventInfo: any // TODO: this should be the FullCalendar event\n setSelected: (reservation: ReservationProps) => void\n isSelected: boolean\n calendarApi: CalendarApi | undefined\n isQuarterlyView: boolean\n}\n\nconst EventButton = (props: ComponentProps) => {\n const { showContextMenu } = useContext(ReservationContextMenuContext)\n const containerRef = useRef()\n const textContentRef = useRef()\n const [containerWidth, setContainerWidth] = useState()\n const [isSmall, setIsSmall] = useState(false)\n const [isOverflow, setIsOverflow] = useState(false)\n const event = props.eventInfo.event\n const reservationState: ReservationStateProps = props.reservations[event.id]\n const persistedReservation = reservationState?.persisted\n\n const [isChanged, setIsChanged] = useState(reservationState?.updated != null)\n\n const reservation: ReservationProps = reservationState?.updated || reservationState?.persisted\n\n useEffect(() => {\n setIsChanged(reservationState.updated != null)\n }, [reservationState.updated])\n\n // NOTE: optional in case of blocked reservation (no user/camper)\n const isUsingCompanyName = CAMP_SLUGS_WITH_CAMPER_COMPANY_NAME_FIELD.includes(props.camp.slug)\n const companyName = persistedReservation?.user?.camper?.company_name\n const { email, first_name, last_name } = persistedReservation?.user?.camper || persistedReservation.user || {}\n const eventTitle =\n isUsingCompanyName && companyName\n ? companyName\n : last_name && first_name\n ? `${last_name}, ${first_name}`\n : last_name || first_name || email\n const amountOfNights = moment(persistedReservation.end_date).diff(persistedReservation.start_date, \"days\")\n\n const changeBlockedImporteStatus = () =>\n ({\n [props.eventInfo.event.id]: {\n persisted: {\n ...reservationState.persisted,\n status: \"blocked-import\",\n },\n updated: reservationState?.updated\n ? {\n ...reservationState.updated,\n status: \"blocked-import\",\n }\n : null,\n },\n }) as { [reservationId: string]: ReservationStateProps }\n\n const buttonStylesFor = (reservation: ReservationProps): CSSProperties => {\n return {\n background: isChanged ? \"white\" : eventColorFor(reservation, true),\n boxShadow: `0 0 0 1px ${eventColorFor(reservation, false)} inset`,\n color: isChanged ? \"black\" : \"white\",\n border: eventBorder(reservation.status),\n outlineOffset: props.isSelected ? \"0px\" : undefined,\n }\n }\n\n const importKindStyle = (kind?: string) => {\n switch (kind) {\n case \"airbnb\":\n return {\n color: `#FF6A86`,\n blockedColor: `repeating-linear-gradient(45deg, #fff, #fff 5px, #FFB0B8 5px, #FFB0B8 10px)`,\n blockedBorder: \"1px solid #FD4D5D\",\n image: AirBnb,\n }\n case \"hipcamp\":\n return {\n color: `#FD4D5D`,\n blockedColor: `repeating-linear-gradient(45deg, #fff, #fff 5px, #FFB0B8 5px, #FFB0B8 10px)`,\n blockedBorder: \"1px solid #FD4D5D\",\n image: Hipcamp,\n }\n case \"booking\":\n return {\n color: `#00ADF4`,\n blockedColor: `repeating-linear-gradient(45deg, #fff, #fff 5px, #84CFEE 5px, #84CFEE 10px)`,\n blockedBorder: \"1px solid #00ADF4\",\n image: Booking,\n }\n case \"vrbo\":\n return {\n color: `#457EC1`,\n blockedColor: `repeating-linear-gradient(45deg, #fff, #fff 5px, #76A2D5 5px, #76A2D5 10px)`,\n blockedBorder: \"1px solid #457EC1\",\n image: Vrbo,\n }\n default:\n return {\n color: `#FD4D5D`,\n blockedColor: `repeating-linear-gradient(45deg, #fff, #fff 5px, #FFB0B8 5px, #FFB0B8 10px)`,\n blockedBorder: \"1px solid #FD4D5D\",\n image: Hipcamp,\n }\n }\n }\n\n const eventBorder = (status: reservationStatus): string => {\n if (status === STATUSES.BLOCKED) {\n return \"1px solid #CDCDCD\"\n } else if (status === STATUSES.PAID) {\n return \"1px solid #78AC6B\"\n } else if (status === STATUSES.UNPAID) {\n return \"1px solid #AAD09F\"\n } else if (status === STATUSES.IMPORTED) {\n return \"1px solid #fff\"\n } else if (status === STATUSES.BLOCKED_IMPORT) {\n return importKindStyle(\n reservation.site?.vendor_calendars?.find((calendar) => calendar.id === reservation.vendor_calendar_id)?.kind,\n ).blockedBorder\n }\n }\n\n const eventColorFor = (reservation: ReservationProps, background?: boolean): string => {\n switch (reservation.status) {\n case STATUSES.IMPORTED:\n return importKindStyle(\n reservation.site?.vendor_calendars?.find((calendar) => calendar.id === reservation.vendor_calendar_id)?.kind,\n ).color\n case STATUSES.BLOCKED_IMPORT:\n return importKindStyle(\n reservation.site?.vendor_calendars?.find((calendar) => calendar.id === reservation.vendor_calendar_id)?.kind,\n ).blockedColor\n case STATUSES.BLOCKED:\n return `repeating-linear-gradient(45deg, #fff, #fff 5px, #CDCDCD 5px, #CDCDCD 10px)`\n case STATUSES.PAID:\n return \"#81C87E\"\n case STATUSES.UNPAID:\n if (reservation.has_pending_payments === true) {\n return `repeating-linear-gradient(45deg, #fff, #fff 5px, #81C87E 5px, #E0F6DB 10px)`\n } else {\n const percentPaid = (reservation.total_paid_in_cents / reservation.total_owed_in_cents) * 100\n if (percentPaid > 0 && background)\n return `linear-gradient(to right,#81C87E 0%,#81C87E ${percentPaid}%,#E0F6DB ${percentPaid}%, #E0F6DB 100%)`\n else return \"#E0F6DB\"\n }\n default:\n return \"grey\"\n }\n }\n let PrimaryIcon = DocumentTextIcon\n\n if (persistedReservation.grouped_reservation_id) {\n PrimaryIcon = UserGroupIcon\n } else if (persistedReservation.status === \"blocked\") {\n PrimaryIcon = NoSymbolIcon\n } else if (persistedReservation.status === \"blocked-import\") {\n PrimaryIcon = importKindStyle(\n reservation.site?.vendor_calendars?.find((calendar) => calendar.id === reservation.vendor_calendar_id)?.kind,\n ).image\n } else if (persistedReservation.kind === \"recurring\") {\n PrimaryIcon = ArrowPathRoundedSquareIcon\n } else if (persistedReservation.stripe_payment_link_admin_url) {\n PrimaryIcon = LinkIcon\n } else if (persistedReservation.vendor_id) {\n if (persistedReservation.is_manual_charge) {\n PrimaryIcon = CreditCardIcon\n } else {\n PrimaryIcon = GlobeAltIcon\n }\n }\n\n const isHourlyReservation = () =>\n moment(persistedReservation.end_date).diff(persistedReservation.start_date, \"hours\") <= 12\n\n const isShortReservationInQuarterlyView = () => {\n if (!props.calendarApi?.view?.type) return false\n\n if (\n props.calendarApi.view.type === \"resourceTimelineQuarterly\" &&\n (amountOfNights < 2 ||\n moment(persistedReservation.end_date).diff(moment(props.calendarApi?.view?.activeStart), \"days\") <= 1)\n ) {\n return true\n }\n\n return false\n }\n\n useEffect(() => {\n if (isShortReservationInQuarterlyView() || isHourlyReservation()) {\n setIsSmall(true)\n } else {\n setIsSmall(false)\n }\n\n if (\n props.calendarApi?.view?.currentStart &&\n moment(persistedReservation.end_date).diff(moment(props.calendarApi.view.currentStart), \"days\") < 1\n ) {\n setIsOverflow(true)\n } else {\n setIsOverflow(false)\n }\n }, [props.calendarApi?.view?.type])\n\n useEffect(() => {\n if (!containerRef?.current) return\n\n setContainerWidth(containerRef.current.clientWidth)\n }, [containerRef])\n\n const handleContextMenu = (e: React.MouseEvent) => {\n e.preventDefault()\n showContextMenu(reservationState, e)\n }\n const [showEventImage, setShowEventImage] = useState(true)\n const calculateDifferenceInDaysForQuarterly = () => {\n const differenceInDays = moment(reservation?.end_date).diff(\n moment(props?.calendarApi?.view.activeStart),\n \"days\",\n true,\n )\n if (differenceInDays <= 1 && props?.isQuarterlyView) {\n showEventImage && setShowEventImage(false)\n if (reservation?.status === \"blocked-import\") return \"small-bottom-import\"\n else return \"small-top-import\"\n }\n\n return \"\"\n }\n\n return (\n <>\n props.setSelected(persistedReservation)}\n onContextMenu={handleContextMenu}\n data-testid={`calendar-button-event-${event?._def?.defId}`}\n >\n {persistedReservation.status !== STATUSES.BLOCKED && (\n
\n
\n \n \n \n \n \n \n \n \n
\n
\n \n
\n
\n
\n \n {PrimaryIcon && showEventImage && (\n \n )}\n {!isSmall && !isOverflow && (\n <>\n {(persistedReservation.invoice?.send_date || persistedReservation.is_invoice_sent) && (\n \n )}\n {persistedReservation.long_term_reservation &&\n persistedReservation.long_term_reservation.is_enabled_auto_charging == true && (\n \n )}\n {persistedReservation.has_pending_payments === true &&\n persistedReservation.status != STATUSES.PAID && (\n \n )}\n \n {eventTitle}\n
\n \n )}\n
\n
\n )}\n \n {reservation.status === \"imported\" && (\n \n )}\n \n )\n}\n\nexport default EventButton\n","import { KINDS } from '../constants'\nimport { validKinds } from '../types'\n\nconst isRvKind = (kind: validKinds) => {\n return kind == KINDS.RV_PULLTHROUGH || kind == KINDS.RV_BACKIN || kind == KINDS.RV_HYBRID || kind == KINDS.RV_PULLIN\n}\n\nexport default isRvKind\n","import React, { useEffect, useState } from \"react\"\nimport classNames from \"../../utils/classNames\"\n\ninterface ExternalSvgProps {\n url: string\n style?: React.CSSProperties\n className?: string\n asImg?: boolean\n fallback?: React.ReactNode\n onError?: (error: Error) => void\n}\n\n\nconst svgCache = new Map()\n\nconst ExternalSvg = ({ url, style, className, asImg, fallback, onError }: ExternalSvgProps) => {\n const [svgContent, setSvgContent] = useState(svgCache.get(url) || null)\n const [svgUrl, setSvgUrl] = useState(url)\n const [isLoading, setIsLoading] = useState(false)\n\n useEffect(() => {\n if (!svgCache.has(url)) {\n setIsLoading(true)\n fetch(url)\n .then((response) => (asImg ? response.blob() : response.text()) as Promise)\n .then((data) => {\n if (asImg) {\n const blob = data as Blob\n const objectUrl = URL.createObjectURL(blob)\n svgCache.set(url, objectUrl)\n setSvgUrl(objectUrl)\n } else {\n const str = data as string\n svgCache.set(url, str)\n setSvgContent(str)\n }\n })\n .catch(error => console.error('Error fetching the SVG:', error))\n .finally(() => setIsLoading(false))\n } else {\n setSvgContent(svgCache.get(url))\n }\n }, [url])\n\n // Don't render anything while loading\n if (isLoading || (!svgContent && !svgUrl)) {\n return fallback;\n }\n\n if (asImg && svgUrl) {\n return (\n \n )\n }\n\n if (svgContent) {\n return (\n \n )\n }\n\n return null\n}\n\nexport default ExternalSvg\n","import React from 'react'\nimport { KINDS } from '../constants'\nimport { SiteProps } from '../interfaces'\n\nimport iconFor from '../utils/iconFor'\nimport classNames from '../utils/classNames'\nimport isRvKind from '../utils/isRvKind'\nimport ExternalSvg from './ui/ExternalSvg'\nimport formatLengthUnit from '~/utils/formatLengthUnit'\n\ninterface ComponentProps {\n site: SiteProps\n size: string\n campingStyle: any\n isCalendarView?: boolean\n isDropdown?: boolean\n lengthUnit: string\n}\n\nconst SiteIcons = (props: ComponentProps) => {\n const ElectricImage = () =>\n props.site.electric && (\n \n )\n\n const externalSVG =\n }\n onError={(error) => console.error('SVG loading failed:', error)}\n />\n\n const kindImage = props.site.icon_url ? externalSVG : props.site.kind ? (\n \n ) : null\n\n const RigLength = () =>\n props.site.max_rig_length && (\n \n {props.site.max_rig_length}\n {formatLengthUnit(props.lengthUnit)}\n \n )\n\n const CamperCapacity = () =>\n props.site.camper_capacity &&\n (props.campingStyle?.name == KINDS.CABIN ||\n props.campingStyle?.name == KINDS.RENTAL_RV ||\n props.campingStyle?.name == KINDS.MOBILE_HOME ||\n props.campingStyle?.name == KINDS.HOME ||\n props.campingStyle?.name == KINDS.LODGING ||\n props.campingStyle?.name == KINDS.LODGE ||\n props.campingStyle?.name == KINDS.GLAMPING ||\n props.campingStyle?.name == KINDS.DOME) && (\n
\n \n
\n \n {props.site.camper_capacity}\n
\n
Max
\n
\n \n \n )\n \n const WaterSewer = () =>\n (props.site.water || props.site.sewage) &&\n isRvKind(props.site.kind) && (\n
\n \n
\n
\n {props.site.water && props.site.sewage ? 'W/S' : props.site.water ? 'W' : 'S'}\n
\n
\n
\n \n )\n\n if (props.isCalendarView)\n return (\n
\n {kindImage}\n
\n )\n else\n return (\n
\n {kindImage}\n \n \n \n \n
\n )\n}\n\nexport default SiteIcons\n","import React, { FormEventHandler, Fragment } from \"react\"\nimport { Dialog, Transition } from \"@headlessui/react\"\nimport { XMarkIcon } from \"@heroicons/react/24/solid\"\nimport classNames from \"../../utils/classNames\"\nimport Button from \"./Button\"\n\ninterface ComponentProps {\n open: boolean\n setOpen: (v: boolean) => void\n header: string\n content: JSX.Element | JSX.Element[]\n onSubmit: FormEventHandler\n isProcessing: boolean\n isSaveDisabled: boolean\n dialogStyles?: React.CSSProperties\n width?: \"max-w-xl\" | \"max-w-2xl\"\n handleRemove?: (any) => void\n errorMessage?: string\n}\n\nconst SlideoverForm = (props: ComponentProps) => {\n if (!props.open) return <>\n\n return (\n \n \n
\n\n
\n
\n \n \n \n \n
\n
\n
\n {props.header}\n
\n props.setOpen(false)}\n data-testid=\"close-button\"\n >\n Close panel\n \n \n
\n
\n
\n
\n
{props.content}
\n
\n
\n
\n {props.errorMessage && (\n
\n

{props.errorMessage}

\n
\n )}\n props.setOpen(false)}\n disabled={props.isProcessing}\n dataTestId=\"cancel-button\"\n >\n Cancel\n \n \n Save\n \n
\n \n \n \n
\n
\n
\n
\n
\n )\n}\n\nexport default SlideoverForm\n","const NIGHTLY: '1d' = '1d'\nconst NIGHTLY_2_PLUS: '2d+' = '2d+'\nconst NIGHTLY_3_PLUS: '3d+' = '3d+'\nconst WEEKLY: '1w' = '1w'\nconst MONTHLY: '1m' = '1m'\nconst FLAT_RATE: 'flat-rate' = 'flat-rate'\nconst SEASONAL: 'seasonal' = 'seasonal'\n\nconst PRICE_DURATIONS = {\n NIGHTLY,\n NIGHTLY_2_PLUS,\n NIGHTLY_3_PLUS,\n WEEKLY,\n MONTHLY,\n FLAT_RATE,\n SEASONAL,\n}\n\nexport { PRICE_DURATIONS }\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n function next() {\n while (env.stack.length) {\n var rec = env.stack.pop();\n try {\n var result = rec.dispose && rec.dispose.call(rec.value);\n if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n catch (e) {\n fail(e);\n }\n }\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n};\n","export var MS = '-ms-'\nexport var MOZ = '-moz-'\nexport var WEBKIT = '-webkit-'\n\nexport var COMMENT = 'comm'\nexport var RULESET = 'rule'\nexport var DECLARATION = 'decl'\n\nexport var PAGE = '@page'\nexport var MEDIA = '@media'\nexport var IMPORT = '@import'\nexport var CHARSET = '@charset'\nexport var VIEWPORT = '@viewport'\nexport var SUPPORTS = '@supports'\nexport var DOCUMENT = '@document'\nexport var NAMESPACE = '@namespace'\nexport var KEYFRAMES = '@keyframes'\nexport var FONT_FACE = '@font-face'\nexport var COUNTER_STYLE = '@counter-style'\nexport var FONT_FEATURE_VALUES = '@font-feature-values'\nexport var LAYER = '@layer'\nexport var SCOPE = '@scope'\n","/**\n * @param {number}\n * @return {number}\n */\nexport var abs = Math.abs\n\n/**\n * @param {number}\n * @return {string}\n */\nexport var from = String.fromCharCode\n\n/**\n * @param {object}\n * @return {object}\n */\nexport var assign = Object.assign\n\n/**\n * @param {string} value\n * @param {number} length\n * @return {number}\n */\nexport function hash (value, length) {\n\treturn charat(value, 0) ^ 45 ? (((((((length << 2) ^ charat(value, 0)) << 2) ^ charat(value, 1)) << 2) ^ charat(value, 2)) << 2) ^ charat(value, 3) : 0\n}\n\n/**\n * @param {string} value\n * @return {string}\n */\nexport function trim (value) {\n\treturn value.trim()\n}\n\n/**\n * @param {string} value\n * @param {RegExp} pattern\n * @return {string?}\n */\nexport function match (value, pattern) {\n\treturn (value = pattern.exec(value)) ? value[0] : value\n}\n\n/**\n * @param {string} value\n * @param {(string|RegExp)} pattern\n * @param {string} replacement\n * @return {string}\n */\nexport function replace (value, pattern, replacement) {\n\treturn value.replace(pattern, replacement)\n}\n\n/**\n * @param {string} value\n * @param {string} search\n * @param {number} position\n * @return {number}\n */\nexport function indexof (value, search, position) {\n\treturn value.indexOf(search, position)\n}\n\n/**\n * @param {string} value\n * @param {number} index\n * @return {number}\n */\nexport function charat (value, index) {\n\treturn value.charCodeAt(index) | 0\n}\n\n/**\n * @param {string} value\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function substr (value, begin, end) {\n\treturn value.slice(begin, end)\n}\n\n/**\n * @param {string} value\n * @return {number}\n */\nexport function strlen (value) {\n\treturn value.length\n}\n\n/**\n * @param {any[]} value\n * @return {number}\n */\nexport function sizeof (value) {\n\treturn value.length\n}\n\n/**\n * @param {any} value\n * @param {any[]} array\n * @return {any}\n */\nexport function append (value, array) {\n\treturn array.push(value), value\n}\n\n/**\n * @param {string[]} array\n * @param {function} callback\n * @return {string}\n */\nexport function combine (array, callback) {\n\treturn array.map(callback).join('')\n}\n\n/**\n * @param {string[]} array\n * @param {RegExp} pattern\n * @return {string[]}\n */\nexport function filter (array, pattern) {\n\treturn array.filter(function (value) { return !match(value, pattern) })\n}\n","import {from, trim, charat, strlen, substr, append, assign} from './Utility.js'\n\nexport var line = 1\nexport var column = 1\nexport var length = 0\nexport var position = 0\nexport var character = 0\nexport var characters = ''\n\n/**\n * @param {string} value\n * @param {object | null} root\n * @param {object | null} parent\n * @param {string} type\n * @param {string[] | string} props\n * @param {object[] | string} children\n * @param {object[]} siblings\n * @param {number} length\n */\nexport function node (value, root, parent, type, props, children, length, siblings) {\n\treturn {value: value, root: root, parent: parent, type: type, props: props, children: children, line: line, column: column, length: length, return: '', siblings: siblings}\n}\n\n/**\n * @param {object} root\n * @param {object} props\n * @return {object}\n */\nexport function copy (root, props) {\n\treturn assign(node('', null, null, '', null, null, 0, root.siblings), root, {length: -root.length}, props)\n}\n\n/**\n * @param {object} root\n */\nexport function lift (root) {\n\twhile (root.root)\n\t\troot = copy(root.root, {children: [root]})\n\n\tappend(root, root.siblings)\n}\n\n/**\n * @return {number}\n */\nexport function char () {\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function prev () {\n\tcharacter = position > 0 ? charat(characters, --position) : 0\n\n\tif (column--, character === 10)\n\t\tcolumn = 1, line--\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function next () {\n\tcharacter = position < length ? charat(characters, position++) : 0\n\n\tif (column++, character === 10)\n\t\tcolumn = 1, line++\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function peek () {\n\treturn charat(characters, position)\n}\n\n/**\n * @return {number}\n */\nexport function caret () {\n\treturn position\n}\n\n/**\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function slice (begin, end) {\n\treturn substr(characters, begin, end)\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function token (type) {\n\tswitch (type) {\n\t\t// \\0 \\t \\n \\r \\s whitespace token\n\t\tcase 0: case 9: case 10: case 13: case 32:\n\t\t\treturn 5\n\t\t// ! + , / > @ ~ isolate token\n\t\tcase 33: case 43: case 44: case 47: case 62: case 64: case 126:\n\t\t// ; { } breakpoint token\n\t\tcase 59: case 123: case 125:\n\t\t\treturn 4\n\t\t// : accompanied token\n\t\tcase 58:\n\t\t\treturn 3\n\t\t// \" ' ( [ opening delimit token\n\t\tcase 34: case 39: case 40: case 91:\n\t\t\treturn 2\n\t\t// ) ] closing delimit token\n\t\tcase 41: case 93:\n\t\t\treturn 1\n\t}\n\n\treturn 0\n}\n\n/**\n * @param {string} value\n * @return {any[]}\n */\nexport function alloc (value) {\n\treturn line = column = 1, length = strlen(characters = value), position = 0, []\n}\n\n/**\n * @param {any} value\n * @return {any}\n */\nexport function dealloc (value) {\n\treturn characters = '', value\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function delimit (type) {\n\treturn trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type)))\n}\n\n/**\n * @param {string} value\n * @return {string[]}\n */\nexport function tokenize (value) {\n\treturn dealloc(tokenizer(alloc(value)))\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function whitespace (type) {\n\twhile (character = peek())\n\t\tif (character < 33)\n\t\t\tnext()\n\t\telse\n\t\t\tbreak\n\n\treturn token(type) > 2 || token(character) > 3 ? '' : ' '\n}\n\n/**\n * @param {string[]} children\n * @return {string[]}\n */\nexport function tokenizer (children) {\n\twhile (next())\n\t\tswitch (token(character)) {\n\t\t\tcase 0: append(identifier(position - 1), children)\n\t\t\t\tbreak\n\t\t\tcase 2: append(delimit(character), children)\n\t\t\t\tbreak\n\t\t\tdefault: append(from(character), children)\n\t\t}\n\n\treturn children\n}\n\n/**\n * @param {number} index\n * @param {number} count\n * @return {string}\n */\nexport function escaping (index, count) {\n\twhile (--count && next())\n\t\t// not 0-9 A-F a-f\n\t\tif (character < 48 || character > 102 || (character > 57 && character < 65) || (character > 70 && character < 97))\n\t\t\tbreak\n\n\treturn slice(index, caret() + (count < 6 && peek() == 32 && next() == 32))\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function delimiter (type) {\n\twhile (next())\n\t\tswitch (character) {\n\t\t\t// ] ) \" '\n\t\t\tcase type:\n\t\t\t\treturn position\n\t\t\t// \" '\n\t\t\tcase 34: case 39:\n\t\t\t\tif (type !== 34 && type !== 39)\n\t\t\t\t\tdelimiter(character)\n\t\t\t\tbreak\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (type === 41)\n\t\t\t\t\tdelimiter(type)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tnext()\n\t\t\t\tbreak\n\t\t}\n\n\treturn position\n}\n\n/**\n * @param {number} type\n * @param {number} index\n * @return {number}\n */\nexport function commenter (type, index) {\n\twhile (next())\n\t\t// //\n\t\tif (type + character === 47 + 10)\n\t\t\tbreak\n\t\t// /*\n\t\telse if (type + character === 42 + 42 && peek() === 47)\n\t\t\tbreak\n\n\treturn '/*' + slice(index, position - 1) + '*' + from(type === 47 ? type : next())\n}\n\n/**\n * @param {number} index\n * @return {string}\n */\nexport function identifier (index) {\n\twhile (!token(peek()))\n\t\tnext()\n\n\treturn slice(index, position)\n}\n","import {COMMENT, RULESET, DECLARATION} from './Enum.js'\nimport {abs, charat, trim, from, sizeof, strlen, substr, append, replace, indexof} from './Utility.js'\nimport {node, char, prev, next, peek, caret, alloc, dealloc, delimit, whitespace, escaping, identifier, commenter} from './Tokenizer.js'\n\n/**\n * @param {string} value\n * @return {object[]}\n */\nexport function compile (value) {\n\treturn dealloc(parse('', null, null, null, [''], value = alloc(value), 0, [0], value))\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {string[]} rule\n * @param {string[]} rules\n * @param {string[]} rulesets\n * @param {number[]} pseudo\n * @param {number[]} points\n * @param {string[]} declarations\n * @return {object}\n */\nexport function parse (value, root, parent, rule, rules, rulesets, pseudo, points, declarations) {\n\tvar index = 0\n\tvar offset = 0\n\tvar length = pseudo\n\tvar atrule = 0\n\tvar property = 0\n\tvar previous = 0\n\tvar variable = 1\n\tvar scanning = 1\n\tvar ampersand = 1\n\tvar character = 0\n\tvar type = ''\n\tvar props = rules\n\tvar children = rulesets\n\tvar reference = rule\n\tvar characters = type\n\n\twhile (scanning)\n\t\tswitch (previous = character, character = next()) {\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (previous != 108 && charat(characters, length - 1) == 58) {\n\t\t\t\t\tif (indexof(characters += replace(delimit(character), '&', '&\\f'), '&\\f', abs(index ? points[index - 1] : 0)) != -1)\n\t\t\t\t\t\tampersand = -1\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t// \" ' [\n\t\t\tcase 34: case 39: case 91:\n\t\t\t\tcharacters += delimit(character)\n\t\t\t\tbreak\n\t\t\t// \\t \\n \\r \\s\n\t\t\tcase 9: case 10: case 13: case 32:\n\t\t\t\tcharacters += whitespace(previous)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tcharacters += escaping(caret() - 1, 7)\n\t\t\t\tcontinue\n\t\t\t// /\n\t\t\tcase 47:\n\t\t\t\tswitch (peek()) {\n\t\t\t\t\tcase 42: case 47:\n\t\t\t\t\t\tappend(comment(commenter(next(), caret()), root, parent, declarations), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tcharacters += '/'\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t// {\n\t\t\tcase 123 * variable:\n\t\t\t\tpoints[index++] = strlen(characters) * ampersand\n\t\t\t// } ; \\0\n\t\t\tcase 125 * variable: case 59: case 0:\n\t\t\t\tswitch (character) {\n\t\t\t\t\t// \\0 }\n\t\t\t\t\tcase 0: case 125: scanning = 0\n\t\t\t\t\t// ;\n\t\t\t\t\tcase 59 + offset: if (ampersand == -1) characters = replace(characters, /\\f/g, '')\n\t\t\t\t\t\tif (property > 0 && (strlen(characters) - length))\n\t\t\t\t\t\t\tappend(property > 32 ? declaration(characters + ';', rule, parent, length - 1, declarations) : declaration(replace(characters, ' ', '') + ';', rule, parent, length - 2, declarations), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @ ;\n\t\t\t\t\tcase 59: characters += ';'\n\t\t\t\t\t// { rule/at-rule\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tappend(reference = ruleset(characters, root, parent, index, offset, rules, points, type, props = [], children = [], length, rulesets), rulesets)\n\n\t\t\t\t\t\tif (character === 123)\n\t\t\t\t\t\t\tif (offset === 0)\n\t\t\t\t\t\t\t\tparse(characters, root, reference, reference, props, rulesets, length, points, children)\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tswitch (atrule === 99 && charat(characters, 3) === 110 ? 100 : atrule) {\n\t\t\t\t\t\t\t\t\t// d l m s\n\t\t\t\t\t\t\t\t\tcase 100: case 108: case 109: case 115:\n\t\t\t\t\t\t\t\t\t\tparse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length, children), children), rules, children, length, points, rule ? props : children)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\t\tparse(characters, reference, reference, reference, [''], children, 0, points, children)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tindex = offset = property = 0, variable = ampersand = 1, type = characters = '', length = pseudo\n\t\t\t\tbreak\n\t\t\t// :\n\t\t\tcase 58:\n\t\t\t\tlength = 1 + strlen(characters), property = previous\n\t\t\tdefault:\n\t\t\t\tif (variable < 1)\n\t\t\t\t\tif (character == 123)\n\t\t\t\t\t\t--variable\n\t\t\t\t\telse if (character == 125 && variable++ == 0 && prev() == 125)\n\t\t\t\t\t\tcontinue\n\n\t\t\t\tswitch (characters += from(character), character * variable) {\n\t\t\t\t\t// &\n\t\t\t\t\tcase 38:\n\t\t\t\t\t\tampersand = offset > 0 ? 1 : (characters += '\\f', -1)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// ,\n\t\t\t\t\tcase 44:\n\t\t\t\t\t\tpoints[index++] = (strlen(characters) - 1) * ampersand, ampersand = 1\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @\n\t\t\t\t\tcase 64:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (peek() === 45)\n\t\t\t\t\t\t\tcharacters += delimit(next())\n\n\t\t\t\t\t\tatrule = peek(), offset = length = strlen(type = characters += identifier(caret())), character++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// -\n\t\t\t\t\tcase 45:\n\t\t\t\t\t\tif (previous === 45 && strlen(characters) == 2)\n\t\t\t\t\t\t\tvariable = 0\n\t\t\t\t}\n\t\t}\n\n\treturn rulesets\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} index\n * @param {number} offset\n * @param {string[]} rules\n * @param {number[]} points\n * @param {string} type\n * @param {string[]} props\n * @param {string[]} children\n * @param {number} length\n * @param {object[]} siblings\n * @return {object}\n */\nexport function ruleset (value, root, parent, index, offset, rules, points, type, props, children, length, siblings) {\n\tvar post = offset - 1\n\tvar rule = offset === 0 ? rules : ['']\n\tvar size = sizeof(rule)\n\n\tfor (var i = 0, j = 0, k = 0; i < index; ++i)\n\t\tfor (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x)\n\t\t\tif (z = trim(j > 0 ? rule[x] + ' ' + y : replace(y, /&\\f/g, rule[x])))\n\t\t\t\tprops[k++] = z\n\n\treturn node(value, root, parent, offset === 0 ? RULESET : type, props, children, length, siblings)\n}\n\n/**\n * @param {number} value\n * @param {object} root\n * @param {object?} parent\n * @param {object[]} siblings\n * @return {object}\n */\nexport function comment (value, root, parent, siblings) {\n\treturn node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0, siblings)\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} length\n * @param {object[]} siblings\n * @return {object}\n */\nexport function declaration (value, root, parent, length, siblings) {\n\treturn node(value, root, parent, DECLARATION, substr(value, 0, length), substr(value, length + 1, -1), length, siblings)\n}\n","import {MS, MOZ, WEBKIT} from './Enum.js'\nimport {hash, charat, strlen, indexof, replace, substr, match} from './Utility.js'\n\n/**\n * @param {string} value\n * @param {number} length\n * @param {object[]} children\n * @return {string}\n */\nexport function prefix (value, length, children) {\n\tswitch (hash(value, length)) {\n\t\t// color-adjust\n\t\tcase 5103:\n\t\t\treturn WEBKIT + 'print-' + value + value\n\t\t// animation, animation-(delay|direction|duration|fill-mode|iteration-count|name|play-state|timing-function)\n\t\tcase 5737: case 4201: case 3177: case 3433: case 1641: case 4457: case 2921:\n\t\t// text-decoration, filter, clip-path, backface-visibility, column, box-decoration-break\n\t\tcase 5572: case 6356: case 5844: case 3191: case 6645: case 3005:\n\t\t// mask, mask-image, mask-(mode|clip|size), mask-(repeat|origin), mask-position, mask-composite,\n\t\tcase 6391: case 5879: case 5623: case 6135: case 4599: case 4855:\n\t\t// background-clip, columns, column-(count|fill|gap|rule|rule-color|rule-style|rule-width|span|width)\n\t\tcase 4215: case 6389: case 5109: case 5365: case 5621: case 3829:\n\t\t\treturn WEBKIT + value + value\n\t\t// tab-size\n\t\tcase 4789:\n\t\t\treturn MOZ + value + value\n\t\t// appearance, user-select, transform, hyphens, text-size-adjust\n\t\tcase 5349: case 4246: case 4810: case 6968: case 2756:\n\t\t\treturn WEBKIT + value + MOZ + value + MS + value + value\n\t\t// writing-mode\n\t\tcase 5936:\n\t\t\tswitch (charat(value, length + 11)) {\n\t\t\t\t// vertical-l(r)\n\t\t\t\tcase 114:\n\t\t\t\t\treturn WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb') + value\n\t\t\t\t// vertical-r(l)\n\t\t\t\tcase 108:\n\t\t\t\t\treturn WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb-rl') + value\n\t\t\t\t// horizontal(-)tb\n\t\t\t\tcase 45:\n\t\t\t\t\treturn WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'lr') + value\n\t\t\t\t// default: fallthrough to below\n\t\t\t}\n\t\t// flex, flex-direction, scroll-snap-type, writing-mode\n\t\tcase 6828: case 4268: case 2903:\n\t\t\treturn WEBKIT + value + MS + value + value\n\t\t// order\n\t\tcase 6165:\n\t\t\treturn WEBKIT + value + MS + 'flex-' + value + value\n\t\t// align-items\n\t\tcase 5187:\n\t\t\treturn WEBKIT + value + replace(value, /(\\w+).+(:[^]+)/, WEBKIT + 'box-$1$2' + MS + 'flex-$1$2') + value\n\t\t// align-self\n\t\tcase 5443:\n\t\t\treturn WEBKIT + value + MS + 'flex-item-' + replace(value, /flex-|-self/g, '') + (!match(value, /flex-|baseline/) ? MS + 'grid-row-' + replace(value, /flex-|-self/g, '') : '') + value\n\t\t// align-content\n\t\tcase 4675:\n\t\t\treturn WEBKIT + value + MS + 'flex-line-pack' + replace(value, /align-content|flex-|-self/g, '') + value\n\t\t// flex-shrink\n\t\tcase 5548:\n\t\t\treturn WEBKIT + value + MS + replace(value, 'shrink', 'negative') + value\n\t\t// flex-basis\n\t\tcase 5292:\n\t\t\treturn WEBKIT + value + MS + replace(value, 'basis', 'preferred-size') + value\n\t\t// flex-grow\n\t\tcase 6060:\n\t\t\treturn WEBKIT + 'box-' + replace(value, '-grow', '') + WEBKIT + value + MS + replace(value, 'grow', 'positive') + value\n\t\t// transition\n\t\tcase 4554:\n\t\t\treturn WEBKIT + replace(value, /([^-])(transform)/g, '$1' + WEBKIT + '$2') + value\n\t\t// cursor\n\t\tcase 6187:\n\t\t\treturn replace(replace(replace(value, /(zoom-|grab)/, WEBKIT + '$1'), /(image-set)/, WEBKIT + '$1'), value, '') + value\n\t\t// background, background-image\n\t\tcase 5495: case 3959:\n\t\t\treturn replace(value, /(image-set\\([^]*)/, WEBKIT + '$1' + '$`$1')\n\t\t// justify-content\n\t\tcase 4968:\n\t\t\treturn replace(replace(value, /(.+:)(flex-)?(.*)/, WEBKIT + 'box-pack:$3' + MS + 'flex-pack:$3'), /s.+-b[^;]+/, 'justify') + WEBKIT + value + value\n\t\t// justify-self\n\t\tcase 4200:\n\t\t\tif (!match(value, /flex-|baseline/)) return MS + 'grid-column-align' + substr(value, length) + value\n\t\t\tbreak\n\t\t// grid-template-(columns|rows)\n\t\tcase 2592: case 3360:\n\t\t\treturn MS + replace(value, 'template-', '') + value\n\t\t// grid-(row|column)-start\n\t\tcase 4384: case 3616:\n\t\t\tif (children && children.some(function (element, index) { return length = index, match(element.props, /grid-\\w+-end/) })) {\n\t\t\t\treturn ~indexof(value + (children = children[length].value), 'span', 0) ? value : (MS + replace(value, '-start', '') + value + MS + 'grid-row-span:' + (~indexof(children, 'span', 0) ? match(children, /\\d+/) : +match(children, /\\d+/) - +match(value, /\\d+/)) + ';')\n\t\t\t}\n\t\t\treturn MS + replace(value, '-start', '') + value\n\t\t// grid-(row|column)-end\n\t\tcase 4896: case 4128:\n\t\t\treturn (children && children.some(function (element) { return match(element.props, /grid-\\w+-start/) })) ? value : MS + replace(replace(value, '-end', '-span'), 'span ', '') + value\n\t\t// (margin|padding)-inline-(start|end)\n\t\tcase 4095: case 3583: case 4068: case 2532:\n\t\t\treturn replace(value, /(.+)-inline(.+)/, WEBKIT + '$1$2') + value\n\t\t// (min|max)?(width|height|inline-size|block-size)\n\t\tcase 8116: case 7059: case 5753: case 5535:\n\t\tcase 5445: case 5701: case 4933: case 4677:\n\t\tcase 5533: case 5789: case 5021: case 4765:\n\t\t\t// stretch, max-content, min-content, fill-available\n\t\t\tif (strlen(value) - 1 - length > 6)\n\t\t\t\tswitch (charat(value, length + 1)) {\n\t\t\t\t\t// (m)ax-content, (m)in-content\n\t\t\t\t\tcase 109:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (charat(value, length + 4) !== 45)\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t// (f)ill-available, (f)it-content\n\t\t\t\t\tcase 102:\n\t\t\t\t\t\treturn replace(value, /(.+:)(.+)-([^]+)/, '$1' + WEBKIT + '$2-$3' + '$1' + MOZ + (charat(value, length + 3) == 108 ? '$3' : '$2-$3')) + value\n\t\t\t\t\t// (s)tretch\n\t\t\t\t\tcase 115:\n\t\t\t\t\t\treturn ~indexof(value, 'stretch', 0) ? prefix(replace(value, 'stretch', 'fill-available'), length, children) + value : value\n\t\t\t\t}\n\t\t\tbreak\n\t\t// grid-(column|row)\n\t\tcase 5152: case 5920:\n\t\t\treturn replace(value, /(.+?):(\\d+)(\\s*\\/\\s*(span)?\\s*(\\d+))?(.*)/, function (_, a, b, c, d, e, f) { return (MS + a + ':' + b + f) + (c ? (MS + a + '-span:' + (d ? e : +e - +b)) + f : '') + value })\n\t\t// position: sticky\n\t\tcase 4949:\n\t\t\t// stick(y)?\n\t\t\tif (charat(value, length + 6) === 121)\n\t\t\t\treturn replace(value, ':', ':' + WEBKIT) + value\n\t\t\tbreak\n\t\t// display: (flex|inline-flex|grid|inline-grid)\n\t\tcase 6444:\n\t\t\tswitch (charat(value, charat(value, 14) === 45 ? 18 : 11)) {\n\t\t\t\t// (inline-)?fle(x)\n\t\t\t\tcase 120:\n\t\t\t\t\treturn replace(value, /(.+:)([^;\\s!]+)(;|(\\s+)?!.+)?/, '$1' + WEBKIT + (charat(value, 14) === 45 ? 'inline-' : '') + 'box$3' + '$1' + WEBKIT + '$2$3' + '$1' + MS + '$2box$3') + value\n\t\t\t\t// (inline-)?gri(d)\n\t\t\t\tcase 100:\n\t\t\t\t\treturn replace(value, ':', ':' + MS) + value\n\t\t\t}\n\t\t\tbreak\n\t\t// scroll-margin, scroll-margin-(top|right|bottom|left)\n\t\tcase 5719: case 2647: case 2135: case 3927: case 2391:\n\t\t\treturn replace(value, 'scroll-', 'scroll-snap-') + value\n\t}\n\n\treturn value\n}\n","import {IMPORT, LAYER, COMMENT, RULESET, DECLARATION, KEYFRAMES} from './Enum.js'\nimport {strlen} from './Utility.js'\n\n/**\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function serialize (children, callback) {\n\tvar output = ''\n\n\tfor (var i = 0; i < children.length; i++)\n\t\toutput += callback(children[i], i, children, callback) || ''\n\n\treturn output\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function stringify (element, index, children, callback) {\n\tswitch (element.type) {\n\t\tcase LAYER: if (element.children.length) break\n\t\tcase IMPORT: case DECLARATION: return element.return = element.return || element.value\n\t\tcase COMMENT: return ''\n\t\tcase KEYFRAMES: return element.return = element.value + '{' + serialize(element.children, callback) + '}'\n\t\tcase RULESET: if (!strlen(element.value = element.props.join(','))) return ''\n\t}\n\n\treturn strlen(children = serialize(element.children, callback)) ? element.return = element.value + '{' + children + '}' : ''\n}\n","import {MS, MOZ, WEBKIT, RULESET, KEYFRAMES, DECLARATION} from './Enum.js'\nimport {match, charat, substr, strlen, sizeof, replace, combine, filter, assign} from './Utility.js'\nimport {copy, lift, tokenize} from './Tokenizer.js'\nimport {serialize} from './Serializer.js'\nimport {prefix} from './Prefixer.js'\n\n/**\n * @param {function[]} collection\n * @return {function}\n */\nexport function middleware (collection) {\n\tvar length = sizeof(collection)\n\n\treturn function (element, index, children, callback) {\n\t\tvar output = ''\n\n\t\tfor (var i = 0; i < length; i++)\n\t\t\toutput += collection[i](element, index, children, callback) || ''\n\n\t\treturn output\n\t}\n}\n\n/**\n * @param {function} callback\n * @return {function}\n */\nexport function rulesheet (callback) {\n\treturn function (element) {\n\t\tif (!element.root)\n\t\t\tif (element = element.return)\n\t\t\t\tcallback(element)\n\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n */\nexport function prefixer (element, index, children, callback) {\n\tif (element.length > -1)\n\t\tif (!element.return)\n\t\t\tswitch (element.type) {\n\t\t\t\tcase DECLARATION: element.return = prefix(element.value, element.length, children)\n\t\t\t\t\treturn\n\t\t\t\tcase KEYFRAMES:\n\t\t\t\t\treturn serialize([copy(element, {value: replace(element.value, '@', '@' + WEBKIT)})], callback)\n\t\t\t\tcase RULESET:\n\t\t\t\t\tif (element.length)\n\t\t\t\t\t\treturn combine(children = element.props, function (value) {\n\t\t\t\t\t\t\tswitch (match(value, callback = /(::plac\\w+|:read-\\w+)/)) {\n\t\t\t\t\t\t\t\t// :read-(only|write)\n\t\t\t\t\t\t\t\tcase ':read-only': case ':read-write':\n\t\t\t\t\t\t\t\t\tlift(copy(element, {props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]}))\n\t\t\t\t\t\t\t\t\tlift(copy(element, {props: [value]}))\n\t\t\t\t\t\t\t\t\tassign(element, {props: filter(children, callback)})\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t// :placeholder\n\t\t\t\t\t\t\t\tcase '::placeholder':\n\t\t\t\t\t\t\t\t\tlift(copy(element, {props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]}))\n\t\t\t\t\t\t\t\t\tlift(copy(element, {props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]}))\n\t\t\t\t\t\t\t\t\tlift(copy(element, {props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]}))\n\t\t\t\t\t\t\t\t\tlift(copy(element, {props: [value]}))\n\t\t\t\t\t\t\t\t\tassign(element, {props: filter(children, callback)})\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn ''\n\t\t\t\t\t\t})\n\t\t\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n */\nexport function namespace (element) {\n\tswitch (element.type) {\n\t\tcase RULESET:\n\t\t\telement.props = element.props.map(function (value) {\n\t\t\t\treturn combine(tokenize(value), function (value, index, children) {\n\t\t\t\t\tswitch (charat(value, 0)) {\n\t\t\t\t\t\t// \\f\n\t\t\t\t\t\tcase 12:\n\t\t\t\t\t\t\treturn substr(value, 1, strlen(value))\n\t\t\t\t\t\t// \\0 ( + > ~\n\t\t\t\t\t\tcase 0: case 40: case 43: case 62: case 126:\n\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t// :\n\t\t\t\t\t\tcase 58:\n\t\t\t\t\t\t\tif (children[++index] === 'global')\n\t\t\t\t\t\t\t\tchildren[index] = '', children[++index] = '\\f' + substr(children[index], index = 1, -1)\n\t\t\t\t\t\t// \\s\n\t\t\t\t\t\tcase 32:\n\t\t\t\t\t\t\treturn index === 1 ? '' : value\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tswitch (index) {\n\t\t\t\t\t\t\t\tcase 0: element = value\n\t\t\t\t\t\t\t\t\treturn sizeof(children) > 1 ? '' : value\n\t\t\t\t\t\t\t\tcase index = sizeof(children) - 1: case 2:\n\t\t\t\t\t\t\t\t\treturn index === 2 ? value + element + element : value + element\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t})\n\t}\n}\n","var unitlessKeys = {\n animationIterationCount: 1,\n aspectRatio: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport { unitlessKeys as default };\n","import{__spreadArray as e,__assign as t}from\"tslib\";import n from\"@emotion/is-prop-valid\";import o,{useRef as r,useState as s,useMemo as i,useEffect as a,useContext as c,useDebugValue as l,createElement as u}from\"react\";import p from\"shallowequal\";import*as d from\"stylis\";import h from\"@emotion/unitless\";var f=\"undefined\"!=typeof process&&void 0!==process.env&&(process.env.REACT_APP_SC_ATTR||process.env.SC_ATTR)||\"data-styled\",m=\"active\",y=\"data-styled-version\",v=\"6.1.16\",g=\"/*!sc*/\\n\",S=\"undefined\"!=typeof window&&\"HTMLElement\"in window,w=Boolean(\"boolean\"==typeof SC_DISABLE_SPEEDY?SC_DISABLE_SPEEDY:\"undefined\"!=typeof process&&void 0!==process.env&&void 0!==process.env.REACT_APP_SC_DISABLE_SPEEDY&&\"\"!==process.env.REACT_APP_SC_DISABLE_SPEEDY?\"false\"!==process.env.REACT_APP_SC_DISABLE_SPEEDY&&process.env.REACT_APP_SC_DISABLE_SPEEDY:\"undefined\"!=typeof process&&void 0!==process.env&&void 0!==process.env.SC_DISABLE_SPEEDY&&\"\"!==process.env.SC_DISABLE_SPEEDY?\"false\"!==process.env.SC_DISABLE_SPEEDY&&process.env.SC_DISABLE_SPEEDY:\"production\"!==process.env.NODE_ENV),b={},E=/invalid hook call/i,N=new Set,P=function(t,n){if(\"production\"!==process.env.NODE_ENV){var o=n?' with the id of \"'.concat(n,'\"'):\"\",s=\"The component \".concat(t).concat(o,\" has been created dynamically.\\n\")+\"You may see this warning because you've called styled inside another component.\\nTo resolve this only create new StyledComponents outside of any render method and function component.\",i=console.error;try{var a=!0;console.error=function(t){for(var n=[],o=1;o?@[\\\\\\]^`{|}~-]+/g,D=/(^-|-$)/g;function R(e){return e.replace(O,\"-\").replace(D,\"\")}var T=/(a)(d)/gi,k=52,j=function(e){return String.fromCharCode(e+(e>25?39:97))};function x(e){var t,n=\"\";for(t=Math.abs(e);t>k;t=t/k|0)n=j(t%k)+n;return(j(t%k)+n).replace(T,\"$1-$2\")}var V,F=5381,M=function(e,t){for(var n=t.length;n;)e=33*e^t.charCodeAt(--n);return e},z=function(e){return M(F,e)};function $(e){return x(z(e)>>>0)}function B(e){return\"production\"!==process.env.NODE_ENV&&\"string\"==typeof e&&e||e.displayName||e.name||\"Component\"}function L(e){return\"string\"==typeof e&&(\"production\"===process.env.NODE_ENV||e.charAt(0)===e.charAt(0).toLowerCase())}var G=\"function\"==typeof Symbol&&Symbol.for,Y=G?Symbol.for(\"react.memo\"):60115,W=G?Symbol.for(\"react.forward_ref\"):60112,q={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},H={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},U={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},J=((V={})[W]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},V[Y]=U,V);function X(e){return(\"type\"in(t=e)&&t.type.$$typeof)===Y?U:\"$$typeof\"in e?J[e.$$typeof]:q;var t}var Z=Object.defineProperty,K=Object.getOwnPropertyNames,Q=Object.getOwnPropertySymbols,ee=Object.getOwnPropertyDescriptor,te=Object.getPrototypeOf,ne=Object.prototype;function oe(e,t,n){if(\"string\"!=typeof t){if(ne){var o=te(t);o&&o!==ne&&oe(e,o,n)}var r=K(t);Q&&(r=r.concat(Q(t)));for(var s=X(e),i=X(t),a=0;a ({})}\\n```\\n\\n',8:'ThemeProvider: Please make your \"theme\" prop an object.\\n\\n',9:\"Missing document ``\\n\\n\",10:\"Cannot find a StyleSheet instance. Usually this happens if there are multiple copies of styled-components loaded at once. Check out this issue for how to troubleshoot and fix the common cases where this situation can happen: https://github.com/styled-components/styled-components/issues/1941#issuecomment-417862021\\n\\n\",11:\"_This error was replaced with a dev-time warning, it will be deleted for v4 final._ [createGlobalStyle] received children which will not be rendered. Please use the component without passing children elements.\\n\\n\",12:\"It seems you are interpolating a keyframe declaration (%s) into an untagged string. This was supported in styled-components v3, but is not longer supported in v4 as keyframes are now injected on-demand. Please wrap your string in the css\\\\`\\\\` helper which ensures the styles are injected correctly. See https://www.styled-components.com/docs/api#css\\n\\n\",13:\"%s is not a styled component and cannot be referred to via component selector. See https://www.styled-components.com/docs/advanced#referring-to-other-components for more details.\\n\\n\",14:'ThemeProvider: \"theme\" prop is required.\\n\\n',15:\"A stylis plugin has been supplied that is not named. We need a name for each plugin to be able to prevent styling collisions between different stylis configurations within the same app. Before you pass your plugin to ``, please make sure each plugin is uniquely-named, e.g.\\n\\n```js\\nObject.defineProperty(importedPlugin, 'name', { value: 'some-unique-name' });\\n```\\n\\n\",16:\"Reached the limit of how many styled components may be created at group %s.\\nYou may only create up to 1,073,741,824 components. If you're creating components dynamically,\\nas for instance in your render method then you may be running into this limitation.\\n\\n\",17:\"CSSStyleSheet could not be found on HTMLStyleElement.\\nHas styled-components' style tag been unmounted or altered by another script?\\n\",18:\"ThemeProvider: Please make sure your useTheme hook is within a ``\"}:{};function de(){for(var e=[],t=0;t0?\" Args: \".concat(n.join(\", \")):\"\")):new Error(de.apply(void 0,e([pe[t]],n,!1)).trim())}var fe=function(){function e(e){this.groupSizes=new Uint32Array(512),this.length=512,this.tag=e}return e.prototype.indexOfGroup=function(e){for(var t=0,n=0;n=this.groupSizes.length){for(var n=this.groupSizes,o=n.length,r=o;e>=r;)if((r<<=1)<0)throw he(16,\"\".concat(e));this.groupSizes=new Uint32Array(r),this.groupSizes.set(n),this.length=r;for(var s=o;s=this.length||0===this.groupSizes[e])return t;for(var n=this.groupSizes[e],o=this.indexOfGroup(e),r=o+n,s=o;sme))throw he(16,\"\".concat(t));return ye.set(e,t),ve.set(t,e),t},we=function(e,t){ge=t+1,ye.set(e,t),ve.set(t,e)},be=\"style[\".concat(f,\"][\").concat(y,'=\"').concat(v,'\"]'),Ee=new RegExp(\"^\".concat(f,'\\\\.g(\\\\d+)\\\\[id=\"([\\\\w\\\\d-]+)\"\\\\].*?\"([^\"]*)')),Ne=function(e,t,n){for(var o,r=n.split(\",\"),s=0,i=r.length;s=0){var n=document.createTextNode(t);return this.element.insertBefore(n,this.nodes[e]||null),this.length++,!0}return!1},e.prototype.deleteRule=function(e){this.element.removeChild(this.nodes[e]),this.length--},e.prototype.getRule=function(e){return e0&&(c+=\"\".concat(e,\",\"))}),o+=\"\".concat(i).concat(a,'{content:\"').concat(c,'\"}').concat(g)},s=0;s0?\".\".concat(t):e},u=c.slice();u.push(function(e){e.type===d.RULESET&&e.value.includes(\"&\")&&(e.props[0]=e.props[0].replace(je,n).replace(o,l))}),i.prefix&&u.push(d.prefixer),u.push(d.stringify);var p=function(e,r,s,a){void 0===r&&(r=\"\"),void 0===s&&(s=\"\"),void 0===a&&(a=\"&\"),t=a,n=r,o=new RegExp(\"\\\\\".concat(n,\"\\\\b\"),\"g\");var c=e.replace(xe,\"\"),l=d.compile(s||r?\"\".concat(s,\" \").concat(r,\" { \").concat(c,\" }\"):c);i.namespace&&(l=Ve(l,i.namespace));var p=[];return d.serialize(l,d.middleware(u.concat(d.rulesheet(function(e){return p.push(e)})))),p};return p.hash=c.length?c.reduce(function(e,t){return t.name||he(15),M(e,t.name)},F).toString():\"\",p}var Me=new ke,ze=Fe(),$e=o.createContext({shouldForwardProp:void 0,styleSheet:Me,stylis:ze}),Be=$e.Consumer,Le=o.createContext(void 0);function Ge(){return c($e)}function Ye(e){var t=s(e.stylisPlugins),n=t[0],r=t[1],c=Ge().styleSheet,l=i(function(){var t=c;return e.sheet?t=e.sheet:e.target&&(t=t.reconstructWithOptions({target:e.target},!1)),e.disableCSSOMInjection&&(t=t.reconstructWithOptions({useCSSOMInjection:!1})),t},[e.disableCSSOMInjection,e.sheet,e.target,c]),u=i(function(){return Fe({options:{namespace:e.namespace,prefix:e.enableVendorPrefixes},plugins:n})},[e.enableVendorPrefixes,e.namespace,n]);a(function(){p(n,e.stylisPlugins)||r(e.stylisPlugins)},[e.stylisPlugins]);var d=i(function(){return{shouldForwardProp:e.shouldForwardProp,styleSheet:l,stylis:u}},[e.shouldForwardProp,l,u]);return o.createElement($e.Provider,{value:d},o.createElement(Le.Provider,{value:u},e.children))}var We=function(){function e(e,t){var n=this;this.inject=function(e,t){void 0===t&&(t=ze);var o=n.name+t.hash;e.hasNameForId(n.id,o)||e.insertRules(n.id,o,t(n.rules,o,\"@keyframes\"))},this.name=e,this.id=\"sc-keyframes-\".concat(e),this.rules=t,ue(this,function(){throw he(12,String(n.name))})}return e.prototype.getName=function(e){return void 0===e&&(e=ze),this.name+e.hash},e}(),qe=function(e){return e>=\"A\"&&e<=\"Z\"};function He(e){for(var t=\"\",n=0;n>>0);if(!t.hasNameForId(this.componentId,s)){var i=n(r,\".\".concat(s),void 0,this.componentId);t.insertRules(this.componentId,s,i)}o=ie(o,s),this.staticRulesId=s}else{for(var a=M(this.baseHash,n.hash),c=\"\",l=0;l>>0);t.hasNameForId(this.componentId,d)||t.insertRules(this.componentId,d,n(c,\".\".concat(d),void 0,this.componentId)),o=ie(o,d)}}return o},e}(),et=o.createContext(void 0),tt=et.Consumer;function nt(){var e=c(et);if(!e)throw he(18);return e}function ot(e){var n=o.useContext(et),r=i(function(){return function(e,n){if(!e)throw he(14);if(re(e)){var o=e(n);if(\"production\"!==process.env.NODE_ENV&&(null===o||Array.isArray(o)||\"object\"!=typeof o))throw he(7);return o}if(Array.isArray(e)||\"object\"!=typeof e)throw he(8);return n?t(t({},n),e):e}(e.theme,n)},[e.theme,n]);return e.children?o.createElement(et.Provider,{value:r},e.children):null}var rt={},st=new Set;function it(e,r,s){var i=se(e),a=e,c=!L(e),p=r.attrs,d=void 0===p?_:p,h=r.componentId,f=void 0===h?function(e,t){var n=\"string\"!=typeof e?\"sc\":R(e);rt[n]=(rt[n]||0)+1;var o=\"\".concat(n,\"-\").concat($(v+n+rt[n]));return t?\"\".concat(t,\"-\").concat(o):o}(r.displayName,r.parentComponentId):h,m=r.displayName,y=void 0===m?function(e){return L(e)?\"styled.\".concat(e):\"Styled(\".concat(B(e),\")\")}(e):m,g=r.displayName&&r.componentId?\"\".concat(R(r.displayName),\"-\").concat(r.componentId):r.componentId||f,S=i&&a.attrs?a.attrs.concat(d).filter(Boolean):d,w=r.shouldForwardProp;if(i&&a.shouldForwardProp){var b=a.shouldForwardProp;if(r.shouldForwardProp){var E=r.shouldForwardProp;w=function(e,t){return b(e,t)&&E(e,t)}}else w=b}var N=new Qe(s,g,i?a.componentStyle:void 0);function O(e,r){return function(e,r,s){var i=e.attrs,a=e.componentStyle,c=e.defaultProps,p=e.foldedComponentIds,d=e.styledComponentId,h=e.target,f=o.useContext(et),m=Ge(),y=e.shouldForwardProp||m.shouldForwardProp;\"production\"!==process.env.NODE_ENV&&l(d);var v=I(r,f,c)||C,g=function(e,n,o){for(var r,s=t(t({},n),{className:void 0,theme:o}),i=0;i` (connect an API like `@emotion/is-prop-valid`) or consider using transient props (`$` prefix for automatic filtering.)')))));var E=function(e,t){var n=Ge(),o=e.generateAndInjectStyles(t,n.styleSheet,n.stylis);return\"production\"!==process.env.NODE_ENV&&l(o),o}(a,g);\"production\"!==process.env.NODE_ENV&&e.warnTooManyClasses&&e.warnTooManyClasses(E);var N=ie(p,d);return E&&(N+=\" \"+E),g.className&&(N+=\" \"+g.className),w[L(S)&&!A.has(S)?\"class\":\"className\"]=N,s&&(w.ref=s),u(S,w)}(D,e,r)}O.displayName=y;var D=o.forwardRef(O);return D.attrs=S,D.componentStyle=N,D.displayName=y,D.shouldForwardProp=w,D.foldedComponentIds=i?ie(a.foldedComponentIds,a.styledComponentId):\"\",D.styledComponentId=g,D.target=i?a.target:e,Object.defineProperty(D,\"defaultProps\",{get:function(){return this._foldedDefaultProps},set:function(e){this._foldedDefaultProps=i?function(e){for(var t=[],n=1;n=200)){var s=t?' with the id of \"'.concat(t,'\"'):\"\";console.warn(\"Over \".concat(200,\" classes were generated for component \").concat(e).concat(s,\".\\n\")+\"Consider using the attrs method, together with a style object for frequently changed styles.\\nExample:\\n const Component = styled.div.attrs(props => ({\\n style: {\\n background: props.background,\\n },\\n }))`width: 100%;`\\n\\n \"),o=!0,n={}}}}(y,g)),ue(D,function(){return\".\".concat(D.styledComponentId)}),c&&oe(D,e,{attrs:!0,componentStyle:!0,displayName:!0,foldedComponentIds:!0,shouldForwardProp:!0,styledComponentId:!0,target:!0}),D}function at(e,t){for(var n=[e[0]],o=0,r=t.length;o2&&ke.registerId(this.componentId+e),this.removeStyles(e,n),this.createStyles(e,t,n,o)},e}();function ft(n){for(var r=[],s=1;s meta tag to the stylesheet, or simply embedding it manually in your index.html section for a simpler app.\"),t.styleSheet.server&&u(r,e,t.styleSheet,n,t.stylis),o.useLayoutEffect(function(){if(!t.styleSheet.server)return u(r,e,t.styleSheet,n,t.stylis),function(){return c.removeStyles(r,t.styleSheet)}},[r,e,t.styleSheet,n,t.stylis]),null};function u(e,n,o,r,s){if(c.isStatic)c.renderStyles(e,b,o,s);else{var i=t(t({},n),{theme:I(n,r,l.defaultProps)});c.renderStyles(e,i,o,s)}}return o.memo(l)}function mt(t){for(var n=[],o=1;o\").concat(t,\"\")},this.getStyleTags=function(){if(e.sealed)throw he(2);return e._emitSheetCSS()},this.getStyleElement=function(){var n;if(e.sealed)throw he(2);var r=e.instance.toString();if(!r)return[];var s=((n={})[f]=\"\",n[y]=v,n.dangerouslySetInnerHTML={__html:r},n),i=Ce();return i&&(s.nonce=i),[o.createElement(\"style\",t({},s,{key:\"sc-0-0\"}))]},this.seal=function(){e.sealed=!0},this.instance=new ke({isServer:!0}),this.sealed=!1}return e.prototype.collectStyles=function(e){if(this.sealed)throw he(2);return o.createElement(Ye,{sheet:this.instance},e)},e.prototype.interleaveWithNodeStream=function(e){throw he(3)},e}(),gt={StyleSheet:ke,mainSheet:Me};\"production\"!==process.env.NODE_ENV&&\"undefined\"!=typeof navigator&&\"ReactNative\"===navigator.product&&console.warn(\"It looks like you've imported 'styled-components' on React Native.\\nPerhaps you're looking to import 'styled-components/native'?\\nRead more about this at https://www.styled-components.com/docs/basics#react-native\");var St=\"__sc-\".concat(f,\"__\");\"production\"!==process.env.NODE_ENV&&\"test\"!==process.env.NODE_ENV&&\"undefined\"!=typeof window&&(window[St]||(window[St]=0),1===window[St]&&console.warn(\"It looks like there are several instances of 'styled-components' initialized in this application. This may cause dynamic styles to not render properly, errors during the rehydration process, a missing theme prop, and makes your application bigger without good reason.\\n\\nSee https://s-c.sh/2BAXzed for more info.\"),window[St]+=1);export{vt as ServerStyleSheet,Be as StyleSheetConsumer,$e as StyleSheetContext,Ye as StyleSheetManager,tt as ThemeConsumer,et as ThemeContext,ot as ThemeProvider,gt as __PRIVATE__,ft as createGlobalStyle,lt as css,dt as default,se as isStyledComponent,mt as keyframes,dt as styled,nt as useTheme,v as version,yt as withTheme};\n//# sourceMappingURL=styled-components.browser.esm.js.map\n","import{jsx as n,jsxs as e,Fragment as r}from\"react/jsx-runtime\";import t,{css as i}from\"styled-components\";import{useState as o,useCallback as a,useEffect as l,useRef as d}from\"react\";\n/*! *****************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */var s=function(){return s=Object.assign||function(n){for(var e,r=1,t=arguments.length;r input {\\n display: block;\\n opacity: 0;\\n position: absolute;\\n pointer-events: none;\\n }\\n\"],[\"\\n position: relative;\\n \",\";\\n &:focus-within {\\n outline: 2px solid black;\\n }\\n & > input {\\n display: block;\\n opacity: 0;\\n position: absolute;\\n pointer-events: none;\\n }\\n\"])),(function(n){return n.overRide?\"\":x})),g=t.div(f||(f=p([\"\\n border: dashed 2px \",\";\\n border-radius: 5px;\\n background-color: \",\";\\n opacity: 0.9;\\n position: absolute;\\n top: 0;\\n right: 0;\\n left: 0;\\n bottom: 0;\\n z-index: 999;\\n & > span {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n transform: translateX(-50%) translateY(-50%);\\n }\\n\"],[\"\\n border: dashed 2px \",\";\\n border-radius: 5px;\\n background-color: \",\";\\n opacity: 0.9;\\n position: absolute;\\n top: 0;\\n right: 0;\\n left: 0;\\n bottom: 0;\\n z-index: 999;\\n & > span {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n transform: translateX(-50%) translateY(-50%);\\n }\\n\"])),\"#666\",\"#999\"),m=t.div(v||(v=p([\"\\n display: flex;\\n justify-content: space-between;\\n flex-grow: 1;\\n & > span {\\n font-size: 12px;\\n color: \",\";\\n }\\n .file-types {\\n overflow: hidden;\\n white-space: nowrap;\\n text-overflow: ellipsis;\\n max-width: 100px;\\n }\\n\"],[\"\\n display: flex;\\n justify-content: space-between;\\n flex-grow: 1;\\n & > span {\\n font-size: 12px;\\n color: \",\";\\n }\\n .file-types {\\n overflow: hidden;\\n white-space: nowrap;\\n text-overflow: ellipsis;\\n max-width: 100px;\\n }\\n\"])),(function(n){return n.error?\"red\":\"#666\"})),y=t.span(h||(h=p([\"\\n font-size: 14px;\\n color: \",\";\\n span {\\n text-decoration: underline;\\n }\\n\"],[\"\\n font-size: 14px;\\n color: \",\";\\n span {\\n text-decoration: underline;\\n }\\n\"])),\"#666\"),w=function(n){return n/1024/1024},z=function(n){return void 0===n?\"\":n.map((function(n){return\".\".concat(n.toLowerCase())})).join(\",\")};function L(e){var r=e.types,t=e.minSize,i=e.maxSize;if(r){var o=r.toString(),a=\"\";return i&&(a+=\"size >= \".concat(i,\", \")),t&&(a+=\"size <= \".concat(t,\", \")),n(\"span\",s({title:\"\".concat(a,\"types: \").concat(o),className:\"file-types\"},{children:o}),void 0)}return null}function C(){return e(\"svg\",s({width:\"32\",height:\"32\",viewBox:\"0 0 32 32\",fill:\"none\",xmlns:\"http://www.w3.org/2000/svg\"},{children:[n(\"path\",{d:\"M5.33317 6.66667H22.6665V16H25.3332V6.66667C25.3332 5.196 24.1372 4 22.6665 4H5.33317C3.8625 4 2.6665 5.196 2.6665 6.66667V22.6667C2.6665 24.1373 3.8625 25.3333 5.33317 25.3333H15.9998V22.6667H5.33317V6.66667Z\",fill:\"#0658C2\"},void 0),n(\"path\",{d:\"M10.6665 14.6667L6.6665 20H21.3332L15.9998 12L11.9998 17.3333L10.6665 14.6667Z\",fill:\"#0658C2\"},void 0),n(\"path\",{d:\"M25.3332 18.6667H22.6665V22.6667H18.6665V25.3333H22.6665V29.3333H25.3332V25.3333H29.3332V22.6667H25.3332V18.6667Z\",fill:\"#0658C2\"},void 0)]}),void 0)}var H=0;var k=function(t,i,o,a,l,d){return o?n(\"span\",{children:\"File type/size error, Hovered on types!\"},void 0):n(y,{children:a?n(\"span\",{children:\"Upload disabled\"},void 0):n(r,t||i?{children:d?n(r,{children:n(\"span\",{children:d},void 0)},void 0):e(r,{children:[n(\"span\",{children:\"Uploaded Successfully!\"},void 0),\" Upload another?\"]},void 0)}:{children:e(r,l?{children:[n(\"span\",{children:l.split(\" \")[0]},void 0),\" \",l.substr(l.indexOf(\" \")+1)]}:{children:[n(\"span\",{children:\"Upload\"},void 0),\" or drop a file right here\"]},void 0)},void 0)},void 0)},E=function(t){var i=t.name,p=t.hoverTitle,c=t.types,u=t.handleChange,f=t.classes,v=t.children,h=t.maxSize,x=t.minSize,y=t.fileOrFiles,E=t.onSizeError,S=t.onTypeError,D=t.onSelect,V=t.onDrop,P=t.disabled,j=t.label,F=t.uploadedLabel,O=t.multiple,R=t.required,T=t.onDraggingStateChange,M=t.dropMessageStyle,U=t.ariaLabel,Z=t.ariaDescribedby,q=d(null),N=d(null),X=o(!1),Y=X[0],B=X[1],A=o(null),G=A[0],I=A[1],J=o(!1),K=J[0],Q=J[1],W=function(n){return c&&!function(n,e){var r=n.name.split(\".\").pop();return e.map((function(n){return n.toLowerCase()})).includes(r.toLowerCase())}(n,c)?(Q(!0),S&&S(\"File type is not supported\"),!1):h&&w(n.size)>h?(Q(!0),E&&E(\"File size is too big\"),!1):!(x&&w(n.size)0||c(!1)}),[]),h=a((function(n){n.preventDefault(),n.stopPropagation()}),[]),x=a((function(n){n.preventDefault(),n.stopPropagation(),c(!1),H=0;var e=n.dataTransfer.files;if(e&&e.length>0){var r=t?e:e[0],o=i(r);d&&o&&d(r)}}),[i]);return l((function(){var n=e.current;return n.addEventListener(\"click\",u),n.addEventListener(\"dragenter\",f),n.addEventListener(\"dragleave\",v),n.addEventListener(\"dragover\",h),n.addEventListener(\"drop\",x),function(){n.removeEventListener(\"click\",u),n.removeEventListener(\"dragenter\",f),n.removeEventListener(\"dragleave\",v),n.removeEventListener(\"dragover\",h),n.removeEventListener(\"drop\",x)}}),[u,f,v,h,x,e]),p}({labelRef:q,inputRef:N,multiple:O,handleChanges:$,onDrop:V});return l((function(){null==T||T(_)}),[_]),l((function(){y?(B(!0),I(y)):(N.current&&(N.current.value=\"\"),B(!1),I(null))}),[y]),e(b,s({overRide:v,className:\"\".concat(f||\"\",\" \").concat(P?\"is-disabled\":\"\"),ref:q,htmlFor:i,onClick:function(n){n.preventDefault(),n.stopPropagation()},\"aria-describedby\":Z,role:\"button\",\"aria-label\":U},{children:[n(\"input\",{onClick:function(n){n.stopPropagation(),N&&N.current&&(N.current.value=\"\",N.current.click())},onChange:function(n){var e=n.target.files,r=O?e:e[0],t=$(r);D&&t&&D(r)},accept:z(c),ref:N,type:\"file\",id:i,name:i,disabled:P,multiple:O,required:R},void 0),_&&n(g,s({style:M},{children:n(\"span\",{children:p||\"Drop Here\"},void 0)}),void 0),!v&&e(r,{children:[n(C,{},void 0),e(m,s({error:K},{children:[k(G,Y,K,P,j,F),n(L,{types:c,minSize:x,maxSize:h},void 0)]}),void 0)]},void 0),v]}),void 0)};export{E as FileUploader};\n","import { useState, useEffect } from \"react\"\nimport { useQuery, useMutation, useQueryClient } from \"@tanstack/react-query\"\nimport { uniqueId } from \"lodash\"\nimport api from \"~/api2\"\nimport { SiteProps } from \"~/interfaces\"\n\ninterface ImageType {\n file: File | null\n url: string\n key: string\n}\n\nexport const useSitePhotos = (site: SiteProps | null, showNotification: (args: any) => void) => {\n const queryClient = useQueryClient()\n const [imageStates, setImageStates] = useState>([])\n\n const fetchImages = async () => {\n if (!site) throw new Error(\"No site provided\")\n const response = await api.Sites.fetchImages(site.id)\n return response.images.map((image) => ({\n file: null,\n url: image.url,\n key: image.key,\n }))\n }\n\n const { data, isLoading } = useQuery({\n queryKey: [\"siteImages\", site?.id],\n queryFn: fetchImages,\n enabled: !!site,\n })\n\n useEffect(() => {\n if (data) {\n setImageStates(data)\n }\n }, [data])\n\n const uploadImageMutation = useMutation({\n mutationFn: (file: File) => api.Sites.uploadImage(site!.id, file),\n onSuccess: (response) => {\n queryClient.invalidateQueries({ queryKey: [\"siteImages\", site!.id] })\n setImageStates((currentStates) =>\n currentStates.map((img) =>\n img.key.startsWith(\"temp-key\")\n ? { ...img, url: response.image.url, key: response.image.key, isLoading: false }\n : img,\n ),\n )\n },\n onError: (err: any, file: File) => {\n console.error(err)\n showNotification({\n type: \"error\",\n title: `Failed to upload image ${file.name}`,\n description: err.message,\n })\n },\n })\n\n const removeImageMutation = useMutation({\n mutationFn: (key: string) => api.Sites.removeImage(site!.id, key),\n onSuccess: () => {\n queryClient.invalidateQueries({ queryKey: [\"siteImages\", site!.id] })\n },\n onError: (err: any, key: string) => {\n console.error(err)\n showNotification({\n type: \"error\",\n title: \"Failed to remove image\",\n description: err.message,\n })\n },\n })\n\n const handleAdd = (files: FileList) => {\n const fileList = Array.from(files)\n const newImages = fileList.map((file) => ({\n file,\n url: URL.createObjectURL(file),\n key: `temp-key-${uniqueId()}`,\n isLoading: true,\n }))\n\n setImageStates((prev) => [...prev, ...newImages])\n fileList.forEach((file) => uploadImageMutation.mutate(file))\n }\n\n const handleRemove = (key: string) => {\n setImageStates((prev) => prev.map((img) => (img.key === key ? { ...img, isLoading: true } : img)))\n removeImageMutation.mutate(key)\n }\n\n const updateImageLoadState = (key: string, isLoading: boolean) => {\n setImageStates((prev) => prev.map((img) => (img.key === key ? { ...img, isLoading } : img)))\n }\n\n return {\n imageStates,\n isLoading,\n handleAdd,\n handleRemove,\n updateImageLoadState,\n }\n}\n","import { DocumentPlusIcon, XCircleIcon, XMarkIcon } from \"@heroicons/react/24/solid\"\nimport React, { MouseEventHandler, ReactEventHandler, useContext } from \"react\"\nimport { FileUploader } from \"react-drag-drop-files\"\nimport { SiteProps } from \"../../interfaces\"\nimport Spinner from \"../ui/Spinner\"\nimport { AdminContext } from \"~/contexts/AdminContext\"\nimport { useSitePhotos } from \"~/hooks/useSitePhotos\"\n\nconst fileTypes = [\"JPG\", \"JPEG\", \"PNG\"]\n\nexport const Image = ({\n src,\n handleRemove,\n isLoading,\n onLoaded,\n onError,\n}: {\n src: string\n handleRemove: MouseEventHandler\n isLoading: boolean\n onLoaded: ReactEventHandler\n onError: ReactEventHandler\n}) => (\n
\n {isLoading && (\n
\n \n
\n )}\n {!isLoading && (\n <>\n \n \n \n window.open(src, \"_blank\")}\n />\n \n )}\n
\n)\n\nfunction SitePhotoUpload({ site }: { site: SiteProps }) {\n const { showNotification } = useContext(AdminContext)\n\n const { imageStates, isLoading, handleAdd, handleRemove, updateImageLoadState } = useSitePhotos(\n site,\n showNotification,\n )\n\n if (!site) return null\n\n return (\n <>\n \n
\n {imageStates?.map(({ url, key }) => (\n handleRemove(key)}\n isLoading={isLoading}\n onLoaded={() => updateImageLoadState(key, false)}\n onError={() => updateImageLoadState(key, false)}\n />\n ))}\n
\n\n \n \n
\n Click or drag a photo here to upload\n {fileTypes.join(\", \")}\n
\n \n }\n />\n \n )\n}\n\nexport default SitePhotoUpload\n","import React, { useEffect, useRef, useState } from \"react\"\nimport ReactQuill from \"react-quill\"\nimport juice from \"juice\"\nimport { desktopToolbar, desktopToolbarHyperlink, mobileToolbar } from \"../../config/quillToolbar\"\nimport { richTextInputStyles } from \"../../constants/rich_text_input_styles\"\nimport { removeNonColorStyles } from \"./Admin/Form/RichTextInput\"\nimport { ChevronDownIcon } from \"@heroicons/react/24/solid\"\nimport Button from \"./Button\"\n\ninterface ComponentProps {\n id?: string\n defaultValue?: string\n value?: string\n setValue: (v: string) => void\n isDisabled?: boolean\n className?: string\n style?: React.CSSProperties\n hyperlink?: boolean\n setValueWithoutHtml?: (v: string) => void\n alwaysReloadQuillValue?: boolean\n setAlwaysReloadQuillValue?: React.Dispatch>\n dataTestId?: string\n optionalVariablesDropBox?: { value: string; label: string }[]\n}\n\nexport const stripHtmlTags = (str: string) => str?.replace(/<\\/?[^>]+(>|$)/g, \"\")\n\nconst RichTextInput = ({\n value,\n setValue,\n id,\n isDisabled,\n className,\n style,\n hyperlink,\n setValueWithoutHtml,\n alwaysReloadQuillValue,\n setAlwaysReloadQuillValue,\n dataTestId,\n optionalVariablesDropBox,\n}: ComponentProps) => {\n const [isReady, setIsReady] = useState(false)\n const [quillValue, setQuillValue] = useState(\"\")\n const [defaultQuillValue, setDefaultQuillValue] = useState(\"\")\n const [toolbarWidth, setToolbarWidth] = useState(0)\n const quillRef = useRef(null)\n\n const handleDropdownVariablesChange = (selectedValue: string) => {\n const quill = quillRef.current?.getEditor()\n\n if (quill) {\n const range = quill.getSelection()\n if (range) {\n quill.insertText(range.index, selectedValue + \" \")\n } else {\n quill.insertText(quill.getLength(), selectedValue + \" \")\n }\n setValue(quill.root.innerHTML)\n setValueWithoutHtml && setValueWithoutHtml(stripHtmlTags(quill.root.innerHTML))\n }\n }\n\n useEffect(() => {\n // Hacky solution to stop from autofocusing\n const timer = setTimeout(() => {\n setIsReady(true)\n }, 100)\n\n setQuillValue(removeNonColorStyles(value || \"\"))\n setDefaultQuillValue(value)\n\n return () => clearTimeout(timer)\n }, [])\n\n useEffect(() => {\n if (defaultQuillValue === value) {\n alwaysReloadQuillValue && setAlwaysReloadQuillValue && setAlwaysReloadQuillValue(false)\n setQuillValue(removeNonColorStyles(value || \"\"))\n }\n }, [value])\n\n return (\n
\n {\n setQuillValue(v)\n setValue(juice(richTextInputStyles + v))\n setValueWithoutHtml && setValueWithoutHtml(stripHtmlTags(v))\n }}\n id={id}\n />\n {optionalVariablesDropBox && (\n \n )}\n
\n )\n}\n\nexport default RichTextInput\n\nconst VariableDropdown = ({\n options,\n onSelect,\n toolbarWidth,\n}: {\n options: { value: string; label: string }[]\n onSelect: (value: string) => void\n toolbarWidth: number\n}) => {\n const [isOpen, setIsOpen] = useState(false)\n\n return (\n
\n {\n e.stopPropagation()\n e.preventDefault()\n setIsOpen(!isOpen)\n }}\n className=\"border text-black font-semibold text-xs px-3 py-[3px] rounded-md flex items-center hover:bg-gray-50 focus:outline-none\"\n >\n Add Variable\n \n \n\n {isOpen && (\n
\n {options.map((option) => (\n {\n onSelect(option.value)\n setIsOpen(false)\n }}\n className=\"block w-full text-left px-3 py-2 hover:bg-gray-100 focus:outline-none\"\n >\n {option.label}\n \n ))}\n
\n )}\n
\n )\n}\n","import React, { MutableRefObject, useState } from \"react\"\nimport classNames from \"../../../utils/classNames\"\nimport { currencySymbol } from \"~/utils/currencySymbol\"\n\nconst InputFieldWithCurrency = ({\n type,\n ref,\n label,\n name,\n id,\n value,\n defaultValue,\n placeholder,\n disabled,\n className,\n icon,\n onError,\n onChange,\n onBlur,\n onFocus,\n full,\n currency,\n hideCurrency,\n isChanged,\n readOnly,\n required,\n min,\n max,\n dataTestId,\n}: {\n type?: string\n ref?: MutableRefObject\n label?: string\n name?: string\n id?: string\n value?: any\n defaultValue?: any\n placeholder?: any\n disabled?: boolean\n className?: string\n icon?: any\n onError?: (err: any) => any\n onChange?: (e: any) => any\n onBlur?: (e: any) => any\n onFocus?: (e: any) => any\n full?: boolean\n currency?: string\n hideCurrency?: boolean\n isChanged?: boolean\n readOnly?: boolean\n required?: boolean\n min?: number\n max?: number\n dataTestId?: string\n}) => {\n const handleChange = (e: React.ChangeEvent) => {\n let finalValue = e.target.value.trim()\n const validNumberRegex = /^-?\\d*(\\.\\d*)?$/\n if (!validNumberRegex.test(finalValue)) {\n return\n }\n\n const parsedValue = parseFloat(finalValue)\n const mMax = max || Number.MAX_SAFE_INTEGER\n\n if (!isNaN(parsedValue)) {\n if (parsedValue > mMax) {\n finalValue = mMax.toString()\n }\n }\n\n onChange && onChange({ target: { name, value: finalValue } })\n }\n\n return (\n
\n {label && (\n \n {label}\n {required && *}\n \n )}\n
\n
\n {currency && {currencySymbol(currency)}}\n
\n \n {!hideCurrency && (\n
\n \n {currency?.toUpperCase() || \"USD\"}\n \n
\n )}\n
\n
\n )\n}\n\nexport default InputFieldWithCurrency\n","import React, { ChangeEvent, MutableRefObject, useState } from 'react'\nimport { JsxElement } from 'typescript'\nimport { titleCase } from '../../../utils'\nimport classNames from '../../../utils/classNames'\n\nconst InputFieldWithButton = ({\n type,\n ref,\n label,\n name,\n defaultValue,\n value,\n disabled,\n className,\n icon,\n onClick,\n onChange,\n full,\n readOnly,\n button,\n}: {\n type?: string\n ref?: MutableRefObject\n label?: string\n name?: string\n defaultValue?: any\n value?: any\n disabled?: boolean\n className?: string\n icon?: any\n onClick?: () => any\n full?: boolean\n onChange?: (e: ChangeEvent) => any\n readOnly?: boolean\n button?: JSX.Element | JSX.Element[]\n}) => {\n const [bgColorClass, setBgColorClass] = useState('bg-white')\n\n return (\n
\n {label ||\n (name && (\n \n ))}\n
\n {\n if (defaultValue !== undefined && e.target.value !== defaultValue) {\n setBgColorClass('bg-blue-50')\n } else {\n setBgColorClass('bg-white')\n }\n\n if (onChange) onChange(e)\n }}\n />\n {button ? (\n button\n ) : (\n \n {icon}\n \n )}\n
\n
\n )\n}\n\nexport default InputFieldWithButton\n","const copyText = (str: string) => {\n if ('clipboard' in navigator) {\n navigator.clipboard.writeText(str)\n } else {\n const el = document.createElement('textarea')\n el.value = str\n document.body.appendChild(el)\n el.select()\n document.execCommand('copy')\n document.body.removeChild(el)\n }\n}\n\nexport default copyText\n","import React from 'react'\nimport { Transition } from '@headlessui/react'\nimport { Fragment, useState } from 'react'\nimport Button from './Button'\nimport classNames from '../../utils/classNames'\nimport copyText from '../../utils/copyText'\nimport { CheckIcon } from '@heroicons/react/24/outline'\nimport { LinkIcon } from '@heroicons/react/24/solid'\n\nconst CopyPasteButton = (props: {\n text?: string\n value: string\n mobile?: boolean\n closeModal?\n isEmbedLinkBtn?: boolean\n buttonClassName?: string\n iconClassName?: any\n isClickedCallback?: (v: boolean) => void\n id?: string\n isClipboardBtn?: boolean\n personalNote?: string\n disabled?: boolean\n}) => {\n const [clicked, setClicked] = useState(false)\n const [clickedTimeout, setClickedTimeout] = useState(setTimeout(() => {}))\n\n const handleClick = () => {\n setClicked(true)\n if (props.isClickedCallback) props.isClickedCallback(true)\n\n copyText(props.value)\n\n clearTimeout(clickedTimeout)\n\n setClickedTimeout(\n setTimeout(() => {\n setClicked(false)\n if (props.isClickedCallback) props.isClickedCallback(false)\n if (props.closeModal) props.closeModal()\n }, 2500)\n )\n }\n\n const handleIcon = () => {\n if (props.isClipboardBtn) {\n return \n }\n\n return \n }\n\n if (!props.text)\n return (\n \n )\n else\n return (\n \n
\n \n \n {handleIcon()}\n Copy {props.text}\n \n \n \n \n \n Copied!\n \n \n
\n \n )\n}\n\nexport default CopyPasteButton\n","const baseUrl = () => {\n const isProduction = !(window.origin.includes('localhost') || window.origin.includes('herokuapp'));\n\n if (isProduction) {\n return `https://parkwith.us`;\n } else {\n return `${window.origin}`;\n }\n};\n\nexport default baseUrl;\n","import React, { useContext, useState } from 'react'\nimport { SiteProps } from '../../../interfaces'\nimport { ModalContext } from '../../../contexts/admin/ModalContext'\nimport api from '../../../api2'\nimport { AdminContext } from '../../../contexts/AdminContext'\nimport IVendorCalendar from '../../../interfaces/IVendorCalendar'\nimport { LinkIcon } from '@heroicons/react/24/outline'\n\nimport AirBnb from \"images/vendor_icons/Airbnb.svg?react\"\nimport Booking from 'images/vendor_icons/booking.svg?react'\nimport Hipcamp from 'images/vendor_icons/hipcamp.svg?react'\nimport Vrbo from 'images/vendor_icons/vrbo.svg?react'\nimport InputFieldWithButton from '../Inputs/InputFieldWithButton'\nimport CopyPasteButton from '../../ui/CopyPasteButton'\nimport Button from '../../ui/Button'\nimport baseUrl from '~/utils/admin/baseUrl'\n\nconst isValidCalendarSync = (url: string): boolean => {\n try {\n const parsedUrl = new URL(url)\n return parsedUrl.hostname.includes(\"booking.com\")\n ? parsedUrl.hostname.includes('.') && url.includes(\"ical\")\n : parsedUrl.hostname.includes('.') && parsedUrl.pathname.includes('.ics')\n } catch (error) {\n return false\n }\n}\n\nconst externalNameFor = (urlStr: string, isThrowingError = false) => {\n try {\n const url = new URL(urlStr)\n const hostnameArr = url.hostname.split('.')\n return hostnameArr[hostnameArr.length - 2]\n } catch (error) {\n if (isThrowingError) {\n throw error\n } else {\n return ''\n }\n }\n}\n\nconst VendorCalendarModalContent = ({ site, vendorCalendar }: { site: SiteProps, vendorCalendar: IVendorCalendar }) => {\n const { showNotification, sites, setSites } = useContext(AdminContext)\n const { onClose } = useContext(ModalContext)\n const [isRemoveButtonClicked, setIsRemoveButtonClicked] = useState(false)\n const [isLoading, setIsLoading] = useState(false)\n const [errorMessage, setErrorMessage] = useState('')\n const [externalUrl, setExternalUrl] = useState(vendorCalendar?.calendar_url || '')\n const [isValidUrl, setIsValidUrl] = useState(isValidCalendarSync(externalUrl))\n\n const handleCreateSave = (e: React.FormEvent) => {\n e.preventDefault()\n setIsLoading(true)\n\n const upsertedData = {\n id: null,\n kind: externalNameFor(externalUrl),\n calendar_url: externalUrl\n }\n\n\n api.Sites.update(site?.id, {\n vendor_calendars_attributes: site?.vendor_calendars?.filter((vc) => vc?.id !== vendorCalendar?.id)?.map((vc) => ({\n id: vc.id,\n kind: vc.kind,\n calendar_url: vc.calendar_url\n })).concat([upsertedData])\n })\n .then(({ site }) => {\n showNotification({\n type: 'success',\n title: 'Vendor Calendar Created!',\n description: 'The calendar sync was successfully created.',\n })\n setSites(sites.map((s) => s.id === site.id ? site : s))\n onClose()\n setIsLoading(false)\n // TODO: reload site data for slideover\n })\n .catch((error) => {\n setErrorMessage(error.message)\n setIsLoading(false)\n })\n }\n\n const handleEditSave = (e: React.FormEvent) => {\n e.preventDefault()\n setIsLoading(true)\n\n api.Sites.update(site?.id, {\n vendor_calendars_attributes: site?.vendor_calendars?.filter((vc) => vc.id !== vendorCalendar.id)?.map((vc) => ({\n id: vc.id,\n kind: vc.kind,\n calendar_url: vc.calendar_url\n }))?.concat([{\n id: vendorCalendar.id,\n kind: externalNameFor(externalUrl),\n calendar_url: externalUrl\n }])\n })\n .then(({ site }) => {\n showNotification({\n type: 'success',\n title: 'Vendor Calendar Updated!',\n description: 'The calendar sync was successfully updated.',\n })\n setSites(sites.map((s) => s.id === site.id ? site : s))\n onClose()\n setIsLoading(false)\n })\n }\n\n const handleCancel = (e: React.FormEvent) => {\n e.preventDefault()\n onClose()\n }\n\n const handleRemoveClick = (e) => {\n isRemoveButtonClicked ? handleArchive(e) : setIsRemoveButtonClicked(true)\n }\n\n const handleArchive = (e: React.FormEvent) => {\n setIsRemoveButtonClicked(false)\n e.preventDefault()\n setIsLoading(true)\n\n api.Sites.update(site?.id, {\n vendor_calendars_attributes: site?.vendor_calendars?.filter((vc) => vc.id !== vendorCalendar.id)?.map((vc) => ({\n id: vc.id,\n kind: vc.kind,\n calendar_url: vc.calendar_url,\n _destroy: false\n }))?.concat([{\n id: vendorCalendar.id,\n kind: vendorCalendar.kind,\n calendar_url: vendorCalendar.calendar_url,\n _destroy: true\n }])\n })\n .then(({ site }) => {\n showNotification({\n type: 'success',\n title: 'Vendor Calendar Deleted!',\n description: 'The calendar sync was successfully deleted.',\n })\n setSites(sites.map((s) => s.id === site.id ? site : s))\n onClose()\n setIsLoading(false)\n })\n }\n\n const parkCalendarUrlFor = (site: SiteProps, externalUrl: string) => {\n if (!externalUrl) {\n return `${baseUrl()}/api/calendars/${site.id}.ics`\n }\n\n try {\n return `${baseUrl()}/api/calendars/${site.id}.ics?calendar=${externalNameFor(externalUrl, true)}`\n } catch (error) {\n return `${baseUrl()}/api/calendars/${site.id}.ics`\n }\n }\n\n return (\n \n
\n
\n Create Calendar Sync\n
\n
Step 1
\n
\n Paste in the external URL. It must be a valid .ics URL path.\n
\n
\n {\n setIsValidUrl(isValidCalendarSync(v))\n setExternalUrl(v)\n }} />\n
\n
Step 2
\n
\n Copy the Park URL and paste it into the vendor.\n
\n
\n \n }\n />\n
\n
\n
\n \n\n
\n \n \n
\n
\n \n )\n}\n\nexport const ExternalCalendarUrlInput = ({ url, setUrl, readOnly }: { url: string; setUrl: (v: string) => void; readOnly?: boolean }) => {\n const [error, setError] = useState(\"\")\n\n const getVendorImage = (url: string) => {\n if (url.toLocaleLowerCase().includes(\"airbnb\")) {\n return \n } else if (url.toLocaleLowerCase().includes(\"hipcamp\")) {\n return \n } else if (url.toLocaleLowerCase().includes(\"booking\")) {\n return \n } else if (url.toLocaleLowerCase().includes(\"vrbo\")) {\n return \n } else {\n return (\n
\n \n
\n )\n }\n }\n\n return (\n
\n
\n {getVendorImage(url)}\n
\n {\n const value = e.currentTarget.value\n\n setError(\"\")\n\n setUrl(value)\n\n if (value !== 'ics') {\n setError('Incorrect file extension, it should be \".ics\"')\n }\n }}\n value={url}\n className='block w-full rounded-md border-gray-300 shadow-sm focus:border-green-700 focus:ring-green-700 pl-11'\n />\n
\n )\n}\n\nexport default VendorCalendarModalContent\n","import { CAMPING_STYLES } from '../constants'\nimport { validCampingStyles } from '../types'\nimport titleCase from './titleCase'\n\nconst formatCampingStyleName = (name: validCampingStyles | string, plural?: boolean) => {\n const formattedName = name?.replace(/-/g, ' ') || ''\n\n switch (formattedName) {\n case CAMPING_STYLES.RV:\n return 'RV Site' + (plural ? 's' : '')\n case CAMPING_STYLES.TENT:\n return 'Tent Site' + (plural ? 's' : '')\n case CAMPING_STYLES.STORAGE:\n return 'Storage unit' + (plural ? 's' : '')\n case CAMPING_STYLES.RV_STORAGE:\n return 'RV Storage'\n case CAMPING_STYLES.RENTAL_RV:\n return 'Rental RV' + (plural ? 's' : '')\n default:\n return titleCase(formattedName) + (plural ? 's' : '')\n }\n}\n\nexport default formatCampingStyleName\n","import React, { useContext } from 'react'\nimport { titleCase } from '../../utils'\n\nimport { SiteProps } from '../../interfaces'\n\nimport iconFor from '../../utils/iconFor'\nimport { ELECTRICS, KINDS } from '../../constants'\nimport ExternalSvg from '../ui/ExternalSvg'\nimport formatCampingStyleName from '../../utils/formatCampingStyleName'\nimport { formatMoney, formatMoneyFromCents } from '~/utils/formatMoney'\nimport formatLengthUnit from '~/utils/formatLengthUnit'\nimport { BookerContext } from '~/contexts/BookerContext'\n\nlet featureText: object = {\n camper_capacity: '?',\n kind: '?',\n pad_type: '?',\n max_rig_length: 'Max rig length: ?',\n extra_car_space: 'Extra car space',\n electric: 'Electric, ? Amps',\n has_wifi: 'Wifi',\n water: 'Water',\n sewage: 'Sewage',\n public_bathrooms: 'Bathrooms',\n showers: '? showers',\n has_laundry: 'Laundry',\n pets: 'Pets allowed',\n public_kitchen: 'Public kitchen access',\n dump_station: 'Dump station available',\n dumpster: 'Dumpsters',\n picnic_table: 'Picnic table',\n cable_tv: 'Cable TV',\n fire_pit: 'Fire pit',\n cellular: 'Mobile cell reception',\n dog_park: 'Dog park',\n general_store: 'General store',\n pool: 'Pool',\n premium_view: 'Premium view',\n has_heating: 'Heater',\n has_microwave: 'Microwave',\n has_oven: 'Oven',\n has_refrigerator: 'Refrigerator',\n has_stove: 'Stove',\n has_air_conditioning: 'Air-conditioning',\n has_private_bathroom: 'Private bathroom',\n number_of_futon_beds: '? futon bed',\n number_of_king_beds: '? king bed',\n number_of_queen_beds: '? queen bed',\n number_of_full_beds: '? full bed',\n number_of_twin_beds: '? twin bed',\n number_of_single_beds: '? single bed',\n number_of_bunk_beds: '? bunk bed',\n has_grill_barbecue: 'Grill/Barbecue',\n has_restaurant: 'Restaurant',\n has_tv: 'TV',\n has_playground: 'Playground',\n has_propane_fill_up: 'Propane fill-up',\n has_volleyball_court: 'Volleyball court',\n has_basketball_court: 'Basketball court',\n disc_golf_course: 'Disc golf course',\n has_golf_course: 'Golf course',\n has_mini_golf_course: 'Mini golf course',\n has_community_fire_pit: 'Community fire pit',\n has_hotplate: 'Hotplate',\n has_towels: 'Bring your own towels',\n}\n\ninterface componentProps {\n name: keyof SiteProps\n value: any\n site: SiteProps\n isShowingLabel: boolean\n}\n\nconst hiddenIfNull = ['has_linens', 'fire_pit', 'picnic_table']\n\nconst Feature = (props: componentProps) => {\n const { camp } = useContext(BookerContext)\n\n if (!iconFor(props.name, props.value) && props.name != 'electric' && props.name != 'kind') {\n return null\n }\n\n if (hiddenIfNull.includes(props.name) && (props.value === undefined || props.value === null)) {\n return null\n }\n\n const name = props.name\n let value = props.value\n\n if (name == 'showers') {\n value = titleCase(value)\n }\n\n const featureTextCheck = () => {\n if (name === 'camper_capacity') {\n return featureText[name].replace('?', 'Max capacity: ' + value)\n } else if (name == 'max_rig_length') {\n return featureText[name].replace('?', value + formatLengthUnit(camp?.length_unit))\n } else if (name === 'has_laundry') {\n return displayTextForLaundry(name, value, props.site.laundry_cost, camp?.currency)\n } else if (name === 'fire_pit') {\n return value ? featureText[name].replace('?', value) : 'No fire pits available'\n } else if (name === 'picnic_table') {\n return value ? featureText[name].replace('?', value) : 'No picnic tables available'\n } else if (name === 'has_linens' && value !== undefined) {\n return value ? 'Linens provided' : 'Bring your own linens'\n } else if (name === 'water' && value === false) {\n return 'No water available at this site'\n } else if (name === 'has_towels' && value !== undefined) {\n return value ? 'Towels provided' : 'Bring your own towels'\n } else if (name == 'electric') {\n if (value == ELECTRICS.NONE) {\n return 'No electric available at this site'\n } else if (value === ELECTRICS.BASIC) {\n return 'Electricity'\n } else {\n return featureText[name].replace('?', value)\n }\n } else if (name == 'has_wifi' && value) {\n let wifiText = featureText[name]\n\n if (props.site.wifi_extra_charge_cents) {\n wifiText += ` (extra charge of ${formatMoneyFromCents(\n props.site.wifi_extra_charge_cents,\n camp?.currency\n )})`\n }\n return wifiText\n } else if (name == 'kind') {\n if (value === KINDS.RV_HYBRID) {\n return 'You may need to back-in or pull-through'\n } else {\n return featureText[name].replace('?', formatCampingStyleName(value))\n }\n } else if (name == 'pad_type' && value) {\n return `${titleCase(value)} surface`\n } else if (name.includes('beds')) {\n if (value === 1) {\n return featureText[name].replace('?', value)\n } else {\n return featureText[name].replace('?', value) + 's'\n }\n } else {\n return featureText[name].replace('?', value)\n }\n }\n\n return (\n props.value != null && (\n
\n {props.name === \"kind\" && props.site.icon_url ? (\n \n ) : (\n {props.name}\n )}\n {props.isShowingLabel &&
\n {featureTextCheck()}\n
}\n
\n )\n )\n}\n\nconst displayTextForLaundry = (name: string, value: boolean, cost: number, currency: string) => {\n if (!value) return 'No laundry available'\n\n let suffix = ''\n\n if (cost !== null) {\n suffix = cost == 0 ? ', free-to-use' : `, pay-per-use ${formatMoney(cost, currency)}`\n }\n\n return featureText[name] + suffix\n}\n\nexport default Feature\n","export const features = [\n \"kind\",\n \"pad_type\",\n \"camper_capacity\",\n \"has_linens\",\n \"max_rig_length\",\n \"extra_car_space\",\n \"premium_view\",\n \"electric\",\n \"electric_15\",\n \"electric_20\",\n \"electric_30\",\n \"electric_50\",\n \"water\",\n \"sewage\",\n \"has_wifi\",\n \"pets\",\n \"dog_park\",\n \"pool\",\n \"dump_station\",\n \"public_bathrooms\",\n \"showers\",\n \"has_laundry\",\n \"public_kitchen\",\n \"picnic_table\",\n \"cable_tv\",\n \"fire_pit\",\n \"general_store\",\n \"has_heating\",\n \"has_microwave\",\n \"has_oven\",\n \"has_refrigerator\",\n \"has_stove\",\n \"has_air_conditioning\",\n \"has_private_bathroom\",\n \"number_of_king_beds\",\n \"number_of_futon_beds\",\n \"number_of_queen_beds\",\n \"number_of_full_beds\",\n \"number_of_twin_beds\",\n \"number_of_single_beds\",\n \"number_of_bunk_beds\",\n \"has_community_fire_pit\",\n \"has_grill_barbecue\",\n \"has_restaurant\",\n \"has_tv\",\n \"has_playground\",\n \"has_propane_fill_up\",\n \"has_volleyball_court\",\n \"has_basketball_court\",\n \"disc_golf_course\",\n \"has_golf_course\",\n \"has_mini_golf_course\",\n \"has_hotplate\",\n \"has_towels\",\n]\n\nexport const booleanFeatures = [\n \"sewage\",\n \"fire_pit\",\n \"has_grill_barbecue\",\n \"pets\",\n \"has_wifi\",\n \"extra_car_space\",\n \"premium_view\",\n \"cable_tv\",\n]\n\nexport const lodgingFeatures = [\n \"has_towels\",\n \"has_private_bathroom\",\n \"has_heating\",\n \"has_air_conditioning\",\n \"has_microwave\",\n \"has_oven\",\n \"has_stove\",\n \"has_hotplate\",\n \"has_refrigerator\",\n \"has_tv\",\n]\n\nexport const bedFeatures = [\n \"number_of_single_beds\",\n \"number_of_twin_beds\",\n \"number_of_bunk_beds\",\n \"number_of_futon_beds\",\n \"number_of_full_beds\",\n \"number_of_queen_beds\",\n \"number_of_king_beds\",\n]\n\n//hold off on these for now\nexport const campFeatures = [\n \"dog_park\",\n \"pool\",\n \"dump_station\",\n \"public_bathrooms\",\n \"showers\",\n \"has_laundry\",\n \"public_kitchen\",\n \"picnic_table\",\n \"general_store\",\n \"has_playground\",\n \"has_propane_fill_up\",\n \"has_volleyball_court\",\n \"has_basketball_court\",\n \"disc_golf_course\",\n \"has_golf_course\",\n \"has_mini_golf_course\",\n \"has_restaurant\",\n \"has_community_fire_pit\",\n]\n","import React, { useContext, useEffect, useState } from \"react\"\nimport { CAMPING_STYLES, ELECTRICS, KINDS } from \"../../../constants\"\nimport { PRICE_DURATIONS } from \"../../../constants/price_durations\"\nimport { CampProps, PriceProps, SiteProps } from \"../../../interfaces\"\nimport { validCampingStyles, validDurations, validElectric, validKinds } from \"../../../types\"\nimport { titleCase } from \"../../../utils\"\nimport classNames from \"../../../utils/classNames\"\nimport HoverTip from \"../../ui/HoverTip\"\nimport SelectInput, { Option } from \"../../ui/SelectInput\"\nimport Toggle from \"../../ui/Toggle\"\nimport { AdminContext } from \"../../../contexts/AdminContext\"\nimport SitePhotoUpload from \"../SitePhotoUpload\"\nimport RichTextInput from \"../../ui/RichTextInput\"\nimport InputFieldWithCurrency from \"../Inputs/InputFieldWithCurrency\"\nimport Button from \"../../ui/Button\"\nimport VendorCalendarModalContent, { ExternalCalendarUrlInput } from \"../VendorCalendars/VendorCalendarModalContent\"\nimport IVendorCalendar from \"../../../interfaces/IVendorCalendar\"\nimport formatLengthUnit from \"~/utils/formatLengthUnit\"\nimport Feature from \"~/components/DetailsPayment/Feature\"\nimport { bedFeatures, booleanFeatures, features, lodgingFeatures } from \"~/components/Sites/SiteFeatures\"\n\nconst campingStyleOptions = [\n { label: \"RV\", value: CAMPING_STYLES.RV },\n { label: \"Seasonal RV\", value: CAMPING_STYLES.RV },\n { label: \"Cabin\", value: CAMPING_STYLES.CABIN },\n { label: \"Tent\", value: CAMPING_STYLES.TENT },\n { label: \"Boat Slip\", value: CAMPING_STYLES.BOAT_SLIP },\n { label: \"Boat Rental\", value: CAMPING_STYLES.BOAT_RENTAL },\n { label: \"Mobile Home\", value: CAMPING_STYLES.MOBILE_HOME },\n { label: \"Storage\", value: CAMPING_STYLES.STORAGE },\n { label: \"Pavilion\", value: CAMPING_STYLES.PAVILION },\n { label: \"Cabana\", value: CAMPING_STYLES.CABANA },\n { label: \"Event Center\", value: CAMPING_STYLES.EVENT_CENTER },\n { label: \"Garage\", value: CAMPING_STYLES.GARAGE },\n { label: \"Horse Pen\", value: CAMPING_STYLES.HORSE_PEN },\n { label: \"Horse Stall\", value: CAMPING_STYLES.HORSE_STALL },\n { label: \"RV Storage\", value: CAMPING_STYLES.RV_STORAGE },\n { label: \"Rental RV\", value: CAMPING_STYLES.RENTAL_RV },\n { label: \"Lodge\", value: CAMPING_STYLES.LODGE },\n { label: \"Golf Cart\", value: CAMPING_STYLES.GOLF_CART },\n { label: \"Pool\", value: CAMPING_STYLES.POOL },\n { label: \"Shelter\", value: CAMPING_STYLES.SHELTER },\n { label: \"Vendor Booth\", value: CAMPING_STYLES.VENDOR_BOOTH },\n { label: \"Disc Golf\", value: CAMPING_STYLES.DISC_GOLF },\n { label: \"Dry Camping\", value: CAMPING_STYLES.DRY_CAMPING },\n { label: \"Dome\", value: CAMPING_STYLES.DOME },\n { label: \"Glamping\", value: CAMPING_STYLES.GLAMPING },\n { label: \"Home\", value: CAMPING_STYLES.HOME },\n { label: \"Lodging\", value: CAMPING_STYLES.LODGING },\n { label: \"Bonfire\", value: CAMPING_STYLES.BONFIRE },\n { label: \"Truck\", value: CAMPING_STYLES.TRUCK },\n { label: \"Croup\", value: CAMPING_STYLES.GROUP },\n { label: \"Cottage\", value: CAMPING_STYLES.COTTAGE },\n { label: \"Main House\", value: CAMPING_STYLES.MAIN_HOUSE },\n { label: \"Food Truck\", value: CAMPING_STYLES.FOOD_TRUCK },\n { label: \"Miscellaneous\", value: CAMPING_STYLES.MISC },\n { label: \"Ensuite Unit\", value: CAMPING_STYLES.ENSUITE_UNIT },\n { label: \"Unpowered Site\", value: CAMPING_STYLES.UNPOWERED_SITE },\n { label: \"Tipi\", value: CAMPING_STYLES.TIPI },\n { label: \"Kayak\", value: CAMPING_STYLES.KAYAK },\n { label: \"Van\", value: CAMPING_STYLES.VAN },\n { label: \"Room\", value: CAMPING_STYLES.ROOM },\n { label: \"Rental Item\", value: CAMPING_STYLES.RENTAL_ITEM },\n { label: \"Generator\", value: CAMPING_STYLES.GENERATOR },\n { label: \"Picnic Area\", value: CAMPING_STYLES.PICNIC_AREA },\n { label: \"Kitchen\", value: CAMPING_STYLES.KITCHEN },\n { label: \"Platform\", value: CAMPING_STYLES.PLATFORM },\n { label: \"Canvas Tent\", value: CAMPING_STYLES.CANVAS_TENT },\n]\n\nconst kindOptions = [\n { label: \"Back-in\", value: KINDS.RV_BACKIN },\n { label: \"Pull-through\", value: KINDS.RV_PULLTHROUGH },\n { label: \"Pull-in\", value: KINDS.RV_PULLIN },\n { label: \"Hybrid\", value: KINDS.RV_HYBRID },\n // NOTE: these are automatically set when changing camping style. Legacy reasons.\n { label: \"Tent\", value: KINDS.TENT, hidden: true },\n { label: \"Cabin\", value: KINDS.CABIN, hidden: true },\n { label: \"Boat Slip\", value: KINDS.BOAT_SLIP, hidden: true },\n { label: \"Boat Rental\", value: KINDS.BOAT_RENTAL, hidden: true },\n { label: \"Mobile Home\", value: KINDS.MOBILE_HOME, hidden: true },\n { label: \"Storage\", value: KINDS.STORAGE, hidden: true },\n { label: \"Pavilion\", value: KINDS.PAVILION, hidden: true },\n { label: \"Cabana\", value: KINDS.CABANA, hidden: true },\n { label: \"Event Center\", value: KINDS.EVENT_CENTER, hidden: true },\n { label: \"Garage\", value: KINDS.GARAGE, hidden: true },\n { label: \"Horse Pen\", value: KINDS.HORSE_PEN, hidden: true },\n { label: \"Horse Stall\", value: KINDS.HORSE_STALL, hidden: true },\n { label: \"RV Storage\", value: KINDS.RV_STORAGE, hidden: true },\n { label: \"Rental RV\", value: KINDS.RENTAL_RV, hidden: true },\n { label: \"Lodge\", value: KINDS.LODGE, hidden: true },\n { label: \"Golf Cart\", value: KINDS.GOLF_CART, hidden: true },\n { label: \"Pool\", value: KINDS.POOL, hidden: true },\n { label: \"Shelter\", value: KINDS.SHELTER, hidden: true },\n { label: \"Vendor Booth\", value: KINDS.VENDOR_BOOTH, hidden: true },\n { label: \"Disc Golf\", value: KINDS.DISC_GOLF, hidden: true },\n { label: \"Dry Camping\", value: KINDS.DRY_CAMPING, hidden: true },\n { label: \"Dome\", value: KINDS.DOME, hidden: true },\n { label: \"Glamping\", value: KINDS.GLAMPING, hidden: true },\n { label: \"Home\", value: KINDS.HOME, hidden: true },\n { label: \"Lodging\", value: KINDS.LODGING, hidden: true },\n { label: \"Bonfire\", value: KINDS.BONFIRE, hidden: true },\n { label: \"Truck\", value: CAMPING_STYLES.TRUCK, hidden: true },\n { label: \"Croup\", value: CAMPING_STYLES.GROUP, hidden: true },\n { label: \"Cottage\", value: CAMPING_STYLES.COTTAGE, hidden: true },\n { label: \"Main House\", value: CAMPING_STYLES.MAIN_HOUSE, hidden: true },\n { label: \"Tipi\", value: CAMPING_STYLES.TIPI, hidden: true },\n { label: \"Kayak\", value: CAMPING_STYLES.KAYAK, hidden: true },\n { label: \"Van\", value: CAMPING_STYLES.VAN, hidden: true },\n { label: \"Room\", value: CAMPING_STYLES.ROOM, hidden: true },\n { label: \"Rental Item\", value: CAMPING_STYLES.RENTAL_ITEM, hidden: true },\n { label: \"Generator\", value: CAMPING_STYLES.GENERATOR, hidden: true },\n { label: \"Picnic Area\", value: CAMPING_STYLES.PICNIC_AREA, hidden: true },\n { label: \"Kitchen\", value: CAMPING_STYLES.KITCHEN, hidden: true },\n { label: \"Platform\", value: CAMPING_STYLES.PLATFORM, hidden: true },\n { label: \"Canvas Tent\", value: CAMPING_STYLES.CANVAS_TENT, hidden: true },\n]\n\nconst electricOptions = [\n { label: \"Don't show electric\", value: null },\n { label: \"Electric (use where amperages don't matter)\", value: ELECTRICS.BASIC },\n { label: \"No electric\", value: ELECTRICS.NONE },\n ...Object.values(ELECTRICS)\n .filter((e) => e && e !== \"basic\" && e !== \"none\")\n .map((e) => ({ label: titleCase(e) + \" amp\", value: e })),\n]\n\nconst generatePriceTypesFor = (sites: SiteProps[]): { label: string; duration: validDurations }[] => {\n let priceTypes = [\n { label: \"Nightly rate\", duration: PRICE_DURATIONS.NIGHTLY },\n null,\n { label: \"Weekly rate\", duration: PRICE_DURATIONS.WEEKLY },\n { label: \"Monthly rate\", duration: PRICE_DURATIONS.MONTHLY },\n { label: \"Seasonal rate\", duration: PRICE_DURATIONS.SEASONAL },\n null,\n ] as { label: string; duration: validDurations }[]\n\n if (sites.flatMap((s) => s.prices).some((p) => p.duration === PRICE_DURATIONS.NIGHTLY_2_PLUS)) {\n priceTypes[1] = { label: \"Nightly rate (2+ nights)\", duration: PRICE_DURATIONS.NIGHTLY_2_PLUS }\n }\n\n if (sites.flatMap((s) => s.prices).some((p) => p.duration === PRICE_DURATIONS.FLAT_RATE)) {\n priceTypes[5] = { label: \"Flat rate\", duration: PRICE_DURATIONS.FLAT_RATE }\n }\n\n return priceTypes.filter((p) => p)\n}\n\nconst kindToStyle = (kind: validKinds): validCampingStyles => {\n if (!kind) return\n\n const rvKinds: validKinds[] = [KINDS.RV_BACKIN, KINDS.RV_PULLTHROUGH, KINDS.RV_HYBRID, KINDS.RV_PULLIN]\n\n if (rvKinds.includes(kind)) {\n return CAMPING_STYLES.RV\n } else {\n return kind as validCampingStyles\n }\n}\n\ninterface ComponentProps {\n site?: SiteProps\n camp?: CampProps\n isProcessing: boolean\n errorMessage: string\n setErrorMessage: (message: string) => void\n setIsSiteSaveDisabled: React.Dispatch>\n setIsSlideoverOpen: React.Dispatch>\n showFeatures: boolean\n setShowFeatures: React.Dispatch>\n}\n\nconst EditSiteForm = (props: ComponentProps) => {\n const { sites, isParkAdminUser, showModal, camp } = useContext(AdminContext)\n const [id, setId] = useState(props.site?.id)\n const [siteFeatures, setSiteFeatures] = useState(props.site)\n const [name, setName] = useState(props.site?.name)\n const [isBookable, setIsBookable] = useState(props.site?.is_bookable)\n const [prices, setPrices] = useState[]>(props.site?.prices)\n const [numberOfActivePrices, setNumberOfActivePrices] = useState(\n prices.filter((p) => (!!p && !!p.id) || (!!p && p[\"isActive\"])).length,\n )\n const [priceTypes, setPriceTypes] = useState<{ label: string; duration: validDurations }[]>(\n generatePriceTypesFor(sites),\n )\n const [selectedCampingStyle, setSelectedCampingStyle] = useState(\n kindToStyle(props.site?.kind as validKinds),\n )\n const [selectedKind, setSelectedKind] = useState(props.site?.kind as validKinds)\n const [selectedElectric, setSelectedElectric] = useState(props.site?.electric as validElectric)\n const [maxRigLength, setMaxRigLength] = useState(String(props.site?.max_rig_length))\n const [camperCapacity, setCamperCapacity] = useState(String(props.site?.camper_capacity))\n const [minimumCapacity, setMinimumCapacity] = useState(String(props.site?.minimum_capacity))\n const [currentMeterReading, setCurrentMeterReading] = useState(String(props.site?.last_meter_reading))\n const [notes, setNotes] = useState(String(props.site?.notes || \"\"))\n const [checkinPolicyAdditions, setCheckinPolicyAdditions] = useState(props.site?.checkin_policy_additions)\n const rigLengthStyles: validCampingStyles[] = [CAMPING_STYLES.RV, CAMPING_STYLES.BOAT_SLIP]\n const CAPACITY_STYLES: validCampingStyles[] = [\n CAMPING_STYLES.CABIN,\n CAMPING_STYLES.RENTAL_RV,\n CAMPING_STYLES.MOBILE_HOME,\n CAMPING_STYLES.HOME,\n CAMPING_STYLES.LODGING,\n CAMPING_STYLES.LODGE,\n CAMPING_STYLES.GLAMPING,\n CAMPING_STYLES.DOME,\n ]\n\n const waterOptions = [\n { label: \"Yes\", value: true },\n { label: \"No\", value: false },\n { label: \"Not specified\", value: null },\n ]\n const linenOptions = [\n { label: \"Provided\", value: true },\n { label: \"Not provided\", value: false },\n { label: \"Not specified\", value: null },\n ]\n const [waterOption, setWaterOption] = useState