diff --git a/src/app/history/page.tsx b/src/app/history/page.tsx index 78b65e2..a376fd8 100644 --- a/src/app/history/page.tsx +++ b/src/app/history/page.tsx @@ -1,72 +1,16 @@ 'use client'; -import { useCachedReleaseData, useCachedReleaseSymbolData, useMyStockList } from '@/lib/socket'; -import { Dialog, DialogContent, DialogTitle, FormControl, Grid, ImageList, ImageListItem, InputLabel, LinearProgress, Link, MenuItem, Select, useMediaQuery, useTheme } from '@mui/material'; +import { useCachedReleaseData, useMyStockList } from '@/lib/socket'; +import { FormControl, FormControlLabel, Grid, InputLabel, LinearProgress, MenuItem, Select, Switch } from '@mui/material'; import { useState } from 'react'; -import { IconButton} from '@mui/material'; -import CloseIcon from '@mui/icons-material/Close'; -const D1 = (props: { dt: string, mytickersSymbols: string[] }) => { - const { dt, mytickersSymbols } = props; - const { cachedSummarySymbolsData } = useCachedReleaseSymbolData(dt); - const theme = useTheme(); - const matchesXs = useMediaQuery(theme.breakpoints.down("sm")); - const matchesMd = useMediaQuery(theme.breakpoints.down("md")); - const numberOfItemsToDisplay = matchesXs ? 2 : matchesMd ? 3 : 4; - const ts = cachedSummarySymbolsData.filter(r => mytickersSymbols.includes(r.name)); //make sure to load only those which are part of the watchlist. +import { HistoricalDex } from '@/components/HistoricalDex'; - const [openDialog, setOpenDialog] = useState(false); - const [selectedImage, setSelectedImage] = useState(''); - - const handleImageClick = (imageSrc: string) => { - setSelectedImage(imageSrc); - setOpenDialog(true); - }; - - const handleCloseDialog = () => { - setOpenDialog(false); - }; - return <> - {ts.map((item) => ( - - handleImageClick(`https://mztrading-data.deno.dev/images?dt=${dt}&s=${item.name}`)} /> - - ))} - - - - - - - - - - - - ; -} - -export default function Page() { - const { mytickers, loading } = useMyStockList(); +export default function Page() { + const [showAllSymbols, setShowAllSymbols] = useState(false); const { cachedSummaryData, isLoadingCachedSummaryData } = useCachedReleaseData(); const [dataMode, setDataMode] = useState(''); - if (isLoadingCachedSummaryData || loading) return ; + if (isLoadingCachedSummaryData) return ; const cachedDates = cachedSummaryData.map(j => j.name); - const mytickersSymbols = mytickers.map(r => r.symbol) + const dt = dataMode || cachedDates.at(0) || ''; return ( <> @@ -85,9 +29,12 @@ export default function Page() { } - Legacy Mode + + setShowAllSymbols(v)} />} label="Show all?" /> + + {/* Legacy Mode */} - + ); } diff --git a/src/components/HistoricalDex.tsx b/src/components/HistoricalDex.tsx new file mode 100644 index 0000000..deb5bed --- /dev/null +++ b/src/components/HistoricalDex.tsx @@ -0,0 +1,65 @@ +'use client'; +import { useCachedReleaseSymbolData } from '@/lib/socket'; +import { Dialog, DialogContent, DialogTitle, ImageList, ImageListItem, useMediaQuery, useTheme } from '@mui/material'; +import { useState } from 'react'; +import { IconButton } from '@mui/material'; +import CloseIcon from '@mui/icons-material/Close'; +import { useMyLocalWatchList } from '@/lib/hooks'; +export const HistoricalDex = (props: { dt: string, showAllSymbols: boolean }) => { + const { wl } = useMyLocalWatchList([]); + const mytickersSymbols = wl.map(r => r.symbol); + const { dt, showAllSymbols } = props; + const { cachedSummarySymbolsData } = useCachedReleaseSymbolData(dt); + const theme = useTheme(); + const matchesXs = useMediaQuery(theme.breakpoints.down("sm")); + const matchesMd = useMediaQuery(theme.breakpoints.down("md")); + const numberOfItemsToDisplay = matchesXs ? 2 : matchesMd ? 3 : 4; + const ts = cachedSummarySymbolsData.filter(r => showAllSymbols || mytickersSymbols.includes(r.name)); //make sure to load only those which are part of the watchlist. + + const [openDialog, setOpenDialog] = useState(false); + const [selectedImage, setSelectedImage] = useState(''); + + const handleImageClick = (imageSrc: string) => { + setSelectedImage(imageSrc); + setOpenDialog(true); + }; + + const handleCloseDialog = () => { + setOpenDialog(false); + }; + return <> + {ts.map((item) => ( + + handleImageClick(`https://mztrading-data.deno.dev/images?dt=${dt}&s=${item.name}`)} /> + + ))} + + + + + + + + + + + + ; +} \ No newline at end of file diff --git a/src/components/Watchlist.tsx b/src/components/Watchlist.tsx index 53d5c5d..c4af319 100644 --- a/src/components/Watchlist.tsx +++ b/src/components/Watchlist.tsx @@ -2,7 +2,7 @@ import * as React from 'react'; import DeleteIcon from '@mui/icons-material/Delete'; import InfoIcon from '@mui/icons-material/Info'; -import { Button, Dialog, DialogContent, DialogTitle, FormControl, InputLabel, MenuItem, Select } from '@mui/material'; +import { Button, Dialog, DialogContent, DialogTitle, FormControl, MenuItem, Select } from '@mui/material'; import { DataGrid, GridActionsCellItem, GridColDef, useGridApiRef } from '@mui/x-data-grid'; import { useEffect, useState } from 'react'; import { StockTickerSymbolView, StockTickerView } from './StockTicker'; @@ -14,6 +14,7 @@ import { TickerSearch } from './TickerSearch'; import { TradingViewWidgetDialog } from './TradingViewWidgetDialog'; import { subscribeStockPriceBatchRequest } from '@/lib/socket'; import collect from 'collect.js'; +import { useMyLocalWatchList } from '@/lib/hooks'; interface IWatchlistProps { tickers: SearchTickerItem[] @@ -23,18 +24,20 @@ interface IWatchlistProps { } export const Watchlist = (props: IWatchlistProps) => { - const { tickers, removFromWatchlist, loading, addToWatchlist } = props; + const { tickers, loading, addToWatchlist } = props; + const { wl , removeFromMyList, addToMyList} = useMyLocalWatchList(tickers); + const apiRef = useGridApiRef(); const [currentStock, setCurrentStock] = useState(null); const [sortMode, setSortMode] = useState('symbol'); - + useEffect(() => { const interval = setInterval(() => { - subscribeStockPriceBatchRequest(tickers); + subscribeStockPriceBatchRequest(wl); }, 1000); //every one second just ping the server to resubscribe return () => clearInterval(interval); - }, [tickers]); + }, [wl]); const columns: GridColDef[] = [ { @@ -57,13 +60,13 @@ export const Watchlist = (props: IWatchlistProps) => { }, renderHeader: () => { return <>Sort {/* Sort by */} - +