logo

ButcherBox Internship

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!

I did 3 main things:
  • Develop a content-authoring tool
  • Increase Datadog observability by adding RUM actions and dashboards
  • Refine UI components—and have fun issues with prefetching and responsiveness
Stack

React

Contentful

Datadog

Year

2024

project thumbnail

Main Project

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.

Visualizing Content Templates

Visualizing Content Templates

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.

what's in the box

Development Process

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.

filtering

Challenge: Filtering

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.

fish smooch

Impact

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!

Learnings

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!

Other Work

I learn by doing! Take a look at some of my past and ongoing projects.

Contact Me

You can find me on social media! Email form coming soon...

https://github.com/s-leirbag/portfolio