summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/right_sidebar.js.coffee
blob: 6740355434001055512d4fb8d85c84c95b3cdea7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
class @Sidebar
  constructor: (currentUser) ->
    @addEventListeners()

  addEventListeners: ->
    $('aside').on('click', '.sidebar-collapsed-icon', @sidebarCollapseClicked)
    $('.dropdown').on('hidden.gl.dropdown', @sidebarDropdownHidden)
    $('.dropdown').on('loading.gl.dropdown', @sidebarDropdownLoading)
    $('.dropdown').on('loaded.gl.dropdown', @sidebarDropdownLoaded)

  sidebarDropdownLoading: (e) ->
    $sidebarCollapsedIcon = $(@).closest('.block').find('.sidebar-collapsed-icon')
    img = $sidebarCollapsedIcon.find('img')
    i = $sidebarCollapsedIcon.find('i')
    $loading = $('<i class="fa fa-spinner fa-spin"></i>')
    if img.length
      img.before($loading)
      img.hide()
    else if i.length
      i.before($loading)
      i.hide()

  sidebarDropdownLoaded: (e) ->
    $sidebarCollapsedIcon = $(@).closest('.block').find('.sidebar-collapsed-icon')
    img = $sidebarCollapsedIcon.find('img')
    $sidebarCollapsedIcon.find('i.fa-spin').remove()
    i = $sidebarCollapsedIcon.find('i')
    if img.length
      img.show()
    else
      i.show()


  sidebarCollapseClicked: (e) ->
    e.preventDefault()
    $block = $(@).closest('.block')

    $('aside')
      .find('.gutter-toggle')
      .trigger('click')
    $editLink = $block.find('.edit-link')

    if $editLink.length
      $editLink.trigger('click')
      $block.addClass('collapse-after-update')
      $('.page-with-sidebar').addClass('with-overlay')

  sidebarDropdownHidden: (e) ->
    $block = $(@).closest('.block')
    if $block.hasClass('collapse-after-update')
      $block.removeClass('collapse-after-update')
      $('.page-with-sidebar').removeClass('with-overlay')
      $('aside')
        .find('.gutter-toggle')
        .trigger('click')