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

Troublesome "pages" collection #125

Open
skalee opened this issue Jul 14, 2020 · 3 comments
Open

Troublesome "pages" collection #125

skalee opened this issue Jul 14, 2020 · 3 comments
Assignees

Comments

@skalee
Copy link
Contributor

skalee commented Jul 14, 2020

Geolexica defines pages collection, which aggregates various meta pages. This leads to many problems:

  • It is abusive to what collections in Jekyll are meant for (series of similar documents, e.g. blog posts, vcards, etc.)
  • It requires additional configuration (pages collection must be explicitly defined somewhere)
  • It is counter-intuitive and confusing.

Pages collection should be removed.

However, we specify page permalinks as /:page/ via that collection configuration. We need to preserve these setting somehow, and it may be non-trivial the other way we do. Usual Jekyll things…

@skalee
Copy link
Contributor Author

skalee commented Jul 14, 2020

We could also instantiate that collection in Geolexica similarly to what we did with concept collections in cc48a99. But for some reason, this isn't working in case of that collection, I have no idea why.

Anyway, I'd rather remove that collection. Doing things in the other way they are supposed to be is often problematic, especially in Jekyll.

skalee added a commit to geolexica/isotc211.geolexica.org that referenced this issue Jul 14, 2020
- Layouts and permalinks (incl. extensions) are set in Jekyll-Geolexica
  classes, thus don't need to be specified explicitly.
- Concept collections are created automatically since Jekyll-Geolexica
  version 1.4, thus don't need to be defined explicitly.
- Pages collection configuration is preserved, see
  geolexica/geolexica-server#125.
skalee added a commit to geolexica/isotc211.geolexica.org that referenced this issue Jul 14, 2020
* Update Geolexica-Site to 1.4

* Delete unnecessary configuration

- Layouts and permalinks (incl. extensions) are set in Jekyll-Geolexica
  classes, thus don't need to be specified explicitly.
- Concept collections are created automatically since Jekyll-Geolexica
  version 1.4, thus don't need to be defined explicitly.
- Pages collection configuration is preserved, see
  geolexica/geolexica-server#125.
@ronaldtse
Copy link
Member

@skalee FYI there is some effort from @strogonoff to generate the Geolexica site using Glossarist via a react toolchain. Perhaps we should start migrating our efforts there?

skalee added a commit to geolexica/isotc211.geolexica.org that referenced this issue Jul 14, 2020
* Update Geolexica-Site to 1.4

* Delete unnecessary configuration

- Layouts and permalinks (incl. extensions) are set in Jekyll-Geolexica
  classes, thus don't need to be specified explicitly.
- Concept collections are created automatically since Jekyll-Geolexica
  version 1.4, thus don't need to be defined explicitly.
- Pages collection configuration is preserved, see
  geolexica/geolexica-server#125.
@skalee
Copy link
Contributor Author

skalee commented Jul 14, 2020

I am already convinced to migrate away from Jekyll at some point. It is good for blogging or landing sites, but not necessarily for sites like ours. Extracting common stuff to building blocks is difficult, writing tests is difficult (in fact, we have almost none of them, and rather than relying on them I'm running diffs to spot differences between old and new), documentation is confusing and incomplete, and more.

From quite some time, I am thinking what feature set we need, and I have a more less clear vision already. I am considering either migrating to another tool or implementing a new one.

We don't use plenty of Jekyll features, so writing a new one is a considerable option. Nevertheless, there is a number of problems which need to be addressed, including processing SASS, rendering templates, composing pages from layouts and partials, or shadowing generic templates with ones dedicated for particular sites. I hope many can be taken from Rails, especially Asset Pipeline, maybe Action View which is responsible for rendering, and some of view helpers. I hope that some testing helpers can be imported too. I haven't prepared any proof of concept however, so it's difficult to tell how much work is really needed.

Perhaps we should migrate to another existing tool. Nanoc is another generator written in Ruby designed around a different philosophy than Jekyll is. It is likely to match our needs, but on the other hand it seems over complicated, at least at the first glance. I need to dig into documentation before telling more. Anyway, it should be far more flexible than Jekyll.

Integrating site generation into Glossarist that you mentioned is another promising idea. I suppose it may enrich Glossarist application with some nice features like live previews. Maybe this will help in creating Geolexica mobile app easier too, if such app is desired and if Cordova-like tools are acceptable. On the other hand, site generation will require 3rd-party tools like LaTeXML or AsciiDoctor, which in that case would have to be bundled with Glossarist, which may cause difficulties on some platforms. Furthermore, site generation requires things like RDF or TBX-ISO-TML generation, which would have to be implemented in Glossarist. But again, this can be a feature in context of live previews.

However, with all above being said, Jekyll issues are manageable, and I've got used to them. Sometimes bit more configuration is needed, sometimes we have to be flexible, but so far it was never a big issue and I doubt it will ever be. I am more worried about breaking something accidentally due to insufficient testing. Also, diff-based testing is potentially quite time-consuming, depending on situation, but though Jekyll is an obstacle indeed, this also isn't a thing which can be improved easily just by switching to another tool.

Perhaps this should be discussed in a separate thread.

skalee added a commit to glossarist/iev-demo-site that referenced this issue Jul 21, 2020
- Layouts and permalinks (incl. extensions) are set in Jekyll-Geolexica
  classes, thus don't need to be specified explicitly.
- Concept collections are created automatically since Jekyll-Geolexica
  version 1.4, thus don't need to be defined explicitly.
- Pages collection configuration is preserved, see
  geolexica/geolexica-server#125.
skalee added a commit to glossarist/iev-demo-site that referenced this issue Jul 21, 2020
* Update Geolexica-Site to 1.4

* Delete unnecessary configuration

- Layouts and permalinks (incl. extensions) are set in Jekyll-Geolexica
  classes, thus don't need to be specified explicitly.
- Concept collections are created automatically since Jekyll-Geolexica
  version 1.4, thus don't need to be defined explicitly.
- Pages collection configuration is preserved, see
  geolexica/geolexica-server#125.
@ronaldtse ronaldtse moved this to 🆕 New in Geolexica Jul 24, 2022
@ronaldtse ronaldtse moved this from 🆕 New to 📋 Backlog in Geolexica Jul 26, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: 📋 Backlog
Development

No branches or pull requests

3 participants