diff --git a/src/components/List/List.tsx b/src/components/List/List.tsx index 3e8c3bee10..4fb2d291db 100644 --- a/src/components/List/List.tsx +++ b/src/components/List/List.tsx @@ -93,7 +93,7 @@ export class List extends React.Component, ListState(); refContainer = React.createRef(); blurTimer: ReturnType | null = null; - loadingItem = {value: '__LIST_ITEM_LOADING__', disabled: true} as unknown as ListItemData< + loadingItem = {value: '__LIST_ITEM_LOADING__', disabled: false} as unknown as ListItemData< T & {value: string} >; uniqId = getUniqId(); @@ -518,11 +518,13 @@ export class List extends React.Component, ListState(this.state.items, activeItem + step, Math.sign(step)), - ); + + event.preventDefault(); + + const items = this.getItemsWithLoading(); + + this.activateItem(List.findNextIndex(items, activeItem + step, Math.sign(step))); } private handleFocus = () => { diff --git a/src/components/List/__stories__/List.stories.tsx b/src/components/List/__stories__/List.stories.tsx index c103bbbd9d..a3f8d74829 100644 --- a/src/components/List/__stories__/List.stories.tsx +++ b/src/components/List/__stories__/List.stories.tsx @@ -44,7 +44,28 @@ export const RenderItem = RenderItemTemplate.bind({}); RenderItem.args = { items, renderItem: (item) => `🔥🔥🔥 ${item} 🔥🔥🔥`, +}; + +const TemplateWithState: ComponentStory = (args) => { + const [items, setItems] = React.useState(args.items); + + const onLoadMore = () => { + // delay for fetching new real items + setTimeout(() => { + setItems([...items, ...args.items]); + }, 300); + }; + + return ; +}; + +export const WithLoadingMoreItems = TemplateWithState.bind({}); +WithLoadingMoreItems.args = { + items: ['one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight'], itemsHeight: 150, + itemHeight: 28, + loading: true, + virtualized: false, }; const ShowcaseTemplate: ComponentStory = () => ;