view.dart 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  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: Container(
  44. color: ColorName.transparent,
  45. padding:
  46. EdgeInsets.only(left: 12.w, right: 12.w, top: 11.h, bottom: 13.h),
  47. child: Column(
  48. crossAxisAlignment: CrossAxisAlignment.start,
  49. children: [
  50. SizedBox(
  51. height: 24.w,
  52. child: Row(
  53. children: [
  54. Container(
  55. decoration: const BoxDecoration(
  56. color: ColorName.colorPrimary,
  57. shape: BoxShape.circle,
  58. ),
  59. width: 20.w,
  60. height: 20.w,
  61. child: Center(
  62. child: Text(
  63. item.speakerId.toString(),
  64. style: TextStyle(fontSize: 12.sp, color: Colors.white),
  65. ),
  66. ),
  67. ),
  68. SizedBox(width: 6.w),
  69. Text(item.speaker.toString(),
  70. style: TextStyle(
  71. fontSize: 14.sp,
  72. color: ColorName.secondaryTextColor)),
  73. SizedBox(width: 4.w),
  74. Text(formatMilliseconds(item.startMs),
  75. style: TextStyle(
  76. fontSize: 12.sp, color: ColorName.tertiaryTextColor)),
  77. const Spacer(),
  78. Obx(() {
  79. return Visibility(
  80. visible: item.isSelected(),
  81. child: GestureDetector(
  82. onTap: () {
  83. controller.talkTranslateClick(item);
  84. },
  85. child: Container(
  86. margin: EdgeInsets.only(right: 12.w),
  87. child: Assets.images.iconTalkTranslate
  88. .image(width: 24.w, height: 24.w)),
  89. ),
  90. );
  91. })
  92. ],
  93. ),
  94. ),
  95. SizedBox(height: 12.h),
  96. Obx(() {
  97. return Text(item.sentence.toString(),
  98. style: TextStyle(
  99. fontSize: 14.sp,
  100. color: item.isSelected()
  101. ? ColorName.colorPrimary
  102. : ColorName.primaryTextColor));
  103. }),
  104. Obx(() {
  105. return Visibility(
  106. visible:
  107. item.getTranslateStatus() == TalkTranslate.translating ||
  108. item.getTranslateStatus() == TalkTranslate.translated,
  109. child: Container(
  110. width: double.infinity,
  111. margin: EdgeInsets.only(top: 8.w),
  112. decoration: BoxDecoration(
  113. color: '#FAF9FB'.toColor(),
  114. border: Border.all(color: '#F2EFF5'.toColor(), width: 1.w),
  115. borderRadius: BorderRadius.circular(6.w),
  116. ),
  117. padding:
  118. EdgeInsets.symmetric(vertical: 11.w, horizontal: 10.w),
  119. child: RichText(
  120. text: TextSpan(
  121. children: [
  122. WidgetSpan(
  123. alignment: PlaceholderAlignment.middle,
  124. child: Container(
  125. margin: EdgeInsets.only(right: 6.w),
  126. child: Assets.images.iconTalkTranslateSmall
  127. .image(width: 22.w, height: 22.w),
  128. ),
  129. ),
  130. TextSpan(
  131. text: item.getTranslatedSentence() ??
  132. StringName.translating.tr,
  133. style: TextStyle(
  134. fontSize: 14.sp,
  135. color: ColorName.secondaryTextColor),
  136. ),
  137. ],
  138. ),
  139. ),
  140. ),
  141. );
  142. })
  143. ],
  144. ),
  145. ),
  146. );
  147. }
  148. String formatMilliseconds(int? totalMilliseconds) {
  149. if (totalMilliseconds == null) {
  150. return '';
  151. }
  152. int totalSeconds = (totalMilliseconds / 1000).round();
  153. int hours = totalSeconds ~/ 3600;
  154. int minutes = (totalSeconds % 3600) ~/ 60;
  155. int seconds = totalSeconds % 60;
  156. if (hours > 0) {
  157. return '${hours.toString().padLeft(2, '0')}:${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  158. } else {
  159. return '${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  160. }
  161. }
  162. }