Ilya Laktyushin
0664197b53
Poll improvements
2026-04-30 15:43:05 +02:00
Ilya Laktyushin
fd75bdb356
Fix
2026-04-29 21:15:55 +02:00
Ilya Laktyushin
1dba0dbb65
Fix deleted messages grouping in recent actions
2026-04-28 00:13:22 +02:00
Ilya Laktyushin
e97422e333
Various fixes
2026-04-27 04:40:29 +02:00
isaac
d1aa0db537
Postbox -> TelegramEngine waves 46-93 (squashed)
...
Squash of 63 commits spanning waves 46-93 (plus interspersed docs commits)
of the gradual Postbox->TelegramEngine consumer-side migration.
Scope: 139 files changed, 2123 insertions(+), 452 deletions(-).
## Themes by wave-block
**Waves 46-58 — Peer field migrations + facade additions**
Foundational EnginePeer convenience init additions (PeerReference, RenderedPeer,
SelectivePrivacyPeer). Multiple `peer: Peer` field migrations across PeerInfo,
ChatList, and SettingsUI components.
**Waves 59-73 — peer field cascade + EnginePeer wrap drops**
Series of single- to two-file peer-field migrations; consumer-side wrap
removal (`EnginePeer(peer)` -> direct EnginePeer use); `as? TelegramUser`
cast conversion to `case let .user(...)` enum match. Wave 64: RenderedPeer
convenience init. Wave 68: SelectivePrivacyPeer convenience init.
**Waves 74-83 — controller-Node bridge cleanup + small migrations**
Wave-71 shadow-pattern cleanup at controller->Node bridges. Migrations of
ChatRecentActionsController.peer (74), PeerInfoMember (75), MentionChatInputPanelItem
(76), PassportUI SecureIdAuthController (77), AccountWithInfo + ShareController
(78), peerInputActivitiesPromise (79), InactiveChannel (80), BlockedPeers (81),
openHashtag resolveSignal (82), NotificationExceptionsList (83).
**Waves 84-90 — TelegramEngine.Resources facade migrations**
Per-method Shape-A/B sweeps converting `<ctx>.account.postbox.mediaBox.X(...)`
to `<ctx>.engine.resources.X(...)`. Wave 90 was a single-commit big sweep:
40 fetchedMediaResource sites in 25 files migrated to engine.resources.fetch
facade in one atomic pass with first-pass-clean build.
Methods covered: storeResourceData, completedResourcePath, cancelInteractiveResourceFetch,
resourceRangesStatus, resourceStatus, fetch (fetchedMediaResource).
**Waves 91-92 — additional type migrations**
Wave 91: ItemListWebsiteItem.peer + RecentSessionsController enum-case payload
+ openWebSession callback Peer? -> EnginePeer?.
Wave 92: ChatListController StateHolder.EntryContext status type
MediaResourceStatus -> EngineMediaResource.FetchStatus.
**Wave 93 — speculative `import Postbox` drop sweep**
Drop import from 7 wave-touched files where it became unused; restore in 5
files where bare PeerId/Message/MediaId/StoryId references escaped the
pre-flight regex. Includes one MediaId(...) -> EngineMedia.Id(...) swap in
InAppPurchaseManager to unlock its import drop.
## Build state
Final state at squash: clean Telegram/Telegram build at debug_sim_arm64.
## Persistent-state notes
- Pre-existing WIP unchanged across the squashed range:
- build-system/bazel-rules/sourcekit-bazel-bsp submodule marker
- Untracked: build-system/tulsi/, submodules/TgVoip/, third-party/libx264/
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-25 20:48:15 +04:00
isaac
c0acc09cb1
Postbox -> TelegramEngine wave 44
...
Migrate RenderedChannelParticipant.peers from [PeerId: Peer] to
[EnginePeer.Id: EnginePeer]. Closes the wave-41 ratchet — the public
struct no longer leaks raw Peer types in any field (presences stays
Postbox-typed; separate migration).
Consumer-surface: -10 bridges. Dropped 6 EnginePeer(peer) read-wraps
at participant.peers[...] extraction sites across
ChannelAdminsController, ChannelMembersSearchContainerNode,
ChannelBlacklistController. Dropped 5 .mapValues({ $0._asPeer() })
constructor-unwrap transforms in ChannelAdminsController,
ChannelMembersSearchContainerNode, ChannelMembersSearchControllerNode.
Added 2 ._asPeer() unwraps in ChatRecentActionsHistoryTransition at
the two iteration sites (line 673 via participant.peers, line 2273
via new.peers in participantSubscriptionExtended) where the iterated
value is inserted into a raw-Peer SimpleDictionary.
TelegramCore producers: 8 files build the local peers dict inside
postbox.transaction and wrap at the insertion point. ChannelMembers,
RequestStartBot, ChannelOwnershipTransfer, JoinChannel, AddPeerMember,
PeerAdmins, ChannelBlacklist, Ranks.
2-iteration build convergence. Iteration-1 surfaced new.peers at
ChatRecentActionsHistoryTransition:2272 that the plan's participant.peers
pre-flight grep missed; wider grep now confirms the two iteration sites
are the complete surface.
No unit tests in this project; full Telegram/Telegram build verified
under configuration=debug_sim_arm64.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-24 23:21:05 +04:00
isaac
493f3103b3
Postbox -> TelegramEngine waves 37-43 + wave 44 design/plan (squashed)
...
Squashes 20 commits — the implementation and outcome commits of
waves 37 through 43 plus wave 44's spec and implementation-plan
docs — into a single commit. Per-wave lessons remain recorded in
docs/superpowers/postbox-refactor-log.md. The unrelated "Add swift
svg" commit is preserved separately outside this squash.
Wave 37 — peerTokenTitle: peer Peer → EnginePeer (1 file)
Wave 38 — canSendMessagesToPeer: peer Peer → EnginePeer (12 files)
Wave 39 — AccountContext.makePeerInfoController: peer Peer → EnginePeer (52 files)
Wave 40 — makeChatQrCodeScreen + makeChatRecentActionsController bundle (8 files)
Wave 41 — RenderedChannelParticipant.peer: Peer → EnginePeer (28 files)
Wave 42 — PeerInfoScreenData.peer: Peer? → EnginePeer? (17 files)
Wave 43 — PeerInfoScreen 6 helpers: peer Peer? → EnginePeer? (12 files)
Wave 44 — RenderedChannelParticipant.peers design doc + implementation plan
(impl and outcome land in subsequent commits, not part of squash)
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-24 23:19:43 +04:00
isaac
8408e0ae19
Postbox -> TelegramEngine waves 27-36
...
Consumer-sweep, facade-addition, and Peer→EnginePeer migrations:
- Wave 27: preferencesView consumer sweep
- Wave 28: resourceData consumer sweep
- Wave 29: resourceStatus consumer sweep
- Wave 30: _asStatus() bridge cleanup
- Wave 31: unused-import sweep re-run
- Wave 32: resourceStatus residue sweep
- Wave 33: loadedPeerWithId consumer sweep
- Wave 34: FoundPeer.peer Peer -> EnginePeer
- Wave 35: SendAsPeer.peer Peer -> EnginePeer
- Wave 36: ContactListPeer.peer Peer -> EnginePeer
Also includes per-wave specs, implementation plans, outcome logs, and
a CLAUDE.md wave-counter update.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-24 11:24:13 +04:00
isaac
524c29cbe3
Various improvements
2026-04-22 00:32:34 +04:00
Isaac
7b2b74e79b
Postbox -> TelegramEngine wave 6: unused import Postbox batch sweep
...
First build-verified unused-import sweep: speculatively dropped
import Postbox from 782 consumer files (plain ^import Postbox$ lines,
excluding TelegramCore/Postbox/TelegramApi paths), iterated 18 full
project builds with --continueOnError, restored the import on every
file that failed to compile. 183 drops survived; 189 consumer modules
newly Postbox-free.
Bundled: spec + plan + C1 atomic batch drop + C2 CLAUDE.md outcome and
permanent methodology guidance under Wave-selection. The methodology
subsection captures the reusable playbook (--continueOnError is
essential, dependency graphs are deep so expect many iterations,
pattern-based preemptive restores accelerate convergence, and
CLAUDE.md's engine typealias cheat sheet arrows are migration targets
rather than typealiases in TelegramCore).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-19 23:46:13 +02:00
Isaac
af6e5f258e
Merge commit '90f110a311466f1b105b16977963b235f362e55f'
...
# Conflicts:
# Telegram/Telegram-iOS/en.lproj/Localizable.strings
# submodules/ChatPresentationInterfaceState/Sources/ChatPresentationInterfaceState.swift
2026-03-20 18:55:29 +01:00
Isaac
bc7858ad2b
AI editing
2026-03-20 18:23:45 +01:00
Ilya Laktyushin
676f46d44d
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2026-03-20 12:48:12 +01:00
Ilya Laktyushin
433237d1e9
[WIP] Polls
2026-03-20 10:15:00 +01:00
Isaac
a2d5c530a5
Various improvements
2026-03-18 00:27:13 +01:00
Ilya Laktyushin
c32f645f5e
[WIP] Polls
2026-03-17 16:32:49 +01:00
Ilya Laktyushin
b1a190f87a
[WIP] Polls
2026-03-16 18:07:12 +01:00
Ilya Laktyushin
dca6b5f145
Various improvements
2026-03-12 13:51:27 +01:00
Isaac
9a4327116d
Refactor
2026-03-10 00:38:36 +01:00
Ilya Laktyushin
c05a1dd17c
Various improvements
2026-02-25 13:00:12 +04:00
Ilya Laktyushin
bae4591799
Web auth improvements
2026-02-24 15:10:22 +04:00
Ilya Laktyushin
f852dca2c8
Manual date formatting
2026-02-24 13:07:08 +04:00
Ilya Laktyushin
5d50aa34af
Various improvements
2026-02-23 21:25:25 +04:00
Ilya Laktyushin
4203d70414
Various improvements
2026-02-23 18:45:47 +04:00
Ilya Laktyushin
d9d1210c1d
Various improvements
2026-02-19 21:53:26 +04:00
Ilya Laktyushin
e81e7c6897
Formatted date support
2026-02-06 14:24:03 +04:00
Ilya Laktyushin
0d12dd29ad
Various improvements
2026-01-25 22:17:49 +04:00
Isaac
2db08cde89
Glass
2026-01-13 19:21:49 +04:00
Isaac
4a13c3830a
Glass
2025-12-26 20:29:30 +08:00
Isaac
3486393f99
Glass
2025-12-20 03:02:08 +08:00
Isaac
a63c90aa00
Glass
2025-12-12 23:58:00 +08:00
Isaac
0055396d4d
Update
2025-11-26 23:05:30 +08:00
Ilya Laktyushin
412e02ef00
Gift auctions
2025-11-12 04:46:02 +04:00
Isaac
6ee1edc8b0
Merge branch 'master' into glass
...
# Conflicts:
# submodules/TelegramUI/Sources/ChatInterfaceStateInputPanels.swift
2025-09-05 15:48:48 +02:00
Isaac
1d06c3f058
Bot forums v2
2025-09-05 15:25:50 +02:00
Isaac
5de7e74180
Merge branch 'master' into glass
...
# Conflicts:
# submodules/AttachmentUI/Sources/AttachmentPanel.swift
# submodules/ChatPresentationInterfaceState/Sources/ChatPanelInterfaceInteraction.swift
# submodules/TelegramUI/BUILD
# submodules/TelegramUI/Components/Chat/ChatRecentActionsController/Sources/ChatRecentActionsController.swift
# submodules/TelegramUI/Components/Chat/ChatTextInputActionButtonsNode/Sources/ChatTextInputActionButtonsNode.swift
# submodules/TelegramUI/Components/Chat/ChatTextInputPanelNode/Sources/ChatTextInputPanelNode.swift
# submodules/TelegramUI/Components/PeerInfo/PeerInfoScreen/Sources/PeerInfoScreen.swift
# submodules/TelegramUI/Components/PeerSelectionController/Sources/PeerSelectionControllerNode.swift
# submodules/TelegramUI/Sources/Chat/ChatControllerLoadDisplayNode.swift
# submodules/TelegramUI/Sources/ChatInterfaceStateInputPanels.swift
2025-09-02 19:55:51 +02:00
Isaac
871072ba95
Refactor text input
2025-09-01 21:45:31 +02:00
Isaac
4337026fba
Glass
2025-09-01 18:44:03 +02:00
Ilya Laktyushin
cb1f5058a7
Update API
2025-08-25 17:23:25 +04:00
Ilya Laktyushin
bdaf5f5a02
Various fixes
2025-08-18 17:33:54 +04:00
Isaac
905a46e6cc
Update API
2025-08-11 16:54:32 +02:00
Ilya Laktyushin
7a99577093
Merge branches 'master' and 'master' of gitlab.com:peter-iakovlev/telegram-ios
2025-07-29 17:47:08 +02:00
Ilya Laktyushin
3c87b308f8
Various improvements
2025-07-29 17:39:46 +02:00
Isaac
b625243040
Various improvements
2025-07-29 15:48:11 +02:00
Isaac
a5ad030123
Update
2025-07-22 16:08:51 +02:00
Ilya Laktyushin
b4832ff856
Update API
2025-07-14 12:50:11 +01:00
Isaac
484c350538
Various improvements
2025-06-24 17:27:17 +02:00
Isaac
df3e2db84c
Suggested posts
2025-06-20 15:37:26 +02:00
Ilya Laktyushin
546f6ca7c2
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2025-06-19 01:27:49 +02:00
Ilya Laktyushin
c5223959b2
Various improvements
2025-06-19 01:26:50 +02:00