GCTC-NTGC / gc-digital-talent

GC Digital Talent is the new recruitment platform for digital and tech jobs in the Government of Canada. // Talents numériques du GC est la nouvelle plateforme de recrutement pour les emplois numériques et technologiques au gouvernement du Canada.
https://talent.canada.ca
GNU Affero General Public License v3.0
22 stars 8 forks source link

[🦔] Data loaders #11745

Open esizer opened 1 week ago

esizer commented 1 week ago

👋 Introduction

This is an example of how we could achieve react-router data loaders with urql.

🕵️ Details

Since loaders are regular functions, we cannot use hooks in them. So, we instead get the client in the router and pass it into a builder that returns the loader.

🧪 Testing

  1. Build the app pnpm run dev:fresh
  2. Login as any user
  3. Confirm the dashboard loads correctly
  4. Navigate away and then return
  5. Notice the query is re-run every time even though it should be near instant read from cache