Untangling Your Dependencies: A Pattern for a Well-Knit React Project

Rate this content
Bookmark

“Alright I’ll just upgrade Typescript, aaaaaand everything is broken now”

Building a complex JavaScript project can feel like a tangled mess of yarn. Fear not, fellow developer! This talk will provide you with the tools and techniques to gently untangle your dependencies and knit a well-structured, maintainable codebase. Our basket of tools include using npm why as our yarn needle, breaking down tasks into manageable stitches, strategically upgrading for progress, utilising branching techniques to keep your project from unraveling, and much more!

Join us as we unravel the secrets of dependency management, leaving you with a project that’s not only functional but beautifully maintainable, stitch by stitch.

This talk has been presented at React Summit US 2024, check out the latest edition of this React Conference.

FAQ

The session covers direct dependencies, transitive dependencies, and peer dependencies, explaining how they function within a project and their impact on the overall codebase.

The bleeding edge branch is a version control practice where a separate branch is used as a sandbox for upgrading dependencies, allowing for broken commits and easy rebasing.

The package lock file specifies the exact versions of dependencies to be installed, ensuring consistency across different development environments and preventing unexpected issues.

Community engagement is crucial as it fosters the creation of tools and resources that simplify dependency management, allowing developers to learn from each other and overcome challenges collaboratively.

The speaker believes best practices for managing dependencies evolve over time and emphasizes the importance of adapting strategies based on personal experiences and project requirements.

The session focuses on managing dependencies in software projects, particularly larger ones, and shares personal experiences and best practices for handling complex dependency management systems.

Common tools for automatic dependency upgrades include Dependabot, Snyk, and Renovate, which handle updates and security patches without manual intervention.

The speaker faced challenges with outdated dependencies, such as an error related to the iPhone 6 simulator and a Java error in the Android build. They tackled these by upgrading dependencies and resolving issues one step at a time.

The speaker recommends tools like Yarn upgrade interactive, NPM check updates, and the React Native upgrade helper for efficiently managing and upgrading dependencies.

The speaker suggests breaking down the problem into smaller tasks, focusing on one issue at a time, and possibly using a bleeding edge branch for testing upgrades incrementally.

Carmen Huidobro
Carmen Huidobro
22 min
22 Nov, 2024

Comments

Sign in or register to post your comment.
Video Summary and Transcription
Thank you for joining my session on untangling your dependencies. I encountered errors when trying to update dependencies in the project, leading to a tangled mess of issues. Managing dependencies can be like working with a ball of yarn, trying to knit a project. I'll share my favorite practices for managing dependencies and provide some background about myself. Leonardo da Vinci said, 'art is never finished, only abandoned,' and this applies to software as well. I'll share tricks and tips for managing complex dependency management systems and understanding different types of dependencies. Working with dependencies often comes with challenges, especially when using React Native. Examples of tools that assist with managing dependencies include yarn upgrade interactive, NPM check updates, and React Native upgrade helper. When encountering issues, breaking them down into smaller chunks helps find solutions. To tackle dependency issues, focus on one platform at a time and choose the right tools. Tools like NPM why and Clip can help identify unnecessary dependencies and unused files. Monorepos and tools like Yarn workspaces and npm shrinkwrap are useful for managing monorepos. Bleeding edge branches and dependency updates allow for incremental and broken commits. Regular updates are recommended to stay aligned with platform changes.

1. Introduction to Untangling Dependencies

Short description:

Thank you for joining my session on untangling your dependencies. I had a client looking for React Native developers, and I decided to take the project even though I had never worked with TypeScript before. The project was a React Native, TypeScript app and presented an interesting challenge. The project had not been worked on in a while, and I encountered errors when running it. After trying to run the iOS and Android builds, I decided to upgrade everything to the latest React Native version.

Hi, everyone. Thank you so much for joining my session on untangling your dependencies. This is a topic that I really enjoy talking about and I feel resonates with a lot of us who have to manage our dependencies, especially in larger projects.

Just to set the stage, I saw a message in the Vienna Freelancers Slack group that said, I have a client looking for React Native devs. Remote, freelance, good rate, could end up being a retainer situation. And I'm sorry, I always laugh when I read this because it always sounds like that TikTok audio, you know, the one that goes, like, I'm looking for a man in finance. Anyway. So I said yes. Being a freelancer has really given me the power to sort of feel confident to just jump in and be like, well, I've never done TypeScript, but I'm sure I can. The project was also React Native, TypeScript, and a lot of fun to work with. And it was a really interesting challenge for me.

Because when I went in, that project hadn't been worked on in a while. So much so, that when I ran it, I got an error. I tried running the iOS version and the error I got was, could not find iPhone 6 simulator. And here's the thing, folks, I tried 6 is not from last year, as I feel in my heart. It is. But it's actually been more time between the iPhone 6 and now, than has been between the original iPhone and the iPhone 6. Just sharing a little bit of my pain.

Anyway, cool. I tried, I was wildly out of date. What about the Android build? I tried, I tried, if you're not familiar with React Native, it lets you write apps for both mobile and I tried platforms as well, including the web. And yes, that includes iOS and Android. So anyway, I ran the Android build, and I got some Java error. I wasn't sure what it meant. But that's okay. I thought to myself, you know what, I'm just gonna upgrade everything. It's gonna be fine. And well, I tried to know how that went. So first, I tried, okay, well, the React Native version on this project is 55.4, and at the time of recording this, of writing this presentation, React Native was at 074.1. And so, I just upgraded it in one go.

2. Dealing with Dependency Issues

Short description:

I encountered errors when trying to update dependencies in the project, leading to a tangled mess of issues. It felt like dealing with a box of cables, where you never know when you'll need them. Managing dependencies can be like working with a ball of yarn, trying to knit a project. I'll share my favorite practices for managing dependencies and provide some background about myself.

Just went into the package.json file and just changed that number. NPM install, up we go. And you might imagine I got an error. Something about React DOM not working well. And I thought, okay, no problem, I'll just update React DOM. And then React broke. And then some other packages broke.

And after a while of trying to fix this, it kind of felt like one of those cable boxes. Do you all have these at home? Like, I want to hear it in the chat, please. Like, do you have in your home just a box full of cables that you really desperately know you need some day? And you've probably got people in your messages or whatever or your friends telling you, throw away those cables. Let me tell you, don't throw them away. You never know when you're going to need that Nokia 3310 charger. Trust me.

Anyway, working through all of this, I tried to stick with our metaphor a little bit more. It kind of felt more like I was working with a very tangly ball of yarn when trying to knit a project. I tried as you get the drawing itself not made by me, but the squiggles a little bit more made by me. I'm not a very good artist. So anyway, that's what we're going to get into today. The question isn't so much, what are the best practices for managing dependencies? I'm a big advocate for best practices change over time. Instead, I tried to talk about what are my favorite practices for managing dependencies. And in order to do that, I'm going to tell you a little bit about myself.

So hey, my name is Katmin, pronouns she, her. I'm originally from Chile, living in Austria for a very long time. I'm working as a developer educator at a company called Directus. And I'm the cofounder of the Bad Website Club where me and my friend Jess make developer education more accessible and get folks into coding in a very low stress, low perfectionism environment, as much as we can. I try to really love communities. I feel like this is one of the best ways that we can learn and grow as human beings. I try to think about dependencies is sometimes we take them for granted, don't we? We just sort of like throw them in and just be like, yeah, whatever. I need something to like, you know, make my life a little bit easier. And I'm not going to really think about the code.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

React's Most Useful Types
React Day Berlin 2023React Day Berlin 2023
21 min
React's Most Useful Types
Top Content
Watch video: React's Most Useful Types
Today's Talk focuses on React's best types and JSX. It covers the types of JSX and React components, including React.fc and React.reactnode. The discussion also explores JSX intrinsic elements and react.component props, highlighting their differences and use cases. The Talk concludes with insights on using React.componentType and passing components, as well as utilizing the react.element ref type for external libraries like React-Select.
TypeScript and React: Secrets of a Happy Marriage
React Advanced 2022React Advanced 2022
21 min
TypeScript and React: Secrets of a Happy Marriage
Top Content
React and TypeScript have a strong relationship, with TypeScript offering benefits like better type checking and contract enforcement. Failing early and failing hard is important in software development to catch errors and debug effectively. TypeScript provides early detection of errors and ensures data accuracy in components and hooks. It offers superior type safety but can become complex as the codebase grows. Using union types in props can resolve errors and address dependencies. Dynamic communication and type contracts can be achieved through generics. Understanding React's built-in types and hooks like useState and useRef is crucial for leveraging their functionality.
Making Magic: Building a TypeScript-First Framework
TypeScript Congress 2023TypeScript Congress 2023
31 min
Making Magic: Building a TypeScript-First Framework
Top Content
Daniel Rowe discusses building a TypeScript-first framework at TypeScript Congress and shares his involvement in various projects. Nuxt is a progressive framework built on Vue.js, aiming to reduce friction and distraction for developers. It leverages TypeScript for inference and aims to be the source of truth for projects. Nuxt provides type safety and extensibility through integration with TypeScript. Migrating to TypeScript offers long-term maintenance benefits and can uncover hidden bugs. Nuxt focuses on improving existing tools and finds inspiration in frameworks like TRPC.
Stop Writing Your Routes
Vue.js London 2023Vue.js London 2023
30 min
Stop Writing Your Routes
Top Content
Designing APIs is a challenge, and it's important to consider the language used and different versions of the API. API ergonomics focus on ease of use and trade-offs. Routing is a misunderstood aspect of API design, and file-based routing can simplify it. Unplugging View Router provides typed routes and eliminates the need to pass routes when creating the router. Data loading and handling can be improved with data loaders and predictable routes. Handling protected routes and index and ID files are also discussed.
Faster TypeScript builds with --isolatedDeclarations
TypeScript Congress 2023TypeScript Congress 2023
24 min
Faster TypeScript builds with --isolatedDeclarations
Top Content
This talk discusses the performance issues in TypeScript builds and introduces a new feature called isolated declarations. By running the compiler in parallel and using isolated modules, significant performance gains can be achieved. Isolated declarations improve build speed, compatibility with other tools, and require developers to write types in code. This feature has the potential to further increase performance and may be available in TypeScript soon.
Full-stack & typesafe React (+Native) apps with tRPC.io
React Advanced 2021React Advanced 2021
6 min
Full-stack & typesafe React (+Native) apps with tRPC.io
Top Content
Alex introduces tRPC, a toolkit for making end-to-end type-safe APIs easily, with auto-completion of API endpoints and inferred data from backend to frontend. tRPC works the same way in React Native and can be adopted incrementally. The example showcases backend communication with a database using queries and validators, with types inferred to the frontend and data retrieval done using Prisma ORM.

Workshops on related topic

React, TypeScript, and TDD
React Advanced 2021React Advanced 2021
174 min
React, TypeScript, and TDD
Top Content
Featured WorkshopFree
Paul Everitt
Paul Everitt
ReactJS is wildly popular and thus wildly supported. TypeScript is increasingly popular, and thus increasingly supported.

The two together? Not as much. Given that they both change quickly, it's hard to find accurate learning materials.

React+TypeScript, with JetBrains IDEs? That three-part combination is the topic of this series. We'll show a little about a lot. Meaning, the key steps to getting productive, in the IDE, for React projects using TypeScript. Along the way we'll show test-driven development and emphasize tips-and-tricks in the IDE.
Mastering advanced concepts in TypeScript
React Summit US 2023React Summit US 2023
132 min
Mastering advanced concepts in TypeScript
Top Content
Featured WorkshopFree
Jiri Lojda
Jiri Lojda
TypeScript is not just types and interfaces. Join this workshop to master more advanced features of TypeScript that will make your code bullet-proof. We will cover conditional types and infer notation, template strings and how to map over union types and object/array properties. Each topic will be demonstrated on a sample application that was written with basic types or no types at all and we will together improve the code so you get more familiar with each feature and can bring this new knowledge directly into your projects.
You will learn:- - What are conditional types and infer notation- What are template strings- How to map over union types and object/array properties.
Deep TypeScript Tips & Tricks
Node Congress 2024Node Congress 2024
83 min
Deep TypeScript Tips & Tricks
Top Content
Featured Workshop
Josh Goldberg
Josh Goldberg
TypeScript has a powerful type system with all sorts of fancy features for representing wild and wacky JavaScript states. But the syntax to do so isn't always straightforward, and the error messages aren't always precise in telling you what's wrong. Let's dive into how many of TypeScript's more powerful features really work, what kinds of real-world problems they solve, and how to wrestle the type system into submission so you can write truly excellent TypeScript code.
Best Practices and Advanced TypeScript Tips for React Developers
React Advanced 2022React Advanced 2022
148 min
Best Practices and Advanced TypeScript Tips for React Developers
Top Content
Featured Workshop
Maurice de Beijer
Maurice de Beijer
Are you a React developer trying to get the most benefits from TypeScript? Then this is the workshop for you.In this interactive workshop, we will start at the basics and examine the pros and cons of different ways you can declare React components using TypeScript. After that we will move to more advanced concepts where we will go beyond the strict setting of TypeScript. You will learn when to use types like any, unknown and never. We will explore the use of type predicates, guards and exhaustive checking. You will learn about the built-in mapped types as well as how to create your own new type map utilities. And we will start programming in the TypeScript type system using conditional types and type inferring.
Building Your Own Custom Type System
React Summit 2024React Summit 2024
38 min
Building Your Own Custom Type System
Featured Workshop
Kunal Dubey
Kunal Dubey
I'll introduce the audience to a concept where they can have end-to-end type systems that helps ensure typesafety across the teams Such a system not only improves communication between teams but also helps teams collaborate effectively and ship way faster than they used to before. By having a custom type system, teams can also identify the errors and modify the API contracts on their IDE, which contributes to a better Developer Experience. The workshop would primarily leverage TS to showcase the concept and use tools like OpenAPI to generate the typesystem on the client side. 
Frictionless Development With Unified Type System
JSNation 2024JSNation 2024
113 min
Frictionless Development With Unified Type System
Featured Workshop
Ejiro Asiuwhu
Ejiro Asiuwhu
Imagine developing where frontend and backend sing in harmony, types dance in perfect sync, and errors become a distant memory. That's the magic of TypeScript Nirvana!
Join me on a journey to unveil the secrets of unified type definitions, the key to unlocking frictionless development. We'll dive into:
- Shared language, shared love: Define types once, share them everywhere. Consistency becomes your BFF, errors your worst nightmare (one you'll rarely see).- Effortless coding: Ditch the manual grind of type checking. TypeScript's got your back, freeing you to focus on building awesomeness.- Maintainability magic: With crystal-clear types guiding your code, maintaining it becomes a walk in the park. More time innovating, less time debugging.- Security fortress: TypeScript's type system shields your app from common vulnerabilities, making it a fortress against security threats.