v1.0.1
This commit is contained in:
23
lib/modules/comic/home/special/comic_special_controller.dart
Normal file
23
lib/modules/comic/home/special/comic_special_controller.dart
Normal file
@@ -0,0 +1,23 @@
|
||||
import 'package:flutter_dmzj/app/controller/base_controller.dart';
|
||||
import 'package:flutter_dmzj/models/comic/special_model.dart';
|
||||
import 'package:flutter_dmzj/requests/comic_request.dart';
|
||||
import 'package:flutter_dmzj/routes/app_navigator.dart';
|
||||
|
||||
class ComicSpecialController extends BasePageController<ComicSpecialModel> {
|
||||
final ComicRequest request = ComicRequest();
|
||||
|
||||
@override
|
||||
Future<List<ComicSpecialModel>> getData(int page, int pageSize) async {
|
||||
var ls = await request.special(page: page - 1);
|
||||
|
||||
return ls;
|
||||
}
|
||||
|
||||
void toDetail(ComicSpecialModel item) {
|
||||
if (item.pageType == 3) {
|
||||
AppNavigator.toSpecialDetail(item.id);
|
||||
} else {
|
||||
AppNavigator.toWebView(item.pageUrl);
|
||||
}
|
||||
}
|
||||
}
|
||||
65
lib/modules/comic/home/special/comic_special_view.dart
Normal file
65
lib/modules/comic/home/special/comic_special_view.dart
Normal file
@@ -0,0 +1,65 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_dmzj/app/app_style.dart';
|
||||
import 'package:flutter_dmzj/app/utils.dart';
|
||||
import 'package:flutter_dmzj/modules/comic/home/special/comic_special_controller.dart';
|
||||
import 'package:flutter_dmzj/widgets/keep_alive_wrapper.dart';
|
||||
import 'package:flutter_dmzj/widgets/net_image.dart';
|
||||
import 'package:flutter_dmzj/widgets/page_list_view.dart';
|
||||
import 'package:flutter_dmzj/widgets/shadow_card.dart';
|
||||
import 'package:get/get.dart';
|
||||
|
||||
class ComicSpecialView extends StatelessWidget {
|
||||
final ComicSpecialController controller;
|
||||
ComicSpecialView({Key? key})
|
||||
: controller = Get.put(ComicSpecialController()),
|
||||
super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return KeepAliveWrapper(
|
||||
child: PageListView(
|
||||
pageController: controller,
|
||||
firstRefresh: true,
|
||||
showPageLoadding: false,
|
||||
padding: AppStyle.edgeInsetsA12.copyWith(top: 0),
|
||||
separatorBuilder: (context, i) => AppStyle.vGap12,
|
||||
itemBuilder: (context, i) {
|
||||
var item = controller.list[i];
|
||||
return ShadowCard(
|
||||
onTap: () {
|
||||
controller.toDetail(item);
|
||||
},
|
||||
radius: 8,
|
||||
child: Column(
|
||||
children: [
|
||||
AspectRatio(
|
||||
aspectRatio: 710 / 284,
|
||||
child: NetImage(
|
||||
item.smallCover,
|
||||
width: 710,
|
||||
height: 354,
|
||||
),
|
||||
),
|
||||
Padding(
|
||||
padding: AppStyle.edgeInsetsA8,
|
||||
child: Row(
|
||||
children: [
|
||||
Expanded(child: Text(item.title)),
|
||||
Text(
|
||||
Utils.formatTimestampToDate(item.createTime),
|
||||
style: const TextStyle(
|
||||
fontSize: 14,
|
||||
color: Colors.grey,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user