controller.dart 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. import 'dart:io';
  2. import 'package:electronic_assistant/base/base_controller.dart';
  3. import 'package:electronic_assistant/data/bean/talks.dart';
  4. import 'package:electronic_assistant/data/repositories/agenda_repository.dart';
  5. import 'package:electronic_assistant/data/repositories/config_repository.dart';
  6. import 'package:electronic_assistant/data/repositories/talk_repository.dart';
  7. import 'package:electronic_assistant/module/main/controller.dart';
  8. import 'package:electronic_assistant/module/talk/view.dart';
  9. import 'package:electronic_assistant/resource/string.gen.dart';
  10. import 'package:electronic_assistant/router/app_pages.dart';
  11. import 'package:electronic_assistant/utils/event_bus.dart';
  12. import 'package:electronic_assistant/widget/pull_to_refresh.dart';
  13. import 'package:file_picker/file_picker.dart';
  14. import 'package:flutter/cupertino.dart';
  15. import 'package:get/get.dart';
  16. import 'package:just_audio/just_audio.dart';
  17. import 'package:uuid/uuid.dart';
  18. import '../../data/api/response/example_info_response.dart';
  19. import '../../data/bean/agenda.dart';
  20. import '../../data/repositories/account_repository.dart';
  21. import '../../dialog/loading_dialog.dart';
  22. import '../../utils/error_handler.dart';
  23. import '../../utils/toast_util.dart';
  24. import 'package:path_provider/path_provider.dart';
  25. class HomePageController extends BaseController {
  26. get isLogin => accountRepository.isLogin.value;
  27. get loginTxt => accountRepository.isLogin.value
  28. ? accountRepository.getUserSubName(accountRepository.phone)
  29. : StringName.homeGoLogin.tr;
  30. final refreshController = PullToRefreshController();
  31. BuildContext? todoTargetContext;
  32. RxList<TalkBean> get talkList => talkRepository.talkList;
  33. RxList<Agenda> get agendaList => agendaRepository.agendaList;
  34. @override
  35. void onReady() {
  36. super.onReady();
  37. refreshController.requestRefresh();
  38. eventBus.on(EventUserLogin, (arg) {
  39. requestHomeData();
  40. });
  41. eventBus.on(EventUserLogout, (arg) {
  42. talkRepository.setTalkList([]);
  43. agendaRepository.setAgendaList([]);
  44. requestHomeData();
  45. });
  46. }
  47. @override
  48. void dispose() {
  49. // TODO: implement dispose
  50. super.dispose();
  51. eventBus.off(EventUserLogin);
  52. eventBus.off(EventUserLogout);
  53. }
  54. void requestHomeData() async {
  55. try {
  56. if (accountRepository.isLogin.value) {
  57. await Future.wait([
  58. talkRepository.refreshHomeTalkData(),
  59. agendaRepository.requestHomeAgendaData(),
  60. ]);
  61. } else {
  62. ExampleInfoResponse exampleInfo =
  63. await configRepository.getExampleInfo();
  64. talkRepository.setTalkList(
  65. exampleInfo.talkInfoList != null ? exampleInfo.talkInfoList! : []);
  66. agendaRepository.setAgendaList(
  67. exampleInfo.agendaList != null ? exampleInfo.agendaList! : []);
  68. }
  69. } catch (e) {
  70. refreshController.refreshCompleted();
  71. // Handle errors if necessary
  72. } finally {
  73. refreshController.refreshCompleted();
  74. }
  75. }
  76. void requestName(String? newName, TalkBean bean) {
  77. talkRepository.talkRename(bean.id, newName).then((data) {
  78. bean.title.value = newName;
  79. ToastUtil.showToast(StringName.talkRenameSuccess.tr);
  80. }).catchError((error) {
  81. ErrorHandler.toastError(error, message: StringName.talkRenameFail.tr);
  82. });
  83. }
  84. void goTalkRecordPage() {
  85. Get.find<MainController>().updateIndexByPageName(StringName.mainTabFile);
  86. }
  87. void showLoginDrawer() {
  88. Get.find<MainController>().openDrawer();
  89. }
  90. void requestDelete(TalkBean item) {
  91. talkRepository.talkDelete(item.id).then((data) {
  92. requestHomeData();
  93. }).catchError((error) {
  94. ErrorHandler.toastError(error, message: StringName.talkDeleteFail.tr);
  95. });
  96. }
  97. void agendaComplete(Agenda item) {
  98. agendaRepository.agendaFinish(item.id, true).then((data) {
  99. agendaRepository.removeItem(item);
  100. }).catchError((error) {
  101. ErrorHandler.toastError(error);
  102. });
  103. }
  104. void onPickerAudioFile() async {
  105. if (!accountRepository.isLogin.value) {
  106. Get.toNamed(RoutePath.login);
  107. ToastUtil.showToast(StringName.errorCodeNoLogin.tr);
  108. return;
  109. }
  110. FilePickerResult? result = await FilePicker.platform
  111. .pickFiles(type: FileType.custom, allowedExtensions: [
  112. 'wav',
  113. 'mp3',
  114. 'm4a',
  115. 'flv',
  116. 'mp4',
  117. 'wma',
  118. '3gp',
  119. 'amr',
  120. 'aac',
  121. 'ogg-opus',
  122. 'flac'
  123. ]);
  124. if (result != null) {
  125. LoadingDialog.show(StringName.fileImporting.tr);
  126. AudioPlayer? player;
  127. try {
  128. String filePath = result.files.single.path!;
  129. File file = File(filePath);
  130. //文件不能超过500M
  131. if (file.lengthSync() > 500 * 1024 * 1024) {
  132. ToastUtil.showToast(StringName.fileChoiceSizeLimit.tr);
  133. return;
  134. }
  135. player = AudioPlayer();
  136. player.setAudioSource(AudioSource.uri(file.uri));
  137. Duration? duration = await player.durationStream
  138. .firstWhere((duration) => duration != null);
  139. if (duration == null) {
  140. ToastUtil.showToast(StringName.fileAudioDurationCannotObtained.tr);
  141. return;
  142. }
  143. //录音时长不能超过5小时
  144. if (duration.inHours > 5) {
  145. ToastUtil.showToast(StringName.fileAudioDurationLimit.tr);
  146. return;
  147. }
  148. late TalkBean bean;
  149. try {
  150. bean = await talkRepository.talkCreate(
  151. const Uuid().v4(), duration.inSeconds,
  152. localAudioUrl: filePath, uploadType: 1);
  153. } catch (e) {
  154. ErrorHandler.toastError(e);
  155. return;
  156. }
  157. String childDirName = bean.id;
  158. Directory dir = await _getChoiceUploadDir(childDirName);
  159. await moveFileToDirectory(file, dir);
  160. TalkPage.start(bean);
  161. } catch (e) {
  162. ErrorHandler.toastError(e, message: StringName.fileImportFail.tr);
  163. } finally {
  164. player?.dispose();
  165. LoadingDialog.hide();
  166. }
  167. }
  168. }
  169. Future<void> moveFileToDirectory(File file, Directory dir) async {
  170. if (!dir.existsSync()) {
  171. dir.createSync(recursive: true);
  172. }
  173. String newFilePath = '${dir.path}/${file.uri.pathSegments.last}';
  174. file.renameSync(newFilePath);
  175. }
  176. }
  177. Future<Directory> _getChoiceUploadDir(String talkId) async {
  178. Directory documentDir = await getApplicationDocumentsDirectory();
  179. return Directory("${documentDir.path}/.atmob/choice/$talkId");
  180. }
  181. Future<File?> getChoiceUploadFile(String talkId) async {
  182. Directory dir = await _getChoiceUploadDir(talkId);
  183. if (!dir.existsSync()) {
  184. return null;
  185. }
  186. List<FileSystemEntity> list = dir.listSync();
  187. if (list.isEmpty) {
  188. return null;
  189. }
  190. return list.first as File;
  191. }