@applicaster/zapp-react-native-utils 14.0.0-alpha.8419134002 → 14.0.0-alpha.9848043301
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/actionsExecutor/ActionExecutorContext.tsx +1 -1
- package/analyticsUtils/AnalyticsEvents/helper.ts +0 -81
- package/analyticsUtils/AnalyticsEvents/sendOnClickEvent.ts +4 -14
- package/analyticsUtils/__tests__/analyticsUtils.test.js +0 -14
- package/analyticsUtils/events.ts +0 -8
- package/appUtils/accessibilityManager/index.ts +3 -3
- package/arrayUtils/__tests__/isFilledArray.test.ts +1 -1
- package/arrayUtils/index.ts +2 -7
- package/configurationUtils/__tests__/configurationUtils.test.js +31 -0
- package/configurationUtils/index.ts +34 -63
- package/focusManager/FocusManager.ts +6 -4
- package/manifestUtils/{_internals/index.js → _internals.js} +25 -2
- package/manifestUtils/createConfig.js +1 -4
- package/manifestUtils/defaultManifestConfigurations/player.js +200 -1239
- package/manifestUtils/progressBar/__tests__/mobileProgressBar.test.js +30 -0
- package/package.json +2 -2
- package/playerUtils/__tests__/configurationUtils.test.ts +65 -1
- package/playerUtils/configurationGenerator.ts +2572 -0
- package/playerUtils/configurationUtils.ts +44 -0
- package/playerUtils/index.ts +51 -2
- package/playerUtils/useValidatePlayerConfig.tsx +19 -22
- package/reactHooks/feed/useBatchLoading.ts +3 -3
- package/reactHooks/feed/usePipesCacheReset.ts +1 -1
- package/reactHooks/navigation/useIsScreenActive.ts +5 -9
- package/reactHooks/screen/useScreenContext.ts +1 -1
- package/reactHooks/state/__tests__/ZStoreProvider.test.tsx +1 -2
- package/riverComponetsMeasurementProvider/index.tsx +1 -1
- package/services/js2native.ts +0 -1
- package/time/BackgroundTimer.ts +3 -5
- package/utils/index.ts +1 -16
- package/arrayUtils/__tests__/isEmptyArray.test.ts +0 -63
- package/audioPlayerUtils/__tests__/getArtworkImage.test.ts +0 -144
- package/audioPlayerUtils/__tests__/getBackgroundImage.test.ts +0 -72
- package/audioPlayerUtils/__tests__/getImageFromEntry.test.ts +0 -110
- package/audioPlayerUtils/assets/index.ts +0 -2
- package/audioPlayerUtils/index.ts +0 -242
- package/conf/player/__tests__/selectors.test.ts +0 -34
- package/conf/player/selectors.ts +0 -10
- package/configurationUtils/__tests__/getMediaItems.test.ts +0 -65
- package/configurationUtils/__tests__/imageSrcFromMediaItem.test.ts +0 -34
- package/manifestUtils/_internals/getDefaultConfiguration.js +0 -28
- package/playerUtils/__tests__/getPlayerActionButtons.test.ts +0 -54
- package/playerUtils/_internals/__tests__/utils.test.ts +0 -71
- package/playerUtils/_internals/index.ts +0 -1
- package/playerUtils/_internals/utils.ts +0 -31
- package/playerUtils/getPlayerActionButtons.ts +0 -17
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { getImageFromEntry } from "..";
|
|
2
|
-
|
|
3
|
-
const entry = {
|
|
4
|
-
media_group: [
|
|
5
|
-
{
|
|
6
|
-
media_item: [
|
|
7
|
-
{
|
|
8
|
-
key: "image_base_key",
|
|
9
|
-
src: "image_base_src",
|
|
10
|
-
},
|
|
11
|
-
{
|
|
12
|
-
key: "thumb_1",
|
|
13
|
-
src: null,
|
|
14
|
-
},
|
|
15
|
-
{
|
|
16
|
-
key: "thumb_2",
|
|
17
|
-
src: null,
|
|
18
|
-
},
|
|
19
|
-
{
|
|
20
|
-
key: "thumb_3",
|
|
21
|
-
src: null,
|
|
22
|
-
},
|
|
23
|
-
],
|
|
24
|
-
type: "image",
|
|
25
|
-
},
|
|
26
|
-
],
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
describe("getImageFromEntry", () => {
|
|
30
|
-
it("returns the src value for existing key", () => {
|
|
31
|
-
const result = getImageFromEntry({
|
|
32
|
-
entry,
|
|
33
|
-
imageKey: "image_base_key",
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
expect(result).toEqual("image_base_src");
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
it("returns undefined for non-existing key", () => {
|
|
40
|
-
const result = getImageFromEntry({
|
|
41
|
-
entry,
|
|
42
|
-
imageKey: "non_existing_key",
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
expect(result).toBeUndefined();
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
it("returns undefined for undefined key", () => {
|
|
49
|
-
const result = getImageFromEntry({
|
|
50
|
-
entry,
|
|
51
|
-
imageKey: undefined,
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
expect(result).toBeUndefined();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
it("returns undefined for non string src", () => {
|
|
58
|
-
const entryWithNonStringSrc = {
|
|
59
|
-
media_group: [
|
|
60
|
-
{
|
|
61
|
-
media_item: [
|
|
62
|
-
{
|
|
63
|
-
key: "image_base_key",
|
|
64
|
-
src: 123,
|
|
65
|
-
},
|
|
66
|
-
{
|
|
67
|
-
key: "thumb_1",
|
|
68
|
-
src: null,
|
|
69
|
-
},
|
|
70
|
-
],
|
|
71
|
-
type: "image",
|
|
72
|
-
},
|
|
73
|
-
],
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
const result = getImageFromEntry({
|
|
77
|
-
entry: entryWithNonStringSrc,
|
|
78
|
-
imageKey: "image_base_key",
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
expect(result).toBeUndefined();
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
it("returns undefined for empty src", () => {
|
|
85
|
-
const entryWithEmptySrc = {
|
|
86
|
-
media_group: [
|
|
87
|
-
{
|
|
88
|
-
media_item: [
|
|
89
|
-
{
|
|
90
|
-
key: "image_base_key",
|
|
91
|
-
src: "",
|
|
92
|
-
},
|
|
93
|
-
{
|
|
94
|
-
key: "thumb_1",
|
|
95
|
-
src: null,
|
|
96
|
-
},
|
|
97
|
-
],
|
|
98
|
-
type: "image",
|
|
99
|
-
},
|
|
100
|
-
],
|
|
101
|
-
};
|
|
102
|
-
|
|
103
|
-
const result = getImageFromEntry({
|
|
104
|
-
entry: entryWithEmptySrc,
|
|
105
|
-
imageKey: "image_base_key",
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
expect(result).toBeUndefined();
|
|
109
|
-
});
|
|
110
|
-
});
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export const DEFAULT_IMAGE =
|
|
2
|
-
"";
|
|
@@ -1,242 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import { get, has } from "@applicaster/zapp-react-native-utils/utils";
|
|
3
|
-
import { useZStore } from "@applicaster/zapp-react-native-utils/reactHooks";
|
|
4
|
-
import { useRoute } from "@applicaster/zapp-react-native-utils/reactHooks/navigation";
|
|
5
|
-
|
|
6
|
-
import { isNotEmptyString } from "@applicaster/zapp-react-native-utils/stringUtils";
|
|
7
|
-
import { getMediaItems } from "@applicaster/zapp-react-native-utils/configurationUtils";
|
|
8
|
-
|
|
9
|
-
import { DEFAULT_IMAGE } from "./assets";
|
|
10
|
-
|
|
11
|
-
export function getImageFromEntry({
|
|
12
|
-
entry,
|
|
13
|
-
imageKey,
|
|
14
|
-
}: {
|
|
15
|
-
entry: ZappEntry;
|
|
16
|
-
imageKey: Option<string>;
|
|
17
|
-
}): Option<string> {
|
|
18
|
-
const mediaItems = getMediaItems(entry);
|
|
19
|
-
|
|
20
|
-
if (!mediaItems) {
|
|
21
|
-
return undefined;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
// Find the media item with the matching key
|
|
25
|
-
const found = mediaItems.find((item) => item.key === imageKey);
|
|
26
|
-
const src = found?.src;
|
|
27
|
-
|
|
28
|
-
// Special case for react native - uri cannot be an empty string (yellow warning).
|
|
29
|
-
return isNotEmptyString(src) ? src : undefined;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const getPropertyFromExtensions = (
|
|
33
|
-
key: string,
|
|
34
|
-
entry: ZappEntry
|
|
35
|
-
): Option<string> => entry?.extensions?.[key];
|
|
36
|
-
|
|
37
|
-
const getPropertyFromConfiguration = (
|
|
38
|
-
key: string,
|
|
39
|
-
plugin_configuration: Record<string, any>
|
|
40
|
-
) => plugin_configuration?.[key];
|
|
41
|
-
|
|
42
|
-
type GetBackgroundImageParams = {
|
|
43
|
-
entry: ZappEntry;
|
|
44
|
-
plugin_configuration: Record<string, any>;
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
export const getBackgroundImage = ({
|
|
48
|
-
entry,
|
|
49
|
-
plugin_configuration,
|
|
50
|
-
}: GetBackgroundImageParams): string => {
|
|
51
|
-
// 1) image_key from extensions
|
|
52
|
-
const imageKeyFromExtensions = getPropertyFromExtensions("image_key", entry);
|
|
53
|
-
|
|
54
|
-
const imageFromExtensions = getImageFromEntry({
|
|
55
|
-
entry,
|
|
56
|
-
imageKey: imageKeyFromExtensions,
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
if (imageFromExtensions) {
|
|
60
|
-
return imageFromExtensions;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
// 2) audio_player_background_image from extensions(KAN case)
|
|
64
|
-
const audioPlayerBackgroundImageFromExtensions = getPropertyFromExtensions(
|
|
65
|
-
"audio_player_background_image",
|
|
66
|
-
entry
|
|
67
|
-
);
|
|
68
|
-
|
|
69
|
-
if (isNotEmptyString(audioPlayerBackgroundImageFromExtensions)) {
|
|
70
|
-
return audioPlayerBackgroundImageFromExtensions;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
// 3) image_key from configuration
|
|
74
|
-
const imageKeyFromConfiguration = getPropertyFromConfiguration(
|
|
75
|
-
"audio_player_image_key",
|
|
76
|
-
plugin_configuration
|
|
77
|
-
);
|
|
78
|
-
|
|
79
|
-
const imageFromConfiguration = getImageFromEntry({
|
|
80
|
-
entry,
|
|
81
|
-
imageKey: imageKeyFromConfiguration,
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
if (imageFromConfiguration) {
|
|
85
|
-
return imageFromConfiguration;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
// 4) audio_player_background_image from configuration
|
|
89
|
-
const audioPlayerBackgroundImageFromConfiguration =
|
|
90
|
-
getPropertyFromConfiguration(
|
|
91
|
-
"audio_player_background_image",
|
|
92
|
-
plugin_configuration
|
|
93
|
-
);
|
|
94
|
-
|
|
95
|
-
if (isNotEmptyString(audioPlayerBackgroundImageFromConfiguration)) {
|
|
96
|
-
return audioPlayerBackgroundImageFromConfiguration;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// default image
|
|
100
|
-
return DEFAULT_IMAGE;
|
|
101
|
-
};
|
|
102
|
-
|
|
103
|
-
type GetArtworkImageParams = {
|
|
104
|
-
key: string;
|
|
105
|
-
entry: ZappEntry;
|
|
106
|
-
plugin_configuration: Record<string, any>;
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
export const getArtworkImage = ({
|
|
110
|
-
key,
|
|
111
|
-
entry,
|
|
112
|
-
plugin_configuration,
|
|
113
|
-
}: GetArtworkImageParams): string => {
|
|
114
|
-
// 1) image_key from extensions
|
|
115
|
-
const imageKeyFromExtensions = getPropertyFromExtensions(key, entry);
|
|
116
|
-
|
|
117
|
-
const imageFromExtensions = getImageFromEntry({
|
|
118
|
-
entry,
|
|
119
|
-
imageKey: imageKeyFromExtensions,
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
if (imageFromExtensions) {
|
|
123
|
-
return imageFromExtensions;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
// 2) image_key from configuration
|
|
127
|
-
const imageKeyFromConfiguration = getPropertyFromConfiguration(
|
|
128
|
-
key,
|
|
129
|
-
plugin_configuration
|
|
130
|
-
);
|
|
131
|
-
|
|
132
|
-
const imageFromConfiguration = getImageFromEntry({
|
|
133
|
-
entry,
|
|
134
|
-
imageKey: imageKeyFromConfiguration,
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
if (imageFromConfiguration) {
|
|
138
|
-
return imageFromConfiguration;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// default image
|
|
142
|
-
return DEFAULT_IMAGE;
|
|
143
|
-
};
|
|
144
|
-
|
|
145
|
-
const useAdjustedKeyFromScreenData = ({ config, keys }) => {
|
|
146
|
-
const { screenData } = useRoute();
|
|
147
|
-
|
|
148
|
-
const adjustedConfig = { ...config };
|
|
149
|
-
|
|
150
|
-
keys.forEach((key) => {
|
|
151
|
-
const path = ["targetScreen", "styles", key];
|
|
152
|
-
|
|
153
|
-
if (has(screenData, path)) {
|
|
154
|
-
const value = get(screenData, path);
|
|
155
|
-
|
|
156
|
-
adjustedConfig[key] = value;
|
|
157
|
-
}
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
return adjustedConfig;
|
|
161
|
-
};
|
|
162
|
-
|
|
163
|
-
const AUDIO_PLAYER_ARTWORK_IMAGE_KEY = "audio_player_artwork_image_key";
|
|
164
|
-
|
|
165
|
-
const audioPlayerArtworkImageKeySelector = (config) =>
|
|
166
|
-
config?.[AUDIO_PLAYER_ARTWORK_IMAGE_KEY];
|
|
167
|
-
|
|
168
|
-
export const useArtworkImage = (entry: ZappEntry): string => {
|
|
169
|
-
const configuration = useZStore("playerConfiguration");
|
|
170
|
-
|
|
171
|
-
const audio_player_artwork_image_key_value = configuration(
|
|
172
|
-
audioPlayerArtworkImageKeySelector
|
|
173
|
-
);
|
|
174
|
-
|
|
175
|
-
const pluginConfiguration = React.useMemo(
|
|
176
|
-
() => ({
|
|
177
|
-
audio_player_artwork_image_key: audio_player_artwork_image_key_value,
|
|
178
|
-
}),
|
|
179
|
-
[audio_player_artwork_image_key_value]
|
|
180
|
-
);
|
|
181
|
-
|
|
182
|
-
// HACK: for override [key] from screenData, because we treat empty string value as missing key and replace it to initial_value from manifest(which is wrong)
|
|
183
|
-
const adjustedPluginConfiguration = useAdjustedKeyFromScreenData({
|
|
184
|
-
keys: [AUDIO_PLAYER_ARTWORK_IMAGE_KEY],
|
|
185
|
-
config: pluginConfiguration,
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
return React.useMemo(
|
|
189
|
-
() =>
|
|
190
|
-
getArtworkImage({
|
|
191
|
-
key: AUDIO_PLAYER_ARTWORK_IMAGE_KEY,
|
|
192
|
-
entry,
|
|
193
|
-
plugin_configuration: adjustedPluginConfiguration,
|
|
194
|
-
}),
|
|
195
|
-
[]
|
|
196
|
-
);
|
|
197
|
-
};
|
|
198
|
-
|
|
199
|
-
const AUDIO_PLAYER_IMAGE_KEY = "audio_player_image_key";
|
|
200
|
-
const AUDIO_PLAYER_BACKGROUND_IMAGE = "audio_player_background_image";
|
|
201
|
-
|
|
202
|
-
const audioPlayerImageKeySelector = (config) =>
|
|
203
|
-
config?.[AUDIO_PLAYER_IMAGE_KEY];
|
|
204
|
-
|
|
205
|
-
const audioPlayerBackgroundImageSelector = (config) =>
|
|
206
|
-
config?.[AUDIO_PLAYER_BACKGROUND_IMAGE];
|
|
207
|
-
|
|
208
|
-
export const useBackgroundImage = (entry: ZappEntry): { uri: string } => {
|
|
209
|
-
const configuration = useZStore("playerConfiguration");
|
|
210
|
-
|
|
211
|
-
const audio_player_image_key_value = configuration(
|
|
212
|
-
audioPlayerImageKeySelector
|
|
213
|
-
);
|
|
214
|
-
|
|
215
|
-
const audio_player_background_image_value = configuration(
|
|
216
|
-
audioPlayerBackgroundImageSelector
|
|
217
|
-
);
|
|
218
|
-
|
|
219
|
-
const pluginConfiguration = React.useMemo(
|
|
220
|
-
() => ({
|
|
221
|
-
audio_player_image_key: audio_player_image_key_value,
|
|
222
|
-
audio_player_background_image: audio_player_background_image_value,
|
|
223
|
-
}),
|
|
224
|
-
[audio_player_image_key_value, audio_player_background_image_value]
|
|
225
|
-
);
|
|
226
|
-
|
|
227
|
-
// HACK: for override [key] from screenData, because we treat empty string value as missing key and replace it to initial_value from manifest(which is wrong)
|
|
228
|
-
const adjustedPluginConfiguration = useAdjustedKeyFromScreenData({
|
|
229
|
-
keys: [AUDIO_PLAYER_IMAGE_KEY, AUDIO_PLAYER_BACKGROUND_IMAGE],
|
|
230
|
-
config: pluginConfiguration,
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
return React.useMemo(
|
|
234
|
-
() => ({
|
|
235
|
-
uri: getBackgroundImage({
|
|
236
|
-
entry,
|
|
237
|
-
plugin_configuration: adjustedPluginConfiguration,
|
|
238
|
-
}),
|
|
239
|
-
}),
|
|
240
|
-
[entry, adjustedPluginConfiguration]
|
|
241
|
-
);
|
|
242
|
-
};
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { selectActionButtons } from "@applicaster/zapp-react-native-utils/conf/player/selectors";
|
|
2
|
-
|
|
3
|
-
describe("selectActionButtons", () => {
|
|
4
|
-
it("returns the player_action_buttons array if present", () => {
|
|
5
|
-
const pluginConf = {
|
|
6
|
-
player_action_buttons: [
|
|
7
|
-
{ id: "like", label: "Like" },
|
|
8
|
-
{ id: "share", label: "Share" },
|
|
9
|
-
],
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
expect(selectActionButtons(pluginConf)).toEqual(
|
|
13
|
-
pluginConf.player_action_buttons
|
|
14
|
-
);
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
it("returns null if player_action_buttons is not present", () => {
|
|
18
|
-
const pluginConf = { some_other_key: [] };
|
|
19
|
-
expect(selectActionButtons(pluginConf)).toBeNull();
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
it("returns null if pluginConf is undefined", () => {
|
|
23
|
-
expect(selectActionButtons(undefined)).toBeNull();
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it("returns null if pluginConf is null", () => {
|
|
27
|
-
expect(selectActionButtons(null)).toBeNull();
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
it("returns null if player_action_buttons is explicitly set to null", () => {
|
|
31
|
-
const pluginConf = { player_action_buttons: null };
|
|
32
|
-
expect(selectActionButtons(pluginConf)).toBeNull();
|
|
33
|
-
});
|
|
34
|
-
});
|
package/conf/player/selectors.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { get } from "@applicaster/zapp-react-native-utils/utils";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Selects the action buttons from the player configuration.
|
|
5
|
-
* @param {Object} pluginConf - player plugin config
|
|
6
|
-
* @returns {Array|null} An array of action buttons or null if not found.
|
|
7
|
-
*/
|
|
8
|
-
export const selectActionButtons = (pluginConf: any) => {
|
|
9
|
-
return get(pluginConf, "player_action_buttons", null);
|
|
10
|
-
};
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { getMediaItems } from "..";
|
|
2
|
-
import { entry as baseEntry } from "./testEntry";
|
|
3
|
-
|
|
4
|
-
describe("getMediaItems", () => {
|
|
5
|
-
it("returns both image and thumbnail media items", () => {
|
|
6
|
-
const items = getMediaItems(baseEntry);
|
|
7
|
-
expect(items).toHaveLength(2);
|
|
8
|
-
expect(items[0].key).toBe("image_base");
|
|
9
|
-
expect(items[1].key).toBe("logo_thumbnail");
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
it("returns only image media items if no thumbnail present", () => {
|
|
13
|
-
const entry = {
|
|
14
|
-
...baseEntry,
|
|
15
|
-
media_group: [
|
|
16
|
-
{
|
|
17
|
-
type: "image",
|
|
18
|
-
media_item: [
|
|
19
|
-
{ key: "image_base", src: "img.png" },
|
|
20
|
-
{ key: "other", src: "other.png" },
|
|
21
|
-
],
|
|
22
|
-
},
|
|
23
|
-
],
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
const items = getMediaItems(entry);
|
|
27
|
-
expect(items).toHaveLength(2);
|
|
28
|
-
expect(items[0].key).toBe("image_base");
|
|
29
|
-
expect(items[1].key).toBe("other");
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
it("returns only thumbnail media items if no image present", () => {
|
|
33
|
-
const entry = {
|
|
34
|
-
...baseEntry,
|
|
35
|
-
media_group: [
|
|
36
|
-
{
|
|
37
|
-
type: "thumbnail",
|
|
38
|
-
media_item: [{ key: "thumb1", src: "thumb1.png" }],
|
|
39
|
-
},
|
|
40
|
-
],
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
const items = getMediaItems(entry);
|
|
44
|
-
expect(items).toHaveLength(1);
|
|
45
|
-
expect(items[0].key).toBe("thumb1");
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
it("returns undefined if no media_group present", () => {
|
|
49
|
-
const entry = { ...baseEntry };
|
|
50
|
-
delete entry.media_group;
|
|
51
|
-
expect(getMediaItems(entry)).toBeUndefined();
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it("returns undefined if media_group is present but has no image or thumbnail", () => {
|
|
55
|
-
const entry = {
|
|
56
|
-
...baseEntry,
|
|
57
|
-
media_group: [
|
|
58
|
-
{ type: "audio", media_item: [{ key: "audio1", src: "audio1.mp3" }] },
|
|
59
|
-
],
|
|
60
|
-
};
|
|
61
|
-
|
|
62
|
-
const items = getMediaItems(entry);
|
|
63
|
-
expect(items).toBeUndefined();
|
|
64
|
-
});
|
|
65
|
-
});
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import * as R from "ramda";
|
|
2
|
-
import { imageSrcFromMediaItem } from "../";
|
|
3
|
-
import { entry } from "./testEntry";
|
|
4
|
-
|
|
5
|
-
describe("imageSrcFromMediaItem", () => {
|
|
6
|
-
it("when the matching key is found and the src is not empty", () => {
|
|
7
|
-
const result = imageSrcFromMediaItem(entry as ZappEntry, [
|
|
8
|
-
"logo_thumbnail",
|
|
9
|
-
]);
|
|
10
|
-
|
|
11
|
-
expect(result).toEqual(entry.media_group[1].media_item[0].src);
|
|
12
|
-
expect(result).not.toEqual("");
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("returns a media item with the 'image_base' key as a fallback", () => {
|
|
16
|
-
const result = imageSrcFromMediaItem(entry as ZappEntry, [
|
|
17
|
-
"does_not_exist",
|
|
18
|
-
]);
|
|
19
|
-
|
|
20
|
-
const fallback = entry.media_group[0].media_item[0];
|
|
21
|
-
expect(result).toEqual(fallback.src);
|
|
22
|
-
expect(fallback.key).toBe("image_base");
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
it("returns undefined if the key was found but the source was empty", () => {
|
|
26
|
-
const badEntry: ZappEntry = R.set(
|
|
27
|
-
R.lensPath(["media_group", 0, "media_item", 0, "src"]),
|
|
28
|
-
"",
|
|
29
|
-
entry
|
|
30
|
-
);
|
|
31
|
-
|
|
32
|
-
expect(imageSrcFromMediaItem(badEntry, ["image_base"])).toBeUndefined();
|
|
33
|
-
});
|
|
34
|
-
});
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
const R = require("ramda");
|
|
2
|
-
const { defaultConfigurations } = require("../defaultManifestConfigurations");
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* returns default configuration keys for provided plugin type
|
|
6
|
-
* @param {('general-content'|'player')} pluginType
|
|
7
|
-
* @param options manifest generator information
|
|
8
|
-
* @param {string} options.version manifest version
|
|
9
|
-
* @param {string} options.platform qb platform value
|
|
10
|
-
*/
|
|
11
|
-
function getDefaultConfiguration(pluginType, options) {
|
|
12
|
-
const defConfig = R.compose(
|
|
13
|
-
R.unless(R.isNil, (fn) => fn(options)),
|
|
14
|
-
R.propOr(null, pluginType)
|
|
15
|
-
)(defaultConfigurations);
|
|
16
|
-
|
|
17
|
-
if (!defConfig) {
|
|
18
|
-
const availableKeys = R.keys(defaultConfigurations);
|
|
19
|
-
|
|
20
|
-
const message = `Requested key "${pluginType}" doesn't exist in the default configuration\nAvailable keys: ${availableKeys}`;
|
|
21
|
-
// eslint-disable-next-line no-console
|
|
22
|
-
console.warn(message);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
return defConfig;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
module.exports = { getDefaultConfiguration };
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { getPlayerActionButtons } from "../getPlayerActionButtons";
|
|
2
|
-
import { selectActionButtons } from "../../conf/player/selectors";
|
|
3
|
-
|
|
4
|
-
jest.mock("../../conf/player/selectors", () => ({
|
|
5
|
-
selectActionButtons: jest.fn(),
|
|
6
|
-
}));
|
|
7
|
-
|
|
8
|
-
describe("getPlayerActionButtons", () => {
|
|
9
|
-
afterEach(() => {
|
|
10
|
-
jest.clearAllMocks();
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
it("returns an empty array if selectActionButtons returns undefined", () => {
|
|
14
|
-
(selectActionButtons as jest.Mock).mockReturnValue(undefined);
|
|
15
|
-
const result = getPlayerActionButtons({});
|
|
16
|
-
expect(result).toEqual([]);
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
it("returns an empty array if selectActionButtons returns null", () => {
|
|
20
|
-
(selectActionButtons as jest.Mock).mockReturnValue(null);
|
|
21
|
-
const result = getPlayerActionButtons({});
|
|
22
|
-
expect(result).toEqual([]);
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
it("returns an empty array if selectActionButtons returns empty string", () => {
|
|
26
|
-
(selectActionButtons as jest.Mock).mockReturnValue("");
|
|
27
|
-
const result = getPlayerActionButtons({});
|
|
28
|
-
expect(result).toEqual([]);
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it("returns the first two trimmed action buttons", () => {
|
|
32
|
-
(selectActionButtons as jest.Mock).mockReturnValue(" play , pause , stop ");
|
|
33
|
-
const result = getPlayerActionButtons({});
|
|
34
|
-
expect(result).toEqual(["play", "pause"]);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it("returns only one button if only one is present", () => {
|
|
38
|
-
(selectActionButtons as jest.Mock).mockReturnValue(" play ");
|
|
39
|
-
const result = getPlayerActionButtons({});
|
|
40
|
-
expect(result).toEqual(["play"]);
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
it("trims whitespace from button names", () => {
|
|
44
|
-
(selectActionButtons as jest.Mock).mockReturnValue(" play , pause ");
|
|
45
|
-
const result = getPlayerActionButtons({});
|
|
46
|
-
expect(result).toEqual(["play", "pause"]);
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it("returns an empty array if selectActionButtons returns only commas", () => {
|
|
50
|
-
(selectActionButtons as jest.Mock).mockReturnValue(" , , ");
|
|
51
|
-
const result = getPlayerActionButtons({});
|
|
52
|
-
expect(result).toEqual(["", ""]);
|
|
53
|
-
});
|
|
54
|
-
});
|
|
@@ -1,71 +0,0 @@
|
|
|
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
|
-
});
|