2024-11-13 01:13:21 -05:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
@pragma('vm:prefer-inline')
|
|
|
|
String _formatDuration(Duration position) {
|
|
|
|
final seconds = position.inSeconds.remainder(60).toString().padLeft(2, "0");
|
|
|
|
final minutes = position.inMinutes.remainder(60).toString().padLeft(2, "0");
|
|
|
|
if (position.inHours == 0) {
|
|
|
|
return "$minutes:$seconds";
|
|
|
|
}
|
|
|
|
final hours = position.inHours.toString().padLeft(2, '0');
|
|
|
|
return "$hours:$minutes:$seconds";
|
|
|
|
}
|
|
|
|
|
|
|
|
class FormattedDuration extends StatelessWidget {
|
|
|
|
final Duration data;
|
|
|
|
const FormattedDuration(this.data, {super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return SizedBox(
|
2024-11-13 09:39:21 -06:00
|
|
|
width: data.inHours > 0 ? 70 : 60, // use a fixed width to prevent jitter
|
2024-11-13 01:13:21 -05:00
|
|
|
child: Text(
|
|
|
|
_formatDuration(data),
|
|
|
|
style: const TextStyle(
|
|
|
|
fontSize: 14.0,
|
2024-11-13 19:49:25 -05:00
|
|
|
color: Colors.white,
|
|
|
|
fontWeight: FontWeight.w500,
|
2024-11-13 01:13:21 -05:00
|
|
|
),
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|