mirror of
https://github.com/venera-app/venera.git
synced 2025-09-27 07:47:24 +00:00
add multiSelect for local_comics_page
This commit is contained in:
@@ -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,16 +207,42 @@ class _LocalComicsPageState extends State<LocalComicsPage> {
|
|||||||
),
|
),
|
||||||
SliverGridComics(
|
SliverGridComics(
|
||||||
comics: comics,
|
comics: comics,
|
||||||
onTap: (c) {
|
onTap: multiSelectMode
|
||||||
(c as LocalComic).read();
|
? (c) {
|
||||||
},
|
setState(() {
|
||||||
|
if (selectedComics.containsKey(c as LocalComic)) {
|
||||||
|
selectedComics.remove(c as LocalComic);
|
||||||
|
} else {
|
||||||
|
selectedComics[c as LocalComic] = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
: (c) {
|
||||||
|
(c as LocalComic).read();
|
||||||
|
},
|
||||||
menuBuilder: (c) {
|
menuBuilder: (c) {
|
||||||
return [
|
return [
|
||||||
MenuEntry(
|
MenuEntry(
|
||||||
icon: Icons.delete,
|
icon: Icons.delete,
|
||||||
text: "Delete".tl,
|
text: "Delete".tl,
|
||||||
onClick: () {
|
onClick: () {
|
||||||
LocalManager().deleteComic(c as LocalComic);
|
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);
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
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 {
|
||||||
var file = await CBZ.export(c as LocalComic);
|
if (multiSelectMode) {
|
||||||
await saveFile(filename: file.name, file: file);
|
for (var comic in selectedComics.keys) {
|
||||||
await file.delete();
|
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);
|
||||||
|
await saveFile(filename: file.name, file: file);
|
||||||
|
await file.delete();
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
context.showMessage(message: e.toString());
|
context.showMessage(message: e.toString());
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user