Last summer, I interned at ButcherBox, a subscription-based meat delivery service that specializes in providing high-quality meat directly to customers' doors! As a Web Development Intern, I worked alongside one of their hybrid teams, pair-programming and participating in stand-ups, retro's, and more. This was my first internship. I got to learn so much!
React
Contentful
Datadog
2024
My main project had to do with our Content Management System, Contentful! We had a bunch of flexible but complex content templates that pained content authors each week. These templates allowed for a variety of configurations of headings, colors, links, and positioning. This gave great customization and standardization across our site! But, since Contentful is headless, by default we can't visualize what configurations are possible within our templates. We had to reference textual documentation in a tedious manner, wasting time and risking making mistakes or creating worse content designs.
Our solution was to create a visual web tool. Authors would use it to view all possible content configurations, filter for certain characteristics, and easily see what configurations are possible within our templates.
We built this tool into an existing internal web app, extending its features. I referenced Figma mockups to create new routes and lay out the pages. One huge part of the project was generating all possible content permutations from our templates. I paired with an engineer and used test-driven development to cover all possible content permutations and detailed nuances. This required me to spend a ton of time in Contentful and gain a thorough understanding of our content model.
A key feature was letting content authors filter for possible configurations, like having a background image and one heading. I found that such a simple feature like filtering can actually be hard to implement! You have to code the UI components, their state, and then the actual filtering code. You have to create clean, modular data structures to represent filter options, UI state, and the filters to apply. This was a surprising challenge but I really enjoyed working through it! I now have a greater appreciation for filters.
While developing this tool, we demo'd our progress in sprint reviews and the tool began to be used even during development! Overall, it helped content authors create great copywriting to help get high-quality meat to customers!
I learned a ton about Contentful, Datadog, React Router, Storybook, and Jest. I dove deeper into the basics of Typescript, React, Git, and even Chrome Dev Tools for debugging.
I was surprised how little time you spend actually writing code compared to reading code; having meetings; and writing tickets, PR's, and documentation. I loved practicing technical communication, planning for meetings, and presenting my work. I learned to break down PR's to make things easy for my team to review.
I also learned a lot from pair-programming. I learned to write pseudocode, to discern what rabbit holes to pursue or leave, and to use test-driven development. I loved working in a real engineering environment and growing my hard and soft skills. I have a long way to go!
I learn by doing! Take a look at some of my past and ongoing projects.
You can find me on social media! Email form coming soon...
https://github.com/s-leirbag/portfolio