mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-08-07 08:01:10 +00:00
136 lines
8.0 KiB
Swift
136 lines
8.0 KiB
Swift
import Foundation
|
|
import AsyncDisplayKit
|
|
import Display
|
|
import TelegramCore
|
|
import Postbox
|
|
import SwiftSignalKit
|
|
|
|
private func whiteColorImage(theme: PresentationTheme) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> {
|
|
return .single({ arguments in
|
|
let context = DrawingContext(size: arguments.drawingSize, clear: true)
|
|
|
|
context.withFlippedContext { c in
|
|
c.setFillColor(UIColor.white.cgColor)
|
|
c.fill(CGRect(origin: CGPoint(), size: arguments.drawingSize))
|
|
|
|
let lineWidth: CGFloat = 1.0
|
|
c.setLineWidth(lineWidth)
|
|
c.setStrokeColor(theme.list.controlSecondaryColor.cgColor)
|
|
c.stroke(CGRect(origin: CGPoint(), size: arguments.drawingSize).insetBy(dx: lineWidth / 2.0, dy: lineWidth / 2.0))
|
|
}
|
|
|
|
return context
|
|
})
|
|
}
|
|
|
|
final class SettingsThemeWallpaperNode: ASDisplayNode {
|
|
private var wallpaper: TelegramWallpaper?
|
|
|
|
let buttonNode = HighlightTrackingButtonNode()
|
|
let backgroundNode = ASDisplayNode()
|
|
let imageNode = TransformImageNode()
|
|
private let statusNode: RadialStatusNode
|
|
|
|
var pressed: (() -> Void)?
|
|
|
|
override init() {
|
|
self.imageNode.contentAnimations = [.subsequentUpdates]
|
|
|
|
self.statusNode = RadialStatusNode(backgroundNodeColor: UIColor(white: 0.0, alpha: 0.6))
|
|
let progressDiameter: CGFloat = 50.0
|
|
self.statusNode.frame = CGRect(x: 0.0, y: 0.0, width: progressDiameter, height: progressDiameter)
|
|
self.statusNode.isUserInteractionEnabled = false
|
|
|
|
super.init()
|
|
|
|
self.addSubnode(self.backgroundNode)
|
|
self.addSubnode(self.imageNode)
|
|
self.addSubnode(self.buttonNode)
|
|
self.addSubnode(self.statusNode)
|
|
|
|
self.buttonNode.addTarget(self, action: #selector(self.buttonPressed), forControlEvents: .touchUpInside)
|
|
}
|
|
|
|
func setWallpaper(account: Account, wallpaper: TelegramWallpaper, selected: Bool, size: CGSize) {
|
|
self.buttonNode.frame = CGRect(origin: CGPoint(), size: size)
|
|
self.backgroundNode.frame = CGRect(origin: CGPoint(), size: size)
|
|
self.imageNode.frame = CGRect(origin: CGPoint(), size: size)
|
|
|
|
let state: RadialStatusNodeState = selected ? .check(.white) : .none
|
|
self.statusNode.transitionToState(state, animated: false, completion: {})
|
|
|
|
let progressDiameter: CGFloat = 50.0
|
|
self.statusNode.frame = CGRect(x: floorToScreenPixels((size.width - progressDiameter) / 2.0), y: floorToScreenPixels((size.height - progressDiameter) / 2.0), width: progressDiameter, height: progressDiameter)
|
|
|
|
if self.wallpaper != wallpaper {
|
|
self.wallpaper = wallpaper
|
|
switch wallpaper {
|
|
case .builtin:
|
|
self.imageNode.isHidden = false
|
|
self.backgroundNode.isHidden = true
|
|
self.imageNode.setSignal(settingsBuiltinWallpaperImage(account: account))
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: CGSize(), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
case let .color(color):
|
|
if color == 0x00ffffff {
|
|
self.imageNode.isHidden = false
|
|
self.backgroundNode.isHidden = true
|
|
self.imageNode.setSignal(whiteColorImage(theme: account.telegramApplicationContext.currentPresentationData.with { $0 }.theme))
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: CGSize(), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
} else {
|
|
self.imageNode.isHidden = true
|
|
self.backgroundNode.isHidden = false
|
|
self.backgroundNode.backgroundColor = UIColor(rgb: UInt32(bitPattern: color))
|
|
}
|
|
case let .image(representations):
|
|
self.imageNode.isHidden = false
|
|
self.backgroundNode.isHidden = true
|
|
|
|
let convertedRepresentations: [ImageRepresentationWithReference] = representations.map({ ImageRepresentationWithReference(representation: $0, reference: .wallpaper(resource: $0.resource)) })
|
|
self.imageNode.setSignal(chatAvatarGalleryPhoto(account: account, representations: convertedRepresentations, autoFetchFullSize: true))
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: largestImageRepresentation(representations)!.dimensions.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
case let .file(file):
|
|
self.imageNode.isHidden = false
|
|
self.backgroundNode.isHidden = true
|
|
|
|
var convertedRepresentations: [ImageRepresentationWithReference] = []
|
|
for representation in file.file.previewRepresentations {
|
|
convertedRepresentations.append(ImageRepresentationWithReference(representation: representation, reference: .standalone(resource: representation.resource)))
|
|
}
|
|
let dimensions = file.file.dimensions ?? CGSize(width: 100.0, height: 100.0)
|
|
convertedRepresentations.append(ImageRepresentationWithReference(representation: .init(dimensions: dimensions, resource: file.file.resource), reference: .standalone(resource: file.file.resource)))
|
|
self.imageNode.setSignal(chatAvatarGalleryPhoto(account: account, fileReference: .standalone(media: file.file), representations: convertedRepresentations, autoFetchFullSize: true))
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: dimensions.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
}
|
|
} else if let wallpaper = self.wallpaper {
|
|
switch wallpaper {
|
|
case .builtin:
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: CGSize(), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
case .color:
|
|
break
|
|
case let .image(representations):
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: largestImageRepresentation(representations)!.dimensions.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
case let .file(file):
|
|
var convertedRepresentations: [ImageRepresentationWithReference] = []
|
|
for representation in file.file.previewRepresentations {
|
|
convertedRepresentations.append(ImageRepresentationWithReference(representation: representation, reference: .standalone(resource: representation.resource)))
|
|
}
|
|
let dimensions = file.file.dimensions ?? CGSize(width: 100.0, height: 100.0)
|
|
convertedRepresentations.append(ImageRepresentationWithReference(representation: .init(dimensions: dimensions, resource: file.file.resource), reference: .standalone(resource: file.file.resource)))
|
|
self.imageNode.setSignal(chatAvatarGalleryPhoto(account: account, fileReference: .standalone(media: file.file), representations: convertedRepresentations, autoFetchFullSize: true))
|
|
let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: dimensions.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets()))
|
|
apply()
|
|
}
|
|
}
|
|
}
|
|
|
|
@objc func buttonPressed() {
|
|
self.pressed?()
|
|
}
|
|
}
|