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

Incorrect route matching with subfolder root #275

Closed
stepanjakl opened this issue Feb 20, 2021 · 8 comments
Closed

Incorrect route matching with subfolder root #275

stepanjakl opened this issue Feb 20, 2021 · 8 comments

Comments

@stepanjakl
Copy link

Hello Krasimir,

I deployed a site on Github Pages inside a subfolder and set Navigo's root to that subfolder i.e. new Navigo('/bohemica-studio-website').

I am getting a wrong match for Navigo links when the href path is (correctly) set to "bohemica-studio-website/en/projects/branding". The matching route should be bohemica-studio-website/:language/projects/:name, but it ends up being bohemica-studio-website/*.

Interestingly, when I call the router.match('bohemica-studio-website/en/projects/branding'), I get the correct route. Same, when I set the link without the root path i.e. "en/projects/branding"

Screenshot 2021-02-20 at 11 16 08

Maybe, there is some wrong deployment setting, but I feel that Navigo is being fed the right data, so it's likely an internal issue. What do you think?

Thank you ✌️

P.S. Everything works fine on localhost when the root path is set to '/'

@krasimir
Copy link
Owner

Hey,

if you ser a specific path as a root of your app you should skip it when writing URLs in the a tags. For example your tag should look like:

<a href="/en/projects/branding" data-navigo>link</a>

The router knows that you mean /bohemica-studio-website/en/projects/branding because it has bohemica-studio-website as a root.

@stepanjakl
Copy link
Author

Okay, thank you for the answer.

Then, I believe that the router.generate() function creates url string with the root, which subsequently can't be used for the link.

Moreover, if you take away the root path, then it can be a bit confusing for the user in the browser .e.g.:

  1. what the user sees:

Screenshot 2021-02-20 at 15 24 07

  1. what the user should actually see:

Screenshot 2021-02-20 at 15 24 24

(I know, it's a minor detail)

@krasimir
Copy link
Owner

I'm a bit confused what is the expected behavior. Can you share a URL or even if possible a codesandbox. You can use this as an example https://codesandbox.io/s/navigo-example-jrui8

@stepanjakl
Copy link
Author

Essentially, I create a path via router.generate('branding') that I can then input inside <a href='...'>. However, currently I get bohemica-studio-website/en/projects/branding instead of en/projects/branding which, like you said, doesn't work for the navigo link as it contains the root folder.

I think it would make more sense for the link to include the full path with the root as mentioned in the previous post. E.g. <a href='bohemica-studio-website/en/projects/branding'> rather than <a href='en/projects/branding'>

I could probably just take the root off the generated path programatically... I am just thinking out loud here :)

The site is still WIP, but I am happy to share it at a later date (I think you'll find it interesting anyway as I use Navigo for an internationalisation system, including language change for the url path).

@krasimir
Copy link
Owner

I see @stepanjakl. I would rather patch the generate method so it returns the path without app than forcing the full url path on the links. Conceptually the idea of Navigo is to be an app oriented. It shouldn't know about the rest of the world. So I'll probably provide an additional argument to the generate function which will strip the root.

@mrdaliri
Copy link

Hi @krasimir,
I'm having the same problem after upgrading to v8 from v7: links with href generated by router.generate() are not correctly handled by Navigo. If I drop data-navigo they work fine, but I'll lose the SPA feature.

krasimir pushed a commit that referenced this issue Feb 28, 2021
@krasimir
Copy link
Owner

krasimir commented Feb 28, 2021

@stepanjakl @mrdaliri can you please try the latest 8.9.0 version. It allows a third argument of the generate method.

router.generate(
  "route-name",
  { data: 'foobar' }, // this cloud be null
  { includeRoot: false } // false means "Don't include the root"
)

@stepanjakl
Copy link
Author

I swapped the project a custom domain (and root folder), so I cannot test it. But it looks good and would consider it fixed👍

@krasimir krasimir closed this as completed Mar 1, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants