Files
PinePods-nix/PinePods-0.8.2/mobile/lib/ui/search/search_bar.dart
2026-03-03 10:57:43 -05:00

79 lines
2.7 KiB
Dart

// Copyright 2020 Ben Hills and the project contributors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'package:pinepods_mobile/l10n/L.dart';
import 'package:pinepods_mobile/ui/widgets/search_slide_route.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'search.dart';
class SearchBar extends StatefulWidget {
const SearchBar({super.key});
@override
State<SearchBar> createState() => _SearchBarState();
}
class _SearchBarState extends State<SearchBar> {
late TextEditingController _searchController;
late FocusNode _searchFocusNode;
@override
void initState() {
super.initState();
_searchController = TextEditingController();
_searchController.addListener(() {
setState(() {});
});
_searchFocusNode = FocusNode();
}
@override
void dispose() {
_searchFocusNode.dispose();
_searchController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return ListTile(
contentPadding: const EdgeInsets.only(left: 16, right: 16),
title: TextField(
controller: _searchController,
focusNode: _searchFocusNode,
keyboardType: TextInputType.text,
textInputAction: TextInputAction.search,
decoration: InputDecoration(hintText: L.of(context)!.search_for_podcasts_hint, border: InputBorder.none),
style: TextStyle(
color: Theme.of(context).primaryIconTheme.color,
fontSize: 18.0,
decorationColor: Theme.of(context).scaffoldBackgroundColor),
onSubmitted: (value) async {
await Navigator.push(
context,
SlideRightRoute(
widget: Search(searchTerm: value),
settings: const RouteSettings(name: 'search'),
));
_searchController.clear();
},
),
trailing: IconButton(
padding: EdgeInsets.zero,
tooltip: _searchFocusNode.hasFocus ? L.of(context)!.clear_search_button_label : null,
color: _searchFocusNode.hasFocus ? Theme.of(context).iconTheme.color : null,
splashColor: _searchFocusNode.hasFocus ? Theme.of(context).splashColor : Colors.transparent,
highlightColor: _searchFocusNode.hasFocus ? Theme.of(context).highlightColor : Colors.transparent,
icon: Icon(_searchController.text.isEmpty && !_searchFocusNode.hasFocus ? Icons.search : Icons.clear),
onPressed: () {
_searchController.clear();
FocusScope.of(context).requestFocus(FocusNode());
SystemChannels.textInput.invokeMethod<String>('TextInput.show');
}),
);
}
}