Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(i18n): fallback should create consistent directories #9142

Merged
merged 3 commits into from
Nov 20, 2023

Conversation

ematipico
Copy link
Member

@ematipico ematipico commented Nov 20, 2023

Changes

Fixes #9096
Fixes #9095
Closes PLT-1230

This PR refactors the fallback system again. There was a business logic flaw in how the routes and paths were computed, plus the flow of things could have been smoother, and that didn't help.

When rendering a page, the flow was like this:

  • we extract the styles/links/scripts
  • generate the paths using getStaticPaths
  • loop over the exploded paths
  • call the generatePath function
  • compute more styles and scripts
  • create a request and render the response

Now the flow is adapted to the fallback, and a few steps have been moved:

  • we extract the styles/links/scripts
  • compute more styles and scripts
  • NEW loop over the exploded routes (itself + fallbacks)
  • loop over the exploded paths
  • call the generatePath function
  • create a request and render the response

The function generatePath now accepts the styles/scripts/links, and they are already computed; it only needs to render the Response.

The function eachRouteInRouteData is now called in a different place and its loop is way smaller.

Testing

I added a new test case that should prevent a regression against the issues we're closing.

The rest of the tests should still pass.

Docs

N/A

Copy link

changeset-bot bot commented Nov 20, 2023

🦋 Changeset detected

Latest commit: 972799b

The changes in this PR will be included in the next version bump.

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@github-actions github-actions bot added the pkg: astro Related to the core `astro` package (scope) label Nov 20, 2023
@github-actions github-actions bot added the pr: docs A PR that includes documentation for review label Nov 20, 2023
Copy link
Contributor

@matthewp matthewp left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

so much simpler, great job!

@ematipico ematipico merged commit 7d55cf6 into main Nov 20, 2023
13 checks passed
@ematipico ematipico deleted the fix/fallback-incorrect-folders branch November 20, 2023 18:23
@astrobot-houston astrobot-houston mentioned this pull request Nov 20, 2023
ematipico added a commit that referenced this pull request Nov 21, 2023
ematipico added a commit that referenced this pull request Nov 30, 2023
* add test case

* fix(i18n): fallback should create consistent directories (#9142)

* fix: index can be 0!!

* tests should have the correct configuration
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pkg: astro Related to the core `astro` package (scope) pr: docs A PR that includes documentation for review
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Issues with page routing in i18n Issues with redirects and page routing with i18n
2 participants