cdb_ui/lib/pages/flow.dart

112 lines
3 KiB
Dart
Raw Normal View History

2024-09-20 06:52:56 +00:00
import 'package:cdb_ui/api.dart' as API;
2024-09-19 06:46:48 +00:00
import 'package:flutter/material.dart';
class FlowsPage extends StatelessWidget {
const FlowsPage({super.key});
2024-09-23 08:31:40 +00:00
Widget listAllFlowInfos(
BuildContext context, Map<String, API.FlowInfo> infos) {
return ListView(
children: infos.values.map((x) {
return ListTile(
title: Text(x.name),
onTap: () {
Navigator.of(context).push(MaterialPageRoute(
builder: (context) => FlowPage(x),
));
},
);
}).toList());
}
2024-09-19 06:46:48 +00:00
@override
Widget build(BuildContext context) {
2024-09-23 08:31:40 +00:00
// todo : flows (info) by item produced
2024-09-20 06:52:56 +00:00
// todo : list currently active
// todo : flows by item needed (show only avail)
2024-09-19 06:46:48 +00:00
return Scaffold(
appBar: AppBar(title: const Text("Flows")),
body: FutureBuilder(
2024-09-20 06:52:56 +00:00
future: API.API().getFlows(),
2024-09-19 06:46:48 +00:00
builder: (ctx, snap) {
if (!snap.hasData) {
return const CircularProgressIndicator();
}
var data = snap.data!;
2024-09-23 08:31:40 +00:00
return listAllFlowInfos(context, data);
2024-09-19 06:46:48 +00:00
}));
}
}
class FlowPage extends StatelessWidget {
2024-09-20 06:52:56 +00:00
final API.FlowInfo info;
2024-09-19 06:46:48 +00:00
const FlowPage(this.info, {super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text(info.name)),
body: Column(
children: [
// todo : ui improve
if (info.next != null) Text("Next: ${info.next}"),
if (info.depends.isNotEmpty)
Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
const Text("Flow can use: "),
...info.depends.map((x) => Text(x)).toList(),
],
),
if (info.produces?.isNotEmpty ?? false)
Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
const Text("Flow can produce: "),
...info.produces!.map((x) => Text(x)).toList(),
],
),
const Divider(),
FutureBuilder(
2024-09-20 06:52:56 +00:00
future: API.API().getActiveFlowsOf(info.id),
2024-09-19 06:46:48 +00:00
builder: (context, snapshot) {
if (!snapshot.hasData) {
return const CircularProgressIndicator();
}
var data = snapshot.data!;
2024-09-20 06:52:56 +00:00
return ListView(
children: data
.map((x) => ListTile(
title: Text(x.id),
onTap: () =>
Navigator.of(context).push(MaterialPageRoute(
builder: (context) => ActiveFlowPage(x),
))))
.toList());
2024-09-19 06:46:48 +00:00
},
)
],
),
);
}
}
2024-09-20 06:52:56 +00:00
class ActiveFlowPage extends StatelessWidget {
late API.Flow flow;
ActiveFlowPage(this.flow);
@override
Widget build(BuildContext context) {
return Scaffold(
body: Column(
children: [],
));
}
}