opt: dynamic comment push
This commit is contained in:
@ -127,7 +127,7 @@ class AtItem extends StatelessWidget {
|
||||
|
||||
return InkWell(
|
||||
onTap: () async {
|
||||
MessageUtils.onClickMessage(context, uri, nativeUri, type);
|
||||
MessageUtils.onClickMessage(context, uri, nativeUri, type, null);
|
||||
},
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(14),
|
||||
|
||||
@ -125,7 +125,7 @@ class LikeItem extends StatelessWidget {
|
||||
final String type = item.item!.type!;
|
||||
return InkWell(
|
||||
onTap: () async {
|
||||
MessageUtils.onClickMessage(context, uri, nativeUri, type);
|
||||
MessageUtils.onClickMessage(context, uri, nativeUri, type, null);
|
||||
},
|
||||
child: Stack(
|
||||
children: [
|
||||
|
||||
@ -117,7 +117,7 @@ class ReplyItem extends StatelessWidget {
|
||||
final String type = item.item!.type!;
|
||||
return InkWell(
|
||||
onTap: () async {
|
||||
MessageUtils.onClickMessage(context, uri, nativeUri, type);
|
||||
MessageUtils.onClickMessage(context, uri, nativeUri, type, item.item!);
|
||||
},
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(14),
|
||||
@ -155,6 +155,9 @@ class ReplyItem extends StatelessWidget {
|
||||
text: '回复了我的评论',
|
||||
style: TextStyle(color: outline),
|
||||
),
|
||||
if (item.item!.type! == 'dynamic')
|
||||
TextSpan(
|
||||
text: '对我的动态发表了评论', style: TextStyle(color: outline)),
|
||||
])),
|
||||
const SizedBox(height: 6),
|
||||
Text.rich(
|
||||
@ -197,11 +200,32 @@ class ReplyItem extends StatelessWidget {
|
||||
),
|
||||
),
|
||||
if (item.item!.type! == 'video')
|
||||
NetworkImgLayer(
|
||||
// NetworkImgLayer(
|
||||
// width: 60,
|
||||
// height: 60,
|
||||
// src: item.item!.image,
|
||||
// radius: 6,
|
||||
// ),
|
||||
Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
src: item.item!.image,
|
||||
radius: 6,
|
||||
clipBehavior: Clip.hardEdge,
|
||||
decoration: const BoxDecoration(
|
||||
borderRadius: BorderRadius.all(Radius.circular(6)),
|
||||
),
|
||||
child: Image.network(item.item!.image!, fit: BoxFit.cover),
|
||||
),
|
||||
if (item.item!.type! == 'dynamic')
|
||||
Container(
|
||||
width: 60,
|
||||
height: 80,
|
||||
padding: const EdgeInsets.all(4),
|
||||
child: Text(
|
||||
item.item!.title!,
|
||||
maxLines: 4,
|
||||
style: const TextStyle(fontSize: 12, letterSpacing: 0.3),
|
||||
overflow: TextOverflow.ellipsis,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
|
||||
@ -3,6 +3,7 @@ import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||||
import 'package:get/get.dart';
|
||||
import 'package:pilipala/http/search.dart';
|
||||
import 'package:pilipala/models/common/reply_type.dart';
|
||||
import 'package:pilipala/models/msg/reply.dart';
|
||||
import 'package:pilipala/pages/video/detail/reply_reply/index.dart';
|
||||
import 'package:pilipala/utils/app_scheme.dart';
|
||||
import 'package:pilipala/utils/utils.dart';
|
||||
@ -10,7 +11,12 @@ import 'package:pilipala/utils/utils.dart';
|
||||
class MessageUtils {
|
||||
// 回复我的、收到的赞点击
|
||||
static void onClickMessage(
|
||||
BuildContext context, Uri uri, Uri nativeUri, String type) async {
|
||||
BuildContext context,
|
||||
Uri uri,
|
||||
Uri nativeUri,
|
||||
String type,
|
||||
ReplyContentItem? item,
|
||||
) async {
|
||||
final String path = uri.path;
|
||||
final String bvid = path.split('/').last;
|
||||
String? sourceType;
|
||||
@ -24,8 +30,8 @@ class MessageUtils {
|
||||
if (nativePath.contains('detail')) {
|
||||
// 动态详情
|
||||
sourceType = 'opus';
|
||||
oid = nativePath.split('/')[3];
|
||||
commentRootId = nativePath.split('/')[4];
|
||||
oid = item?.subjectId!.toString() ?? nativePath.split('/')[3];
|
||||
commentRootId = item?.sourceId!.toString() ?? nativePath.split('/')[4];
|
||||
}
|
||||
switch (type) {
|
||||
case 'video':
|
||||
@ -47,6 +53,7 @@ class MessageUtils {
|
||||
}
|
||||
break;
|
||||
case 'reply':
|
||||
case 'dynamic':
|
||||
debugPrint('commentRootId: $oid, $commentRootId');
|
||||
navigateToComment(
|
||||
context,
|
||||
|
||||
@ -282,8 +282,14 @@ class PiliSchame {
|
||||
}
|
||||
break;
|
||||
default:
|
||||
final Map<String, String> queryParameters = value.queryParameters;
|
||||
final String? enterUri = queryParameters['enterUri'];
|
||||
if (enterUri != null && enterUri.startsWith('bilibili://')) {
|
||||
biliScheme(Uri.parse(enterUri));
|
||||
} else {
|
||||
SmartDialog.showToast('未匹配地址,请联系开发者');
|
||||
Clipboard.setData(ClipboardData(text: value.toString()));
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user