view.dart 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. import 'package:electronic_assistant/base/base_page.dart';
  2. import 'package:electronic_assistant/data/bean/store_item.dart';
  3. import 'package:electronic_assistant/data/bean/talks.dart';
  4. import 'package:electronic_assistant/resource/assets.gen.dart';
  5. import 'package:electronic_assistant/resource/colors.gen.dart';
  6. import 'package:electronic_assistant/resource/string.gen.dart';
  7. import 'package:electronic_assistant/utils/expand.dart';
  8. import 'package:flutter/material.dart';
  9. import 'package:flutter_screenutil/flutter_screenutil.dart';
  10. import 'package:get/get.dart';
  11. import '../../../data/bean/talk_original.dart';
  12. import '../common_view.dart';
  13. import 'controller.dart';
  14. class OriginalView extends BasePage<OriginalController> {
  15. const OriginalView({super.key});
  16. @override
  17. Widget buildBody(BuildContext context) {
  18. return buildOriginalContentView();
  19. }
  20. Widget buildOriginalContentView() {
  21. return Obx(() {
  22. if (controller.originalList.isEmpty &&
  23. controller.talkController.talkBean.value?.status.value ==
  24. TalkStatus.analysisFail) {
  25. return getTalkFailView();
  26. } else if (controller.originalList.isEmpty) {
  27. return getTalkLoadingView();
  28. } else {
  29. return ListView.builder(
  30. padding: EdgeInsets.only(bottom: 150.h),
  31. itemBuilder: _buildOriginalItem,
  32. itemCount: controller.originalList.length,
  33. );
  34. }
  35. });
  36. }
  37. Widget _buildOriginalItem(BuildContext context, int index) {
  38. TalkOriginal item = controller.originalList[index];
  39. return GestureDetector(
  40. onTap: () {
  41. controller.talkController.seekTo(item.startMs);
  42. },
  43. child: Padding(
  44. padding:
  45. EdgeInsets.only(left: 12.w, right: 12.w, top: 11.h, bottom: 13.h),
  46. child: Column(
  47. crossAxisAlignment: CrossAxisAlignment.start,
  48. children: [
  49. SizedBox(
  50. height: 24.w,
  51. child: Row(
  52. children: [
  53. Container(
  54. decoration: const BoxDecoration(
  55. color: ColorName.colorPrimary,
  56. shape: BoxShape.circle,
  57. ),
  58. width: 20.w,
  59. height: 20.w,
  60. child: Center(
  61. child: Text(
  62. item.speakerId.toString(),
  63. style: TextStyle(fontSize: 12.sp, color: Colors.white),
  64. ),
  65. ),
  66. ),
  67. SizedBox(width: 6.w),
  68. Text(item.speaker.toString(),
  69. style: TextStyle(
  70. fontSize: 14.sp,
  71. color: ColorName.secondaryTextColor)),
  72. SizedBox(width: 4.w),
  73. Text(formatMilliseconds(item.startMs),
  74. style: TextStyle(
  75. fontSize: 12.sp, color: ColorName.tertiaryTextColor)),
  76. const Spacer(),
  77. Obx(() {
  78. return Visibility(
  79. visible: item.isSelected(),
  80. child: GestureDetector(
  81. onTap: () {
  82. controller.talkTranslateClick(item);
  83. },
  84. child: Container(
  85. margin: EdgeInsets.only(right: 12.w),
  86. child: Assets.images.iconTalkTranslate
  87. .image(width: 24.w, height: 24.w)),
  88. ),
  89. );
  90. })
  91. ],
  92. ),
  93. ),
  94. SizedBox(height: 12.h),
  95. Obx(() {
  96. return Text(item.sentence.toString(),
  97. style: TextStyle(
  98. fontSize: 14.sp,
  99. color: item.isSelected()
  100. ? ColorName.colorPrimary
  101. : ColorName.primaryTextColor));
  102. }),
  103. Obx(() {
  104. return Visibility(
  105. visible:
  106. item.getTranslateStatus() == TalkTranslate.translating ||
  107. item.getTranslateStatus() == TalkTranslate.translated,
  108. child: Container(
  109. width: double.infinity,
  110. margin: EdgeInsets.only(top: 8.w),
  111. decoration: BoxDecoration(
  112. color: '#FAF9FB'.toColor(),
  113. border: Border.all(color: '#F2EFF5'.toColor(), width: 1.w),
  114. borderRadius: BorderRadius.circular(6.w),
  115. ),
  116. padding:
  117. EdgeInsets.symmetric(vertical: 11.w, horizontal: 10.w),
  118. child: RichText(
  119. text: TextSpan(
  120. children: [
  121. WidgetSpan(
  122. alignment: PlaceholderAlignment.middle,
  123. child: Container(
  124. margin: EdgeInsets.only(right: 6.w),
  125. child: Assets.images.iconTalkTranslateSmall
  126. .image(width: 22.w, height: 22.w),
  127. ),
  128. ),
  129. TextSpan(
  130. text: item.getTranslatedSentence() ??
  131. StringName.translating.tr,
  132. style: TextStyle(
  133. fontSize: 14.sp,
  134. color: ColorName.secondaryTextColor),
  135. ),
  136. ],
  137. ),
  138. ),
  139. ),
  140. );
  141. })
  142. ],
  143. ),
  144. ),
  145. );
  146. }
  147. String formatMilliseconds(int? totalMilliseconds) {
  148. if (totalMilliseconds == null) {
  149. return '';
  150. }
  151. int totalSeconds = (totalMilliseconds / 1000).round();
  152. int hours = totalSeconds ~/ 3600;
  153. int minutes = (totalSeconds % 3600) ~/ 60;
  154. int seconds = totalSeconds % 60;
  155. if (hours > 0) {
  156. return '${hours.toString().padLeft(2, '0')}:${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  157. } else {
  158. return '${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  159. }
  160. }
  161. }