Implement search in ports tab

This commit is contained in:
2024-07-08 10:22:11 +02:00
parent fd626950de
commit c6b714747c

View File

@ -15,6 +15,9 @@ class PortsTab extends StatefulWidget {
} }
class _PortsTabState extends State<PortsTab> { class _PortsTabState extends State<PortsTab> {
final searchController = TextEditingController();
String searchText = "";
void onEditPort(mixer.Port port) { void onEditPort(mixer.Port port) {
CreatePortDialog().show(context, widget.sendAction, port, false); CreatePortDialog().show(context, widget.sendAction, port, false);
} }
@ -48,9 +51,36 @@ class _PortsTabState extends State<PortsTab> {
child: Padding( child: Padding(
padding: const EdgeInsets.all(8.0), padding: const EdgeInsets.all(8.0),
child: Column( child: Column(
children: [...widget.mixerState.inputs, ...widget.mixerState.outputs] children: [
TextField(
decoration: InputDecoration(
prefixIcon: const Icon(Icons.search),
suffixIcon: IconButton(
icon: const Icon(Icons.clear),
onPressed: () {
setState(() {
searchController.text = "";
searchText = "";
});
},
),
labelText: 'Search',
border: const OutlineInputBorder(),
),
onChanged: (val) {
setState(() {
searchText = val;
});
},
controller: searchController),
const SizedBox(height: 10),
...[...widget.mixerState.inputs, ...widget.mixerState.outputs]
.indexed .indexed
.map( .where((elem) {
return elem.$2.name
.toLowerCase()
.contains(searchText.toLowerCase());
}).map(
(elem) => Card( (elem) => Card(
child: ListTile( child: ListTile(
leading: (elem.$1 >= widget.mixerState.inputs.length) leading: (elem.$1 >= widget.mixerState.inputs.length)
@ -89,7 +119,7 @@ class _PortsTabState extends State<PortsTab> {
), ),
), ),
) )
.toList(), ],
), ),
), ),
); );