@applicaster/zapp-react-native-ui-components 14.0.0-alpha.8419134002 → 14.0.0-alpha.8557119261

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.
Files changed (105) hide show
  1. package/Components/AnimatedInOut/index.tsx +5 -3
  2. package/Components/AudioPlayer/mobile/Layout.tsx +1 -1
  3. package/Components/AudioPlayer/tv/helpers.tsx +10 -3
  4. package/Components/BaseFocusable/index.tsx +23 -12
  5. package/Components/Cell/__tests__/CellWIthFocusable.test.js +3 -2
  6. package/Components/Cell/index.js +1 -1
  7. package/Components/ComponentResolver/index.ts +1 -1
  8. package/Components/FeedLoader/FeedLoader.tsx +6 -15
  9. package/Components/FeedLoader/FeedLoaderHOC.tsx +21 -0
  10. package/Components/FeedLoader/index.js +2 -8
  11. package/Components/Focusable/Focusable.tsx +5 -3
  12. package/Components/Focusable/FocusableTvOS.tsx +3 -3
  13. package/Components/Focusable/FocusableiOS.tsx +2 -2
  14. package/Components/Focusable/__tests__/index.android.test.tsx +3 -0
  15. package/Components/Focusable/index.android.tsx +12 -8
  16. package/Components/Focusable/index.tsx +1 -1
  17. package/Components/FocusableList/index.tsx +4 -0
  18. package/Components/FreezeWithCallback/__tests__/index.test.tsx +67 -43
  19. package/Components/GeneralContentScreen/utils/__tests__/useCurationAPI.test.js +42 -59
  20. package/Components/GeneralContentScreen/utils/useCurationAPI.ts +13 -10
  21. package/Components/HandlePlayable/HandlePlayable.tsx +25 -9
  22. package/Components/Layout/TV/LayoutBackground.tsx +1 -1
  23. package/Components/Layout/TV/__tests__/index.test.tsx +0 -1
  24. package/Components/MasterCell/DefaultComponents/ActionButton.tsx +2 -0
  25. package/Components/MasterCell/DefaultComponents/Button.tsx +1 -1
  26. package/Components/MasterCell/DefaultComponents/FocusableView/index.tsx +4 -27
  27. package/Components/MasterCell/DefaultComponents/Image/hoc/withDimensions.tsx +1 -1
  28. package/Components/MasterCell/DefaultComponents/ImageContainer/index.tsx +1 -1
  29. package/Components/MasterCell/DefaultComponents/__tests__/image.test.js +10 -10
  30. package/Components/MasterCell/DefaultComponents/__tests__/text.test.tsx +18 -18
  31. package/Components/MasterCell/SharedUI/CollapsibleTextContainer/__tests__/index.test.tsx +10 -10
  32. package/Components/MasterCell/elementMapper.tsx +1 -2
  33. package/Components/MasterCell/utils/behaviorProvider.ts +82 -14
  34. package/Components/MasterCell/utils/index.ts +11 -5
  35. package/Components/OfflineHandler/NotificationView/__tests__/index.test.tsx +13 -18
  36. package/Components/OfflineHandler/__tests__/__snapshots__/index.test.tsx.snap +9 -0
  37. package/Components/OfflineHandler/__tests__/index.test.tsx +26 -35
  38. package/Components/PlayerContainer/ErrorDisplay/index.ts +1 -1
  39. package/Components/PlayerContainer/PlayerContainer.tsx +41 -28
  40. package/Components/PlayerContainer/ProgramInfo/index.tsx +1 -1
  41. package/Components/PlayerContainer/index.ts +1 -1
  42. package/Components/River/ComponentsMap/ComponentsMap.tsx +0 -1
  43. package/Components/River/ComponentsMap/hooks/__tests__/useLoadingState.test.ts +378 -0
  44. package/Components/River/ComponentsMap/hooks/useLoadingState.ts +2 -2
  45. package/Components/River/RefreshControl.tsx +11 -17
  46. package/Components/River/TV/River.tsx +2 -17
  47. package/Components/River/TV/index.tsx +3 -1
  48. package/Components/River/TV/withPipesV1DataLoader.tsx +43 -0
  49. package/Components/River/TV/withRiverDataLoader.tsx +17 -0
  50. package/Components/River/TV/withTVEventHandler.tsx +1 -1
  51. package/Components/River/__tests__/__snapshots__/componentsMap.test.js.snap +2 -0
  52. package/Components/River/__tests__/river.test.js +12 -26
  53. package/Components/River/index.tsx +1 -1
  54. package/Components/Screen/__tests__/Screen.test.tsx +28 -29
  55. package/Components/ScreenRevealManager/ScreenRevealManager.ts +76 -0
  56. package/Components/ScreenRevealManager/__tests__/ScreenRevealManager.test.ts +107 -0
  57. package/Components/ScreenRevealManager/__tests__/withScreenRevealManager.test.tsx +96 -0
  58. package/Components/ScreenRevealManager/index.ts +1 -0
  59. package/Components/ScreenRevealManager/withScreenRevealManager.tsx +79 -0
  60. package/Components/Tabs/TV/Tabs.android.tsx +0 -2
  61. package/Components/Tabs/Tabs.tsx +2 -3
  62. package/Components/Touchable/__tests__/__snapshots__/touchable.test.tsx.snap +34 -0
  63. package/Components/Touchable/__tests__/touchable.test.tsx +12 -17
  64. package/Components/Transitioner/__tests__/__snapshots__/Scene.test.js.snap +15 -9
  65. package/Components/VideoLive/animationUtils.ts +3 -3
  66. package/Components/VideoModal/ModalAnimation/AnimatedScrollModal.tsx +3 -9
  67. package/Components/VideoModal/ModalAnimation/ModalAnimationContext.tsx +32 -8
  68. package/Components/VideoModal/PlayerDetails.tsx +24 -2
  69. package/Components/VideoModal/PlayerWrapper.tsx +26 -142
  70. package/Components/VideoModal/VideoModal.tsx +3 -17
  71. package/Components/VideoModal/__tests__/PlayerDetails.test.tsx +5 -5
  72. package/Components/VideoModal/__tests__/PlayerWrapper.test.tsx +1 -7
  73. package/Components/VideoModal/__tests__/__snapshots__/PlayerWrapper.test.tsx.snap +44 -240
  74. package/Components/VideoModal/hooks/index.ts +0 -2
  75. package/Components/VideoModal/hooks/useModalSize.ts +18 -2
  76. package/Components/VideoModal/utils.ts +6 -0
  77. package/Components/Viewport/ViewportAware/__tests__/viewportAware.test.js +12 -16
  78. package/Components/Viewport/ViewportTracker/__tests__/viewportTracker.test.js +84 -24
  79. package/Contexts/ConfigutaionContext/__tests__/ConfigurationProvider.test.tsx +3 -3
  80. package/Contexts/ScreenContext/index.tsx +46 -6
  81. package/Decorators/ConfigurationWrapper/__tests__/withConfigurationProvider.test.tsx +3 -3
  82. package/Decorators/ConfigurationWrapper/withConfigurationProvider.tsx +2 -2
  83. package/Decorators/RiverFeedLoader/__tests__/__snapshots__/riverFeedLoader.test.tsx.snap +221 -209
  84. package/Decorators/RiverFeedLoader/__tests__/riverFeedLoader.test.tsx +14 -16
  85. package/Decorators/RiverFeedLoader/__tests__/utils.test.ts +0 -20
  86. package/Decorators/RiverFeedLoader/index.tsx +22 -4
  87. package/Decorators/RiverFeedLoader/utils/index.ts +0 -18
  88. package/Decorators/RiverResolver/__tests__/riverResolver.test.tsx +3 -6
  89. package/Decorators/ZappPipesDataConnector/ResolverSelector.tsx +25 -0
  90. package/Decorators/ZappPipesDataConnector/__tests__/NullFeedResolver.test.tsx +78 -0
  91. package/Decorators/ZappPipesDataConnector/__tests__/ResolverSelector.test.tsx +205 -0
  92. package/Decorators/ZappPipesDataConnector/__tests__/StaticFeedResolver.test.tsx +251 -0
  93. package/Decorators/ZappPipesDataConnector/__tests__/UrlFeedResolver.test.tsx +368 -0
  94. package/Decorators/ZappPipesDataConnector/__tests__/utils.test.ts +39 -0
  95. package/Decorators/ZappPipesDataConnector/index.tsx +26 -293
  96. package/Decorators/ZappPipesDataConnector/resolvers/NullFeedResolver.tsx +25 -0
  97. package/Decorators/ZappPipesDataConnector/resolvers/StaticFeedResolver.tsx +87 -0
  98. package/Decorators/ZappPipesDataConnector/resolvers/UrlFeedResolver.tsx +266 -0
  99. package/Decorators/ZappPipesDataConnector/types.ts +29 -0
  100. package/Decorators/ZappPipesDataConnector/utils/mongoFilter.ts +738 -0
  101. package/Decorators/ZappPipesDataConnector/utils/useFilter.tsx +157 -0
  102. package/events/index.ts +1 -0
  103. package/package.json +5 -10
  104. package/Components/River/__tests__/__snapshots__/river.test.js.snap +0 -27
  105. package/Components/VideoModal/hooks/useBackgroundColor.ts +0 -10
@@ -13,7 +13,8 @@ import {
13
13
  } from "@applicaster/zapp-react-native-utils/reactHooks";
14
14
  import { useModalNavigationContext } from "@applicaster/zapp-react-native-ui-components/Contexts/ModalNavigationContext";
15
15
  import { useNestedNavigationContext } from "@applicaster/zapp-react-native-ui-components/Contexts/NestedNavigationContext";
16
- import { create, StoreApi, UseBoundStore } from "zustand";
16
+ import { create } from "zustand";
17
+ import { subscribeWithSelector } from "zustand/middleware";
17
18
  import { useShallow } from "zustand/react/shallow";
18
19
  import { Animated } from "react-native";
19
20
 
@@ -39,11 +40,26 @@ interface NavBarState {
39
40
  setSummary: (subtitle: string) => void;
40
41
  }
41
42
 
42
- type ScreenContextType = {
43
- _navBarStore: UseBoundStore<StoreApi<NavBarStoreState>>;
44
- navBar: NavBarState;
45
- legacyFormatScreenData: LegacyNavigationScreenData | null;
46
- };
43
+ const createStateStore = () =>
44
+ create(
45
+ subscribeWithSelector<ScreenStateStore>((set) => ({
46
+ data: {},
47
+ setValue: (key, value) =>
48
+ set((state) => ({
49
+ data: {
50
+ ...state.data,
51
+ [key]: value,
52
+ },
53
+ })),
54
+ removeValue: (key) =>
55
+ set((state) => {
56
+ const newData = { ...state.data };
57
+ delete newData[key];
58
+
59
+ return { data: newData };
60
+ }),
61
+ }))
62
+ );
47
63
 
48
64
  const createStore = () =>
49
65
  create<NavBarStoreState>((set) => ({
@@ -65,7 +81,15 @@ const createStore = () =>
65
81
  },
66
82
  }));
67
83
 
84
+ type ScreenContextType = {
85
+ _navBarStore: ReturnType<typeof createStore>;
86
+ _stateStore: ReturnType<typeof createStateStore>;
87
+ navBar: NavBarState;
88
+ legacyFormatScreenData: LegacyNavigationScreenData | null;
89
+ };
90
+
68
91
  export const ScreenContext = createContext<ScreenContextType>({
92
+ _stateStore: createStateStore(),
69
93
  _navBarStore: createStore(),
70
94
  navBar: {
71
95
  visible: true,
@@ -103,6 +127,21 @@ export function ScreenContextProvider({
103
127
  null
104
128
  );
105
129
 
130
+ const screenStateRef = useRef<null | ReturnType<typeof createStateStore>>(
131
+ null
132
+ );
133
+
134
+ const getScreenState = useCallback(() => {
135
+ if (screenStateRef.current !== null) {
136
+ return screenStateRef.current;
137
+ }
138
+
139
+ const stateStore = createStateStore();
140
+ screenStateRef.current = stateStore;
141
+
142
+ return stateStore;
143
+ }, []);
144
+
106
145
  const getScreenNavBarState = useCallback(() => {
107
146
  if (screenNavBarStateRef.current !== null) {
108
147
  return screenNavBarStateRef.current;
@@ -163,6 +202,7 @@ export function ScreenContextProvider({
163
202
  value={useMemo(
164
203
  () => ({
165
204
  _navBarStore: getScreenNavBarState(),
205
+ _stateStore: getScreenState(),
166
206
  navBar: navBarState,
167
207
  legacyFormatScreenData: routeScreenData,
168
208
  }),
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import TestRenderer from "react-test-renderer";
2
+ import { render } from "@testing-library/react-native";
3
3
  import { useConfiguration } from "@applicaster/zapp-react-native-utils/reactHooks/configuration";
4
4
  import { View } from "react-native";
5
5
  import { withConfigurationProvider } from "@applicaster/zapp-react-native-ui-components/Decorators/ConfigurationWrapper";
@@ -15,12 +15,12 @@ describe("withConfigurationProvider", () => {
15
15
  it("correctly passes all the configuration keys child component", () => {
16
16
  const Component = withConfigurationProvider(TestComponent);
17
17
 
18
- const wrapper = TestRenderer.create(
18
+ const { toJSON } = render(
19
19
  <Component
20
20
  screenData={{ styles: {}, general: {}, data: { source: "test" } }}
21
21
  />
22
22
  );
23
23
 
24
- expect(wrapper.toJSON()).toMatchSnapshot();
24
+ expect(toJSON()).toMatchSnapshot();
25
25
  });
26
26
  });
@@ -21,13 +21,13 @@ const prepareConfiguration = (
21
21
  keys: [string]
22
22
  ) => R.compose(R.evolve(keysMap), R.pickAll(keys))(configuration);
23
23
 
24
+ const configurationKeys = R.keys(keysMap);
25
+
24
26
  export function withConfigurationProvider(Component: React.ComponentType<any>) {
25
27
  return function WithConfigurationProvider(props: Props) {
26
28
  const styles = props?.screenData?.styles;
27
29
  const general = props?.screenData?.general;
28
30
 
29
- const configurationKeys = React.useMemo(() => R.keys(keysMap), []);
30
-
31
31
  const configuration = React.useMemo(
32
32
  () => prepareConfiguration({ ...general, ...styles }, configurationKeys),
33
33
  []
@@ -1,214 +1,226 @@
1
1
  // Jest Snapshot v1, https://goo.gl/fbAQLP
2
2
 
3
3
  exports[`WithRiverFeedLoader renders correctly 1`] = `
4
- <View
5
- dispatch={[MockFunction]}
6
- river={
7
- {
8
- "id": "A1234",
9
- "ui_components": [
10
- {
11
- "data": {
12
- "source": "http://datasource0",
13
- },
14
- "rules": {
15
- "clear_cache_on_reload": false,
16
- },
17
- },
18
- {
19
- "data": {
20
- "source": "http://datasource1",
21
- },
22
- "rules": {
23
- "clear_cache_on_reload": false,
24
- },
25
- },
26
- {
27
- "data": {
28
- "source": "http://datasource2",
29
- },
30
- "rules": {
31
- "clear_cache_on_reload": false,
32
- },
33
- },
34
- {
35
- "data": {
36
- "source": "http://datasource3",
37
- },
38
- "rules": {
39
- "clear_cache_on_reload": false,
40
- },
41
- },
42
- {
43
- "data": {
44
- "source": "http://datasource4",
45
- },
46
- "rules": {
47
- "clear_cache_on_reload": false,
48
- },
49
- },
50
- {
51
- "data": {
52
- "source": "http://datasource5",
53
- },
54
- "rules": {
55
- "clear_cache_on_reload": false,
56
- },
57
- },
58
- {
59
- "data": {
60
- "source": "http://datasource6",
61
- },
62
- "rules": {
63
- "clear_cache_on_reload": false,
64
- },
65
- },
66
- {
67
- "data": {
68
- "source": "http://datasource7",
69
- },
70
- "rules": {
71
- "clear_cache_on_reload": false,
72
- },
73
- },
74
- {
75
- "data": {
76
- "source": "http://datasource8",
77
- },
78
- "rules": {
79
- "clear_cache_on_reload": false,
80
- },
81
- },
82
- {
83
- "data": {
84
- "source": "http://datasource9",
85
- },
86
- "rules": {
87
- "clear_cache_on_reload": false,
88
- },
89
- },
90
- {
91
- "data": {
92
- "source": "http://datasource10",
93
- },
94
- "rules": {
95
- "clear_cache_on_reload": false,
96
- },
97
- },
98
- {
99
- "data": {
100
- "source": "http://datasource11",
101
- },
102
- "rules": {
103
- "clear_cache_on_reload": false,
104
- },
105
- },
106
- {
107
- "data": {
108
- "source": "http://datasource12",
109
- },
110
- "rules": {
111
- "clear_cache_on_reload": true,
112
- },
113
- },
114
- {
115
- "data": {
116
- "source": "http://datasource13",
117
- },
118
- "rules": {
119
- "clear_cache_on_reload": false,
120
- },
121
- },
122
- {
123
- "data": {
124
- "source": "http://datasource14",
125
- },
126
- "rules": {
127
- "clear_cache_on_reload": false,
128
- },
129
- },
130
- {
131
- "data": {
132
- "source": "http://datasource15",
133
- },
134
- "rules": {
135
- "clear_cache_on_reload": false,
136
- },
137
- },
138
- {
139
- "data": {
140
- "source": "http://datasource16",
141
- },
142
- "rules": {
143
- "clear_cache_on_reload": false,
144
- },
145
- },
146
- {
147
- "data": {
148
- "source": "http://datasource17",
149
- },
150
- "rules": {
151
- "clear_cache_on_reload": false,
152
- },
153
- },
154
- {
155
- "data": {
156
- "source": "http://datasource18",
157
- },
158
- "rules": {
159
- "clear_cache_on_reload": false,
160
- },
161
- },
162
- {
163
- "data": {
164
- "source": "http://datasource19",
165
- },
166
- "rules": {
167
- "clear_cache_on_reload": false,
168
- },
169
- },
170
- {
171
- "data": {
172
- "source": "http://datasource20",
173
- },
174
- "rules": {
175
- "clear_cache_on_reload": true,
176
- },
177
- },
178
- {
179
- "data": {
180
- "source": "http://datasource21",
181
- },
182
- "rules": {
183
- "clear_cache_on_reload": false,
184
- },
185
- },
186
- {
187
- "data": {
188
- "source": "http://datasource22",
189
- },
190
- "rules": {
191
- "clear_cache_on_reload": false,
192
- },
193
- },
194
- {
195
- "data": {
196
- "source": "http://datasource23",
197
- },
198
- "rules": {
199
- "clear_cache_on_reload": false,
200
- },
201
- },
202
- {
203
- "data": {
204
- "source": "http://datasource24",
205
- },
206
- "rules": {
207
- "clear_cache_on_reload": false,
208
- },
209
- },
210
- ],
211
- }
4
+ <RNCSafeAreaProvider
5
+ onInsetsChange={[Function]}
6
+ style={
7
+ [
8
+ {
9
+ "flex": 1,
10
+ },
11
+ undefined,
12
+ ]
212
13
  }
213
- />
14
+ >
15
+ <View
16
+ dispatch={[MockFunction]}
17
+ river={
18
+ {
19
+ "id": "A1234",
20
+ "ui_components": [
21
+ {
22
+ "data": {
23
+ "source": "http://datasource0",
24
+ },
25
+ "rules": {
26
+ "clear_cache_on_reload": false,
27
+ },
28
+ },
29
+ {
30
+ "data": {
31
+ "source": "http://datasource1",
32
+ },
33
+ "rules": {
34
+ "clear_cache_on_reload": false,
35
+ },
36
+ },
37
+ {
38
+ "data": {
39
+ "source": "http://datasource2",
40
+ },
41
+ "rules": {
42
+ "clear_cache_on_reload": false,
43
+ },
44
+ },
45
+ {
46
+ "data": {
47
+ "source": "http://datasource3",
48
+ },
49
+ "rules": {
50
+ "clear_cache_on_reload": false,
51
+ },
52
+ },
53
+ {
54
+ "data": {
55
+ "source": "http://datasource4",
56
+ },
57
+ "rules": {
58
+ "clear_cache_on_reload": false,
59
+ },
60
+ },
61
+ {
62
+ "data": {
63
+ "source": "http://datasource5",
64
+ },
65
+ "rules": {
66
+ "clear_cache_on_reload": false,
67
+ },
68
+ },
69
+ {
70
+ "data": {
71
+ "source": "http://datasource6",
72
+ },
73
+ "rules": {
74
+ "clear_cache_on_reload": false,
75
+ },
76
+ },
77
+ {
78
+ "data": {
79
+ "source": "http://datasource7",
80
+ },
81
+ "rules": {
82
+ "clear_cache_on_reload": false,
83
+ },
84
+ },
85
+ {
86
+ "data": {
87
+ "source": "http://datasource8",
88
+ },
89
+ "rules": {
90
+ "clear_cache_on_reload": false,
91
+ },
92
+ },
93
+ {
94
+ "data": {
95
+ "source": "http://datasource9",
96
+ },
97
+ "rules": {
98
+ "clear_cache_on_reload": false,
99
+ },
100
+ },
101
+ {
102
+ "data": {
103
+ "source": "http://datasource10",
104
+ },
105
+ "rules": {
106
+ "clear_cache_on_reload": false,
107
+ },
108
+ },
109
+ {
110
+ "data": {
111
+ "source": "http://datasource11",
112
+ },
113
+ "rules": {
114
+ "clear_cache_on_reload": false,
115
+ },
116
+ },
117
+ {
118
+ "data": {
119
+ "source": "http://datasource12",
120
+ },
121
+ "rules": {
122
+ "clear_cache_on_reload": true,
123
+ },
124
+ },
125
+ {
126
+ "data": {
127
+ "source": "http://datasource13",
128
+ },
129
+ "rules": {
130
+ "clear_cache_on_reload": false,
131
+ },
132
+ },
133
+ {
134
+ "data": {
135
+ "source": "http://datasource14",
136
+ },
137
+ "rules": {
138
+ "clear_cache_on_reload": false,
139
+ },
140
+ },
141
+ {
142
+ "data": {
143
+ "source": "http://datasource15",
144
+ },
145
+ "rules": {
146
+ "clear_cache_on_reload": false,
147
+ },
148
+ },
149
+ {
150
+ "data": {
151
+ "source": "http://datasource16",
152
+ },
153
+ "rules": {
154
+ "clear_cache_on_reload": false,
155
+ },
156
+ },
157
+ {
158
+ "data": {
159
+ "source": "http://datasource17",
160
+ },
161
+ "rules": {
162
+ "clear_cache_on_reload": false,
163
+ },
164
+ },
165
+ {
166
+ "data": {
167
+ "source": "http://datasource18",
168
+ },
169
+ "rules": {
170
+ "clear_cache_on_reload": false,
171
+ },
172
+ },
173
+ {
174
+ "data": {
175
+ "source": "http://datasource19",
176
+ },
177
+ "rules": {
178
+ "clear_cache_on_reload": false,
179
+ },
180
+ },
181
+ {
182
+ "data": {
183
+ "source": "http://datasource20",
184
+ },
185
+ "rules": {
186
+ "clear_cache_on_reload": true,
187
+ },
188
+ },
189
+ {
190
+ "data": {
191
+ "source": "http://datasource21",
192
+ },
193
+ "rules": {
194
+ "clear_cache_on_reload": false,
195
+ },
196
+ },
197
+ {
198
+ "data": {
199
+ "source": "http://datasource22",
200
+ },
201
+ "rules": {
202
+ "clear_cache_on_reload": false,
203
+ },
204
+ },
205
+ {
206
+ "data": {
207
+ "source": "http://datasource23",
208
+ },
209
+ "rules": {
210
+ "clear_cache_on_reload": false,
211
+ },
212
+ },
213
+ {
214
+ "data": {
215
+ "source": "http://datasource24",
216
+ },
217
+ "rules": {
218
+ "clear_cache_on_reload": false,
219
+ },
220
+ },
221
+ ],
222
+ }
223
+ }
224
+ />
225
+ </RNCSafeAreaProvider>
214
226
  `;
@@ -1,9 +1,8 @@
1
1
  import React from "react";
2
- import * as R from "ramda";
3
2
  import { View } from "react-native";
4
- import { render } from "@testing-library/react-native";
5
3
 
6
4
  import * as mock_fixtures from "./fixtures";
5
+ import { renderWithProviders } from "@applicaster/zapp-react-native-utils/testUtils";
7
6
 
8
7
  const mockUsePipesContexts = () => ({
9
8
  entry: mock_fixtures.entryContext,
@@ -11,8 +10,13 @@ const mockUsePipesContexts = () => ({
11
10
  search: mock_fixtures.searchContext,
12
11
  });
13
12
 
14
- const mockGetDatasourceUrl = jest.fn(
15
- R.curry((_, component) => component.data.source)
13
+ const mockDispatchLoadPipesData = jest.fn();
14
+
15
+ jest.mock(
16
+ "@applicaster/zapp-react-native-utils/reactHooks/feed/useLoadPipesDataDispatch",
17
+ () => ({
18
+ useLoadPipesDataDispatch: jest.fn(() => mockDispatchLoadPipesData),
19
+ })
16
20
  );
17
21
 
18
22
  jest.mock(
@@ -31,8 +35,6 @@ jest.mock(
31
35
 
32
36
  jest.mock("../utils", () => ({
33
37
  ...jest.requireActual("../utils"),
34
- loadDatasources: jest.fn(),
35
- getDatasourceUrl: mockGetDatasourceUrl,
36
38
  usePipesContexts: mockUsePipesContexts,
37
39
  }));
38
40
 
@@ -45,27 +47,23 @@ const riverProps = {
45
47
  dispatch: jest.fn(),
46
48
  };
47
49
 
48
- const { loadDatasources, getDatasourceUrl } = require("../utils");
49
-
50
50
  const { WithRiverFeedLoader } = require("..");
51
51
 
52
52
  describe("WithRiverFeedLoader", () => {
53
53
  const DecoratedRiver = WithRiverFeedLoader(River);
54
- const wrapper = render(<DecoratedRiver {...riverProps} />);
54
+ const wrapper = renderWithProviders(<DecoratedRiver {...riverProps} />);
55
55
 
56
56
  it("renders correctly", () => {
57
57
  expect(wrapper.toJSON()).toMatchSnapshot();
58
58
  });
59
59
 
60
60
  it("collects the datasources in the screen and loads them", () => {
61
- expect(getDatasourceUrl).toHaveBeenCalledTimes(1);
62
- expect(loadDatasources).toHaveBeenCalledTimes(1);
61
+ expect(mockDispatchLoadPipesData).toHaveBeenCalledTimes(23);
63
62
 
64
- expect(loadDatasources).toHaveBeenNthCalledWith(
65
- 1,
66
- mock_fixtures.riverDataSources,
67
- mock_fixtures.river.id,
68
- riverProps.dispatch
63
+ expect(mockDispatchLoadPipesData).toHaveBeenLastCalledWith(
64
+ "http://datasource24",
65
+ {},
66
+ { withResolvers: true, withScreenRouteMapping: true }
69
67
  );
70
68
  });
71
69
  });
@@ -14,31 +14,11 @@ jest.mock("@applicaster/zapp-react-native-redux/ZappPipes", () => ({
14
14
  }));
15
15
 
16
16
  const {
17
- loadDatasources,
18
17
  riverIsCurrentRoute,
19
18
  getDatasourceUrl,
20
19
  ignoreComponentsWithClearCacheFlag,
21
20
  } = require("../utils");
22
21
 
23
- const {
24
- loadPipesData,
25
- } = require("@applicaster/zapp-react-native-redux/ZappPipes");
26
-
27
- const dispatch = (value) => Promise.resolve(value);
28
-
29
- describe("loadDataSource", () => {
30
- it("calls loadPipesData for each provided urls", async () => {
31
- const urls = [
32
- ["http://datasource1", "http://datasource2"],
33
- ["http://datasource3", "http://datasource4"],
34
- ];
35
-
36
- await loadDatasources(urls, river.id, dispatch);
37
-
38
- expect(loadPipesData).toHaveBeenCalledTimes(R.flatten(urls).length);
39
- });
40
- });
41
-
42
22
  describe("riverIsCurrentRoute", () => {
43
23
  const route = "/river/homeId/river/screenId";
44
24
  const riverId = "screenId";