mirror of
https://github.com/bggRGjQaUbCoE/PiliPlus.git
synced 2026-05-30 23:58:13 +08:00
mod: blacklist item
Closes #390 Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
import 'package:PiliPlus/common/widgets/dialog.dart';
|
||||||
import 'package:PiliPlus/common/widgets/loading_widget.dart';
|
import 'package:PiliPlus/common/widgets/loading_widget.dart';
|
||||||
import 'package:PiliPlus/common/widgets/refresh_indicator.dart';
|
import 'package:PiliPlus/common/widgets/refresh_indicator.dart';
|
||||||
import 'package:PiliPlus/http/loading_state.dart';
|
import 'package:PiliPlus/http/loading_state.dart';
|
||||||
@@ -59,7 +60,10 @@ class _BlackListPageState extends State<BlackListPage> {
|
|||||||
_blackListController.onLoadMore();
|
_blackListController.onLoadMore();
|
||||||
}
|
}
|
||||||
return ListTile(
|
return ListTile(
|
||||||
onTap: () {},
|
onTap: () {
|
||||||
|
Get.toNamed(
|
||||||
|
'/member?mid=${loadingState.response[index].mid}');
|
||||||
|
},
|
||||||
leading: NetworkImgLayer(
|
leading: NetworkImgLayer(
|
||||||
width: 45,
|
width: 45,
|
||||||
height: 45,
|
height: 45,
|
||||||
@@ -81,8 +85,11 @@ class _BlackListPageState extends State<BlackListPage> {
|
|||||||
),
|
),
|
||||||
dense: true,
|
dense: true,
|
||||||
trailing: TextButton(
|
trailing: TextButton(
|
||||||
onPressed: () => _blackListController
|
onPressed: () => _blackListController.removeBlack(
|
||||||
.removeBlack(loadingState.response[index].mid),
|
context,
|
||||||
|
loadingState.response[index].uname,
|
||||||
|
loadingState.response[index].mid,
|
||||||
|
),
|
||||||
child: const Text('移除'),
|
child: const Text('移除'),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
@@ -130,16 +137,23 @@ class BlackListController extends CommonController {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Future removeBlack(mid) async {
|
Future removeBlack(context, name, mid) async {
|
||||||
var result = await BlackHttp.removeBlack(fid: mid);
|
showConfirmDialog(
|
||||||
if (result['status']) {
|
context: context,
|
||||||
List list = (loadingState.value as Success).response;
|
title: '确定将 $name 移出黑名单?',
|
||||||
list.removeWhere((e) => e.mid == mid);
|
onConfirm: () async {
|
||||||
total.value = total.value - 1;
|
Get.back();
|
||||||
loadingState.value =
|
var result = await BlackHttp.removeBlack(fid: mid);
|
||||||
LoadingState.success(list.isNotEmpty ? list : <BlackListItem>[]);
|
if (result['status']) {
|
||||||
SmartDialog.showToast(result['msg']);
|
List list = (loadingState.value as Success).response;
|
||||||
}
|
list.removeWhere((e) => e.mid == mid);
|
||||||
|
total.value = total.value - 1;
|
||||||
|
loadingState.value =
|
||||||
|
LoadingState.success(list.isNotEmpty ? list : <BlackListItem>[]);
|
||||||
|
SmartDialog.showToast(result['msg']);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
|
|||||||
Reference in New Issue
Block a user