Ilya Laktyushin
ffd82647ee
Various fixes
2026-05-01 15:29:18 +02:00
Ilya Laktyushin
0664197b53
Poll improvements
2026-04-30 15:43:05 +02:00
Ilya Laktyushin
29ecff3728
Various fixes
2026-04-30 12:43:12 +02:00
Ilya Laktyushin
fd75bdb356
Fix
2026-04-29 21:15:55 +02:00
Ilya Laktyushin
5c2cebc7bf
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2026-04-29 20:27:28 +02:00
Ilya Laktyushin
14bbdca050
Various improvements
2026-04-29 20:24:29 +02:00
isaac
301be02a89
Update localization
2026-04-29 21:23:36 +04:00
isaac
fefea439ba
Merge commit '37d1e2d93e8eea99ce83658b2bd5b2eede31043d'
2026-04-29 18:45:34 +04:00
Ilya Laktyushin
37d1e2d93e
Various fixes
2026-04-29 15:49:21 +02:00
isaac
3188c793bc
Merge commit 'd25010c1cbfbacddf2482c30af805af5cb1dc1e7'
2026-04-29 16:55:40 +04:00
isaac
96089108ca
Fixes
2026-04-29 16:55:37 +04:00
Ilya Laktyushin
d25010c1cb
Various fixes
2026-04-29 12:46:08 +02:00
Ilya Laktyushin
5d7edcf36f
Various fixes
2026-04-29 04:35:17 +02:00
Ilya Laktyushin
837acfa784
Various fixes
2026-04-29 04:26:58 +02:00
Ilya Laktyushin
7ab4685940
Various fixes
2026-04-29 03:52:19 +02:00
Ilya Laktyushin
ea090a6858
Various improvements
2026-04-28 23:53:26 +02:00
Ilya Laktyushin
dbcef2ac87
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2026-04-28 19:16:15 +02:00
Ilya Laktyushin
bde3418ce5
Various fixes
2026-04-28 19:16:08 +02:00
isaac
a386e79f59
Fix emoji status selection search
2026-04-28 19:19:33 +04:00
isaac
d83734eb46
Various improvements
2026-04-28 19:00:04 +04:00
isaac
1ae854e2e9
Merge commit '73d25e7be31fcc672a6c70bb6bc002cd11a4f388'
2026-04-28 17:00:21 +04:00
isaac
bc5c462eea
Fix rtl reveal
2026-04-28 17:00:16 +04:00
isaac
027ac77ad7
Various improvements
2026-04-28 16:58:04 +04:00
isaac
511a58e51a
Sticker pack improvements
2026-04-28 16:56:02 +04:00
Ilya Laktyushin
73d25e7be3
Various improvements
2026-04-28 14:31:17 +02:00
Ilya Laktyushin
1793490519
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2026-04-28 00:13:29 +02:00
Ilya Laktyushin
1dba0dbb65
Fix deleted messages grouping in recent actions
2026-04-28 00:13:22 +02:00
isaac
49709e3231
Merge commit '12bb7a851cc0a3a63a9119f6ba61f6baa53b6834'
2026-04-28 00:44:58 +04:00
isaac
55b2b47797
Various improvements
2026-04-28 00:44:54 +04:00
Ilya Laktyushin
e97422e333
Various fixes
2026-04-27 04:40:29 +02:00
Ilya Laktyushin
2c002ba3a7
Various fixes
2026-04-27 03:07:38 +02:00
Ilya Laktyushin
c4e1049396
Various fixes
2026-04-27 01:36:16 +02:00
isaac
7ccb382f53
Postbox -> TelegramEngine waves 103-105 (squashed)
...
Wave 103 (original): ChatRecentActionsControllerNode.peer Peer ->
EnginePeer migration ABANDONED after pre-flight discovered a 75-site
ADD-bridge cascade through chatRecentActionsHistoryPreparedTransition
into Message.peers SimpleDictionary<PeerId, Peer> store sites.
Lessons captured in docs/superpowers/postbox-refactor-log.md "Wave 103
ABANDONED" section + ~/.claude/projects/-Users-isaac-build-telegram
-telegram-ios/memory/feedback_wave71_shadow_risk.md (4-layer pre-flight
checklist for stored-Peer-field migrations).
Wave 103 (retry, 92230b0691): drained 5 accountManager.mediaBox
.storeResourceData Shape-A sites against the wave-94 facade. 2 files /
3 Edit calls (1 single + 2 replace_all) / 1-iter / 29.5s build. Closes
the storeResourceData accountManager-side drain entirely.
Wave 104 (08fc3f721e): drained 3 of 8 accountManager.mediaBox.resourceData
Shape-A sites against the wave-32/wave-94 AccountManagerResources.data
(resource:) facade + 3 consumer-side .complete -> .isComplete renames
(EngineMediaResource.ResourceData field rename). 1 file / 6 Edit calls
/ 1-iter / 11.7s build. 5 of 8 candidates deferred behind Postbox-typed
-function-parameter barriers (fetchCachedScaled*Representation cascade,
combineLatest typed-tuple coupling). Established the "Postbox-typed
-function-parameter barrier registry" pattern.
Wave 105 (0c76724409): DeviceContactInfoSubject enum 3 case Peer?
payloads + 2 callback signatures + 1 computed property migrate to
EnginePeer?. 5 files / 17 edits / 1-iter / 203s build (foundational
AccountContext touch). Net wrap delta -8 (10 drops, 2 ADD bridges, 1
downcast->case-let). First wave-71-shadow-style migration after the
wave-103 abandonment forced a discipline reset; first-pass-clean via
thorough pre-flight inventory (~15 min).
Net session progress: -16 wraps across 4 wave attempts plus durable
scaffolding (feedback memory, barrier registry, 4-layer pre-flight
checklist).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-26 16:57:55 +04:00
Ilya Laktyushin
adc0d5ba6e
Various improvements
2026-04-26 01:22:29 +02:00
Ilya Laktyushin
53c2da81fe
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2026-04-26 01:07:19 +02:00
Ilya Laktyushin
3c6ea30767
Various fixes
2026-04-26 01:07:12 +02:00
isaac
a04db4a2a6
Merge commit '6b78a35695e3e6aeb122d33e4350879129af84bf'
2026-04-26 02:52:26 +04:00
isaac
2ac8a490b0
Postbox -> TelegramEngine waves 94-102 (squashed)
...
Adds AccountManagerResources facade in TelegramCore mirroring
TelegramEngine.Resources, drains the entire accountManager-side
mediaBox refactor across consumer modules, and validates the
Shape-C/D handle-migration pattern (account: Account ->
engine: TelegramEngine) on three classes.
Wave 94 (AccountManagerResources facade + 8 sites): new
AccountManagerResources class in TelegramCore with
storeResourceData, completedResourcePath (resource + id overloads),
status (with approximateSynchronousValue), moveResourceData,
fetch. Migrate EditThemeController (5 storeResourceData + 2
completedResourcePath) and WebBrowserSettingsController (1
storeResourceData).
Wave 95 (10 sites): WallpaperUtils.swift sweep, 5 distinct
storeResourceData patterns, replace_all on the two repeated ones.
Wave 96 (7 sites): theme controller triple — TPC (1 store + 2
moveResourceData), TPCN (1 status + 1 fetch + closure type
MediaResourceStatus -> EngineMediaResource.FetchStatus + rename
account local to engine), TAC (1 completedResourcePath + 1 store).
Wave 97 (9 sites): WallpaperGalleryController.swift, 4
completedResourcePath + 5 storeResourceData via replace_all.
Wave 98 (2 files): WallpaperGallery status-type cascade
Promise<MediaResourceStatus> -> Promise<EngineMediaResource.FetchStatus>
across WallpaperGalleryItem.swift + WallpaperGalleryController.swift.
Drops cosmetic `_asStatus()` unwrap.
Wave 99 (2 facade extensions + 7 sites): adds
AccountManagerResources.data() and approximateSynchronousValue
to engine.resources.status(). Migrates OpenResolvedUrl (data +
storeResourceData with .complete -> .isComplete cascade),
SettingsThemeWallpaperNode (paired engine + accountManager
status), WallpaperUploadManager, OpenChatMessage,
LiveChatReactionStreamView.
Wave 100 (Shape-C/D, free function): legacyWebSearchItem
account: Account -> engine: TelegramEngine. 4 files.
Wave 101 (Shape-C/D, small class): VerticalListContextResults
ChatInputPanelItem stored field migration. 2 files. Drops
`|> map(EngineMediaResource.FetchStatus.init)` redundancy.
Wave 102 (Shape-C/D, medium class with weak-context retention):
SharedMediaPlayer account: Account -> engine: TelegramEngine.
Engine field is intentionally a strong handle since the class
stores context as `weak var`. 2 files.
After this squash the accountManager-side mediaBox refactor is
essentially complete; only Postbox-protocol-blocked
cachedResourceRepresentation triple remains as the foundational
deferred item.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-26 02:46:44 +04:00
Ilya Laktyushin
6b78a35695
Various fixes
2026-04-25 19:53:39 +02:00
isaac
7ce00a00fa
Merge commit '6df5f109739b05467716dbeaef51b197e1efc106'
2026-04-25 20:50:35 +04: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
Ilya Laktyushin
6df5f10973
Fix build
2026-04-25 18:35:36 +02:00
Ilya Laktyushin
5f7bcb7746
Merge branch 'master' of gitlab.com:peter-iakovlev/telegram-ios
2026-04-25 17:41:48 +02:00
Ilya Laktyushin
9c15b8c27d
Various improvements
2026-04-25 17:32:26 +02:00
isaac
6b7a23867c
Postbox -> TelegramEngine wave 45
...
PeerInfoHeader* update(peer:) bundle: Peer? -> EnginePeer?.
Four update methods across PeerInfoHeaderNode, PeerInfoHeaderEditingContentNode,
PeerInfoEditingAvatarNode, PeerInfoEditingAvatarOverlayNode.
Drops wave-43 ADD-WRAP bridges (net ~-11 wraps). Stored
PeerInfoHeaderNode.peer: Peer? field stays raw (out of scope).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com >
2026-04-25 00:02:22 +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
68a95f53f2
Various improvements
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
e51fef57d8
Add swift svg
2026-04-24 23:19:15 +04:00
isaac
f5cb1391aa
Merge commit '96b1432434205e2d09d7615bde1402d762ac2b8c'
2026-04-24 11:24:47 +04:00