Skip to content

SearchBar

Manages a "search view" route that allows the user to select one of the suggested completions for a search query.

Inherits: LayoutControl

Properties

Events

Methods

  • close_view

    Closes an opened search view.

  • focus

    Requests focus for this control.

  • open_view

    Opens the search view.

Examples#

Live example

Basic Example#

import flet as ft

colors = [
    "Amber",
    "Blue Grey",
    "Brown",
    "Deep Orange",
    "Green",
    "Light Blue",
    "Orange",
    "Red",
]


def main(page: ft.Page):
    page.horizontal_alignment = ft.CrossAxisAlignment.CENTER

    def build_tiles(items: list[str]) -> list[ft.ListTile]:
        return [
            ft.ListTile(
                title=ft.Text(item),
                data=item,
                on_click=handle_tile_click,
            )
            for item in items
        ]

    async def handle_tile_click(e: ft.Event[ft.ListTile]):
        await anchor.close_view()

    async def handle_change(e: ft.Event[ft.SearchBar]):
        query = e.control.value.strip().lower()
        matching = (
            [color for color in colors if query in color.lower()] if query else colors
        )
        anchor.controls = build_tiles(matching)

    def handle_submit(e: ft.Event[ft.SearchBar]):
        print(f"Submit: {e.data}")

    async def handle_tap(e: ft.Event[ft.SearchBar]):
        await anchor.open_view()

    page.add(
        anchor := ft.SearchBar(
            view_elevation=4,
            divider_color=ft.Colors.AMBER,
            bar_hint_text="Search colors...",
            view_hint_text="Choose a color from the suggestions...",
            on_change=handle_change,
            on_submit=handle_submit,
            on_tap=handle_tap,
            controls=build_tiles(colors),
        ),
    )


ft.run(main)

basic

Properties#

autofocus class-attribute instance-attribute #

autofocus: bool = False

Whether the text field should focus itself if nothing else is already focused.

bar_bgcolor class-attribute instance-attribute #

bar_bgcolor: ControlStateValue[ColorValue] | None = None

Defines the background color of the search bar in all or specific ControlState states.

bar_border_side class-attribute instance-attribute #

bar_border_side: ControlStateValue[BorderSide] | None = None

The color and weight of the search bar's outline.

This value is combined with bar_shape to create a shape decorated with an outline.

bar_elevation class-attribute instance-attribute #

bar_elevation: ControlStateValue[Number | None] | None = (
    None
)

The elevation of the search bar.

bar_hint_text class-attribute instance-attribute #

bar_hint_text: str | None = None

Defines the text to be shown in the search bar when it is empty and the search view is close.

Usually some text that suggests what sort of input the field accepts.

bar_hint_text_style class-attribute instance-attribute #

bar_hint_text_style: ControlStateValue[TextStyle] | None = (
    None
)

The style to use for the SearchBar.bar_hint_text.

bar_leading class-attribute instance-attribute #

bar_leading: Control | None = None

A control to display before the text input field when the search view is close.

Typically an Icon or an IconButton.

bar_overlay_color class-attribute instance-attribute #

bar_overlay_color: ControlStateValue[ColorValue] | None = (
    None
)

Defines the highlight color that's typically used to indicate that the search bar is in FOCUSED, HOVERED, or PRESSED states.

bar_padding class-attribute instance-attribute #

bar_padding: ControlStateValue[PaddingValue] | None = None

The padding between the search bar's boundary and its contents.

bar_scroll_padding class-attribute instance-attribute #

bar_scroll_padding: PaddingValue = 20

Configures the padding around a Scrollable when the text field scrolls into view.

If the bar's text field is partially off-screen or covered (e.g., by the keyboard), it scrolls into view, ensuring it is positioned at the specified distance from the Scrollable edges.

bar_shadow_color class-attribute instance-attribute #

bar_shadow_color: ControlStateValue[ColorValue] | None = (
    None
)

The shadow color of the search bar.

bar_shape class-attribute instance-attribute #

bar_shape: ControlStateValue[OutlinedBorder] | None = None

The shape of the search bar.

This shape is combined with bar_border_side to create a shape decorated with an outline.

bar_size_constraints class-attribute instance-attribute #

bar_size_constraints: BoxConstraints | None = None

Optional size constraints for the search bar.

bar_text_style class-attribute instance-attribute #

bar_text_style: ControlStateValue[TextStyle] | None = None

The style to use for the text being edited.

bar_trailing class-attribute instance-attribute #

bar_trailing: list[Control] | None = None

A list of controls to display after the text input field when the search view is close.

These controls can represent additional modes of searching (e.g voice search), an avatar, or an overflow menu and are usually not more than two.

capitalization class-attribute instance-attribute #

capitalization: TextCapitalization | None = None

Enables automatic on-the-fly capitalization of entered text.

controls class-attribute instance-attribute #

controls: list[Control] = field(default_factory=list)

The list of controls to be displayed below the search bar when in search view.

Typically ListTiles and will be displayed in a ListView.

divider_color class-attribute instance-attribute #

divider_color: ColorValue | None = None

The color of the divider when in search view.

full_screen class-attribute instance-attribute #

full_screen: bool = False

Defines whether the search view grows to fill the entire screen when the search bar is tapped.

keyboard_type class-attribute instance-attribute #

keyboard_type: KeyboardType = TEXT

The type of action button to use for the keyboard.

shrink_wrap class-attribute instance-attribute #

shrink_wrap: bool | None = None

Whether the search view should shrink-wrap its contents.

value class-attribute instance-attribute #

value: str = ''

The text in the search bar.

view_bar_padding class-attribute instance-attribute #

view_bar_padding: PaddingValue | None = None

The padding to use for the search view's search bar.

If null, then the default value is 8.0 horizontally.

view_bgcolor class-attribute instance-attribute #

view_bgcolor: ColorValue | None = None

Defines the background color of the search view.

view_elevation class-attribute instance-attribute #

view_elevation: Number | None = None

Defines the elevation of the search view.

view_header_height class-attribute instance-attribute #

view_header_height: Number | None = None

The height of the search field on the search view.

view_header_text_style class-attribute instance-attribute #

view_header_text_style: TextStyle | None = None

Defines the text style of the text being edited on the search view.

view_hint_text class-attribute instance-attribute #

view_hint_text: str | None = None

Defines the text to be displayed when the search bar's input field is empty.

view_hint_text_style class-attribute instance-attribute #

view_hint_text_style: TextStyle | None = None

Defines the text style of view_hint_text.

view_leading class-attribute instance-attribute #

view_leading: Control | None = None

A Control to display before the text input field when the search view is open.

Typically an Icon or an IconButton.

Defaults to a back button which closes/pops the search view.

view_padding class-attribute instance-attribute #

view_padding: PaddingValue | None = None

The padding to use for the search view.

Has no effect if the search view is full-screen.

view_shape class-attribute instance-attribute #

view_shape: OutlinedBorder | None = None

Defines the shape of the search view.

view_side class-attribute instance-attribute #

view_side: BorderSide | None = None

Defines the color and weight of the search view's outline.

view_size_constraints class-attribute instance-attribute #

view_size_constraints: BoxConstraints | None = None

Optional size constraints for the search view.

By default, the search view has the same width as the search bar and is ⅔ the height of the screen. If the width and height of the view are within the view_size_constraints, the view will show its default size. Otherwise, the size of the view will be constrained by this property.

view_trailing class-attribute instance-attribute #

view_trailing: list[Control] | None = None

A list of Controls to display after the text input field when the search view is open.

Defaults to a close button which closes/pops the search view.

Events#

on_blur class-attribute instance-attribute #

on_blur: ControlEventHandler[SearchBar] | None = None

Fired when the search bar loses focus.

on_change class-attribute instance-attribute #

on_change: ControlEventHandler[SearchBar] | None = None

Called when the typed input in the search bar has changed.

on_focus class-attribute instance-attribute #

on_focus: ControlEventHandler[SearchBar] | None = None

Fired when the search bar gains focus.

on_submit class-attribute instance-attribute #

on_submit: ControlEventHandler[SearchBar] | None = None

Called when user presses ENTER while focus is on SearchBar.

on_tap class-attribute instance-attribute #

on_tap: ControlEventHandler[SearchBar] | None = None

Called when the search bar is tapped.

on_tap_outside_bar class-attribute instance-attribute #

on_tap_outside_bar: (
    ControlEventHandler[SearchBar] | None
) = None

Fired when the user taps outside the search bar while the search view is open.

Methods#

close_view async #

close_view(text: str | None = None)

Closes an opened search view.

Parameters:

  • text (str | None, default: None ) –

    The text to set in the search bar when closing the view. If not provided, the current value of the search bar will be used.

focus async #

focus()

Requests focus for this control.

open_view async #

open_view()

Opens the search view.