From f6e785a8943c4a93a76ac6c718420d303f2d3223 Mon Sep 17 00:00:00 2001 From: CMK Date: Tue, 20 Apr 2021 13:40:14 +0800 Subject: [PATCH] feat: set GIF pause and auto resume when toggle content warning overlay --- .../Diffiable/Section/StatusSection.swift | 1 + .../StatusProvider/StatusProviderFacade.swift | 55 +++++++++++++++---- .../View/Container/PlayerContainerView.swift | 1 + .../Content/ContentWarningOverlayView.swift | 4 ++ 4 files changed, 49 insertions(+), 12 deletions(-) diff --git a/Mastodon/Diffiable/Section/StatusSection.swift b/Mastodon/Diffiable/Section/StatusSection.swift index 1dd155d5..4f09142a 100644 --- a/Mastodon/Diffiable/Section/StatusSection.swift +++ b/Mastodon/Diffiable/Section/StatusSection.swift @@ -469,6 +469,7 @@ extension StatusSection { statusView.revealContentWarningButton.isHidden = false statusView.contentWarningOverlayView.isHidden = true statusView.statusMosaicImageViewContainer.contentWarningOverlayView.isHidden = false + statusView.playerContainerView.contentWarningOverlayView.isHidden = false statusView.updateContentWarningDisplay(isHidden: true, animated: false) func updateContentOverlay() { diff --git a/Mastodon/Protocol/StatusProvider/StatusProviderFacade.swift b/Mastodon/Protocol/StatusProvider/StatusProviderFacade.swift index 75efcd36..2e610222 100644 --- a/Mastodon/Protocol/StatusProvider/StatusProviderFacade.swift +++ b/Mastodon/Protocol/StatusProvider/StatusProviderFacade.swift @@ -417,26 +417,52 @@ extension StatusProviderFacade { extension StatusProviderFacade { + static func responseToStatusContentWarningRevealAction(dependency: NotificationViewController, cell: UITableViewCell) { + let status = Future { promise in + guard let diffableDataSource = dependency.viewModel.diffableDataSource, + let indexPath = dependency.tableView.indexPath(for: cell), + let item = diffableDataSource.itemIdentifier(for: indexPath) else { + promise(.success(nil)) + return + } + + switch item { + case .notification(let objectID, _): + dependency.viewModel.fetchedResultsController.managedObjectContext.perform { + let notification = dependency.viewModel.fetchedResultsController.managedObjectContext.object(with: objectID) as! MastodonNotification + promise(.success(notification.status)) + } + default: + promise(.success(nil)) + } + } + + _responseToStatusContentWarningRevealAction( + dependency: dependency, + status: status + ) + } + static func responseToStatusContentWarningRevealAction(provider: StatusProvider, cell: UITableViewCell) { _responseToStatusContentWarningRevealAction( - provider: provider, + dependency: provider, status: provider.status(for: cell, indexPath: nil) ) } - private static func _responseToStatusContentWarningRevealAction(provider: StatusProvider, status: Future) { + private static func _responseToStatusContentWarningRevealAction(dependency: NeedsDependency, status: Future) { status - .compactMap { [weak provider] status -> AnyPublisher? in - guard let provider = provider else { return nil } + .compactMap { [weak dependency] status -> AnyPublisher? in + guard let dependency = dependency else { return nil } guard let _status = status else { return nil } - return provider.context.managedObjectContext.performChanges { - guard let status = provider.context.managedObjectContext.object(with: _status.objectID) as? Status else { return } - let appStartUpTimestamp = provider.context.documentStore.appStartUpTimestamp + return dependency.context.managedObjectContext.performChanges { + guard let status = dependency.context.managedObjectContext.object(with: _status.objectID) as? Status else { return } + let appStartUpTimestamp = dependency.context.documentStore.appStartUpTimestamp let isRevealing: Bool = { - if provider.context.documentStore.defaultRevealStatusDict[status.id] == true { + if dependency.context.documentStore.defaultRevealStatusDict[status.id] == true { return true } - if status.reblog.flatMap({ provider.context.documentStore.defaultRevealStatusDict[$0.id] }) == true { + if status.reblog.flatMap({ dependency.context.documentStore.defaultRevealStatusDict[$0.id] }) == true { return true } if let revealedAt = status.revealedAt, revealedAt > appStartUpTimestamp { @@ -446,15 +472,20 @@ extension StatusProviderFacade { return false }() // toggle reveal - provider.context.documentStore.defaultRevealStatusDict[status.id] = false + dependency.context.documentStore.defaultRevealStatusDict[status.id] = false status.update(isReveal: !isRevealing) status.reblog?.update(isReveal: !isRevealing) // pause video playback if isRevealing before toggle if isRevealing, let attachment = (status.reblog ?? status).mediaAttachments?.first, - let playerViewModel = provider.context.videoPlaybackService.dequeueVideoPlayerViewModel(for: attachment), playerViewModel.videoKind == .video { + let playerViewModel = dependency.context.videoPlaybackService.dequeueVideoPlayerViewModel(for: attachment) { playerViewModel.pause() } + // resume GIF playback if NOT isRevealing before toggle + if !isRevealing, let attachment = (status.reblog ?? status).mediaAttachments?.first, + let playerViewModel = dependency.context.videoPlaybackService.dequeueVideoPlayerViewModel(for: attachment), playerViewModel.videoKind == .gif { + playerViewModel.play() + } } .map { result in return status @@ -464,7 +495,7 @@ extension StatusProviderFacade { .sink { _ in // do nothing } - .store(in: &provider.context.disposeBag) + .store(in: &dependency.context.disposeBag) } } diff --git a/Mastodon/Scene/Share/View/Container/PlayerContainerView.swift b/Mastodon/Scene/Share/View/Container/PlayerContainerView.swift index a6fd4406..f7a8a154 100644 --- a/Mastodon/Scene/Share/View/Container/PlayerContainerView.swift +++ b/Mastodon/Scene/Share/View/Container/PlayerContainerView.swift @@ -22,6 +22,7 @@ final class PlayerContainerView: UIView { let contentWarningOverlayView: ContentWarningOverlayView = { let contentWarningOverlayView = ContentWarningOverlayView() + contentWarningOverlayView.update(cornerRadius: PlayerContainerView.cornerRadius) return contentWarningOverlayView }() diff --git a/Mastodon/Scene/Share/View/Content/ContentWarningOverlayView.swift b/Mastodon/Scene/Share/View/Content/ContentWarningOverlayView.swift index a695e1c1..f04a56e9 100644 --- a/Mastodon/Scene/Share/View/Content/ContentWarningOverlayView.swift +++ b/Mastodon/Scene/Share/View/Content/ContentWarningOverlayView.swift @@ -181,6 +181,10 @@ extension ContentWarningOverlayView { } } + func update(cornerRadius: CGFloat) { + blurVisualEffectView.layer.cornerRadius = cornerRadius + } + } extension ContentWarningOverlayView {