UNPKG

@uiw/react-native

Version:
149 lines (122 loc) 15.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _reactNative = require("react-native"); var _Item = _interopRequireDefault(require("./Item")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } const noop = () => null; /** * @see https://facebook.github.io/react-native/docs/flatlist.html#props */ class List extends _react.Component { constructor(props) { super(props); this.state = { data: [] }; } getData(nextProps) { const { size, extra, paddingLeft, children } = nextProps || this.props; const dataSource = _react.default.Children.toArray(children).map(child => { if (!_react.default.isValidElement(child)) { return null; } const props = { size, ...child.props }; return _react.default.cloneElement(<_Item.default paddingLeft={paddingLeft} extra={extra} {...props} />); }).filter(Boolean); this.setState({ data: dataSource }); } componentDidMount() { if (!this.props.renderItem) { this.getData(); } } UNSAFE_componentWillReceiveProps(nextProps) { if (nextProps !== this.props) { this.getData(nextProps); } } renderItemChild(props) { return props.item; } render() { const { renderItem, data, children, titleStyle, paddingLeft, flat, // eslint-disable-next-line @typescript-eslint/no-unused-vars size, // eslint-disable-next-line @typescript-eslint/no-unused-vars extra, ListHeaderComponent, title, ...otherProps } = this.props; const props = {}; if (!renderItem) { props.data = this.state.data; props.renderItem = this.renderItemChild.bind(this); } else if (typeof renderItem === 'function') { props.data = data; props.renderItem = itemProps => renderItem({ ...itemProps }); } let header = ListHeaderComponent; if (title) { header = // eslint-disable-next-line react-native/no-inline-styles <_reactNative.View style={[{ paddingLeft, paddingVertical: 12 }, titleStyle]}> {typeof title === 'string' ? // eslint-disable-next-line react-native/no-inline-styles <_reactNative.Text style={{ color: '#808080' }}>{title}</_reactNative.Text> : <_reactNative.View>{title}</_reactNative.View>} </_reactNative.View>; } if (!props.renderItem) { props.renderItem = noop; } if (!flat) { return <_reactNative.View {...otherProps}> {header} {(renderItem && (!data || data.length === 0) || !renderItem && (!children || _react.default.Children.toArray(children).length === 0)) && otherProps.ListEmptyComponent} {(props.data || []).map((item, idx) => _react.default.cloneElement(props.renderItem && props.renderItem({ item, index: idx }) || <_reactNative.View />, { key: idx }))} </_reactNative.View>; } return <_reactNative.FlatList ListHeaderComponent={header} keyExtractor={(__, index) => index.toString()} {...otherProps} {...props} />; } } exports.default = List; List.Item = _Item.default; List.defaultProps = { data: [], paddingLeft: 16, flat: true, size: 'default' }; module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/index.tsx"],"names":["noop","List","Component","constructor","props","state","data","getData","nextProps","size","extra","paddingLeft","children","dataSource","React","Children","toArray","map","child","isValidElement","cloneElement","filter","Boolean","setState","componentDidMount","renderItem","UNSAFE_componentWillReceiveProps","renderItemChild","item","render","titleStyle","flat","ListHeaderComponent","title","otherProps","bind","itemProps","header","paddingVertical","color","length","ListEmptyComponent","idx","index","key","__","toString","Item","defaultProps"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport { FlatList, FlatListProps, Text, StyleProp, ViewStyle, View } from 'react-native';\nimport Item, { ListItemProps } from './Item';\n\nconst noop = () => null;\n\n/**\n * @see https://facebook.github.io/react-native/docs/flatlist.html#props\n */\nexport interface ListRenderItemInfoCustom<ItemT> {\n  item: ItemT;\n  index: number;\n  separators?: {\n    highlight: () => void;\n    unhighlight: () => void;\n    updateProps: (select: 'leading' | 'trailing', newProps: any) => void;\n  };\n}\n\nexport interface ListProps extends Omit<FlatListProps<{}>, 'renderItem'> {\n  children?: React.ReactNode;\n  renderItem?: (info: ListRenderItemInfoCustom<{}>) => React.ReactElement | null;\n  /**\n   * flat default: `true`\n   * - flat = `true` => `FlatList`\n   * - flat = `false` => `<View>` 上拉下拉刷新失效，是一个简单的 `List`\n   */\n  flat?: boolean;\n  /**\n   * 标题\n   */\n  title?: React.ReactNode;\n  /**\n   * 额外内容，展示右侧内容;\n   */\n  extra?: React.ReactNode;\n  titleStyle?: StyleProp<ViewStyle>;\n  paddingLeft?: ListItemProps['paddingLeft'];\n  size?: ListItemProps['size'];\n}\n\nexport interface ListState {\n  data: ListProps['data'];\n}\n\nexport default class List extends Component<ListProps, ListState> {\n  static Item = Item;\n  static defaultProps: ListProps = {\n    data: [],\n    paddingLeft: 16,\n    flat: true,\n    size: 'default',\n  };\n  constructor(props: ListProps) {\n    super(props);\n    this.state = {\n      data: [],\n    };\n  }\n  getData(nextProps?: ListProps) {\n    const { size, extra, paddingLeft, children } = nextProps || this.props;\n    const dataSource = React.Children.toArray(children)\n      .map((child: React.ReactNode) => {\n        if (!React.isValidElement(child)) {\n          return null;\n        }\n        const props = { size, ...child.props };\n        return React.cloneElement(<Item paddingLeft={paddingLeft} extra={extra} {...props} />);\n      })\n      .filter(Boolean);\n    this.setState({ data: dataSource as ListProps['data'] });\n  }\n  componentDidMount() {\n    if (!this.props.renderItem) {\n      this.getData();\n    }\n  }\n  UNSAFE_componentWillReceiveProps(nextProps: ListProps) {\n    if (nextProps !== this.props) {\n      this.getData(nextProps);\n    }\n  }\n  renderItemChild(props: ListRenderItemInfoCustom<{}>): React.ReactElement {\n    return props.item as React.ReactElement;\n  }\n  render() {\n    const {\n      renderItem,\n      data,\n      children,\n      titleStyle,\n      paddingLeft,\n      flat,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      size,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      extra,\n      ListHeaderComponent,\n      title,\n      ...otherProps\n    } = this.props;\n    const props = {} as ListProps & FlatListProps<{}>;\n    if (!renderItem) {\n      props.data = this.state.data;\n      props.renderItem = this.renderItemChild.bind(this);\n    } else if (typeof renderItem === 'function') {\n      props.data = data;\n      props.renderItem = (itemProps: ListRenderItemInfoCustom<{}>) => renderItem({ ...itemProps });\n    }\n    let header = ListHeaderComponent;\n    if (title) {\n      header = (\n        // eslint-disable-next-line react-native/no-inline-styles\n        <View style={[{ paddingLeft, paddingVertical: 12 }, titleStyle]}>\n          {typeof title === 'string' ? (\n            // eslint-disable-next-line react-native/no-inline-styles\n            <Text style={{ color: '#808080' }}>{title}</Text>\n          ) : (\n            <View>{title}</View>\n          )}\n        </View>\n      );\n    }\n    if (!props.renderItem) {\n      props.renderItem = noop;\n    }\n    if (!flat) {\n      return (\n        <View {...otherProps}>\n          {header}\n          {((renderItem && (!data || data.length === 0)) ||\n            (!renderItem && (!children || React.Children.toArray(children).length === 0))) &&\n            otherProps.ListEmptyComponent}\n          {(props.data || []).map((item, idx) =>\n            React.cloneElement((props.renderItem && props.renderItem({ item, index: idx })) || <View />, { key: idx }),\n          )}\n        </View>\n      );\n    }\n    return (\n      <FlatList\n        ListHeaderComponent={header}\n        keyExtractor={(__, index) => index.toString()}\n        {...otherProps}\n        {...props}\n      />\n    );\n  }\n}\n"]}