1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2024-11-22 12:59:21 +00:00

Can delete posts

This commit is contained in:
Pierre HUBERT 2019-05-19 14:54:09 +02:00
parent d3f5fb6c28
commit 1fbe59c83c
4 changed files with 85 additions and 25 deletions

View File

@ -56,6 +56,16 @@ class PostsHelper {
}
}
/// Delete a post
Future<bool> delete(int id) async {
return (await APIRequest(
uri: "posts/delete",
needLogin: true,
args: {"postID": id.toString()},
).exec())
.isOK;
}
/// Turn an API entry into a [Post] object
Post _apiToPost(Map<String, dynamic> map) {
// Parse comments

View File

@ -32,8 +32,8 @@ class Post implements LikeElement {
final UserAccessLevels access;
final CommentsList comments;
Post({
@required this.id,
Post(
{@required this.id,
@required this.userID,
@required this.userPageID,
@required this.groupID,
@ -53,8 +53,8 @@ class Post implements LikeElement {
@required this.likes,
@required this.userLike,
@required this.access,
@required this.comments
}) : assert(id != null),
@required this.comments})
: assert(id != null),
assert(userID != null),
assert(userPageID != 0 || groupID != 0),
assert(timeSent != null),
@ -69,4 +69,8 @@ class Post implements LikeElement {
bool get hasContent => content != null;
bool get hasComments => comments != null;
bool get canDelete =>
access == UserAccessLevels.FULL ||
access == UserAccessLevels.INTERMEDIATE;
}

View File

@ -4,6 +4,7 @@ import 'package:comunic/enums/likes_type.dart';
import 'package:comunic/enums/post_kind.dart';
import 'package:comunic/helpers/comments_helper.dart';
import 'package:comunic/helpers/likes_helper.dart';
import 'package:comunic/helpers/posts_helper.dart';
import 'package:comunic/lists/users_list.dart';
import 'package:comunic/models/comment.dart';
import 'package:comunic/models/like_element.dart';
@ -29,16 +30,22 @@ const TextStyle _userNameStyle = TextStyle(
fontWeight: FontWeight.w600,
fontSize: 16.0);
/// Post actions
enum _PostActions { DELETE }
class PostTile extends StatefulWidget {
final Post post;
final UsersList usersInfo;
final void Function(Post) onDeletedPost;
const PostTile({
Key key,
@required this.post,
@required this.usersInfo,
@required this.onDeletedPost,
}) : assert(post != null),
assert(usersInfo != null),
assert(onDeletedPost != null),
super(key: key);
@override
@ -47,6 +54,7 @@ class PostTile extends StatefulWidget {
class _PostTileState extends State<PostTile> {
// Helpers
final _postsHelper = PostsHelper();
final _likesHelper = LikesHelper();
final _commentsHelper = CommentsHelper();
@ -89,8 +97,16 @@ class _PostTileState extends State<PostTile> {
),
),
PopupMenuButton(
itemBuilder: (c) => [],
PopupMenuButton<_PostActions>(
itemBuilder: (c) => [
// Delete post
PopupMenuItem(
child: Text(tr("Delete")),
value: _PostActions.DELETE,
enabled: widget.post.canDelete,
),
],
onSelected: _selectedPostMenuAction,
)
],
);
@ -402,4 +418,30 @@ class _PostTileState extends State<PostTile> {
widget.post.comments.remove(comment);
});
}
/// Method called each time the user has selected an option
void _selectedPostMenuAction(_PostActions value) {
switch (value) {
case _PostActions.DELETE:
confirmDelete();
break;
}
}
/// Perform the deletion of the post
Future<void> confirmDelete() async {
// Ask user confirmation
if (!await showConfirmDialog(
context: context,
message: tr(
"Do you really want to delete this post ? The operation can not be reverted !"),
)) return;
if (!await _postsHelper.delete(widget.post.id)) {
showSimpleSnack(context, tr("Could not delete the post!"));
return;
}
widget.onDeletedPost(widget.post);
}
}

View File

@ -1,6 +1,7 @@
import 'package:comunic/helpers/users_helper.dart';
import 'package:comunic/lists/posts_list.dart';
import 'package:comunic/lists/users_list.dart';
import 'package:comunic/models/post.dart';
import 'package:comunic/ui/screens/conversation_screen.dart';
import 'package:comunic/ui/tiles/post_tile.dart';
import 'package:comunic/utils/intl_utils.dart';
@ -73,6 +74,7 @@ class _PostsListWidgetState extends State<PostsListWidget> {
itemBuilder: (c, i) => PostTile(
post: _list[i],
usersInfo: _users,
onDeletedPost: _removePost,
),
);
}
@ -83,4 +85,6 @@ class _PostsListWidgetState extends State<PostsListWidget> {
if (_list == null) return buildCenteredProgressBar();
return _buildListView();
}
void _removePost(Post post) => setState(() => _list.remove(post));
}