You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

79 lines
2.3KB

  1. import 'package:farm_tpf/utils/const_color.dart';
  2. import 'package:flutter/material.dart';
  3. class SearchWidget extends StatefulWidget {
  4. final Function(String) searchPressed;
  5. SearchWidget({@required this.searchPressed});
  6. @override
  7. _SearchWidgetState createState() => _SearchWidgetState();
  8. }
  9. class _SearchWidgetState extends State<SearchWidget> {
  10. BuildContext _blocContext;
  11. TextEditingController _searchController = TextEditingController();
  12. @override
  13. void initState() {
  14. super.initState();
  15. _searchController.addListener(() {
  16. final keyword = _searchController.text;
  17. if (keyword.isNotEmpty) {
  18. //search when text change
  19. }
  20. });
  21. }
  22. Widget getSearchBarUI() {
  23. _searchController.text = "";
  24. return Padding(
  25. padding: const EdgeInsets.only(left: 8, right: 8, top: 0, bottom: 4),
  26. child: Row(
  27. children: <Widget>[
  28. Expanded(
  29. child: Padding(
  30. padding: const EdgeInsets.only(right: 8, top: 0, bottom: 0),
  31. child: Container(
  32. child: Padding(
  33. padding: const EdgeInsets.only(
  34. left: 16, right: 16, top: 4, bottom: 4),
  35. child: TextField(
  36. textInputAction: TextInputAction.done,
  37. controller: _searchController,
  38. onChanged: (String txt) {},
  39. cursorColor: AppColors.GRAY1,
  40. decoration: InputDecoration(
  41. suffixIcon: IconButton(
  42. icon: Icon(
  43. Icons.search,
  44. size: 30,
  45. ),
  46. onPressed: () {
  47. widget.searchPressed(_searchController.text);
  48. }),
  49. hintText: 'Tìm thiết bị',
  50. hintStyle: TextStyle(color: Colors.grey[500]),
  51. ),
  52. onSubmitted: widget.searchPressed,
  53. ),
  54. ),
  55. ),
  56. ),
  57. ),
  58. ],
  59. ),
  60. );
  61. }
  62. @override
  63. Widget build(BuildContext context) {
  64. _blocContext = context;
  65. return Container(child: getSearchBarUI());
  66. }
  67. @override
  68. void dispose() {
  69. _searchController.dispose();
  70. super.dispose();
  71. }
  72. }