@applicaster/zapp-react-native-utils 13.0.6-alpha.9045435588 → 14.0.0-alpha.1015356256

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 (39) hide show
  1. package/actionsExecutor/ActionExecutorContext.tsx +1 -1
  2. package/analyticsUtils/AnalyticsEvents/helper.ts +81 -0
  3. package/analyticsUtils/AnalyticsEvents/sendOnClickEvent.ts +14 -4
  4. package/analyticsUtils/__tests__/analyticsUtils.test.js +14 -0
  5. package/analyticsUtils/events.ts +8 -0
  6. package/appUtils/accessibilityManager/index.ts +3 -3
  7. package/appUtils/playerManager/OverlayObserver/OverlaysObserver.ts +0 -15
  8. package/appUtils/playerManager/useChapterMarker.tsx +0 -1
  9. package/configurationUtils/__tests__/manifestKeyParser.test.ts +547 -0
  10. package/configurationUtils/manifestKeyParser.ts +57 -32
  11. package/focusManager/FocusManager.ts +22 -10
  12. package/focusManager/Tree.ts +25 -21
  13. package/focusManager/__tests__/FocusManager.test.ts +50 -8
  14. package/manifestUtils/_internals/getDefaultConfiguration.js +28 -0
  15. package/manifestUtils/{_internals.js → _internals/index.js} +2 -25
  16. package/manifestUtils/createConfig.js +4 -1
  17. package/manifestUtils/defaultManifestConfigurations/player.js +1565 -572
  18. package/manifestUtils/progressBar/__tests__/mobileProgressBar.test.js +0 -30
  19. package/navigationUtils/__tests__/navigationUtils.test.js +0 -65
  20. package/navigationUtils/index.ts +0 -31
  21. package/package.json +2 -2
  22. package/playerUtils/__tests__/configurationUtils.test.ts +1 -65
  23. package/playerUtils/_internals/__tests__/utils.test.ts +71 -0
  24. package/playerUtils/_internals/index.ts +1 -0
  25. package/playerUtils/_internals/utils.ts +31 -0
  26. package/playerUtils/configurationUtils.ts +0 -44
  27. package/playerUtils/getPlayerActionButtons.ts +1 -1
  28. package/playerUtils/index.ts +51 -0
  29. package/playerUtils/useValidatePlayerConfig.tsx +22 -19
  30. package/reactHooks/feed/useBatchLoading.ts +1 -1
  31. package/reactHooks/feed/usePipesCacheReset.ts +1 -1
  32. package/reactHooks/layout/isTablet/index.ts +7 -3
  33. package/reactHooks/navigation/index.ts +7 -3
  34. package/reactHooks/screen/useScreenContext.ts +1 -1
  35. package/reactHooks/state/__tests__/ZStoreProvider.test.tsx +2 -1
  36. package/riverComponetsMeasurementProvider/index.tsx +1 -1
  37. package/services/js2native.ts +1 -0
  38. package/utils/index.ts +4 -0
  39. package/playerUtils/configurationGenerator.ts +0 -2572
@@ -18,36 +18,6 @@ describe("mobileProgressBar", () => {
18
18
  ]),
19
19
  });
20
20
 
21
- // const timeRemainingLabelConditions = (condition) => ({
22
- // rules: "all_conditions",
23
- // conditional_fields: compact([
24
- // {
25
- // key: "assets/progress_bar_switch",
26
- // condition_value: true,
27
- // },
28
- // {
29
- // key: "assets/progress_bar_time_remaining_label_enable",
30
- // condition_value: true,
31
- // },
32
- // condition,
33
- // ]),
34
- // });
35
-
36
- // const watchedLabelConditions = (condition) => ({
37
- // rules: "all_conditions",
38
- // conditional_fields: compact([
39
- // {
40
- // key: "assets/progress_bar_switch",
41
- // condition_value: true,
42
- // },
43
- // {
44
- // key: "assets/progress_bar_watched_label_enable",
45
- // condition_value: true,
46
- // },
47
- // condition,
48
- // ]),
49
- // });
50
-
51
21
  it("generate progress-bar configuration - enabled and with bottom_of_cell", () => {
52
22
  const enable = true;
53
23
  const hideUnwatched = true;
@@ -319,68 +319,3 @@ describe("getRiverFromRoute", () => {
319
319
  expect(getRiverFromRoute({ route, rivers })).toEqual(river);
320
320
  });
321
321
  });
322
-
323
- describe("isPreviousRouteHook", () => {
324
- const { isPreviousRouteHook } = navigationUtils;
325
-
326
- const history = {
327
- entries: [],
328
- };
329
-
330
- it("returns false if it's a root route", () => {
331
- history.entries.push({ pathname: "/river/root" });
332
- const currentResult = isPreviousRouteHook(history.entries);
333
- expect(currentResult).toBe(false);
334
- });
335
-
336
- it("returns false if previous root is not a hook", () => {
337
- history.entries.push({ pathname: "/almostHooks/secondLevel" });
338
- const currentResult = isPreviousRouteHook(history.entries);
339
- expect(currentResult).toBe(false);
340
- });
341
-
342
- it("returns true if previous root is a hook", () => {
343
- history.entries.push({ pathname: "/hooks/ThirdLevel" });
344
- history.entries.push({ pathname: "/almostHooks/forthLevel" });
345
- const currentResult = isPreviousRouteHook(history.entries);
346
- expect(currentResult).toBe(true);
347
- });
348
- });
349
-
350
- describe("getPreviousHooksCount", () => {
351
- const { getPreviousHooksCount } = navigationUtils;
352
-
353
- const history = {
354
- entries: [],
355
- };
356
-
357
- it("returns 0 if it's a root route", () => {
358
- history.entries.push({ pathname: "/river/root" });
359
- const currentResult = getPreviousHooksCount(history);
360
- expect(currentResult).toBe(0);
361
- });
362
-
363
- it("returns 0 if previous root is not a hook", () => {
364
- history.entries.push({ pathname: "/almostHooks/secondLevel" });
365
- const currentResult = getPreviousHooksCount(history);
366
- expect(currentResult).toBe(0);
367
- });
368
-
369
- it("returns 1 if previous root is a hook", () => {
370
- history.entries = [];
371
- history.entries.push({ pathname: "/hooks/ThirdLevel" });
372
- history.entries.push({ pathname: "/almostHooks/forthLevel" });
373
- const currentResult = getPreviousHooksCount(history);
374
- expect(currentResult).toBe(1);
375
- });
376
-
377
- it("returns 2 if 2 previous routes are a hooks", () => {
378
- history.entries = [];
379
- history.entries.push({ pathname: "/almostHooks/forthLevel" });
380
- history.entries.push({ pathname: "/hooks/myHook" });
381
- history.entries.push({ pathname: "/hooks/myHook" });
382
- history.entries.push({ pathname: "/almostHooks/forthLevel" });
383
- const currentResult = getPreviousHooksCount(history);
384
- expect(currentResult).toBe(2);
385
- });
386
- });
@@ -363,37 +363,6 @@ export function getRiverFromRoute({
363
363
  return screenType && screenId ? { screenType, screenId } : null;
364
364
  }
365
365
 
366
- /**
367
- * Function returns true if the previous route (in the react-router history) is a hook plugin
368
- * @param {*} entries - React-Router History Object
369
- * @return boolean
370
- */
371
- export function isPreviousRouteHook(entries: [{ pathname: string }]): boolean {
372
- const previousRoute = entries[entries.length - 2];
373
- if (!previousRoute) return false;
374
-
375
- return R.test(/\/hooks\/.*/g, previousRoute.pathname);
376
- }
377
-
378
- /**
379
- * Function returns number of consecutive hooks that are behind the current route
380
- * @param {*} history - React-Router History Object
381
- * @return true
382
- */
383
- export function getPreviousHooksCount(history: {
384
- entries: [{ pathname: string }];
385
- }): number {
386
- let hooksCount = 0;
387
- let entries = R.clone(history.entries);
388
-
389
- while (isPreviousRouteHook(entries)) {
390
- hooksCount++;
391
- entries = R.init(entries);
392
- }
393
-
394
- return hooksCount;
395
- }
396
-
397
366
  export const usesVideoModal = (
398
367
  item: ZappEntry,
399
368
  rivers: Record<string, ZappRiver>,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@applicaster/zapp-react-native-utils",
3
- "version": "13.0.6-alpha.9045435588",
3
+ "version": "14.0.0-alpha.1015356256",
4
4
  "description": "Applicaster Zapp React Native utilities package",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",
@@ -27,7 +27,7 @@
27
27
  },
28
28
  "homepage": "https://github.com/applicaster/quickbrick#readme",
29
29
  "dependencies": {
30
- "@applicaster/applicaster-types": "13.0.6-alpha.9045435588",
30
+ "@applicaster/applicaster-types": "14.0.0-alpha.1015356256",
31
31
  "buffer": "^5.2.1",
32
32
  "camelize": "^1.0.0",
33
33
  "dayjs": "^1.11.10",
@@ -1,72 +1,8 @@
1
1
  import * as utils from "../configurationUtils";
2
2
 
3
- const { modifyDefaultConfigValues, parseLanguageTracks } = utils;
4
-
5
- const configuration = {
6
- general: { fields: [{ key: "general_1", initial_value: true }] },
7
- styles: { fields: [{ key: "styles_1", initial_value: true }] },
8
- localizations: {
9
- fields: [{ key: "localizations_1", initial_value: true, label: "label" }],
10
- },
11
- custom_configuration_fields: [
12
- { key: "custom_configuration_fields_1", initial_value: true },
13
- { key: "custom_configuration_fields_2", initial_value: "black" },
14
- {
15
- group: true,
16
- fields: [{ key: "custom_configuration_fields_3", initial_value: "red" }],
17
- },
18
- ],
19
- };
3
+ const { parseLanguageTracks } = utils;
20
4
 
21
5
  describe("utilities", () => {
22
- describe("modifyDefaultConfigValues", () => {
23
- it("should not modify the configuration if a map key doesn't exist in configuration ", function () {
24
- const res = modifyDefaultConfigValues(configuration, {
25
- custom_configuration_fields: {
26
- non_existing_key: { initial_value: "true" },
27
- },
28
- });
29
-
30
- expect(res).toEqual(configuration);
31
- });
32
-
33
- it("should modify the key from mapping", function () {
34
- const currentResult = modifyDefaultConfigValues(configuration, {
35
- styles: { styles_1: { initial_value: false } },
36
- });
37
-
38
- expect(currentResult.styles.fields[0].initial_value).toBe(false);
39
- });
40
-
41
- it("should add extra keys the key from mapping", function () {
42
- const currentResult = modifyDefaultConfigValues(configuration, {
43
- styles: { styles_1: { extra_key: false } },
44
- });
45
-
46
- expect(currentResult.styles.fields[0].extra_key).toBeDefined();
47
- });
48
-
49
- it("should not remove existing keys that aren't being overwritten", function () {
50
- const currentResult = modifyDefaultConfigValues(configuration, {
51
- localizations: { localizations_1: { initial_value: false } },
52
- });
53
-
54
- expect(currentResult.localizations.fields[0].label).toBeDefined();
55
- });
56
-
57
- it("should modify values in groups as well", function () {
58
- const currentResult = modifyDefaultConfigValues(configuration, {
59
- custom_configuration_fields: {
60
- custom_configuration_fields_3: { initial_value: "blue" },
61
- },
62
- });
63
-
64
- expect(
65
- currentResult.custom_configuration_fields[2].fields[0].initial_value
66
- ).toBe("blue");
67
- });
68
- });
69
-
70
6
  describe("parseLanguageTracks", () => {
71
7
  const textTrack = { index: 0, id: "text-0" };
72
8
  const audioTrack = { index: 0, id: "audio-0" };
@@ -0,0 +1,71 @@
1
+ import { getAllFields, getConfigurationDiff } from "../utils";
2
+
3
+ describe("getAllFields", () => {
4
+ it("should return all field keys from flat configs", () => {
5
+ const config1 = {
6
+ fields: [{ key: "foo" }, { key: "bar" }],
7
+ };
8
+
9
+ const config2 = {
10
+ fields: [{ key: "baz" }],
11
+ };
12
+
13
+ expect(getAllFields(config1, config2)).toEqual(["foo", "bar", "baz"]);
14
+ });
15
+
16
+ it("should handle grouped fields", () => {
17
+ const config = {
18
+ fields: [
19
+ {
20
+ group: true,
21
+ fields: [{ key: "grouped1" }, { key: "grouped2" }],
22
+ },
23
+ { key: "single" },
24
+ ],
25
+ };
26
+
27
+ expect(getAllFields(config)).toEqual(["grouped1", "grouped2", "single"]);
28
+ });
29
+
30
+ it("should filter out fields without a key", () => {
31
+ const config = {
32
+ fields: [{ key: "foo" }, { notAKey: "bar" }],
33
+ };
34
+
35
+ expect(getAllFields(config)).toEqual(["foo"]);
36
+ });
37
+
38
+ it("should return an empty array if no fields are present", () => {
39
+ expect(getAllFields({})).toEqual([]);
40
+ });
41
+ });
42
+
43
+ describe("getConfigurationDiff", () => {
44
+ it("should return keys in defaultConfig not present in config", () => {
45
+ const defaultConfig = ["foo", "bar", "baz"];
46
+ const config = { foo: 1, baz: 2 };
47
+
48
+ expect(getConfigurationDiff(defaultConfig, config)).toEqual(["bar"]);
49
+ });
50
+
51
+ it("should return all keys if config is empty", () => {
52
+ const defaultConfig = ["foo", "bar"];
53
+ const config = {};
54
+
55
+ expect(getConfigurationDiff(defaultConfig, config)).toEqual(["foo", "bar"]);
56
+ });
57
+
58
+ it("should return an empty array if all keys are present", () => {
59
+ const defaultConfig = ["foo"];
60
+ const config = { foo: 1 };
61
+
62
+ expect(getConfigurationDiff(defaultConfig, config)).toEqual([]);
63
+ });
64
+
65
+ it("should return defaultConfig if config has no matching keys", () => {
66
+ const defaultConfig = ["foo", "bar"];
67
+ const config = { baz: 1 };
68
+
69
+ expect(getConfigurationDiff(defaultConfig, config)).toEqual(["foo", "bar"]);
70
+ });
71
+ });
@@ -0,0 +1 @@
1
+ export * from "./utils";
@@ -0,0 +1,31 @@
1
+ import {
2
+ flatMap,
3
+ get,
4
+ flatten,
5
+ difference,
6
+ } from "@applicaster/zapp-react-native-utils/utils";
7
+
8
+ const extractFields = (field: any) => {
9
+ if (field.group === true) {
10
+ return field.fields;
11
+ }
12
+
13
+ return field;
14
+ };
15
+
16
+ export const getAllFields = (...configs: any[]) => {
17
+ const allFields = flatMap(configs, (config) => get(config, "fields", []));
18
+
19
+ const processedFields = flatten(allFields.map(extractFields))
20
+ .map((field) => get(field, "key"))
21
+ .filter(Boolean);
22
+
23
+ return processedFields;
24
+ };
25
+
26
+ export const getConfigurationDiff = (
27
+ defaultConfig,
28
+ config: Record<string, any>
29
+ ) => {
30
+ return difference(defaultConfig, Object.keys(config));
31
+ };
@@ -1,50 +1,6 @@
1
1
  import { parseJsonIfNeeded } from "../functionUtils";
2
2
  import * as R from "ramda";
3
3
 
4
- import { getNativeName as nativeNameUtil } from "../localizationUtils/localeLanguage";
5
-
6
- export const modifyDefaultConfigValues = (
7
- configuration: ConfigurationKeys,
8
- mapping: ConfigValuesMapping
9
- ): DefaultConfiguration => {
10
- return R.mapObjIndexed((value, key) => {
11
- const isFieldlessKey = key === "custom_configuration_fields";
12
- const keyMapping = mapping[key];
13
- const fields = value?.fields || value;
14
-
15
- if (!keyMapping) {
16
- return value;
17
- }
18
-
19
- const mapper = (obj) => {
20
- if (obj.fields) {
21
- return R.mergeLeft({ fields: R.map(mapper)(obj.fields) })(obj);
22
- }
23
-
24
- return R.mergeLeft(keyMapping?.[obj.key])(obj);
25
- };
26
-
27
- const mappedFields = R.map(mapper)(fields);
28
-
29
- return R.unless(() => isFieldlessKey, R.objOf("fields"))(mappedFields);
30
- })(configuration);
31
- };
32
-
33
- export function nativeName(localeCode) {
34
- try {
35
- const {
36
- getNativeName,
37
- } = require("@applicaster/zapp-react-native-utils/localizationUtils/localeLanguage");
38
-
39
- return getNativeName(localeCode);
40
- } catch (error) {
41
- // eslint-disable-next-line no-console
42
- console.warn("Could not load localeLanguage utils from QB", error);
43
-
44
- return nativeNameUtil(localeCode);
45
- }
46
- }
47
-
48
4
  const setTrackType = R.curry(
49
5
  (
50
6
  type: QuickBrickPlayer.TrackType,
@@ -1,4 +1,4 @@
1
- import { take, map, trim } from "lodash";
1
+ import { map, take, trim } from "../utils";
2
2
  import { selectActionButtons } from "../conf/player/selectors";
3
3
 
4
4
  /**
@@ -5,6 +5,7 @@ import { isFilledArray } from "@applicaster/zapp-react-native-utils/arrayUtils";
5
5
  import { isTV } from "@applicaster/zapp-react-native-utils/reactUtils";
6
6
 
7
7
  import { getBoolFromConfigValue } from "../configurationUtils";
8
+ import { Dimensions } from "react-native";
8
9
 
9
10
  export { getPlayerActionButtons } from "./getPlayerActionButtons";
10
11
 
@@ -97,3 +98,53 @@ export const isAudioItem = (item: Option<ZappEntry>) => {
97
98
  export const isInlineTV = (screenData) => {
98
99
  return isTV() && isFilledArray(screenData?.ui_components);
99
100
  };
101
+
102
+ const isPercentage = (value: string | number): boolean => {
103
+ if (typeof value === "string") {
104
+ return value.includes("%");
105
+ }
106
+
107
+ return false;
108
+ };
109
+
110
+ const getPercentageOf = (percent: string, value: number) => {
111
+ const percentageValue = parseFloat(percent.replace("%", ""));
112
+
113
+ if (isNaN(percentageValue)) {
114
+ return value;
115
+ }
116
+
117
+ return (value * percentageValue) / 100;
118
+ };
119
+
120
+ type DimensionsT = {
121
+ width: number | string;
122
+ height: number | string | undefined;
123
+ aspectRatio?: number;
124
+ };
125
+
126
+ export const getTabletWidth = (
127
+ tablet_landscape_sidebar_width,
128
+ dimensions: DimensionsT
129
+ ) => {
130
+ const { width: SCREEN_WIDTH } = Dimensions.get("screen");
131
+
132
+ const { width } = dimensions;
133
+ let widthValue = Number(width);
134
+
135
+ if (isPercentage(width)) {
136
+ widthValue = getPercentageOf(width.toString(), SCREEN_WIDTH);
137
+ }
138
+
139
+ const sidebarWidth = Number(tablet_landscape_sidebar_width?.replace("%", ""));
140
+
141
+ if (tablet_landscape_sidebar_width?.includes("%")) {
142
+ return widthValue * (1 - sidebarWidth / 100);
143
+ }
144
+
145
+ if (Number.isNaN(sidebarWidth)) {
146
+ return widthValue * 0.65;
147
+ }
148
+
149
+ return widthValue - sidebarWidth;
150
+ };
@@ -1,34 +1,37 @@
1
1
  import * as React from "react";
2
- import * as R from "ramda";
3
- import generateConfiguration from "./configurationGenerator";
4
2
  import { createLogger } from "../logger";
3
+ import { createConfig } from "../manifestUtils/createConfig";
4
+ import { getAllFields, getConfigurationDiff } from "./_internals";
5
5
 
6
6
  export const logger = createLogger({
7
7
  category: "useValidatePlayerConfig",
8
8
  subsystem: "useValidatePlayerConfig",
9
9
  });
10
10
 
11
- const configuration = generateConfiguration();
11
+ /** Default Player Configuration */
12
+ const {
13
+ styles,
14
+ general,
15
+ localizations,
16
+ custom_configuration_fields,
17
+ }: DefaultConfiguration = createConfig(
18
+ () => {
19
+ return {};
20
+ },
21
+ { extend: "player" }
22
+ ) as any;
23
+
24
+ const QBPlayerConfigFields = getAllFields(
25
+ styles,
26
+ general,
27
+ localizations,
28
+ custom_configuration_fields
29
+ );
12
30
 
13
31
  export const useValidatePlayerConfig = (config) => {
14
32
  React.useEffect(() => {
15
33
  try {
16
- const QBPlayerConfigFields = R.compose(
17
- R.map(R.prop("key")),
18
- R.flatten,
19
- R.map(R.compose(R.when(R.propEq("group", true), R.prop("fields")))),
20
- R.concat
21
- )(
22
- configuration.styles.fields,
23
- configuration.general.fields,
24
- configuration.localizations.fields,
25
- configuration.custom_configuration_fields
26
- );
27
-
28
- const diff = R.compose(
29
- R.difference(QBPlayerConfigFields),
30
- R.keys
31
- )(config);
34
+ const diff = getConfigurationDiff(QBPlayerConfigFields, config);
32
35
 
33
36
  logger.log_info(
34
37
  "Missing following configuration properties. Some elements of the player may not work correctly. Check QuickBrickPlayerPlugin for the configuration reference https://github.com/applicaster/QuickBrick/tree/main/plugins/zapp-react-native-default-player/manifests",
@@ -10,7 +10,7 @@ import {
10
10
  getSearchContext,
11
11
  } from "@applicaster/zapp-react-native-utils/reactHooks";
12
12
  import { isGallery } from "@applicaster/zapp-react-native-utils/componentsUtils";
13
- import { useScreenContext } from "../screen/useScreenContext";
13
+ import { useScreenContext } from "../screen";
14
14
 
15
15
  type Options = {
16
16
  initialBatchSize?: number;
@@ -5,7 +5,7 @@ import { getDatasourceUrl } from "@applicaster/zapp-react-native-ui-components/D
5
5
  import { usePipesContexts } from "@applicaster/zapp-react-native-ui-components/Decorators/RiverFeedLoader/utils/usePipesContexts";
6
6
  import { clearPipesData } from "@applicaster/zapp-react-native-redux/ZappPipes";
7
7
 
8
- import { useRoute } from "../navigation/useRoute";
8
+ import { useRoute } from "../navigation";
9
9
 
10
10
  /**
11
11
  * reset river components cache when screen is unmounted
@@ -1,5 +1,11 @@
1
1
  import { NativeModules, Platform } from "react-native";
2
2
 
3
+ export const isAndroidTablet = () => {
4
+ const { initialProps } = NativeModules.QuickBrickCommunicationModule;
5
+
6
+ return initialProps?.is_tablet;
7
+ };
8
+
3
9
  /**
4
10
  * Determines wether the given device is a tablet based on dimensions, orientation, and platform
5
11
  * @param {Object} dimensions - Dimensions object passed to the function
@@ -13,9 +19,7 @@ export const isTablet = (
13
19
  if (Platform?.OS === "ios") {
14
20
  return Platform?.isPad;
15
21
  } else if (Platform?.OS === "android") {
16
- const { initialProps } = NativeModules.QuickBrickCommunicationModule;
17
-
18
- return initialProps?.is_tablet;
22
+ return isAndroidTablet();
19
23
  }
20
24
 
21
25
  const { width } = dimensions || {};
@@ -14,7 +14,7 @@ import { HOOKS_EVENTS } from "../../appUtils/HooksManager/constants";
14
14
  import { getRiverFromRoute, getTargetRoute } from "../../navigationUtils";
15
15
  import { useConnectionInfo } from "../connection";
16
16
 
17
- import { isTV } from "@applicaster/zapp-react-native-utils/reactUtils";
17
+ import { isTV, isWeb } from "@applicaster/zapp-react-native-utils/reactUtils";
18
18
  import { useNavbarState } from "../screen";
19
19
 
20
20
  export { useNavigation } from "./useNavigation";
@@ -127,10 +127,14 @@ export function isNavBarVisible(
127
127
 
128
128
  export const useBackHandler = (cb: () => boolean) => {
129
129
  useEffect(() => {
130
- BackHandler.addEventListener("hardwareBackPress", cb);
130
+ if (!isWeb()) {
131
+ BackHandler.addEventListener("hardwareBackPress", cb);
132
+ }
131
133
 
132
134
  return () => {
133
- BackHandler.removeEventListener("hardwareBackPress", cb);
135
+ if (!isWeb()) {
136
+ BackHandler.removeEventListener("hardwareBackPress", cb);
137
+ }
134
138
  };
135
139
  }, [cb]);
136
140
  };
@@ -2,7 +2,7 @@ import { useContext, useMemo } from "react";
2
2
 
3
3
  import { useModalNavigationContext } from "@applicaster/zapp-react-native-ui-components/Contexts/ModalNavigationContext";
4
4
  import { useNestedNavigationContext } from "@applicaster/zapp-react-native-ui-components/Contexts/NestedNavigationContext";
5
- import { useNavigation } from "../navigation/useNavigation";
5
+ import { useNavigation } from "../navigation";
6
6
 
7
7
  import { ScreenContext } from "@applicaster/zapp-react-native-ui-components/Contexts/ScreenContext";
8
8
  import { ScreenDataContext } from "@applicaster/zapp-react-native-ui-components/Contexts/ScreenDataContext";
@@ -1,7 +1,8 @@
1
+ /* eslint-disable no-console */
1
2
  import React from "react";
2
3
  import { render, screen } from "@testing-library/react-native";
3
4
  import { Text } from "react-native";
4
- import { ZStoreProvider, useZStore } from "../ZStoreProvider";
5
+ import { useZStore, ZStoreProvider } from "../ZStoreProvider";
5
6
  import { useStore } from "zustand";
6
7
 
7
8
  interface TestState {
@@ -3,7 +3,7 @@ import { NativeModules, StyleSheet, View } from "react-native";
3
3
  import { getXray } from "@applicaster/zapp-react-native-utils/logger";
4
4
 
5
5
  import { isApplePlatform, isWeb } from "../reactUtils";
6
- import { useRivers } from "../reactHooks/state";
6
+ import { useRivers } from "../reactHooks";
7
7
 
8
8
  const layoutReducer = (state, { payload }) => {
9
9
  return state.map((item, index, _state) => ({
@@ -496,6 +496,7 @@ async function removeStorageListenerHandler(payload: { listenerId?: string }) {
496
496
  function log({ level, messages }) {
497
497
  try {
498
498
  const parsedMessages = parseJsonIfNeeded(messages);
499
+ // eslint-disable-next-line no-console
499
500
  const logFn = console[level] || console.log;
500
501
 
501
502
  if (Array.isArray(parsedMessages)) {
package/utils/index.ts CHANGED
@@ -13,4 +13,8 @@ export {
13
13
  has,
14
14
  flatMap,
15
15
  difference,
16
+ take,
17
+ map,
18
+ trim,
19
+ toString,
16
20
  } from "lodash";