opt download (#1755)

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
dom
2025-11-27 21:00:13 +08:00
committed by GitHub
parent ded78e534f
commit 9ccaa3072b
25 changed files with 1161 additions and 410 deletions

View File

@@ -1,14 +1,25 @@
import 'dart:async';
import 'package:PiliPlus/common/widgets/dialog/dialog.dart';
import 'package:PiliPlus/models_new/download/download_info.dart';
import 'package:PiliPlus/pages/common/multi_select/base.dart'
show BaseMultiSelectMixin;
import 'package:PiliPlus/services/download/download_service.dart';
import 'package:PiliPlus/utils/storage.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:get/get.dart';
class DownloadPageController extends GetxController {
class DownloadPageController extends GetxController
with BaseMultiSelectMixin<DownloadPageInfo> {
final _downloadService = Get.find<DownloadService>();
final pages = RxList<DownloadPageInfo>();
final flag = RxInt(0);
@override
List<DownloadPageInfo> get list => pages;
@override
RxList<DownloadPageInfo> get state => pages;
@override
void onInit() {
super.onInit();
@@ -35,15 +46,6 @@ class DownloadPageController extends GetxController {
final page = list.firstWhereOrNull((e) => e.pageId == pageId);
if (page != null) {
final aSortKey = entry.sortKey;
if (!entry.isCompleted) {
if (page.entry case final lastEntry?) {
if (aSortKey < lastEntry.sortKey) {
page.entry = entry;
}
} else {
page.entry = entry;
}
}
final bSortKey = page.sortKey;
if (aSortKey < bSortKey) {
page
@@ -61,7 +63,6 @@ class DownloadPageController extends GetxController {
sortKey: entry.sortKey,
seasonType: entry.ep?.seasonType,
entrys: [entry],
entry: entry.isCompleted ? null : entry,
),
);
}
@@ -69,4 +70,32 @@ class DownloadPageController extends GetxController {
pages.value = list;
flag.value++;
}
@override
void onRemove() {
showConfirmDialog(
context: Get.context!,
title: '确定删除选中视频?',
onConfirm: () async {
SmartDialog.showLoading();
final allChecked = this.allChecked.toList();
final watchProgress = GStorage.watchProgress;
for (var page in allChecked) {
await watchProgress.deleteAll(
page.entrys.map((e) => e.cid.toString()),
);
await _downloadService.deletePage(
pageDirPath: page.dirPath,
refresh: false,
);
}
_downloadService.flagNotifier.refresh();
if (enableMultiSelect.value) {
rxCount.value = 0;
enableMultiSelect.value = false;
}
SmartDialog.dismiss();
},
);
}
}