Senior Software Engineer - Developer Experience
Sanity.io
·
Posted:
August 22, 2023
·
Remote
About the position
We are seeking a skilled developer to join our Developer Experience team and contribute to the creation of a robust framework and tooling for real-time collaborative editing of structured content. The role involves building APIs, ensuring reactivity and collaboration, debugging and optimizing performance, continuous improvement, and learning and teaching best practices. The ideal candidate should have experience with web applications, be proficient in React and state management, possess knowledge of core web and browser concepts, be familiar with module systems and bundling, and have a good understanding of TypeScript and unit testing.
Responsibilities
- React. Given our entire application is rendered with React, we really do need you to know your way around useState and useEffect. We really hope you know about the React developer tools, and have gotten your way out of useEffect loops. Context isn’t always the right choice, but we hope you’ve got experience with it anyway. We’d be very happy if you’ve optimized some rendering in a React application, and we’d be absolutely over the moon if you know what useSyncExternalStore is, or know the intricacies of strict mode.
- State management. We don’t really care if you’re an old-time Reflux user, have years of experience with Redux or if you’re on the zustand train - but we do care that you know when and why you might reach for one of these. We’d also like you to know about “selectors”, or other techniques of fine-grained subscription.
- Core web and browser concepts. You need to know what HTTP requests are, what the event loop is (and why it matters), how promises work, how to use browser development tools and preferably also know your way around some DOM and browser APIs. In other words; you know what the fetch API is and roughly how it works, and you’ve at least heard about IntersectionObserver and getBoundingClientRect.
- Module systems and bundling. No, we don’t need you to be an expert on Webpack. But we DO need you to know what bundlers like Webpack, Vite and Rollup DO. Similarly, we don’t expect you to solve any ESM vs CommonJS issue we may encounter, but we really hope you know what those two names mean, and how they are different.
- TypeScript. The basics: interfaces, types, some knowledge of generics. Why you shouldn’t use any. If you care about type narrowing, discriminated unions and other fancy TypeScript features, we’d be even happier!
- Unit testing. Using something like Jest, vitest, tap, mocha… The framework isn’t important, what is important is that you know why and how to write tests. We’d love it if you could talk about test isolation and the pro
Requirements
- Experience building APIs and implementing minimal, beautiful APIs for internal and external developers
- Understanding of collaboration and the ability to create reactive APIs
- Proficiency in debugging and optimizing React-based applications
- Willingness to continuously learn and teach best practices and new approaches
- Commitment to continuously improving the product, including test coverage, API robustness, and staying up to date with dependencies
- Familiarity with React, including useState, useEffect, React developer tools, and optimization techniques
- Knowledge of state management, such as Reflux, Redux, or Zustand, and familiarity with fine-grained subscription techniques
- Understanding of core web and browser concepts, including HTTP requests, event loops, promises, browser development tools, DOM, and browser APIs
- Familiarity with module systems and bundling, such as Webpack, Vite, and Rollup, and knowledge of ESM vs CommonJS
- Proficiency in TypeScript, including interfaces, types, generics, and avoiding the use of "any"
- Experience with unit testing using frameworks like Jest, vitest, tap, mocha, and understanding of test isolation and snapshot testing
- Bonus: Knowledge of RxJS for driving reactivity and combining async events
- Bonus: Experience with automated browser testing tools like Cypress, Playwright, Puppeteer
- Bonus: Familiarity with Node.js for navigating Node-based tools and dependencies, and backend development experience
Benefits
- Highly-skilled, inspiring, and supportive team
- Positive, flexible, and trust-based work environment
- Remote/WFH on the Central/East Coast in the US or Canada
- Universal healthcare, support for physical and mental health, and parental leave
- Healthy work-life balance with flexible work hours
- Competitive salary and stock options program
- Opportunity to work with cool technology
- Long-term personal growth opportunities
- Inclusive and diverse team culture
- Equal employment opportunity regardless of various factors