2022-08-26 02:34:25 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:selfprivacy/logic/models/json/server_job.dart';
|
2024-11-06 00:22:30 +00:00
|
|
|
import 'package:selfprivacy/ui/atoms/icons/job_icon.dart';
|
|
|
|
import 'package:selfprivacy/ui/atoms/progress_indicators/brand_linear_indicator.dart';
|
2022-08-26 02:34:25 +00:00
|
|
|
|
|
|
|
class ServerJobCard extends StatelessWidget {
|
|
|
|
const ServerJobCard({
|
2022-10-26 16:26:09 +00:00
|
|
|
required this.serverJob,
|
|
|
|
super.key,
|
2022-08-26 02:34:25 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
final ServerJob serverJob;
|
|
|
|
|
|
|
|
@override
|
2022-09-18 17:56:55 +00:00
|
|
|
Widget build(final BuildContext context) {
|
|
|
|
Color color;
|
|
|
|
IconData icon;
|
|
|
|
|
2024-11-05 19:27:21 +00:00
|
|
|
color = getJobColor(serverJob.status, context);
|
|
|
|
icon = getJobIcon(serverJob.status);
|
2022-09-18 17:56:55 +00:00
|
|
|
|
|
|
|
final String? statusString =
|
|
|
|
serverJob.error ?? serverJob.result ?? serverJob.statusText;
|
|
|
|
|
|
|
|
return GestureDetector(
|
|
|
|
child: Card(
|
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.all(16.0),
|
2022-08-26 02:34:25 +00:00
|
|
|
child: Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
2022-09-18 17:56:55 +00:00
|
|
|
Row(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
2022-09-18 22:11:26 +00:00
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
2022-09-18 17:56:55 +00:00
|
|
|
children: [
|
2022-09-18 22:11:26 +00:00
|
|
|
Flexible(
|
|
|
|
child: Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
serverJob.name,
|
|
|
|
style: Theme.of(context).textTheme.bodyMedium,
|
|
|
|
),
|
|
|
|
Text(
|
|
|
|
serverJob.description,
|
|
|
|
style: Theme.of(context).textTheme.bodySmall,
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
2022-09-18 17:56:55 +00:00
|
|
|
),
|
|
|
|
Icon(
|
|
|
|
icon,
|
|
|
|
color: color,
|
|
|
|
),
|
|
|
|
],
|
2022-08-26 02:34:25 +00:00
|
|
|
),
|
|
|
|
const SizedBox(height: 8),
|
|
|
|
BrandLinearIndicator(
|
|
|
|
value: serverJob.progress == null
|
|
|
|
? 0.0
|
|
|
|
: serverJob.progress! / 100.0,
|
2022-09-18 17:56:55 +00:00
|
|
|
color: color,
|
2024-08-21 09:22:20 +00:00
|
|
|
backgroundColor:
|
|
|
|
Theme.of(context).colorScheme.surfaceContainerHighest,
|
2024-10-23 01:46:56 +00:00
|
|
|
height: 8.0,
|
2022-08-26 02:34:25 +00:00
|
|
|
),
|
|
|
|
const SizedBox(height: 8),
|
2022-09-18 17:56:55 +00:00
|
|
|
if (statusString != null)
|
|
|
|
Text(
|
|
|
|
statusString,
|
|
|
|
style: Theme.of(context).textTheme.labelSmall?.copyWith(
|
|
|
|
color: Theme.of(context).colorScheme.onSurface,
|
|
|
|
),
|
|
|
|
),
|
2022-08-26 02:34:25 +00:00
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
2022-09-18 17:56:55 +00:00
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
2022-08-26 02:34:25 +00:00
|
|
|
}
|