mirror of
https://github.com/venera-app/venera.git
synced 2025-09-27 07:47:24 +00:00
fix #33
This commit is contained in:
@@ -1,5 +1,6 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
|
import 'package:sliver_tools/sliver_tools.dart';
|
||||||
import 'package:url_launcher/url_launcher_string.dart';
|
import 'package:url_launcher/url_launcher_string.dart';
|
||||||
import 'package:venera/components/components.dart';
|
import 'package:venera/components/components.dart';
|
||||||
import 'package:venera/foundation/app.dart';
|
import 'package:venera/foundation/app.dart';
|
||||||
@@ -1021,6 +1022,8 @@ class _ComicThumbnailsState extends State<_ComicThumbnails> {
|
|||||||
|
|
||||||
String? error;
|
String? error;
|
||||||
|
|
||||||
|
bool isLoading = false;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void didChangeDependencies() {
|
void didChangeDependencies() {
|
||||||
state = context.findAncestorStateOfType<_ComicPageState>()!;
|
state = context.findAncestorStateOfType<_ComicPageState>()!;
|
||||||
@@ -1034,6 +1037,11 @@ class _ComicThumbnailsState extends State<_ComicThumbnails> {
|
|||||||
if (!isInitialLoading && next == null) {
|
if (!isInitialLoading && next == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Future.microtask(() {
|
||||||
|
setState(() {
|
||||||
|
isLoading = true;
|
||||||
|
});
|
||||||
|
});
|
||||||
var res = await state.comicSource.loadComicThumbnail!(state.comic.id, next);
|
var res = await state.comicSource.loadComicThumbnail!(state.comic.id, next);
|
||||||
if (res.success) {
|
if (res.success) {
|
||||||
thumbnails.addAll(res.data);
|
thumbnails.addAll(res.data);
|
||||||
@@ -1042,13 +1050,15 @@ class _ComicThumbnailsState extends State<_ComicThumbnails> {
|
|||||||
} else {
|
} else {
|
||||||
error = res.errorMessage;
|
error = res.errorMessage;
|
||||||
}
|
}
|
||||||
setState(() {});
|
setState(() {
|
||||||
|
isLoading = false;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return SliverMainAxisGroup(
|
return MultiSliver(
|
||||||
slivers: [
|
children: [
|
||||||
SliverToBoxAdapter(
|
SliverToBoxAdapter(
|
||||||
child: ListTile(
|
child: ListTile(
|
||||||
title: Text("Preview".tl),
|
title: Text("Preview".tl),
|
||||||
@@ -1148,7 +1158,7 @@ class _ComicThumbnailsState extends State<_ComicThumbnails> {
|
|||||||
],
|
],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
else if (next != null || isInitialLoading)
|
else if (isLoading)
|
||||||
const SliverToBoxAdapter(
|
const SliverToBoxAdapter(
|
||||||
child: ListLoadingIndicator(),
|
child: ListLoadingIndicator(),
|
||||||
),
|
),
|
||||||
|
Reference in New Issue
Block a user