Files
gomix_flutter/lib/ports_tab.dart
2024-07-08 10:22:11 +02:00

128 lines
4.2 KiB
Dart

import 'package:flutter/material.dart';
import 'package:gomix_flutter/edit_port_dialog.dart';
import 'package:gomix_flutter/mixer_state.dart' as mixer;
enum MenuAction { edit, delete }
class PortsTab extends StatefulWidget {
final mixer.MixerState mixerState;
final void Function(Map<String, Object> data) sendAction;
const PortsTab(
{super.key, required this.mixerState, required this.sendAction});
@override
State<PortsTab> createState() => _PortsTabState();
}
class _PortsTabState extends State<PortsTab> {
final searchController = TextEditingController();
String searchText = "";
void onEditPort(mixer.Port port) {
CreatePortDialog().show(context, widget.sendAction, port, false);
}
void onDeletePort(mixer.Port port) {
showDialog<String>(
context: context,
builder: (BuildContext context) => AlertDialog(
title: const Text("Delete Port"),
content: Text("Are you sure you want to delete ${port.name}?"),
actions: <Widget>[
TextButton(
onPressed: () => Navigator.pop(context, 'Cancel'),
child: const Text('Cancel'),
),
TextButton(
onPressed: () {
widget.sendAction({"method": "deletePort", "uuid": port.uuid});
Navigator.pop(context, 'Delete');
},
child: const Text("Delete"),
),
],
),
);
}
@override
Widget build(BuildContext context) {
return SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
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
.where((elem) {
return elem.$2.name
.toLowerCase()
.contains(searchText.toLowerCase());
}).map(
(elem) => Card(
child: ListTile(
leading: (elem.$1 >= widget.mixerState.inputs.length)
? const Icon(Icons.speaker_outlined)
: const Icon(Icons.mic_none_outlined),
title: Text(elem.$2.name),
subtitle: Text('Backend: ${elem.$2.properties.backend}'),
trailing: PopupMenuButton<MenuAction>(
tooltip: "More Options",
onSelected: (MenuAction item) {
switch (item) {
case MenuAction.edit:
onEditPort(elem.$2);
case MenuAction.delete:
onDeletePort(elem.$2);
}
},
itemBuilder: (BuildContext context) =>
<PopupMenuEntry<MenuAction>>[
const PopupMenuItem<MenuAction>(
value: MenuAction.edit,
child: ListTile(
leading: Icon(Icons.mode_edit),
title: Text('Edit'),
),
),
const PopupMenuItem<MenuAction>(
value: MenuAction.delete,
child: ListTile(
leading: Icon(Icons.delete),
title: Text('Delete'),
),
),
],
),
),
),
)
],
),
),
);
}
}