Update LogsTerminal.tsx

This commit is contained in:
Hristo Nedelkov 2023-11-03 17:01:26 +02:00
parent 7b8475a618
commit 792448cdcd

View File

@ -1,30 +1,52 @@
import { LazyLog } from 'react-lazylog';
import { FixedSizeList as List } from 'react-window';
import InfiniteLoader from 'react-window-infinite-loader';
import { Button } from "tamagui";
// This is just a sample row renderer. Adjust according to your data.
function Row(props: any) {
const { index, style } = props;
return (
<div style={style}>
<Button>{`Row ${index}`}</Button>
</div>
);
}
function LogsTerminal() {
const lineStyle = {
borderBottom: '1px solid #e0e0e0',
fontFamily: 'Courier New, monospace',
lineHeight: '1.5',
fontSize: '14px',
// Sample itemCount & loadMoreItems for demonstration purposes.
const itemCount = 1000;
const loadMoreItems = (startIndex: number, stopIndex: number) => {
console.log("Loading more items from:", startIndex, "to", stopIndex);
return new Promise((resolve) => setTimeout(resolve, 1000));
};
const oddLineStyle = {
...lineStyle,
backgroundColor: '#f7f7f7',
};
const lineContentStyle = {
color: '#333',
const isItemLoaded = (index: number) => {
// Add your logic here to check if the item is already loaded or not.
return false;
};
return (
<div>
<LazyLog
url="path_to_your_log_file.log"
lineStyle={(lineNumber: number) => lineNumber % 2 === 0 ? lineStyle : oddLineStyle}
textStyle={lineContentStyle}
/>
<div style={{ height: '400px', width: '100%' }}>
<InfiniteLoader
isItemLoaded={isItemLoaded}
itemCount={itemCount}
loadMoreItems={loadMoreItems}
>
{({ onItemsRendered, ref }) => (
<List
height={400}
itemCount={itemCount}
itemSize={35}
onItemsRendered={onItemsRendered}
ref={ref}
width={'100%'}
>
{Row}
</List>
)}
</InfiniteLoader>
</div>
);
}