How To Finish Strong
This week was our second code challenge at Flat Iron and I came up against one of my biggest personal weaknesses.
I love conceptual work. I'm a decent beginner dev. I know I'm motivated by working on things I care about. That was the first problem.
We started by brainstorming a (what I thought was) pretty cool idea for a site that would use user's geolocation to display an astronomically accurate representation of the sky's darkness/lightness and maybe hue dynamically. The idea was that it could be used as a mood light, or on a TV that wasn't particularly in use. It could be used by people who are incarcerated or by yoga studios or anywhere sunshine would be of use. It could be brought into other projects in a modular fashion to style things based on the day/night cycle. I wanted to make it so that multiple skyboxes could be loaded side-by-side so that let's say your family member were in a different time zone, you could have this tiny art piece in a digital picture frame somewhere in your house that let you "look at their sky". It had a cool name-- "Circadian!" and I liked the idea. I thought it was sleek and wouldn't require me to do hardly any CSS (the true measure of a good project) lol.
Circadian!
We started and made decent headway during the first 72 hours-- here were the challenges, victories, and lessons I learned along the way...
Grabbing User Geolocation
This part wasn't too hard.
We Used An API For Sunrise/Set Times
This didn't work too bad. 5 out of 10 on this API, I ran into occasional weirdness. A few times I ran an infinite loop of GET requests because dependency arrays are tricky and I hadn't totally figured them out yet--
They kicked my IP so I opened a VPN that way I could keep working on it. That was a fun little trick.
I really struggled with state re-renders and dependency arrays-- more on that later.
But here's where the rubber hit the road...
What a nightmare...
Something like 85% of this is working-- I had to slice and reformat date and time strings... multiply and divide by 60, account for AM + PM, at first I thought I had to account for time-zones until I realized the API gave me UTC rise and set times and I could grab UTC from the user's machine:
Eventually subtracted set-time from rise-time to figure out the length of each phase, and writing somewhat clunky logic to figure out what phase of the day the user was in-- night, day, rising, or setting. Accounting for the length I planned for the color-change animations to be, 90 minutes- 60 minutes.
Except for API and state re-render weirdness this was working. It would figure out the phase.
But what happens when the user boots the page when the sun is halfway risen, how do I delay the animation?
This was working too haha.
Here's how you start an animation halfway in the CSS by writing JSX, once you've figured out how far you wanna delay it...
At some point though the re-render problems I was facing, the difficulty in testing a 90 minute animation. Concerns about how in some places the day starts, the sun sets and then rises afterwards it became too much for me to hold in my working memory which is why my code is riddled with logs and eventually we decided on a different approach.
Doing The Bare Minimum
We made an absolute shitpost of a web app purely hitting on the deliverables-- intentionally banal.
It took a little over an hour and a half-- I had to learn React Routing.
I left school feeling really upset with myself that day-- like I had let my teammates down as well as been shitty about the spirit of the project.
But this actually worked out okay because what we ended up with was a really viable frame for something meaningful.
I spent a lot of time feeling overwhelmed this week and my mom reminded me to focus on the present moment. I spent some time meditating and doing yoga and as many people know even a little bit helps.
This more-or-less led me towards the idea for the third project.
Mountain!
I usually set my sights high and it can feel like everything I want to do in this life is daunting-- I get overwhelmed.
I use a ton of to-do lists and taking my mom's advice I came up with the idea for one that would encourage me to focus on the present moment. Sam Harris had let me know in a guided meditation earlier in the week that was "all I had".
The idea was to take my regularly-generated 30-plus-item to-do-list and have the app feed it back to me one action at a time. I only ever need to be focused on the thing I do right now...
The second project was 85% of the way towards doing this already.
Making this project we settled on was a bit like writing a lab. I realized that nailing the deliverables first and then adapting the code was pretty easy. I felt a bit cheeky about learning to better take baby steps throughout this week and landing on a project which attempted to crystallize that.
I got stuck a couple of times and tried jenky solutions- these were largely related to my using dependency arrays and then using setState functions with the wrong JS array methods. What follows is a whistlestop tour of the code which does a full CRUD round on our db.json and delivers fully on the concept despite being a little understyled.
CRUD
I made use of a lot of what I learned in the labs leading to this project:
And I added in one or two more on brand bits, too:
I styled with just 47 lines of CSS:
Ultimately, I felt I ended up with very clean code-- and have looked at the experience as a great exercise.
It was lovely to work with Jake on the project, too.
If you'd like to check it out you can clone the repo here!
Onwards and upwards to the next mountain top.
Top comments (4)
That was a nice read! Liked, bookmarked and followed, keep the good work!
Wow. This was inspiring and insightful!🙏
Cheers to everyone learning the same stuff and to the homies here on campus!
I question the wisdom of a 90 minute CSS animation. lmao. First of all, no one is going to be able to differentiate that level of detail between colors over the span of 90 minutes. Second, you're locked into your animation now, essentially running a function that never stops for 90 minutes. Hence the troubleshooting issues. Maybe some CSS master can come correct me, but that seems like a waste of resources.
Personally, I'd set some sort of set timeout for some interval x (a minute would probably work), then use a function launched on the interval to grab the local time and increment your CSS with an animation. Now you're animating for a smaller duration, you get some idle time, you can modify your DOM without fear, and you can even throw some check functions in to make sure everything is doing what it's supposed to.
Ok ok, enough unsolicited advice... I'm super glad to hear your bootcamp experience is rockin'! Seems like you're learning a lot! Miss you, buddy!