@streamscloud/embeddable 13.0.1 → 13.2.0
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/dist/core/utils/utils.d.ts +1 -0
- package/dist/core/utils/utils.js +4 -0
- package/dist/external-api/data-providers/internal-media-center-data-provider.svelte.d.ts +2 -0
- package/dist/external-api/data-providers/internal-media-center-data-provider.svelte.js +4 -3
- package/dist/media-center/config/types.d.ts +2 -1
- package/dist/media-center/media-center/cmp.media-center-proxy.svelte +8 -3
- package/dist/media-center/media-center/discover/community-features.svelte +3 -3
- package/dist/media-center/media-center/discover/data-loading.js +2 -2
- package/dist/media-center/media-center/discover/discover-view-handler.svelte.d.ts +11 -3
- package/dist/media-center/media-center/discover/discover-view-handler.svelte.js +26 -13
- package/dist/media-center/media-center/discover/discover-view-localization.d.ts +1 -0
- package/dist/media-center/media-center/discover/discover-view-localization.js +6 -0
- package/dist/media-center/media-center/discover/discover-view.svelte +84 -60
- package/dist/media-center/media-center/footer/media-center-footer.svelte +1 -1
- package/dist/media-center/media-center/header/media-center-header.svelte +11 -7
- package/dist/media-center/media-center/media-center-context.svelte.d.ts +14 -10
- package/dist/media-center/media-center/media-center-context.svelte.js +102 -43
- package/dist/media-center/media-center/media-center-settings.svelte.d.ts +3 -1
- package/dist/media-center/media-center/media-center-settings.svelte.js +8 -14
- package/dist/media-center/media-center/media-center-view.svelte +22 -25
- package/dist/media-center/media-center/moments/moments-feed-handler.svelte.d.ts +13 -4
- package/dist/media-center/media-center/moments/moments-feed-handler.svelte.js +30 -6
- package/dist/media-center/media-center/moments/moments-state.svelte.d.ts +4 -1
- package/dist/media-center/media-center/moments/moments-state.svelte.js +10 -2
- package/dist/media-center/media-center/{feed → posts-feed}/feed-providers-generator.d.ts +4 -8
- package/dist/media-center/media-center/posts-feed/feed-providers-generator.js +61 -0
- package/dist/media-center/media-center/posts-feed/index.d.ts +1 -0
- package/dist/media-center/media-center/posts-feed/index.js +1 -0
- package/dist/media-center/media-center/posts-feed/posts-feed-handler.svelte.d.ts +42 -0
- package/dist/media-center/media-center/posts-feed/posts-feed-handler.svelte.js +106 -0
- package/dist/media-center/media-center/posts-feed/types.d.ts +8 -0
- package/dist/media-center/media-center/streams-feed/feed-providers-generator.d.ts +12 -0
- package/dist/media-center/media-center/streams-feed/feed-providers-generator.js +56 -0
- package/dist/media-center/media-center/streams-feed/index.d.ts +1 -0
- package/dist/media-center/media-center/streams-feed/index.js +1 -0
- package/dist/media-center/media-center/streams-feed/streams-feed-handler.svelte.d.ts +45 -0
- package/dist/media-center/media-center/streams-feed/streams-feed-handler.svelte.js +111 -0
- package/dist/media-center/media-center/streams-feed/types.d.ts +9 -0
- package/dist/media-center/media-center/types.d.ts +3 -1
- package/dist/media-center/navigation/index.d.ts +1 -1
- package/dist/media-center/navigation/{media-center-state.d.ts → media-center-state.types.d.ts} +4 -3
- package/dist/media-center/navigation/media-center-state.types.js +1 -0
- package/dist/media-center/navigation/mock-navigation-handler.svelte.d.ts +3 -2
- package/dist/media-center/navigation/mock-navigation-handler.svelte.js +5 -2
- package/dist/media-center/navigation/types.d.ts +1 -2
- package/dist/media-page/cmp.media-page.svelte +1 -1
- package/dist/media-page/index.d.ts +4 -1
- package/dist/streams/streams-player/streams-player-view.svelte +4 -4
- package/dist/streams/streams-player/types.d.ts +5 -0
- package/dist/ui/player/providers/chunks-player-buffer/player-chunks-manager.svelte.d.ts +1 -0
- package/dist/ui/player/providers/chunks-player-buffer/player-chunks-manager.svelte.js +10 -0
- package/dist/ui/player/providers/default-chunks-player-buffer.svelte.d.ts +1 -0
- package/dist/ui/player/providers/default-chunks-player-buffer.svelte.js +3 -0
- package/dist/ui/player/providers/default-feed-player-buffer.svelte.d.ts +1 -0
- package/dist/ui/player/providers/default-feed-player-buffer.svelte.js +8 -0
- package/dist/ui/player/providers/types.d.ts +1 -0
- package/dist/ui/player/slider/cmp.player-slider.svelte +1 -1
- package/dist/ui/shadow-dom/cmp.shadow-root.svelte +2 -0
- package/dist/ui/shadow-dom/colors.scss +2 -0
- package/package.json +9 -7
- package/dist/media-center/media-center/feed/feed-handler.svelte.d.ts +0 -52
- package/dist/media-center/media-center/feed/feed-handler.svelte.js +0 -92
- package/dist/media-center/media-center/feed/feed-providers-generator.js +0 -83
- package/dist/media-center/media-center/feed/index.d.ts +0 -1
- package/dist/media-center/media-center/feed/index.js +0 -1
- package/dist/media-center/media-center/feed/types.d.ts +0 -12
- /package/dist/media-center/media-center/{feed → posts-feed}/types.js +0 -0
- /package/dist/media-center/{navigation/media-center-state.js → media-center/streams-feed/types.js} +0 -0
|
@@ -13,6 +13,7 @@ export declare class DefaultChunksPlayerBuffer<TItem extends WithId, TChunk exte
|
|
|
13
13
|
constructor(provider: IChunksPlayerDataProvider<TItem, TChunk>);
|
|
14
14
|
get activeChunk(): import("./chunks-player-buffer").PlayerChunk<TItem, TChunk>;
|
|
15
15
|
setActiveChunkItemIndex: (index: number) => void;
|
|
16
|
+
tryActivateItemById: (id: string) => boolean;
|
|
16
17
|
loadNext: () => Promise<void>;
|
|
17
18
|
loadPrevious: () => Promise<void>;
|
|
18
19
|
reset: () => void;
|
|
@@ -28,6 +28,9 @@ export class DefaultChunksPlayerBuffer {
|
|
|
28
28
|
}
|
|
29
29
|
this.activeChunk.setActiveItemIndex(index);
|
|
30
30
|
};
|
|
31
|
+
tryActivateItemById = (id) => {
|
|
32
|
+
return this._playerChunksManager.tryActivateItemById(id);
|
|
33
|
+
};
|
|
31
34
|
loadNext = async () => {
|
|
32
35
|
if (!this.canLoadNext) {
|
|
33
36
|
return;
|
|
@@ -18,6 +18,7 @@ export declare class DefaultFeedPlayerBuffer<T extends WithId> implements IFeedP
|
|
|
18
18
|
private _fetchDeferred;
|
|
19
19
|
private _onEndReachedFn;
|
|
20
20
|
constructor(provider: IFeedPlayerDataProvider<T>);
|
|
21
|
+
tryActivateItemById: (id: string) => boolean;
|
|
21
22
|
loadNext: () => Promise<void>;
|
|
22
23
|
loadPrevious: () => Promise<void>;
|
|
23
24
|
reset: () => void;
|
|
@@ -23,6 +23,14 @@ export class DefaultFeedPlayerBuffer {
|
|
|
23
23
|
this.loadPrevious = Utils.throttle(this.loadPrevious, this.animationDuration);
|
|
24
24
|
this.initializeBuffer({ initialData: provider.initialData });
|
|
25
25
|
}
|
|
26
|
+
tryActivateItemById = (id) => {
|
|
27
|
+
const itemIndex = this._loaded.findIndex((item) => item.id === id);
|
|
28
|
+
if (itemIndex === -1) {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
this._currentIndex = itemIndex;
|
|
32
|
+
return true;
|
|
33
|
+
};
|
|
26
34
|
loadNext = async () => {
|
|
27
35
|
if (!this.canLoadNext) {
|
|
28
36
|
return;
|
|
@@ -77,6 +77,7 @@ const styles = $derived.by(() => {
|
|
|
77
77
|
--sc-mc-color--text-brand: #144ab0;
|
|
78
78
|
--sc-mc-color--text-inverted: #ffffff;
|
|
79
79
|
--sc-mc-color--text-primary: #000000;
|
|
80
|
+
--sc-mc-color--text-primary-shadow: 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 3px rgba(255, 255, 255, 0.1), 0 1px 6px rgba(255, 255, 255, 0.05);
|
|
80
81
|
--sc-mc-color--text-secondary: #6b7280;
|
|
81
82
|
--sc-mc-color--text-white: #ffffff;
|
|
82
83
|
--sc-mc-color--text-white-shadow: 0 1px 0 rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 6px rgba(0, 0, 0, 0.05);
|
|
@@ -109,6 +110,7 @@ const styles = $derived.by(() => {
|
|
|
109
110
|
--sc-mc-color--text-brand: #5a8dec;
|
|
110
111
|
--sc-mc-color--text-inverted: #ffffff;
|
|
111
112
|
--sc-mc-color--text-primary: #ffffff;
|
|
113
|
+
--sc-mc-color--text-primary-shadow: 0 1px 0 rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 6px rgba(0, 0, 0, 0.05);
|
|
112
114
|
--sc-mc-color--text-secondary: #d1d5db;
|
|
113
115
|
--sc-mc-color--text-white: #ffffff;
|
|
114
116
|
--sc-mc-color--text-white-shadow: 0 1px 0 rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 6px rgba(0, 0, 0, 0.05);
|
|
@@ -31,6 +31,7 @@
|
|
|
31
31
|
--sc-mc-color--text-brand: #{colors.$color-primary-500};
|
|
32
32
|
--sc-mc-color--text-inverted: #{colors.$color-white};
|
|
33
33
|
--sc-mc-color--text-primary: #{colors.$color-black};
|
|
34
|
+
--sc-mc-color--text-primary-shadow: 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 3px rgba(255, 255, 255, 0.1), 0 1px 6px rgba(255, 255, 255, 0.05);
|
|
34
35
|
--sc-mc-color--text-secondary: #{colors.$color-neutral-500};
|
|
35
36
|
--sc-mc-color--text-white: #{colors.$color-white};
|
|
36
37
|
--sc-mc-color--text-white-shadow: 0 1px 0 rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 6px rgba(0, 0, 0, 0.05);
|
|
@@ -67,6 +68,7 @@
|
|
|
67
68
|
--sc-mc-color--text-brand: #{colors.$color-primary-400};
|
|
68
69
|
--sc-mc-color--text-inverted: #{colors.$color-white};
|
|
69
70
|
--sc-mc-color--text-primary: #{colors.$color-white};
|
|
71
|
+
--sc-mc-color--text-primary-shadow: 0 1px 0 rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 6px rgba(0, 0, 0, 0.05);
|
|
70
72
|
--sc-mc-color--text-secondary: #{colors.$color-neutral-300};
|
|
71
73
|
--sc-mc-color--text-white: #{colors.$color-white};
|
|
72
74
|
--sc-mc-color--text-white-shadow: 0 1px 0 rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 6px rgba(0, 0, 0, 0.05);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@streamscloud/embeddable",
|
|
3
|
-
"version": "13.0
|
|
3
|
+
"version": "13.2.0",
|
|
4
4
|
"author": "StreamsCloud",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -129,12 +129,15 @@
|
|
|
129
129
|
}
|
|
130
130
|
},
|
|
131
131
|
"peerDependencies": {
|
|
132
|
-
"@fluentui/svg-icons": "^1.1.
|
|
132
|
+
"@fluentui/svg-icons": "^1.1.301",
|
|
133
|
+
"@popperjs/core": "^2.11.8",
|
|
133
134
|
"@streamscloud/streams-analytics-collector": "^2.0.9",
|
|
134
135
|
"@urql/core": "^5.1.1",
|
|
136
|
+
"dequal": "^2.0.3",
|
|
135
137
|
"dompurify": "^3.2.6",
|
|
136
138
|
"mobile-detect": "^1.4.5",
|
|
137
|
-
"svelte": "^5.33.4"
|
|
139
|
+
"svelte": "^5.33.4",
|
|
140
|
+
"wheel-gestures": "^2.2.48"
|
|
138
141
|
},
|
|
139
142
|
"devDependencies": {
|
|
140
143
|
"@eslint/compat": "^1.2.9",
|
|
@@ -149,11 +152,13 @@
|
|
|
149
152
|
"@graphql-codegen/typescript": "^4.1.6",
|
|
150
153
|
"@graphql-codegen/typescript-operations": "^4.6.1",
|
|
151
154
|
"@graphql-typed-document-node/core": "^3.2.0",
|
|
155
|
+
"@popperjs/core": "^2.11.8",
|
|
152
156
|
"@sveltejs/package": "^2.3.11",
|
|
153
157
|
"@sveltejs/vite-plugin-svelte": "^5.0.3",
|
|
154
158
|
"@tsconfig/svelte": "^5.0.4",
|
|
155
159
|
"@urql/core": "^5.1.1",
|
|
156
160
|
"autoprefixer": "^10.4.21",
|
|
161
|
+
"dequal": "^2.0.3",
|
|
157
162
|
"eslint": "^9.27.0",
|
|
158
163
|
"eslint-config-prettier": "^10.1.5",
|
|
159
164
|
"eslint-formatter-codeframe": "^7.32.1",
|
|
@@ -176,10 +181,7 @@
|
|
|
176
181
|
"typescript": "^5.8.3",
|
|
177
182
|
"typescript-eslint": "^8.32.1",
|
|
178
183
|
"vite": "^6.3.5",
|
|
179
|
-
"vite-tsconfig-paths": "^5.1.4"
|
|
180
|
-
},
|
|
181
|
-
"dependencies": {
|
|
182
|
-
"@popperjs/core": "^2.11.8",
|
|
184
|
+
"vite-tsconfig-paths": "^5.1.4",
|
|
183
185
|
"wheel-gestures": "^2.2.48"
|
|
184
186
|
}
|
|
185
187
|
}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import type { IMediaCenterDataProvider } from '../..';
|
|
2
|
-
import type { PostPlayerModel } from '../../../posts/posts-player';
|
|
3
|
-
import type { IStreamsPlayerDataProvider } from '../../../streams/streams-player';
|
|
4
|
-
import type { ICloseOrchestrator } from '../../../ui/player/close-orchestrator';
|
|
5
|
-
import type { IPlayerDataProvider } from '../../../ui/player/providers';
|
|
6
|
-
import { MediaCenterSettingsHandler } from '../handlers';
|
|
7
|
-
import type { PlayerProps } from '../types';
|
|
8
|
-
import type { PostsDataProviderFilter, StreamsDataProviderFilter } from './types';
|
|
9
|
-
export declare class FeedHandler {
|
|
10
|
-
private _active;
|
|
11
|
-
private _providersGenerator;
|
|
12
|
-
private _feedPlayerProps;
|
|
13
|
-
private _dataProvider;
|
|
14
|
-
private _mediaCenterSettingsHandler;
|
|
15
|
-
private _closeOrchestrator;
|
|
16
|
-
private _onPlayerReachedEnd;
|
|
17
|
-
constructor(data: {
|
|
18
|
-
dataProvider: IMediaCenterDataProvider;
|
|
19
|
-
mediaCenterSettingsHandler: MediaCenterSettingsHandler;
|
|
20
|
-
closeOrchestrator: ICloseOrchestrator;
|
|
21
|
-
onPlayerReachedEnd: () => void;
|
|
22
|
-
});
|
|
23
|
-
get active(): boolean;
|
|
24
|
-
get feedPlayerProps(): PlayerProps | null;
|
|
25
|
-
deactivate: () => void;
|
|
26
|
-
activatePostsFeed: (options: {
|
|
27
|
-
dataProvider?: IPlayerDataProvider<PostPlayerModel>;
|
|
28
|
-
filter?: PostsDataProviderFilter;
|
|
29
|
-
onPostActivated?: (id: string) => void;
|
|
30
|
-
}) => Promise<void>;
|
|
31
|
-
activateStreamsFeed: (options: {
|
|
32
|
-
dataProvider?: IStreamsPlayerDataProvider;
|
|
33
|
-
filter?: StreamsDataProviderFilter;
|
|
34
|
-
onStreamActivated?: (data: {
|
|
35
|
-
title: string;
|
|
36
|
-
image: string | null;
|
|
37
|
-
}) => void;
|
|
38
|
-
}) => Promise<void>;
|
|
39
|
-
private makePostsPlayerProps;
|
|
40
|
-
private makeStreamsPlayerProps;
|
|
41
|
-
}
|
|
42
|
-
export type MakePostsPlayerPropsData = {
|
|
43
|
-
dataProvider: IPlayerDataProvider<PostPlayerModel>;
|
|
44
|
-
onPostActivated?: (id: string) => void;
|
|
45
|
-
};
|
|
46
|
-
export type MakeStreamsPlayerPropsData = {
|
|
47
|
-
dataProvider: IStreamsPlayerDataProvider;
|
|
48
|
-
onStreamActivated?: (data: {
|
|
49
|
-
title: string;
|
|
50
|
-
image: string | null;
|
|
51
|
-
}) => void;
|
|
52
|
-
};
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import { StreamsPlayerBuffer } from '../../../streams/streams-player/streams-player-buffer.svelte';
|
|
2
|
-
import { initBufferFromProvider } from '../../../ui/player/providers/service';
|
|
3
|
-
import { MediaCenterSettingsHandler } from '../handlers';
|
|
4
|
-
import { FeedProvidersGenerator } from './feed-providers-generator';
|
|
5
|
-
export class FeedHandler {
|
|
6
|
-
_active = $state(false);
|
|
7
|
-
_providersGenerator;
|
|
8
|
-
_feedPlayerProps = $state.raw(null);
|
|
9
|
-
_dataProvider;
|
|
10
|
-
_mediaCenterSettingsHandler;
|
|
11
|
-
_closeOrchestrator;
|
|
12
|
-
_onPlayerReachedEnd;
|
|
13
|
-
constructor(data) {
|
|
14
|
-
const { dataProvider, mediaCenterSettingsHandler, closeOrchestrator, onPlayerReachedEnd } = data;
|
|
15
|
-
this._providersGenerator = new FeedProvidersGenerator(dataProvider);
|
|
16
|
-
this._mediaCenterSettingsHandler = mediaCenterSettingsHandler;
|
|
17
|
-
this._dataProvider = dataProvider;
|
|
18
|
-
this._closeOrchestrator = closeOrchestrator;
|
|
19
|
-
this._onPlayerReachedEnd = onPlayerReachedEnd;
|
|
20
|
-
}
|
|
21
|
-
get active() {
|
|
22
|
-
return this._active;
|
|
23
|
-
}
|
|
24
|
-
get feedPlayerProps() {
|
|
25
|
-
return this._feedPlayerProps;
|
|
26
|
-
}
|
|
27
|
-
deactivate = () => {
|
|
28
|
-
this._active = false;
|
|
29
|
-
};
|
|
30
|
-
activatePostsFeed = async (options) => {
|
|
31
|
-
const { dataProvider, filter, onPostActivated } = options;
|
|
32
|
-
if (dataProvider) {
|
|
33
|
-
if (!dataProvider.onEndReached) {
|
|
34
|
-
dataProvider.onEndReached = this._onPlayerReachedEnd;
|
|
35
|
-
}
|
|
36
|
-
this._feedPlayerProps = this.makePostsPlayerProps({ dataProvider, onPostActivated });
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
const dataProvider = this._providersGenerator.makePostPlayerItemsProvider({ filter, onEndReached: this._onPlayerReachedEnd });
|
|
40
|
-
this._feedPlayerProps = this.makePostsPlayerProps({ dataProvider, onPostActivated });
|
|
41
|
-
}
|
|
42
|
-
this._active = true;
|
|
43
|
-
};
|
|
44
|
-
activateStreamsFeed = async (options) => {
|
|
45
|
-
const { dataProvider, filter, onStreamActivated } = options;
|
|
46
|
-
if (dataProvider) {
|
|
47
|
-
if (!dataProvider.onEndReached) {
|
|
48
|
-
dataProvider.onEndReached = this._onPlayerReachedEnd;
|
|
49
|
-
}
|
|
50
|
-
this._feedPlayerProps = this.makeStreamsPlayerProps({ dataProvider, onStreamActivated });
|
|
51
|
-
}
|
|
52
|
-
else {
|
|
53
|
-
const dataProvider = this._providersGenerator.makeStreamsPlayerDataProvider({ filter, onEndReached: this._onPlayerReachedEnd });
|
|
54
|
-
this._feedPlayerProps = this.makeStreamsPlayerProps({ dataProvider, onStreamActivated });
|
|
55
|
-
}
|
|
56
|
-
this._active = true;
|
|
57
|
-
};
|
|
58
|
-
makePostsPlayerProps = (data) => {
|
|
59
|
-
const { dataProvider, onPostActivated } = data;
|
|
60
|
-
return {
|
|
61
|
-
type: 'posts',
|
|
62
|
-
props: {
|
|
63
|
-
dataProvider: { type: 'buffer', buffer: initBufferFromProvider(dataProvider) },
|
|
64
|
-
socialInteractionsHandler: this._dataProvider.handlers?.socialInteractionsHandler,
|
|
65
|
-
analyticsHandler: this._dataProvider.handlers?.analyticsHandler,
|
|
66
|
-
playerSettings: this._mediaCenterSettingsHandler.playerSettings,
|
|
67
|
-
closeOrchestrator: this._closeOrchestrator,
|
|
68
|
-
on: {
|
|
69
|
-
postActivated: onPostActivated,
|
|
70
|
-
backgroundImageLoaded: this._mediaCenterSettingsHandler.backgroundImageLoadedHandler
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
};
|
|
75
|
-
makeStreamsPlayerProps = (data) => {
|
|
76
|
-
const { dataProvider, onStreamActivated } = data;
|
|
77
|
-
return {
|
|
78
|
-
type: 'streams',
|
|
79
|
-
props: {
|
|
80
|
-
dataProvider: { type: 'buffer', buffer: new StreamsPlayerBuffer(dataProvider) },
|
|
81
|
-
analyticsHandler: this._dataProvider.handlers?.analyticsHandler,
|
|
82
|
-
postSocialInteractionsHandler: this._dataProvider.handlers?.socialInteractionsHandler,
|
|
83
|
-
playerSettings: this._mediaCenterSettingsHandler.playerSettings,
|
|
84
|
-
closeOrchestrator: this._closeOrchestrator,
|
|
85
|
-
on: {
|
|
86
|
-
streamActivated: onStreamActivated,
|
|
87
|
-
backgroundImageLoaded: this._mediaCenterSettingsHandler.backgroundImageLoadedHandler
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
};
|
|
91
|
-
};
|
|
92
|
-
}
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { ContinuationToken } from '../../../core/continuation-token';
|
|
2
|
-
import { CursorDataLoader } from '../../../core/data-loaders';
|
|
3
|
-
import { PostType } from '../../../core/enums';
|
|
4
|
-
export class FeedProvidersGenerator {
|
|
5
|
-
dataProvider;
|
|
6
|
-
constructor(dataProvider) {
|
|
7
|
-
this.dataProvider = dataProvider;
|
|
8
|
-
}
|
|
9
|
-
makePostPlayerItemsProvider = (data) => {
|
|
10
|
-
const { filter, onEndReached } = data;
|
|
11
|
-
const { categoryId, prefetchedItems: initialPrefetchedItems = [], initialPostId } = filter || {};
|
|
12
|
-
const loader = new CursorDataLoader({
|
|
13
|
-
loadPage: async (continuationToken) => {
|
|
14
|
-
const result = await this.dataProvider.postsPlayer.getPostsCursor({
|
|
15
|
-
filter: {
|
|
16
|
-
types: [PostType.Article, PostType.Media, PostType.ShortVideo, PostType.Video],
|
|
17
|
-
categoryId,
|
|
18
|
-
excludeIds: initialPrefetchedItems.length ? initialPrefetchedItems.map((i) => i.id) : undefined
|
|
19
|
-
},
|
|
20
|
-
continuationToken: continuationToken.toNextChunkString(),
|
|
21
|
-
limit: 20
|
|
22
|
-
});
|
|
23
|
-
const items = result.items;
|
|
24
|
-
return {
|
|
25
|
-
items: items,
|
|
26
|
-
continuationToken: ContinuationToken.fromPayload(result.continuationToken)
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
});
|
|
30
|
-
let prefetchedItems = initialPrefetchedItems;
|
|
31
|
-
if (initialPostId) {
|
|
32
|
-
const targetPost = prefetchedItems.find((p) => p.id === initialPostId);
|
|
33
|
-
if (targetPost) {
|
|
34
|
-
prefetchedItems = [targetPost, ...prefetchedItems.filter((p) => p.id !== initialPostId)];
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
return {
|
|
38
|
-
kind: 'feed',
|
|
39
|
-
initialData: {
|
|
40
|
-
prefetchedItems,
|
|
41
|
-
startIndex: prefetchedItems.length ? 0 : -1
|
|
42
|
-
},
|
|
43
|
-
loadMore: loader.loadMore,
|
|
44
|
-
onEndReached
|
|
45
|
-
};
|
|
46
|
-
};
|
|
47
|
-
makeStreamsPlayerDataProvider = (data) => {
|
|
48
|
-
const { filter, onEndReached } = data;
|
|
49
|
-
const { categoryId, prefetchedStreams: initialPrefetchedStreams = [], initialStreamId } = filter || {};
|
|
50
|
-
const loader = new CursorDataLoader({
|
|
51
|
-
loadPage: async (continuationToken) => {
|
|
52
|
-
const result = await this.dataProvider.streamPlayer.getStreamsCursor({
|
|
53
|
-
filter: {
|
|
54
|
-
categoryId,
|
|
55
|
-
excludeIds: initialPrefetchedStreams.length ? initialPrefetchedStreams.map((i) => i.id) : undefined
|
|
56
|
-
},
|
|
57
|
-
continuationToken: continuationToken.toNextChunkString(),
|
|
58
|
-
limit: 20
|
|
59
|
-
});
|
|
60
|
-
const items = result.items;
|
|
61
|
-
return {
|
|
62
|
-
items: items,
|
|
63
|
-
continuationToken: ContinuationToken.fromPayload(result.continuationToken)
|
|
64
|
-
};
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
let prefetchedStreams = initialPrefetchedStreams;
|
|
68
|
-
if (initialStreamId) {
|
|
69
|
-
const targetStream = prefetchedStreams.find((stream) => stream.id === initialStreamId);
|
|
70
|
-
if (targetStream) {
|
|
71
|
-
prefetchedStreams = [targetStream, ...prefetchedStreams.filter((stream) => stream.id !== initialStreamId)];
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
return {
|
|
75
|
-
initialData: {
|
|
76
|
-
prefetchedStreams
|
|
77
|
-
},
|
|
78
|
-
loadMoreStreams: loader.loadMore,
|
|
79
|
-
getStreamPages: this.dataProvider.streamPlayer.getStreamPages,
|
|
80
|
-
onEndReached
|
|
81
|
-
};
|
|
82
|
-
};
|
|
83
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { FeedHandler } from './feed-handler.svelte';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { FeedHandler } from './feed-handler.svelte';
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { PostPlayerModel } from '../../../posts/posts-player/types';
|
|
2
|
-
import type { StreamPlayerModel } from '../../../streams/streams-player/types';
|
|
3
|
-
export type PostsDataProviderFilter = {
|
|
4
|
-
categoryId?: string;
|
|
5
|
-
prefetchedItems?: PostPlayerModel[];
|
|
6
|
-
initialPostId?: string;
|
|
7
|
-
};
|
|
8
|
-
export type StreamsDataProviderFilter = {
|
|
9
|
-
categoryId?: string;
|
|
10
|
-
prefetchedStreams?: StreamPlayerModel[];
|
|
11
|
-
initialStreamId?: string;
|
|
12
|
-
};
|
|
File without changes
|
/package/dist/media-center/{navigation/media-center-state.js → media-center/streams-feed/types.js}
RENAMED
|
File without changes
|