Senior front end developer

Expatfile.tax
Remote
Posted Apr 7, 2026

Senior Front-end Developer

Contract:                   Freelance, fully remote

Commitment:           4 days per week (32 hours)

Compensation:        $70,000 - $90,000 per year

The Opportunity

Looking for a fully remote, but ongoing contract where you can leverage your Front-end development? 

Expatfile is looking for an eager senior front-end developer to become an integral part of our team! Expatfile builds tax software for American expats - making a painful, complex process simple. We're a small, product-driven team shipping across multiple Next.js applications that handle everything from onboarding and document extraction to payments. Our users trust us with sensitive financial data, and we take that seriously in how we build.

About Expatfile

Filing U.S. taxes from abroad is notoriously painful, confusing, and expensive. At Expatfile, we'€™re on a mission to change that. We'€™ve built the most sophisticated, user-friendly tax software specifically designed for the millions of Americans living overseas.

We aren't just another tax tool; we are a high-growth FinTech scale up that prioritizes security, simplicity, and speed. Because we handle sensitive financial data for users in over 100 countries, our software must be flawless. We are SOC 2 aligned and obsessed with quality.

Why Join Us?

  • Real Impact: Your work directly ensures that thousands of expats can file their taxes accurately and without stress.
  • Freedom & Stability: We offer the flexibility of a remote, part-time freelance lifestyle with the security of a long-term, permanent seat at the table.
  • Modern Stack: No legacy baggage. We work with the latest tools and tech stack and move fast.

Role focus:

  • Build features across multiple Next.js applications
  • Implement designs from Figma with high fidelity
  • Write and consume GraphQL queries and mutations with codegen
  • Write tests - component tests with Jest/Bun + Testing Library, API mocking with MSW
  • Maintain Storybook - keeping component documentation current
  • Code review the junior developer's PRs and pair when needed
  • Collaborate with the FE Lead on architectural decisions
  • Work with feature flags for safe rollouts

How We Work:

  • 2-week sprints with daily standups
  • Central European Time (CET) working hours
  • Office space in Amsterdam; remote is an option
  • Company provided modern M-series MacBook Pro (32 GB+ RAM)

Required Skills

Core Stack:

  • TypeScript: advanced proficiency. Generics, discriminated unions, utility types, strict mode.
  • React 18/19: deep understanding of the rendering model, hooks, Suspense, transitions, concurrent features.
  • Next.js (App Router): fluent with React Server Components, server actions, streaming, layouts, route groups, middleware. This is the daily toolkit.
  • Next.js (Pages Router): fluent with getStaticProps/getServerSideProps and understands when migration to RSC makes sense, and when it doesn't.

Styling:

  • SCSS / CSS Modules: production experience writing scalable, maintainable SCSS. Solid grasp of CSS specificity, responsive design, and CSS variables.

Data Layer:

  • GraphQL: strong, not surface-level. Comfortable with schema comprehension, codegen workflows, client cache management (Apollo Client and/or URQL), optimistic updates, pagination patterns, error handling, and composing fragments efficiently.

Design & Accessibility:

  • Figma-to-code: can receive designs and implement them with pixel-perfect fidelity. Understands design tokens, spacing systems, and typography scales.
  • Storybook: experience building and maintaining component stories for documentation, visual review, and design collaboration.
  • WCAG 2.1 AA: practical, not theoretical. Accessible forms, modals, focus management, ARIA attributes, keyboard navigation, screen reader compatibility.

Testing:

  • Jest or Bun test: unit and integration testing of components and hooks.
  • React Testing Library: testing behavior, not implementation details.
  • MSW (Mock Service Worker): mocking API responses in tests and Storybook.

Ideal Experience

  • 7+ years of professional front-end experience.
  • Patient, communicative, and able to give constructive code review feedback, you'll be co-mentoring a junior developer.
  • Comfortable making pragmatic tradeoffs to deliver value to users.
  • Availability during CET work hours.







Please mention the word CHAMP and tag RMTYyLjIyMC4yMzQuMjY= when applying to show you read the job post completely (#RMTYyLjIyMC4yMzQuMjY=). This is a beta feature to avoid spam applicants. Companies can search these words to find applicants that read this and see they're human.

Job Details

Job Type

admin_data_entry

How to Apply

This job has specific application instructions. Please read the full job description carefully.

Company Verification

This company has not been fully verified. Research the company before submitting personal information.

Remote Job Safety Tip

Check company reviews on sites like Glassdoor or LinkedIn before applying.

Original job posting from: Direct_scraper

Related Jobs

Employee Wellness Assistant

Virginia Community College System

VA, US

Employee Wellness Assistant

Northern Virginia Community College

VA, US

Front Desk Receptionist | Appoinment setter | Recruitment Assistant

Encore Medical Research LLC.

Hollywood, FL, US

Education Disability Coordinator 1

Mid-Columbia Children's Council

Hood River, OR, US

Administrative Assistant/Data Entry Clerk

PPC Flexible Packaging

Payson, UT, US

Junior Specialist- Race Lab

UC Davis

Sacramento, CA, US

Operations Manager - Student Accomm & Suppt Svcs

Eastern Washington University

Cheney, WA, US

Administrative Assistant

Accel Property Management

McAllen, TX, US

Administrative Assistant

Victory Starts Now

Los Angeles, CA, US

Administration and Membership Assistant

YMCA OF PIERCE AND KITSAP COUNTIES

Tacoma, WA, US

Get Job Alerts

Never miss out on the latest remote opportunities. Get new job listings delivered to your inbox daily.

No spam, unsubscribe at any time