Elytra v2.3 has just been released, you can read all about here.
I’m also excited to announce that Elytra is now also available on macOS as a Notarized app. You can head over here to download the latest release.
It’s same as the Mac App Store release with two distinct differences:
The app can auto-update itself (or you can manually check for updates) between the two Release and Test Build pipelines. The release line is recommended for most users, the test line is for those who like living on the edge.
The app will use an external Payment Processor which enables me to offer discounts, especially for students, you can read more about it here.
Going forward, I’ll be able to release more frequent fixes directly to the Notarized builds. These builds currently do not have any kind of crash reporter built-in. So if you encounter any crashing bugs, please do take a moment to send me the crash report.
I look forward to hearing from you about this, you can always reach out to me on twitter or email me at email@example.com. Happy Reading.
Elytra’s 2021 Summer Release is here, just in time for WWDC 2021. It’s been extra challenging to work on v2.3 as this is the first release of Elytra that introduced Swift into various core systems of the app.
If you have read my earlier post about the public beta, you’d know this has been in the works for a while, but the work on the new version started all the way back in February of 2020.
This is slightly bigger release (even I am not used to this) so this is going to need a TLDR.
New system for adding feeds: You can explore topics by prefixing your keyword with the # symbol. Or directly search for a website with its base URL.
Sync is now faster: more reliable and uses a delta updates approach to conserve power and network bandwidth.
Two new Widgets: Folders (configurable) and Bloccs.
Improved App Performance: Thanks to a new core, the app’s performance has seen a big boost and crashes less.
Filters on macOS: You can now add and remove filters directly from the macOS App.
Mini Audio player: Elytra now ships with a mini-audio player to quickly browse through audio-clips and podcast episodes.
Media Playback: Elytra now comes with improved support for Youtube and Apple Trailers feeds.
Search: Searching for feeds and articles is now simpler than ever and on macOS, it’s always available.
Reader Bar: You can now customise the reader bar size and choose from three sizes: Small, Regular and Large.
Finally: As always, an assortment of improvements and fixes.
Elytra v2.3 introduces a new system for finding and adding feeds to your lists. You can explore some pre-defined topics or search for topics of your interest by prefixing the keyword with a # key.
To directly explore feeds linked by a website, simply type in the website’s URL. If you have a feed URL, then you can directly use that.
Something that been asked for a long time is to directly add a feed to a folder when creating it. It’s now possible to do so and all your folders will be listed out. By default, None will be selected.
Syncing across all apps is now faster, more reliable and also automatically syncs in the background to keep all your devices in sync and ready to go. This lays a critical foundation for future releases.
The new sync system is written in Swift (version 5.4 for those who care) and is much more resilient, fault-tolerant and heavily tested compared to its previous iteration.
It also now uses a delta updates system so your devices only download the data they don’t already have. Multiple sync triggers can happen simultaneously on a single device of yours (say you added a feed, then marked all the items inside that feed as read which will trigger two events). This ensures your devices consume less power and consume less network bandwidth.
Two New Widget Types
v2.3 brings two new Widgets: Folders and Bloccs. The Bloccs widget brings up to 6 of the latest unread articles from your feeds to your device’s homescreen, decorated by the articles’ cover images. The Folders’ widget enables to you select a folder of your choice and showcase up to 4 articles from that folder. I can’t wait to see how you have these setup on your devices.
I’ve spent all of March working through various modules in the app to optimise the performance. The Article Reader was the only component in the app that was optimised down to the last bit (to my best knowledge and technical capabilities). Everything else was just mish-mash. You should now notice improved performance in the app for just about any activity you’d perform in it.
Filters on macOS
Filters have been available in Elytra since v1.0 so it was always weird that there was no UI for it on macOS. Now there is, it’s mac-assed and works exactly as you’d expect it to.
### New Subscriptions UI
I also took this opportunity to redesign the subscriptions interface. The new design is an indicator towards the next iteration of the design system for Elytra, it better and more clearly explains the advantages of each subscription type and enables you to quickly switch between the two offerings.
Mini Audio Player
For a long time, I’ve used Elytra to notify me when new episodes are available for the podcasts I follow. In v2.3, I’ve built a mini-audio player into the app. It detects Podcast episodes and automatically updates its rendering state. This is in no way a replacement to a full-fledged Podcast app, but just a little something to get you a sneak-peak into that episode if you so desire.
I’ve made several improvements to the API and the apps to improve media playback. This fixes some Youtube videos not loading correctly. But most importantly, the apps now load, and enable playback of Movie trailers from the trailers.apple.com RSS Feeds.
The apps now feature global search enabling you to search for Feeds and Articles. You can also match for author names. In a future release, tokens will also be introduced to tokenise your search for a more precise hunt.
If you’re looking up an article and there are no feed suggestions for the app to provide, the app will suggest feeds from the articles it has found. So you can jump to the feed or the article.
Reader Bar Sizes
To ensure the app is accessible by everyone, Elytra has always supported Dynamic Type, Voice Over and the various navigation accessibility features that macOS and iOS provides. In March, a customer got in touch with a complaint about the reader bar and a potential solution. We worked on that solution and I am now happy to let you know that the reader bar now comes in three sizes: Small, Regular (default) and Large. You can toggle the size from Settings > Misc.
PS: This setting has no effect if you’re using the toolbar.
Drastically improved performance and accuracy of batch marking articles as read. (In my testing, marking a batch of 2000 articles as read previously took over 8s, and now only takes 2s).
Counting unread articles is now literally 6 times faster. The app can now spend less time keeping these counters up to date and more time rendering articles.
Improved handling and logic for rotation on iPadOS. This also fixes the blank slate launch state of the app on iPads in portrait mode.
Sharing articles on macOS will now use the recommended approach instead of the workaround I was previously using. This will ensure a smoother experience across various macOS versions.
The macOS app will now correctly sync after waking up your mac from sleep.
Fixed a critical and long standing issue where articles marked as read on one of your devices would not sync to your other devices.
Fixed a critical bug where the “Start Trial” button would have no effect or start the process and keep the button disabled preventing retries.
Fixed an issue where opening a Feed or a Folder and then opening the Unread list would reset the sorting preference to Unread – Latest First.
Fixed an issue with sync not working correctly upon a fresh signup.
Fixed an issue where the wrong state for the article reader would be setup: incorrectly showing next and previous articles to be available when only a single article was available in that list.
Fixed an crashing bug on iPadOS where the app would crash after backgrounding the app.
Fixed a bug in which HTML would show in the summary field.
Fixed a bug with Substack newsletters where the images in the posts would be really small (Substack converts the original URLs into their image proxy URLs for the Feeds which caused this issue, Elytra strips out this information and then loads the images).
Fixed a bug where custom feed names would not correctly sync across to your other devices.
The macOS app will no longer open duplicate windows. If it finds an existing window for the same activity, it’ll bring that window to the foreground.
Externally connected displays on iPads will now mirror the the iPad screen. This would previously display the app’s UI at native resolution with no scaling. A future release will correctly address this issue.
It’s finally happened. It took 3 years and I hope it was worth the wait.
Elytra for macOS brings the same native rendering performance you have come to know and love on iOS and iPad OS.
All of this has been possible because of Apple’s Mac Catalyst system which has been significantly improved on Big Sur, since its debut on macOS Catalina.
Your subscription will carry forward to the macOS App as well, no separate purchase or subscription will be necessary. (You can also take this opportunity to take advantage of the special pricing I have going on for Diwali)
I’ll be sharing a deep-dive into the design decisions for Elytra, but for now, I hope you enjoy the release.
As always, Happy Reading!
PS: A small update for iOS and iPadOS has also been released, so be sure to grab that from the App Store as well.
Version 2.1 brings a lot of stability and Quality of Life improvements to Elytra before the final Winter release of this year. This also brings the iOS App up to parity with its macOS app to be released soon.
This build also brings support the the newly released iPhone 12 lineup as well as the iPad Air 4th Gen.
Designed by the Braille Institute of America, and offered for free, Atkinson Hyperlegible is a great new font choice for greater visibility and legibility for low vision readers. Paired with an Accessibility focused app like Elytra, I hope this improves the reading experience for you.
If you have a URL copied, the app will automatically detect it when attempting to add a new feed.
Tapping an article now dismisses the sidebar on iPads in portrait mode.
The sidebar items are now correctly highlighted. They no longer use the tint colour when selected.
Search in the sidebar now uses Alpha sorting like the rest of the view.
Multiple improvements throughout the app for Voice Control (VC) and Voice Over (VO) a11y options.
The app now correctly shows titles for icon only buttons when VC is activated.
The app now correctly updates states for icon only buttons when VC is activated.
Simplified Article labels for VC to make it easier to select articles. They will now be presented as “Article 1”, “Article 2” and so on… Previously, the article title’s was used which could be difficult to command with long titles.
VO will now read the article index followed by its title.
Improves formatting for CJK Text. CJK text should no longer appear as one big blob of text. It may still happen if the source provides it that way.
Unreads Widget intents now work as expected. You can now toggle between loading favicons and cover images in the widgets.
The article viewer will now draw horizontal rules. (<hr /> element equivalent.)
During first launch, if your account already has a subscription, the trial interface is no longer shown. You are directly taken to the Feeds Interface.
Added support for dragging and dropping articles into the Unread or Bookmark rows in the Sidebar to perform respective actions.
Added support for dragging feeds between folders or outside folders.
Added support for dragging feeds to external applications. This action will drag with the RSS Feed URL. (iPadOS only)
Updated images for GIF loading and playback controls.
Tapping a gallery image now opens it in full view.
Fixed a rare bug that would prevent the bookmarks counter from updating when adding or removing bookmarks.
Fixed an issue where unread counters would not update when you have 0 unread articles.
Fixed loading of GIF favicons.
Removing a bookmark while in the bookmarks feed now removes the article after a small delay.
Fixed a rare crashing bug that would occur when initiating a Refresh in the Feeds Interface. (Thank you for Lee.)
Fixed an issue with the Today Count always reporting as 1.
Fixed rotation behaviour on iPads.
Fixed an issue where the unread/today counts would change when reading an article from a feed you’re not subscribed to.
Fixed an issue where the selected feed would remain selected after opening recommendations.
Fixed an issue with the Unreads widget not updating in a timely manner.
Fixed a background crash that would occur when syncing and downloading new data.
The app now saves restoration data properly so launching the app from a saved state is now faster.
Fixed an issue where images in the article viewer would fail to load (network issues, invalid URL or for whatever other reason) and would show a large placeholder image.
Twitter apps selection now works again when tapping tweets.
Matched the keyboard navigation to the macOS App.
Images in Widgets should now load reliably. I’ve discarded the older method of loading images in favour of a more standard approach as recommended by Apple Engineering.
Fixed the app using a semi-bold font for headings on iOS 14.0.1 and higher.
Image Loading options now correctly apply to favicons inside the Articles List Interface.
Title Font preference now correctly applies to headings inside the article as well.
Hot off the tracks of v2.0.2 comes v2.0.3 with a couple of more fixes. All known issues in Elytra’s v2 are now fixed and patched. If any additional issues are reported, those will be addressed in v2.1.0 unless they prevent the app from functioning.
Improved Swift & SwiftUI syntax highlighting in code blocks.
Fixed an issue where selecting the “Only load on Wi-Fi” image bandwidth setting did not persist correctly.
Fixed an issue where selecting the “Low Res” image resolution setting did not persist correctly.
Fixed a bug where toggling dark mode (or already present) did not correctly set the colours for the filters’ input.
Fixed an issue where the Image Viewer would not display the image at full resolution once it is loaded.
Fixed an issue where the OPML Interface would launch with the base tint on the button backgrounds and then update to your preferred tint.
Fixed an issue where semantic colours would not load correctly on iOS 14.0.1 for your selected tint colour.
Fixed a crash that would occur when bootstrapping the local cache database.
Fixed a crash that would occur when saving restoration data.
Fixed an issue where images in articles would be scaled incorrectly when using the image proxy.
Fixed a bug where tapping on the Attributions item in the Settings interface would crash the app.
Fixed a crash that would occur when decoding certain HTML encodings. (16-bit decoding is hard, y’all!)
Elytra’s first website was made in the fall of 2017. It was extremely basic, gave the requiste information to the reader and a link to sign up for the TestFlight beta ( TestFlight Links were not a thing back then).
With the release of v1.0, I updated to an improved layout, more details and screenshots. I kept updating the screenshots up to the release of v1.4 and then completely forgot about it (this did lead to some confusion).
With the release of v2.0, it was time to update it, however, with the rushed release of iOS 14, I didn’t get enough time to complete it.
I have simplified the website by much, reduced as many interaction points as possible to ensure the reader can quickly get an idea of the app, and proceed to viewing further details on the App Store.
For the main navigation in the header, I used a simple <details> block with <nav> as its detail block. Accessible, simple, and known interaction.
Almost all images are optimised for retina screens as well as for various breakpoints at varying sizes.
One critical section I thought I must add was about Privacy.
With Apple’s strong focus on Privacy, and a wonderful marketing page to go with it, I thought it would only compliment their message and my committment towards ensuring the same as a 3rd party developer on their platform.
Some additional enhancements I’d like to make sooner than later:
I would like to make some tweaks to the font sizes of headers based on the device width metric, but I found it not to be a blocker, and release it as is.
Add sRGB and P3 specific images to the sources. When viewing the website on my Macbook Pro, the colours are evidently faded. Since I do have source images in the P3 format, I should be able easily do this.
Additional hints for a11y.
Dark/Light mode. The previous website support this, however, for this time around I decided to go with a static colour scheme to suite the various bands I am using on the page as decorative backgrounds for the device images.
This darker colour scheme also strongly compliments the beautiful imagery one experiences when using Elytra with various Photography and Art & Design blogs.
If you have any suggestions for improvements or noticed a bug, do let me know.
Elytra 2.0.2 (38) is now available on the App Store. This build includes some critical fixes and an update is recommended.
Fixes a rotation bug on iPads.
Fixes an article scaling bug on iPads when toggling the sidebar.
Changing the selected tint colour now applies correctly throughout the app.
Fixed the app not loading the selected tint colour on launch.
Fixed an issue when searching for a feed by title or keywords would dismiss the modal.
Fixed an issue with pagination when searching for feeds in the Add New Feed interface.
Fixed an issue where the App would show a “No Subscription Found” error after resetting or deactivating your account.
Fixed an issue where an interrupted on-boarding would prevent you from using the app without purchasing a subscription. This now ensures you are always able to start your free trial if your onboarding was interrupted.
If you’re currently enrolled in the Free Trial, the subscriptions interface will now correctly indicate that.
Some blog engines convert emojis to an image with the emoji as the alt text on the image. Elytra will now skip rendering the image and appropriately render the emoji used by the author in the same context as the original blog post. This prevents the paragraph breaking on to the next line to accommodate the custom emoji image the blog engine inserts.
Fixes an issue with sorting of Feeds. Feeds which are not inside any folder are now correctly sorted in ascending alphabetical order. Thank you Jason, for pointing this out.
iPads in Portrait mode now correctly hide the sidebar upon tapping an article.
Elytra’s Fall 2020 update is finally here alongside the release of iOS 14. This is v2.0 and will be the first build to only support iOS 14. If you’re still on iOS 13 and for whatever reason you won’t be updating to iOS 14 soon, rest assured, v1.8 will continue to function as long as you use it.
Apple will be releasing new hardware later in October starting with the recently announced new iPad Air 4th Generation devices. Elytra will be ready on day-1 when these devices reach you with no new updates required.
iOS 14 UI
Throughout the app, I’ve made changes to the app’s interface to closely follow new updates Apple has released this year, including menus from buttons (for the sorting option), new Sidebar Layout style on the iPad, Triple Column Layout on the iPad and new List styles.
New Code Theme
Also in this release, I’ve included a new Code theme which uses the semantic colours from iOS, auto-updates for dark mode without reloading the entire stack and, may I say so myself, looks beautiful. You can read more about in this blog post I wrote earlier.
How could an iOS 14 release build be complete without new Widgets! I’ve personally been looking forward to using Widgets and making them was fun too! Elytra 2.0 ships with 2 different widgets:
Counters Widget: Shows the latest counts of articles from Unread, Today and Bookmarks sections of the app. This widget is only available in the small size.
Unread: Shows the latest articles from the unread section. The medium size widget shows 2 articles and the large size widget will show 4 articles. This widget will prioritize articles with cover images.
Full Change Log
All new triple column support using Apple’s own UI Framework.
An all new Sidebar Interface. This uses Apple’s latest UI Framework for displaying your folders and feeds.
iOS 14 Widgets support. Contains a Counters (Small) Widget and an Unread Articles (medium and large) widget.
Implements Trailing Swipe actions on Article List Items.
Directional marking as read. Long press on an article in Unread, Today or a Feed to see these options.
New Code Theme for pre-formatted code blocks.
The Add Feed interface now shows Recommendations for its default state to help improve finding and adding new feeds.
Unread counts update more reliably as you read through your content.
Improved underlying code for managing the initial state of the app.
Force touch and tapping on urls now works reliably.
Updated Feed Sorting options to use a menu interface instead of an options controller.
Improved styling for inline code blocks.
New Folder/Edit Folder interface now uses a basic interface which is faster to use IMO.
Prevents an issue causing the app to sync data twice upon successfully launching.
Fixes an issue where marking currently loaded articles as read in the Unread view would prevent new articles from loading.
If you have setup a custom title for a Feed, the custom title will now show up correctly for the empty state.
Fixed a crash caused when trying to share a Feed’s URL or its website’s URL.
Fixed an issue where reading an article from today would not decrement the “Unread Today” counter.
Fixes showing cover images inside the Article Reader.
Fixed I/O View not appearing when importing / exporting OPML files.
Fixed some pre-formatted quotes appearing as single-line code blocks.
Fixed code blocks appearing out of order. A year old bug finally fixed!
This update also includes miscellaneous improvements and fixes under the hood to improve the general stability of the app.
As recently put by one of Elytra’s admirers on twitter: