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

feat: add cleanUrls option (#219) #869

Closed
wants to merge 16 commits into from

Conversation

georges-gomes
Copy link
Collaborator

@georges-gomes georges-gomes commented Jun 27, 2022

( Replaces #488 for alpha)

This feature is meant to be working with SPA and MPA mode so it's a little bit bigger than just rename the browser location.

  • New option: cleanUrls (default false)
  • Generates /foo.md -> /foo/index.html (This works best for MPA mode with most static site hosting services)
  • Internal links in .md files are not transformed to .html
  • When on SPA mode, the client router doesn't rename /foo into /foo.html anymore.
  • Supports 404 page so it still generate /404.html (and not /404/index.html like other pages).

fixes #219, fixes #444

@brc-dd
Copy link
Member

brc-dd commented Jun 27, 2022

@kiaking I was thinking if instead of providing an option for cleanUrls, we can make it default? It'll simplify the code much more (like there will not be any need to pass it through different functions to normalizeHref). Also, this should fix our Algolia issue 😅.

@georges-gomes Is there any compelling reason that people would want to set cleanUrls to false?

@georges-gomes
Copy link
Collaborator Author

georges-gomes commented Jun 27, 2022

@brc-dd for people already using VitePress, this would change their URLs... It has a number of impacts for them.
We can have cleanUrls default to true for v1.0.0 (not my call) but I think we need this option for migration.

@georges-gomes
Copy link
Collaborator Author

@kiaking Does it looks good to you? Let me know if I should adjust something.

@azat-io
Copy link
Contributor

azat-io commented Jun 29, 2022

Awesome 😍

src/client/app/router.ts Outdated Show resolved Hide resolved
src/node/config.ts Outdated Show resolved Hide resolved
@brc-dd
Copy link
Member

brc-dd commented Jul 1, 2022

There is .html inside certain docs too. Since we're not automatically removing html from pages, it will be better to have consistent URLs in the docs. Also, it appears you've not allowed edits by maintainers in the PR.

These docs had this https://github.com/vuejs/vitepress/pull/724/files#diff-d019d98f93ab320a29453160fbb723955227add7e423571649818128db30c595, https://github.com/vuejs/vitepress/pull/724/files#diff-3193bd261794eacfc0903b854591814239fe7c7737175464622570a374b517db. There might be a few more now.

@brc-dd
Copy link
Member

brc-dd commented Jul 1, 2022

Not sure, but we might need to change this too:

const locationPath = location.pathname.replace(/(\bindex)?\.html$/, '')

georges-gomes and others added 2 commits July 1, 2022 15:51
Co-authored-by: Divyansh Singh <[email protected]>
Co-authored-by: Divyansh Singh <[email protected]>
@brc-dd
Copy link
Member

brc-dd commented Jul 1, 2022

This issue is also there: #412 if you add trailing slash to your URL (shows title 404, etc.). I had fixed this in vite-3 branch itself.

@brc-dd
Copy link
Member

brc-dd commented Jul 1, 2022

Also, there is some issue with sidebar. Open this: https://deploy-preview-869--vitepress-docs.netlify.app/guide/getting-started/, now click on configuration in sidebar. URL becomes this: https://deploy-preview-869--vitepress-docs.netlify.app/guide/configuration.html. Reload page it becomes: https://deploy-preview-869--vitepress-docs.netlify.app/guide/configuration/.

Sorry, the content is not changing. Just the URL is. (and the title)

@georges-gomes
Copy link
Collaborator Author

Also, there is some issue with sidebar. Open this: https://deploy-preview-869--vitepress-docs.netlify.app/guide/getting-started/, now click on configuration in sidebar. URL becomes this: https://deploy-preview-869--vitepress-docs.netlify.app/guide/configuration.html. Reload page it becomes: https://deploy-preview-869--vitepress-docs.netlify.app/guide/configuration/.

This is new, I have to check why. Thanks

@brc-dd
Copy link
Member

brc-dd commented Jul 1, 2022

@georges-gomes
Copy link
Collaborator Author

You need to change this normalizedPath thing for sidebar issues IG:

https://github.com/vuejs/vitepress/pull/724/files#diff-4eb03faf823699119c94556187e2edb5771912371c55f9aef88804ec6c996564

Should be much better now.

@georges-gomes
Copy link
Collaborator Author

@kiaking @brc-dd when you are happy with this change we can switch off the cleanUrls option before merging if you don't want it for the production site. But since we are bringing a brand new documentation, it would be the moment to bring this on... Your call.

@brc-dd
Copy link
Member

brc-dd commented Jul 4, 2022

when you are happy with this change we can switch off the cleanUrls option before merging if you don't want it for the production site. But since we are bringing a brand new documentation, it would be the moment to bring this on... Your call.

Yeah, there is no need to disable it. 👍

@brc-dd
Copy link
Member

brc-dd commented Jul 4, 2022

Can you target this to chore/vite-3 branch for now? Some fixes are not on main currently. That's why reloading pages is giving 404 with hydration mismatch.

@brc-dd brc-dd changed the base branch from main to chore/vite-3 July 4, 2022 09:16
src/client/app/router.ts Outdated Show resolved Hide resolved
georges-gomes and others added 2 commits July 4, 2022 14:28
Co-authored-by: Divyansh Singh <[email protected]>
Co-authored-by: Divyansh Singh <[email protected]>
@brc-dd
Copy link
Member

brc-dd commented Jul 4, 2022

@georges-gomes Without trailing slash Netlify is having issue. Open this site for example: https://62c2e731bab5b3761e2ce010--fastidious-stroopwafel-625e87.netlify.app/guide/getting-started

@georges-gomes
Copy link
Collaborator Author

@georges-gomes Without trailing slash Netlify is having issue. Open this site for example: https://62c2e731bab5b3761e2ce010--fastidious-stroopwafel-625e87.netlify.app/guide/getting-started

Is Netlify setup with "Pretty URLs" ?

@brc-dd
Copy link
Member

brc-dd commented Jul 4, 2022

Is Netlify setup with "Pretty URLs" ?

No, asset optimization is disabled.

@brc-dd
Copy link
Member

brc-dd commented Jul 4, 2022

Having trailing slash will cause other issues like a URL or asset like this ./theme-introduction will resolve incorrectly. And Netlify apparently adds that:

With a file at /blog.html

  • Navigating to /blog.html will serve /blog.html
  • Navigating to /blog will serve /blog
  • Navigating to /blog/ will 301 redirect and serve /blog

With a file at /blog/index.html (and no file at /blog.html!)

  • Navigating to /blog.html will 301 redirect and serve /blog/
  • Navigating to /blog will 301 redirect and serve /blog/
  • Navigating to /blog/ will serve /blog/

What's the solution here? :/

@georges-gomes
Copy link
Collaborator Author

When I use npx serve or Firebase hosting, I don't have issues. But we need to find the proper setup for Netlify I agree

@brc-dd
Copy link
Member

brc-dd commented Jul 4, 2022

The issue is on Vercel too, but on Vercel we can set trailingSlash redirects, so that fixes the stuff there.

@georges-gomes
Copy link
Collaborator Author

I'm reading that Netlify is biais toward trailing slash in our configuration. I think I'm going to option trailing and non-trailing slash option depending on the hosting solution. Nothing is easy.

@georges-gomes
Copy link
Collaborator Author

I created the option

cleanUrls

  • Type: "off" | "with-trailing-slash" | "without-trailing-slash"
  • Default: "off"

When set to "off", page foo/bar.md is generated into foo/bar.html.

When set to "with-trailing-slash" or "without-trailing-slash", page foo/bar.md is generated into foo/bar/index.html.

When set to "with-trailing-slash", URLs will be foo/bar/.
When set to "without-trailing-slash", URLs will be foo/bar.

Notes:

  • 404.md page is kept transforming to 404.html for hosting services.
  • Also work in MPA mode.

@georges-gomes
Copy link
Collaborator Author

But there is still an issue with the router. It doesn't like trailing slashes. I couldn't find the solution quickly.

@georges-gomes
Copy link
Collaborator Author

OK trailing slash is fixed.

But there is a little challenge:

When with-trailing-slash is on, URL foo/bar/ could be resolved to file foo/bar.md or foo/bar/index.md. For the moment I hardcoded the resolve to foo/bar.md...

The without-trailing-slash option doesn't have this problem.

@brc-dd
Copy link
Member

brc-dd commented Jul 5, 2022

There are some more issues with clean urls. Like we have relative links in markdown. Click links in the "what's next" section on this page: http://localhost:4173/guide/getting-started/. They aren't being properly resolved. Also prefetching links is not working (see console for errors as you scroll to the bottom). I suppose the links can be handled in the markdown plugin. But there would be a challenge in determining if the page is index (no need to modify urls in this case) or if its just foo which we have made foo/index (will need to increase one level). Also this won't handle links inside Vue components. Also vitepress dev is not working. This is getting a lot more complex than I expected. 🥲

@georges-gomes
Copy link
Collaborator Author

It's starting to require a lot of code to deal with trailing slash...
We better just not support it... and keep the option off while VitePress doc is hosted on Netlify...

@brc-dd
Copy link
Member

brc-dd commented Jul 5, 2022

I am thinking lets have three options:

  1. Don't nest directories (no trailing slash) (just the router stuff, will work on almost all of the popular hosting services including Netlify, Vercel, GitHub Pages, Cloudflare Pages, cPanel/Apache/Nginx based hosting providers with 1-2 line config).

  2. Nest directories (no trailing slash) will work with many hosting providers, especially the CDN type / static ones.

  3. Off

Regarding the MPA mode, not nesting will work if the server is configured to rewrite the URLs, otherwise it won't. It will work in MPA if nested.

@georges-gomes
Copy link
Collaborator Author

I don't understand what you call "nest directories" and "don't nest directory"

@brc-dd
Copy link
Member

brc-dd commented Jul 6, 2022

I meant this:

/foo.md -> /foo/index.html (create clean directory structure))
/foo.md -> /foo.html (don't create clean directory structure)

@georges-gomes
Copy link
Collaborator Author

I don't know if we can do (1) - it would rely of the hosting service to sert /foo.html when requested /foo without redirect... I can leave the door open for (1) but just implement (2) and (3) for now.

@brc-dd
Copy link
Member

brc-dd commented Jul 6, 2022

Fine! 👍 BTW, VuePress also has this warning in place:

This plugin will always work on your dev server, but VuePress does not have the right to modify server identification. If you want your URLs to follow a certain pattern (e.g. /routing instead of /routing.html or routing/), you should make sure that your server would treat it as an HTML. This means that you may need to configure your server specifically.

@georges-gomes
Copy link
Collaborator Author

Done, with nicer documentation.
Switched off in the PR so the VitePress documentation works great on Netlify.

@brc-dd brc-dd changed the title feat(cleanUrls): Clean Urls options. No .html in location. (Works in MPA) feat: add cleanUrls option (#219) Jul 7, 2022
@brc-dd brc-dd mentioned this pull request Jul 7, 2022
4 tasks
@brc-dd
Copy link
Member

brc-dd commented Jul 7, 2022

Okay so I've merged these changes to the Vite3 branch with certain changes. Thanks for all the work!! 💚

@brc-dd brc-dd closed this Jul 7, 2022
@brc-dd
Copy link
Member

brc-dd commented Jul 7, 2022

Can you review #856 and verify if the clean urls are working cool with with-subfolders option? I had tested it on my setup. It worked fine. Just making sure twice.

@georges-gomes
Copy link
Collaborator Author

Can you review #856 and verify if the clean urls are working cool with with-subfolders option? I had tested it on my setup. It worked fine. Just making sure twice.

Testing soon!

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Jan 21, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants