# <waterfall>

WARNING

<waterfall> is only supported on Android and iOS, and is not supported on web.

# Summary

A component providing waterfall layout over list component.

# Child Components

Notes: The waterfall only supports the following child components: cell, header, refresh, loading and fixed-position components. Other kinds of components will not be guaranteed to be displayed correctly.

  • cell: presents the content for a single data item in waterfall
  • header: components that need to stretch across multiple columns. It can be sticky by using css position.

# Attributes

  • column-width : This property describes the width of columns in waterfall elements.
    • auto: means that the column width will be determined by other properties(e.g., column-count, if it has a non-auto value).
    • <length>: describes the optimal column width. The actual column width may be wider (to fill the available space), or narrower (only if the available space is smaller than the specified column width). Specified values must be greater than 0.
  • column-count:This property describes the number of columns of a multicol element.
    • auto: means that the number of columns will be determined by other properties (e.g., column-width, if it has a non-auto value).
    • <integer>: describes the optimal number of columns into which the content of the element will be flowed. Values must be greater than 0. If both column-width and column-count have non-auto values, the integer value describes the maximum number of columns.
  • column-gap:sets the gap between columns. if normal is specified, the gap will be 32.
  • left-gap:sets the gap between left edge and left cell. if none is specified, the gap will be 0v0.19+.
  • right-gap:sets the gap between right edge and right most cell. if none is specified, the gap will be 0v0.19+.

To see other attributes in list, please checkout List Component Attributes

# Styles

common styles: check out common styles for components

  • support flexbox related styles
  • support box model related styles
  • support position related styles
  • support opacity, background-color etc.

# Events

common events: check out the common events

# API

All subcomponents in waterfall support the scrollToElement API in dom module

# Vue Example

waterfall example

# Rax Example

rax-waterfall is the component <waterfall> of rax, which can run in web and weex.

import { createElement, useState, useRef, render } from 'rax';
import View from 'rax-view';
import Text from 'rax-text';
import Driver from "driver-universal"
import RefreshControl from 'rax-refreshcontrol';
import Waterfall from 'rax-waterfall';

const data = [
  { height: 550, item: {} },
  { height: 624, item: {} },
  { height: 708, item: {} },
  { height: 600, item: {} },
  { height: 300, item: {} },
  { height: 100, item: {} },
  { height: 400, item: {} },
  { height: 550, item: {} },
  { height: 624, item: {} },
  { height: 708, item: {} },
  { height: 600, item: {} },
  { height: 300, item: {} },
  { height: 100, item: {} },
  { height: 400, item: {} }
];

let App = (props) => {

  let [refreshing, setRefreshing] = useState(false);
  let handleRefresh = () => {
    if (refreshing) {
      return;
    }
    setRefreshing(true);
    setTimeout(() => {
      setRefreshing(false);
    }, 500);
  }
  let loadMore = () => {
    console.log('load more');
  }

  return (
    <Waterfall
      columnWidth={370}
      columnCount={2}
      columnGap={10}
      dataSource={data}
      renderHeader={() => {
        return [
          <RefreshControl
            key="0"
            refreshing={refreshing}
            onRefresh={handleRefresh}>
            <Text>RefreshControl</Text>
          </RefreshControl>,
          <View key="1" style={{
            height: 100, 
            backgroundColor: '#efefef', 
            marginBottom: 10
          }}><Text>Header Mod</Text></View>
        ];
      }}
      renderFooter={() => {
        return <View key="3" style={{width: 750, height: 100, backgroundColor: '#efefef', marginTop: 10}}><Text>Footer Mod</Text></View>;
      }}
      renderItem={(item, index) => {
        return (
          <View style={{
            height: item.height, 
            backgroundColor: '#efefef', 
            marginBottom: 10
          }}>
            <Text>{index}</Text>
          </View>
        );
      }}
      onEndReached={loadMore} />
  );
}

render(<App />, document.body, { driver: Driver });

rax-waterfall doc

Last Updated: 8/15/2022
Excellent docUnusable doc