Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios

This commit is contained in:
Ilya Laktyushin
2023-08-10 23:47:41 +02:00
5 changed files with 84 additions and 9 deletions

View File

@@ -947,6 +947,11 @@ public enum PremiumIntroSource {
case fasterDownload case fasterDownload
case translation case translation
case stories case stories
case storiesDownload
case storiesStealthMode
case storiesPermanentViews
case storiesFormatting
case storiesExpirationDurations
} }
public enum PremiumDemoSubject { public enum PremiumDemoSubject {

View File

@@ -190,6 +190,36 @@ public enum PremiumSource: Equatable {
} else { } else {
return false return false
} }
case .storiesDownload:
if case .storiesDownload = rhs {
return true
} else {
return false
}
case .storiesStealthMode:
if case .storiesStealthMode = rhs {
return true
} else {
return false
}
case .storiesPermanentViews:
if case .storiesPermanentViews = rhs {
return true
} else {
return false
}
case .storiesFormatting:
if case .storiesFormatting = rhs {
return true
} else {
return false
}
case .storiesExpirationDurations:
if case .storiesExpirationDurations = rhs {
return true
} else {
return false
}
} }
} }
@@ -220,6 +250,11 @@ public enum PremiumSource: Equatable {
case linksPerSharedFolder case linksPerSharedFolder
case membershipInSharedFolders case membershipInSharedFolders
case stories case stories
case storiesDownload
case storiesStealthMode
case storiesPermanentViews
case storiesFormatting
case storiesExpirationDurations
var identifier: String? { var identifier: String? {
switch self { switch self {
@@ -279,6 +314,16 @@ public enum PremiumSource: Equatable {
return "double_limits__communities_joined" return "double_limits__communities_joined"
case .stories: case .stories:
return "stories" return "stories"
case .storiesDownload:
return "stories__save_stories_to_gallery"
case .storiesStealthMode:
return "stories__stealth_mode"
case .storiesPermanentViews:
return "stories__permanent_views_history"
case .storiesFormatting:
return "stories__links_and_formatting"
case .storiesExpirationDurations:
return "stories__expiration_durations"
} }
} }
} }

View File

@@ -499,6 +499,8 @@ public final class PeerListItemComponent: Component {
} else { } else {
clipStyle = .round clipStyle = .round
} }
let _ = clipStyle
let _ = synchronousLoad
self.avatarNode.setPeer(context: component.context, theme: component.theme, peer: peer, clipStyle: clipStyle, synchronousLoad: synchronousLoad, displayDimensions: CGSize(width: avatarSize, height: avatarSize)) self.avatarNode.setPeer(context: component.context, theme: component.theme, peer: peer, clipStyle: clipStyle, synchronousLoad: synchronousLoad, displayDimensions: CGSize(width: avatarSize, height: avatarSize))
self.avatarNode.setStoryStats(storyStats: component.storyStats.flatMap { storyStats -> AvatarNode.StoryStats in self.avatarNode.setStoryStats(storyStats: component.storyStats.flatMap { storyStats -> AvatarNode.StoryStats in
return AvatarNode.StoryStats( return AvatarNode.StoryStats(

View File

@@ -1163,7 +1163,7 @@ public final class StoryItemSetContainerComponent: Component {
if let currentIndex = component.slice.allItems.firstIndex(where: { $0.storyItem.id == component.slice.item.storyItem.id }) { if let currentIndex = component.slice.allItems.firstIndex(where: { $0.storyItem.id == component.slice.item.storyItem.id }) {
if index != currentIndex { if index != currentIndex {
let nextId = component.slice.allItems[index].storyItem.id let nextId = component.slice.allItems[index].storyItem.id
self.awaitingSwitchToId = (component.slice.allItems[currentIndex].storyItem.id, nextId) //self.awaitingSwitchToId = (component.slice.allItems[currentIndex].storyItem.id, nextId)
component.navigate(.id(nextId)) component.navigate(.id(nextId))
} }
} }
@@ -1598,12 +1598,25 @@ public final class StoryItemSetContainerComponent: Component {
} }
var footerPanelY: CGFloat = self.itemsContainerView.frame.minY + itemLayout.contentFrame.center.y + itemLayout.contentFrame.height * 0.5 * itemScale var footerPanelY: CGFloat = self.itemsContainerView.frame.minY + itemLayout.contentFrame.center.y + itemLayout.contentFrame.height * 0.5 * itemScale
footerPanelY += (1.0 - footerExpandFraction) * 4.0 + footerExpandFraction * (-41.0) footerPanelY += (1.0 - footerExpandFraction) * 4.0 + footerExpandFraction * (-41.0)
let footerPanelMinScale: CGFloat = (1.0 - scaleFraction) + (itemLayout.sideVisibleItemScale / itemLayout.contentMinScale) * scaleFraction
let footerPanelScale = itemLayout.contentScaleFraction * footerPanelMinScale + 1.0 * (1.0 - itemLayout.contentScaleFraction)
footerPanelY += (footerSize.height - footerSize.height * footerPanelScale) * 0.5
let footerPanelFrame = CGRect(origin: CGPoint(x: itemPositionX - footerSize.width * 0.5, y: footerPanelY), size: footerSize) let footerPanelFrame = CGRect(origin: CGPoint(x: itemPositionX - footerSize.width * 0.5, y: footerPanelY), size: footerSize)
itemTransition.setFrame(view: footerPanelView, frame: footerPanelFrame)
itemTransition.setAlpha(view: footerPanelView, alpha: 1.0 - itemLayout.contentOverflowFraction) itemTransition.setPosition(view: footerPanelView, position: footerPanelFrame.center)
itemTransition.setBounds(view: footerPanelView, bounds: CGRect(origin: CGPoint(), size: footerPanelFrame.size))
itemTransition.setScale(view: footerPanelView, scale: footerPanelScale)
var footerAlpha: CGFloat = 1.0 - itemLayout.contentOverflowFraction
if component.hideUI || self.isEditingStory {
footerAlpha = 0.0
}
itemTransition.setAlpha(view: footerPanelView, alpha: footerAlpha)
} }
} else if let footerPanel = visibleItem.footerPanel { } else if let footerPanel = visibleItem.footerPanel {
visibleItem.footerPanel = nil visibleItem.footerPanel = nil
@@ -3034,7 +3047,7 @@ public final class StoryItemSetContainerComponent: Component {
guard let self else { guard let self else {
return return
} }
self.presentStoriesUpgradeScreen() self.presentStoriesUpgradeScreen(source: .storiesPermanentViews)
}, },
setIsSearchActive: { [weak self] value in setIsSearchActive: { [weak self] value in
guard let self else { guard let self else {
@@ -4718,7 +4731,7 @@ public final class StoryItemSetContainerComponent: Component {
} }
switch action { switch action {
case .info: case .info:
self.presentStoriesUpgradeScreen() self.presentStoriesUpgradeScreen(source: .storiesDownload)
return true return true
default: default:
break break
@@ -4733,11 +4746,11 @@ public final class StoryItemSetContainerComponent: Component {
guard let self else { guard let self else {
return return
} }
self.presentStoriesUpgradeScreen() self.presentStoriesUpgradeScreen(source: .storiesStealthMode)
}) })
} }
private func presentStoriesUpgradeScreen() { private func presentStoriesUpgradeScreen(source: PremiumSource) {
guard let component = self.component else { guard let component = self.component else {
return return
} }
@@ -4751,7 +4764,7 @@ public final class StoryItemSetContainerComponent: Component {
return return
} }
let controller = PremiumIntroScreen(context: context, source: .stories, forceDark: true) let controller = PremiumIntroScreen(context: context, source: source, forceDark: true)
self.sendMessageContext.actionSheet = controller self.sendMessageContext.actionSheet = controller
controller.wasDismissed = { [weak self, weak controller]in controller.wasDismissed = { [weak self, weak controller]in
guard let self else { guard let self else {

View File

@@ -1779,6 +1779,16 @@ public final class SharedAccountContextImpl: SharedAccountContext {
mappedSource = .translation mappedSource = .translation
case .stories: case .stories:
mappedSource = .stories mappedSource = .stories
case .storiesDownload:
mappedSource = .storiesDownload
case .storiesStealthMode:
mappedSource = .storiesStealthMode
case .storiesPermanentViews:
mappedSource = .storiesPermanentViews
case .storiesFormatting:
mappedSource = .storiesFormatting
case .storiesExpirationDurations:
mappedSource = .storiesExpirationDurations
} }
let controller = PremiumIntroScreen(context: context, source: mappedSource, forceDark: forceDark) let controller = PremiumIntroScreen(context: context, source: mappedSource, forceDark: forceDark)
controller.wasDismissed = dismissed controller.wasDismissed = dismissed