Files
nairobi/app/assets/javascripts/tree_navigator.js.coffee
Javi Martín 86e704d8a4 Use strict mode in JavaScript
Strict mode is supported by 98% of the browsers, including Internet
Explorer 10, and it helps developers avoid common JavaScript pitfalls.
2019-09-11 03:14:17 +02:00

35 lines
1006 B
CoffeeScript

"use strict"
App.TreeNavigator =
setNodes: (nodes) ->
children = nodes.children("ul")
children.each ->
link = $(this).prev("a")
$('<span class="open"></span>').insertBefore(link)
App.TreeNavigator.setNodes($(this).children())
initialize: ->
elem = $("[data-tree-navigator]")
if(elem.length == 0)
return
ul = elem.find("ul:eq(0)")
if(ul.length && ul.children().length)
App.TreeNavigator.setNodes(ul.children())
$("[data-tree-navigator] span").on
click: ->
elem = $(this)
if(elem.hasClass("open"))
elem.removeClass("open").addClass("closed")
elem.siblings("ul").hide()
else if(elem.hasClass("closed"))
elem.removeClass("closed").addClass("open")
elem.siblings("ul").show()
if anchor = $(location).attr("hash")
elem.find("a[href='#{anchor}']").parents("ul").each ->
$(this).show()
$(this).siblings("span").removeClass("closed").addClass("open")