Implement HasMenuCurrent and IsMenuCurrent for Nodes
authorbep <bjorn.erik.pedersen@gmail.com>
Sat, 18 Oct 2014 18:25:10 +0000 (20:25 +0200)
committerspf13 <steve.francia@gmail.com>
Sun, 2 Nov 2014 02:34:49 +0000 (22:34 -0400)
commitd013edb7f838b739db72530e06eb47721baec7b8
tree4e1885e661e603f264b4fa9a3067f25754d96faf
parent2b412d4ac7fb143addf2bf5139de7ee903525b24
Implement HasMenuCurrent and IsMenuCurrent for Nodes

Prior to this commit, `HasMenuCurrent` and `IsMenuCurrent` on `Node` always returned false.

This made it hard (if possible at all) to mark the currently selected menu item/group for non-Page content (home page, category pages etc.), i.e. for menus defined in the site configuration.

This commit provides an implementation of these two methods.

Notable design choices:

* These menu items have a loose coupling to the the resources they navigate to; the `Url` is the best common identificator. To facilitate a consistent matching, and to get it in line with the menu items connected to `Page`, relative Urls (Urls starting with '/') for menu items in the site configuration are converted to permaLinks using the same rules used for others’.
* `IsMenuCurrent` only looks at the children of the current node; this is in line with the implementation on `Page`.
* Due to this loose coupling, `IsMenuCurrent` have to search downards in the tree to make sure that the node is inside the current menu. This could have been made simpler if it could answer `yes` to any match of any menu item matching the current resource.

This commit also adds a set of unit tests for the menu system.

Fixes #367
hugolib/menu.go
hugolib/menu_test.go [new file with mode: 0644]
hugolib/node.go
hugolib/site.go