view.dart 7.1 KB

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