Skip to content

Latest commit

 

History

History
69 lines (56 loc) · 2.73 KB

README.md

File metadata and controls

69 lines (56 loc) · 2.73 KB

Filterchips

Filterchips is a lightweight UI component that lets you add an aligned field of chips that can be used for filtering (or anything else). It has no other dependencies, supports Auto-Layout and is Swift only.

In a later release it will support laying out any view conforming to some protocol.

FilterChipViewContainer is instantiated with an array of FilterChipViews. These are aligned automatically in a line breaking layout based on a given configuration.

You can configure the layout via FilterChipViewContainer.Configuration which is currently pretty basic. It supports configuring the alignment, vertical margin between the chips and the horizontal margins between rows.

grafik grafik grafik grafik

grafik

Example

A FilterChipViewContainer manages any number of FilterChipViews. Currently, only adding FilterChipViews is possible, in a later update a protocol will be added, conforming views can be added and laid out to FilterChipViewContainer as well.

You can create a FilterChipViewContainer and later set its chipViews property or fill it with FilterChipView during initializing.

/// Initialize a `FilterChipViewContainer` with a `FilterChipViewContainer.Configuration`
let chipsContainer = FilterChipViewContainer(
    configuration: .init(
        alignment: .center,
        horizontalMargin: 8,
        verticalMargin: 8
    )
)

/// Add `FilterChipView`s
chipsContainer.chipViews = [
    "Hello!",
    "We",
    "are",
    "FilterChipViews!",
    "Let's",
    "create",
    "funky",
    "filters!"
].map {
    FilterChipView(text: $0,
                   selectedColor: .systemGreen,
                   tapHandler: nil)
}

/// Adding `FilterChipView`s during initialization
let chipsContainer = FilterChipViewContainer(
    filterChipViews: [
        .init(text: "Hello", selectedColor: .systemGreen, tapHandler: nil),
        .init(text: "🚀", selectedColor: .systemRed, tapHandler: nil),
        .init(text: "🚂", selectedColor: .systemBlue, tapHandler: nil)
    ],
    configuration: .init(
        alignment: .center,
        horizontalMargin: 8,
        verticalMargin: 8
    )
)

Changelog

0.0.2 - updated readme, added code examples 0.0.1 - initial version with basic configuration