85 lines
2.8 KiB
Dart
Raw Normal View History

2022-08-02 15:56:37 +05:30
import 'package:flutter/material.dart';
class SearchBar extends StatefulWidget {
2022-08-08 00:24:45 +01:00
const SearchBar({
2023-11-11 19:07:32 +07:00
super.key,
2022-08-08 00:45:52 +05:30
required this.hintText,
this.showSelectIcon = false,
this.onSelectAll,
required this.onQueryChanged,
2023-11-11 19:07:32 +07:00
});
final String? hintText;
final bool showSelectIcon;
final Function(bool)? onSelectAll;
2022-08-02 15:56:37 +05:30
2022-08-02 18:41:29 +05:30
final Function(String) onQueryChanged;
2022-08-02 15:56:37 +05:30
@override
State<SearchBar> createState() => _SearchBarState();
}
class _SearchBarState extends State<SearchBar> {
2022-08-12 01:45:51 +03:00
final TextEditingController _textController = TextEditingController();
bool _toggleSelectAll = false;
2022-08-02 15:56:37 +05:30
@override
Widget build(BuildContext context) {
return Container(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(48),
color: Theme.of(context).colorScheme.secondaryContainer,
2022-08-02 15:56:37 +05:30
),
child: Row(
children: <Widget>[
2022-08-02 15:56:37 +05:30
Expanded(
child: TextFormField(
2022-08-02 18:41:29 +05:30
onChanged: widget.onQueryChanged,
2022-08-12 01:45:51 +03:00
controller: _textController,
style: TextStyle(
color: Theme.of(context).colorScheme.secondary,
),
2022-08-02 15:56:37 +05:30
decoration: InputDecoration(
filled: true,
fillColor: Theme.of(context).colorScheme.secondaryContainer,
2022-08-02 15:56:37 +05:30
contentPadding: const EdgeInsets.all(12.0),
2022-08-08 00:45:52 +05:30
hintText: widget.hintText,
prefixIcon: Icon(
2022-08-02 15:56:37 +05:30
Icons.search,
color: Theme.of(context).colorScheme.secondary,
2022-08-02 15:56:37 +05:30
),
2022-08-12 01:45:51 +03:00
suffixIcon: _textController.text.isNotEmpty
? IconButton(
icon: const Icon(Icons.clear),
onPressed: () {
_textController.clear();
widget.onQueryChanged('');
},
)
: widget.showSelectIcon
? IconButton(
icon: _toggleSelectAll
? const Icon(Icons.deselect)
: const Icon(Icons.select_all),
onPressed: widget.onSelectAll != null
? () {
setState(() {
_toggleSelectAll = !_toggleSelectAll;
});
widget.onSelectAll!(_toggleSelectAll);
}
: () => {},
)
: null,
2022-08-02 15:56:37 +05:30
border: OutlineInputBorder(
borderRadius: BorderRadius.circular(100),
2022-08-02 15:56:37 +05:30
borderSide: BorderSide.none,
),
),
),
),
],
),
);
}
}