@applicaster/zapp-react-native-ui-components 15.0.0-rc.99 → 16.0.0-rc.1

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 (138) hide show
  1. package/Components/Cell/TvOSCellComponent.tsx +1 -3
  2. package/Components/GeneralContentScreen/GeneralContentScreen.tsx +39 -28
  3. package/Components/GeneralContentScreen/__tests__/GeneralContentScreen.test.tsx +104 -0
  4. package/Components/GeneralContentScreen/utils/__tests__/getScreenDataSource.test.ts +19 -0
  5. package/Components/GeneralContentScreen/utils/getScreenDataSource.ts +9 -0
  6. package/Components/HandlePlayable/HandlePlayable.tsx +16 -29
  7. package/Components/HandlePlayable/utils.ts +31 -0
  8. package/Components/HookRenderer/HookRenderer.tsx +40 -10
  9. package/Components/HookRenderer/__tests__/HookRenderer.test.tsx +60 -0
  10. package/Components/Layout/TV/NavBarContainer.tsx +1 -10
  11. package/Components/Layout/TV/__tests__/__snapshots__/NavBarContainer.test.tsx.snap +7 -12
  12. package/Components/Layout/TV/__tests__/__snapshots__/ScreenContainer.test.tsx.snap +7 -12
  13. package/Components/Layout/TV/__tests__/__snapshots__/index.test.tsx.snap +5 -0
  14. package/Components/MasterCell/CONFIG_BUILDER_TO_REACT_COMPONENT.md +144 -0
  15. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/__tests__/model.test.ts +80 -0
  16. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/__tests__/placement.test.ts +187 -0
  17. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/__tests__/selectors.test.ts +45 -0
  18. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/__tests__/style.test.ts +49 -0
  19. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/components/ActionButtonController.tsx +165 -0
  20. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/components/__tests__/ActionButtonController.test.tsx +405 -0
  21. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/components/index.ts +1 -0
  22. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/model.ts +47 -0
  23. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/placement.ts +170 -0
  24. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/selectors.ts +26 -0
  25. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/style.ts +29 -0
  26. package/Components/MasterCell/DefaultComponents/ActionButtonsCore/types.ts +37 -0
  27. package/Components/MasterCell/DefaultComponents/Button.tsx +0 -15
  28. package/Components/MasterCell/DefaultComponents/ButtonContainerView/components/HorizontalSeparator.tsx +8 -0
  29. package/Components/MasterCell/DefaultComponents/ButtonContainerView/index.tsx +15 -0
  30. package/Components/MasterCell/DefaultComponents/ButtonContainerView/index.tv.android.tsx +58 -0
  31. package/Components/MasterCell/DefaultComponents/{tv/ButtonContainerView/index.tsx → ButtonContainerView/index.tv.tsx} +3 -11
  32. package/Components/MasterCell/DefaultComponents/ButtonContainerView/index.web.ts +1 -0
  33. package/Components/MasterCell/DefaultComponents/ButtonContainerView/types.ts +40 -0
  34. package/Components/MasterCell/DefaultComponents/DataProvider/index.tsx +163 -0
  35. package/Components/MasterCell/DefaultComponents/FocusableView/index.android.tsx +2 -23
  36. package/Components/MasterCell/DefaultComponents/FocusableView/index.tsx +4 -22
  37. package/Components/MasterCell/DefaultComponents/Image/Image.android.tsx +3 -1
  38. package/Components/MasterCell/DefaultComponents/LiveImage/__tests__/prepareEntry.test.ts +352 -0
  39. package/Components/MasterCell/DefaultComponents/LiveImage/executePreloadHooks.ts +136 -0
  40. package/Components/MasterCell/DefaultComponents/LiveImage/index.tsx +33 -16
  41. package/Components/MasterCell/DefaultComponents/PressableView.tsx +34 -0
  42. package/Components/MasterCell/DefaultComponents/Text/hooks/useText.ts +11 -0
  43. package/Components/MasterCell/DefaultComponents/Text/index.tsx +2 -6
  44. package/Components/MasterCell/DefaultComponents/__tests__/DataProvider.test.tsx +141 -0
  45. package/Components/MasterCell/DefaultComponents/index.ts +9 -3
  46. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/ActionButton.tsx +135 -0
  47. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/Asset.ts +33 -0
  48. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/AssetComponent.tsx +22 -0
  49. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/Button.ts +125 -0
  50. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/Spacer.ts +16 -0
  51. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/TextLabel.ts +67 -0
  52. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/TextLabelsContainer.ts +37 -0
  53. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/__tests__/PressableView.test.tsx +393 -0
  54. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/__tests__/builders.test.ts +141 -0
  55. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/__tests__/index.test.ts +343 -0
  56. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/helpers.ts +105 -0
  57. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/index.ts +122 -0
  58. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/utils/__tests__/insertButtons.test.ts +118 -0
  59. package/Components/MasterCell/DefaultComponents/mobile/MobileActionButtons/utils/index.ts +238 -0
  60. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/Asset.ts +4 -18
  61. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/Button.ts +24 -73
  62. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/TextLabelsContainer.ts +37 -18
  63. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/TvActionButton.tsx +27 -0
  64. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/__tests__/index.test.ts +89 -0
  65. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/__tests__/renderedTree.test.tsx +231 -0
  66. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/index.ts +47 -52
  67. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/utils/__tests__/getPluginIdentifier.test.ts +35 -171
  68. package/Components/MasterCell/DefaultComponents/tv/TvActionButtons/utils/index.ts +98 -145
  69. package/Components/MasterCell/MappingFunctions/index.js +3 -2
  70. package/Components/MasterCell/README.md +4 -0
  71. package/Components/MasterCell/__tests__/__snapshots__/dataAdapter.test.js.snap +24 -0
  72. package/Components/MasterCell/__tests__/configInflater.test.js +1 -0
  73. package/Components/MasterCell/__tests__/elementMapper.test.js +46 -0
  74. package/Components/MasterCell/dataAdapter.ts +4 -1
  75. package/Components/MasterCell/elementMapper.tsx +52 -7
  76. package/Components/MasterCell/utils/__tests__/cloneChildrenWithIds.test.tsx +43 -0
  77. package/Components/MasterCell/utils/__tests__/useFilterChildren.test.tsx +80 -0
  78. package/Components/MasterCell/utils/index.ts +85 -15
  79. package/Components/Navigator/StackNavigator.tsx +6 -0
  80. package/Components/PlayerContainer/PlayerContainer.tsx +2 -19
  81. package/Components/PreloaderWrapper/__tests__/index.test.tsx +26 -0
  82. package/Components/PreloaderWrapper/index.tsx +15 -0
  83. package/Components/River/ComponentsMap/ComponentsMap.tsx +2 -16
  84. package/Components/River/RefreshControl.tsx +19 -82
  85. package/Components/River/River.tsx +9 -82
  86. package/Components/River/RiverItem.tsx +26 -20
  87. package/Components/River/hooks/__tests__/usePullToRefresh.test.ts +132 -0
  88. package/Components/River/hooks/index.ts +1 -0
  89. package/Components/River/hooks/usePullToRefresh.ts +51 -0
  90. package/Components/Screen/__tests__/Screen.test.tsx +1 -0
  91. package/Components/Screen/hooks.ts +73 -3
  92. package/Components/Screen/index.tsx +7 -1
  93. package/Components/ScreenFeedLoader/ScreenFeedLoader.tsx +46 -0
  94. package/Components/ScreenFeedLoader/__tests__/ScreenFeedLoader.test.tsx +94 -0
  95. package/Components/ScreenFeedLoader/index.ts +1 -0
  96. package/Components/ScreenResolver/__tests__/screenResolver.test.js +24 -0
  97. package/Components/ScreenResolver/hooks/index.ts +3 -0
  98. package/Components/ScreenResolver/hooks/useGetComponent.ts +15 -0
  99. package/Components/ScreenResolver/hooks/useScreenComponentResolver.tsx +90 -0
  100. package/Components/ScreenResolver/index.tsx +15 -117
  101. package/Components/ScreenResolver/utils/__tests__/getScreenTypeProps.test.ts +45 -0
  102. package/Components/ScreenResolver/utils/getScreenTypeProps.ts +43 -0
  103. package/Components/ScreenResolver/utils/index.ts +1 -0
  104. package/Components/ScreenResolver/withDefaultScreenContext.tsx +16 -0
  105. package/Components/ScreenResolverFeedProvider/ScreenResolverFeedProvider.tsx +25 -0
  106. package/Components/ScreenResolverFeedProvider/__tests__/ScreenResolverFeedProvider.test.tsx +44 -0
  107. package/Components/ScreenResolverFeedProvider/index.ts +1 -0
  108. package/Components/ScreenRevealManager/withScreenRevealManager.tsx +4 -1
  109. package/Components/TopCutoffOverlay/__tests__/TopCutoffOverlay.test.tsx +201 -0
  110. package/Components/TopCutoffOverlay/hooks/__tests__/useMarginTop.test.ts +130 -0
  111. package/Components/TopCutoffOverlay/hooks/index.ts +1 -0
  112. package/Components/TopCutoffOverlay/hooks/useMarginTop.ts +59 -0
  113. package/Components/TopCutoffOverlay/index.tsx +55 -0
  114. package/Components/Transitioner/Scene.tsx +9 -15
  115. package/Components/VideoLive/LiveImageManager.ts +199 -54
  116. package/Components/VideoLive/PlayerLiveImageComponent.tsx +31 -33
  117. package/Components/VideoLive/__tests__/PlayerLiveImageComponent.test.tsx +2 -17
  118. package/Components/Viewport/ViewportAware/__tests__/viewportAware.test.js +0 -2
  119. package/Components/Viewport/ViewportAware/index.tsx +16 -7
  120. package/Components/ZappUIComponent/index.tsx +12 -6
  121. package/Components/default-cell-renderer/viewTrees/mobile/index.ts +0 -3
  122. package/Components/index.js +1 -1
  123. package/Contexts/ScreenContext/__tests__/index.test.tsx +57 -0
  124. package/Contexts/ScreenContext/index.tsx +46 -1
  125. package/Contexts/ZappPipesContext/ZappPipesContextFactory.tsx +18 -7
  126. package/Decorators/ZappPipesDataConnector/ResolverSelector.tsx +25 -7
  127. package/Decorators/ZappPipesDataConnector/__tests__/ResolverSelector.test.tsx +212 -5
  128. package/Decorators/ZappPipesDataConnector/__tests__/UrlFeedResolver.test.tsx +39 -21
  129. package/Decorators/ZappPipesDataConnector/resolvers/UrlFeedResolver.tsx +18 -7
  130. package/package.json +5 -5
  131. package/Components/MasterCell/DefaultComponents/Text/utils/__tests__/withAdjustedLineHeight.test.ts +0 -46
  132. package/Components/MasterCell/DefaultComponents/Text/utils/index.ts +0 -21
  133. package/Components/MasterCell/DefaultComponents/tv/ButtonContainerView/index.android.tsx +0 -135
  134. package/Components/MasterCell/DefaultComponents/tv/ButtonContainerView/types.ts +0 -25
  135. package/Components/PlayerContainer/ErrorDisplay/ErrorDisplay.tsx +0 -57
  136. package/Components/PlayerContainer/ErrorDisplay/index.ts +0 -9
  137. package/Components/PlayerContainer/useRestrictMobilePlayback.tsx +0 -101
  138. /package/Components/HookRenderer/{index.tsx → index.ts} +0 -0
@@ -1,6 +1,5 @@
1
1
  import React from "react";
2
2
  import * as useFeedLoaderModule from "@applicaster/zapp-react-native-utils/reactHooks/feed/useFeedLoader";
3
- import * as useFeedRefreshModule from "@applicaster/zapp-react-native-utils/reactHooks/feed/useFeedRefresh";
4
3
  import { favoritesListener } from "@applicaster/zapp-react-native-bridge/Favorites";
5
4
  import { UrlFeedResolver } from "../resolvers/UrlFeedResolver";
6
5
  import { renderWithProviders } from "@applicaster/zapp-react-native-utils/testUtils";
@@ -14,10 +13,6 @@ jest
14
13
 
15
14
  jest.mock("@applicaster/zapp-react-native-utils/reactHooks/feed/useFeedLoader");
16
15
 
17
- jest.mock(
18
- "@applicaster/zapp-react-native-utils/reactHooks/feed/useFeedRefresh"
19
- );
20
-
21
16
  jest.mock("@applicaster/zapp-pipes-v2-client");
22
17
 
23
18
  jest.mock("@applicaster/zapp-react-native-bridge/Favorites", () => ({
@@ -62,6 +57,9 @@ describe("UrlFeedResolver", () => {
62
57
  component: { ...componentRequiredKeys } as any,
63
58
  children: mockChildren,
64
59
  riverId: "test-river",
60
+ screenContext: {
61
+ id: "screenId",
62
+ },
65
63
  };
66
64
 
67
65
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -82,6 +80,9 @@ describe("UrlFeedResolver", () => {
82
80
  } as any,
83
81
  children: mockChildren,
84
82
  riverId: "test-river",
83
+ screenContext: {
84
+ id: "screenId",
85
+ },
85
86
  };
86
87
 
87
88
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -103,6 +104,9 @@ describe("UrlFeedResolver", () => {
103
104
  } as any,
104
105
  children: mockChildren,
105
106
  riverId: "test-river",
107
+ screenContext: {
108
+ id: "screenId",
109
+ },
106
110
  };
107
111
 
108
112
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -132,6 +136,9 @@ describe("UrlFeedResolver", () => {
132
136
  } as any,
133
137
  children: mockChildren,
134
138
  riverId: "test-river",
139
+ screenContext: {
140
+ id: "screenId",
141
+ },
135
142
  };
136
143
 
137
144
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -155,6 +162,9 @@ describe("UrlFeedResolver", () => {
155
162
  children: mockChildren,
156
163
  riverId: "test-river",
157
164
  plugins: [],
165
+ screenContext: {
166
+ id: "screenId",
167
+ },
158
168
  };
159
169
 
160
170
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -173,6 +183,9 @@ describe("UrlFeedResolver", () => {
173
183
  component: { ...componentRequiredKeys } as any,
174
184
  children: mockChildren,
175
185
  riverId: "test-river",
186
+ screenContext: {
187
+ id: "screenId",
188
+ },
176
189
  };
177
190
 
178
191
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -197,6 +210,9 @@ describe("UrlFeedResolver", () => {
197
210
  },
198
211
  },
199
212
  ] as any,
213
+ screenContext: {
214
+ id: "screenId",
215
+ },
200
216
  };
201
217
 
202
218
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -215,6 +231,9 @@ describe("UrlFeedResolver", () => {
215
231
  } as any,
216
232
  children: mockChildren,
217
233
  riverId: "test-river",
234
+ screenContext: {
235
+ id: "screenId",
236
+ },
218
237
  };
219
238
 
220
239
  (useFeedLoaderModule.useFeedLoader as jest.Mock).mockReturnValue({
@@ -250,6 +269,9 @@ describe("UrlFeedResolver", () => {
250
269
  children: mockChildren,
251
270
  riverId: "test-river",
252
271
  isLast: true,
272
+ screenContext: {
273
+ id: "screenId",
274
+ },
253
275
  };
254
276
 
255
277
  renderWithProviders(<UrlFeedResolver {...props1} />);
@@ -272,6 +294,9 @@ describe("UrlFeedResolver", () => {
272
294
  children: mockChildren,
273
295
  riverId: "test-river",
274
296
  isLast: false,
297
+ screenContext: {
298
+ id: "screenId",
299
+ },
275
300
  };
276
301
 
277
302
  renderWithProviders(<UrlFeedResolver {...props2} />);
@@ -294,6 +319,9 @@ describe("UrlFeedResolver", () => {
294
319
  children: mockChildren,
295
320
  riverId: "test-river",
296
321
  isLast: false,
322
+ screenContext: {
323
+ id: "screenId",
324
+ },
297
325
  };
298
326
 
299
327
  renderWithProviders(<UrlFeedResolver {...props3} />);
@@ -311,6 +339,9 @@ describe("UrlFeedResolver", () => {
311
339
  component: { ...componentRequiredKeys } as any,
312
340
  children: mockChildren,
313
341
  riverId: "test-river",
342
+ screenContext: {
343
+ id: "screenId",
344
+ },
314
345
  };
315
346
 
316
347
  renderWithProviders(<UrlFeedResolver {...props} />);
@@ -327,22 +358,6 @@ describe("UrlFeedResolver", () => {
327
358
  });
328
359
  });
329
360
 
330
- it("should apply feed refresh hook", () => {
331
- const props = {
332
- feedUrl: "https://example.com/feed",
333
- component: { ...componentRequiredKeys } as any,
334
- children: mockChildren,
335
- riverId: "test-river",
336
- };
337
-
338
- renderWithProviders(<UrlFeedResolver {...props} />);
339
-
340
- expect(useFeedRefreshModule.useFeedRefresh).toHaveBeenCalledWith({
341
- reloadData: mockReloadData,
342
- component: props.component,
343
- });
344
- });
345
-
346
361
  it("should clean up listeners on unmount", () => {
347
362
  const props = {
348
363
  component: {
@@ -354,6 +369,9 @@ describe("UrlFeedResolver", () => {
354
369
  } as any,
355
370
  children: mockChildren,
356
371
  riverId: "test-river",
372
+ screenContext: {
373
+ id: "screenId",
374
+ },
357
375
  };
358
376
 
359
377
  const { unmount } = renderWithProviders(<UrlFeedResolver {...props} />);
@@ -9,9 +9,9 @@ import {
9
9
  getInflatedDataSourceUrl,
10
10
  getSearchContext,
11
11
  useFeedLoader,
12
- useFeedRefresh,
13
12
  useRoute,
14
13
  } from "@applicaster/zapp-react-native-utils/reactHooks";
14
+ import { refreshCoordinator } from "@applicaster/zapp-react-native-utils/refreshUtils/RefreshCoordinator";
15
15
 
16
16
  import { ComponentDataSourceContext, ZappPipesDataProps } from "../types";
17
17
  import { useScreenStateStore } from "@applicaster/zapp-react-native-utils/reactHooks/navigation/useScreenStateStore";
@@ -199,6 +199,8 @@ export function UrlFeedResolver({
199
199
  const { pathname } = useRoute();
200
200
  const screenStateStore = useScreenStateStore();
201
201
 
202
+ const screenId = (screenContext?.id || "unknown_screen_id") as string;
203
+
202
204
  // Setup listeners for data source URL
203
205
  useEffect(() => {
204
206
  if (!reloadData) {
@@ -214,10 +216,19 @@ export function UrlFeedResolver({
214
216
  url: dataSourceUrl,
215
217
  pathname,
216
218
  screenStateStore,
219
+ component,
220
+ screenId,
217
221
  callback: reloadData,
218
222
  });
219
223
  }
220
- }, [dataSourceUrl, reloadData, pathname, screenStateStore]);
224
+ }, [
225
+ dataSourceUrl,
226
+ reloadData,
227
+ pathname,
228
+ screenStateStore,
229
+ component,
230
+ screenId,
231
+ ]);
221
232
 
222
233
  // Setup favorites listener
223
234
  useEffect(() => {
@@ -230,11 +241,11 @@ export function UrlFeedResolver({
230
241
  }
231
242
  }, [type, reloadData]);
232
243
 
233
- // Apply feed refresh hook
234
- useFeedRefresh({
235
- reloadData,
236
- component,
237
- });
244
+ useEffect(() => {
245
+ const unregister = refreshCoordinator.register(component, screenId);
246
+
247
+ return () => unregister();
248
+ }, [component, screenId]);
238
249
 
239
250
  const loadNextData = useMemo(
240
251
  () => (!isLast && isVerticalListOrGrid(component) ? undefined : loadNext),
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@applicaster/zapp-react-native-ui-components",
3
- "version": "15.0.0-rc.99",
3
+ "version": "16.0.0-rc.1",
4
4
  "description": "Applicaster Zapp React Native ui components for the Quick Brick App",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",
@@ -28,10 +28,10 @@
28
28
  },
29
29
  "homepage": "https://github.com/applicaster/quickbrick#readme",
30
30
  "dependencies": {
31
- "@applicaster/applicaster-types": "15.0.0-rc.99",
32
- "@applicaster/zapp-react-native-bridge": "15.0.0-rc.99",
33
- "@applicaster/zapp-react-native-redux": "15.0.0-rc.99",
34
- "@applicaster/zapp-react-native-utils": "15.0.0-rc.99",
31
+ "@applicaster/applicaster-types": "16.0.0-rc.1",
32
+ "@applicaster/zapp-react-native-bridge": "16.0.0-rc.1",
33
+ "@applicaster/zapp-react-native-redux": "16.0.0-rc.1",
34
+ "@applicaster/zapp-react-native-utils": "16.0.0-rc.1",
35
35
  "fast-json-stable-stringify": "^2.1.0",
36
36
  "promise": "^8.3.0",
37
37
  "url": "^0.11.0",
@@ -1,46 +0,0 @@
1
- import { PixelRatio } from "react-native";
2
- import { withAdjustedLineHeight } from "..";
3
-
4
- const FONT_SCALE = 1.118;
5
- jest.spyOn(PixelRatio, "getFontScale").mockReturnValue(FONT_SCALE);
6
-
7
- describe("withAdjustedLineHeight", () => {
8
- it("with provided fontScale and styles", () => {
9
- // setup
10
- const styles = {
11
- lineHeight: 10,
12
- };
13
-
14
- // run
15
- const result = withAdjustedLineHeight(styles);
16
-
17
- // verify
18
- expect(result).toEqual({
19
- lineHeight: styles.lineHeight * FONT_SCALE,
20
- });
21
- });
22
-
23
- it("with provided fontScale and empty styles", () => {
24
- // setup
25
- const styles = {};
26
-
27
- // run
28
- const result = withAdjustedLineHeight(styles);
29
-
30
- // verify
31
- expect(result).toEqual(styles);
32
- });
33
-
34
- it("with non-number lineHeight", () => {
35
- // setup
36
- const styles = {
37
- lineHeight: NaN,
38
- };
39
-
40
- // run
41
- const result = withAdjustedLineHeight(styles);
42
-
43
- // verify
44
- expect(result).toEqual(styles);
45
- });
46
- });
@@ -1,21 +0,0 @@
1
- import { PixelRatio } from "react-native";
2
- import { isNil, identity } from "ramda";
3
- import { toNumber } from "@applicaster/zapp-react-native-utils/numberUtils";
4
- import { platformSelect } from "@applicaster/zapp-react-native-utils/reactUtils";
5
-
6
- // HACK - to prevent text flickering
7
- export const withAdjustedLineHeight = (styles) => {
8
- const fontScale = PixelRatio.getFontScale();
9
- const lineHeight = toNumber(styles.lineHeight);
10
-
11
- if (isNil(lineHeight)) {
12
- return styles;
13
- }
14
-
15
- return { ...styles, lineHeight: lineHeight * fontScale };
16
- };
17
-
18
- export const withScaledLineHeight = platformSelect({
19
- ios: withAdjustedLineHeight,
20
- default: identity,
21
- });
@@ -1,135 +0,0 @@
1
- import React from "react";
2
- import { View, ButtonProps } from "react-native";
3
- import { Focusable } from "@applicaster/zapp-react-native-ui-components/Components/Focusable";
4
- import { useActions } from "@applicaster/zapp-react-native-utils/reactHooks/actions";
5
- import * as R from "ramda";
6
- import { useInitialFocus } from "@applicaster/zapp-react-native-utils/focusManager";
7
- import { getXray } from "@applicaster/zapp-react-native-utils/logger";
8
- import { useFocusable } from "@applicaster/zapp-react-native-ui-components/Components/Focusable/index.android";
9
- import {
10
- useIsRTL,
11
- applyRTLStylesIfNeeded,
12
- } from "@applicaster/zapp-react-native-utils/localizationUtils";
13
-
14
- const { Logger } = getXray();
15
-
16
- import {
17
- cloneElementsWithIds,
18
- insertBetween,
19
- recursiveCloneElementsWithState,
20
- useFilterChildren,
21
- } from "../../../utils";
22
-
23
- import type {
24
- HorizontalSeparatorProps,
25
- ContainerProps,
26
- ContainerChildren,
27
- } from "./types";
28
-
29
- const logger = new Logger("plugin", "plugins/navigation-action");
30
-
31
- const generateId = (cellUUID, suffixId) => `${cellUUID}--${suffixId}`;
32
-
33
- const HorizontalSeparator = ({ width }: HorizontalSeparatorProps) => (
34
- <View style={{ width }} />
35
- );
36
-
37
- export function ButtonContainerView({
38
- style,
39
- children,
40
- ...otherProps
41
- }: ContainerProps) {
42
- const isRTL = useIsRTL();
43
-
44
- const horizontalGutter = R.pathOr(0, ["horizontalGutter"], otherProps);
45
-
46
- const filteredChildren = useFilterChildren<ContainerChildren>(children);
47
-
48
- const buttonIds = filteredChildren.map((child) => {
49
- const { cellUUID, suffixId } = child.props;
50
-
51
- return generateId(cellUUID, suffixId);
52
- });
53
-
54
- useInitialFocus(otherProps.state === "focused", R.head(buttonIds));
55
-
56
- if (R.isEmpty(filteredChildren)) {
57
- return null;
58
- }
59
-
60
- return (
61
- <View style={applyRTLStylesIfNeeded(style, isRTL)}>
62
- {insertBetween(
63
- (index) => (
64
- <HorizontalSeparator
65
- key={`separator_${index}`}
66
- width={horizontalGutter}
67
- />
68
- ),
69
- cloneElementsWithIds(buttonIds, filteredChildren)
70
- )}
71
- </View>
72
- );
73
- }
74
-
75
- export function FocusableViewComponent(
76
- { style, children, item, ...otherProps }: ButtonProps,
77
- ref
78
- ) {
79
- const {
80
- cellUUID,
81
- groupId,
82
- suffixId,
83
- normalStyles,
84
- focusedStyles,
85
- nextFocusLeft,
86
- nextFocusRight,
87
- pluginIdentifier,
88
- disableFocus,
89
- } = otherProps;
90
-
91
- const parentFocus = useFocusable();
92
-
93
- const actionContext = useActions(pluginIdentifier);
94
-
95
- const onPress = () => {
96
- if (!actionContext) {
97
- logger.warning(
98
- `Cannot resolve action context for ${pluginIdentifier} - please make sure the plugin is installed and up to date`
99
- );
100
-
101
- return;
102
- }
103
-
104
- actionContext?.invokeAction?.(item);
105
- };
106
-
107
- return (
108
- <Focusable
109
- id={generateId(cellUUID, suffixId)}
110
- disableFocus={disableFocus}
111
- groupId={groupId}
112
- onPress={onPress}
113
- nextFocusUp={parentFocus?.nextFocusUp}
114
- nextFocusDown={parentFocus?.nextFocusDown}
115
- nextFocusLeft={nextFocusLeft || parentFocus?.nextFocusLeft}
116
- nextFocusRight={nextFocusRight || parentFocus?.nextFocusRight}
117
- ref={ref}
118
- >
119
- {(isFocused) => {
120
- const additionalStyles = isFocused ? focusedStyles : normalStyles;
121
-
122
- return (
123
- <View
124
- style={{
125
- ...style,
126
- ...additionalStyles,
127
- }}
128
- >
129
- {recursiveCloneElementsWithState(isFocused, children)}
130
- </View>
131
- );
132
- }}
133
- </Focusable>
134
- );
135
- }
@@ -1,25 +0,0 @@
1
- import { ImageStyle } from "react-native";
2
-
3
- export type ContainerProps = Record<string, any> & {
4
- buttonsToggleEnabled: boolean;
5
- skipButtons: boolean;
6
- style: ImageStyle;
7
- children: ContainerChildren[];
8
- };
9
-
10
- export type ButtonProps = Record<string, any> & {
11
- style: ImageStyle;
12
- };
13
-
14
- export type HorizontalSeparatorProps = {
15
- width: number;
16
- };
17
-
18
- export type ContainerChildren = {
19
- props: {
20
- item: any;
21
- pluginIdentifier: string;
22
- cellUUID: string;
23
- suffixId: string;
24
- };
25
- };
@@ -1,57 +0,0 @@
1
- import * as React from "react";
2
- import * as R from "ramda";
3
- import { Text, TextStyle, View, ViewStyle } from "react-native";
4
-
5
- import { getLocalizations } from "@applicaster/zapp-react-native-utils/localizationUtils";
6
- import { getAppStylesColor } from "@applicaster/zapp-react-native-utils/stylesUtils";
7
- import { useTheme } from "@applicaster/zapp-react-native-utils/theme";
8
- import { styleKeys } from "@applicaster/zapp-react-native-utils/styleKeysUtils";
9
-
10
- type Props = {
11
- styles: {};
12
- error: {};
13
- remoteConfigurations: { localizations: {} };
14
- };
15
-
16
- const defaultAppStyles = {
17
- loading_error_label: {
18
- color: "#aaa",
19
- },
20
- };
21
-
22
- const textStyles = (appStyles = defaultAppStyles): TextStyle => ({
23
- color: getAppStylesColor("loading_error_label", appStyles),
24
- fontSize: 36,
25
- textAlign: "center",
26
- });
27
-
28
- const errorStyles = ({ backgroundColor }): ViewStyle => ({
29
- flex: 1,
30
- width: "100%",
31
- height: "100%",
32
- justifyContent: "center",
33
- alignItems: "center",
34
- position: "absolute",
35
- zIndex: 100,
36
- backgroundColor,
37
- });
38
-
39
- export function ErrorDisplayComponent({
40
- styles,
41
- remoteConfigurations: { localizations },
42
- }: Props) {
43
- const theme = useTheme();
44
- const backgroundColor = theme?.app_background_color;
45
-
46
- const { stream_error_message = "Cannot play stream" } = getLocalizations({
47
- localizations,
48
- });
49
-
50
- const appStyles = R.prop(styleKeys.style_namespace, styles);
51
-
52
- return (
53
- <View style={errorStyles({ backgroundColor })}>
54
- <Text style={textStyles(appStyles)}>{stream_error_message}</Text>
55
- </View>
56
- );
57
- }
@@ -1,9 +0,0 @@
1
- import * as R from "ramda";
2
-
3
- import { connectToStore } from "@applicaster/zapp-react-native-redux/utils/connectToStore";
4
-
5
- import { ErrorDisplayComponent } from "./ErrorDisplay";
6
-
7
- export const ErrorDisplay = R.compose(
8
- connectToStore(R.pick(["remoteConfigurations"]))
9
- )(ErrorDisplayComponent);
@@ -1,101 +0,0 @@
1
- import { Player } from "@applicaster/zapp-react-native-utils/appUtils/playerManager/player";
2
- import NetInfo from "@react-native-community/netinfo";
3
-
4
- import { useEffect, useMemo, useRef, useState } from "react";
5
- import { showAlertDialog } from "@applicaster/zapp-react-native-utils/alertUtils";
6
- import { useTheme } from "@applicaster/zapp-react-native-utils/theme";
7
- import { isTV } from "@applicaster/zapp-react-native-utils/reactUtils";
8
- import { log_info } from "./logger";
9
-
10
- type RestrictMobilePlaybackProps = {
11
- player?: Player;
12
- entry?: ZappEntry;
13
- pluginConfiguration?: Record<string, string>;
14
- close: () => void;
15
- };
16
-
17
- export const useRestrictMobilePlayback = ({
18
- player,
19
- entry,
20
- pluginConfiguration,
21
- close,
22
- }: RestrictMobilePlaybackProps): { isRestricted: boolean } => {
23
- const dialogVisibleRef = useRef<boolean>(false);
24
- const theme = useTheme();
25
-
26
- useEffect(() => {
27
- return () => {
28
- if (isTV()) {
29
- return;
30
- }
31
-
32
- dialogVisibleRef.current = false;
33
- };
34
- }, []);
35
-
36
- const isConnectionRestricted = useMemo(() => {
37
- if (isTV()) {
38
- return false;
39
- }
40
-
41
- return player && entry?.extensions?.connection_restricted;
42
- }, [player, entry]);
43
-
44
- const [isRestricted, setIsRestricted] = useState<boolean>(
45
- isConnectionRestricted
46
- );
47
-
48
- useEffect(() => {
49
- if (!isConnectionRestricted) {
50
- return;
51
- }
52
-
53
- const stopPlayer = () => {
54
- log_info(
55
- "Stopping player due to mobile restriction, connection_restricted: true"
56
- );
57
-
58
- player?.close();
59
-
60
- dialogVisibleRef.current = true;
61
-
62
- showAlertDialog({
63
- title:
64
- pluginConfiguration?.mobile_connection_restricted_alert_title ||
65
- "Restricted Connection Type",
66
- message:
67
- pluginConfiguration?.mobile_connection_restricted_alert_message ||
68
- "This content can only be viewed over a Wi-Fi or LAN network.",
69
- okButtonText: theme.ok_button || "OK",
70
- completion: () => {
71
- dialogVisibleRef.current = false;
72
-
73
- close();
74
- },
75
- });
76
- };
77
-
78
- return NetInfo.addEventListener((state) => {
79
- if (state.type === "cellular") {
80
- setIsRestricted(true);
81
-
82
- if (dialogVisibleRef.current) {
83
- return;
84
- }
85
-
86
- stopPlayer();
87
- } else {
88
- setIsRestricted(false);
89
- }
90
- });
91
- }, [
92
- close,
93
- entry?.extensions?.connection_restricted,
94
- pluginConfiguration,
95
- player,
96
- theme.ok_button,
97
- isConnectionRestricted,
98
- ]);
99
-
100
- return { isRestricted };
101
- };
File without changes