diff options
| author | Robert Speicher <rspeicher@gmail.com> | 2015-06-21 19:01:13 -0400 |
|---|---|---|
| committer | Robert Speicher <rspeicher@gmail.com> | 2015-06-21 22:57:32 -0400 |
| commit | e17020b9079d6e4f349a1a01e5d43393b6b49f18 (patch) | |
| tree | e27378043d71f2eaf3c3dd64fdd5f829a2b91d9b /app | |
| parent | 8e72c65cda2f8eeda5ffd33965cbf1b19e6bf944 (diff) | |
| download | gitlab-ce-e17020b9079d6e4f349a1a01e5d43393b6b49f18.tar.gz | |
Add MergeRequestTabs specsrs-dev-issue-2355
Diffstat (limited to 'app')
| -rw-r--r-- | app/assets/javascripts/merge_request_tabs.js.coffee | 133 |
1 files changed, 89 insertions, 44 deletions
diff --git a/app/assets/javascripts/merge_request_tabs.js.coffee b/app/assets/javascripts/merge_request_tabs.js.coffee index 4daace89771..de9a4c2cc2f 100644 --- a/app/assets/javascripts/merge_request_tabs.js.coffee +++ b/app/assets/javascripts/merge_request_tabs.js.coffee @@ -1,42 +1,79 @@ +# MergeRequestTabs +# +# Handles persisting and restoring the current tab selection and lazily-loading +# content on the MergeRequests#show page. +# +# ### Example Markup +# +# <ul class="nav nav-tabs merge-request-tabs"> +# <li class="notes-tab active"> +# <a data-action="notes" data-target="#notes" data-toggle="tab" href="/foo/bar/merge_requests/1"> +# Discussion +# </a> +# </li> +# <li class="commits-tab"> +# <a data-action="commits" data-target="#commits" data-toggle="tab" href="/foo/bar/merge_requests/1/commits"> +# Commits +# </a> +# </li> +# <li class="diffs-tab"> +# <a data-action="diffs" data-target="#diffs" data-toggle="tab" href="/foo/bar/merge_requests/1/diffs"> +# Diffs +# </a> +# </li> +# </ul> +# +# <div class="tab-content"> +# <div class="notes tab-pane active" id="notes"> +# Notes Content +# </div> +# <div class="commits tab-pane" id="commits"> +# Commits Content +# </div> +# <div class="diffs tab-pane" id="diffs"> +# Diffs Content +# </div> +# </div> +# +# <div class="mr-loading-status"> +# <div class="loading"> +# Loading Animation +# </div> +# </div> +# class @MergeRequestTabs diffsLoaded: false commitsLoaded: false - constructor: (@opts) -> + constructor: (@opts = {}) -> + # Store the `location` object, allowing for easier stubbing in tests + @_location = location + @bindEvents() - @activateTabFromPath() + @activateTab(@opts.action) switch @opts.action when 'commits' then @commitsLoaded = true when 'diffs' then @diffsLoaded = true bindEvents: -> - $(document).on 'shown.bs.tab', '.merge-request-tabs a[data-toggle="tab"]', @tabShow + $(document).on 'shown.bs.tab', '.merge-request-tabs a[data-toggle="tab"]', @tabShown - tabShow: (event) => + tabShown: (event) => $target = $(event.target) action = $target.data('action') - # Lazy-load commits - if action == 'commits' && !@commitsLoaded - @loadCommits() - - # Lazy-load diffs - if action == 'diffs' && !@diffsLoaded - @loadDiff() + if action == 'commits' + @loadCommits($target.attr('href')) + else if action == 'diffs' + @loadDiff($target.attr('href')) @setCurrentAction(action) - # Activate a tab based on the current URL path - # - # If the current action is 'show' or 'new' (i.e., initial page load), - # activates the first tab, otherwise activates the tab corresponding to the - # current action (diffs, commits). - activateTabFromPath: -> - if @opts.action == 'show' || @opts.action == 'new' - $('.merge-request-tabs a[data-toggle="tab"]:first').tab('show') - else - $(".merge-request-tabs a[data-action='#{@opts.action}']").tab('show') + # Activate a tab based on the current action + activateTab: (action) -> + action = 'notes' if action == 'show' + $(".merge-request-tabs a[data-action='#{action}']").tab('show') # Replaces the current Merge Request-specific action in the URL with a new one # @@ -56,19 +93,21 @@ class @MergeRequestTabs # location.pathname # => "/namespace/project/merge_requests/1/diffs" # setCurrentAction('commits') # location.pathname # => "/namespace/project/merge_requests/1/commits" - setCurrentAction: (action) -> + # + # Returns the new URL String + setCurrentAction: (action) => # Normalize action, just to be safe action = 'notes' if action == 'show' # Remove a trailing '/commits' or '/diffs' - new_state = location.pathname.replace(/\/(commits|diffs)\/?$/, '') + new_state = @_location.pathname.replace(/\/(commits|diffs)\/?$/, '') # Append the new action if we're on a tab other than 'notes' unless action == 'notes' new_state += "/#{action}" # Ensure parameters and hash come along for the ride - new_state += location.search + location.hash + new_state += @_location.search + @_location.hash # Replace the current history state with the new one without breaking # Turbolinks' history. @@ -76,33 +115,39 @@ class @MergeRequestTabs # See https://github.com/rails/turbolinks/issues/363 history.replaceState {turbolinks: true, url: new_state}, document.title, new_state - loadCommits: -> - $.ajax - type: 'GET' - dataType: 'json' - url: $('.merge-request-tabs .commits-tab a').attr('href') + ".json" - beforeSend: @toggleLoading - complete: => - @commits_loaded = true - @toggleLoading() + new_state + + loadCommits: (source) -> + return if @commitsLoaded + + @_get + url: "#{source}.json" success: (data) => document.getElementById('commits').innerHTML = data.html - $('.js-timeago').timeago() + @commitsLoaded = true - loadDiff: -> - $.ajax - type: 'GET' - dataType: 'json' - url: $('.merge-request-tabs .diffs-tab a').attr('href') + ".json" - beforeSend: => @toggleLoading() - complete: => - @diffs_loaded = true - @toggleLoading() + loadDiff: (source) -> + return if @diffsLoaded + + @_get + url: "#{source}.json" success: (data) => document.getElementById('diffs').innerHTML = data.html - $('.diff-header').trigger('sticky_kit:recalc') + @diffsLoaded = true toggleLoading: -> $('.mr-loading-status .loading').toggle() + + _get: (options) -> + defaults = { + beforeSend: @toggleLoading + complete: @toggleLoading + dataType: 'json' + type: 'GET' + } + + options = $.extend({}, defaults, options) + + $.ajax(options) |
