Swiftgram/TelegramUI/ListMessageHoleItem.swift
2016-11-22 21:31:10 +03:00

113 lines
4.5 KiB
Swift

import Foundation
import AsyncDisplayKit
import Display
import TelegramCore
import SwiftSignalKit
import Postbox
final class ListMessageHoleItem: ListViewItem {
public init() {
}
public func nodeConfiguredForWidth(async: @escaping (@escaping () -> Void) -> Void, width: CGFloat, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> Void) -> Void) {
let configure = { () -> Void in
let node = ListMessageHoleItemNode()
let nodeLayout = node.asyncLayout()
let (top, bottom, dateAtBottom) = (false, false, false)
let (layout, apply) = nodeLayout(self, width, top, bottom, dateAtBottom)
node.updateSelectionState(animated: false)
node.contentSize = layout.contentSize
node.insets = layout.insets
completion(node, {
apply(.None)
})
}
if Thread.isMainThread {
async {
configure()
}
} else {
configure()
}
}
public func updateNode(async: @escaping (@escaping () -> Void) -> Void, node: ListViewItemNode, width: CGFloat, previousItem: ListViewItem?, nextItem: ListViewItem?, animation: ListViewItemUpdateAnimation, completion: @escaping (ListViewItemNodeLayout, @escaping () -> Void) -> Void) {
if let node = node as? ListMessageHoleItemNode {
Queue.mainQueue().async {
node.updateSelectionState(animated: false)
let nodeLayout = node.asyncLayout()
async {
let (top, bottom, dateAtBottom) = (false, false, false) //self.mergedWithItems(top: previousItem, bottom: nextItem)
let (layout, apply) = nodeLayout(self, width, top, bottom, dateAtBottom)
Queue.mainQueue().async {
completion(layout, {
apply(animation)
})
}
}
}
} else {
assertionFailure()
}
}
}
final class ListMessageHoleItemNode: ListViewItemNode {
private var activityIndicator: UIActivityIndicatorView?
init() {
super.init(layerBacked: false, dynamicBounce: false)
}
override func didLoad() {
super.didLoad()
let activityIndicator = UIActivityIndicatorView(activityIndicatorStyle: .gray)
self.activityIndicator = activityIndicator
self.view.addSubview(activityIndicator)
let size = activityIndicator.bounds.size
activityIndicator.frame = CGRect(origin: CGPoint(x: floor((self.bounds.size.width - size.width) / 2.0), y: floor((self.bounds.size.height - size.height) / 2.0)), size: size)
activityIndicator.startAnimating()
}
override public func layoutForWidth(_ width: CGFloat, item: ListViewItem, previousItem: ListViewItem?, nextItem: ListViewItem?) {
if let item = item as? ListMessageHoleItem {
let doLayout = self.asyncLayout()
let merged = (top: false, bottom: false, dateAtBottom: false)//item.mergedWithItems(top: previousItem, bottom: nextItem)
let (layout, apply) = doLayout(item, width, merged.top, merged.bottom, merged.dateAtBottom)
self.contentSize = layout.contentSize
self.insets = layout.insets
apply(.None)
}
}
func asyncLayout() -> (_ item: ListMessageHoleItem, _ width: CGFloat, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) {
return { [weak self] _, width, _, _, _ in
return (ListViewItemNodeLayout(contentSize: CGSize(width: width, height: 50.0), insets: UIEdgeInsets()), { _ in
if let strongSelf = self, let activityIndicator = strongSelf.activityIndicator {
let boundsSize = CGSize(width: width, height: 50.0)
let size = activityIndicator.bounds.size
activityIndicator.frame = CGRect(origin: CGPoint(x: floor((boundsSize.width - size.width) / 2.0), y: floor((boundsSize.height - size.height) / 2.0)), size: size)
}
})
}
}
func transitionNode(id: MessageId, media: Media) -> ASDisplayNode? {
return nil
}
func updateHiddenMedia() {
}
func updateSelectionState(animated: Bool) {
}
}