-
Notifications
You must be signed in to change notification settings - Fork 826
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
Migrate to an Elixir SSG (tableau) ?? #1771
Comments
Thank you, I'd love to see how it would look like. My initial suggestion is to do the home page and one blog post, and we evaluate from there. Everything else should fall under these two "templates" anyway. But I recommend waiting 24h before getting started so other team members can jump in. |
I would recommend a couple of research tasks first
|
I'll have a look at that.
My first impulse would be to switch to Heex, and adopt mainstream elixir tooling where possible. |
I would start with liquid/solid because that's a smaller changes and then consider moving to HEEx. Fewer moving pieces at once. |
The way I used the solid package was to create a sigil, but in order to decrease the size of the diff you might want to just have it read the templates from disk https://github.com/mhanberg/blog/blob/a719f3f9f68d9aeca058a631de780e78841ae715/lib/blog.ex#L126-L154 Either way, you'll see some options I used in that macro as well as how I handled the assigns. |
There will also be some jekyll-isms like this that you'll have to recreate as a custom Liquid tag |
This eve I did a minimal proof-of-concept - a test migration from Jekyll to Tableau. Click here for the tableau code. Here's a screenshot of the current work-in-progress: After this exercise, I believe that a migration from Jekyll to Tableau is quite feasible. re: Jekyll plugins - looks to me like the Jekyll plugins are 'site map' and 'RSS feed', which AFAIK exist as Tableau extensions. re: liquid templates vs HEEX - for me, HEEX is just easier, so that is what I used. In the migration, To finish the migration, I think these are more-or-less the next actions:
Per Jose's suggestion, I'll wait a couple days to collect feedback. If the consensus is to move forward, I'll work in my spare time to finish the migration, which might take a couple weeks depending on my schedule. |
Thank you, that was a nice starting point. Do we need to define modules for each page or can we just point to a directory and have it treat each file in there as its own page? |
The latter. We need to define 2-4 'layout' modules which wrapper each markdown file. We have a working example of the core layout module - the root layout. This was built by repurposing HTML from the old site. The root layout still needs TLC, but works now as a proof of concept. FYI layouts can be nested. Markdown files are customized with |
Elixir now has a great Static Site Generator - Tableau written by @mhanberg. IMO Tableau is solid and deserves more attention.
The ElixirLang website is currently rendered with Ruby using Jekyll.
If people are interested in migrating from Jekyll to Tableau, I'll take a crack at it:
People may prefer to stick to the current tooling. If so - no problemo.
But I hope there is consensus to give it a try. It would be great to put up a Tableau showcase, and to give developers another reason to adopt Elixir.
The text was updated successfully, but these errors were encountered: