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

Mustache rendering {{#current}} blocks break page context #8

Closed
roblillack opened this issue Jun 7, 2021 · 1 comment
Closed

Mustache rendering {{#current}} blocks break page context #8

roblillack opened this issue Jun 7, 2021 · 1 comment
Assignees
Labels
Milestone

Comments

@roblillack
Copy link
Owner

roblillack commented Jun 7, 2021

According to the Mustache spec, rendering a section by accessing a boolean value like current this should happen:

use a single-element list containing the data, otherwise use an empty list. For each element in the data list, the element MUST be pushed onto the context stack, the section MUST be rendered, and the element MUST be popped off the context stack.

https://github.com/mustache/spec/blob/master/specs/sections.yml

This means, that a block like this:

{{#navigation}}
{{#current}}{{name}}{{/current}}
{{^current}}<a href="{{permalink}}">{{name}}</a>{{/current}}
{{/navigation}}

should render

<a href="/a">A</a>
B
<a href="/c">C</a>

for this context:

{
  "name": "B",
  "permalink": "/b",
  "navigation": [
    {
      "name": "A",
      "permalink": "/a"
    },
    {
      "current": true,
      "name": "B",
      "permalink": "/b"
    },
    {
      "name": "C",
      "permalink": "/c"
    }
  ]
}

But instead it renders:

<a href="/b">B</a>
B
<a href="/b">B</a>

as the variables inside the current will be resolved from the top level not the iterated navigation.

@roblillack
Copy link
Owner Author

This currently breaks many #navigation use-cases.

I opened a ticket upstream: cbroglie/mustache#53 – let's see.

@roblillack roblillack self-assigned this Jun 8, 2021
@roblillack roblillack added this to the v1.0.1 milestone Jun 8, 2021
roblillack added a commit that referenced this issue Jun 10, 2021
This adds a bunch of fully integrated test sites.

While here, fix some bugs:
- Fix not being able to read `.md` or `.yaml` files instead of `.mkd` and `.yml`. #22
- Fix title casing. #3 
- Fix iterate `siblings` in correct order. #4
- Fix crash for non-existent asset directories. #5 
- Fix rendering section context. #8 (Needs cbroglie/mustache#54)
- Fix rendering non-false value sections. #23 (Needs cbroglie/mustache#55)

Also, add these features:
- Allow the root index page to be defined with metadata and markup directly in `content/`. #19
- Add support for empty pages (no metadata or markup defined) if they have non-empty children. #20
- Add support for `children` to iterate non-floating child pages. #16
- Add support for `posts` to iterate all child pages marked with a date. #18
- Add support for `menu` sections to iterate all `siblings` and the current page (only for non-floating pages). #17
- For each entry of page collections (`children`, `menu`, `navigation`, `posts`, `siblings`) add `first` and `last` boolean values that can be used to construct better separators. #21
@roblillack roblillack modified the milestones: v1.0.1, v1.1.0 Jun 10, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant