view.dart 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import 'package:electronic_assistant/base/base_page.dart';
  2. import 'package:electronic_assistant/resource/colors.gen.dart';
  3. import 'package:flutter/material.dart';
  4. import 'package:flutter_screenutil/flutter_screenutil.dart';
  5. import 'package:get/get.dart';
  6. import '../../../data/bean/talk_original.dart';
  7. import '../common_view.dart';
  8. import 'controller.dart';
  9. class OriginalView extends BasePage<OriginalController> {
  10. const OriginalView({super.key});
  11. @override
  12. Widget buildBody(BuildContext context) {
  13. return buildOriginalContentView();
  14. }
  15. Widget buildOriginalContentView() {
  16. return Obx(() {
  17. if (controller.originalList.isEmpty) {
  18. return getTalkLoadingView();
  19. } else {
  20. return ListView.builder(
  21. padding: EdgeInsets.only(bottom: 70.h),
  22. itemBuilder: _buildOriginalItem,
  23. itemCount: controller.originalList.length,
  24. );
  25. }
  26. });
  27. }
  28. Widget _buildOriginalItem(BuildContext context, int index) {
  29. TalkOriginal item = controller.originalList[index];
  30. return Padding(
  31. padding:
  32. EdgeInsets.only(left: 12.w, right: 12.w, top: 11.h, bottom: 13.h),
  33. child: Column(
  34. crossAxisAlignment: CrossAxisAlignment.start,
  35. children: [
  36. Row(
  37. children: [
  38. Container(
  39. decoration: const BoxDecoration(
  40. color: ColorName.colorPrimary,
  41. shape: BoxShape.circle,
  42. ),
  43. width: 20.w,
  44. height: 20.w,
  45. child: Center(
  46. child: Text(
  47. item.speakerId.toString(),
  48. style: TextStyle(fontSize: 12.sp, color: Colors.white),
  49. ),
  50. ),
  51. ),
  52. SizedBox(width: 6.w),
  53. Text(item.speaker.toString(),
  54. style: TextStyle(
  55. fontSize: 14.sp, color: ColorName.secondaryTextColor)),
  56. SizedBox(width: 4.w),
  57. Text(formatMilliseconds(item.startMs),
  58. style: TextStyle(
  59. fontSize: 12.sp, color: ColorName.tertiaryTextColor)),
  60. ],
  61. ),
  62. SizedBox(height: 12.h),
  63. Text(item.sentence.toString(),
  64. style: TextStyle(
  65. fontSize: 14.sp, color: ColorName.primaryTextColor)),
  66. ],
  67. ),
  68. );
  69. }
  70. String formatMilliseconds(int? totalMilliseconds) {
  71. if (totalMilliseconds == null) {
  72. return '';
  73. }
  74. int totalSeconds = (totalMilliseconds / 1000).round();
  75. int hours = totalSeconds ~/ 3600;
  76. int minutes = (totalSeconds % 3600) ~/ 60;
  77. int seconds = totalSeconds % 60;
  78. if (hours > 0) {
  79. return '${hours.toString().padLeft(2, '0')}:${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  80. } else {
  81. return '${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  82. }
  83. }
  84. }