| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- import 'dart:io';
- import 'package:electronic_assistant/data/api/atmob_api.dart';
- import 'package:electronic_assistant/data/api/atmob_file_api.dart';
- import 'package:electronic_assistant/data/api/request/talk_create_request.dart';
- import 'package:electronic_assistant/data/api/request/talk_delete_request.dart';
- import 'package:electronic_assistant/data/api/request/talk_file_request.dart';
- import 'package:get/get.dart';
- import '../../utils/http_handler.dart';
- import '../api/request/talk_generate_request.dart';
- import '../api/request/talk_paginate_request.dart';
- import '../api/request/talk_rename_request.dart';
- import '../api/request/talk_request.dart';
- import '../api/response/talk_check_electric_response.dart';
- import '../api/response/talk_info_response.dart';
- import '../api/response/talk_paginate_response.dart';
- import '../bean/talk_original.dart';
- import '../bean/talks.dart';
- import 'account_repository.dart';
- class TalkRepository {
- TalkRepository._();
- final Set<String> _uploadingTalkIds = {};
- final _talkList = RxList<TalkBean>();
- RxList<TalkBean> get talkList => _talkList;
- bool isUploadingTalk(String talkId) {
- return _uploadingTalkIds.contains(talkId);
- }
- void renovateTalkData(TalkBean talkInfo) {
- for (int i = 0; i < _talkList.length; i++) {
- if (_talkList[i].id == talkInfo.id) {
- _talkList[i].updateBean(talkInfo);
- break;
- }
- }
- }
- void setTalkList(List<TalkBean> list) {
- _talkList.assignAll(list);
- }
- void addNewTalkData(TalkBean talkInfo) {
- _talkList.insert(0, talkInfo);
- }
- clearTalkList() {
- _talkList.clear();
- }
- Future<TalkPaginateResponse> refreshHomeTalkData({int? sortType = 1}) {
- int limit;
- if (_talkList.isEmpty) {
- limit = 10;
- } else {
- limit = _talkList.length;
- }
- return requestTalkPagePaginate(0, limit,
- sortType: sortType, isClearAll: true);
- }
- Future<TalkPaginateResponse> requestTalkPagePaginate(int offset, int limit,
- {String? searchKeyword, int? sortType = 1, bool? isClearAll = false}) {
- return talkPagePaginate(offset, limit,
- searchKeyword: searchKeyword, sortType: sortType)
- .then((response) {
- if (isClearAll == true) {
- _talkList.clear();
- }
- if (response.list != null) {
- _talkList.addAll(response.list!);
- }
- return response;
- });
- }
- ///sortType 1:按创建时间倒序 2:按更新时间倒序
- Future<TalkPaginateResponse> talkPagePaginate(int offset, int limit,
- {String? searchKeyword, int? sortType = 1}) {
- return atmobApi
- .talkPagePaginate(TalkPaginateRequest(offset, limit,
- searchKeyword: searchKeyword, sortType: sortType))
- .then(HttpHandler.handle(false));
- }
- Future<List<TalkOriginal>> talkOriginal(String? talkId) {
- return atmobApi
- .talkOriginal(
- TalkRequest(talkId, isExample: !accountRepository.isLogin.value))
- .then(HttpHandler.handle(false))
- .then((data) {
- if (data.list != null) {
- return data.list!;
- } else {
- return [];
- }
- });
- }
- // duration 音频时长,单位为秒
- Future<TalkCheckElectricResponse> checkElectric(double duration) {
- return atmobApi
- .checkElectric(TalkGenerateRequest(duration))
- .then(HttpHandler.handle(false));
- }
- Future<TalkInfoResponse> talkInfo(String id) {
- return atmobApi
- .talkInfo(TalkRequest(id, isExample: !accountRepository.isLogin.value))
- .then(HttpHandler.handle(true));
- }
- Future<void> talkRename(String? id, String? title) {
- return atmobApi
- .talkRename(TalkRenameRequest(id, title))
- .then(HttpHandler.handle(true));
- }
- Future<void> talkDelete(String? id) {
- return atmobApi
- .talkDelete(TalkDeleteRequest(id))
- .then(HttpHandler.handle(true));
- }
- Future<TalkBean> talkCreate(String requestId, int duration,
- {String? localAudioUrl, int? uploadType}) {
- return atmobApi
- .talkCreate(TalkCreateRequest(duration, requestId,
- localAudioUrl: localAudioUrl, uploadType: uploadType))
- .then(HttpHandler.handle(true))
- .then((bean) {
- //添加新的录音到最新记录
- talkRepository.addNewTalkData(bean);
- return bean;
- });
- }
- Future<String> uploadTalkFile(String talkId, double duration, File file) {
- _uploadingTalkIds.add(talkId);
- return atmobFileApi
- .uploadTalkFile(TalkFileRequest(talkId, duration, file: file).toJson())
- .then(HttpHandler.handle(true))
- .then((response) {
- _uploadingTalkIds.remove(talkId);
- return response.taskId;
- }).catchError((error) {
- _uploadingTalkIds.remove(talkId);
- throw error;
- });
- }
- }
- final talkRepository = TalkRepository._();
|