today’s a special day for OpenTodoList - exactly 10 years ago, the first blog
post announced the availability of the first version of the app! 🎉
So… the best way to celebrate is to push out a new release, right? Joking
aside - there are some issues in the previous release’s Android build, that
we’d like to get sorted out by this. So, here is what changed:
Changelog
No Encrypted (HTTPS) Traffic Possible In Android Version Of The App
In 3.45.0, we updated the underlying Qt framework to a newer version. However,
this would have required a newer version of the OpenSSL library to be shipped
with the app as well on Android - which we missed. As a consequence, the app
started just fine, but was unable to do any communication over encrypted
channels. This affected both existing accounts as well as when one tried to
add new ones.
This release fixes this by adding the needed newer version of the OpenSSL
libraries to the APK.
As a little gimmick, this release also fixes the text in a label in the
recurrence editor. This is nothing big, of course, but it makes the user
interface more consistent, right? 😉
Downloads
Please find the download links for major platforms on GitHub.
For Android, the release is available via Google Play.
For iOS, the release is available via the App Store.
If you use snap, you can install the app from the snapcraft.io.
If you use flatpak, you can install the app from Flathub.
For Arch based Linux distributions, you can install the app from AUR.
Known Issues
There is a minor known regression with the Qt6 based build of the app when running on Linux with Wayland. Reordering items via drag and drop works, but you sometimes have to click somewhere (e.g. the tool bar) to re-enable hover for the items after such a drag and drop operation. This has been reported as a bug against Qt in their bugtracker. Usually, you can start the app passing it the -platform xcb option to force using X11/XWayland (which does not show the same symptoms).
We hope most of you enjoy some free time outside, relaxing and getting away from
all the stress we usually have around us. For us, we were a bit busy and hence
accumulated a bit of delay for this release. And hey, it’s really a special
release! You wonder why?
OpenTodoList is turning 10 years on the 25th of July! 🎉
10 years - in terms of software, this is really a lot. And looking back, it
was quite a journey! OpenTodoList started as a project to discover the newly
release QML tooling within the Qt framework at that time. Initially started with
a skeuomorphic design, you wouldn’t recognize the app again nowadays. Cannot
believe it? Here’s some examples 😉
We want to take the chance to say a big thank you to everyone supporting us
and the app until here! Be it through feature requests, bug reports, donations
or also lending us an ear when we had issues and difficulties - all of that kept
the development of the app going. And we’re not getting tired of it; the issue
tracker is well filled so chances will continue to come for quite a while.
Speaking of changes… you surely are curious what this release provides,
aren’t you? So, let’s have a deeper look into that!
OpenTodoList allows most items to have a due date. And on top, you can set
recurrence patterns, such that an item repeats e.g. every week or every
15 days.
But, what happens with child items within such a recurring item? For example,
if you set a todo list to recur, what is with the contained todos (and their
sub-tasks)? The simple answer in the past was: Nothing!
The “parent” item would be scheduled again for another date, but the children
would remain marked as done.
With this release, this changes - so when an item recurs, all of its child
items will get reopened magically. This should make recurrence on
complex item structures way more useful!
Recurrence is a theme for this release. We also took the chance to refactor the
recurrence editor a bit - it should be way easier to control now, especially on
large screens you don’t have to aim at tiny icons anymore to trigger an action!
This might also serve as a blue print for some further refactoring of the user
interface in other parts of the app.
The usual bug fixing cannot be missed, of course! There was in fact a bug -
in the recurrence editor, every second time one opened recurrence mode
dialog, the dialog would jump between the actually selected mode and the
default one.
While this was not critical (the mode was applied correctly, so no harm done),
it still was annoying and hence we’re happy that this one got fixed!
When a recurring item is marked as done, it actually is not getting closed but
OpenTodoList basically updates the next effective due date for it. But, what
happens if you try to mark a future instance of an item as done?
In the past, OpenTodoList would simply have allowed you to do so, rescheduling
the item even farther into the future. So, users might accidentally close
items and schedule them for later! 😱
Good, that this release brings relief here! When an item is schedule for the
future and not yet due in the current scheduling interval, the app will show
a short warning and you have to explicitly agree to close that future instance
of the item (which might - after all - still be a use case here and there).
Todo lists contain todos. Todos in turn can have sub-tasks that further
structure the work that needs to be done to get that item “completed”. But
what happens once e.g. all sub-tasks within an item are closed?
Until now, the answer was a clear: Nothing.
Starting from this version on, the app will - once all items within a container
are marked as done - display a short tooltip which you can tap to also close
the parent item. Of course, if that container still shall remain “undone”, you
can simply ignore this message, but it can speed up your daily workflow a bit
where it fits.
Up to some techy stuff: We had to introduce a workaround that avoided Qt’s
internal translations to be shipped with the app on Windows. That workaround
could be removed in that release 😉
While not exactly user centric, this is an interesting one: GitLab, the
platform where OpenTodoList is hosted and mainly developed, also
provides us the resources for building the app for most platforms. However,
that build platform is rather Linux centric - while one could add own runners
to their projects there, GitLab itself didn’t provide anything beyond Linux for
a long time.
Some time back that changed and they introduced shared macOS runners. So we
decided to switch to these to build the app for both macOS as well as iOS.
The clear advantage: We can always build 🛠️
Sounds too technical? Well, until now we had a macBook sitting somewhere on
which any build had to run. And if this hardware was not available, build
pipelines would simply start to fail. Not ideal, right? This is a thing of the
past now!
Going into the very same direction is this change: We also use the shared
Windows runners for building the Windows version of OpenTodoList now. Here,
the story is a bit different, though.
We were perfectly able to build the app from the Linux containers in GitLabs
build farm. However, the underlying technique to get this done - using cross
compilation from Linux to Windows - sometimes broke. This was also the reason
why we worked on this story for this particular release: The Windows build once
again broke, with us unable to workaround it (except with quite some effort).
As a result, we now natively build on Windows. This allows us to use the
“vanilla” Qt binaries from the Qt Company - which should stabilize things a bit
as well.
👉 Please note that due to this change, we had to drop support for Windows 32bit
builds! This shouldn’t be a blocker for most users and we really hope that
meanwhile most of you have a 64bit capable Windows installation in use. If not,
feel free to open an issue so we can investigate how to work around this.
However, we feel that with Linux having abandoned 32bit in most use cases as
well, it is time to sunset this variant of the app for Windows as well.
Finally, a little but probably welcome change: If you edit the notes of an item,
you probably realized the round button which can be used to finish editing
the text, right? Previously, we had a rather strange icon in use there,
which most people associated with a kind of download function. We used this
release to improve there and pick an icon which better reflects the function
of that button!
Downloads
Please find the download links for major platforms on GitHub.
For Android, the release is available via Google Play.
For iOS, the release is available via the App Store.
If you use snap, you can install the app from the snapcraft.io.
If you use flatpak, you can install the app from Flathub.
For Arch based Linux distributions, you can install the app from AUR.
Known Issues
There is a minor known regression with the Qt6 based build of the app when running on Linux with Wayland. Reordering items via drag and drop works, but you sometimes have to click somewhere (e.g. the tool bar) to re-enable hover for the items after such a drag and drop operation. This has been reported as a bug against Qt in their bugtracker. Usually, you can start the app passing it the -platform xcb option to force using X11/XWayland (which does not show the same symptoms).
Just a few days after v3.44 has been released, some mindful user reported a really annoying bug in that release. As this bug can really be a killer for a lot of use cases, we’re pushing out a hot fix release. So, here we go:
Changelog
rpdev/opentodolist#616: Tags not showing up in the sidebar and when adding tags to items
Due to some refactoring work, the functionality to properly read back the tags used within a library got broken. This had two implications:
First of all, the tags would no longer show up in the sidebar, hence, making tags on top level items rather useless.
And second, when adding tags to an item, the existing tags would no longer be available for pre-selection.
This bug is fixed and on top we extended the testing a bit to avoid this to happen again.
Downloads
Please find the download links for major platforms on GitHub.
For Android, the release is available via Google Play.
For iOS, the release is available via the App Store.
If you use snap, you can install the app from the snapcraft.io.
If you use flatpak, you can install the app from Flathub.
For Arch based Linux distributions, you can install the app from AUR.
Known Issues
There is a minor known regression with the Qt6 based build of the app when running on Linux with Wayland. Reordering items via drag and drop works, but you sometimes have to click somewhere (e.g. the tool bar) to re-enable hover for the items after such a drag and drop operation. This has been reported as a bug against Qt in their bugtracker. Usually, you can start the app passing it the -platform xcb option to force using X11/XWayland (which does not show the same symptoms).
Yes, we are again a bit late for the next release of your favorite Todo List and note taking app, but unfortunately, I got hit by a bad cold, followed by Corona, so I think this should be excuse enough. But hey, better late than never! So, here comes the list of changes that made it into this release of OpenTodoList - and what should I say? While the list was rather short for the previous release, this one includes just the more of them 😉
The previous release broke - due to its many under-the-hood changes - the build of the app on Arch Linux (and friends). More concrete, building worked fine, but after installing, the app was missing some runtime libraries so it simply would not start.
OpenTodoList uses a cache to access the items in your libraries. If you are into these kinds of topics, its somehow similar to a database system, just without an actual DB running in the background.
In this release, we improve the speed of queries run against the case to retrieve items from it. This should greatly reduce the time needed to completely render pages, especially on older devices with slow I/O performance 🐌
If you run the app on macOS, you might have noticed it fell out a bit - visually, of course. It used to use a colorful icon for the system tray. Here as well, the correct tense is the past tense, because we now default to using a monochrome style icon instead. On other platforms, we still use the colored one by default, however, regardless of where you run the app on, you can always select explicitly which style you want it to use.
As the title suggests: There were several issues rendering Markdown content in the app. We hopefully got most of them, fixing them by switching to use Qt’s internal Markdown rendering as well as using another component to render the generated HTML.
We hope this should greatly improve the user experience without breaking existing Markdown documents!
There was a close button in the settings page - however, it simply didn’t work (and frankly, we nowhere else use a close button to “go back” in the page stack). So, in the end we simply removed it 🚮
After the previous update, we noticed that under certain circumstances the app might hang during a sync. The only way to get out of that was to quit the app and restart it.
This is fixed now by introducing a sync timeout - once we detect that no more data is transferred for some while, network requests and cancelled. So, this annoying bug should be a thing of the past!
There were some bad Spanish translations - thanks to the great users out there reporting and letting is know!
If you, too, find strangely translated parts within the app, feel free to report these as well or - even better - head over to POEditor and lend us a hand extending and fixing translations 😉
We put some love into the Windows installer of the app. In particular, the update procedure got way better (most importantly, we no longer open the uninstaller from within the installer to actually run the update).
Sometimes, e.g. due to transient network errors, a sync operation might fail. OpenTodoList reports such incidents as problems, which you can review in the user interface. To make “solving” such issues even easier, we introduced “Quick Solutions” buttons in the problems view:
For example, if a sync issue occurred, you’ll now find a “Retry” button right on the reported problem, which you can hit to simply retry running the sync. Before, you had to click the problem report to open the affected library and manually start a new sync from there.
Sometimes its necessary to review the folder structure of a library as is stored on disk.
You’ll now find a new option “Open Library Folder” in the menu of the library page, which will open the file explorer in the folder of the library.
Note that this is considered “expert knowledge”, so only use this to check out the structure of the library on disk but don’t try to manually edit any files in there, as this might make reading these files within the app impossible and hence cause data loss.
You might already have used the “Move Todo” functionality of OpenTodoList. This function allows you to move a todo into another todo list.
However, this only can be done within the same library. But, there was a bug in the appropriate dialog, so we always showed all available todo lists across all libraries as possible “targets” for the move operation. This - obviously - is nonsense. So, fixed in this release ✅
A bit techy, but: There was a unit test that occasionally would fail on macOS for unknown reasons. We tried to improve and stabilize this test (which is of course of no further relevance to users of the app, but still an important fix for those who have to develop OpenTodoList 😉).
Last but not least, we did some refactoring of the code: Namely, we introduced shared base classes for those classes in the code, that use the SynqClient library for running the sync operation. Again, this is nothing directly visible to users of the app, but it makes the code easier to maintain and hence saves us valuable time in the future.
Downloads
Please find the download links for major platforms on GitHub.
For Android, the release is available via Google Play.
For iOS, the release is available via the App Store.
If you use snap, you can install the app from the snapcraft.io.
If you use flatpak, you can install the app from Flathub.
For Arch based Linux distributions, you can install the app from AUR.
Known Issues
There is a minor known regression with the Qt6 based build of the app when running on Linux with Wayland. Reordering items via drag and drop works, but you sometimes have to click somewhere (e.g. the tool bar) to re-enable hover for the items after such a drag and drop operation. This has been reported as a bug against Qt in their bugtracker. Usually, you can start the app passing it the -platform xcb option to force using X11/XWayland (which does not show the same symptoms).
First of all: Happy new year to everyone! 🎉 I really hope you all had a great start into 2023 - let is be a wonderful and peaceful year!
What could be better than getting into the new year with a new release of your favorite todo list and note taking app? Right, so, let’s have a look at what this version brings (disclaimer: it might look disappointing at first, but this release is huge):
Yes, you see correctly - this is the one and only issue that made it into this release. And well, it was in fact quite some work getting there.
Qt is the framework OpenTodoList is built upon. It allows us to build the app for all of the operating systems and platforms we currently support. Without that, we wouldn’t have the resources to support the app on such a wide variety of platforms.
Up to now, OpenTodoList was based on the previous release of Qt - version 5.15. However, the v5 line is no longer developed. So in order to benefit from further development, we needed to migrate to the new v6 version line. This release of OpenTodoList is the first which is built again Qt 6.
With that, we lay the foundations for further great development of the app. But what about you (as a user)? In fact, by migrating, we also pull in all of the interesting things that happened in Qt between v5 and v6. For example:
On Android, the app now follows the system color scheme automatically.
On iOS, positioning the text cursor in text inputs works as expected (e.g. when using swipe on the spacebar to move the cursor).
On macOS, you can now keep a key (e.g. A) pressed to get a list of possible alternatives (e.g. Umlauts or accented versions of the letter).
Generally, Qt6 supports other graphic backends than OpenGL. This is particularly interesting on Windows, where OpenGL is often a problem - here, rendering can be done via DirectX, which should work more stably on a larger set of devices.
We tried to thoroughly test the app before the release, however, such a large change always brings the chance of regressions (also see the known issues section at the end of the update). So - for this release more than any other - please report any new issues you encounter in our bug tracker. Thanks a lot! 😄
Downloads
Please find the download links for major platforms on GitHub.
For Android, the release is available via Google Play.
For iOS, the release is available via the App Store.
If you use snap, you can install the app from the snapcraft.io.
If you use flatpak, you can install the app from Flathub.
For Arch based Linux distributions, you can install the app from AUR.
Known Issues
There is a minor known regression with the Qt6 based build of the app when running on Linux with Wayland. Reordering items via drag and drop works, but you sometimes have to click somewhere (e.g. the tool bar) to re-enable hover for the items after such a drag and drop operation. This has been reported as a bug against Qt in their bugtracker. Usually, you can start the app passing it the -platform xcb option to force using X11/XWayland (which does not show the same symptoms).