@trackunit/react-core-contexts-test 1.7.54 → 1.7.56

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.cjs.js CHANGED
@@ -115,6 +115,7 @@ const mockOemBrandingContext = {
115
115
 
116
116
  const mockToastContext = {
117
117
  addToast: doNothing,
118
+ removeToast: doNothing,
118
119
  setIsManifestError: doNothing,
119
120
  };
120
121
 
@@ -184,6 +185,10 @@ const mockCurrentUserPreferenceContext = {
184
185
  setSystemOfMeasurement: doNothing,
185
186
  };
186
187
 
188
+ const mockExportDataContextState = {
189
+ exportData: () => Promise.resolve(),
190
+ };
191
+
187
192
  /**
188
193
  * Mocks the ErrorHandlingContextValue
189
194
  *
@@ -551,6 +556,7 @@ class TrackunitProvidersMockBuilder {
551
556
  this.selectedOemBrandingContext = mockOemBrandingContext;
552
557
  this.selectedUserSubscriptionContext = mockUserSubscriptionContext;
553
558
  this.selectedFilterBarValues = mockFilterBarContext;
559
+ this.selectedExportDataContext = mockExportDataContextState;
554
560
  }
555
561
  /**
556
562
  * Use this Analytics Context.
@@ -793,6 +799,25 @@ class TrackunitProvidersMockBuilder {
793
799
  this.selectedAssetSortingContext = { ...mockAssetSortingContext, ...assetSortingContext };
794
800
  return this;
795
801
  }
802
+ /**
803
+ * Use this to pass in a differerent export data context.
804
+ * Defaults to mockExportDataContextState.
805
+ *
806
+ * This context is used by the useExportDataContext hook from lib "@trackunit/react-core-hooks"
807
+ *
808
+ * @see mockExportDataContextState
809
+ * @example
810
+ * ...
811
+ * it("should allow render", async () => {
812
+ * await trackunitProviders().exportData(yourPartialExportDataMock).render(<YourTestComponent data-testid="yourTestId" />);
813
+ * expect(screen.getByTestId("yourTestId")).toBeInTheDocument();
814
+ * });
815
+ * ...
816
+ */
817
+ exportData(exportDataContext) {
818
+ this.selectedExportDataContext = { ...mockExportDataContextState, ...exportDataContext };
819
+ return this;
820
+ }
796
821
  /**
797
822
  * Set OEM Branding context.
798
823
  * Defaults to mockOemBrandingContext.
@@ -965,7 +990,7 @@ class TrackunitProvidersMockBuilder {
965
990
  * @param testChildren - the child element being tested.
966
991
  */
967
992
  getMockedCompositionRoot(testChildren) {
968
- return (jsxRuntime.jsx(reactCoreHooks.ErrorHandlingContextProvider, { value: this.selectedErrorHandler, children: jsxRuntime.jsx(reactCoreHooks.CurrentUserProvider, { value: this.selectedCurrentUserContext, children: jsxRuntime.jsx(reactCoreHooks.AnalyticsContext.Provider, { value: this.selectedAnalyticsContext, children: jsxRuntime.jsx(reactCoreHooks.UserSubscriptionProvider, { value: this.selectedUserSubscriptionContext, children: jsxRuntime.jsx(reactCoreHooks.OemBrandingContextProvider, { value: this.selectedOemBrandingContext, children: jsxRuntime.jsx(reactCoreHooks.TokenProvider, { value: this.selectedTokenContext, children: jsxRuntime.jsx(reactCoreHooks.ToastProvider, { value: this.selectedToastContext, children: jsxRuntime.jsx(reactCoreHooks.ConfirmationDialogProvider, { value: this.selectedConfirmationDialogContext, children: jsxRuntime.jsx(reactCoreHooks.FilterBarProvider, { value: this.selectedFilterBarValues, children: jsxRuntime.jsx(reactCoreHooks.AssetSortingProvider, { value: this.selectedAssetSortingContext, children: jsxRuntime.jsx(ApolloMockedProviderWithError, { addTypename: false, mocks: this.selectedApolloMocks, children: jsxRuntime.jsx(reactCoreHooks.NavigationContextProvider, { value: this.selectedNavigationContext, children: jsxRuntime.jsx(reactCoreHooks.CurrentUserPreferenceProvider, { value: this.selectedCurrentUserPreferenceContext, children: jsxRuntime.jsx(reactCoreHooks.EnvironmentContextProvider, { value: this.selectedEnvironmentContext, children: jsxRuntime.jsx(reactCoreHooks.ModalDialogContextProvider, { value: this.selectedModalDialogContext, children: jsxRuntime.jsx(reactCoreHooks.TimeRangeProvider, { value: this.selectedTimeRangeContext, children: jsxRuntime.jsx(reactCoreHooks.WidgetConfigProvider, { value: this.selectedWidgetConfigContext, children: testChildren }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }));
993
+ return (jsxRuntime.jsx(reactCoreHooks.ErrorHandlingContextProvider, { value: this.selectedErrorHandler, children: jsxRuntime.jsx(reactCoreHooks.CurrentUserProvider, { value: this.selectedCurrentUserContext, children: jsxRuntime.jsx(reactCoreHooks.AnalyticsContext.Provider, { value: this.selectedAnalyticsContext, children: jsxRuntime.jsx(reactCoreHooks.UserSubscriptionProvider, { value: this.selectedUserSubscriptionContext, children: jsxRuntime.jsx(reactCoreHooks.OemBrandingContextProvider, { value: this.selectedOemBrandingContext, children: jsxRuntime.jsx(reactCoreHooks.TokenProvider, { value: this.selectedTokenContext, children: jsxRuntime.jsx(reactCoreHooks.ToastProvider, { value: this.selectedToastContext, children: jsxRuntime.jsx(reactCoreHooks.ConfirmationDialogProvider, { value: this.selectedConfirmationDialogContext, children: jsxRuntime.jsx(reactCoreHooks.FilterBarProvider, { value: this.selectedFilterBarValues, children: jsxRuntime.jsx(reactCoreHooks.ExportDataContext.Provider, { value: this.selectedExportDataContext, children: jsxRuntime.jsx(reactCoreHooks.AssetSortingProvider, { value: this.selectedAssetSortingContext, children: jsxRuntime.jsx(ApolloMockedProviderWithError, { addTypename: false, mocks: this.selectedApolloMocks, children: jsxRuntime.jsx(reactCoreHooks.NavigationContextProvider, { value: this.selectedNavigationContext, children: jsxRuntime.jsx(reactCoreHooks.CurrentUserPreferenceProvider, { value: this.selectedCurrentUserPreferenceContext, children: jsxRuntime.jsx(reactCoreHooks.EnvironmentContextProvider, { value: this.selectedEnvironmentContext, children: jsxRuntime.jsx(reactCoreHooks.ModalDialogContextProvider, { value: this.selectedModalDialogContext, children: jsxRuntime.jsx(reactCoreHooks.TimeRangeProvider, { value: this.selectedTimeRangeContext, children: jsxRuntime.jsx(reactCoreHooks.WidgetConfigProvider, { value: this.selectedWidgetConfigContext, children: testChildren }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }));
969
994
  }
970
995
  getMockedCompositionRootWithRouter(testChildren) {
971
996
  const childrenWithRouter = (jsxRuntime.jsx(RouterContainer, { addTestRootContainer: true, rootRoute: this.selectedRootRoute, selectedRouterProps: this.selectedRouterProps, children: testChildren }));
package/index.esm.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { AssetSortByProperty, SortOrder } from '@trackunit/react-core-contexts-api';
2
2
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
3
3
  import { act, render } from '@testing-library/react';
4
- import { ErrorHandlingContextProvider, CurrentUserProvider, AnalyticsContext, UserSubscriptionProvider, OemBrandingContextProvider, TokenProvider, ToastProvider, ConfirmationDialogProvider, FilterBarProvider, AssetSortingProvider, NavigationContextProvider, CurrentUserPreferenceProvider, EnvironmentContextProvider, ModalDialogContextProvider, TimeRangeProvider, WidgetConfigProvider } from '@trackunit/react-core-hooks';
4
+ import { ErrorHandlingContextProvider, CurrentUserProvider, AnalyticsContext, UserSubscriptionProvider, OemBrandingContextProvider, TokenProvider, ToastProvider, ConfirmationDialogProvider, FilterBarProvider, ExportDataContext, AssetSortingProvider, NavigationContextProvider, CurrentUserPreferenceProvider, EnvironmentContextProvider, ModalDialogContextProvider, TimeRangeProvider, WidgetConfigProvider } from '@trackunit/react-core-hooks';
5
5
  import { omit } from 'es-toolkit';
6
6
  import { ApolloLink } from '@apollo/client';
7
7
  import { loadDevMessages, loadErrorMessages } from '@apollo/client/dev';
@@ -113,6 +113,7 @@ const mockOemBrandingContext = {
113
113
 
114
114
  const mockToastContext = {
115
115
  addToast: doNothing,
116
+ removeToast: doNothing,
116
117
  setIsManifestError: doNothing,
117
118
  };
118
119
 
@@ -182,6 +183,10 @@ const mockCurrentUserPreferenceContext = {
182
183
  setSystemOfMeasurement: doNothing,
183
184
  };
184
185
 
186
+ const mockExportDataContextState = {
187
+ exportData: () => Promise.resolve(),
188
+ };
189
+
185
190
  /**
186
191
  * Mocks the ErrorHandlingContextValue
187
192
  *
@@ -549,6 +554,7 @@ class TrackunitProvidersMockBuilder {
549
554
  this.selectedOemBrandingContext = mockOemBrandingContext;
550
555
  this.selectedUserSubscriptionContext = mockUserSubscriptionContext;
551
556
  this.selectedFilterBarValues = mockFilterBarContext;
557
+ this.selectedExportDataContext = mockExportDataContextState;
552
558
  }
553
559
  /**
554
560
  * Use this Analytics Context.
@@ -791,6 +797,25 @@ class TrackunitProvidersMockBuilder {
791
797
  this.selectedAssetSortingContext = { ...mockAssetSortingContext, ...assetSortingContext };
792
798
  return this;
793
799
  }
800
+ /**
801
+ * Use this to pass in a differerent export data context.
802
+ * Defaults to mockExportDataContextState.
803
+ *
804
+ * This context is used by the useExportDataContext hook from lib "@trackunit/react-core-hooks"
805
+ *
806
+ * @see mockExportDataContextState
807
+ * @example
808
+ * ...
809
+ * it("should allow render", async () => {
810
+ * await trackunitProviders().exportData(yourPartialExportDataMock).render(<YourTestComponent data-testid="yourTestId" />);
811
+ * expect(screen.getByTestId("yourTestId")).toBeInTheDocument();
812
+ * });
813
+ * ...
814
+ */
815
+ exportData(exportDataContext) {
816
+ this.selectedExportDataContext = { ...mockExportDataContextState, ...exportDataContext };
817
+ return this;
818
+ }
794
819
  /**
795
820
  * Set OEM Branding context.
796
821
  * Defaults to mockOemBrandingContext.
@@ -963,7 +988,7 @@ class TrackunitProvidersMockBuilder {
963
988
  * @param testChildren - the child element being tested.
964
989
  */
965
990
  getMockedCompositionRoot(testChildren) {
966
- return (jsx(ErrorHandlingContextProvider, { value: this.selectedErrorHandler, children: jsx(CurrentUserProvider, { value: this.selectedCurrentUserContext, children: jsx(AnalyticsContext.Provider, { value: this.selectedAnalyticsContext, children: jsx(UserSubscriptionProvider, { value: this.selectedUserSubscriptionContext, children: jsx(OemBrandingContextProvider, { value: this.selectedOemBrandingContext, children: jsx(TokenProvider, { value: this.selectedTokenContext, children: jsx(ToastProvider, { value: this.selectedToastContext, children: jsx(ConfirmationDialogProvider, { value: this.selectedConfirmationDialogContext, children: jsx(FilterBarProvider, { value: this.selectedFilterBarValues, children: jsx(AssetSortingProvider, { value: this.selectedAssetSortingContext, children: jsx(ApolloMockedProviderWithError, { addTypename: false, mocks: this.selectedApolloMocks, children: jsx(NavigationContextProvider, { value: this.selectedNavigationContext, children: jsx(CurrentUserPreferenceProvider, { value: this.selectedCurrentUserPreferenceContext, children: jsx(EnvironmentContextProvider, { value: this.selectedEnvironmentContext, children: jsx(ModalDialogContextProvider, { value: this.selectedModalDialogContext, children: jsx(TimeRangeProvider, { value: this.selectedTimeRangeContext, children: jsx(WidgetConfigProvider, { value: this.selectedWidgetConfigContext, children: testChildren }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }));
991
+ return (jsx(ErrorHandlingContextProvider, { value: this.selectedErrorHandler, children: jsx(CurrentUserProvider, { value: this.selectedCurrentUserContext, children: jsx(AnalyticsContext.Provider, { value: this.selectedAnalyticsContext, children: jsx(UserSubscriptionProvider, { value: this.selectedUserSubscriptionContext, children: jsx(OemBrandingContextProvider, { value: this.selectedOemBrandingContext, children: jsx(TokenProvider, { value: this.selectedTokenContext, children: jsx(ToastProvider, { value: this.selectedToastContext, children: jsx(ConfirmationDialogProvider, { value: this.selectedConfirmationDialogContext, children: jsx(FilterBarProvider, { value: this.selectedFilterBarValues, children: jsx(ExportDataContext.Provider, { value: this.selectedExportDataContext, children: jsx(AssetSortingProvider, { value: this.selectedAssetSortingContext, children: jsx(ApolloMockedProviderWithError, { addTypename: false, mocks: this.selectedApolloMocks, children: jsx(NavigationContextProvider, { value: this.selectedNavigationContext, children: jsx(CurrentUserPreferenceProvider, { value: this.selectedCurrentUserPreferenceContext, children: jsx(EnvironmentContextProvider, { value: this.selectedEnvironmentContext, children: jsx(ModalDialogContextProvider, { value: this.selectedModalDialogContext, children: jsx(TimeRangeProvider, { value: this.selectedTimeRangeContext, children: jsx(WidgetConfigProvider, { value: this.selectedWidgetConfigContext, children: testChildren }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }));
967
992
  }
968
993
  getMockedCompositionRootWithRouter(testChildren) {
969
994
  const childrenWithRouter = (jsx(RouterContainer, { addTestRootContainer: true, rootRoute: this.selectedRootRoute, selectedRouterProps: this.selectedRouterProps, children: testChildren }));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@trackunit/react-core-contexts-test",
3
- "version": "1.7.54",
3
+ "version": "1.7.56",
4
4
  "repository": "https://github.com/Trackunit/manager",
5
5
  "license": "SEE LICENSE IN LICENSE.txt",
6
6
  "engines": {
@@ -11,10 +11,10 @@
11
11
  "@testing-library/react": "16.2.0",
12
12
  "react": "19.0.0",
13
13
  "graphql": "^16.10.0",
14
- "@trackunit/react-core-contexts-api": "1.8.50",
15
- "@trackunit/react-core-hooks": "1.7.54",
16
- "@trackunit/shared-utils": "1.9.46",
17
- "@trackunit/react-test-setup": "1.4.46",
14
+ "@trackunit/react-core-contexts-api": "1.8.52",
15
+ "@trackunit/react-core-hooks": "1.7.56",
16
+ "@trackunit/shared-utils": "1.9.47",
17
+ "@trackunit/react-test-setup": "1.4.47",
18
18
  "@tanstack/react-router": "1.114.29",
19
19
  "@tanstack/router-core": "1.114.29",
20
20
  "es-toolkit": "^1.39.10"
@@ -2,6 +2,7 @@ import { MockedResponse } from "@apollo/client/testing";
2
2
  import { AnyRoute } from "@tanstack/react-router";
3
3
  import { RenderResult } from "@testing-library/react";
4
4
  import { AssetSortingContextValue, ConfirmationDialogContextValue, CurrentUserContextInterface, ErrorHandlingContextValue, FilterBarContext, IAnalyticsContext, IEnvironmentContext, INavigationContext, IToastContext, ITokenContext, IUserPreferencesContext, IUserSubscriptionContext, ModalDialogContextValue, OemBrandingContext, TimeRangeContext, WidgetConfigContext } from "@trackunit/react-core-contexts-api";
5
+ import { ExportDataContextState } from "@trackunit/react-core-hooks";
5
6
  import { ReactElement, ReactNode } from "react";
6
7
  import { MemoryRouterProps } from "./utils/routingUtils";
7
8
  /**
@@ -33,6 +34,7 @@ export declare class TrackunitProvidersMockBuilder<T extends AnyRoute> {
33
34
  protected selectedOemBrandingContext: OemBrandingContext;
34
35
  protected selectedUserSubscriptionContext: IUserSubscriptionContext;
35
36
  protected selectedFilterBarValues: FilterBarContext;
37
+ protected selectedExportDataContext: ExportDataContextState;
36
38
  /**
37
39
  * Use this Analytics Context.
38
40
  * Defaults to mockAnalyticsContext.
@@ -231,6 +233,22 @@ export declare class TrackunitProvidersMockBuilder<T extends AnyRoute> {
231
233
  * @returns { TrackunitProvidersMockBuilder } - The builder.
232
234
  */
233
235
  assetSorting(assetSortingContext: Partial<AssetSortingContextValue>): this;
236
+ /**
237
+ * Use this to pass in a differerent export data context.
238
+ * Defaults to mockExportDataContextState.
239
+ *
240
+ * This context is used by the useExportDataContext hook from lib "@trackunit/react-core-hooks"
241
+ *
242
+ * @see mockExportDataContextState
243
+ * @example
244
+ * ...
245
+ * it("should allow render", async () => {
246
+ * await trackunitProviders().exportData(yourPartialExportDataMock).render(<YourTestComponent data-testid="yourTestId" />);
247
+ * expect(screen.getByTestId("yourTestId")).toBeInTheDocument();
248
+ * });
249
+ * ...
250
+ */
251
+ exportData(exportDataContext: Partial<ExportDataContextState>): this;
234
252
  /**
235
253
  * Set OEM Branding context.
236
254
  * Defaults to mockOemBrandingContext.
@@ -0,0 +1,2 @@
1
+ import { ExportDataContextState } from "@trackunit/react-core-hooks";
2
+ export declare const mockExportDataContextState: ExportDataContextState;