mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-16 23:26:14 +08:00
78 lines
2.5 KiB
Dart
78 lines
2.5 KiB
Dart
import 'package:PiliPlus/common/constants.dart';
|
|
import 'package:PiliPlus/models/dynamics/article_opus/opus.dart';
|
|
import 'package:PiliPlus/pages/dynamics/widgets/vote.dart';
|
|
import 'package:PiliPlus/utils/app_scheme.dart';
|
|
import 'package:PiliPlus/utils/extension.dart';
|
|
import 'package:PiliPlus/utils/utils.dart';
|
|
import 'package:cached_network_image/cached_network_image.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:get/get.dart';
|
|
|
|
class ReadOpus extends StatelessWidget {
|
|
const ReadOpus({super.key, required this.ops});
|
|
|
|
final List<ReadOpusModel>? ops;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
if (ops.isNullOrEmpty) {
|
|
return const SliverToBoxAdapter();
|
|
}
|
|
|
|
return SliverList.separated(
|
|
itemCount: ops!.length,
|
|
itemBuilder: (context, index) {
|
|
try {
|
|
final item = ops![index];
|
|
if (item.insert is String) {
|
|
return SelectableText(item.insert);
|
|
}
|
|
|
|
if (item.insert is Insert) {
|
|
InsertCard card = item.insert.card;
|
|
if (card.url?.isNotEmpty == true) {
|
|
return GestureDetector(
|
|
onTap: () {
|
|
switch (item.attributes?.clazz) {
|
|
case 'article-card card':
|
|
if (card.id != null) {
|
|
Get.toNamed(
|
|
'/articlePage',
|
|
parameters: {
|
|
'id': card.id!.substring(2),
|
|
'type': 'read',
|
|
},
|
|
);
|
|
}
|
|
case 'video-card card':
|
|
if (card.id != null) {
|
|
PiliScheme.videoPush(null, card.id);
|
|
}
|
|
case 'vote-card card':
|
|
if (card.id != null) {
|
|
showVoteDialog(context, int.parse(card.id!));
|
|
}
|
|
}
|
|
},
|
|
child: ClipRRect(
|
|
borderRadius: StyleString.mdRadius,
|
|
child: CachedNetworkImage(
|
|
imageUrl: Utils.thumbnailImgUrl(card.url, 60),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
return Text('${item.attributes}');
|
|
} catch (e) {
|
|
return Text(e.toString());
|
|
}
|
|
},
|
|
separatorBuilder: (context, index) {
|
|
return const SizedBox(height: 10);
|
|
},
|
|
);
|
|
}
|
|
}
|