finsignal-feed-explore 1.9.2 → 1.9.4

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/README.md CHANGED
@@ -13,12 +13,12 @@ yarn add finsignal-feed-explore
13
13
  ## Quick Start
14
14
 
15
15
  ```tsx
16
- import { NewsFeed } from 'finsignal-feed-explore';
16
+ import { FeedList } from 'finsignal-feed-explore';
17
17
  import 'finsignal-feed-explore/dist/newsfeed.css';
18
18
 
19
19
  function App() {
20
20
  return (
21
- <NewsFeed
21
+ <FeedList
22
22
  onNewsClick={(news) => console.log('Clicked:', news)}
23
23
  onFiltersApply={(filters) => console.log('Filters:', filters)}
24
24
  />
@@ -30,15 +30,15 @@ function App() {
30
30
 
31
31
  ## Main Components
32
32
 
33
- ### NewsFeed
33
+ ### FeedList
34
34
 
35
35
  The main component for displaying a news feed with filtering, infinite scroll, and interactive actions.
36
36
 
37
37
  ```tsx
38
- import { NewsFeed } from 'finsignal-feed-explore';
38
+ import { FeedList } from 'finsignal-feed-explore';
39
39
  import 'finsignal-feed-explore/dist/newsfeed.css';
40
40
 
41
- <NewsFeed
41
+ <FeedList
42
42
  onNewsClick={(news) => handleNewsClick(news)}
43
43
  onShowFilter={() => console.log('Filter button clicked')}
44
44
  initialFilters={['earnings', 'ipo']}
@@ -93,7 +93,7 @@ import { FiltersOverlay } from 'finsignal-feed-explore';
93
93
 
94
94
  ## API Reference
95
95
 
96
- ### NewsFeed Props
96
+ ### FeedList Props
97
97
 
98
98
  | Prop | Type | Required | Description |
99
99
  |------|------|----------|-------------|
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import { WidgetConfig } from './types';
3
+ import './FeedList.css';
4
+ export interface FeedListProps extends WidgetConfig {
5
+ initialFilters?: string[];
6
+ enableInfiniteScroll?: boolean;
7
+ }
8
+ export declare const FeedList: React.FC<FeedListProps>;
9
+ //# sourceMappingURL=FeedList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeedList.d.ts","sourceRoot":"","sources":["../src/FeedList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmD,MAAM,OAAO,CAAC;AAMxE,OAAO,EAAE,YAAY,EAAY,MAAM,SAAS,CAAC;AAIjD,OAAO,gBAAgB,CAAC;AAExB,MAAM,WAAW,aAAc,SAAQ,YAAY;IACjD,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAED,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CA8O5C,CAAC"}
@@ -0,0 +1,128 @@
1
+ import React, { useCallback, useState, useRef, useEffect } from 'react';
2
+ import { NewsSnippet } from './snippets/NewsSnippet';
3
+ import { FiltersOverlay } from './filters/FiltersOverlay';
4
+ import { FilterIcon } from './components/icons';
5
+ import { useFeedData } from './hooks/useFeedData';
6
+ import { useFilters } from './hooks/useFilters';
7
+ import { theme } from './utils/theme';
8
+ import { MOCK_NEWS } from './constants/mock-news';
9
+ import { DEFAULT_API_URL } from './constants/api';
10
+ import './FeedList.css';
11
+ export const FeedList = ({ apiUrl, initialFilters = [], enableInfiniteScroll = true, onNewsClick, onShareClick, onBookmarkClick, onLikeClick, onDislikeClick, onAIClick, onFiltersOpen, onFiltersClose, onFiltersApply, onShowFilter, showShareIcon = true, showBookmarkIcon = true, showLikeIcon = true, showDislikeIcon = true, showAIIcon = true, showFilterIcon = true, marketEventsTaxonomy }) => {
12
+ const { selectedMarketEvents, isOpen: isFiltersOpen, toggleFilter, clearFilters, setFilters, openFilters, closeFilters } = useFilters(initialFilters);
13
+ const { items, isLoading, hasMore, error, loadMore, refresh } = useFeedData({
14
+ apiUrl: apiUrl || DEFAULT_API_URL,
15
+ filters: selectedMarketEvents,
16
+ limit: 20
17
+ });
18
+ const [likedItems, setLikedItems] = useState(new Set());
19
+ const [dislikedItems, setDislikedItems] = useState(new Set());
20
+ const [bookmarkedItems, setBookmarkedItems] = useState(new Set());
21
+ const observerTarget = useRef(null);
22
+ useEffect(() => {
23
+ if (!enableInfiniteScroll || !observerTarget.current)
24
+ return;
25
+ const observer = new IntersectionObserver((entries) => {
26
+ if (entries[0].isIntersecting && hasMore && !isLoading) {
27
+ loadMore();
28
+ }
29
+ }, { threshold: 0.1 });
30
+ observer.observe(observerTarget.current);
31
+ return () => observer.disconnect();
32
+ }, [enableInfiniteScroll, hasMore, isLoading, loadMore]);
33
+ const handleFiltersOpen = useCallback(() => {
34
+ onShowFilter?.();
35
+ openFilters();
36
+ onFiltersOpen?.();
37
+ }, [openFilters, onFiltersOpen, onShowFilter]);
38
+ const handleFiltersClose = useCallback(() => {
39
+ closeFilters();
40
+ onFiltersClose?.();
41
+ }, [closeFilters, onFiltersClose]);
42
+ const handleFiltersApply = useCallback((filters) => {
43
+ setFilters(filters);
44
+ onFiltersApply?.(filters);
45
+ }, [setFilters, onFiltersApply]);
46
+ const handleFiltersReset = useCallback(() => {
47
+ clearFilters();
48
+ onFiltersApply?.([]);
49
+ }, [clearFilters, onFiltersApply]);
50
+ const handleNewsClick = useCallback((news) => {
51
+ onNewsClick?.(news);
52
+ }, [onNewsClick]);
53
+ const handleShare = useCallback((news) => {
54
+ onShareClick?.(news);
55
+ }, [onShareClick]);
56
+ const handleBookmark = useCallback((news) => {
57
+ setBookmarkedItems(prev => {
58
+ const next = new Set(prev);
59
+ if (next.has(news.id)) {
60
+ next.delete(news.id);
61
+ }
62
+ else {
63
+ next.add(news.id);
64
+ }
65
+ return next;
66
+ });
67
+ onBookmarkClick?.(news);
68
+ }, [onBookmarkClick]);
69
+ const handleLike = useCallback((news) => {
70
+ setLikedItems(prev => {
71
+ const next = new Set(prev);
72
+ if (next.has(news.id)) {
73
+ next.delete(news.id);
74
+ }
75
+ else {
76
+ next.add(news.id);
77
+ setDislikedItems(d => {
78
+ const nd = new Set(d);
79
+ nd.delete(news.id);
80
+ return nd;
81
+ });
82
+ }
83
+ return next;
84
+ });
85
+ onLikeClick?.(news);
86
+ }, [onLikeClick]);
87
+ const handleDislike = useCallback((news) => {
88
+ setDislikedItems(prev => {
89
+ const next = new Set(prev);
90
+ if (next.has(news.id)) {
91
+ next.delete(news.id);
92
+ }
93
+ else {
94
+ next.add(news.id);
95
+ setLikedItems(l => {
96
+ const nl = new Set(l);
97
+ nl.delete(news.id);
98
+ return nl;
99
+ });
100
+ }
101
+ return next;
102
+ });
103
+ onDislikeClick?.(news);
104
+ }, [onDislikeClick]);
105
+ const handleAI = useCallback((news) => {
106
+ onAIClick?.(news);
107
+ }, [onAIClick]);
108
+ const displayItems = items.length > 0 ? items : (!isLoading ? MOCK_NEWS : []);
109
+ const showMockIndicator = displayItems === MOCK_NEWS && displayItems.length > 0;
110
+ return (React.createElement("div", { className: "news-feed" },
111
+ showFilterIcon && (React.createElement("div", { className: "news-feed__header" },
112
+ React.createElement("button", { className: `news-feed__filter-btn ${selectedMarketEvents.length > 0 ? 'news-feed__filter-btn--active' : ''}`, onClick: handleFiltersOpen, "aria-label": "Open filters" },
113
+ React.createElement(FilterIcon, { size: 20, color: theme.colors.foreground }),
114
+ selectedMarketEvents.length > 0 && (React.createElement("span", { className: "news-feed__filter-badge" }, selectedMarketEvents.length))))),
115
+ React.createElement("div", { className: "news-feed__list" },
116
+ error && (React.createElement("div", { className: "news-feed__error" },
117
+ "Error loading news: ",
118
+ error.message,
119
+ React.createElement("br", null),
120
+ React.createElement("small", null, "Showing example news below"))),
121
+ showMockIndicator && (React.createElement("div", { className: "news-feed__mock-indicator" }, "\uD83D\uDCF0 Showing example news (API data not available)")),
122
+ displayItems.map((news) => (React.createElement(NewsSnippet, { key: news.id, news: news, onPress: () => handleNewsClick(news), onShare: () => handleShare(news), onBookmark: () => handleBookmark(news), onLike: () => handleLike(news), onDislike: () => handleDislike(news), onAI: () => handleAI(news), showShareIcon: showShareIcon, showBookmarkIcon: showBookmarkIcon, showLikeIcon: showLikeIcon, showDislikeIcon: showDislikeIcon, showAIIcon: showAIIcon, isLiked: likedItems.has(news.id), isDisliked: dislikedItems.has(news.id), isBookmarked: bookmarkedItems.has(news.id) }))),
123
+ isLoading && (React.createElement("div", { className: "news-feed__loading" },
124
+ React.createElement("div", { className: "news-feed__spinner" }))),
125
+ enableInfiniteScroll && hasMore && !isLoading && items.length > 0 && (React.createElement("div", { ref: observerTarget, className: "news-feed__scroll-trigger" }))),
126
+ React.createElement(FiltersOverlay, { isOpen: isFiltersOpen, selectedFilters: selectedMarketEvents, onClose: handleFiltersClose, onApply: handleFiltersApply, onReset: handleFiltersReset, marketEventsTaxonomy: marketEventsTaxonomy })));
127
+ };
128
+ //# sourceMappingURL=FeedList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeedList.js","sourceRoot":"","sources":["../src/FeedList.tsx"],"names":[],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- export { NewsFeed } from './NewsFeed';
2
- export type { NewsFeedProps } from './NewsFeed';
1
+ export { FeedList } from './FeedList';
2
+ export type { FeedListProps } from './FeedList';
3
3
  export { NewsSnippet } from './snippets/NewsSnippet';
4
4
  export type { NewsSnippetProps } from './snippets/NewsSnippet';
5
5
  export { FiltersOverlay } from './filters/FiltersOverlay';
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- export { NewsFeed } from './NewsFeed';
1
+ export { FeedList } from './FeedList';
2
2
  export { NewsSnippet } from './snippets/NewsSnippet';
3
3
  export { FiltersOverlay } from './filters/FiltersOverlay';
4
4
  export { useFeedData } from './hooks/useFeedData';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "finsignal-feed-explore",
3
- "version": "1.9.2",
3
+ "version": "1.9.4",
4
4
  "description": "News feed explorer components for React web applications",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.js",
@@ -10,7 +10,7 @@
10
10
  "README.md"
11
11
  ],
12
12
  "scripts": {
13
- "build": "tsc && cp src/newsfeed.css dist/newsfeed.css",
13
+ "build": "tsc && cp src/FeedList.css dist/newsfeed.css",
14
14
  "prepublishOnly": "npm run build"
15
15
  },
16
16
  "keywords": [