diff options
author | Eugene Sokolov <eug-vs@keemail.me> | 2020-02-08 20:54:36 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-08 20:54:36 +0000 |
commit | a72027d21154ba94e26d6b96092afc9704b8288c (patch) | |
tree | 4ce18b62e7e79e3543c43a94b72a161d0f20d1d2 /src/lib/SmartList | |
parent | d246305bfa280221efa8ee31cf6a841fbf54f378 (diff) | |
parent | ac6f957cef0d858a9720a7e97cf45fbf5900f926 (diff) | |
download | react-benzin-a72027d21154ba94e26d6b96092afc9704b8288c.tar.gz |
Merge pull request #4 from eug-vs/developv3.0.0
Release 3.0.0
Diffstat (limited to 'src/lib/SmartList')
-rw-r--r-- | src/lib/SmartList/SmartList.tsx | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/src/lib/SmartList/SmartList.tsx b/src/lib/SmartList/SmartList.tsx new file mode 100644 index 0000000..22cd3b2 --- /dev/null +++ b/src/lib/SmartList/SmartList.tsx @@ -0,0 +1,44 @@ +import React from 'react'; +import { FixedSizeList } from 'react-window'; +import AutoSizer from 'react-virtualized-auto-sizer'; + + +interface RenderPropTypes { + index: number; + style: React.CSSProperties; +} + +interface PropTypes { + itemSize: number; + itemCount: number; + renderItem: React.FC<RenderPropTypes>; +} + +interface Size { + height: number; + width: number; +} + + +const SmartList: React.FC<PropTypes> = ({ itemSize, itemCount, renderItem }) => { + + const ResizedList: React.FC<Size> = ({ width, height}) => ( + <FixedSizeList + height={height} + width={width} + itemSize={itemSize} + itemCount={itemCount} + > + {renderItem} + </FixedSizeList> + ); + + return ( + <div style={{ flex: '1 1 auto', overflow: 'hidden' }}> + <AutoSizer children={ResizedList} /> + </div> + ); +}; + + +export default SmartList; |