Skip to content
This repository has been archived by the owner on Dec 24, 2024. It is now read-only.

Commit

Permalink
Merge pull request #93 from Stremio/feat/library-item-notifications-c…
Browse files Browse the repository at this point in the history
…ount

feat: add notifications count for library items
  • Loading branch information
tymmesyde authored Feb 2, 2024
2 parents b5008ed + 3bdc6cc commit 76f85f7
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 10 deletions.
6 changes: 2 additions & 4 deletions src/model/model.rs
Original file line number Diff line number Diff line change
Expand Up @@ -140,16 +140,14 @@ impl WebModel {
}
WebModelField::Library => serialize_library(
&self.library,
&self.ctx.streams,
&self.ctx,
self.streaming_server.base_url.as_ref(),
&self.ctx.profile.settings,
"library".to_owned(),
),
WebModelField::ContinueWatching => serialize_library(
&self.continue_watching,
&self.ctx.streams,
&self.ctx,
self.streaming_server.base_url.as_ref(),
&self.ctx.profile.settings,
"continuewatching".to_owned(),
),
WebModelField::Search => serialize_catalogs_with_extra(&self.search, &self.ctx),
Expand Down
17 changes: 11 additions & 6 deletions src/model/serialize_library.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@ use crate::model::deep_links_ext::DeepLinksExt;
use gloo_utils::format::JsValueSerdeExt;
use serde::Serialize;
use stremio_core::deep_links::{LibraryDeepLinks, LibraryItemDeepLinks};
use stremio_core::models::ctx::Ctx;
use stremio_core::models::library_with_filters::{LibraryWithFilters, Selected, Sort};
use stremio_core::types::profile::Settings;
use stremio_core::types::resource::PosterShape;
use stremio_core::types::streams::{StreamsBucket, StreamsItemKey};
use stremio_core::types::streams::StreamsItemKey;
use url::Url;
use wasm_bindgen::JsValue;

Expand All @@ -20,6 +20,7 @@ mod model {
pub r#type: &'a String,
pub poster: &'a Option<Url>,
pub poster_shape: &'a PosterShape,
pub notifications: usize,
pub progress: f64,
pub watched: bool,
pub deep_links: LibraryItemDeepLinks,
Expand Down Expand Up @@ -61,9 +62,8 @@ mod model {

pub fn serialize_library<F>(
library: &LibraryWithFilters<F>,
streams_bucket: &StreamsBucket,
ctx: &Ctx,
streaming_server_url: Option<&Url>,
settings: &Settings,
root: String,
) -> JsValue {
<JsValue as JsValueSerdeExt>::from_serde(&model::LibraryWithFilters {
Expand Down Expand Up @@ -111,7 +111,7 @@ pub fn serialize_library<F>(
// Try to get the stream from the StreamBucket
// given that we have a video_id in the LibraryItemState!
let streams_item = library_item.state.video_id.as_ref().and_then(|video_id| {
streams_bucket.items.get(&StreamsItemKey {
ctx.streams.items.get(&StreamsItemKey {
meta_id: library_item.id.to_owned(),
video_id: video_id.to_owned(),
})
Expand All @@ -127,13 +127,18 @@ pub fn serialize_library<F>(
} else {
&library_item.poster_shape
},
notifications: ctx
.notifications
.items
.get(&library_item.id)
.map_or(0, |item| item.len()),
progress: library_item.progress(),
watched: library_item.watched(),
deep_links: LibraryItemDeepLinks::from((
library_item,
streams_item,
streaming_server_url,
settings,
&ctx.profile.settings,
))
.into_web_deep_links(),
}
Expand Down

0 comments on commit 76f85f7

Please sign in to comment.