FeedProvider and useFeed Hook
The FeedProvider
and useFeed
hook are central to implementing feeds in Replyke. Here, we’ll explore how they work and the properties that can be passed to customize their behavior.
Using the FeedProvider
To integrate feeds into your app, wrap any content requiring feed context with the FeedProvider
. All child components within the provider gain access to the feed’s data and functions via the useFeed
hook.
Multiple Feed Providers
You are not limited to a single feed in your app. You can implement multiple feeds as needed, but avoid wrapping any content with more than one FeedProvider
, as this can cause unexpected behavior. For instance, you can use multiple FeedProvider
instances on the same screen. In a social app’s home screen, you could display two feeds side by side—one sorted by “new” and the other by “popularity”—and allow users to switch between them with gestures.
FeedProvider Properties
Below is the interface for FeedContextProps
, followed by an explanation of each property:
interface FeedContextProps {
userId?: string | null;
sortBy?: FeedSortByOptions;
limit?: number;
followedOnly?: boolean;
timeFrame?: TimeFrame | null;
keywordsFilters?: KeywordsFilters | null;
titleFilters?: TitleFilters | null;
contentFilters?: ContentFilters | null;
mediaFilters?: MediaFilters | null;
locationFilters?: LocationFilters | null;
metadataFilters?: MetadataFilters | null;
onReset?: () => void;
infuseData?: (referenceId: string) => Promise<Record<string, any> | null>;
}
Detailed Explanation of Properties
The FeedProvider
accepts the following properties to customize the feed:
userId
: If a user ID is provided, the feed will include only entities created by that user. This property is particularly useful for building user profile pages. If no user ID is provided, the feed will not filter by user. By default, this property is set to null
.
sortBy
: Determines the default sorting criteria for the feed. Available options include:
"top"
: Sorts entities by net upvotes (upvotes minus downvotes)."hot"
: Sorts by a “hotness” score, auto-generated by Replyke."new"
: Sorts entities by creation date, with the newest appearing first."controversial"
: Sorts by mixed voting score.
By default, this property is set to "hot"
. Note that sorting by time frame (e.g., “hour,” “day,” “week,” etc.) restricts results to entities created within the specified period.
limit
: Specifies the number of entities fetched per “page” when loading more entities. A lower limit reduces costs by avoiding redundant fetching. If no value is provided, the default is 10
.
followedOnly
: A boolean flag that, when set to true
, limits the feed to entities created by accounts the currently logged-in user follows. This property defaults to false
.
timeFrame
: Restricts the feed to entities created within a specific time frame. Supported options include:
"hour"
: Only includes entities created in the last hour."day"
: Includes entities created in the past 24 hours."week"
: Fetches entities from the past seven days."month"
: Returns entities from the past 30 days."year"
: Includes entities created in the past 12 months.
If no value is provided, this property defaults to null
, meaning no time frame restriction is applied.
keywordsFilters
: Allows filtering by the keywords
property of entities. This property expects an object with two optional fields:
includes
: An array of keywords. Entities must contain all specified keywords to be included.doesNotInclude
: An array of keywords. Entities containing any of these keywords are excluded.
By default, no filtering is applied (null
).
titleFilters
: Filters entities based on their title
property. This property accepts an object with the following optional fields:
hasTitle
: A boolean flag to include or exclude entities with a title.includes
: A string or array of strings. Entities must include at least one of the specified strings in their title.doesNotInclude
: A string or array of strings. Entities with any of these strings in their title are excluded.
By default, this property is set to null
, meaning no filtering by title is applied.
contentFilters
: Filters entities based on their content
property. This property accepts an object with the following optional fields:
hasContent
: A boolean flag to include or exclude entities with content.includes
: A string or array of strings. Entities must include at least one of the specified strings in their content.doesNotInclude
: A string or array of strings. Entities with any of these strings in their content are excluded.
By default, this property is set to null
, meaning no filtering by content is applied.
mediaFilters
: Filters entities based on the presence of media. This property accepts an object with the hasMedia
flag, which can include or exclude entities based on whether they contain media. By default, no media filtering is applied (null
).
locationFilters
: Filters entities by geographic location. This property expects an object with the following fields:
latitude
: The latitude of the center point.longitude
: The longitude of the center point.radius
: The radius (in kilometers) around the center point within which entities should be included.
Entities without a location property or outside the specified radius are excluded. By default, this property is set to null
.
metadataFilters
: Enables filtering based on the metadata
property of entities, which can store unstructured data. This property accepts an object with the following optional fields:
includes
: Key-value pairs that entities must contain.doesNotInclude
: Key-value pairs that entities must not contain.exists
: Keys that must be present in the metadata.doesNotExist
: Keys that must not be present in the metadata.
By default, this property is set to null
. The metadata filtering capabilities will be explored further in subsequent chapters.
onReset
: An optional callback function executed whenever filters change and the feed is reset. This function does not affect the feed’s behavior but can be used for custom actions such as displaying a toast notification or any other behavior, if desired, upon a feed refresh.
infuseData
: This optional callback is essential for applications integrating Replyke with external data sets. The function receives a referenceId
and fetches additional data for that entity from an external database. The fetched data is merged with Replyke’s entity data, providing a complete data object for the application. This feature will be covered in greater detail in the following chapters.
Note on Using Filters in the FeedProvider
-
Filters for Static or Initial Filtering: Passing filters directly into the
FeedProvider
is the correct approach both for cases where the feed should always be filtered in a specific way (e.g., on a user’s profile, where the feed is filtered by that user ID) and for cases where we want the feed to start with certain filters but allow dynamic changes later. This ensures the feed is initialized with the desired filtering logic. -
Filters Passed to
FeedProvider
Are Static After Initialization: When filters are passed as props to theFeedProvider
, they are only used during the initialization of the feed. If the variables used for these filters change after the feed has been initialized, the feed will not reset or reapply the updated filters. To apply dynamic changes to the filters after initialization, use theuseFeed
hook to modify the feed context dynamically.
For detailed guidance on dynamically updating filters, continue to the next chapters.