2020-08-17 15:07:16 -05:00
|
|
|
import React from 'react'
|
2020-08-17 15:59:29 -05:00
|
|
|
import PropTypes from 'prop-types'
|
2020-03-24 23:08:43 -04:00
|
|
|
import ImmutablePureComponent from 'react-immutable-pure-component'
|
2020-04-23 02:13:29 -04:00
|
|
|
import ImmutablePropTypes from 'react-immutable-proptypes'
|
2020-02-22 18:26:23 -05:00
|
|
|
import Block from './block'
|
2020-02-20 19:57:29 -05:00
|
|
|
import ScrollableList from './scrollable_list'
|
|
|
|
import ListItem from './list_item'
|
2020-05-14 17:47:33 -04:00
|
|
|
import Dummy from './dummy'
|
2020-07-28 15:11:51 -05:00
|
|
|
import ListItemPlaceholder from './placeholder/list_item_placeholder'
|
2020-02-20 19:57:29 -05:00
|
|
|
|
2020-08-17 19:57:35 -05:00
|
|
|
class List extends ImmutablePureComponent {
|
2020-02-20 19:57:29 -05:00
|
|
|
|
|
|
|
render() {
|
2020-04-02 12:57:04 -04:00
|
|
|
const {
|
|
|
|
items,
|
|
|
|
scrollKey,
|
|
|
|
emptyMessage,
|
|
|
|
hasMore,
|
2020-04-06 21:53:23 -04:00
|
|
|
size,
|
2020-06-05 15:28:46 -04:00
|
|
|
onLoadMore,
|
|
|
|
showLoading,
|
2020-04-02 12:57:04 -04:00
|
|
|
} = this.props
|
2020-02-20 19:57:29 -05:00
|
|
|
|
2020-05-14 17:47:33 -04:00
|
|
|
const Wrapper = !!scrollKey ? ScrollableList : Dummy
|
2020-12-31 16:39:27 -05:00
|
|
|
const itemsSize = !!items ? Array.isArray(items) ? items.length : items.size : 0
|
2020-05-14 17:47:33 -04:00
|
|
|
|
2020-02-20 19:57:29 -05:00
|
|
|
return (
|
2020-02-22 18:26:23 -05:00
|
|
|
<Block>
|
2020-05-14 17:47:33 -04:00
|
|
|
<Wrapper
|
2020-04-02 12:57:04 -04:00
|
|
|
onLoadMore={onLoadMore}
|
|
|
|
hasMore={hasMore}
|
2020-02-20 19:57:29 -05:00
|
|
|
scrollKey={scrollKey}
|
|
|
|
emptyMessage={emptyMessage}
|
2020-06-05 15:28:46 -04:00
|
|
|
showLoading={showLoading}
|
2020-07-28 15:11:51 -05:00
|
|
|
placeholderComponent={ListItemPlaceholder}
|
2020-07-29 15:40:47 -05:00
|
|
|
placeholderCount={12}
|
2020-02-20 19:57:29 -05:00
|
|
|
>
|
|
|
|
{
|
2021-01-13 12:05:29 -05:00
|
|
|
!!items && itemsSize > 0 &&
|
2020-03-24 23:08:43 -04:00
|
|
|
items.map((item, i) => (
|
|
|
|
<ListItem
|
2020-04-06 21:53:23 -04:00
|
|
|
size={size}
|
2020-03-24 23:08:43 -04:00
|
|
|
key={`list-item-${i}`}
|
2020-12-31 16:39:27 -05:00
|
|
|
isLast={itemsSize - 1 === i}
|
2020-03-24 23:08:43 -04:00
|
|
|
{...item}
|
|
|
|
/>
|
|
|
|
))
|
2020-02-20 19:57:29 -05:00
|
|
|
}
|
2020-05-14 17:47:33 -04:00
|
|
|
</Wrapper>
|
2020-04-29 18:32:49 -04:00
|
|
|
</Block>
|
2020-02-20 19:57:29 -05:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2020-08-17 19:57:35 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
List.propTypes = {
|
|
|
|
items: PropTypes.oneOfType([
|
|
|
|
PropTypes.array,
|
|
|
|
ImmutablePropTypes.map,
|
|
|
|
ImmutablePropTypes.list,
|
|
|
|
]),
|
|
|
|
scrollKey: PropTypes.string,
|
|
|
|
emptyMessage: PropTypes.any,
|
|
|
|
size: PropTypes.oneOf([
|
|
|
|
'small',
|
|
|
|
'large'
|
|
|
|
]),
|
|
|
|
onLoadMore: PropTypes.func,
|
|
|
|
hasMore: PropTypes.bool,
|
|
|
|
showLoading: PropTypes.bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
export default List
|