Skip to content

Commit

Permalink
Merge pull request #7 from 1pxone/max-width-feature
Browse files Browse the repository at this point in the history
fix(all): adds max width property
  • Loading branch information
Artemiy Vereshchinskiy authored Sep 29, 2020
2 parents a308206 + 7be9dd0 commit 8ffcf00
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 20 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
"main": "./lib/index.js",
"types": "./lib/index.d.ts",
"scripts": {
"format": "prettier --write \"src/**/*.ts\" \"src/**/*.js\"",
"format": "prettier --write \"src/**/*.ts*\"",
"lint": "tslint -p tsconfig.json",
"test-jest": "jest --config jestconfig.json",
"test": "echo \"No tests to execute\" && exit 0",
Expand Down
20 changes: 10 additions & 10 deletions src/__tests__/test.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as React from 'react';
import { shallow, ShallowWrapper } from 'enzyme';
import { MorefinityListLoader, MorefinityContainer, IMorefinityProps } from '../index';
import { MorefinityListLoader, Morefinity, IMorefinityProps } from '../index';
import { useState } from 'react';

const mockedItemHeight = 30;
Expand Down Expand Up @@ -36,8 +36,8 @@ const fetchItems = async (
});
};

describe('<MorefinityContainer />', () => {
const MorefinityContainerTest = () => {
describe('<Morefinity />', () => {
const MorefinityTest = () => {
const [items, setItems] = useState<{ id: number; text: string }[]>([
{
id: 0,
Expand All @@ -53,18 +53,18 @@ describe('<MorefinityContainer />', () => {
};
return (
<div className="App" style={{ height: '290px' }}>
<MorefinityContainer
<Morefinity
notAllLoaded={true}
isLoading={isLoading}
scrollOffset={100}
onScrollEnd={onScrollEnd}
>
{items.map(itemRenderer)}
</MorefinityContainer>
</Morefinity>
</div>
);
};
const container = shallow(<MorefinityContainerTest />);
const container = shallow(<MorefinityTest />);

let wrapper: ShallowWrapper;
const useEffect = jest.spyOn(React, 'useEffect');
Expand All @@ -84,21 +84,21 @@ describe('<MorefinityContainer />', () => {
};

test('should pass scrollOffset prop', () => {
expect(container.find(MorefinityContainer).props().scrollOffset).toBe(100);
expect(container.find(Morefinity).props().scrollOffset).toBe(100);
});

test('should request items with start offset and limit from props', () => {
mockUseEffect();
wrapper = shallow(<MorefinityContainer {...props} />);
wrapper = shallow(<Morefinity {...props} />);
expect(props.onScrollEnd).toBeCalledTimes(0);
});

test('container height should be equal to passed property', () => {
wrapper = shallow(<MorefinityContainer {...props} />);
wrapper = shallow(<Morefinity {...props} />);
expect(wrapper.find('div').props().height).toBe(props.height);
});

test('should render <MorefinityContainer />', () => {
test('should render <Morefinity />', () => {
expect(wrapper.length).toBe(1);
});

Expand Down
40 changes: 31 additions & 9 deletions src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ function useDebouncedState<T>(initialValue: T, delay: number = 50): [T, (newValu
export interface IMorefinityProps {
isLoading?: boolean;
loader?: React.ReactElement;
maxHeight?: number;
height?: number;
notAllLoaded?: boolean;
scrollOffset?: number;
Expand Down Expand Up @@ -88,10 +89,24 @@ export const MorefinityListLoader = ({
return isLoading ? <div style={getMorefinityElementStyle(listHeight)}>{element}</div> : null;
};

export const MorefinityContainer: React.FC<IMorefinityProps> = React.memo(
({ isLoading, height, notAllLoaded, onScrollEnd, scrollOffset = 0, loader, children }) => {
export const Morefinity: React.FC<IMorefinityProps> = React.memo(
({
isLoading,
height,
notAllLoaded,
maxHeight,
onScrollEnd,
scrollOffset = 0,
loader,
children,
}) => {
const [offsetHeight, setOffsetHeight] = useState(0);

const { ref, size: contentSize } = useObservedSize<HTMLDivElement>() as {
ref: RefObject<HTMLDivElement>;
size: IObservableSize;
};

const [scrollTop, setScrollTop] = useDebouncedState(0, 50);

const { ref: containerRef, size } = useObservedSize<HTMLDivElement>() as {
Expand Down Expand Up @@ -211,7 +226,16 @@ export const MorefinityContainer: React.FC<IMorefinityProps> = React.memo(
});
}, [listHeight, children, minPredicted, maxPredicted]);

const pageWrapperStyles: React.CSSProperties = useMemo(() => {
const wrapperStyles: React.CSSProperties = useMemo(() => {
return {
position: 'relative',
height: maxHeight ? contentSize.height : height ?? 'inherit',
overflow: 'auto',
maxHeight,
};
}, [contentSize.height, maxHeight, height]);

const containerStyles: React.CSSProperties = useMemo(() => {
const offset = Math.max(minPredicted - 1, 0) * avgItemHeight;
return {
position: 'absolute',
Expand All @@ -226,12 +250,10 @@ export const MorefinityContainer: React.FC<IMorefinityProps> = React.memo(
};

return (
<div
style={{ position: 'relative', height: height ?? 'inherit', overflow: 'auto' }}
ref={containerRef}
onScroll={onScroll}
>
<div style={pageWrapperStyles}>{renderItems()}</div>
<div ref={containerRef} onScroll={onScroll} style={wrapperStyles}>
<div ref={ref} style={containerStyles}>
{renderItems()}
</div>
<MorefinityListLoader
loader={loader}
isLoading={isLoading}
Expand Down

0 comments on commit 8ffcf00

Please sign in to comment.