add multiSelect for local_comics_page

This commit is contained in:
boa-z
2024-11-07 23:30:01 +08:00
parent 234bf218a9
commit d910b8a35d

View File

@@ -24,8 +24,12 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
bool searchMode = false; bool searchMode = false;
bool multiSelectMode = false;
Map<LocalComic, bool> selectedComics = {};
void update() { void update() {
if(keyword.isEmpty) { if (keyword.isEmpty) {
setState(() { setState(() {
comics = LocalManager().getComics(sortType); comics = LocalManager().getComics(sortType);
}); });
@@ -95,8 +99,7 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
actions: [ actions: [
FilledButton( FilledButton(
onPressed: () { onPressed: () {
appdata.implicitData["local_sort"] = appdata.implicitData["local_sort"] =sortType.value;
sortType.value;
appdata.writeImplicitData(); appdata.writeImplicitData();
Navigator.pop(context); Navigator.pop(context);
update(); update();
@@ -115,7 +118,7 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
return Scaffold( return Scaffold(
body: SmoothCustomScrollView( body: SmoothCustomScrollView(
slivers: [ slivers: [
if(!searchMode) if (!searchMode && !multiSelectMode)
SliverAppbar( SliverAppbar(
title: Text("Local".tl), title: Text("Local".tl),
actions: [ actions: [
@@ -145,10 +148,38 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
showPopUpWidget(context, const DownloadingPage()); showPopUpWidget(context, const DownloadingPage());
}, },
), ),
) ),
Tooltip(
message: multiSelectMode
? "Exit Multi-Select".tl
: "Multi-Select".tl,
child: IconButton(
icon: const Icon(Icons.checklist),
onPressed: () {
setState(() {
multiSelectMode = !multiSelectMode;
});
},
),
),
], ],
) )
else else if (multiSelectMode)
SliverAppbar(
title: Text("Selected ${selectedComics.length} comics"),
actions: [
IconButton(
icon: const Icon(Icons.close),
onPressed: () {
setState(() {
multiSelectMode = false;
selectedComics.clear();
});
},
),
],
)
else if (searchMode)
SliverAppbar( SliverAppbar(
title: TextField( title: TextField(
autofocus: true, autofocus: true,
@@ -176,7 +207,17 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
), ),
SliverGridComics( SliverGridComics(
comics: comics, comics: comics,
onTap: (c) { onTap: multiSelectMode
? (c) {
setState(() {
if (selectedComics.containsKey(c as LocalComic)) {
selectedComics.remove(c as LocalComic);
} else {
selectedComics[c as LocalComic] = true;
}
});
}
: (c) {
(c as LocalComic).read(); (c as LocalComic).read();
}, },
menuBuilder: (c) { menuBuilder: (c) {
@@ -185,7 +226,23 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
icon: Icons.delete, icon: Icons.delete,
text: "Delete".tl, text: "Delete".tl,
onClick: () { onClick: () {
if (multiSelectMode) {
showConfirmDialog(
context: context,
title: "Delete".tl,
content: "Delete selected comics?".tl,
onConfirm: () {
for (var comic in selectedComics.keys) {
LocalManager().deleteComic(comic);
}
setState(() {
selectedComics.clear();
});
},
);
} else {
LocalManager().deleteComic(c as LocalComic); LocalManager().deleteComic(c as LocalComic);
}
}), }),
MenuEntry( MenuEntry(
icon: Icons.outbox_outlined, icon: Icons.outbox_outlined,
@@ -196,9 +253,20 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
allowCancel: false, allowCancel: false,
); );
try { try {
if (multiSelectMode) {
for (var comic in selectedComics.keys) {
var file = await CBZ.export(comic);
await saveFile(filename: file.name, file: file);
await file.delete();
}
setState(() {
selectedComics.clear();
});
} else {
var file = await CBZ.export(c as LocalComic); var file = await CBZ.export(c as LocalComic);
await saveFile(filename: file.name, file: file); await saveFile(filename: file.name, file: file);
await file.delete(); await file.delete();
}
} catch (e) { } catch (e) {
context.showMessage(message: e.toString()); context.showMessage(message: e.toString());
} }