Skip to content

Hemkesh/flutter_easy_search_bar

 
 

Repository files navigation

Easy Search Bar

Buy Me A Pizza

A Flutter plugin to help you handle search inside your application. Can be used inside appBar or inside your application body depending on your necessities.

Preview

Default AppBar Preview Floating AppBar Preview

Installation

In the pubspec.yaml of your flutter project, add the following dependency:

dependencies:
  ...
  easy_search_bar: ^2.3.1

Migrating from 1.x.x to 2.x.x

Now instead of using the EasySearchBar widget inside AppBar widget, you can replace the AppBar with it.

This is what you used before:

Scaffold(
  appBar: AppBar(
    title: EasySearchBar(
      title: 'Example',
      onSearch: (value) => setState(() => searchValue = value)
    )
  )
)

And this is what it is supposed to look like now:

Scaffold(
  appBar: EasySearchBar(
    title: Text('Example'),
    onSearch: (value) => setState(() => searchValue = value)
  )
)

Basic example with suggestions

You can create a simple searchbar example widget with suggestions with the following example:

import 'package:easy_search_bar/easy_search_bar.dart';
import 'package:flutter/material.dart';

void main() {
  runApp(const MyHomePage());
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({Key? key}) : super(key: key);

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  String searchValue = '';
  final List<String> _suggestions = ['Afeganistan', 'Albania', 'Algeria', 'Australia', 'Brazil', 'German', 'Madagascar', 'Mozambique', 'Portugal', 'Zambia'];

  @override
  Widget build(BuildContext context) {
    return  MaterialApp(
      title: 'Example',
      theme: ThemeData(
        primarySwatch: Colors.orange
      ),
      home: Scaffold(
        appBar: EasySearchBar(
          title: const Text('Example'),
          onSearch: (value) => setState(() => searchValue = value),
          suggestions: _suggestions
        ),
        drawer: Drawer(
          child: ListView(
            padding: EdgeInsets.zero,
            children: [
              const DrawerHeader(
                decoration: BoxDecoration(
                  color: Colors.blue,
                ),
                child: Text('Drawer Header'),
              ),
              ListTile(
                title: const Text('Item 1'),
                onTap: () => Navigator.pop(context)
              ),
              ListTile(
                title: const Text('Item 2'),
                onTap: () => Navigator.pop(context)
              )
            ]
          )
        ),
        body: Center(
          child: Text('Value: $searchValue')
        )
      )
    );
  }
}

Note: If you want to create a FloatingAppBar and want the body content to go behing the AppBar you need to set extendBodyBehindAppBar Scaffold property to true. And it's also recommended to wrap your Scaffold inside a SafeArea.

API

Attribute Type Required Description Default value
title Widget ✔️ The title to be displayed inside AppBar
onSearch Function(String) ✔️ Returns the current search value.When search is closed, this method returns an empty value to clear the current search
actions List<Widget> Extra custom actions that can be displayed inside AppBar
backgroundColor Color Can be used to change AppBar background color
foregroundColor Color Can be used to change AppBar foreground color
elevation double Can be used to change AppBar elevation 5
iconTheme IconThemeData Can be used to set custom icon theme for AppBar icons
appBarHeight double Can be used to change AppBar height 56
animationDuration Duration Can be used to set a duration for the AppBar search show and hide animation Duration(milliseconds: 450)
isFloating bool Can be used to determine if it will be a normal or floating AppBar false
titleTextStyle TextStyle Can be used to set the AppBar title style
searchBackgroundColor Color Can be used to set the search input background color
searchCursorColor Color Can be used to set search textfield cursor color
searchHintText String Can be used to set search textfield hint text
searchHintStyle TextStyle Can be used to set search textfield hint style
searchTextStyle TextStyle Can be used to set search textfield text style
searchBackIconTheme IconThemeData Can be used to set custom icon theme for the search textfield back button
systemOverlayStyle SystemUiOverlayStyle Can be used to set SystemUiOverlayStyle to the AppBar
suggestions List<String> Can be used to create a suggestions list
asyncSuggestions Future<List<String>> Function(String value) Can be used to set async suggestions list
suggestionsElevation double Can be used to change suggestion list elevation 5
suggestionLoaderBuilder Widget Function() A function that can be used to create a widget to display a custom suggestions loader
suggestionTextStyle TextStyle Can be used to change the suggestions text style
suggestionBackgroundColor Color Can be used to change suggestions list background color
suggestionBuilder Widget Function(String data) Can be used to create custom suggestion item widget
onSuggestionTap Function(String data) Instead of using the default suggestion tap action that fills the textfield, you can set your own custom action for it
debounceDuration Duration Can be used to set the debounce time for async data fetch Duration(milliseconds: 400)

Issues & Suggestions

If you encounter any issue you or want to leave a suggestion you can do it by filling an issue.

Thank you for the support!

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dart 88.4%
  • HTML 10.1%
  • Swift 1.1%
  • Other 0.4%