Skip to content

Commit

Permalink
Reset comments on block (#1886)
Browse files Browse the repository at this point in the history
  • Loading branch information
ifosli committed Nov 20, 2023
1 parent ae907e4 commit 235c6ae
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 3 deletions.
Expand Up @@ -10,13 +10,18 @@ private enum Layout {
}
}

protocol CommentRepliesViewControllerDelegate: AnyObject {
func commentRepliesViewControllerDidBlockUser(_: CommentRepliesViewController)
}

final class CommentRepliesViewController: UITableViewController, MessageBannerViewControllerPresenting {
// MARK: Properties

private let dataSource = CommentRepliesDataSource()
internal let viewModel: CommentRepliesViewModelType = CommentRepliesViewModel()

public var messageBannerViewController: MessageBannerViewController?
weak var delegate: CommentRepliesViewControllerDelegate?

private lazy var commentComposer: CommentComposerView = {
let frame = CGRect(x: 0, y: 0, width: self.view.frame.width, height: Layout.Composer.originalHeight)
Expand Down Expand Up @@ -75,6 +80,7 @@ final class CommentRepliesViewController: UITableViewController, MessageBannerVi
self.navigationItem.title = Strings.Replies()

self.messageBannerViewController = self.configureMessageBannerViewController(on: self)
self.messageBannerViewController?.delegate = self
self.tableView.dataSource = self.dataSource
self.tableView.delegate = self
self.tableView.registerCellClass(CommentCell.self)
Expand Down Expand Up @@ -166,14 +172,16 @@ final class CommentRepliesViewController: UITableViewController, MessageBannerVi
self.viewModel.outputs.userBlocked
.observeForUI()
.observeValues { [weak self] success in
self?.commentComposer.isHidden = true
guard let self else { return }
self.commentComposer.isHidden = true

// Scott TODO: Use localized strings once translations can be done [mbl-1037](https://kickstarter.atlassian.net/browse/MBL-1037)
if success {
self?.messageBannerViewController?
self.messageBannerViewController?
.showBanner(with: .success, message: "This user has been successfully blocked")
self.delegate?.commentRepliesViewControllerDidBlockUser(self)
} else {
self?.messageBannerViewController?
self.messageBannerViewController?
.showBanner(with: .error, message: "Your request did not go through. Try again.")
}
}
Expand Down Expand Up @@ -252,6 +260,16 @@ extension CommentRepliesViewController: RootCommentCellDelegate {
}
}

// MARK: - MessageBannerViewControllerDelegate

extension CommentRepliesViewController: MessageBannerViewControllerDelegate {
func messageBannerViewDidHide(type: MessageBannerType) {
if type == .success {
self.navigationController?.popViewController(animated: true)
}
}
}

// MARK: - Styles

private let tableViewStyle: TableViewStyle = { tableView in
Expand Down
Expand Up @@ -65,6 +65,7 @@ internal final class CommentsViewController: UITableViewController, MessageBanne
self.commentComposer.delegate = self

self.messageBannerViewController = self.configureMessageBannerViewController(on: self)
self.messageBannerViewController?.delegate = self
self.tableView.registerCellClass(CommentCell.self)
self.tableView.registerCellClass(CommentPostFailedCell.self)
self.tableView.registerCellClass(CommentRemovedCell.self)
Expand Down Expand Up @@ -147,6 +148,7 @@ internal final class CommentsViewController: UITableViewController, MessageBanne
inputAreaBecomeFirstResponder: becomeFirstResponder,
replyId: nil
)
vc.delegate = self
self?.navigationController?.pushViewController(vc, animated: true)
}

Expand Down Expand Up @@ -284,6 +286,14 @@ extension CommentsViewController: CommentCellDelegate {
}
}

// MARK: - CommentRepliesViewControllerDelegate

extension CommentsViewController: CommentRepliesViewControllerDelegate {
func commentRepliesViewControllerDidBlockUser(_: CommentRepliesViewController) {
self.tableView.scrollToTop()
self.viewModel.inputs.refresh() }
}

// MARK: - CommentRemovedCellDelegate

extension CommentsViewController: CommentRemovedCellDelegate {
Expand All @@ -292,6 +302,17 @@ extension CommentsViewController: CommentRemovedCellDelegate {
}
}

// MARK: - MessageBannerViewControllerDelegate

extension CommentsViewController: MessageBannerViewControllerDelegate {
func messageBannerViewDidHide(type: MessageBannerType) {
if type == .success {
self.tableView.scrollToTop()
self.viewModel.inputs.refresh()
}
}
}

// MARK: - Styles

private let tableViewStyle: TableViewStyle = { tableView in
Expand Down

0 comments on commit 235c6ae

Please sign in to comment.