{"version":3,"file":"static/js/index.844ee5a1.js","sources":["webpack://web/./src/App.tsx","webpack://web/./src/AppDependencies.tsx","webpack://web/./src/AppVersion.mjs","webpack://web/./src/CommunicationHandler.tsx","webpack://web/./src/MessagingWidgetApp.tsx","webpack://web/./src/client/CarrierInfoClient.ts","webpack://web/./src/client/FeedClient.ts","webpack://web/./src/client/LoadVisibilityRulesClient.ts","webpack://web/./src/client/OnboardedCarriersClient.ts","webpack://web/./src/client/PostLoadsClient.ts","webpack://web/./src/client/ShareableLoadsClient.ts","webpack://web/./src/client/UnsubscribeClient.ts","webpack://web/./src/client/UserSettingsClient.ts","webpack://web/./src/client/VerifyEmailClient.ts","webpack://web/./src/client/WelcomebackCampaignClient.ts","webpack://web/./src/common/src/api/ApiErrorCode.ts","webpack://web/./src/common/src/api/ApiOptions.ts","webpack://web/./src/common/src/api/ApiResponse.ts","webpack://web/./src/common/src/api/ApiService.ts","webpack://web/./src/common/src/api/PendingAction.ts","webpack://web/./src/common/src/client/AvatarClient.ts","webpack://web/./src/common/src/client/BaseClient.ts","webpack://web/./src/common/src/client/BidsClient.ts","webpack://web/./src/common/src/client/CarrierTrackingClient.ts","webpack://web/./src/common/src/client/CommunicationClient.ts","webpack://web/./src/common/src/client/CompanyAvatarClient.ts","webpack://web/./src/common/src/client/CompanyClient.ts","webpack://web/./src/common/src/client/ContactClient.ts","webpack://web/./src/common/src/client/DocumentsClient.ts","webpack://web/./src/common/src/client/FeedbackClient.ts","webpack://web/./src/common/src/client/FtpClient.ts","webpack://web/./src/common/src/client/GeocodingClient.ts","webpack://web/./src/common/src/client/IdentityVerificationClient.ts","webpack://web/./src/common/src/client/InboxClient.ts","webpack://web/./src/common/src/client/LoadFeedbackClient.ts","webpack://web/./src/common/src/client/LoadsClient.ts","webpack://web/./src/common/src/client/LocationMatchClient.ts","webpack://web/./src/common/src/client/LocationsClient.ts","webpack://web/./src/common/src/client/MileageCalculatorClient.ts","webpack://web/./src/common/src/client/MyCarrierPortalClient.ts","webpack://web/./src/common/src/client/MyLoadsClient.ts","webpack://web/./src/common/src/client/PaymentClient.ts","webpack://web/./src/common/src/client/PermissionsClient.ts","webpack://web/./src/common/src/client/PostTruckClient.ts","webpack://web/./src/common/src/client/QuoteClient.ts","webpack://web/./src/common/src/client/RateCheckClient.ts","webpack://web/./src/common/src/client/RouteClient.ts","webpack://web/./src/common/src/client/SettingsClient.ts","webpack://web/./src/common/src/client/SharedLoadClient.ts","webpack://web/./src/common/src/client/SupportClient.ts","webpack://web/./src/common/src/client/TermsAndConditionsClient.ts","webpack://web/./src/common/src/client/ThunderFundingClient.ts","webpack://web/./src/common/src/client/TmsClient.ts","webpack://web/./src/common/src/client/TrackingClient.ts","webpack://web/./src/common/src/client/TripBuilderClient.ts","webpack://web/./src/common/src/client/TruckAlertsClient.ts","webpack://web/./src/common/src/client/TrucksClient.ts","webpack://web/./src/common/src/client/UploadFileClient.ts","webpack://web/./src/common/src/client/UserClient.ts","webpack://web/./src/common/src/client/UserPlanManagementClient.ts","webpack://web/./src/common/src/client/VendorBidsClient.ts","webpack://web/./src/common/src/client/VerifyPhoneClient.ts","webpack://web/./src/common/src/formatter/Constants.ts","webpack://web/./src/common/src/formatter/Dates.ts","webpack://web/./src/common/src/formatter/Number.ts","webpack://web/./src/common/src/helper/AlertPolling.ts","webpack://web/./src/common/src/helper/AnnouncementsHelper.ts","webpack://web/./src/common/src/helper/ApiHelper.ts","webpack://web/./src/common/src/helper/AutoRefreshManager.ts","webpack://web/./src/common/src/helper/BannerHelper.ts","webpack://web/./src/common/src/helper/BidsHelper.ts","webpack://web/./src/common/src/helper/ConversationHelper.ts","webpack://web/./src/common/src/helper/CreditRatingHelper.ts","webpack://web/./src/common/src/helper/DateHelper.ts","webpack://web/./src/common/src/helper/DocumentHelper.ts","webpack://web/./src/common/src/helper/DocumentSortingHelper.tsx","webpack://web/./src/common/src/helper/EquipmentHelper.ts","webpack://web/./src/common/src/helper/FileHelper.ts","webpack://web/./src/common/src/helper/FilterHelper.ts","webpack://web/./src/common/src/helper/FlowIDHeaderHelper.ts","webpack://web/./src/common/src/helper/Functions.ts","webpack://web/./src/common/src/helper/ImmutableLRUMap.ts","webpack://web/./src/common/src/helper/ItemHelper.ts","webpack://web/./src/common/src/helper/LRUMap.ts","webpack://web/./src/common/src/helper/LoadAvailabilityHelper.ts","webpack://web/./src/common/src/helper/LoadHelper.ts","webpack://web/./src/common/src/helper/LoadSearchRegionsHelper.ts","webpack://web/./src/common/src/helper/LoadSearchRequestFactory.ts","webpack://web/./src/common/src/helper/LoadTextFormater.ts","webpack://web/./src/common/src/helper/LocationHelper.ts","webpack://web/./src/common/src/helper/LocationPickerHelper.ts","webpack://web/./src/common/src/helper/MapHelper.ts","webpack://web/./src/common/src/helper/MyLoadsHelper.ts","webpack://web/./src/common/src/helper/NumberHelper.ts","webpack://web/./src/common/src/helper/PCMilerHelper.ts","webpack://web/./src/common/src/helper/PhoneHelper.ts","webpack://web/./src/common/src/helper/ProgressHelper.ts","webpack://web/./src/common/src/helper/RateCheckHistoryHelper.ts","webpack://web/./src/common/src/helper/SearchHelper.ts","webpack://web/./src/common/src/helper/SortByKeys.ts","webpack://web/./src/common/src/helper/TruckAvailabilityHelper.ts","webpack://web/./src/common/src/helper/URLValidationHelper.ts","webpack://web/./src/common/src/helper/UserHelper.ts","webpack://web/./src/common/src/helper/UserRolesUtils.ts","webpack://web/./src/common/src/helper/ValidationHelper.ts","webpack://web/./src/common/src/helper/Validators.ts","webpack://web/./src/common/src/helper/VendorLoadHelper.ts","webpack://web/./src/common/src/info/ContactInfo.ts","webpack://web/./src/common/src/info/ExternalLink.ts","webpack://web/./src/common/src/model/AppErrorCode.ts","webpack://web/./src/common/src/model/Bid.ts","webpack://web/./src/common/src/model/BookNow.ts","webpack://web/./src/common/src/model/Carrier.ts","webpack://web/./src/common/src/model/Carriers.ts","webpack://web/./src/common/src/model/Company.ts","webpack://web/./src/common/src/model/Conversation.ts","webpack://web/./src/common/src/model/CostPerDaySettings.ts","webpack://web/./src/common/src/model/Document.ts","webpack://web/./src/common/src/model/Equipment.ts","webpack://web/./src/common/src/model/Ftp.ts","webpack://web/./src/common/src/model/FuelPrice.ts","webpack://web/./src/common/src/model/Geolocation.ts","webpack://web/./src/common/src/model/Inbox.ts","webpack://web/./src/common/src/model/Invoice.ts","webpack://web/./src/common/src/model/Load.ts","webpack://web/./src/common/src/model/LoadAvailability.ts","webpack://web/./src/common/src/model/LoadFeedbackRequest.ts","webpack://web/./src/common/src/model/LoadSearchRequest.ts","webpack://web/./src/common/src/model/LoadSearchSettings.ts","webpack://web/./src/common/src/model/LoadSearchSort.ts","webpack://web/./src/common/src/model/LoadUserdata.ts","webpack://web/./src/common/src/model/LoadView.ts","webpack://web/./src/common/src/model/Location.ts","webpack://web/./src/common/src/model/LocationSuggestion.ts","webpack://web/./src/common/src/model/Messages.ts","webpack://web/./src/common/src/model/MyCarrierPortal.ts","webpack://web/./src/common/src/model/MyLoadsRequest.ts","webpack://web/./src/common/src/model/Payment.ts","webpack://web/./src/common/src/model/PostedLoadsUrl.ts","webpack://web/./src/common/src/model/PosterMetadata.ts","webpack://web/./src/common/src/model/ProfitCalculatorSettings.ts","webpack://web/./src/common/src/model/Quote.ts","webpack://web/./src/common/src/model/RateCheck.ts","webpack://web/./src/common/src/model/RatingInfo.ts","webpack://web/./src/common/src/model/RecentSearchLocationsResponse.ts","webpack://web/./src/common/src/model/RoutesSettings.ts","webpack://web/./src/common/src/model/SearchDirectory.ts","webpack://web/./src/common/src/model/States.ts","webpack://web/./src/common/src/model/Storage.ts","webpack://web/./src/common/src/model/SystemSettings.ts","webpack://web/./src/common/src/model/ThunderFundingRequest.ts","webpack://web/./src/common/src/model/Tracking.ts","webpack://web/./src/common/src/model/TripBuilder.ts","webpack://web/./src/common/src/model/Truck.ts","webpack://web/./src/common/src/model/UserAuthentication.ts","webpack://web/./src/common/src/model/UserPlan.ts","webpack://web/./src/common/src/model/UserProfile.ts","webpack://web/./src/common/src/model/VendorBid.ts","webpack://web/./src/common/src/model/VerificationPoints.ts","webpack://web/./src/common/src/model/messaging/MessageWidget.ts","webpack://web/./src/common/src/model/messaging/WidgetAction.ts","webpack://web/./src/common/src/redux/Base.ts","webpack://web/./src/common/src/redux/LastRequestOverrideMiddleware.ts","webpack://web/./src/common/src/redux/NormalizationHelper.ts","webpack://web/./src/common/src/redux/ReduxHelper.ts","webpack://web/./src/common/src/redux/ReduxRegistry.tsx","webpack://web/./src/common/src/redux/epic/AvatarEpic.ts","webpack://web/./src/common/src/redux/epic/BrokerEpic.ts","webpack://web/./src/common/src/redux/epic/CarrierTrackingEpic.ts","webpack://web/./src/common/src/redux/epic/CommunicationEpic.ts","webpack://web/./src/common/src/redux/epic/CompanyAvatarEpic.ts","webpack://web/./src/common/src/redux/epic/CompanyEpic.ts","webpack://web/./src/common/src/redux/epic/DocumentListEpic.ts","webpack://web/./src/common/src/redux/epic/DocumentsEpic.ts","webpack://web/./src/common/src/redux/epic/EpicHelper.ts","webpack://web/./src/common/src/redux/epic/FeedbackEpic.ts","webpack://web/./src/common/src/redux/epic/FoldersEpic.ts","webpack://web/./src/common/src/redux/epic/FtpEpic.ts","webpack://web/./src/common/src/redux/epic/IdentityVerificationEpic.ts","webpack://web/./src/common/src/redux/epic/InboxEpic.ts","webpack://web/./src/common/src/redux/epic/LoadAvailabilityEpic.ts","webpack://web/./src/common/src/redux/epic/LoadDetailsEpic.ts","webpack://web/./src/common/src/redux/epic/LoadDetailsMapEpic.ts","webpack://web/./src/common/src/redux/epic/LoadFeedbackEpic.ts","webpack://web/./src/common/src/redux/epic/LoadInfoEpic.ts","webpack://web/./src/common/src/redux/epic/LoadSearchSettingsEpic.ts","webpack://web/./src/common/src/redux/epic/LoadsEpic.ts","webpack://web/./src/common/src/redux/epic/LocationMatchEpic.ts","webpack://web/./src/common/src/redux/epic/MarketRatesEpic.ts","webpack://web/./src/common/src/redux/epic/MyCarrierPortalEpic.ts","webpack://web/./src/common/src/redux/epic/MyLoadsEpic.ts","webpack://web/./src/common/src/redux/epic/PaginatedListReducer.ts","webpack://web/./src/common/src/redux/epic/PaymentEpic.ts","webpack://web/./src/common/src/redux/epic/PermissionsEpic.ts","webpack://web/./src/common/src/redux/epic/PostTruckEpic.ts","webpack://web/./src/common/src/redux/epic/QuoteEpic.ts","webpack://web/./src/common/src/redux/epic/RateCheckEpic.ts","webpack://web/./src/common/src/redux/epic/RecentSearchLocationsEpic.ts","webpack://web/./src/common/src/redux/epic/RoutesEpic.ts","webpack://web/./src/common/src/redux/epic/ServiceCodeEpic.ts","webpack://web/./src/common/src/redux/epic/SettingsEpic.ts","webpack://web/./src/common/src/redux/epic/SettingsStateHelper.ts","webpack://web/./src/common/src/redux/epic/SharedLoadEpic.ts","webpack://web/./src/common/src/redux/epic/SystemTimeEpic.ts","webpack://web/./src/common/src/redux/epic/TermsAndConditionsEpic.ts","webpack://web/./src/common/src/redux/epic/ThunderFundingQuotesEpic.ts","webpack://web/./src/common/src/redux/epic/TmsEpic.ts","webpack://web/./src/common/src/redux/epic/TripBuilderEpic.ts","webpack://web/./src/common/src/redux/epic/TruckAlertsEpic.ts","webpack://web/./src/common/src/redux/epic/UploadFileEpic.ts","webpack://web/./src/common/src/redux/epic/UserEpic.ts","webpack://web/./src/common/src/redux/epic/UserPlanManagementEpic.ts","webpack://web/./src/common/src/redux/epic/UserTrucksEpic.ts","webpack://web/./src/common/src/redux/epic/VerifyPhoneEpic.ts","webpack://web/./src/common/src/redux/epic/bids/BidsEpic.ts","webpack://web/./src/common/src/redux/epic/bids/BidsStateHelper.ts","webpack://web/./src/common/src/redux/epic/bids/VendorBidsEpic.ts","webpack://web/./src/common/src/redux/epic/loadSearch/CompanySearchEpic.ts","webpack://web/./src/common/src/redux/epic/loadSearch/CompanySearchHelper.ts","webpack://web/./src/common/src/redux/epic/loadSearch/HelperFunctions.ts","webpack://web/./src/common/src/redux/epic/loadSearch/LoadSearchBackhaulsEpic.ts","webpack://web/./src/common/src/redux/epic/loadSearch/LoadSearchEpic.ts","webpack://web/./src/common/src/redux/epic/loadSearch/LoadSearchHelper.ts","webpack://web/./src/common/src/redux/epic/loadSearch/LoadSearchReducer.ts","webpack://web/./src/common/src/redux/epic/loadSearch/LoadSearchShared.ts","webpack://web/./src/common/src/redux/epic/loadSearch/MapSearchEpic.ts","webpack://web/./src/common/src/redux/epic/rateCheck/RateCheckHelper.ts","webpack://web/./src/common/src/redux/epic/rateCheck/RateCheckPreviewHelper.ts","webpack://web/./src/common/src/redux/reducer/ScreenSharingReducer.ts","webpack://web/./src/common/src/redux/reducer/TopRibbonReducer.ts","webpack://web/./src/common/src/redux/reducer/TutorialReducer.ts","webpack://web/./src/common/src/redux/reducer/UnderDevelopmentBaseReducer.ts","webpack://web/./src/common/src/socket/Communication.ts","webpack://web/./src/common/src/socket/SignalRSettings.ts","webpack://web/./src/common/src/sort/LoadSort.ts","webpack://web/./src/common/src/sort/LoadsMerger.ts","webpack://web/./src/common/src/sort/Sort.ts","webpack://web/./src/common/src/sort/TruckSort.ts","webpack://web/./src/common/src/translation/english.ts","webpack://web/./src/common/src/util/123lbBaseTracker.ts","webpack://web/./src/common/src/util/BidsTimeHelper.tsx","webpack://web/./src/common/src/util/CostPerDayHelper.tsx","webpack://web/./src/common/src/util/DependencyManager.tsx","webpack://web/./src/common/src/util/ProfitCalculatorHelper.tsx","webpack://web/./src/common/src/util/encoder/URLDefaultEncoder.ts","webpack://web/./src/common/src/util/hooks/UseDidUpdate.ts","webpack://web/./src/common/src/util/hooks/UseFactory.ts","webpack://web/./src/common/src/util/hooks/UseForceUpdate.ts","webpack://web/./src/common/src/util/hooks/UseInterval.ts","webpack://web/./src/common/src/util/hooks/UseMount.ts","webpack://web/./src/common/src/util/hooks/UseRefFunction.ts","webpack://web/./src/common/src/util/hooks/UseUnmount.ts","webpack://web/./src/common/src/util/parser/ParserUtils.ts","webpack://web/./src/component/backdrop/Backdrop.tsx","webpack://web/./src/component/badge/NewBadge.tsx","webpack://web/./src/component/badge/RatingBadge.tsx","webpack://web/./src/component/badge/VerificationBadge.tsx","webpack://web/./src/component/banner/Banner.tsx","webpack://web/./src/component/banner/ContactNotVerifiedBanner.tsx","webpack://web/./src/component/button/Button.tsx","webpack://web/./src/component/button/ButtonThemes.tsx","webpack://web/./src/component/button/CustomButton.tsx","webpack://web/./src/component/button/FloatingActionButton.tsx","webpack://web/./src/component/button/TextButton.tsx","webpack://web/./src/component/button/UploadButton.tsx","webpack://web/./src/component/buttons/ClearButton.tsx","webpack://web/./src/component/buttons/ContactsButton.tsx","webpack://web/./src/component/buttons/FilterButton.tsx","webpack://web/./src/component/buttons/IconActionButton.tsx","webpack://web/./src/component/buttons/LinkButton.tsx","webpack://web/./src/component/buttons/MainButton.tsx","webpack://web/./src/component/buttons/MessageWidgetButton.tsx","webpack://web/./src/component/buttons/MoreMenuButton.tsx","webpack://web/./src/component/buttons/MultipurposeButton.tsx","webpack://web/./src/component/buttons/MultipurposeButtonStyle.tsx","webpack://web/./src/component/buttons/NewLoadsButton.tsx","webpack://web/./src/component/buttons/TopButton.tsx","webpack://web/./src/component/calendar/Calendar.tsx","webpack://web/./src/component/calendar/CalendarGroup.tsx","webpack://web/./src/component/calendar/CalendarStyles.tsx","webpack://web/./src/component/calendar/DatesCalendar.tsx","webpack://web/./src/component/calendar/StatesCalendar.tsx","webpack://web/./src/component/cards/BackhaulCard.tsx","webpack://web/./src/component/cards/BackhaulsCard.tsx","webpack://web/./src/component/cards/CardsStyle.tsx","webpack://web/./src/component/cards/Destination.tsx","webpack://web/./src/component/cards/MyTruckCard.tsx","webpack://web/./src/component/cards/TruckPostCard.tsx","webpack://web/./src/component/chart/BaseChart.tsx","webpack://web/./src/component/chip/ActionChip.tsx","webpack://web/./src/component/chip/CancelableChip.tsx","webpack://web/./src/component/chip/ChipStyle.tsx","webpack://web/./src/component/chip/ChoiceChips.tsx","webpack://web/./src/component/chip/DateChip.tsx","webpack://web/./src/component/chip/TextChip.tsx","webpack://web/./src/component/chip/TimeChip.tsx","webpack://web/./src/component/contact/CallButton.tsx","webpack://web/./src/component/contact/MCUSDOT.tsx","webpack://web/./src/component/contact/PhoneNumber.tsx","webpack://web/./src/component/contact/UpgradeLink.tsx","webpack://web/./src/component/control/ActionsMenu.tsx","webpack://web/./src/component/control/Checkbox.tsx","webpack://web/./src/component/control/ControlStyles.tsx","webpack://web/./src/component/control/Radio.tsx","webpack://web/./src/component/control/RadioGroup.tsx","webpack://web/./src/component/conversation/ConversationAttachments.tsx","webpack://web/./src/component/conversation/ConversationAvatar.tsx","webpack://web/./src/component/conversation/ConversationMessageBubble.tsx","webpack://web/./src/component/conversation/ConversationStyles.tsx","webpack://web/./src/component/conversation/ConversationTime.tsx","webpack://web/./src/component/conversation/ConversationWidgetBubble.tsx","webpack://web/./src/component/conversation/composer/ChatFooter.tsx","webpack://web/./src/component/conversation/composer/ChatTextField.tsx","webpack://web/./src/component/conversation/composer/SendAttachmentButton.tsx","webpack://web/./src/component/conversation/widget/GenericWidget.tsx","webpack://web/./src/component/coutryRadioGroup/CountryRadioGroup.tsx","webpack://web/./src/component/coutryRadioGroup/CountryRadioGroupStyle.tsx","webpack://web/./src/component/dropdown/DropdownList.tsx","webpack://web/./src/component/dropdown/LocationDropdownList.tsx","webpack://web/./src/component/expansionPanel/ExpansionPanel.tsx","webpack://web/./src/component/expansionPanel/ExpansionPanelStyle.tsx","webpack://web/./src/component/expansionPanel/SideMenuExpansionPanel.tsx","webpack://web/./src/component/feed/ComingSoon.tsx","webpack://web/./src/component/feed/FeedController.tsx","webpack://web/./src/component/feed/FeedMappingHelper.ts","webpack://web/./src/component/feed/FeedPopup.tsx","webpack://web/./src/component/feed/FeedPopupButtons.tsx","webpack://web/./src/component/footers/ApplyButtonFooter.tsx","webpack://web/./src/component/fragmentPortal/FragmentHolder.ts","webpack://web/./src/component/fragmentPortal/FragmentPortalDestination.tsx","webpack://web/./src/component/fragmentPortal/FragmentPortalOrigin.tsx","webpack://web/./src/component/globalBanner/BillingIssueBanner.tsx","webpack://web/./src/component/globalBanner/GlobalBanner.tsx","webpack://web/./src/component/icon/ActionIcon.tsx","webpack://web/./src/component/image/ImageBase64.tsx","webpack://web/./src/component/input/checkBox/CheckBox.tsx","webpack://web/./src/component/input/chip/CheckboxChip.tsx","webpack://web/./src/component/input/select/BorderedSelect.tsx","webpack://web/./src/component/input/select/CustomSelect.tsx","webpack://web/./src/component/input/select/Fieldset.tsx","webpack://web/./src/component/input/textField/ConversationTextField.tsx","webpack://web/./src/component/input/textField/CustomTextField.tsx","webpack://web/./src/component/input/textField/MultilineTextField.tsx","webpack://web/./src/component/input/textField/StyledTextField.tsx","webpack://web/./src/component/input/textField/ValidatedTextInput.tsx","webpack://web/./src/component/lazyComponent/LazyComponent.tsx","webpack://web/./src/component/list/CustomList.tsx","webpack://web/./src/component/list/CustomListItem.tsx","webpack://web/./src/component/loadListCard/LoadListCardStyle.tsx","webpack://web/./src/component/loader/Loader.tsx","webpack://web/./src/component/loadingSpinner/LoadingSpinner.tsx","webpack://web/./src/component/locationsSpacer/LocationsSpacer.tsx","webpack://web/./src/component/main/AuthenticatedInitialLoading.tsx","webpack://web/./src/component/main/DesktopThinBlackFrame.tsx","webpack://web/./src/component/main/InitialLoading.tsx","webpack://web/./src/component/main/MainLayout.tsx","webpack://web/./src/component/main/MobileDrawer.tsx","webpack://web/./src/component/main/MobileTopBar.tsx","webpack://web/./src/component/main/TopMenuNotificationDot.tsx","webpack://web/./src/component/main/mainHooks.ts","webpack://web/./src/component/map/ALKMapsLayer.tsx","webpack://web/./src/component/map/BaseMap.tsx","webpack://web/./src/component/map/CustomMarkerClusterGroup.tsx","webpack://web/./src/component/map/ExpandIcon.tsx","webpack://web/./src/component/map/GestureHandlingMap.ts","webpack://web/./src/component/map/Legend.tsx","webpack://web/./src/component/map/MarkerWithData.tsx","webpack://web/./src/component/map/ShadowRadius.tsx","webpack://web/./src/component/map/ShrinkIcon.tsx","webpack://web/./src/component/map/SimpleTooltip.tsx","webpack://web/./src/component/map/WithLeaflet.ts","webpack://web/./src/component/map/alkmaps/alkmaps-reduced.js","webpack://web/./src/component/map/gestureHandlingPlugin/leaflet-gesture-handling.js","webpack://web/./src/component/menu/AlertsIconBadge.tsx","webpack://web/./src/component/menu/AppLogo.tsx","webpack://web/./src/component/menu/DesktopMenu.tsx","webpack://web/./src/component/menu/DropdownMenu.tsx","webpack://web/./src/component/menu/DropdownMenuSelect.tsx","webpack://web/./src/component/menu/LinkWithNotification.tsx","webpack://web/./src/component/menu/MenuFooter.tsx","webpack://web/./src/component/menu/MenuHeader.tsx","webpack://web/./src/component/menu/MenuNav.tsx","webpack://web/./src/component/menu/MenuPreferenceSelect.tsx","webpack://web/./src/component/menu/MenuUserProfile.tsx","webpack://web/./src/component/menu/MobileMenu.tsx","webpack://web/./src/component/menu/NavLink.tsx","webpack://web/./src/component/menu/NavigationMenuHelper.ts","webpack://web/./src/component/menu/SideMenuContent.tsx","webpack://web/./src/component/menu/UserAvatarContainer.tsx","webpack://web/./src/component/menu/menuList.tsx","webpack://web/./src/component/menu/menuStyles.tsx","webpack://web/./src/component/mobileStoreLink/MobileStoreLink.tsx","webpack://web/./src/component/mobileStoreLink/MobileStoreLinkStyle.ts","webpack://web/./src/component/multiSelect/MultiSelect.tsx","webpack://web/./src/component/overflowRenderer/ItemsWidthMeasurer.tsx","webpack://web/./src/component/overflowRenderer/OverflowRenderer.tsx","webpack://web/./src/component/overflowRenderer/WidthMeasurer.tsx","webpack://web/./src/component/panelSizeDetector/PanelSizeDetector.tsx","webpack://web/./src/component/panel/BackPanelContext.ts","webpack://web/./src/component/panel/PageWithPanels.tsx","webpack://web/./src/component/panel/Panel.tsx","webpack://web/./src/component/panel/PanelFooter.tsx","webpack://web/./src/component/panel/PanelHeader.tsx","webpack://web/./src/component/panel/PanelHooks.ts","webpack://web/./src/component/panel/PanelSize.ts","webpack://web/./src/component/panel/WindowScrollViewTrackingContext.tsx","webpack://web/./src/component/panel/panelLayout.ts","webpack://web/./src/component/panels/basePanel/loadDetails/Backhauls.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/Company.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/CompanyLoads.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/CreditRating.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/EmailPopup.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/LoadDetailsMoreInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/LoadDetailsMoreInfoContact.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/LoadDetailsValueRow.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/LoadDocuments.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/Mileage.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/Notes.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/TruckAlertMessage.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/costPerDay/CostPerDayUIHelper.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/DrivingTimeInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/LoadDetailsGeneralInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/LoadDetailsGeneralInfoHeader.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/LoadDetailsInfoBar.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/LoadDetailsOriginDestination.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/UnlockLink.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/marketRates/CargoChiefRateInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/marketRates/ExpediteAllRateInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/marketRates/GreenscreensRateInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/marketRates/RateCheckInfo.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/CargoChiefRate.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/CargoChiefRateComponent.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/GreenscreensRate.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/GreenscreensRateContent.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/MarketRates.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/RateCheckHeader.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/RateCheckPanel.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/RateCheckPostedRateDifference.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/RateUnavailablePopup.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/AdditionalCosts.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/Calculation.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/Cost.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/CostPerDayCard.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/Field.ts","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/FuelCost.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/LinehaulRevenue.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/ProfitCalculator.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/TextInputBox.tsx","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/TotalProfit.tsx","webpack://web/./src/component/panels/basePanel/panelFiltersSection/PanelFiltersList.tsx","webpack://web/./src/component/panels/basePanel/searchPanel/RadiusSelect.tsx","webpack://web/./src/component/panels/basePanel/searchPanel/findLoadsSimpleMap/MapInfo.ts","webpack://web/./src/component/panels/basePanel/searchPanel/findLoadsSimpleMap/Regions.ts","webpack://web/./src/component/panels/basePanel/searchPanel/findLoadsSimpleMap/StateSpecific.ts","webpack://web/./src/component/panels/basePostPanel/PostLoadExpediteAllRateHelper.ts","webpack://web/./src/component/panels/basePostPanel/userData.ts","webpack://web/./src/component/panels/communication/CommunicationDisabledByBrokerPanel.tsx","webpack://web/./src/component/panels/communication/CommunicationListPanel.tsx","webpack://web/./src/component/panels/communication/ConversationListFilters.tsx","webpack://web/./src/component/panels/communication/EmptyConversationsPanel.tsx","webpack://web/./src/component/panels/communication/NoUnreadMessagesPanel.tsx","webpack://web/./src/component/panels/communication/header/MenuOptions.tsx","webpack://web/./src/component/panels/communication/header/MessagingWidgetMenuOptions.tsx","webpack://web/./src/component/panels/companyDetails/Authority.tsx","webpack://web/./src/component/panels/companyDetails/CarrierHistoryStatesMap.tsx","webpack://web/./src/component/panels/companyDetails/CarrierMapData.ts","webpack://web/./src/component/panels/companyDetails/CarrierRatingExpansionPanel.tsx","webpack://web/./src/component/panels/companyDetails/CompanyDetailsRows.tsx","webpack://web/./src/component/panels/companyDetails/CreditRating.tsx","webpack://web/./src/component/panels/companyDetails/Insurance.tsx","webpack://web/./src/component/panels/companyDetails/MapLink.tsx","webpack://web/./src/component/panels/companyDetails/myCarrierPortal/RiskAssessmentExpansionPanel.tsx","webpack://web/./src/component/panels/findLoads/backhaulsPanel/BackhaulsPanel.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/BookNowBanner.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/CotaUrlHelper.ts","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/EditCompanyPopup.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/Header.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/InfoRibbon.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsActionsBar.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsData.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsExpansionPanels.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsExportSection.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsPanel.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsPanelStyle.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/LoadDetailsPopups.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/ManageDocuments.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/MapRoutes.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/BidButton.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/BookNowButton.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/ContactButtons.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/EmailButton.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/MessageButton.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/PhoneButton.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/SaveButton.tsx","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/VhubBookWithButton.tsx","webpack://web/./src/component/panels/findLoads/searchPanel/GeolocationPopups.tsx","webpack://web/./src/component/panels/findLoads/searchPanel/SearchPanelHelper.tsx","webpack://web/./src/component/panels/findLoads/searchPanel/TrailerTypeComponent.tsx","webpack://web/./src/component/panels/findLoads/searchResultPanel/SearchResultPanelStyle.tsx","webpack://web/./src/component/panels/findLoads/searchResultPanel/SetAlertButton.tsx","webpack://web/./src/component/panels/mileageCalculator/DirectionList.tsx","webpack://web/./src/component/panels/mileageCalculator/IftaFuelTax.tsx","webpack://web/./src/component/panels/mileageCalculator/MapRoutingTollSections.tsx","webpack://web/./src/component/panels/mileageCalculator/MileageCalculatorHelper.ts","webpack://web/./src/component/panels/mileageCalculator/MileageCalculatorStyleSheet.tsx","webpack://web/./src/component/panels/modalPanel/CurrentLocationButton.tsx","webpack://web/./src/component/panels/modalPanel/HomeLocationButton.tsx","webpack://web/./src/component/panels/modalPanel/LocationPicker.tsx","webpack://web/./src/component/panels/modalPanel/LocationPickerPanel.tsx","webpack://web/./src/component/panels/modalPanel/RegionPickerParts.tsx","webpack://web/./src/component/panels/modalPanel/StatesMaxSelectionWarning.tsx","webpack://web/./src/component/panels/modalPanel/StatesPicker.tsx","webpack://web/./src/component/panels/modalPanel/StatesProvincesRegionsMapButton.tsx","webpack://web/./src/component/panels/myTruck/MyTruck.tsx","webpack://web/./src/component/panels/myTruck/MyTruckTrailerType.tsx","webpack://web/./src/component/panels/myTruck/TruckForm.tsx","webpack://web/./src/component/panels/notFoundSearches/ErrorIcon.tsx","webpack://web/./src/component/panels/notFoundSearches/NotFoundPanel.tsx","webpack://web/./src/component/panels/notFoundSearches/NotFoundPanels.tsx","webpack://web/./src/component/panels/pickerPanels/Dates.tsx","webpack://web/./src/component/panels/pickerPanels/HomePick.tsx","webpack://web/./src/component/panels/pickerPanels/PickUpDropOffStyles.tsx","webpack://web/./src/component/panels/pickerPanels/RecentLocationsStyles.ts","webpack://web/./src/component/panels/pickerPanels/RecentSearchLocations.tsx","webpack://web/./src/component/panels/settings/FormSettingsStyles.tsx","webpack://web/./src/component/panels/settings/MPGPanel.tsx","webpack://web/./src/component/panels/settings/company/BusinessProfileHelper.ts","webpack://web/./src/component/panels/truckLocator/carrierDetails/CarrierDetailsData.tsx","webpack://web/./src/component/panels/truckLocator/carrierDetails/CarrierDetailsPanelStyles.tsx","webpack://web/./src/component/panels/truckPost/CreateNewTruckPost.tsx","webpack://web/./src/component/panels/truckPost/NoTruckPost.tsx","webpack://web/./src/component/panels/truckPost/PostTruckForm.tsx","webpack://web/./src/component/panels/truckPost/PostTruckFormSections.tsx","webpack://web/./src/component/panels/truckPost/PostTruckFormUI.tsx","webpack://web/./src/component/panels/truckPost/PostTruckUIPlanFeatures.tsx","webpack://web/./src/component/panels/truckPost/TruckPostLists.tsx","webpack://web/./src/component/paper/Paper.tsx","webpack://web/./src/component/pcmilerRoute/PCMilerRoute.tsx","webpack://web/./src/component/popup/ApiErrorPopup.tsx","webpack://web/./src/component/popup/BasePopup.tsx","webpack://web/./src/component/popup/BidFailedPopup.tsx","webpack://web/./src/component/popup/ConnectionErrorPopup.tsx","webpack://web/./src/component/popup/EnterDotPopup.tsx","webpack://web/./src/component/popup/MaintenancePopup.tsx","webpack://web/./src/component/popup/PlaceBidPopup.tsx","webpack://web/./src/component/popup/Popup.tsx","webpack://web/./src/component/popup/PopupButtons.tsx","webpack://web/./src/component/popup/PopupContentSections.tsx","webpack://web/./src/component/popup/PopupTrackingContext.tsx","webpack://web/./src/component/popup/SessionExpiredPopUp.tsx","webpack://web/./src/component/popup/UnlockFeaturePopup.tsx","webpack://web/./src/component/popup/myCarrierPortal/LinkBrokerAccountPopup.tsx","webpack://web/./src/component/popup/myCarrierPortal/MCPOnboardingPopup.tsx","webpack://web/./src/component/popup/myCarrierPortal/SetupIntegrationInfoPopup.tsx","webpack://web/./src/component/progress/LoadingProgress.tsx","webpack://web/./src/component/progress/OverlayLoadingProgress.tsx","webpack://web/./src/component/rateCheck/RateCheckFeedbackResponse.tsx","webpack://web/./src/component/rateCheck/RateCheckIsAccurate.tsx","webpack://web/./src/component/rateCheck/RateConfirmation.tsx","webpack://web/./src/component/rateCheck/RateConfirmationInput.tsx","webpack://web/./src/component/recaptcha/Recaptcha.tsx","webpack://web/./src/component/screenSharing/ScreenSharing.tsx","webpack://web/./src/component/screenSharing/ScreenSharingButton.tsx","webpack://web/./src/component/screenSharing/ScreenSharingHelper.tsx","webpack://web/./src/component/screenSharing/ScreenSharingPopup.tsx","webpack://web/./src/component/scrollView/AreaScrollView.tsx","webpack://web/./src/component/scrollView/DivScrollView.tsx","webpack://web/./src/component/scrollView/FixedArea.tsx","webpack://web/./src/component/scrollView/FixedAreaPortalDestination.tsx","webpack://web/./src/component/scrollView/FixedAreaRenderContext.tsx","webpack://web/./src/component/scrollView/InfiniteScrollView.tsx","webpack://web/./src/component/scrollView/KeyboardOpen.tsx","webpack://web/./src/component/scrollView/NonScrollView.tsx","webpack://web/./src/component/scrollView/PageScroll.tsx","webpack://web/./src/component/scrollView/SafeBottomInsetSpace.tsx","webpack://web/./src/component/scrollView/WindowScrollView.tsx","webpack://web/./src/component/scrollView/collapsibleLogic.ts","webpack://web/./src/component/scrollView/scrollUtil.ts","webpack://web/./src/component/scrollView/setupBodyFixed.ts","webpack://web/./src/component/section/Section.tsx","webpack://web/./src/component/section/SectionTitle.tsx","webpack://web/./src/component/select/Select.tsx","webpack://web/./src/component/select/SelectStyles.tsx","webpack://web/./src/component/simplemap/Regions.ts","webpack://web/./src/component/simplemap/SimpleMap.tsx","webpack://web/./src/component/simplemap/StateBboxArray.ts","webpack://web/./src/component/simplemap/StateLabels.ts","webpack://web/./src/component/simplemap/StatePaths.ts","webpack://web/./src/component/simplemap/StateSpecific.ts","webpack://web/./src/component/simplemap/raphael.js","webpack://web/./src/component/simplemap/simplemaps.js","webpack://web/./src/component/slider/CustomSlider.tsx","webpack://web/./src/component/slider/CustomSliderStyles.ts","webpack://web/./src/component/slider/WeightAndLengthSliders.tsx","webpack://web/./src/component/snack/Snackbar.tsx","webpack://web/./src/component/snack/SnackbarContent.tsx","webpack://web/./src/component/snack/SnackbarContentStyle.tsx","webpack://web/./src/component/statusBar/ManageLine.tsx","webpack://web/./src/component/statusBar/StatusBar.tsx","webpack://web/./src/component/statusBar/StatusBarContactOptions.tsx","webpack://web/./src/component/statusBar/StatusBarPopups.tsx","webpack://web/./src/component/statusBar/StatusBarStyle.tsx","webpack://web/./src/component/table/loadTable/LoadTableHelper.ts","webpack://web/./src/component/table/loadTable/LoadTableStyles.ts","webpack://web/./src/component/table/truckTable/TruckComponents.tsx","webpack://web/./src/component/table/truckTable/TruckElement.tsx","webpack://web/./src/component/table/truckTable/TruckTableStyles.tsx","webpack://web/./src/component/table/truckTable/Warning.tsx","webpack://web/./src/component/tabs/Tab.tsx","webpack://web/./src/component/tabs/Tabs.tsx","webpack://web/./src/component/textInput/NumberValidationInput.tsx","webpack://web/./src/component/textInput/TextInputStyle.tsx","webpack://web/./src/component/text/TappableTextContent.tsx","webpack://web/./src/component/text/Text.tsx","webpack://web/./src/component/topRibbon/TopRibbon.tsx","webpack://web/./src/component/truckAndLoadForm/TruckAndLoadFormStyles.tsx","webpack://web/./src/index.tsx","webpack://web/./src/model/CapacityFinder.ts","webpack://web/./src/model/Dispatcher.ts","webpack://web/./src/model/FormPickers.ts","webpack://web/./src/model/LoadAvailability.ts","webpack://web/./src/model/LoadDetailsTabs.ts","webpack://web/./src/model/LoadMetrics.ts","webpack://web/./src/model/LoadPostRequest.ts","webpack://web/./src/model/LocationTypes.ts","webpack://web/./src/model/MyPostedLoadsRequest.ts","webpack://web/./src/model/OnboardedCarriers.ts","webpack://web/./src/model/PosterLoadSearchRequest.ts","webpack://web/./src/model/PrivateNetwork.ts","webpack://web/./src/model/RecentPostedLoads.ts","webpack://web/./src/model/UserManagement.ts","webpack://web/./src/page/aspxPage/AspxEmbedIframe.tsx","webpack://web/./src/page/aspxPage/AspxMapper.ts","webpack://web/./src/page/aspxPage/AspxPage.tsx","webpack://web/./src/page/aspxPage/AspxRouteMap.ts","webpack://web/./src/page/aspxPage/AspxRouteTypes.ts","webpack://web/./src/page/aspxPage/AspxSelfEmbedProtection.ts","webpack://web/./src/page/aspxPage/AspxSwitcher.tsx","webpack://web/./src/page/bids/BidCards.tsx","webpack://web/./src/page/bids/BidFormRateCheck.tsx","webpack://web/./src/page/bids/BidFormsPanel.tsx","webpack://web/./src/page/bids/BidNavigationHelper.tsx","webpack://web/./src/page/bids/BidStatusHelper.ts","webpack://web/./src/page/bids/BidsList.tsx","webpack://web/./src/page/bids/BidsLoadDetails.tsx","webpack://web/./src/page/bids/BidsPCMilerMap.tsx","webpack://web/./src/page/bids/BidsPanel.tsx","webpack://web/./src/page/bids/BidsPanelHeader.tsx","webpack://web/./src/page/bids/BidsPanelRouting.tsx","webpack://web/./src/page/bids/BidsTabsPanel.tsx","webpack://web/./src/page/bids/VendorBidsList.tsx","webpack://web/./src/page/bids/filters/BidsFilterPanel.tsx","webpack://web/./src/page/bids/style/BidsStyleHelper.ts","webpack://web/./src/page/bids/summary/BidHistoryList.tsx","webpack://web/./src/page/bids/summary/BidInfoRibbonSummary.tsx","webpack://web/./src/page/bids/summary/BidListItem.tsx","webpack://web/./src/page/bids/summary/BidSummaryHelpers.tsx","webpack://web/./src/page/bids/summary/BidSummaryPanel.tsx","webpack://web/./src/page/bids/summary/BiddingSummary.tsx","webpack://web/./src/page/bids/summary/ExpirationTimeBanner.tsx","webpack://web/./src/page/bids/summary/OfferActions.tsx","webpack://web/./src/page/communication/AttachmentsBottomMenu.tsx","webpack://web/./src/page/communication/CommunicationBrokerLoadDetails.tsx","webpack://web/./src/page/communication/CommunicationChat.tsx","webpack://web/./src/page/communication/CommunicationChatHeader.tsx","webpack://web/./src/page/communication/CommunicationLoadDetails.tsx","webpack://web/./src/page/communication/CommunicationPCMilerMap.tsx","webpack://web/./src/page/communication/CommunicationRoute.tsx","webpack://web/./src/page/communication/ContactInfoDetails.ts","webpack://web/./src/page/communication/ContactInfoSections.tsx","webpack://web/./src/page/communication/Conversation.tsx","webpack://web/./src/page/communication/ConversationContactInfoPanel.tsx","webpack://web/./src/page/communication/ConversationHelper.tsx","webpack://web/./src/page/communication/ConversationList.tsx","webpack://web/./src/page/communication/ConversationListFilter.tsx","webpack://web/./src/page/communication/Conversations.tsx","webpack://web/./src/page/communication/GlobalConversations.tsx","webpack://web/./src/page/communication/LoadContactInfoPanel.tsx","webpack://web/./src/page/communication/LoadConversations.tsx","webpack://web/./src/page/communication/NotificationWarningBanner.tsx","webpack://web/./src/page/communication/RegisterBrowserToFirebaseNotification.tsx","webpack://web/./src/page/communication/chat/ChatHeaderNameStatus.tsx","webpack://web/./src/page/dashboard/FeedHooks.ts","webpack://web/./src/page/dashboard/Promotion.tsx","webpack://web/./src/page/dashboard/widgets/CarrierRatingUIHelper.tsx","webpack://web/./src/page/error/GenericError.tsx","webpack://web/./src/page/findLoads/LoadSearchRequestEncoder.ts","webpack://web/./src/page/findLoads/RouteParams.ts","webpack://web/./src/page/loadAvailability/LoadAvailabilityEncoder.ts","webpack://web/./src/page/loadAvailability/Utility.ts","webpack://web/./src/page/marketRates/marketRates/SearchFormHelper.ts","webpack://web/./src/page/marketRates/marketRates/widgets/MinMaxBox.tsx","webpack://web/./src/page/myDocuments/ActionsMenu.tsx","webpack://web/./src/page/myDocuments/DeletePopups.tsx","webpack://web/./src/page/myDocuments/LoadingFullscreenPanel.tsx","webpack://web/./src/page/myDocuments/MyDocumentsEncoder.ts","webpack://web/./src/page/myDocuments/PDFViewer.tsx","webpack://web/./src/page/myDocuments/PreviewNotAvailable.tsx","webpack://web/./src/page/myDocuments/ViewDocument.tsx","webpack://web/./src/page/newSettings/panelSectionFilter/SettingsHelper.ts","webpack://web/./src/page/partnerServices/RegisterForm.tsx","webpack://web/./src/page/postLoads/RouteParams.ts","webpack://web/./src/page/profitCalculator/ProfitCalculatorHelper.ts","webpack://web/./src/page/rateCheck/MinMaxBox.tsx","webpack://web/./src/page/rateCheck/RateCheckHelper.ts","webpack://web/./src/page/rateCheck/RateCheckHistory.tsx","webpack://web/./src/page/settings/PrivateNetworkHelper.ts","webpack://web/./src/page/truckLocator/locateTruck/CompaniesAvatarLogo.tsx","webpack://web/./src/page/truckLocator/locateTruck/CompaniesProfileAvatarLogo.tsx","webpack://web/./src/page/truckLocator/locateTruck/LocateTruckEncoder.ts","webpack://web/./src/page/truckLocator/locateTruck/TruckDestinations.tsx","webpack://web/./src/page/unsubscribeAssistant/UnsubscribeStylesHelper.ts","webpack://web/./src/reduxStore/History.ts","webpack://web/./src/reduxStore/RootEpic.ts","webpack://web/./src/reduxStore/Store.ts","webpack://web/./src/reduxStore/epic/ApplicationSettingsReducer.ts","webpack://web/./src/reduxStore/epic/CapacityFinderEpic.ts","webpack://web/./src/reduxStore/epic/CarrierEpic.ts","webpack://web/./src/reduxStore/epic/ConnectionErrorEpic.ts","webpack://web/./src/reduxStore/epic/FeedEpic.ts","webpack://web/./src/reduxStore/epic/InboxMessageContentEpic.ts","webpack://web/./src/reduxStore/epic/LoadMetricsEpic.ts","webpack://web/./src/reduxStore/epic/LoadVisibilityRulesEpic.ts","webpack://web/./src/reduxStore/epic/LoadVisibilityRulesHelper.ts","webpack://web/./src/reduxStore/epic/LocationEpic.ts","webpack://web/./src/reduxStore/epic/LocationPickerEpic.ts","webpack://web/./src/reduxStore/epic/MileageCalculatorEpic.ts","webpack://web/./src/reduxStore/epic/OnboardedCarriersEpic.ts","webpack://web/./src/reduxStore/epic/PCMilerEpic.ts","webpack://web/./src/reduxStore/epic/PanelEpic.ts","webpack://web/./src/reduxStore/epic/PostLoadEpic.ts","webpack://web/./src/reduxStore/epic/PostingContactsEpic.ts","webpack://web/./src/reduxStore/epic/PrivateNetworkEpic.ts","webpack://web/./src/reduxStore/epic/ReducerSyncEpic.ts","webpack://web/./src/reduxStore/epic/SearchDirectoryEpic.ts","webpack://web/./src/reduxStore/epic/TruckEpic.ts","webpack://web/./src/reduxStore/epic/URLScrapeEpic.ts","webpack://web/./src/reduxStore/epic/UnsubscribeEpic.ts","webpack://web/./src/reduxStore/epic/UserActivityEpic.ts","webpack://web/./src/reduxStore/epic/UserSettingsEpic.ts","webpack://web/./src/reduxStore/epic/VerifyEmailEpic.ts","webpack://web/./src/reduxStore/epic/WelcomebackCampaignEpic.ts","webpack://web/./src/reduxStore/epic/postLoad/PostLoadFormEpic.ts","webpack://web/./src/reduxStore/epic/postLoad/PostLoadFormStateHelper.ts","webpack://web/./src/reduxStore/reducer/FormValidationReducer.ts","webpack://web/./src/reduxStore/reducer/LoadDetailsTabsReducer.ts","webpack://web/./src/reduxStore/reducer/LoadSearchFormReducer.ts","webpack://web/./src/reduxStore/reducer/PostTruckAvailabilityReducer.ts","webpack://web/./src/reduxStore/reducer/PostedLoadsPanelActionsReducer.ts","webpack://web/./src/reduxStore/reducer/SnackbarReducer.ts","webpack://web/./src/reduxStore/reducer/TruckReducer.ts","webpack://web/./src/reduxStore/reducer/UnderDevelopmentReducer.ts","webpack://web/./src/registerServiceWorker.ts","webpack://web/./src/router/AuthenticatedRoute.tsx","webpack://web/./src/router/Logout.tsx","webpack://web/./src/router/RouteGroup.tsx","webpack://web/./src/router/RouteHelper.tsx","webpack://web/./src/router/Routes.ts","webpack://web/./src/router/Routing.tsx","webpack://web/./src/style/Color.ts","webpack://web/./src/style/StyleConstants.ts","webpack://web/./src/style/Theme.ts","webpack://web/./src/style/TypographyStyle.ts","webpack://web/./src/style/WithTheme.ts","webpack://web/./src/translate/EquipmentTranslation.ts","webpack://web/./src/translate/TranslationKeys.ts","webpack://web/./src/translate/english.ts","webpack://web/./src/translate/french.ts","webpack://web/./src/translate/spanish.ts","webpack://web/./src/translate/translation.ts","webpack://web/./src/util/AppConfig.ts","webpack://web/./src/util/AppVersionHelper.mjs","webpack://web/./src/util/BugsnagHelper.ts","webpack://web/./src/util/Constants.ts","webpack://web/./src/util/FileHelper.ts","webpack://web/./src/util/Formatter.ts","webpack://web/./src/util/GenId.ts","webpack://web/./src/util/GeolocationHelper.ts","webpack://web/./src/util/Link.ts","webpack://web/./src/util/LoadAgeProvider.tsx","webpack://web/./src/util/LocalDataStorage.ts","webpack://web/./src/util/MainSpinnerHelper.ts","webpack://web/./src/util/MediaQueries.ts","webpack://web/./src/util/Metadata.tsx","webpack://web/./src/util/OldMemberSiteLink.ts","webpack://web/./src/util/PageHelper.ts","webpack://web/./src/util/SyncTimer.ts","webpack://web/./src/util/TruckDataHelper.ts","webpack://web/./src/util/UrlParamsHelper.ts","webpack://web/./src/util/WithResizeDetectorAndRef.tsx","webpack://web/./src/util/firebaseNotification/FirebasePushNotification.ts","webpack://web/./src/util/helper/ContactOptionsHelper.ts","webpack://web/./src/util/helper/CostPerDayHelper.ts","webpack://web/./src/util/helper/EquipmentHelper.ts","webpack://web/./src/util/helper/KeyboardHelper.ts","webpack://web/./src/util/helper/PathHelper.ts","webpack://web/./src/util/helper/PostLoadHelper.ts","webpack://web/./src/util/helper/SimpleMapsHelper.ts","webpack://web/./src/util/helper/UserActivityManager.ts","webpack://web/./src/util/hooks/EventHook.ts","webpack://web/./src/util/hooks/FloatingScrollbarsHook.ts","webpack://web/./src/util/hooks/MediaQueryHook.ts","webpack://web/./src/util/hooks/MobileViewHook.ts","webpack://web/./src/util/hooks/OpenedTabsControl.ts","webpack://web/./src/util/hooks/UniqueIdHook.ts","webpack://web/./src/util/hooks/UseContentHeightMeasurer.tsx","webpack://web/./src/util/hooks/UseContentScrollControl.ts","webpack://web/./src/util/hooks/UseCsv.ts","webpack://web/./src/util/hooks/UseDebounce.ts","webpack://web/./src/util/hooks/UseLoadMoreIfNecessary.tsx","webpack://web/./src/util/hooks/UseRedux.ts","webpack://web/./src/util/hooks/UseVisibility.ts","webpack://web/./src/util/hooks/WindowResizeHook.ts","webpack://web/./src/util/iconsConstants.ts","webpack://web/./src/util/linkify/Linkify.tsx","webpack://web/./src/util/parsers/DirectorySearchRequestParsers.ts","webpack://web/./src/util/parsers/LoadSearchRequestParsers.ts","webpack://web/./src/util/parsers/MapDataParsers.ts","webpack://web/./src/util/trackers/123lbTracker.ts","webpack://web/./src/util/trackers/AppInsights.js","webpack://web/./src/util/trackers/GoogleAnalyticsTracker.ts","webpack://web/./src/webApi/AnonymousMemberApiService.ts","webpack://web/./src/webApi/ApiServiceHelper.ts","webpack://web/./src/webApi/CapacityFinderClient.ts","webpack://web/./src/webApi/CookiesHelper.ts","webpack://web/./src/webApi/LoadMetricsClient.ts","webpack://web/./src/webApi/LoadTemplatesClient.ts","webpack://web/./src/webApi/MemberApiService.ts","webpack://web/./src/webApi/MembersClient.ts","webpack://web/./src/webApi/MembersEpic.ts","webpack://web/./src/webApi/PrivateNetworkClient.ts","webpack://web/./src/webApi/RawApiService.ts","webpack://web/./src/webApi/ResponseHandler.ts","webpack://web/./src/webApi/TokenRefresher.ts","webpack://web/./src/component/banner/error-block.svg","webpack://web/./src/component/banner/icon_success.svg","webpack://web/./src/component/banner/icon_warning.svg","webpack://web/./src/component/banner/info.svg","webpack://web/./src/component/banner/onboarding.svg","webpack://web/./src/component/buttons/more-menu.svg","webpack://web/./src/component/feed/icon-feed-dark.svg","webpack://web/./src/component/feed/icon-feed-selected.svg","webpack://web/./src/component/feed/icon-feed.svg","webpack://web/./src/component/feed/icon-help-dark.svg","webpack://web/./src/component/feed/icon-help-selected.svg","webpack://web/./src/component/feed/icon-help.svg","webpack://web/./src/component/feed/icon-youtube.svg","webpack://web/./src/component/globalBanner/warning-icon.svg","webpack://web/./src/component/menu/icon/border-wait-times.svg","webpack://web/./src/component/menu/icon/credit-report.svg","webpack://web/./src/component/menu/icon/dashboard.svg","webpack://web/./src/component/menu/icon/export-posts.svg","webpack://web/./src/component/menu/icon/fmcsa-search.svg","webpack://web/./src/component/menu/icon/fuel-prices.svg","webpack://web/./src/component/menu/icon/get-paid-faster.svg","webpack://web/./src/component/menu/icon/help-icon.svg","webpack://web/./src/component/menu/icon/hot-leads.svg","webpack://web/./src/component/menu/icon/html-embed-code.svg","webpack://web/./src/component/menu/icon/icon-bid.svg","webpack://web/./src/component/menu/icon/icon-bullhorn.svg","webpack://web/./src/component/menu/icon/icon-menu.svg","webpack://web/./src/component/menu/icon/icon-message.svg","webpack://web/./src/component/menu/icon/load-planner.svg","webpack://web/./src/component/menu/icon/loadAvailability.svg","webpack://web/./src/component/menu/icon/logout-icon.svg","webpack://web/./src/component/menu/icon/mileage-calculator.svg","webpack://web/./src/component/menu/icon/my-carriers.svg","webpack://web/./src/component/menu/icon/my-companies.svg","webpack://web/./src/component/menu/icon/my-documents.svg","webpack://web/./src/component/menu/icon/my-loads.svg","webpack://web/./src/component/menu/icon/my-truck-post.svg","webpack://web/./src/component/menu/icon/post.svg","webpack://web/./src/component/menu/icon/posting-aid.svg","webpack://web/./src/component/menu/icon/profit-calculator.svg","webpack://web/./src/component/menu/icon/rate-check.svg","webpack://web/./src/component/menu/icon/reefer-rates.svg","webpack://web/./src/component/menu/icon/register.svg","webpack://web/./src/component/menu/icon/roadside-assistance.svg","webpack://web/./src/component/menu/icon/save-at-the-pump.svg","webpack://web/./src/component/menu/icon/search-directory.svg","webpack://web/./src/component/menu/icon/search-trucks.svg","webpack://web/./src/component/menu/icon/search.svg","webpack://web/./src/component/menu/icon/settings.svg","webpack://web/./src/component/menu/icon/sign-in.svg","webpack://web/./src/component/menu/icon/tms-integration.svg","webpack://web/./src/component/menu/icon/trucking-authority.svg","webpack://web/./src/component/menu/icon/upload-posts.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/update-status.svg","webpack://web/./src/component/statusBar/selected.svg","webpack://web/./src/component/statusBar/unselected.svg","webpack://web/./src/icons/icon-arrow-right.svg","webpack://web/./src/icons/icon_dollar.svg","webpack://web/./src/icons/icon_up_arrow.svg","webpack://web/./src/page/communication/download.svg","webpack://web/./src/page/myDocuments/add-file.svg","webpack://web/./src/page/myDocuments/change-folder.svg","webpack://web/./src/page/myDocuments/change-type.svg","webpack://web/./src/page/myDocuments/delete.svg","webpack://web/./src/page/myDocuments/download.svg","webpack://web/./src/page/myDocuments/edit.svg","webpack://web/./src/page/myDocuments/error.svg","webpack://web/./src/page/myDocuments/folder.svg","webpack://web/./src/page/myDocuments/rename.svg","webpack://web/./src/page/myDocuments/select.svg","webpack://web/./src/page/myDocuments/send.svg","webpack://web/./src/page/myDocuments/view.svg","webpack://web/./src/component/badge/icon-rating-small.svg","webpack://web/./src/component/badge/icon-rating.svg","webpack://web/./src/component/buttons/arrow-up.svg","webpack://web/./src/component/buttons/filter.svg","webpack://web/./src/component/chip/cancel.svg","webpack://web/./src/component/conversation/composer/icon-add-file.svg","webpack://web/./src/component/conversation/composer/icon-attach-plus-o.svg","webpack://web/./src/component/conversation/composer/icon-attach-plus.svg","webpack://web/./src/component/conversation/composer/icon-folder.svg","webpack://web/./src/component/expansionPanel/icon-arrow-down.svg","webpack://web/./src/component/expansionPanel/icon-arrow-up.svg","webpack://web/./src/component/feed/not-found.svg","webpack://web/./src/component/map/marker.svg","webpack://web/./src/component/map/markerGreen.svg","webpack://web/./src/component/menu/icon/app-store.svg","webpack://web/./src/component/menu/icon/bid-icon-conversation.svg","webpack://web/./src/component/menu/icon/bid-icon-pale.svg","webpack://web/./src/component/menu/icon/checkmark-badge-green.svg","webpack://web/./src/component/menu/icon/facebook.svg","webpack://web/./src/component/menu/icon/google-play.svg","webpack://web/./src/component/menu/icon/icon-add-avatar-24px.svg","webpack://web/./src/component/menu/icon/icon-add-avatar.svg","webpack://web/./src/component/menu/icon/icon-sound-off.svg","webpack://web/./src/component/menu/icon/icon-sound-on.svg","webpack://web/./src/component/menu/icon/icon-unverified.svg","webpack://web/./src/component/menu/icon/instagram.svg","webpack://web/./src/component/menu/icon/linkedin.svg","webpack://web/./src/component/menu/icon/logo.svg","webpack://web/./src/component/menu/icon/twitter.svg","webpack://web/./src/component/menu/icon/youtube.svg","webpack://web/./src/component/mobileStoreLink/images/appstore.svg","webpack://web/./src/component/mobileStoreLink/images/googleplay.svg","webpack://web/./src/component/panel/close.svg","webpack://web/./src/component/panel/icons_back.svg","webpack://web/./src/component/panel/refresh.svg","webpack://web/./src/component/panels/basePanel/loadDetails/backhauls.svg","webpack://web/./src/component/panels/basePanel/loadDetails/close.svg","webpack://web/./src/component/panels/basePanel/loadDetails/company-loads.svg","webpack://web/./src/component/panels/basePanel/loadDetails/company.svg","webpack://web/./src/component/panels/basePanel/loadDetails/credit rating.svg","webpack://web/./src/component/panels/basePanel/loadDetails/credit report.svg","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/icon-favorite-off.svg","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/icon-favorite-on.svg","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/icon-onboarded-off.svg","webpack://web/./src/component/panels/basePanel/loadDetails/generalInfo/icon-onboarded-on.svg","webpack://web/./src/component/panels/basePanel/loadDetails/google map.svg","webpack://web/./src/component/panels/basePanel/loadDetails/icon-alerts.svg","webpack://web/./src/component/panels/basePanel/loadDetails/load-documents.svg","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/cargo-data.svg","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/greenscreens-data.svg","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/rate-check.svg","webpack://web/./src/component/panels/basePanel/loadDetails/marketRates/rc-logo.svg","webpack://web/./src/component/panels/basePanel/loadDetails/mileage.svg","webpack://web/./src/component/panels/basePanel/loadDetails/new window.svg","webpack://web/./src/component/panels/basePanel/loadDetails/onboarded.svg","webpack://web/./src/component/panels/basePanel/loadDetails/pc miler.svg","webpack://web/./src/component/panels/basePanel/loadDetails/post-truck.svg","webpack://web/./src/component/panels/basePanel/loadDetails/profitCalculator/profit calculator.svg","webpack://web/./src/component/panels/basePanel/loadDetails/thunder logo icon.svg","webpack://web/./src/component/panels/basePanel/panelFiltersSection/arrow-right.svg","webpack://web/./src/component/panels/companyDetails/icon-authority.svg","webpack://web/./src/component/panels/companyDetails/icon-insurance.svg","webpack://web/./src/component/panels/companyDetails/icon-rating.svg","webpack://web/./src/component/panels/companyDetails/myCarrierPortal/logo-mcp.svg","webpack://web/./src/component/panels/companyDetails/myCarrierPortal/risk-fail.svg","webpack://web/./src/component/panels/companyDetails/myCarrierPortal/risk-low.svg","webpack://web/./src/component/panels/companyDetails/myCarrierPortal/risk-medium.svg","webpack://web/./src/component/panels/companyDetails/myCarrierPortal/risk-review.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-bid-sent.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-bid.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-book-now.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-book.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-booked.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-called.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-email-load-off.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-email-load-on.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/buttons/icon-vHub.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/cota.svg","webpack://web/./src/component/panels/findLoads/loadDetailsPanel/icon_message.svg","webpack://web/./src/component/panels/findLoads/searchResultPanel/alert-bell-off.svg","webpack://web/./src/component/panels/findLoads/searchResultPanel/alert-bell-on.svg","webpack://web/./src/component/panels/mileageCalculator/icon-download.svg","webpack://web/./src/component/panels/myTruck/my_truck.svg","webpack://web/./src/component/panels/notFoundSearches/loadBlocked.svg","webpack://web/./src/component/panels/notFoundSearches/new-search.svg","webpack://web/./src/component/panels/notFoundSearches/noLoadsFound.svg","webpack://web/./src/component/panels/settings/company/dotVerification/icon-external-link.svg","webpack://web/./src/component/panels/truckPost/no_truck_post.svg","webpack://web/./src/component/panels/truckPost/no_truck_post_expired.svg","webpack://web/./src/component/panels/truckPost/no_truck_post_scheduled.svg","webpack://web/./src/component/panels/truckPost/pc_miler.svg","webpack://web/./src/component/popup/maintenance-truck.svg","webpack://web/./src/component/rateCheck/fields-clear.svg","webpack://web/./src/component/screenSharing/close-white.svg","webpack://web/./src/component/statusBar/icon-status.svg","webpack://web/./src/component/table/truckTable/warning.svg","webpack://web/./src/icons/123connect_icon.svg","webpack://web/./src/icons/arrow-right-gray.svg","webpack://web/./src/icons/arrow-right-green.svg","webpack://web/./src/icons/arrow-right-red.svg","webpack://web/./src/icons/arrow-right-silver.svg","webpack://web/./src/icons/arrow-right.svg","webpack://web/./src/icons/ascending.svg","webpack://web/./src/icons/backhaul.svg","webpack://web/./src/icons/btn-send-on.svg","webpack://web/./src/icons/btn-send.svg","webpack://web/./src/icons/calendar.svg","webpack://web/./src/icons/call-disabled.svg","webpack://web/./src/icons/call.svg","webpack://web/./src/icons/check.svg","webpack://web/./src/icons/clear-small.svg","webpack://web/./src/icons/close.svg","webpack://web/./src/icons/closeLight.svg","webpack://web/./src/icons/collapse.svg","webpack://web/./src/icons/delete-orange.svg","webpack://web/./src/icons/delete.svg","webpack://web/./src/icons/descending.svg","webpack://web/./src/icons/dollar.svg","webpack://web/./src/icons/edit.svg","webpack://web/./src/icons/empty-folder.svg","webpack://web/./src/icons/error-block.svg","webpack://web/./src/icons/expand.svg","webpack://web/./src/icons/favorite.svg","webpack://web/./src/icons/fields - arrow right.svg","webpack://web/./src/icons/home.svg","webpack://web/./src/icons/icon-arrow-right-orange.svg","webpack://web/./src/icons/icon-bullet-check.svg","webpack://web/./src/icons/icon-hide.svg","webpack://web/./src/icons/icon-loads.svg","webpack://web/./src/icons/icon-message-off.svg","webpack://web/./src/icons/icon-onboarded-off.svg","webpack://web/./src/icons/icon-onboarded-on.svg","webpack://web/./src/icons/icon-send.svg","webpack://web/./src/icons/icon-trip.svg","webpack://web/./src/icons/icon-view.svg","webpack://web/./src/icons/icon-zoom.svg","webpack://web/./src/icons/icon_error_block.svg","webpack://web/./src/icons/icon_info.svg","webpack://web/./src/icons/icon_success.svg","webpack://web/./src/icons/icon_warning.svg","webpack://web/./src/icons/icons - back.svg","webpack://web/./src/icons/info_small.svg","webpack://web/./src/icons/info_small_gray.svg","webpack://web/./src/icons/info_small_white.svg","webpack://web/./src/icons/location.svg","webpack://web/./src/icons/logo-gray.svg","webpack://web/./src/icons/logo-orange.svg","webpack://web/./src/icons/map-error.svg","webpack://web/./src/icons/map-look-up.svg","webpack://web/./src/icons/marker.svg","webpack://web/./src/icons/message-blue.svg","webpack://web/./src/icons/message_locked_icon.svg","webpack://web/./src/icons/new-loads-arrow-down.svg","webpack://web/./src/icons/new-loads-arrow.svg","webpack://web/./src/icons/no_conversations.svg","webpack://web/./src/icons/point A.svg","webpack://web/./src/icons/point B.svg","webpack://web/./src/icons/print-disabled.svg","webpack://web/./src/icons/print.svg","webpack://web/./src/icons/road-sign-two-way-disabled.svg","webpack://web/./src/icons/road-sign-two-way.svg","webpack://web/./src/icons/save search.svg","webpack://web/./src/icons/save-disabled.svg","webpack://web/./src/icons/save.svg","webpack://web/./src/icons/saved.svg","webpack://web/./src/icons/search-trucks.svg","webpack://web/./src/icons/share-disabled.svg","webpack://web/./src/icons/share.svg","webpack://web/./src/icons/states.svg","webpack://web/./src/icons/trip-load-tab-added.svg","webpack://web/./src/icons/trip-load-tab-available.svg","webpack://web/./src/icons/trip-load-tab-deadhead.svg","webpack://web/./src/icons/warning.svg","webpack://web/./src/icons/warning_menu.svg","webpack://web/./src/page/bids/clipart-bids.svg","webpack://web/./src/page/communication/close.svg","webpack://web/./src/page/communication/icon-mileage.svg","webpack://web/./src/page/communication/icon-tia-logo.svg","webpack://web/./src/page/dashboard/widgets/logo-carriersource.svg","webpack://web/./src/page/dashboard/widgets/star.svg","webpack://web/./src/page/error/boxAlert.svg","webpack://web/./src/page/error/notFound.svg","webpack://web/./src/page/rateCheck/down-arrow.svg","webpack://web/./src/page/rateCheck/up-arrow.svg"],"sourcesContent":["import React, { useEffect } from 'react';\r\n\r\nimport { ConnectedRouter } from 'connected-react-router';\r\nimport { Helmet } from 'react-helmet';\r\nimport { Provider, ReactReduxContext } from 'react-redux';\r\nimport { PersistGate } from 'redux-persist/integration/react';\r\nimport 'simplebar/dist/simplebar.min.css';\r\n\r\nimport { MuiThemeProvider } from '@material-ui/core';\r\nimport { withAITracking } from '@microsoft/applicationinsights-react-js';\r\n\r\nimport { history } from '@/reduxStore/History';\r\nimport { persistor, store } from '@/reduxStore/Store';\r\nimport { Routing } from '@/router/Routing';\r\nimport { ReduxRegistryConnect } from '@common/redux/ReduxRegistry';\r\nimport { FeedController } from '@component/feed/FeedController';\r\nimport { FeedPopup, FeedPopupMob } from '@component/feed/FeedPopup';\r\nimport { InitialLoading } from '@component/main/InitialLoading';\r\nimport { MainLayout } from '@component/main/MainLayout';\r\nimport { TopMenuNotificationDot } from '@component/main/TopMenuNotificationDot';\r\nimport { DesktopMenu } from '@component/menu/DesktopMenu';\r\nimport { MobileMenu } from '@component/menu/MobileMenu';\r\nimport { ConnectionErrorPopup } from '@component/popup/ConnectionErrorPopup';\r\nimport { MaintenancePopup } from '@component/popup/MaintenancePopup';\r\nimport { Popup } from '@component/popup/Popup';\r\nimport { PopupProvider } from '@component/popup/PopupTrackingContext';\r\nimport { SessionExpiredPopUp } from '@component/popup/SessionExpiredPopUp';\r\nimport { ScreenSharing } from '@component/screenSharing/ScreenSharing';\r\nimport { FixedHeader } from '@component/scrollView';\r\nimport Snackbar from '@component/snack/Snackbar';\r\nimport { TopRibbon } from '@component/topRibbon';\r\nimport '@page/aspxPage/AspxSelfEmbedProtection';\r\nimport THEME from '@style/Theme';\r\nimport { t, T } from '@translate';\r\nimport { AppConfig } from '@util/AppConfig';\r\nimport { hideMainSpinner } from '@util/MainSpinnerHelper';\r\nimport {\r\n DESCRIPTION_META,\r\n OG_DESCRIPTION_META,\r\n OG_TITLE_META,\r\n TITLE_META,\r\n TWITTER_DESCRIPTION_META,\r\n TWITTER_TITLE_META,\r\n} from '@util/Metadata';\r\n\r\nimport { appDependencies, DependencyProvider } from './AppDependencies';\r\nimport { isMessagingWidgetView } from './MessagingWidgetApp';\r\nimport { reactPlugin } from './util/trackers/AppInsights';\r\n\r\nconst isMessagingWidget = isMessagingWidgetView();\r\n\r\nconst App: React.FC = () => {\r\n useEffect(() => {\r\n hideMainSpinner();\r\n }, []);\r\n\r\n return (\r\n <>\r\n \r\n {AppConfig.NAME}\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n }\r\n topRightComponent={}\r\n mobileMenuChildren={}\r\n desktopMenuChildren={}\r\n >\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n >\r\n );\r\n};\r\n\r\nconst MobileMenuChildren: React.FC = () => (\r\n <>\r\n \r\n \r\n >\r\n);\r\n\r\nconst DesktopMenuChildren: React.FC = () => (\r\n <>\r\n \r\n \r\n >\r\n);\r\n\r\nexport default withAITracking(reactPlugin, App);\r\n","import { memberApi } from '@/reduxStore/RootEpic';\r\nimport { Api } from '@common/api';\r\nimport { ClientType, CommunicationService } from '@common/socket/Communication';\r\nimport { createDependencyManager } from '@common/util/DependencyManager';\r\n\r\ninterface Dependencies {\r\n authenticatedAPI: Api;\r\n communicationService: CommunicationService;\r\n}\r\n\r\nexport const appDependencies: Dependencies = {\r\n authenticatedAPI: memberApi,\r\n communicationService: new CommunicationService(memberApi, ClientType.Web, false),\r\n};\r\n\r\nconst dependencyManager = createDependencyManager();\r\nexport const DependencyProvider = dependencyManager.provider;\r\n\r\nexport const useCommunicationService = () => {\r\n return dependencyManager.hook().communicationService;\r\n};\r\n","//------------------------------------------------------------------------\r\n// This file defines the current Application (members) version number\r\n//\r\n//------------------------------------------------------------------------\r\n// NOTES:\r\n// Given that the file will be modified often, we refrained from\r\n// using the number stored in package.json to reduce merge conflicts\r\n// and allow easier git logs analysis.\r\n//\r\n// This file is parsed by the VSTS build process to extract the information.\r\n// Do not add logic or other lines here.\r\n//------------------------------------------------------------------------\r\n// format : 'major.minor.patch'\r\n//\r\nexport default '3.111.0';\r\n","import React, { useCallback, useEffect, useRef } from 'react';\r\n\r\nimport { find, forEach } from 'lodash';\r\nimport { useDispatch } from 'react-redux';\r\nimport { useHistory } from 'react-router-dom';\r\n\r\nimport { voidFunction } from '@common/helper';\r\nimport { BiddingRole, UpdateBidEventType } from '@common/model';\r\nimport { getBiddingSummary, receivedBidUpdateEvent } from '@common/redux/epic/bids/BidsEpic';\r\nimport {\r\n getCommunicationStatus,\r\n getConversationsByID,\r\n getConversationsSummary,\r\n getMessagesSummary,\r\n onNewMessage,\r\n resetCommunicationsState,\r\n} from '@common/redux/epic/CommunicationEpic';\r\nimport { fetchAlertSettings } from '@common/redux/epic/SettingsEpic';\r\nimport { newTruckAlert } from '@common/redux/epic/TruckAlertsEpic';\r\nimport {\r\n CommunicationStatsUpdate,\r\n ConnectedTopics,\r\n EmptyConnectedTopics,\r\n TopicCategory,\r\n} from '@common/socket/Communication';\r\nimport { mapSettingsUpdateToActions, SettingsUpdate, SettingUpdate } from '@common/socket/SignalRSettings';\r\nimport { useIsCarrier } from '@component/menu/NavigationMenuHelper';\r\nimport { useIsBiddingEnabled } from '@page/bids/BidStatusHelper';\r\nimport { useSelector } from '@util/hooks/UseRedux';\r\nimport { useAppVisibilityChange } from '@util/hooks/UseVisibility';\r\nimport { hasLoginCookies } from '@webApi/CookiesHelper';\r\n\r\nimport { useCommunicationService } from './AppDependencies';\r\n\r\nexport const CommunicationHandler: React.FC = () => {\r\n const dispatch = useDispatch();\r\n const history = useHistory();\r\n const isUserLoggedIn = hasLoginCookies();\r\n const isBiddingEnabled = useIsBiddingEnabled();\r\n const isCarrier = useIsCarrier();\r\n const signalRService = useCommunicationService();\r\n\r\n const userId = useSelector((state) => state.user.profile?.payload?.id) ?? '';\r\n const isCommunicationsEnabled = useSelector((state) => state.communication.isCommunicationsEnabled);\r\n const isProfileFetched = useSelector((state) => state.user.profileFetchedAt !== undefined);\r\n\r\n const connectedTopics = useRef(EmptyConnectedTopics);\r\n const userStatusRef = useRef('foreground');\r\n const latestIsCommunicationsEnabled = useRef(isCommunicationsEnabled);\r\n latestIsCommunicationsEnabled.current = isCommunicationsEnabled;\r\n\r\n const isCommunicationListOpened = () => {\r\n return history.location.pathname.includes('communication');\r\n };\r\n\r\n const connectToBiddingTopics = useConnectToBiddingTopics(\r\n connectedTopics,\r\n isCarrier ? BiddingRole.Carrier : BiddingRole.Broker\r\n );\r\n const latestIsBiddingEnabled = useRef(isBiddingEnabled);\r\n latestIsBiddingEnabled.current = isBiddingEnabled;\r\n\r\n const disconnectFromTopics = (...topicCategories: TopicCategory[]) => {\r\n forEach(topicCategories, (category) => {\r\n if (connectedTopics.current[category]) {\r\n forEach(connectedTopics.current[category], (topic) => signalRService.disconnectFromTopic(topic));\r\n connectedTopics.current[category] = [];\r\n }\r\n });\r\n };\r\n\r\n const connectToCommunicationTopics = () => {\r\n dispatch(getMessagesSummary());\r\n connectedTopics.current.communication = signalRService.connectToTopics({\r\n onUpdatedConversations: (updatedIds) => {\r\n dispatch(getMessagesSummary());\r\n if (isCommunicationListOpened()) {\r\n dispatch(getConversationsByID(updatedIds, userId));\r\n }\r\n },\r\n onNewMessage: (message) => {\r\n dispatch(\r\n onNewMessage(message.conversationId, {\r\n documents: message.documents,\r\n messageId: message.messageId,\r\n text: message.text,\r\n sentAt: message.sentAt,\r\n read: false,\r\n sentBy: message.sentBy,\r\n clientMessageId: message.clientMessageId,\r\n users: [],\r\n widget: message.widget ?? undefined,\r\n })\r\n );\r\n },\r\n });\r\n };\r\n\r\n const connectToGeneralTopics = () => {\r\n connectedTopics.current.general = signalRService.connectToTopics({\r\n onUpdateClientStatus: () => {\r\n signalRService.updateClientStatus(userStatusRef.current);\r\n },\r\n onSettingsUpdate: (update: SettingsUpdate) => {\r\n if (isCommunicationSettingsUpdate(update.settings)) {\r\n dispatch(getCommunicationStatus());\r\n }\r\n //This fix check is only temporary.\r\n //We are checking if there was any updates made to alerts settings\r\n //If yes we fetch the new settings\r\n //Once we have implemented the real time database this will be obsolete - bernard\r\n if (isAlertsPollIntervalSettingsUpdated(update.settings)) {\r\n dispatch(fetchAlertSettings());\r\n }\r\n const systemSettingFetchActions = mapSettingsUpdateToActions(update);\r\n forEach(systemSettingFetchActions, (action) => {\r\n dispatch(action);\r\n });\r\n },\r\n onNewTruckAlert: () => {\r\n if (isCarrier) {\r\n dispatch(newTruckAlert());\r\n }\r\n },\r\n });\r\n };\r\n\r\n useEffect(() => {\r\n dispatch(getCommunicationStatus());\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (isUserLoggedIn && isProfileFetched) {\r\n signalRService.startListening().then(() => {\r\n connectToGeneralTopics();\r\n if (latestIsCommunicationsEnabled.current && connectedTopics.current.communication.length === 0) {\r\n connectToCommunicationTopics();\r\n dispatch(getConversationsSummary());\r\n }\r\n if (latestIsBiddingEnabled.current && connectedTopics.current.bidding.length === 0) {\r\n connectToBiddingTopics();\r\n dispatch(getBiddingSummary(isCarrier ? BiddingRole.Carrier : BiddingRole.Broker));\r\n }\r\n });\r\n\r\n return () => {\r\n signalRService.updateClientStatus('offline');\r\n\r\n disconnectFromTopics(TopicCategory.General, TopicCategory.Communication, TopicCategory.Bidding);\r\n\r\n signalRService.stopListening();\r\n dispatch(resetCommunicationsState());\r\n };\r\n }\r\n\r\n return voidFunction;\r\n }, [isUserLoggedIn, isProfileFetched]);\r\n\r\n useEffect(() => {\r\n if (signalRService.isConnected()) {\r\n if (isCommunicationsEnabled) {\r\n if (connectedTopics.current.communication.length === 0) {\r\n connectToCommunicationTopics();\r\n dispatch(getConversationsSummary());\r\n }\r\n } else {\r\n disconnectFromTopics(TopicCategory.Communication);\r\n }\r\n }\r\n }, [isCommunicationsEnabled]);\r\n\r\n useEffect(() => {\r\n if (signalRService.isConnected()) {\r\n if (isBiddingEnabled) {\r\n if (connectedTopics.current.bidding.length === 0) {\r\n connectToBiddingTopics();\r\n dispatch(getBiddingSummary(isCarrier ? BiddingRole.Carrier : BiddingRole.Broker));\r\n }\r\n } else {\r\n disconnectFromTopics(TopicCategory.Bidding);\r\n }\r\n }\r\n }, [isBiddingEnabled]);\r\n\r\n useAppVisibilityChange(\r\n (isVisible) => {\r\n if (isCommunicationsEnabled) {\r\n const currentStatus = isVisible ? 'foreground' : 'background';\r\n userStatusRef.current = currentStatus;\r\n signalRService.updateClientStatus(currentStatus);\r\n } else if (isVisible) {\r\n dispatch(getCommunicationStatus());\r\n }\r\n },\r\n [isCommunicationsEnabled]\r\n );\r\n\r\n return null;\r\n};\r\n\r\nconst useConnectToBiddingTopics = (connectedTopics: React.MutableRefObject, role: BiddingRole) => {\r\n const dispatch = useDispatch();\r\n const signalRService = useCommunicationService();\r\n\r\n return useCallback(() => {\r\n connectedTopics.current.bidding = signalRService.connectToTopics({\r\n onNewBids: (event) => {\r\n dispatch(receivedBidUpdateEvent(UpdateBidEventType.NewBids, event, role));\r\n },\r\n onUpdatedBids: (event) => {\r\n dispatch(receivedBidUpdateEvent(UpdateBidEventType.UpdatedBids, event, role));\r\n },\r\n });\r\n }, [connectedTopics, signalRService]);\r\n};\r\n\r\nconst isCommunicationSettingsUpdate = (updates: SettingUpdate[]) => {\r\n return find(updates, (update) => update.name.includes('messaging.client')) ? true : false;\r\n};\r\n\r\nconst isAlertsPollIntervalSettingsUpdated = (updates: SettingUpdate[]) => {\r\n return find(\r\n updates,\r\n (update) => update.name.includes('load.alerts.pollIntervalSecs') || update.name.includes('load.alerts.active')\r\n )\r\n ? true\r\n : false;\r\n};\r\n","import React, { useEffect, useState } from 'react';\r\n\r\nimport { ConnectedRouter } from 'connected-react-router';\r\nimport { Helmet } from 'react-helmet';\r\nimport { Provider, ReactReduxContext, useDispatch } from 'react-redux';\r\nimport { generatePath } from 'react-router';\r\nimport { PersistGate } from 'redux-persist/integration/react';\r\nimport 'simplebar/dist/simplebar.min.css';\r\nimport styled from 'styled-components';\r\n\r\nimport { MuiThemeProvider } from '@material-ui/core';\r\n\r\nimport { history } from '@/reduxStore/History';\r\nimport { persistor, store } from '@/reduxStore/Store';\r\nimport { Flag } from '@common/model';\r\nimport { fetchLoadId } from '@common/redux/epic/LoadDetailsEpic';\r\nimport { getSystemSetting } from '@common/redux/epic/SettingsEpic';\r\nimport { fetchUnreadTruckAlertsCount } from '@common/redux/epic/TruckAlertsEpic';\r\nimport { fetchUser } from '@common/redux/epic/UserEpic';\r\nimport { MessageWidgetButton } from '@component/buttons/MessageWidgetButton';\r\nimport { MainLayout } from '@component/main/MainLayout';\r\nimport { PageWithPanels } from '@component/panel';\r\nimport '@page/aspxPage/AspxSelfEmbedProtection';\r\nimport { CommunicationRoute } from '@page/communication/CommunicationRoute';\r\nimport { LoadConversationsOriginUI } from '@page/communication/LoadConversations';\r\nimport THEME from '@style/Theme';\r\nimport { t, T } from '@translate';\r\nimport { AppConfig } from '@util/AppConfig';\r\nimport { useAppVisibilityChange, useSelector } from '@util/hooks';\r\nimport icons from '@util/iconsConstants';\r\nimport { hideMainSpinner } from '@util/MainSpinnerHelper';\r\nimport {\r\n DESCRIPTION_META,\r\n OG_DESCRIPTION_META,\r\n OG_TITLE_META,\r\n TITLE_META,\r\n TWITTER_DESCRIPTION_META,\r\n TWITTER_TITLE_META,\r\n} from '@util/Metadata';\r\nimport { createMessagingPartnerPortalTrackData, track } from '@util/trackers/123lbTracker';\r\nimport { hasLoginCookies } from '@webApi/CookiesHelper';\r\n\r\nimport { appDependencies, DependencyProvider } from './AppDependencies';\r\nimport { CommunicationHandler } from './CommunicationHandler';\r\nimport { Routes } from './router/Routes';\r\n\r\nexport const Container = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n`;\r\n\r\nexport const ButtonContainer = styled(Container)<{ isWidgetButton?: boolean }>`\r\n justify-content: center;\r\n height: 100%;\r\n width: ${(props) => (props.isWidgetButton ? '' : '100%')};\r\n align-items: center;\r\n background: ${(props) => (props.isWidgetButton ? 'transparent' : 'white')};\r\n`;\r\n\r\ntype PartnerPortalMessage =\r\n | { type: 'buttonWidget'; isWidgetButton: boolean }\r\n | { type: 'openWidget'; isWidgetOpen: boolean }\r\n | { type: 'reference'; referenceId?: string };\r\ninterface MessagingWidgetAppProps {\r\n parentHostname: string;\r\n}\r\n\r\nconst MessagingWidgetApp = (props: MessagingWidgetAppProps) => {\r\n const { parentHostname } = props;\r\n const [referenceId, setReferenceId] = useState('');\r\n const [isWidgetButton, setIsWidgetButton] = useState(false);\r\n const [isWidgetOpen, setIsWidgetOpen] = useState(false);\r\n\r\n const [isLoggedIn, setIsLoggedIn] = useState(hasLoginCookies());\r\n\r\n const dispatch = useDispatch();\r\n\r\n const fetchSystemSettings = () => {\r\n dispatch(getSystemSetting(Flag.BiddingDisabled));\r\n dispatch(getSystemSetting(Flag.BiddingV2Disabled));\r\n dispatch(getSystemSetting(Flag.VendorBiddingDisabled));\r\n dispatch(getSystemSetting(Flag.HideParadeContact));\r\n dispatch(getSystemSetting(Flag.BookNowDisabled));\r\n };\r\n\r\n useEffect(() => {\r\n if (isLoggedIn) {\r\n fetchSystemSettings();\r\n }\r\n hideMainSpinner();\r\n if (window.parent) {\r\n window.parent.postMessage('alive', '*');\r\n }\r\n const handleMessage = (event: MessageEvent) => {\r\n const data = event.data as PartnerPortalMessage | undefined;\r\n if (data?.type === 'reference') {\r\n setReferenceId(data?.referenceId ?? '');\r\n }\r\n if (data?.type === 'buttonWidget') {\r\n setIsWidgetButton(data?.isWidgetButton);\r\n }\r\n if (data?.type === 'openWidget') {\r\n setIsWidgetOpen(data?.isWidgetOpen);\r\n }\r\n };\r\n window.addEventListener('message', handleMessage);\r\n return () => {\r\n window.removeEventListener('message', handleMessage);\r\n };\r\n }, []);\r\n\r\n useAppVisibilityChange((isVisible) => {\r\n if (isVisible) {\r\n if (hasLoginCookies()) {\r\n fetchSystemSettings();\r\n }\r\n setIsLoggedIn(hasLoginCookies());\r\n }\r\n }, []);\r\n\r\n const handleLogin = () => {\r\n window.open(\r\n AppConfig.getLoginLink(\r\n `${AppConfig.LBConfig.MembersRoot}/partner-widget/?partner=${parentHostname}&isWidgetOpen=false`\r\n ),\r\n '_blank'\r\n );\r\n };\r\n\r\n return (\r\n <>\r\n \r\n {AppConfig.NAME}\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n {isLoggedIn ? (\r\n <>\r\n \r\n \r\n >\r\n ) : (\r\n \r\n \r\n \r\n )}\r\n \r\n \r\n \r\n \r\n \r\n \r\n >\r\n );\r\n};\r\n\r\ninterface RenderMessagesButtonProps {\r\n parentHostname: string;\r\n isWidgetOpen: boolean;\r\n referenceId?: string;\r\n isWidgetButton?: boolean;\r\n}\r\n\r\nconst RenderMessagesButton = (props: RenderMessagesButtonProps) => {\r\n const { parentHostname, isWidgetOpen, referenceId, isWidgetButton } = props;\r\n\r\n const dispatch = useDispatch();\r\n const unreadMessagesCount = useSelector((state) => state.communication.unreadMessagesCount);\r\n\r\n const userId = useSelector((state) => state.user.profile?.payload?.id);\r\n const loadID = useSelector((state) => state.loadDetails.widgetLoadId);\r\n\r\n useEffect(() => {\r\n dispatch(fetchUnreadTruckAlertsCount());\r\n if (!userId) {\r\n dispatch(fetchUser());\r\n }\r\n }, []);\r\n\r\n const handleClick = () => {\r\n if (window.parent) {\r\n window.parent.postMessage('resize', '*');\r\n }\r\n\r\n if (userId) {\r\n track(createMessagingPartnerPortalTrackData(parentHostname, userId, unreadMessagesCount));\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (referenceId !== undefined && userId) {\r\n dispatch(fetchLoadId(referenceId, userId));\r\n }\r\n }, [referenceId, userId]);\r\n\r\n useEffect(() => {\r\n if (isWidgetOpen && userId) {\r\n track(createMessagingPartnerPortalTrackData(parentHostname, userId, unreadMessagesCount));\r\n history.push(generatePath(Routes.COMMUNICATION));\r\n }\r\n }, [userId, isWidgetOpen, loadID]);\r\n\r\n let content =\r\n unreadMessagesCount > 0 ? (\r\n \r\n ) : (\r\n \r\n );\r\n\r\n if (isWidgetOpen) {\r\n content = (\r\n \r\n \r\n \r\n );\r\n }\r\n\r\n return {content};\r\n};\r\n\r\nexport const isMessagingWidgetView = () => {\r\n return (\r\n window.name === 'lb123connect' ||\r\n (window.location !== window.parent.location && window.location.pathname.includes('/partner-widget/'))\r\n );\r\n};\r\n\r\nexport default MessagingWidgetApp;\r\n","import { CarrierMapInfo } from '@/model/Carrier';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\n\r\nexport class CarrierInfoClient extends BaseClient {\r\n fetchCarrierMapInfo$ = (contactGUID: string) => this.api.get$(`/contacts/${contactGUID}/map`, {});\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { AppConfig } from '@util/AppConfig';\r\n\r\nconst FEED_BASE_PATH = AppConfig.LBConfig.FeedBaseUrl;\r\nconst DASHBOARD_FEED_BASE_PATH = AppConfig.LBConfig.DashboardFeedBaseUrl;\r\nconst VIDEO_FEED_BASE_PATH = AppConfig.LBConfig.VideoFeedBaseUrl;\r\nconst PROMO_BASE_PATH = AppConfig.LBConfig.PromoBaseUrl;\r\nconst HOSTING_ROOT = AppConfig.LBConfig.AzureHostingRootUrl;\r\nconst BROKER_FEED_PATH = `${FEED_BASE_PATH}feed-brokers.html`;\r\nconst CARRIER_FEED_PATH = `${FEED_BASE_PATH}feed-carriers.html`;\r\nconst DASHBOARD_FEED_CARRIER_PATH = `${DASHBOARD_FEED_BASE_PATH}dashboard-feed-carriers.html`;\r\nconst DASHBOARD_FEED_BROKER_PATH = `${DASHBOARD_FEED_BASE_PATH}dashboard-feed-brokers.html`;\r\n\r\nexport class FeedClient extends BaseClient {\r\n getFeed$ = (isBroker: boolean) => this.api.get$(isBroker ? BROKER_FEED_PATH : CARRIER_FEED_PATH, {});\r\n getDashboardFeed$ = (isBroker: boolean) =>\r\n this.api.get$(isBroker ? DASHBOARD_FEED_BROKER_PATH : DASHBOARD_FEED_CARRIER_PATH, {});\r\n getVideoList$ = (videoFileName: string) => this.api.get$(`${VIDEO_FEED_BASE_PATH}${videoFileName}`, {});\r\n getPromo$ = (promoFileName: string) => this.api.get$(`${PROMO_BASE_PATH}${promoFileName}`, {});\r\n getMappingFile$ = () =>\r\n this.api.get$(\r\n `${HOSTING_ROOT}/ext-mapping.csv`,\r\n {},\r\n { headers: { Accept: 'application/json, text/plain, */*' } }\r\n );\r\n}\r\n","import { LoadVisibilityRuleset, LoadVisibilityRulesetResponse } from '@/model/LoadVisibilityRules';\r\nimport { convertRulesetForRequest } from '@/reduxStore/epic/LoadVisibilityRulesHelper';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport { EmptyResponse } from '@common/redux/Base';\r\n\r\nexport class LoadVisibilityRulesClient extends BaseClient {\r\n createRuleset$ = (request: LoadVisibilityRuleset) =>\r\n this.api.post$(\r\n '/loadvisibility/v1/broker/rulesets',\r\n convertRulesetForRequest(request)\r\n );\r\n\r\n getRuleset$ = (id: string) =>\r\n this.api.get$(`/loadvisibility/v1/broker/rulesets/${id}`, {});\r\n\r\n getAllRulesets$ = () =>\r\n this.api.get$<{ rulesets: LoadVisibilityRulesetResponse[] }>('/loadvisibility/v1/broker/rulesets', {});\r\n\r\n modifyRuleset$ = (request: LoadVisibilityRuleset) =>\r\n this.api.mergePatch$(\r\n `/loadvisibility/v1/broker/rulesets/${request.id}`,\r\n convertRulesetForRequest(request)\r\n );\r\n\r\n deleteRuleset$ = (id: string) => this.api.delete$(`/loadvisibility/v1/broker/rulesets/${id}`, {});\r\n}\r\n","import { OnboardedCarriers, OnboardedCarriersResponse } from '@/model';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\n\r\nexport class OnboardedCarriersClient extends BaseClient {\r\n modifyOnboardedCarriers$ = (usdotNumbers: string[]) =>\r\n this.api.put$<{}>('/broker/preferredCarriers', { usdotNumbers: usdotNumbers });\r\n\r\n deleteOnboardedCarriers$ = (request: OnboardedCarriers) =>\r\n this.api.post$<{}>('/broker/preferredCarriers/delete', request);\r\n\r\n //@TODO: MEM-3786 remove custom limit and add pagination support\r\n /** default values on the server - offset = 0, limit = 20 */\r\n getOnboardedCarriers$ = (offset?: number, limit: number = 10000) =>\r\n this.api.get$('/broker/preferredCarriers', { offset: offset, limit: limit });\r\n}\r\n","import QueryString from 'qs';\r\n\r\nimport {\r\n BrokerLoadsSummaryResponseMetadata,\r\n BulkPatchLoadsFields,\r\n DispatcherDetail,\r\n LegacyPosterLoadSearchRequest,\r\n LoadPostRequest,\r\n PostedLoadStatus,\r\n PosterLoadSearchRequest,\r\n RateCheckRequest,\r\n} from '@/model';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport {\r\n Load,\r\n MileageRoutesPostRequest,\r\n PostedLoadProgress,\r\n PostedLoadSearchResponse,\r\n RateCheck,\r\n RouteInfo,\r\n} from '@common/model';\r\nimport { EmptyResponse, SearchResponseMetadata } from '@common/redux/Base';\r\n\r\nexport class PostLoadsClient extends BaseClient {\r\n getPostedLoadsMetadata$ = (request: LegacyPosterLoadSearchRequest) =>\r\n this.api.post$('loads/search/poster/metadata', request);\r\n\r\n getBrokerLoadsSummary$ = (includeAllCompanyLoads: boolean) =>\r\n this.api.get$('broker/loads/summary', {\r\n includeAllCompanyLoads: includeAllCompanyLoads,\r\n });\r\n\r\n getPostedLoads$ = ({\r\n fields,\r\n ...request\r\n }: PosterLoadSearchRequest | Pick) =>\r\n this.api.post$(\r\n `internal/broker/loads/search?${QueryString.stringify({ fields: fields })}`,\r\n request\r\n );\r\n\r\n setLoadStatus$ = (loadId: string, status: string) =>\r\n this.api.mergePatch$(`/loads/${loadId}`, { status: status });\r\n deletePostedLoad$ = (loadId: string) => this.api.delete$(`/loads/${loadId}`, {});\r\n refreshLoadAge$ = (loadId: string) => this.api.post$(`/loads/${loadId}/refresh`, {});\r\n\r\n fetchDispatcherInfo$ = () => this.api.get$('/contacts/dispatcher', {});\r\n fetchRouteMileage$ = (request: MileageRoutesPostRequest) => this.api.post$('/routes/info', request);\r\n\r\n patchLoadsById$ = (loadIds: string[], patch: Partial) =>\r\n this.api.mergePatch$('/loads', { loadIds: loadIds, patchDocument: patch });\r\n\r\n patchLoadsByQuery$ = (\r\n excludedLoadIds: string[],\r\n patch: Partial,\r\n searchQuery: LegacyPosterLoadSearchRequest\r\n ) =>\r\n this.api.mergePatch$('/loads/filter', {\r\n excludeIds: excludedLoadIds,\r\n patchDocument: patch,\r\n searchQuery: searchQuery,\r\n });\r\n\r\n updateLoadsAge$ = (loadIds: string[]) => this.api.post$('/loads/refresh', { loadIds: loadIds });\r\n updateLoadsAgeWithExcludeIds$ = (loadIds: string[], searchQuery: LegacyPosterLoadSearchRequest) =>\r\n this.api.post$('/loads/filter/refresh', { excludeIds: loadIds, searchQuery: searchQuery });\r\n\r\n fetchRateCheck$ = (request: RateCheckRequest) => this.api.post$('/ratechecks', request);\r\n\r\n postLoad$ = (loadPostRequest: LoadPostRequest) => this.api.post$('/loads', loadPostRequest);\r\n editLoad$ = (loadPostRequest: LoadPostRequest, id: string) => this.api.put$(`/loads/${id}`, loadPostRequest);\r\n\r\n setPostedLoadProgress$ = (data: { loadID: string; progress: PostedLoadProgress; dotNo?: number }) => {\r\n return this.api.mergePatch$(`/broker/loads/${data.loadID}/progress`, {\r\n status: data.progress,\r\n dotNo: data.dotNo ?? 0, // endpoint requires 0 for empty\r\n });\r\n };\r\n}\r\n","import {\r\n ShareableLoadList,\r\n ShareableLoadListResponse,\r\n ShareableLoadPatchRequest,\r\n ShareableLoadPostRequest,\r\n ShareableLoadView,\r\n} from '@/model/URLScrape';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport { EmptyResponse } from '@common/redux/Base';\r\n\r\nexport class ShareableLoadsClient extends BaseClient {\r\n getShareableLoadList$ = () => this.api.get$('/broker/loads/share', {});\r\n deleteShareableLoad$ = (id: string) => this.api.delete$(`/broker/loads/share/${id}`, {});\r\n postShareableLoad$ = (request: ShareableLoadPostRequest) =>\r\n this.api.post$('/broker/loads/share', request);\r\n updateShareableLoad$ = ({ id, ...rest }: ShareableLoadPatchRequest) =>\r\n this.api.patch$(`/broker/loads/share/${id}`, rest);\r\n getSharedBrokerLoads$ = (id: string) => this.api.get$(`/broker/share/${id}/loads`, {});\r\n}\r\n","import { ContactSupportData, TrackingUnsubscribeData, TrialExtensionData, UnsubscribeData } from '@/model/Unsubscribe';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\n\r\nexport class UnsubscribeClient extends BaseClient {\r\n requestTrialExtension$ = (data: TrialExtensionData) =>\r\n this.api.post$('/memberships/unsubscribe/requestTrialExtension', data);\r\n\r\n contactSupport$ = (data: ContactSupportData) => this.api.post$('/memberships/unsubscribe/scheduleCall ', data);\r\n\r\n unsubscribeRequest$ = (data: UnsubscribeData) => this.api.post$('/memberships/unsubscribe/finalize ', data);\r\n\r\n trackingUnsubscribeData$ = (data: TrackingUnsubscribeData) =>\r\n this.api.post$('/tracking/membership/unsubscribe ', data);\r\n\r\n // @TODO: remove since we moved this to SystemTimeEpic in common to make it available in MOB\r\n getSystemTime$ = () => this.api.get$('/system/info/time', {});\r\n}\r\n","import {\r\n AlertsPayload,\r\n DispatcherDetail,\r\n DispatcherPatchRequest,\r\n DispatcherPayload,\r\n DispatcherPostRequest,\r\n DispatcherPostResponse,\r\n DispatchersPayload,\r\n DispatchersRequest,\r\n EmailNotificationsPayload,\r\n HotLeadsPayload,\r\n MessagesNotificationsPayload,\r\n ResetPasswordPayload,\r\n UserAddDetails,\r\n UserEditDetails,\r\n UsersSettingsPayload,\r\n} from '@/model';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport { PaginatedRequest } from '@common/redux/epic/PaginatedListReducer';\r\n\r\nexport class UserSettingsClient extends BaseClient {\r\n addUser$ = (data: UserAddDetails) => this.api.post$('/contacts/requestNew', data);\r\n getUsers$ = (id: string, offset: number) =>\r\n this.api.get$(`companies/${id}/contacts`, { offset: offset });\r\n getDispatchers$ = ({ id, ...rest }: DispatchersRequest) =>\r\n this.api.get$(`companies/${id}/dispatchers`, rest);\r\n getDispatcher$ = (id: string) => this.api.get$(`/dispatchers/${id}`, {});\r\n getDispatchersList$ = (request: PaginatedRequest) => this.api.get$('/dispatchers', request);\r\n addDispatcher$ = (data: DispatcherPostRequest) => this.api.post$('/dispatchers', data);\r\n deleteDispatcher$ = (id: string) => this.api.delete$<{}>(`/dispatchers/${id}`, {});\r\n editDispatcher$ = (id: string, data: DispatcherPatchRequest) =>\r\n this.api.mergePatch$(`/dispatchers/${id}`, data);\r\n getDefaultDispatcher$ = () => this.api.get$('/contacts/dispatcher', {});\r\n updateUser$ = (id: number, userDetails: UserEditDetails) =>\r\n this.api.put$(`contacts/${id}`, userDetails);\r\n getUser$ = (id: string) => this.api.get$(`contacts/${id}/info`, {});\r\n deleteUser$ = (guid: string) => this.api.delete$(`contacts/${guid}`, {});\r\n getHotLeads$ = () => this.api.get$(`/settings/privacycontrol`, {});\r\n updateHotLeads$ = (hotLeads: HotLeadsPayload) =>\r\n this.api.mergePatch$(`/settings/privacycontrol`, hotLeads);\r\n getAlerts$ = () => this.api.get$(`/settings/alerts`, {});\r\n updateAlerts$ = (data: AlertsPayload) => this.api.mergePatch$(`/settings/alerts`, data);\r\n getEmailNotifications$ = () => this.api.get$(`/settings/emailnotifications `, {});\r\n\r\n updateEmailNotifications$ = (data: EmailNotificationsPayload) =>\r\n this.api.mergePatch$(`/settings/emailnotifications`, data);\r\n\r\n resetPasswordWithEmail$ = (data: { email: string }) =>\r\n this.api.post$('/credentials/ForgottenPassword', data);\r\n\r\n postNotificationToken$ = (data: MessagesNotificationsPayload) =>\r\n this.api.post$(`/settings/notification`, notificationStatusParams(data.deviceId, data.token));\r\n\r\n updateNotificationToken$ = (data: MessagesNotificationsPayload) =>\r\n this.api.put$(\r\n `/settings/notification/${data.deviceId}`,\r\n notificationStatusParams(data.deviceId, data.token)\r\n );\r\n\r\n saveNotificationToken$ = () => this.api.get$('/settings', { fields: 'messaging' });\r\n}\r\n\r\nconst notificationStatusParams = (deviceId: string, token: string) => ({\r\n deviceId: deviceId,\r\n token: token,\r\n os: 'Desktop',\r\n osVersion: '10',\r\n enabled: true,\r\n authorizationStatus: 1,\r\n notificationVersion: 2,\r\n});\r\n","import { VerifyEmailResponsePayload } from '@/reduxStore/epic/VerifyEmailEpic';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\n\r\nexport class VerifyEmailClient extends BaseClient {\r\n verifyEmail$ = (activationCode: string) =>\r\n this.api.get$(`account/verify/${activationCode}`, {});\r\n resendConfirmationEmail$ = () => this.api.post$<{}>('/Account/ConfirmationEmail', {});\r\n}\r\n","import { LoadPreview } from '@/reduxStore/epic/WelcomebackCampaignEpic';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\n\r\nexport class WelcomebackCampaignClient extends BaseClient {\r\n getLoadSearchPreview$ = (query: string) => this.api.post$(`/loadsearchpreview?token=${query}`, {});\r\n}\r\n","export enum ApiErrorCode {\r\n PERMISSION_DENIED = 4030003,\r\n EMAIL_NOT_VERIFIED = 4030004,\r\n /** email exists, but pending confirmation */\r\n EMAIL_NOT_CONFIRMED = 4030013,\r\n EMAIL_ALREADY_EXISTS = 4000007,\r\n LOAD_LIMIT_REACHED = 4030006,\r\n LOAD_NOT_FOUND = 4040009,\r\n NAMED_LOAD_SEARCH_NOT_FOUND = 4042200,\r\n ACTION_PERMISSION_DENIED = 4030011,\r\n RATE_CHECK_LIMIT_REACHED = 4030016,\r\n EMAIL_NOT_FOUND_NO_EMAIL = 4000047,\r\n EMAIL_NOT_FOUND_NO_USERNAME = 4000360,\r\n FOLDER_ALREADY_EXISTS = 4001508,\r\n MCP_INVALID_CREDENTIALS = 4002125,\r\n MCP_ONBOARDING_CARRIER_FAILED_RISK_ASSESSMENT = 4002126,\r\n PUSH_NOTIFICATION_TOKEN_NOT_FOUND = 4040022,\r\n INVALID_UPLOAD_FILE_TYPE = 4001513,\r\n INVALID_CHARACTERS_FILENAME_TYPE = 4001506,\r\n UNABLE_TO_RETRIEVE_TF_INTEGRATION_STATUS = 5000936,\r\n LOAD_SEARCH_SETTINGS_ALREADY_EXIST = 4090012,\r\n INVALID_VALIDATION_CODE = 4001294,\r\n EXPIRED_VALIDATION_CODE = 4000341,\r\n PHONE_IS_LANDLINE = 4006030,\r\n RATING_NOT_FOUND_FOR_USDOT = 4042608,\r\n USER_DOES_NOT_HAVE_COMPANY = 4040110,\r\n PHONEVERIFICATION_TOO_MANY_ATTEMPTS = 4290001,\r\n VALIDATION_CODE_TOO_MANY_ATTEMPTS = 4290002,\r\n PHONENUMBER_INVALID = 4040127,\r\n /** most likely invalid phone number */\r\n TWILIO_BAD_REQUEST = 4006085,\r\n PHONENUMBER_BLACKLISTED = 4030041,\r\n UPGRADE_PROMO_CODE_INVALID = 4040026,\r\n LOAD_SEARCH_LIMIT_REACHED = 4030005,\r\n LOAD_VIEW_LIMIT_REACHED = 4030006,\r\n RATE_CHECK_FAILED_TO_COMPUTE_MILAGE = 4040111,\r\n RATE_CHECK_RATE_NOT_FOUND = 4040020,\r\n GEOLOCATION_DOES_NOT_CORRESPOND = 4040112,\r\n ZIP_CODE_DOES_NOT_CORRESPOND = 4040113,\r\n VERIFY_EMAIL_CODE_EXPIRED = 4000076,\r\n VERIFY_EMAIL_CODE_ALREADY_USED = 4040002,\r\n CREDITCARD_NUMBER_NOT_ACCEPTED = 4006108,\r\n CREDITCARD_AVS_NOT_ACCEPTED = 4006109,\r\n CREDITCARD_CVD_NOT_ACCEPTED = 4006110,\r\n CREDITCARD_EXPIRED = 4006111,\r\n INVALID_MEMBERSHIP_STATUS = 4090042,\r\n REACTIVATION_CHARGE_INVOICE_ERROR = 4090043,\r\n /** Booking/Vendor Bid error codes */\r\n BOOK_NOW_LOAD_UNAVAILABLE = 4042101,\r\n BOOK_NOW_NOT_FOUND_ERROR = 4042102,\r\n BID_LOAD_UNAVAILABLE = 4041102,\r\n BID_NOT_FOUND_ERROR = 4040141,\r\n BID_DISQUALIFIED_CARRIER = 4060021,\r\n BID_INVALID_DOT_MC_ERROR = 4009021, // same dot and mc error from Parade\r\n}\r\n\r\nexport enum ErrorUri {\r\n InvalidUserNameOrPassword = '0',\r\n AccessForbidden = '1',\r\n ForbiddenAccessForBasic = '2',\r\n EmailNotConfirmed = '3',\r\n UserDoesNotExist = '4',\r\n EmailDoesNotExist = '5',\r\n EmailNotValid = '6',\r\n InternalError = '7',\r\n EmailBounced = '8',\r\n EmailSoftBounced = '9',\r\n InvalidVersionHeader = '10',\r\n VersionNotSupported = '11',\r\n InvalidVersionFormat = '12',\r\n OtherLoadboardException = '13',\r\n MissingUserNameOrPassword = '14',\r\n MissingGrantType = '15',\r\n OAuthClientNotFound = '16',\r\n InvalidClientSecret = '17',\r\n MissingClientIdOrSecret = '18',\r\n InactiveApi = '19',\r\n ExternalEmailMissing = '20',\r\n ExternalEmailNotConfirmed = '21',\r\n ExternalLoginNotFound = '22',\r\n ExternalEmailTooLong = '23',\r\n EmailDomainNotSupported = '24',\r\n ExternalFirstNameMissing = '25',\r\n ExternalLastNameMissing = '26',\r\n ExternalProfileUnavailable = '27',\r\n}\r\n","/** Standard Request Options */\r\nexport const authenticationToApiOptions = (authenticated: boolean): ApiOptions => ({\r\n allowUnauthenticated: !authenticated,\r\n shouldPreventLoginRedirect: !authenticated,\r\n});\r\n\r\nexport enum LBHeaders {\r\n Referrer = '123LB-Referrer',\r\n FlowID = '123LB-FD',\r\n ApiVersion = '123LB-Api-Version',\r\n CorrelationId = '123LB-Correlation-Id',\r\n BackgroundStatus = '123LB-is-background',\r\n DeviceID = '123LB-BID',\r\n}\r\n\r\nexport interface ApiOptions {\r\n /** If true: Use the access token if possible.\r\n *\r\n * If user not logged in, does not attempt to login.\r\n * NOTE: Access token needs to be refreshed if possible.\r\n * If the refresh failed, does as if the user was logged out. (no access token)\r\n * Used on endpoints that supports both authenticated and anonymous access.\r\n * Meant to be used in areas like the 'Shared Loads' public web page where\r\n * the user might optionally be logged in.\r\n *\r\n * Defaults to false\r\n */\r\n allowUnauthenticated?: boolean;\r\n\r\n /** If true: Do not redirect to login on 401 failure.\r\n *\r\n * Refresh token might need refresh, but the 'final' failure should not redirect.\r\n * Used on endpoints that require authentication in public pages\r\n * where the user might optionally be logged in (like /profile)\r\n *\r\n * Defaults to false\r\n */\r\n shouldPreventLoginRedirect?: boolean;\r\n\r\n /**\r\n * true to \"silently stop\" ongoing requests (with matching cancelTag) before starting this one.\r\n *\r\n */\r\n //cancelAllPrevious?: boolean;\r\n\r\n /** If true: Do not automatically show Api failures messages.\r\n *\r\n * Else it will show a popup with the error message from the API.\r\n * This ONLY applies to errors coming from the Api. Most 5xx and 4xx.\r\n * It does not apply to Network failures.\r\n *\r\n * NOTE: Pending Actions will be executed (and shown) regardless of this value.\r\n *\r\n * Defaults to false\r\n */\r\n silentApiFailure?: boolean;\r\n\r\n /** If true: Do not automatically show Network failures messages.\r\n *\r\n * Else it will show a popup with a network unavailable / timeout error message.\r\n * This ONLY applies when there is essentially no response from the server.\r\n * Either a Timeout or some network issue like internet connectivity issues, Host unreachable, etc.\r\n * It does not apply to failures coming from the API (with an http status code).\r\n *\r\n * Defaults to false\r\n */\r\n silentNetworkFailure?: boolean;\r\n\r\n /** if true: Allow extended time to perform this request.\r\n *\r\n * Extended time is 70 seconds. If false, it's 18 seconds.\r\n *\r\n * Defaults to false\r\n */\r\n longTimeout?: boolean;\r\n\r\n /** if true: force a refresh token before calling the end point.\r\n * Defaults to false\r\n */\r\n forceRefreshToken?: boolean;\r\n\r\n /** if true: do not automatically handle special 503 errors. It will handle\r\n * it following the silentNetworkFailure option.\r\n *\r\n * 503 errors typically means the whole infrastructure is down.\r\n * At that point, the DNS might have been redirected into another\r\n * temporary host that contains information about the issue.\r\n * The api should be \"pinged\" in the background until a non-503 response is received at which\r\n * point, you stop showing the webview and \"route\" the app to the begining.\r\n *\r\n * Defaults to false\r\n */\r\n //no503Handling?: boolean;\r\n cancelGroup?: string;\r\n}\r\n","import { AxiosRequestConfig } from 'axios';\r\nimport { find, some } from 'lodash';\r\n\r\nimport { ErrorUri } from '@common/api';\r\nimport { PendingAction, PendingActionType } from '@common/api/PendingAction';\r\nimport { getFlowIDFrom } from '@common/helper/FlowIDHeaderHelper';\r\nimport { FieldError } from '@common/model';\r\nimport { AppErrorCode } from '@common/model/AppErrorCode';\r\nimport { Response, ResponseAction } from '@common/redux/Base';\r\n\r\nexport interface ApiResult {\r\n readonly success: boolean;\r\n readonly httpStatus: number;\r\n url?: string;\r\n headers?: { [key: string]: any };\r\n config?: AxiosRequestConfig;\r\n duration?: number;\r\n result: (onSuccess: (data: T) => R, onError: (error: ApiError) => R) => R;\r\n resultWithoutData: (onSuccess: () => R, onError: (error: ApiError) => R) => R;\r\n resultDataResponse: (actionType: string) => ResponseAction;\r\n}\r\nexport class ApiResponseSuccess implements ApiResult {\r\n readonly success: boolean = true;\r\n readonly httpStatus: number;\r\n data: T | undefined;\r\n headers: {};\r\n config?: AxiosRequestConfig;\r\n duration?: number;\r\n\r\n constructor(\r\n status: number,\r\n data: T | undefined,\r\n headers: {} = {},\r\n config: AxiosRequestConfig | undefined = {},\r\n duration: number | undefined = 0\r\n ) {\r\n this.data = data;\r\n this.httpStatus = status;\r\n this.config = config;\r\n this.headers = headers;\r\n this.duration = duration;\r\n }\r\n\r\n result = (onSuccess: (data: T, headers: {}) => R, onError: (error: ApiError, headers: {}) => R): R => {\r\n if (!this.data) {\r\n const error = new ApiError(this.httpStatus);\r\n error.message = 'The response requires data and it was missing.';\r\n return onError(error, this.headers);\r\n } else {\r\n return onSuccess(this.data, this.headers);\r\n }\r\n };\r\n\r\n resultDataResponse = (actionType: string): ResponseAction => {\r\n const response = this.result>(\r\n (data, headers) => ({ success: true, payload: data, headers: headers }),\r\n (error, headers) => ({ success: false, error: error, headers: headers })\r\n );\r\n\r\n return { type: actionType, response: response, flowID: getFlowIDFrom(this) };\r\n };\r\n\r\n resultWithoutData = (onSuccess: () => R): R => {\r\n return onSuccess();\r\n };\r\n}\r\n\r\nexport class ApiError implements ApiResult {\r\n readonly success: boolean = false;\r\n readonly httpStatus: number;\r\n code: number;\r\n message: string;\r\n title: string;\r\n actions?: PendingAction[];\r\n cause?: any;\r\n wasCancelled: boolean;\r\n headers?: {};\r\n config?: AxiosRequestConfig;\r\n duration?: number;\r\n fieldErrors?: FieldError[];\r\n error?: string;\r\n errorDescription?: string;\r\n error_uri?: ErrorUri;\r\n\r\n constructor(\r\n httpStatus: number = -1,\r\n code: number = -1,\r\n message: string = '',\r\n title: string = '',\r\n cause?: any,\r\n headers: {} | undefined = {},\r\n config: AxiosRequestConfig | undefined = {},\r\n duration: number | undefined = 0,\r\n error_uri?: ErrorUri,\r\n fieldErrors?: FieldError[],\r\n error?: '',\r\n errorDescription?: ''\r\n ) {\r\n this.httpStatus = httpStatus;\r\n this.message = message;\r\n this.title = title;\r\n this.code = code;\r\n this.cause = cause;\r\n this.wasCancelled = code === AppErrorCode.CANCEL_ERROR;\r\n this.headers = headers;\r\n this.config = config;\r\n this.duration = duration;\r\n this.fieldErrors = fieldErrors;\r\n this.error_uri = error_uri;\r\n this.error = error;\r\n this.errorDescription = errorDescription;\r\n }\r\n\r\n result = (onSuccess: (data: any) => R, onError: (error: ApiError) => R): R => {\r\n return onError(this);\r\n };\r\n resultWithoutData = (onSuccess: () => R, onError: (error: ApiError) => R): R => {\r\n return onError(this);\r\n };\r\n resultDataResponse = (actionType: string): ResponseAction => {\r\n return { type: actionType, response: { success: false, error: this }, flowID: getFlowIDFrom(this) };\r\n };\r\n}\r\n\r\nexport type ApiResponse123 = (ApiError | ApiResponseSuccess) & ApiResult; // we need & ApiResult or typescript wont allow to call\r\n\r\nexport const is401 = (error: ApiResult) => error.httpStatus === 401;\r\n\r\nexport const is4xxError = (status: number) => status >= 400 && status <= 499;\r\n\r\nexport const isNetworkError = (response: ApiResponse123) => {\r\n if (response.httpStatus <= 0) {\r\n return true;\r\n }\r\n const errorCode = (response as ApiError).code;\r\n if (!errorCode) {\r\n return false;\r\n }\r\n return some(\r\n [AppErrorCode.TIMEOUT_ERROR, AppErrorCode.CONNECTION_ERROR, AppErrorCode.UNKNOWN_ERROR],\r\n (code) => errorCode === code\r\n );\r\n};\r\n\r\nexport const isRefreshTokenPendingAction = (result: ApiResponse123): boolean =>\r\n result.httpStatus === 403 &&\r\n find((result as ApiError).actions, (action: PendingAction) => action.name === PendingActionType.refreshToken) !==\r\n undefined;\r\n","import { ApiResponse, ApisauceInstance, CancelToken, CLIENT_ERROR, create, SERVER_ERROR } from 'apisauce';\r\nimport Axios, {\r\n AxiosError,\r\n AxiosRequestConfig,\r\n AxiosResponse,\r\n Canceler,\r\n CancelToken as AxiosCancelToken,\r\n CancelTokenSource,\r\n} from 'axios';\r\nimport { Buffer } from 'buffer';\r\nimport { clone, forEach, includes, isEqual, some, toLower } from 'lodash';\r\nimport QueryString from 'qs';\r\nimport { defer as defer$, from as from$, Observable, of as of$, Subject } from 'rxjs';\r\nimport { mergeMap as mergeMap$, multicast as multicast$, refCount as refCount$ } from 'rxjs/operators';\r\n\r\nimport { ApiOptions, ErrorUri, LBHeaders, PendingAction, Request$ } from '@common/api';\r\nimport { MimeType, typesSupportedByDownload } from '@common/helper/FileHelper';\r\nimport { FieldError } from '@common/model';\r\nimport { AppErrorCode } from '@common/model/AppErrorCode';\r\n\r\nimport { ApiError, ApiResponse123, ApiResponseSuccess } from './ApiResponse';\r\n\r\ninterface CancelTokenConfiguration {\r\n cfg: AxiosRequestConfig;\r\n timeout: any; //NodeJS.Timer doesn't behave well between web / react native, still timeout has the same interface on both.\r\n}\r\n\r\nexport type PatchOp = 'remove' | 'replace';\r\n\r\nexport interface Patch {\r\n op: PatchOp;\r\n path: string;\r\n value: T;\r\n}\r\n\r\nexport interface OffsetLimitRequest {\r\n offset?: number;\r\n limit?: number;\r\n}\r\n\r\nexport type HttpRequest = (\r\n url: string,\r\n data: any,\r\n axiosConfig?: AxiosRequestConfig,\r\n extraConfig?: ApiOptions\r\n) => Request$;\r\nexport const DuplicatedRequestErrorCode = -7875;\r\nconst APP_TIMEOUT_ERROR = 'APP_TIMEOUT_ERROR_123';\r\n\r\ntype ApiCall = (config: AxiosRequestConfig) => Promise>;\r\n\r\nexport interface NetworkRetryManager {\r\n execute$: (\r\n apiCall: () => Observable>,\r\n maxRetries: number,\r\n config?: AxiosRequestConfig\r\n ) => Observable>;\r\n}\r\n\r\nexport interface Api {\r\n get$: HttpRequest;\r\n post$: HttpRequest;\r\n put$: HttpRequest;\r\n delete$: HttpRequest;\r\n patch$: HttpRequest;\r\n mergePatch$: HttpRequest;\r\n}\r\n\r\n/** Helper to overwrite the API Version for a specific endpoint */\r\nexport const withApiVersion = (version: string): AxiosRequestConfig => ({\r\n headers: { [LBHeaders.ApiVersion]: version },\r\n});\r\n\r\n/** Helper to set JSON Merge Patch (RFC7396) content type */\r\nexport const withMergePatch = (config?: AxiosRequestConfig): AxiosRequestConfig => ({\r\n ...config,\r\n headers: { 'Content-Type': 'application/merge-patch+json' },\r\n});\r\n\r\nconst getCorrelationId = (response: AxiosResponse) =>\r\n (response.headers as any)[toLower(LBHeaders.CorrelationId)] ?? undefined;\r\n\r\n/** perform JSON.parse in an interceptor only if content-type is json.\r\n * Also handle when cannot parse the JSON data\r\n */\r\nconst createResponseInterceptor =\r\n (logger?: ApiLogger) =>\r\n (originalResponse: AxiosResponse): AxiosResponse => {\r\n const response = clone(originalResponse);\r\n if (!response.headers || !response.headers['content-type']) {\r\n return response;\r\n }\r\n\r\n const isHeaderMimeType = (...mimeTypes: Readonly) =>\r\n some(mimeTypes, (mime) => response.headers?.['content-type'] && includes(response.headers['content-type'], mime));\r\n\r\n if (isHeaderMimeType(MimeType.json)) {\r\n try {\r\n response.data = JSON.parse(response.data);\r\n } catch (exception) {\r\n if (logger) {\r\n logger({\r\n mustReport: false,\r\n httpStatus: originalResponse.status,\r\n title: 'Error parsing json response',\r\n exception: exception,\r\n extra: {\r\n url: response.config.url ?? undefined,\r\n correlationId: getCorrelationId(response),\r\n },\r\n });\r\n }\r\n // unparsable json data, leave it as null and reject the response\r\n // NOTE: rejecting will probably do nothing special because of apisauce, but\r\n // http status outside of normal range will yield an \"UNKNOWN_ERROR\" in apisauce\r\n // hopefully the ApiError will be handled correctly\r\n response.data = new ApiError(\r\n response.status,\r\n AppErrorCode.FATAL_ERROR,\r\n 'Oops! something went wrong, if the issue persist, please contact support',\r\n 'Oops! something went wrong.',\r\n exception\r\n );\r\n response.status = 600;\r\n response.statusText = 'Unknown Error';\r\n }\r\n } else if (isHeaderMimeType(...typesSupportedByDownload) && !isHeaderMimeType(MimeType.csv)) {\r\n try {\r\n response.data = new Buffer(response.data, 'binary').toString('base64');\r\n } catch (exception) {\r\n if (logger) {\r\n logger({\r\n mustReport: true,\r\n httpStatus: originalResponse.status,\r\n title: 'Error on parsing image response',\r\n exception: exception,\r\n extra: {\r\n url: response.config.url ?? undefined,\r\n correlationId: getCorrelationId(response),\r\n },\r\n });\r\n }\r\n }\r\n }\r\n\r\n return response;\r\n };\r\n\r\nexport type ApiLoggerDiagnosticData = Record;\r\n\r\nexport type ApiLogger = (data: {\r\n title?: string;\r\n mustReport: boolean;\r\n url?: string;\r\n httpStatus: number;\r\n code?: number;\r\n errorResponse?: ApiResponse123;\r\n exception?: any;\r\n extra?: ApiLoggerDiagnosticData;\r\n}) => void;\r\n\r\ninterface CachedRequest {\r\n url: string;\r\n firstTimestamp: number;\r\n lastTimestamp: number;\r\n data: any;\r\n count: number;\r\n reportThreshold: number;\r\n}\r\n\r\nexport class ApiService implements Api {\r\n private readonly api: ApisauceInstance;\r\n private readonly retrier?: NetworkRetryManager;\r\n cachedRequests: CachedRequest[] = [];\r\n logger?: ApiLogger;\r\n constructor(\r\n baseUrl: string,\r\n headers: {},\r\n setupApi?: (api: ApisauceInstance) => void,\r\n retrier?: NetworkRetryManager,\r\n logger?: ApiLogger\r\n ) {\r\n this.api = create({\r\n baseURL: baseUrl,\r\n headers: headers,\r\n // override the default transformRequest to do nothing instead of\r\n // the default JSON.parse() always (!) and without error handling (!)\r\n transformResponse: [(data) => data],\r\n });\r\n this.logger = logger;\r\n this.retrier = retrier;\r\n const parseAxiosResponseInterceptor = createResponseInterceptor(logger);\r\n this.api.axiosInstance.interceptors.response.use(parseAxiosResponseInterceptor, (error: any): AxiosError => {\r\n if (Axios.isCancel(error) && error.message !== APP_TIMEOUT_ERROR) {\r\n return error;\r\n }\r\n if (!error) {\r\n return {\r\n config: {},\r\n name: '',\r\n message: '',\r\n isAxiosError: false,\r\n toJSON: () => ({}),\r\n };\r\n }\r\n if (error.response && !isEqual(error.response, {})) {\r\n error.response = parseAxiosResponseInterceptor(error.response);\r\n }\r\n return error;\r\n });\r\n\r\n if (setupApi) {\r\n setupApi(this.api);\r\n }\r\n }\r\n\r\n get$: HttpRequest = (url, params, axiosConfig) =>\r\n this.methodWrapper(this.api.get, url, params, {\r\n paramsSerializer: (params) =>\r\n QueryString.stringify(params, {\r\n arrayFormat: 'brackets',\r\n encode: false,\r\n }),\r\n ...axiosConfig,\r\n });\r\n post$: HttpRequest = (url, params, axiosConfig) => this.methodWrapper(this.api.post, url, params, axiosConfig);\r\n put$: HttpRequest = (url, params, axiosConfig) => this.methodWrapper(this.api.put, url, params, axiosConfig);\r\n delete$: HttpRequest = (url, params, axiosConfig) => this.methodWrapper(this.api.delete, url, params, axiosConfig);\r\n patch$: HttpRequest = (url, params, axiosConfig) => this.methodWrapper(this.api.patch, url, params, axiosConfig);\r\n mergePatch$: HttpRequest = (url, params, axiosConfig) =>\r\n this.methodWrapper(this.api.patch, url, params, withMergePatch(axiosConfig));\r\n\r\n methodWrapper = (\r\n methodFunction: (\r\n url: string,\r\n params?: {},\r\n axiosConfig?: AxiosRequestConfig\r\n ) => Promise>,\r\n url: string,\r\n params: any,\r\n axiosConfig: AxiosRequestConfig | undefined\r\n ): Observable> => {\r\n const requestCache = this.cachedRequests;\r\n const filteredRequestCache: CachedRequest[] = [];\r\n let isDuplicateRequest = false;\r\n const currentTimestamp = Date.now();\r\n forEach(requestCache, (cachedRequest) => {\r\n if (currentTimestamp <= cachedRequest.lastTimestamp + 10000) {\r\n if (cachedRequest.url === url && isEqual(params, cachedRequest.data)) {\r\n isDuplicateRequest = true;\r\n const timestampDifference = Date.now() - cachedRequest.lastTimestamp;\r\n cachedRequest.lastTimestamp = Date.now();\r\n cachedRequest.count += 1;\r\n if (cachedRequest.count >= cachedRequest.reportThreshold) {\r\n const { data, ...diagnosticData } = cachedRequest;\r\n this.logger?.({\r\n mustReport: true,\r\n title: 'Duplicate requests within 10s',\r\n httpStatus: -1,\r\n extra: {\r\n ...diagnosticData,\r\n lastTimestampDifference: timestampDifference,\r\n },\r\n url: url,\r\n code: DuplicatedRequestErrorCode,\r\n });\r\n cachedRequest.reportThreshold *= 2;\r\n }\r\n }\r\n filteredRequestCache.push(cachedRequest);\r\n }\r\n });\r\n if (!isDuplicateRequest) {\r\n const time = Date.now();\r\n filteredRequestCache.push({\r\n url: url,\r\n data: params,\r\n count: 1,\r\n reportThreshold: 10,\r\n firstTimestamp: time,\r\n lastTimestamp: time,\r\n });\r\n }\r\n this.cachedRequests = filteredRequestCache;\r\n return this.executeRequest$((config: AxiosRequestConfig) => methodFunction(url, params, config), url, axiosConfig);\r\n };\r\n\r\n executeRequest$ = (\r\n apiCall: ApiCall,\r\n url: string,\r\n axiosConfig?: AxiosRequestConfig\r\n ): Observable> => {\r\n const cancelSource: CancelTokenSource = CancelToken.source();\r\n const cancelID = `${Date.now()}${url}`;\r\n const executeRequest$ = (): Observable> => {\r\n const cfgWithCancelToken = setCancelToken(cancelSource.token, axiosConfig);\r\n const canceler = cancelSource.cancel;\r\n return callApi$(apiCall, url, cfgWithCancelToken.cfg, canceler, cfgWithCancelToken.timeout);\r\n };\r\n let request$: Request$;\r\n if (this.retrier) {\r\n request$ = this.retrier.execute$(executeRequest$, 1, axiosConfig);\r\n } else {\r\n request$ = executeRequest$();\r\n }\r\n request$.cancelID = cancelID;\r\n request$.cancel = cancelSource.cancel;\r\n return request$;\r\n };\r\n}\r\n\r\n// https://github.com/axios/axios/issues/647#issuecomment-322209906\r\n// timeout is sometimes unreliable\r\nconst setCancelToken = (token: AxiosCancelToken, axiosConfig?: AxiosRequestConfig): CancelTokenConfiguration => {\r\n let timeout = 30000;\r\n const newConfig: AxiosRequestConfig = {\r\n cancelToken: token,\r\n ...axiosConfig,\r\n };\r\n\r\n timeout = newConfig.timeout || timeout;\r\n return {\r\n cfg: newConfig,\r\n timeout: timeout,\r\n };\r\n};\r\n\r\nconst callApi$ = (\r\n apiCall: ApiCall,\r\n url: string,\r\n config: AxiosRequestConfig,\r\n cancel?: Canceler,\r\n timeout?: number\r\n) => {\r\n let timeoutID: any | undefined; //NodeJS.Timer doesn't behave well between web / react native, still timeout has the same interface on both.\r\n if (cancel && timeout) {\r\n timeoutID = setTimeout(() => {\r\n cancel(APP_TIMEOUT_ERROR);\r\n }, timeout + 1000);\r\n //We add 1second here to prevent this to be called instead of the axios timeout. Otherwise the error will be cancel instead of a timeout.\r\n }\r\n\r\n //Defer will convert a hot observable to cold (promisse to observable)\r\n const deferedApiCall$ = defer$(() => from$(apiCall(config)).pipe(mergeMap$(createResponseHandler$(url, timeoutID))));\r\n //To avoid creating a new instance per subscription we multicast it to a new subject.\r\n return deferedApiCall$.pipe(\r\n multicast$(() => new Subject()),\r\n //Refcount means don't wait for a explicit connect() call, start emmiting once the first subscription is created.\r\n refCount$()\r\n ) as Observable>;\r\n};\r\n\r\nconst createResponseHandler$ =\r\n (url: string, timeoutID?: any) =>\r\n (response: ApiResponse): Observable> => {\r\n // timeout has type any for the same reason as above (in callApi$)\r\n if (response && timeoutID) {\r\n clearTimeout(timeoutID);\r\n }\r\n const convertedResponse: ApiResponse123 = convertApiResponse(response);\r\n convertedResponse.url = url;\r\n return of$(convertedResponse);\r\n };\r\n\r\nconst Apisauce2AppErrorCode = {\r\n TIMEOUT_ERROR: AppErrorCode.TIMEOUT_ERROR,\r\n CONNECTION_ERROR: AppErrorCode.CONNECTION_ERROR,\r\n NETWORK_ERROR: AppErrorCode.NETWORK_ERROR,\r\n UNKNOWN_ERROR: AppErrorCode.UNKNOWN_ERROR,\r\n CANCEL_ERROR: AppErrorCode.CANCEL_ERROR,\r\n CLIENT_ERROR: AppErrorCode.CLIENT_ERROR,\r\n SERVER_ERROR: AppErrorCode.SERVER_ERROR,\r\n};\r\n\r\nexport const convertApiResponse = (response: ApiResponse<{}>): ApiResponse123 => {\r\n const httpStatus = response.status ? response.status : -1;\r\n if (response.ok) {\r\n return new ApiResponseSuccess(httpStatus, response.data as T, response.headers, response.config, response.duration);\r\n }\r\n const debugError = debugErrorFrom(response.originalError);\r\n if (response.problem === CLIENT_ERROR || response.problem === SERVER_ERROR) {\r\n const data = response.data as {\r\n code: number;\r\n title: string;\r\n\r\n message: string;\r\n\r\n actions?: PendingAction[];\r\n fieldErrors: FieldError[];\r\n\r\n error_description?: string;\r\n error_uri?: ErrorUri;\r\n };\r\n\r\n if (!data) {\r\n return new ApiError(\r\n httpStatus,\r\n -1,\r\n '',\r\n 'No data',\r\n debugError,\r\n response.headers,\r\n response.config,\r\n response.duration\r\n );\r\n }\r\n\r\n const error = new ApiError(\r\n httpStatus,\r\n data.code,\r\n data.error_description || data.message,\r\n data.title,\r\n debugError,\r\n response.headers,\r\n response.config,\r\n response.duration,\r\n data.error_uri,\r\n data.fieldErrors\r\n );\r\n if (data.actions && data.actions.length > 0) {\r\n error.actions = data.actions;\r\n }\r\n\r\n return error;\r\n }\r\n\r\n // No response from Server, map the apisauce error\r\n return new ApiError(\r\n httpStatus,\r\n Apisauce2AppErrorCode[response.problem] || AppErrorCode.UNKNOWN_ERROR,\r\n response.problem,\r\n 'Oops something happened',\r\n debugError,\r\n response.headers,\r\n response.config,\r\n response.duration\r\n );\r\n};\r\n\r\nconst debugErrorFrom = (error: AxiosError) => {\r\n if (!error) {\r\n return {};\r\n }\r\n return {\r\n requestCorrelation: error.request?.headers ? error.request.headers : 'N/A',\r\n responseCorrelation: error.response?.headers ? error.response.headers : 'N/A',\r\n name: error.name,\r\n message: error.message,\r\n errorCode: error.code,\r\n error: error,\r\n url: error.config ? error.config.url : '',\r\n axiosHeaders: error.config ? error.config.headers : '',\r\n stack: error.stack,\r\n };\r\n};\r\n","import { ApiErrorCode } from './';\r\n\r\nexport const enum PendingActionType {\r\n display = 'Display',\r\n logout = 'Logout',\r\n refreshToken = 'RefreshToken',\r\n linkAccount = 'LinkAccount',\r\n}\r\n\r\nexport enum LinkType {\r\n None = 'None',\r\n Web = 'Web',\r\n API = 'API',\r\n OS = 'OS',\r\n App = 'App',\r\n}\r\n\r\nexport interface Link {\r\n title: string;\r\n url?: string;\r\n type: LinkType;\r\n displayAsDismiss?: boolean;\r\n}\r\n\r\nexport interface PendingAction {\r\n title: string;\r\n message: string;\r\n links: Link[];\r\n name: PendingActionType;\r\n code: ApiErrorCode;\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { Avatar } from '@common/redux/epic/AvatarEpic';\r\n\r\nexport interface UploadAvatarData {\r\n mimeType: string;\r\n file: Blob | Uint8Array;\r\n}\r\n\r\nexport class AvatarClient extends BaseClient {\r\n fetchAvatar$ = (imageSize: string) =>\r\n this.api.get$(`/profile/avatar/?imageType=${imageSize}`, {}, { responseType: 'arraybuffer' });\r\n fetchOtherUserAvatar$ = (id: string) =>\r\n this.api.get$(`/profile/${id}/avatar?imageType=Small`, {}, { responseType: 'arraybuffer' });\r\n uploadAvatar$ = (uploadParams: UploadAvatarData) => {\r\n return this.api.put$('/profile/avatar', uploadParams.file, {\r\n headers: { 'Content-Type': uploadParams.mimeType },\r\n });\r\n };\r\n deleteAvatar$ = () => this.api.delete$(`/profile/avatar`, {});\r\n}\r\n","import { Api } from '@common/api';\r\n\r\nexport abstract class BaseClient {\r\n protected api: Api;\r\n\r\n constructor(api: Api) {\r\n this.api = api;\r\n }\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport {\r\n BidActionRequest,\r\n BidDetails,\r\n BiddingSummaryRequest,\r\n BiddingSummaryResponse,\r\n BidsSummariesRequest,\r\n BidSummariesResponse,\r\n CarrierInfo,\r\n LoadBidsRequest,\r\n LoadBidsResponse,\r\n LoadFieldsBiddingOnly,\r\n LoadWithDataForBiddingOnly,\r\n LoadWithStatusOnly,\r\n PostBidRequest,\r\n} from '@common/model';\r\n\r\nexport class BidsClient extends BaseClient {\r\n getBidSummaries$ = (request: BidsSummariesRequest) =>\r\n this.api.get$('/bids', {\r\n ...request,\r\n roles: request.roles && request.roles.length > 0 ? request.roles.toString() : undefined,\r\n status: request.status && request.status.length > 0 ? request.status.toString() : undefined,\r\n });\r\n\r\n getBiddingSummary$ = (request: BiddingSummaryRequest) =>\r\n this.api.get$('/bids/summary', {\r\n bidUpdatesCount: true,\r\n roles: [request.role],\r\n });\r\n\r\n getBiddingSummaryList$ = ({ loadId, ...request }: LoadBidsRequest) =>\r\n this.api.get$(`/loads/${loadId}/bids`, request);\r\n\r\n getBidSummary$ = ({ loadId, carrierId, ...request }: LoadBidsRequest) =>\r\n this.api.get$(`/loads/${loadId}/bids/history/${carrierId ?? 'self'}`, request);\r\n\r\n getBid$ = (bidId: string) => this.api.get$(`/bids/${bidId}`, {});\r\n\r\n getCarrierInfo$ = (bidId: string) => this.api.get$(`/bids/${bidId}/carrierinfo`, {});\r\n\r\n actOnBid$ = ({ bidId, ...request }: BidActionRequest) =>\r\n this.api.post$(`/bids/${bidId}/updates`, request);\r\n\r\n postBid$ = ({ loadId, ...request }: PostBidRequest) => this.api.post$(`/loads/${loadId}/bids`, request);\r\n\r\n getLoadIsOnline$ = (loadId: string) => this.api.get$(`/loads/${loadId}`, { fields: 'status' });\r\n\r\n getBidLoadDetails$ = (loadId: string) =>\r\n this.api.get$(`/loads/${loadId}`, { fields: LoadFieldsBiddingOnly });\r\n\r\n markAllBidsAsViewed$ = () => this.api.post$<{}>('/bids/mark-as-read', {});\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { SendOneTimeLocationRequest } from '@common/model/OneTimeLocation';\r\n\r\nexport class CarrierTrackingClient extends BaseClient {\r\n requestOneTimeLocationSharing$ = (conversationId: string) =>\r\n this.api.post$<{}>(`/carrierTracking/requestOneTimeLocation`, { conversationId: conversationId });\r\n\r\n sendOneTimeLocation$ = (request: SendOneTimeLocationRequest) =>\r\n this.api.post$<{}>('/carrierTracking/sendOneTimeLocation', request);\r\n}\r\n","import { LBHeaders } from '@common/api/ApiOptions';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport {\r\n CanMessageResponse,\r\n CommunicationStatus,\r\n Conversation,\r\n ConversationMessageResponse,\r\n ConversationResponse,\r\n ConversationsListRequest,\r\n ConversationsSummary,\r\n ConversationUserStatuses,\r\n LoadFieldsConversationOnly,\r\n LoadWithDataForConversation,\r\n MessagePayload,\r\n MessagesSummary,\r\n} from '@common/model/Conversation';\r\n\r\nexport interface SendMessageResponse {\r\n messageId: string;\r\n}\r\nexport class CommunicationClient extends BaseClient {\r\n negotiate$ = () => this.api.post$<{ accessToken: string; url: string }>('/conversations/negotiate', {});\r\n getConversationsSummary$ = () => this.api.get$('/conversations/summary', {});\r\n getMessagesSummary$ = () =>\r\n this.api.get$('/conversations/summary', {\r\n computeUnreadMessages: true,\r\n computeUnreadConversations: false,\r\n });\r\n getConversations$ = (data: ConversationsListRequest) =>\r\n this.api.get$('/conversations', {\r\n unread: data.unread,\r\n token: data.token,\r\n limit: data.limit,\r\n });\r\n getConversation$ = (conversationID: string) => this.api.get$(`/conversations/${conversationID}`, {});\r\n getLoadConversations$ = (loadID: string, appOrigin: string, inquireBroker: boolean) =>\r\n this.api.get$(\r\n `/loads/${loadID}/conversations`,\r\n {\r\n inquireBroker: inquireBroker,\r\n },\r\n {\r\n headers: {\r\n [LBHeaders.Referrer]: appOrigin,\r\n [LBHeaders.FlowID]: '',\r\n },\r\n }\r\n );\r\n getCommunicationStatus$ = () => this.api.get$('conversations/status', {});\r\n getMessages$ = (conversationID: string) =>\r\n this.api.get$(`/conversations/${conversationID}/messages`, { recipients_info: true });\r\n sendMessage$ = (conversationID: string, message: MessagePayload) =>\r\n this.api.post$(`/conversations/${conversationID}/messages`, message);\r\n getUserStatus$ = (conversationID: string) =>\r\n this.api.get$(`/conversations/${conversationID}/user-statuses`, {});\r\n markMessageRead$ = (conversationID: string, messageID: string, isRead = true) =>\r\n this.api.mergePatch$<{}>(`/conversations/${conversationID}/messages/${messageID}/status`, { read: isRead });\r\n markAllMessagesAsRead$ = () => this.api.post$<{}>('/conversations/mark-as-read', {});\r\n getCanMessage$ = (userIDs: string[]) =>\r\n this.api.post$('conversations/can-message', { users: userIDs });\r\n\r\n getConversationLoadDetails$ = (loadId: string) =>\r\n this.api.get$(`/loads/${loadId}`, { fields: LoadFieldsConversationOnly });\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { Avatar } from '@common/redux/epic/AvatarEpic';\r\n\r\nexport interface UploadAvatarData {\r\n mimeType: string;\r\n file: Blob | Uint8Array;\r\n}\r\n\r\nexport class CompanyAvatarClient extends BaseClient {\r\n fetchCompanyAvatar$ = (imageSize: string) =>\r\n this.api.get$(`/companies/avatar/?imageType=${imageSize}`, {}, { responseType: 'arraybuffer' });\r\n fetchOtherCompanyAvatar$ = (id: string) =>\r\n this.api.get$(`/companies/${id}/avatar?imageType=Small`, {}, { responseType: 'arraybuffer' });\r\n uploadCompanyAvatar$ = (uploadParams: UploadAvatarData) => {\r\n return this.api.put$('/companies/avatar', uploadParams.file, {\r\n headers: { 'Content-Type': uploadParams.mimeType },\r\n });\r\n };\r\n deleteCompanyAvatar$ = () => this.api.delete$(`/companies/avatar`, {});\r\n}\r\n","import { AxiosRequestConfig } from 'axios';\r\nimport { reduce } from 'lodash';\r\nimport { Observable, of as of$ } from 'rxjs';\r\nimport { mergeMap as mergeMap$ } from 'rxjs/operators';\r\n\r\nimport { Api } from '@common/api';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport { addArchivingHeader } from '@common/helper/FlowIDHeaderHelper';\r\nimport {\r\n BrokerPaginationRequest,\r\n CarrierFeedback,\r\n CarrierRating,\r\n CarrierSearchRequest,\r\n CarrierSearchResponse,\r\n CarrierStatus,\r\n Company,\r\n CompanyAuthorityInfo,\r\n CompanyInsuranceInfo,\r\n CompanyLicensingInfo,\r\n CompanyUserDataPayload,\r\n CompanyUserDataQuery,\r\n CompanyVerificationDetailsResponse,\r\n CreditInfo,\r\n UserDataCompany,\r\n} from '@common/model';\r\nimport { SearchDirectoryCompanyRequest, SearchDirectoryCompanyResponse } from '@common/model/SearchDirectory';\r\nimport { EmptyResponse } from '@common/redux/Base';\r\n\r\nexport interface CompanyUserData {\r\n id: string;\r\n value: T;\r\n}\r\n\r\nexport class CompanyClient extends BaseClient {\r\n getCompanyInfo$ = () => this.api.get$('/companies', {});\r\n getCompanyDetails$ = (id: string) => this.api.get$(`/companies/${id}`, {});\r\n getCompanyAuthority$ = (id: string) => this.api.get$(`/companies/${id}/authority`, {});\r\n getCompanyAuthorityLicensing$ = (id: string) =>\r\n this.api.get$<{ authorityInfo: CompanyAuthorityInfo; licensingInfo: CompanyLicensingInfo }>(\r\n `/companies/${id}/authorityAndLicensing`,\r\n {}\r\n );\r\n getCompanyInsurance$ = (id: string) => this.api.get$(`/companies/${id}/insurance`, {});\r\n getCompanyCredit$ = (id: string) => this.api.get$(`/companies/${id}/credit`, {});\r\n getCompanyUserData = (query: CompanyUserDataQuery, fields: string = 'all', request?: BrokerPaginationRequest) =>\r\n this.api.get$('/companies/search/userdata', { fields: fields, ...query, ...request });\r\n updateCompanyInfo$ = (companyInfo: Company) => {\r\n if (companyInfo.id && companyInfo.id.length > 0) {\r\n return this.api.put$(`/companies/${companyInfo.id}`, companyInfo);\r\n } else {\r\n return this.api.post$('/companies', companyInfo);\r\n }\r\n };\r\n favoriteCarriers$ = (carriers: Array>) =>\r\n performMultiplePatches$(this.api, '/favoriteCarrier', carriers, createCompanyEndpoint);\r\n favoriteBrokers$ = (brokers: Array>, archivingFlowID: string | undefined) =>\r\n performMultiplePatches$(\r\n this.api,\r\n '/favoriteBroker',\r\n brokers,\r\n createCompanyEndpoint,\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n onboardedBrokers$ = (brokers: Array>, archivingFlowID: string | undefined) =>\r\n performMultiplePatches$(\r\n this.api,\r\n '/onboarded',\r\n brokers,\r\n createCompanyEndpoint,\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n hideCarriers$ = (carriers: Array>) =>\r\n performMultiplePatches$(this.api, '/hiddenCarrier', carriers, createCompanyEndpoint);\r\n hideBrokers$ = (brokers: Array>, archivingFlowID: string | undefined) =>\r\n performMultiplePatches$(\r\n this.api,\r\n '/hiddenBroker',\r\n brokers,\r\n createCompanyEndpoint,\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n addNotes$ = (id: string, note: string) => this.api.patch$(createCompanyEndpoint(id), payload('/note', note));\r\n onboardCarrier$ = (carriers: Array>) =>\r\n performMultiplePatches$(this.api, '/onboarded', carriers, createCarrierEndpoint);\r\n searchCarriers$ = (query: CarrierSearchRequest, request?: BrokerPaginationRequest) =>\r\n this.api.get$('/carriers/search', { ...query, ...request });\r\n updateCarrier$ = (id: string, status: CarrierStatus) =>\r\n this.api.mergePatch$(`/carriers/${id}/userdata`, status);\r\n updateCarrierFeedback$ = (id: string, feedback: CarrierFeedback) =>\r\n this.api.mergePatch$(createCarrierEndpoint(id), feedback);\r\n updateCarriers$ = (contactIds: string[], status: CarrierStatus) =>\r\n this.api.mergePatch$('/carriers/userdata', { contactIds: contactIds, patchDocument: status });\r\n updateCarriersFeedback$ = (contactIds: string[], feedback: CarrierFeedback) =>\r\n this.api.mergePatch$('/carriers/feedbacks', { contactIds: contactIds, patchDocument: feedback });\r\n getSearchDirectoriesCompanies$ = (fetchRequest: SearchDirectoryCompanyRequest) =>\r\n this.api.get$('/companies/search/directories', fetchRequest);\r\n setDirectoriesCompanyViewedStatus$ = (id: string) =>\r\n this.api.post$(`/companies/${id}/directories/viewed`, {});\r\n fetchVolpeInformationByDotNumber$ = (dotNumber: string) =>\r\n this.api.get$(`/companies/docketNumberRecordsByUsDot/${dotNumber}`, {});\r\n fetchCarrierRating$ = (dotNumber: string) =>\r\n this.api.get$(`/companies/${dotNumber}/carrierSource/rating`, {});\r\n patchCompanyDetails$ = (id: string, onboardingUrl: string) =>\r\n this.api.mergePatch$<{}>(`/companies/${id}`, { onboardingUrl: onboardingUrl });\r\n}\r\n\r\nconst createCompanyEndpoint = (id: string) => `/companies/${id}/userdata`;\r\nconst createCarrierEndpoint = (id: string) => `/carriers/${id}/feedbacks`;\r\nconst payload = (url: string, value: any) => [{ op: 'replace', path: url, value: value }];\r\nconst performMultiplePatches$ = (\r\n api: Api,\r\n path: string,\r\n companies: Array>,\r\n endPoint: (id: string) => string,\r\n config?: AxiosRequestConfig\r\n) => {\r\n return reduce(\r\n companies,\r\n (callStack: Observable, company) => {\r\n return callStack.pipe(mergeMap$(() => api.patch$(endPoint(company.id), payload(path, company.value), config)));\r\n },\r\n of$(null) /* we start with an empty event, then iterate over all calls */\r\n );\r\n};\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { CarrierInfo, ContactBrokerInfo } from '@common/model/Carrier';\r\n\r\nexport class ContactClient extends BaseClient {\r\n fetchCarrierInfo$ = (contactGUID: string) => this.api.get$(`/contacts/${contactGUID}/carrierInfo`, {});\r\n fetchBrokerInfo$ = (contactGUID: string) =>\r\n this.api.get$(`/contacts/${contactGUID}/brokerInfo`, {});\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { METADATA_ONLY } from '@common/helper';\r\nimport {\r\n CustomFolder,\r\n CustomFoldersRequest,\r\n CustomFoldersResponse,\r\n DefaultFoldersResponse,\r\n Document,\r\n DocumentFilters,\r\n DocumentTypes,\r\n FolderIdentifier,\r\n FolderResponse,\r\n MyDocumentsSendRequest,\r\n NewCustomFolderRequest,\r\n NewCustomFolderResponse,\r\n} from '@common/model';\r\nimport { EmptyResponse } from '@common/redux/Base';\r\nimport { DocumentsResponse } from '@common/redux/epic/DocumentListEpic';\r\n\r\nexport class DocumentsClient extends BaseClient {\r\n fetchDocuments$ = (request: DocumentFilters) =>\r\n this.api.get$('/documents', {\r\n documentType: request.documentType ? request.documentType.enumName : undefined,\r\n folderType: request.folder ? request.folder.type : undefined,\r\n folderId: request.folder ? request.folder.id : undefined,\r\n fromCreated: request.date ? request.date.dateStart : undefined,\r\n toCreated: request.date ? request.date.dateEnd : undefined,\r\n sortBy: request.sorting,\r\n sortDirection: undefined,\r\n limit: request.limit,\r\n offset: request.offset,\r\n SortDirection: request.sortDirection,\r\n fields: request.fields,\r\n });\r\n fetchDocumentTotal$ = () => this.api.get$('/documents', METADATA_ONLY);\r\n fetchFolderByLoad$ = (guid: string) => this.api.get$(`/loads/${guid}/folder`, {});\r\n fetchTypes$ = () => this.api.get$('/documents/types', {});\r\n fetchDocumentFile$ = (id: string) => this.api.get$(`/documents/${id}`, {}, { responseType: 'arraybuffer' });\r\n fetchConversationDocumentFile$ = (conversationID: string, messageID: string, docID: string) =>\r\n this.api.get$(\r\n `/conversations/${conversationID}/messages/${messageID}/documents/${docID}`,\r\n {},\r\n { responseType: 'arraybuffer' }\r\n );\r\n sendDocuments$ = (request: MyDocumentsSendRequest) => this.api.post$('/documents/send', request);\r\n setDocName$ = (id: string, newName: string) =>\r\n this.api.patch$(`/documents/${id}`, [\r\n {\r\n op: 'replace',\r\n path: '/displayName',\r\n value: newName,\r\n },\r\n ]);\r\n deleteDocument$ = (uid: string) =>\r\n this.api.post$<{ failCount: string; successCount: string }>('/documents/delete', { documentsGuids: [uid] });\r\n changeDocType$ = (id: string, type: string) => {\r\n return this.api.patch$(`/documents/${id}`, [\r\n {\r\n op: 'replace',\r\n path: '/type',\r\n value: type,\r\n },\r\n ]);\r\n };\r\n changeDocFolder$ = (id: string, newFolder: FolderIdentifier) => {\r\n return this.api.patch$(`/documents/${id}`, [\r\n {\r\n op: 'replace',\r\n path: '/folderType',\r\n value: newFolder.type,\r\n },\r\n {\r\n op: 'replace',\r\n path: '/folderId',\r\n value: newFolder.id,\r\n },\r\n ]);\r\n };\r\n fetchCustomFolders$ = (request: CustomFoldersRequest) =>\r\n this.api.get$('/documents/folders/custom', request);\r\n fetchDefaultFolders$ = () => this.api.get$('/documents/folders/default', {});\r\n createCustomFolder$ = (request: NewCustomFolderRequest) =>\r\n this.api.post$('/documents/folders/custom', request);\r\n changeFolderName$ = (id: string, name: string) =>\r\n this.api.patch$(`/documents/folders/custom/${id}`, [\r\n {\r\n op: 'replace',\r\n path: '/name',\r\n value: name,\r\n },\r\n ]);\r\n deleteFolder$ = (id: string) => this.api.delete$(`/documents/folders/custom/${id}`, {});\r\n getCustomFolder$ = (id: string) => this.api.get$(`/documents/folders/custom/${id}`, {});\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { PostedLoadsUrl } from '@common/model';\r\nimport { FeedbackRequest } from '@common/model/FeedbackRequest';\r\n\r\nexport class FeedbackClient extends BaseClient {\r\n requestFTPIntegration$ = () => this.api.post$('/feedback/contactus/loadposting/ftp', {});\r\n requestURLScrape$ = (contactUsUrl: PostedLoadsUrl) =>\r\n this.api.post$('/feedback/contactus/loadposting/url', contactUsUrl);\r\n requestBrokerFeature$ = (isBroker: boolean) => this.api.post$('/feedback/contactus/requestBrokerFeatures', isBroker);\r\n requestCSVUpload$ = (data: FormData) => this.api.post$('/loads/file', data);\r\n requestFeedback$ = (feedbackRequest: FeedbackRequest) => this.api.post$('/feedback', feedbackRequest);\r\n}\r\n","import { Observable, of as of$ } from 'rxjs';\r\nimport { mergeMap } from 'rxjs/operators';\r\n\r\nimport { ApiError, ApiResponse123 } from '@common/api';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport { Ftp, ModifiedFtp, NewFtp } from '@common/model';\r\n\r\nexport class FtpClient extends BaseClient {\r\n fetchFtps$ = (): Observable> => this.api.get$('/contacts/postingftp', {});\r\n\r\n postFtp$ = (ftp: NewFtp): Observable> => {\r\n const postFtpResponse$: Observable> = this.api.post$('/contacts/postingftp', ftp);\r\n return postFtpResponse$.pipe(\r\n mergeMap((postFtpResponse: ApiResponse123): Observable> => {\r\n if (postFtpResponse.success) {\r\n return this.fetchFtps$();\r\n }\r\n const error = postFtpResponse as ApiError;\r\n return of$(error);\r\n })\r\n );\r\n };\r\n\r\n patchFtp$ = (ftp: ModifiedFtp): Observable> => {\r\n const { id, ...ftpData } = ftp;\r\n const patchFtpResponse$: Observable> = this.api.patch$(\r\n `/contacts/postingftp/${id}`,\r\n ftpData,\r\n { headers: { 'content-type': 'application/merge-patch+json' } }\r\n );\r\n return patchFtpResponse$.pipe(\r\n mergeMap((patchFtpResponse: ApiResponse123): Observable> => {\r\n if (patchFtpResponse.success) {\r\n return this.fetchFtps$();\r\n }\r\n\r\n const error = patchFtpResponse as ApiError;\r\n return of$(error);\r\n })\r\n );\r\n };\r\n\r\n deleteFtp$ = (ftpId: string) => this.api.delete$(`/contacts/postingftp/${ftpId}`, {});\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { Geolocation, ReverseGeolocationResult } from '@common/model';\r\n\r\nexport class GeocodingClient extends BaseClient {\r\n locationFor$ = (geolocation: Geolocation) =>\r\n this.api.post$('/locations/geocode/reverse', {\r\n location: {\r\n latitude: geolocation.latitude,\r\n longitude: geolocation.longitude,\r\n },\r\n allowFallback: true,\r\n });\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { ContactsCompanyVerificationResponse, IdentityVerificationPhoneResponse, Phone } from '@common/model';\r\n\r\nexport class IdentityVerificationClient extends BaseClient {\r\n getIdentityVerificationCompany$ = () =>\r\n this.api.get$('/identityVerification/company', {});\r\n\r\n addIdentityVerificationPhoneNumber$ = (phone: Phone) =>\r\n this.api.post$('/identityVerification/phoneNumber', {\r\n phoneNumber: phone.number,\r\n extension: phone.extension,\r\n });\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { GetMessagesResponse, InboxMessage, MessageAction } from '@common/model/Inbox';\r\nimport { EmptyResponse } from '@common/redux/Base';\r\n\r\nconst MESSAGES_LIMIT = 10;\r\n\r\nconst getTokenParam = (token: string | undefined): string => (token ? `&token=${token}` : '');\r\n\r\nexport class InboxClient extends BaseClient {\r\n fetchAllInboxMessages$ = (\r\n token: string | undefined,\r\n limit: number = MESSAGES_LIMIT,\r\n deleted: boolean = false,\r\n count: boolean = false\r\n ) =>\r\n this.api.get$(\r\n `/internalmessages?&deleted=${deleted}&limit=${limit}&count=${count}${getTokenParam(token)}`,\r\n {}\r\n );\r\n\r\n updateInboxMessage$ = (data: { action: MessageAction; messageIds: string[] }) =>\r\n this.api.mergePatch$('/internalmessages', {\r\n patchDocument: { status: data.action },\r\n ids: data.messageIds,\r\n });\r\n\r\n readMessage$ = (messageId: string) =>\r\n this.api.mergePatch$(`/internalmessages`, {\r\n patchDocument: { read: true },\r\n ids: [messageId],\r\n });\r\n\r\n fetchMessage$ = (messageId: string) => this.api.get$(`/internalmessages/${messageId}`, {});\r\n\r\n clearAllMessage$ = () =>\r\n this.api.mergePatch$('/internalmessages/filter', {\r\n patchDocument: { status: MessageAction.delete },\r\n excludedIds: [],\r\n });\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { addArchivingHeader } from '@common/helper/FlowIDHeaderHelper';\r\nimport { LoadFeedbackRequest } from '@common/model/LoadFeedbackRequest';\r\n\r\nexport class LoadFeedbackClient extends BaseClient {\r\n sendLoadFeedback$ = (\r\n loadID: string,\r\n loadFeedbackRequest: LoadFeedbackRequest,\r\n archivingFlowID: string | undefined\r\n ) => {\r\n const loadFeedbackRequestArray: LoadFeedbackRequest[] = [loadFeedbackRequest];\r\n return this.api.patch$<{}>(\r\n `loads/${loadID}/userdata`,\r\n loadFeedbackRequestArray,\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n}\r\n","import { join } from 'lodash';\r\n\r\nimport { authenticationToApiOptions, LBHeaders } from '@common/api/ApiOptions';\r\nimport { Api, withApiVersion } from '@common/api/ApiService';\r\nimport { BaseClient } from '@common/client/BaseClient';\r\nimport { intermediateRequest } from '@common/helper';\r\nimport { addArchivingHeader } from '@common/helper/FlowIDHeaderHelper';\r\nimport {\r\n AlertNotification,\r\n AspectRatio,\r\n BookNowResponse,\r\n CargoChiefRate,\r\n EquipmentType,\r\n FuelPrice,\r\n getStatesFromSortCategory,\r\n GreenscreensRate,\r\n Load,\r\n LoadAvailabilitySortCategory,\r\n LoadBackhauls,\r\n LoadProgress,\r\n LoadRateCheckPreviewResponse,\r\n LoadSearchGeoResponse,\r\n LoadSearchMetadata,\r\n LoadSearchRequest,\r\n LoadSearchResponse,\r\n LoadSortDirection,\r\n NamedSearchRequest,\r\n NearbyLoadsResponse,\r\n NearbyLoadsSearchRequest,\r\n PersistentLoadSearchDef,\r\n RateCheck,\r\n SimilarLoadSearchResponse,\r\n StateLoadAvailabilityResponse,\r\n StateMileagePayload,\r\n} from '@common/model';\r\nimport { LoadCreditRatingsResponse } from '@common/model/LoadCreditRatingsResponse';\r\nimport { RouteDirections, RouteInfo } from '@common/model/PCMiler';\r\nimport { SharedLoadMessage } from '@common/model/SharedLoadMessage';\r\nimport { EmptyResponse, SearchResponseMetadata } from '@common/redux/Base';\r\nimport {\r\n AlertsResponse,\r\n SearchesResponse,\r\n UpdateSearchAlertRequest,\r\n ViewFilter,\r\n} from '@common/redux/epic/loadSearch/HelperFunctions';\r\n\r\nexport class LoadsClient extends BaseClient {\r\n private readonly isLiveEnvironment: boolean;\r\n constructor(api: Api, isLiveEnvironment: boolean) {\r\n super(api);\r\n this.isLiveEnvironment = isLiveEnvironment;\r\n }\r\n fetchLoadCount$ = (request: LoadSearchRequest) => {\r\n return this.api.post$('/loads/search/metadata', {\r\n ...request,\r\n });\r\n };\r\n\r\n fetchLoads$ = (companyName?: string) =>\r\n this.api.get$('/loads', { onlineOnly: true, companyName: companyName }, withApiVersion('1.2'));\r\n fetchLoadDetails$ = (id: string, archivingFlowID: string | undefined, fields: string, onlineOnly: boolean = true) =>\r\n this.api.get$(\r\n `/loads/${id}`,\r\n { fields: fields, onlineOnly: onlineOnly },\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n fetchLoadCargoChiefRate$ = (id: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${id}/c4rates`, {}, addArchivingHeader(archivingFlowID));\r\n fetchLoadGreenscreensRate$ = (id: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${id}/greenscreensrates`, {}, addArchivingHeader(archivingFlowID));\r\n fetchSharedLoad$ = (token: string, isPoster?: boolean) =>\r\n this.api.get$(\r\n `/loads/shared/${isPoster ? 'poster/' : ''}${token}`,\r\n {},\r\n {},\r\n authenticationToApiOptions(false)\r\n );\r\n fetchPostedLoadsList$ = (fields: string) =>\r\n this.api.get$('/loads/list', { fields: fields, onlineOnly: true, limit: 0 });\r\n postAlertNotification$ = (loadId: string, alertNotification: AlertNotification) => {\r\n if (!this.isLiveEnvironment) {\r\n return this.api.post$(`/loads/${loadId}/alertdevice`, { ...alertNotification, sendToSelf: true });\r\n }\r\n return this.api.post$(`/loads/${loadId}/alertdevice`, alertNotification);\r\n };\r\n\r\n searchLoads$ = (\r\n request: LoadSearchRequest,\r\n shouldSilenceFailures = false,\r\n archivingFlowId: string | undefined,\r\n cancelGroup?: string,\r\n referrer?: string\r\n ) =>\r\n this.api.post$(\r\n 'loads/search',\r\n intermediateRequest(request),\r\n addArchivingHeader(\r\n archivingFlowId,\r\n referrer\r\n ? {\r\n headers: {\r\n [LBHeaders.Referrer]: referrer,\r\n },\r\n }\r\n : undefined\r\n ),\r\n {\r\n silentApiFailure: shouldSilenceFailures,\r\n silentNetworkFailure: shouldSilenceFailures,\r\n cancelGroup: cancelGroup,\r\n }\r\n );\r\n searchLoadsById$ = (\r\n id: string,\r\n request: { metadata: LoadSearchMetadata },\r\n shouldSilenceFailures = false,\r\n archivingFlowId: string | undefined\r\n ) =>\r\n this.api.post$(\r\n `/loads/named-searches/${id}/search`,\r\n request.metadata,\r\n addArchivingHeader(archivingFlowId),\r\n {\r\n silentApiFailure: shouldSilenceFailures,\r\n silentNetworkFailure: shouldSilenceFailures,\r\n }\r\n );\r\n searchGeoLoads$ = (request: LoadSearchRequest, archivingFlowId: string | undefined) =>\r\n this.api.post$(\r\n 'loads/geosearch',\r\n intermediateRequest(request),\r\n addArchivingHeader(archivingFlowId)\r\n );\r\n searchGeoLoadsById$ = (id: string, request: { metadata: LoadSearchMetadata }, archivingFlowId: string | undefined) =>\r\n this.api.post$(\r\n `/loads/named-searches/${id}/geosearch`,\r\n request.metadata,\r\n addArchivingHeader(archivingFlowId)\r\n );\r\n searchSimilarLoads$ = (request: LoadSearchRequest, archivingFlowId: string | undefined) =>\r\n this.api.post$(\r\n 'loads/search/similar',\r\n intermediateRequest(request),\r\n addArchivingHeader(archivingFlowId)\r\n );\r\n\r\n fetchLoadBackhauls$ = (loadId: string, namedSearchId: string | undefined, archivingFlowID: string | undefined) =>\r\n this.api.get$(\r\n `/loads/${loadId}/backhauls`,\r\n { fromNamedSearchId: namedSearchId },\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n fetchRouteInfo$ = (loadId: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${loadId}/routeinfo`, {}, addArchivingHeader(archivingFlowID));\r\n fetchRouteDirections$ = (loadId: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${loadId}/routedirections`, {}, addArchivingHeader(archivingFlowID));\r\n getRouteStateMileage$ = (loadId: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${loadId}/routestatemileage`, {}, addArchivingHeader(archivingFlowID));\r\n fetchRouteMap$ = (\r\n loadId: string,\r\n thumbnail: boolean,\r\n aspectRatio = AspectRatio.Ratio2_1,\r\n archivingFlowID: string | undefined\r\n ) =>\r\n this.api.get$(\r\n `/loads/${loadId}/routemap`,\r\n { thumbnail: thumbnail, aspectRatio: aspectRatio },\r\n addArchivingHeader(archivingFlowID, { responseType: 'arraybuffer' })\r\n );\r\n fetchCreditRatings$ = (loadId: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${loadId}/creditratings`, {}, addArchivingHeader(archivingFlowID));\r\n fetchRateCheck$ = (loadId: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${loadId}/ratecheck`, {}, addArchivingHeader(archivingFlowID));\r\n fetchLoadRateCheckPreviews$ = (loadIds: string[], archivingFlowID: string | undefined) =>\r\n this.api.post$(`/loads/ratecheck`, loadIds, addArchivingHeader(archivingFlowID));\r\n fetchFuelPrice$ = (state: string, country: string | undefined, archivingFlowID: string | undefined) =>\r\n this.api.get$('/fuelPrice', { state: state, country: country }, addArchivingHeader(archivingFlowID));\r\n setSavedLoad$ = (loadId: string, isSaved: boolean, archivingFlowID: string | undefined) => {\r\n return this.api.patch$(\r\n `/loads/${loadId}/userdata`,\r\n [\r\n {\r\n op: 'replace',\r\n path: '/isSaved',\r\n value: isSaved,\r\n },\r\n ],\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n setHiddenLoad$ = (loadId: string, archivingFlowID: string | undefined, isHidden: boolean = true) => {\r\n return this.api.patch$(\r\n `/loads/${loadId}/userdata`,\r\n [\r\n {\r\n op: 'replace',\r\n path: '/isHidden',\r\n value: isHidden,\r\n },\r\n ],\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n setLoadNote$ = (loadID: string, note: string, archivingFlowID: string | undefined) => {\r\n return this.api.patch$(\r\n `/loads/${loadID}/userdata`,\r\n [\r\n {\r\n op: 'replace',\r\n path: '/note',\r\n value: note,\r\n },\r\n ],\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n setPrivateLoadNote$ = (loadID: string, privateLoadNote: string, archivingFlowID: string | undefined) => {\r\n return this.api.patch$(\r\n `/loads/${loadID}/userdata`,\r\n [\r\n {\r\n op: 'replace',\r\n path: '/privateLoadNote',\r\n value: privateLoadNote,\r\n },\r\n ],\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n setLoadProgress$ = (loadID: string, progress: LoadProgress, archivingFlowID: string | undefined) => {\r\n return this.api.patch$(\r\n `/loads/${loadID}/userdata`,\r\n [\r\n {\r\n op: 'replace',\r\n path: '/progress',\r\n value: progress,\r\n },\r\n {\r\n op: 'replace',\r\n path: '/isSaved',\r\n value: false,\r\n },\r\n ],\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n setLoadCall$ = (loadID: string, isCalled: boolean, archivingFlowID: string | undefined) => {\r\n return this.api.patch$(\r\n `/loads/${loadID}/userdata`,\r\n [\r\n {\r\n op: 'replace',\r\n path: '/isCalled',\r\n value: isCalled,\r\n },\r\n ],\r\n addArchivingHeader(archivingFlowID)\r\n );\r\n };\r\n getSharedLoadUrl$ = (loadID: string, archivingFlowID: string | undefined) => {\r\n return this.api.get$(`/loads/${loadID}/share`, {}, addArchivingHeader(archivingFlowID));\r\n };\r\n\r\n fetchLoadAvailability$ = (equipmentTypes: EquipmentType[], sortCategory: LoadAvailabilitySortCategory) =>\r\n this.api.post$('/loads/availability/search', {\r\n metadata: {\r\n includeQueries: true,\r\n },\r\n equipmentTypes: join(equipmentTypes, ','),\r\n statesToInclude: getStatesFromSortCategory(sortCategory),\r\n sortExpression: 'None',\r\n sortDirection: LoadSortDirection.Desc,\r\n });\r\n\r\n searchNearbyLoads$ = (request: NearbyLoadsSearchRequest) =>\r\n this.api.post$('/loads/search/nearby', request);\r\n\r\n sendEmailToBroker$ = (loadID: string, comment: string) =>\r\n this.api.post$(`/loads/${loadID}/sendEmailtoBroker`, { comment: comment });\r\n\r\n getStateMileage$ = (loadID: string, archivingFlowID: string | undefined) =>\r\n this.api.get$(`/loads/${loadID}/routestatemileage`, {}, addArchivingHeader(archivingFlowID));\r\n\r\n sendBookNow$ = (loadID: string) => this.api.post$(`/loads/${loadID}/book-now`, {});\r\n\r\n fetchAllSearches$ = (filter?: ViewFilter) =>\r\n this.api.get$(`/loads/named-searches`, {\r\n hasAlerts: filter === ViewFilter.ALL ? undefined : filter === ViewFilter.WITH_ALERTS,\r\n });\r\n\r\n deleteAllSearches$ = (filter?: ViewFilter) =>\r\n this.api.delete$<{}>('/loads/named-searches', deleteSearchesQueryFromFilter(filter));\r\n\r\n createSearch$ = (request: NamedSearchRequest) =>\r\n this.api.post$('/loads/named-searches', request);\r\n\r\n fetchSearchByID$ = (namedSearchId: string) =>\r\n this.api.get$(`/loads/named-searches/${namedSearchId}`, {});\r\n\r\n editSearchRequest$ = (namedSearchId: string, request: NamedSearchRequest) =>\r\n this.api.put$(`/loads/named-searches/${namedSearchId}`, request);\r\n\r\n deleteSearch$ = (id: string) => this.api.delete$<{}>(`/loads/named-searches/${id}`, {});\r\n\r\n updateSearch$ = (request: UpdateSearchAlertRequest) =>\r\n this.api.mergePatch$<{}>(`/loads/named-searches/${request.namedSearchId}`, {\r\n hasAlert: request.hasAlert,\r\n });\r\n\r\n getSearchAlerts$ = () => this.api.get$('/loads/named-searches/alerts', {});\r\n}\r\n\r\nconst deleteSearchesQueryFromFilter = (filter?: ViewFilter) => {\r\n switch (filter) {\r\n case ViewFilter.WITH_ALERTS:\r\n return {\r\n onlyWithAlerts: true,\r\n onlyWithoutAlerts: undefined,\r\n };\r\n case ViewFilter.WITHOUT_ALERTS:\r\n return {\r\n onlyWithAlerts: undefined,\r\n onlyWithoutAlerts: true,\r\n };\r\n case ViewFilter.ALL:\r\n default:\r\n return {\r\n onlyWithAlerts: false,\r\n onlyWithoutAlerts: undefined,\r\n };\r\n }\r\n};\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { LocationSuggestions } from '@common/model';\r\n\r\nexport class LocationMatchClient extends BaseClient {\r\n fetchLocationMatch$ = (location: string, includeStates: boolean) =>\r\n this.api.get$('/suggestions/loc', { q: location, includeStates: includeStates });\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport { RecentLocationType, RecentSearchLocationsResponse } from '@common/model';\r\n\r\nexport class LocationsClient extends BaseClient {\r\n fetchRecentLocations$ = (locationTypes?: RecentLocationType[]) =>\r\n this.api.get$('/locations/recent', { locationTypes: locationTypes ?? 'All' });\r\n}\r\n","import { BaseClient } from '@common/client/BaseClient';\r\nimport {\r\n MileageRoutesPostRequest,\r\n MileageRoutesRequest,\r\n RouteDirections,\r\n RoutePoints,\r\n StateMileagePayload,\r\n UiSettingsPayload,\r\n} from '@common/model';\r\n\r\nexport class MileageCalculatorClient extends BaseClient {\r\n getRoutesDirection$ = (data: MileageRoutesRequest) => this.api.get$('/routes/direction', data);\r\n\r\n //For the three endpoints (POST /routes/direction, /route/routePath, /routes/statemileage):\r\n //post that acts like a get to be used if we have stops, it returns the apporopriate data for the PC miler\r\n //isCustom flag is used to track the number of calls to the PcMiler data and count it as new request to the tool\r\n //isFollowUp will track the call to the api for the pcMiler but not count it as a new request to the tool\r\n postRouteDirection$ = (data: MileageRoutesPostRequest, isCustomRequest: boolean) =>\r\n this.api.post$(`/routes/direction?isCustomRequest=${isCustomRequest}`, data);\r\n postRoutePath$ = (data: { route: MileageRoutesPostRequest }) =>\r\n this.api.post$('/route/routePath?isFollowUp=true', data);\r\n postStateMileage$ = (data: MileageRoutesPostRequest) =>\r\n this.api.post$('/routes/statemileage?isFollowUp=true', data);\r\n\r\n getUiSettings$ = () => this.api.get$