Separates list elements by conditionally inserting new elements.

Overview

This is a handy little package that brings the separate extension method to lists/iterables.

Useful for e.g putting space between children in a Row/Column in flutter, similar to ListView.separated.

It might be the most straightforward way to add gap between elements like in Figma.

Basic usage

This package operates on lists/iterables so it's very flexible. Here follows some examples specifically for putting gaps between elements in a Column. See the example for more details.

Fixed spacing

Column(
  children: <Widget>[
    if (imgUrl != null) Header(url: imgUrl),
    Text(name),
    if (age != null) Text(age),
  ].separate((i, e0, e1) => const SizedBox(height: 16)),
)
// i=index, e0=element before, e1=element after
// Basically: "Separate element e0 and e1 with returned element"

Dynamic spacing

Column(
  children: <Widget>[
    if (imgUrl != null) Header(url: imgUrl),
    Text(name),
    if (age != null) Text(age),
  ].separate(
    (i, e0, e1) => const SizedBox(
      // Increased gap between the header and name
      height: e0 is Header ? 24 : 16,
    ),
  ),
)

Before and after

Column(
  children: <Widget>[
    if (imgUrl != null) Header(url: imgUrl),
    if (age != null) Text(age),
  ].separate(
    // Put nothing between elements
    (i, e0, e1) => null,
    // Top=32 (only if there are any elements at all)
    before: (first) => const SizedBox(height: 32),
    // Bottom divider, if last item is the header
    after: (last) => last is Header ? const Divider() : null,
  ),
);

Author

Libraries

separate