controller.dart 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. import 'dart:io';
  2. import 'package:electronic_assistant/base/base_controller.dart';
  3. import 'package:electronic_assistant/resource/string.gen.dart';
  4. import 'package:electronic_assistant/utils/audio_picker_utils.dart';
  5. import 'package:electronic_assistant/utils/error_handler.dart';
  6. import 'package:electronic_assistant/utils/file_upload_check_helper.dart';
  7. import 'package:electronic_assistant/utils/toast_util.dart';
  8. import 'package:flutter/cupertino.dart';
  9. import 'package:flutter_screenutil/flutter_screenutil.dart';
  10. import 'package:get/get.dart';
  11. import 'package:photo_manager/photo_manager.dart';
  12. import 'package:pull_to_refresh/pull_to_refresh.dart';
  13. import 'package:uuid/uuid.dart';
  14. import '../../data/bean/talks.dart';
  15. import '../../data/repositories/talk_repository.dart';
  16. import '../../dialog/alert_dialog.dart';
  17. import '../../resource/colors.gen.dart';
  18. import '../talk/view.dart';
  19. class AudioPickerController extends BaseController {
  20. final audioList = RxList<AssetEntity>();
  21. AssetPathEntity? currentPath;
  22. final _currentEntity = Rxn<AssetEntity?>();
  23. AssetEntity? get currentEntity => _currentEntity.value;
  24. final refreshController = RefreshController(initialRefresh: false);
  25. int limit = 20;
  26. int totalCount = 0;
  27. @override
  28. void onReady() async {
  29. super.onReady();
  30. if (!await AudioPickerUtils.hasPermission()) {
  31. bool isAllow = await _showRequestPermissionDialog();
  32. if (isAllow) {
  33. bool permission = await AudioPickerUtils.requestPermissionExtend();
  34. if (!permission) {
  35. _onRecordPermissionDenied();
  36. return;
  37. }
  38. } else {
  39. _onRecordPermissionDenied();
  40. return;
  41. }
  42. }
  43. currentPath = await initPathEntity();
  44. totalCount = await currentPath?.assetCountAsync ?? 0;
  45. requestList(0, limit, isClearAll: true);
  46. }
  47. _onRecordPermissionDenied() {
  48. ToastUtil.showToast(StringName.authorizationFailed.tr);
  49. }
  50. Future<bool> _showRequestPermissionDialog() async {
  51. bool? isAllow = await EAAlertDialog.show(
  52. contentWidget: Container(
  53. margin: EdgeInsets.only(top: 16.h),
  54. child: Text(
  55. textAlign: TextAlign.center,
  56. '是否允许小听获取此设备的存储权限,为您提供转文字、智能总结服务?',
  57. style: TextStyle(
  58. fontWeight: FontWeight.bold,
  59. fontSize: 15.sp,
  60. color: ColorName.primaryTextColor),
  61. ),
  62. ),
  63. cancelText: '禁止',
  64. confirmText: '允许',
  65. cancelOnTap: () {
  66. EAAlertDialog.dismiss(result: false);
  67. },
  68. confirmOnTap: () {
  69. EAAlertDialog.dismiss(result: true);
  70. });
  71. return isAllow ?? false;
  72. }
  73. void requestList(int offset, int limit, {bool? isClearAll = false}) {
  74. if (currentPath == null) {
  75. return;
  76. }
  77. AudioPickerUtils.getAssetListRange(currentPath!, offset, limit)
  78. .then((list) {
  79. if (isClearAll == true) {
  80. audioList.clear();
  81. }
  82. audioList.addAll(list);
  83. if (audioList.length >= totalCount) {
  84. debugPrint("getAssetListRange-没有更多数据了");
  85. refreshController.loadNoData();
  86. } else {
  87. refreshController.loadComplete();
  88. }
  89. refreshController.refreshCompleted();
  90. }).catchError((error) {
  91. debugPrint("requestTalkData-catchError-$error");
  92. refreshController.loadFailed();
  93. refreshController.refreshFailed();
  94. });
  95. }
  96. Future<AssetPathEntity?> initPathEntity() async {
  97. List<AssetPathEntity> listEntity =
  98. await AudioPickerUtils.getAssetPathList();
  99. if (listEntity.isEmpty) {
  100. return null;
  101. }
  102. return listEntity.first;
  103. }
  104. void onItemClick(AssetEntity entity) {
  105. _currentEntity.value = entity;
  106. }
  107. void onImportClick() async {
  108. AssetEntity? entity = _currentEntity.value;
  109. if (entity == null) {
  110. ToastUtil.showToast(StringName.pleaseChoiceLocalAudioFile.tr);
  111. return;
  112. }
  113. File? file = await entity.file;
  114. if (file == null) {
  115. ToastUtil.showToast('文件不存在');
  116. return;
  117. }
  118. //文件格式是否允许
  119. if (!FileUploadCheckHelper.isAllowAudioFile(file.path)) {
  120. ToastUtil.showToast(StringName.audioNotSupportType.tr);
  121. return;
  122. }
  123. //文件大小不能超过500M
  124. if (file.lengthSync() > 500 * 1024 * 1024) {
  125. ToastUtil.showToast(StringName.fileChoiceSizeLimit.tr);
  126. return;
  127. }
  128. //录音时长不能超过5小时不能低于3s
  129. if (entity.duration < 3) {
  130. ToastUtil.showToast(StringName.recordingDurationCannotLessThan3s.tr);
  131. return;
  132. }
  133. if (entity.duration > 5 * 60 * 60) {
  134. ToastUtil.showToast(StringName.fileAudioDurationLimit.tr);
  135. return;
  136. }
  137. //上传文件
  138. try {
  139. TalkBean bean = await talkRepository.talkCreate(
  140. const Uuid().v4(), entity.duration,
  141. localAudioUrl:
  142. FileUploadCheckHelper.joinUploadServerAudioTag(entity.id),
  143. uploadType: FileUploadType.local);
  144. Get.back();
  145. TalkPage.start(bean);
  146. } catch (e) {
  147. ErrorHandler.toastError(e);
  148. }
  149. }
  150. void onLoadMoreData() {
  151. requestList(audioList.length, limit);
  152. }
  153. void pickSystemFile() {
  154. FileUploadCheckHelper.choicePlatformLocalFileAndCreateOrder(
  155. choiceSuccessCallback: () {
  156. Get.back();
  157. });
  158. }
  159. }