opt multi del

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2025-08-05 17:18:40 +08:00
parent 3caa684b2e
commit 104d295389
58 changed files with 379 additions and 404 deletions

View File

@@ -119,7 +119,7 @@ class _FavNoteChildPageState extends State<FavNoteChildPage>
showConfirmDialog(
context: context,
title: '确定删除已选中的笔记吗?',
onConfirm: _favNoteController.onConfirm,
onConfirm: _favNoteController.onRemove,
);
}
},

View File

@@ -1,7 +1,7 @@
import 'package:PiliPlus/http/fav.dart';
import 'package:PiliPlus/http/loading_state.dart';
import 'package:PiliPlus/models_new/fav/fav_note/list.dart';
import 'package:PiliPlus/pages/common/multi_select_controller.dart';
import 'package:PiliPlus/pages/common/multi_select/multi_select_controller.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
class FavNoteController
@@ -35,11 +35,13 @@ class FavNoteController
}
@override
Future<void> onConfirm() async {
Set<FavNoteItemModel> removeList = allChecked.toSet();
Future<void> onRemove() async {
final removeList = allChecked;
final res = await FavHttp.delNote(
isPublish: isPublish,
noteIds: removeList.map((item) => isPublish ? item.cvid : item.noteId),
noteIds: removeList
.map((item) => isPublish ? item.cvid : item.noteId)
.join(','),
);
if (res['status']) {
afterDelete(removeList);

View File

@@ -3,7 +3,7 @@ import 'package:PiliPlus/http/loading_state.dart';
import 'package:PiliPlus/http/video.dart';
import 'package:PiliPlus/models_new/fav/fav_pgc/data.dart';
import 'package:PiliPlus/models_new/fav/fav_pgc/list.dart';
import 'package:PiliPlus/pages/common/multi_select_controller.dart';
import 'package:PiliPlus/pages/common/multi_select/multi_select_controller.dart';
import 'package:PiliPlus/utils/accounts.dart';
import 'package:flutter/foundation.dart' show kDebugMode;
import 'package:flutter/material.dart';
@@ -66,29 +66,29 @@ class FavPgcController
}
@override
void onConfirm() {
void onRemove() {
assert(false, 'call onUpdateList');
}
Future<void> onUpdateList(int followStatus) async {
final updateList = allChecked.toSet();
final removeList = allChecked;
final res = await VideoHttp.pgcUpdate(
seasonId: updateList.map((item) => item.seasonId).toList(),
seasonId: removeList.map((item) => item.seasonId).join(','),
status: followStatus,
);
if (res['status']) {
afterDelete(updateList);
try {
final ctr = Get.find<FavPgcController>(tag: '$type$followStatus');
if (ctr.loadingState.value.isSuccess) {
ctr.loadingState
..value.data!.insertAll(
0,
updateList.map((item) => item..checked = null),
removeList.map((item) => item..checked = null),
)
..refresh();
ctr.allSelected.value = false;
}
afterDelete(removeList);
} catch (e) {
if (kDebugMode) debugPrint('fav pgc onUpdate: $e');
}
@@ -98,7 +98,7 @@ class FavPgcController
Future<void> onUpdate(int index, int followStatus, int? seasonId) async {
var result = await VideoHttp.pgcUpdate(
seasonId: [seasonId],
seasonId: seasonId.toString(),
status: followStatus,
);
if (result['status']) {

View File

@@ -4,7 +4,7 @@ import 'package:PiliPlus/common/widgets/button/icon_button.dart';
import 'package:PiliPlus/common/widgets/image/network_img_layer.dart';
import 'package:PiliPlus/models/common/badge_type.dart';
import 'package:PiliPlus/models_new/fav/fav_pgc/list.dart';
import 'package:PiliPlus/pages/common/multi_select_controller.dart';
import 'package:PiliPlus/pages/common/multi_select/base.dart';
import 'package:PiliPlus/utils/page_utils.dart';
import 'package:flutter/material.dart';