✨ Implement search in ports tab
This commit is contained in:
@ -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(),
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
Reference in New Issue
Block a user