view.dart 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  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 getTalkAnalyseView(
  28. controller.talkController.isUploading.value == true &&
  29. controller.talkController.talkBean.value?.status.value ==
  30. TalkStatus.notAnalysis
  31. ? '录音上传中,请勿关闭小听'
  32. : controller
  33. .talkController.talkBean.value?.progressContent.value ??
  34. '',
  35. controller.talkController.isUploading.value == true &&
  36. controller.talkController.talkBean.value?.status.value ==
  37. TalkStatus.notAnalysis
  38. ? controller.talkController.uploadProgress.value
  39. : controller.talkController.talkBean.value?.progress.value
  40. ?.toDouble() ??
  41. 0.0);
  42. } else {
  43. return ListView.builder(
  44. padding: EdgeInsets.only(bottom: 150.h),
  45. itemBuilder: _buildOriginalItem,
  46. itemCount: controller.originalList.length,
  47. );
  48. }
  49. });
  50. }
  51. Widget _buildOriginalItem(BuildContext context, int index) {
  52. TalkOriginal item = controller.originalList[index];
  53. return GestureDetector(
  54. onTap: () {
  55. controller.talkController.seekTo(item.startMs);
  56. },
  57. child: Container(
  58. color: ColorName.transparent,
  59. padding:
  60. EdgeInsets.only(left: 12.w, right: 12.w, top: 11.h, bottom: 13.h),
  61. child: Column(
  62. crossAxisAlignment: CrossAxisAlignment.start,
  63. children: [
  64. SizedBox(
  65. height: 24.w,
  66. child: Row(
  67. children: [
  68. Container(
  69. decoration: const BoxDecoration(
  70. color: ColorName.colorPrimary,
  71. shape: BoxShape.circle,
  72. ),
  73. width: 20.w,
  74. height: 20.w,
  75. child: Center(
  76. child: Text(
  77. item.speakerId.toString(),
  78. style: TextStyle(fontSize: 12.sp, color: Colors.white),
  79. ),
  80. ),
  81. ),
  82. SizedBox(width: 6.w),
  83. Text(item.speaker.toString(),
  84. style: TextStyle(
  85. fontSize: 14.sp,
  86. color: ColorName.secondaryTextColor)),
  87. SizedBox(width: 4.w),
  88. Text(formatMilliseconds(item.startMs),
  89. style: TextStyle(
  90. fontSize: 12.sp, color: ColorName.tertiaryTextColor)),
  91. const Spacer(),
  92. Obx(() {
  93. return Visibility(
  94. visible: item.isSelected(),
  95. child: GestureDetector(
  96. onTap: () {
  97. controller.talkTranslateClick(item);
  98. },
  99. child: Container(
  100. margin: EdgeInsets.only(right: 12.w),
  101. child: Assets.images.iconTalkTranslate
  102. .image(width: 24.w, height: 24.w)),
  103. ),
  104. );
  105. })
  106. ],
  107. ),
  108. ),
  109. SizedBox(height: 12.h),
  110. Obx(() {
  111. return Text(item.sentence.toString(),
  112. style: TextStyle(
  113. fontSize: 14.sp,
  114. color: item.isSelected()
  115. ? ColorName.colorPrimary
  116. : ColorName.primaryTextColor));
  117. }),
  118. Obx(() {
  119. return Visibility(
  120. visible:
  121. item.getTranslateStatus() == TalkTranslate.translating ||
  122. item.getTranslateStatus() == TalkTranslate.translated,
  123. child: Container(
  124. width: double.infinity,
  125. margin: EdgeInsets.only(top: 8.w),
  126. decoration: BoxDecoration(
  127. color: '#FAF9FB'.toColor(),
  128. border: Border.all(color: '#F2EFF5'.toColor(), width: 1.w),
  129. borderRadius: BorderRadius.circular(6.w),
  130. ),
  131. padding:
  132. EdgeInsets.symmetric(vertical: 11.w, horizontal: 10.w),
  133. child: RichText(
  134. text: TextSpan(
  135. children: [
  136. WidgetSpan(
  137. alignment: PlaceholderAlignment.middle,
  138. child: Container(
  139. margin: EdgeInsets.only(right: 6.w),
  140. child: Assets.images.iconTalkTranslateSmall
  141. .image(width: 22.w, height: 22.w),
  142. ),
  143. ),
  144. TextSpan(
  145. text: item.getTranslatedSentence() ??
  146. StringName.translating.tr,
  147. style: TextStyle(
  148. fontSize: 14.sp,
  149. color: ColorName.secondaryTextColor),
  150. ),
  151. ],
  152. ),
  153. ),
  154. ),
  155. );
  156. })
  157. ],
  158. ),
  159. ),
  160. );
  161. }
  162. String formatMilliseconds(int? totalMilliseconds) {
  163. if (totalMilliseconds == null) {
  164. return '';
  165. }
  166. int totalSeconds = (totalMilliseconds / 1000).round();
  167. int hours = totalSeconds ~/ 3600;
  168. int minutes = (totalSeconds % 3600) ~/ 60;
  169. int seconds = totalSeconds % 60;
  170. if (hours > 0) {
  171. return '${hours.toString().padLeft(2, '0')}:${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  172. } else {
  173. return '${minutes.toString().padLeft(2, '0')}:${seconds.toString().padLeft(2, '0')}';
  174. }
  175. }
  176. }