My Hobby Collection project has easily been longest-lived, most iterated, and most personally applicable project I’ve worked on in my personal portfolio. Outside of a multiplayer online battle arena I developed among a team of Computer Science students at University it’s perhaps the most personally fulfilling pieces of technology I’ve had the privilege to build.
As i’ve detailed on the Hobby Collection Django project page it was created to solve the problem of tracking my personal hobby collection. It’s an incredibly gratifying feeling to have not only built something which solves such an important problem, but it to this day remains a tool I actively depend on as a solution to that problem. In fact I’m so dependent on it that the scale of my hobby collection has gotten to the point where the web app in its current state is reaching its limits of feasibility with regards to continuous tracking.
Though my hobby collection is going quite rapidly digital I still maintain a growing collection of physical items including game and PC hardware, and most particularly figures. My physical collection is large and physically disperse enough to the point what I’m currently at high risk of the integrity of my data becoming corrupt if/when I make a significant geographical move. Simply put, my current means of maintaining location tracking (the web application) will not scale when that time comes and I dread not being ready when that time comes.
I have for quite some time now desired to make a native mobile application of my Hobby Collection project to enhance my ability to track and manage location data with varying levels of granularity regardless of which physical site I happen to be at. I’ve actually dabbled in some experimentation in the past with the Django REST framework as a natural extension of Hobby Collection Django, implementing RESTful API integration with a mobile app. I’d actually built a working prototype Android application using the recently debuted Google Material Design language. It was purely GET integration but it served as an effective proof of concept of what could be done to extend the project from web to mobile. I didn’t push the project through to full production but I always knew in the back of my mind that the project would never completely fade from my mind so long as the Hobby Collection project was maintained and continued to grow. I knew at some point the scale of the data and physical distribution of items would insist that such a project become a priority.
Well that time is now and the time is rather exciting. It’s a project to fulfill a personal need, extending the project will RESTful APIs opens up a number of possibilities in how I can hook into my collection data, and with what will be my largest personal iOS project since Album Shuffle I’m happy it comes in the era of Swift UI.
The decision to resurrect the project at this time, given what it entails in extending Hobby Collection Django with web service APIs has naturally led to me working to update Hobby Collection Django itself. I’m currently in the process up upgrading from Django 2 to Django 3 and I’m taking the opportunity to revisit various facets of the implementation including enhancing the admin interface with richer controls, restoring the presentation layer of the Audio section and adding additional search filters.
It’s interesting to think all the way back to the origins of this project as a primitive Win32 console app to what it is now and what it is yet to become. It’s one of the most gratifying benefits of being a Software Engineer.