Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
iv
gitlab-ce
Commits
3f156ed4
Commit
3f156ed4
authored
May 29, 2015
by
Robert Speicher
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve MergeRequest tab-persisting behavior
Now uses the path instead of the hash. See discussion in #728.
parent
f46b3670
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
56 additions
and
35 deletions
+56
-35
app/assets/javascripts/merge_request.js.coffee
app/assets/javascripts/merge_request.js.coffee
+50
-29
app/views/projects/merge_requests/_new_submit.html.haml
app/views/projects/merge_requests/_new_submit.html.haml
+3
-3
app/views/projects/merge_requests/_show.html.haml
app/views/projects/merge_requests/_show.html.haml
+3
-3
No files found.
app/assets/javascripts/merge_request.js.coffee
View file @
3f156ed4
...
@@ -26,7 +26,7 @@ class @MergeRequest
...
@@ -26,7 +26,7 @@ class @MergeRequest
@
commits_loaded
=
@
opts
.
commits_loaded
or
false
@
commits_loaded
=
@
opts
.
commits_loaded
or
false
this
.
bindEvents
()
this
.
bindEvents
()
this
.
activateTabFrom
Has
h
()
this
.
activateTabFrom
Pat
h
()
this
.
initMergeWidget
()
this
.
initMergeWidget
()
this
.
$
(
'.show-all-commits'
).
on
'click'
,
=>
this
.
$
(
'.show-all-commits'
).
on
'click'
,
=>
...
@@ -82,19 +82,16 @@ class @MergeRequest
...
@@ -82,19 +82,16 @@ class @MergeRequest
bindEvents
:
->
bindEvents
:
->
this
.
$
(
'.merge-request-tabs a[data-toggle="tab"]'
).
on
'shown.bs.tab'
,
(
e
)
=>
this
.
$
(
'.merge-request-tabs a[data-toggle="tab"]'
).
on
'shown.bs.tab'
,
(
e
)
=>
$target
=
$
(
e
.
target
)
$target
=
$
(
e
.
target
)
tab_action
=
$target
.
data
(
'action'
)
# Nothing else to be done if we're on the first tab
return
if
$target
.
data
(
'action'
)
==
'notes'
# Persist current tab selection via URL
href
=
$target
.
attr
(
'href'
)
if
href
.
substr
(
0
,
1
)
==
'#'
location
.
replace
(
"#!
#{
href
.
substr
(
1
)
}
"
)
# Lazy-load diffs
# Lazy-load diffs
if
$target
.
data
(
'action'
)
==
'diffs'
if
tab_action
==
'diffs'
this
.
loadDiff
()
unless
@
diffs_loaded
this
.
loadDiff
()
unless
@
diffs_loaded
$
(
'.diff-header'
).
trigger
(
"sticky_kit:recalc"
)
$
(
'.diff-header'
).
trigger
(
'sticky_kit:recalc'
)
# Skip tab-persisting behavior on MergeRequests#new
unless
@
opts
.
action
==
'new'
@
setCurrentAction
(
tab_action
)
this
.
$
(
'.accept_merge_request'
).
on
'click'
,
->
this
.
$
(
'.accept_merge_request'
).
on
'click'
,
->
$
(
'.automerge_widget.can_be_merged'
).
hide
()
$
(
'.automerge_widget.can_be_merged'
).
hide
()
...
@@ -112,27 +109,51 @@ class @MergeRequest
...
@@ -112,27 +109,51 @@ class @MergeRequest
this
.
$
(
'.remove_source_branch_in_progress'
).
hide
()
this
.
$
(
'.remove_source_branch_in_progress'
).
hide
()
this
.
$
(
'.remove_source_branch_widget.failed'
).
show
()
this
.
$
(
'.remove_source_branch_widget.failed'
).
show
()
# Activate
s a tab section based on the `#!` URL has
h
# Activate
a tab based on the current URL pat
h
#
#
# If no hash value is present (i.e., on the initial page load), the first tab
# If the current action is 'show' or 'new' (i.e., initial page load),
# is selected by default.
# activates the first tab, otherwise activates the tab corresponding to the
# current action (diffs, commits).
activateTabFromPath
:
->
if
@
opts
.
action
==
'show'
||
@
opts
.
action
==
'new'
this
.
$
(
'.merge-request-tabs a[data-toggle="tab"]:first'
).
tab
(
'show'
)
else
this
.
$
(
".merge-request-tabs a[data-action='
#{
@
opts
.
action
}
']"
).
tab
(
'show'
)
# Replaces the current Merge Request-specific action in the URL with a new one
#
#
#
... unless the current controller action is `diffs`, in which case that tab
#
If the action is "notes", the URL is reset to the standard
#
is selected instead. Fun, right?
#
`MergeRequests#show` route.
#
#
#
Note: We use a `#!` instead of a standard URL hash for two reason
s:
#
Example
s:
#
#
# 1. Prevents the hash acting like an anchor and scrolling the page.
# location.pathname # => "/namespace/project/merge_requests/1"
# 2. Prevents mutating browser history.
# setCurrentAction('diffs')
activateTabFromHash
:
->
# location.pathname # => "/namespace/project/merge_requests/1/diffs"
# Correct the hash if we came here directly via the `/diffs` path
#
if
location
.
hash
==
''
and
@
opts
.
action
==
'diffs'
# location.pathname # => "/namespace/project/merge_requests/1/diffs"
location
.
replace
(
'#!diffs'
)
# setCurrentAction('notes')
# location.pathname # => "/namespace/project/merge_requests/1"
if
location
.
hash
==
''
#
this
.
$
(
'.merge-request-tabs a[data-toggle="tab"]:first'
).
tab
(
'show'
)
# location.pathname # => "/namespace/project/merge_requests/1/diffs"
else
if
location
.
hash
.
substr
(
0
,
2
)
==
'#!'
# setCurrentAction('commits')
this
.
$
(
".merge-request-tabs a[href='#
#{
location
.
hash
.
substr
(
2
)
}
']"
).
tab
(
"show"
)
# location.pathname # => "/namespace/project/merge_requests/1/commits"
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)\/?$/
,
''
)
# Append the new action if we're on a tab other than 'notes'
unless
action
==
'notes'
new_state
+=
"/
#{
action
}
"
# Replace the current history state with the new one without breaking
# Turbolinks' history.
#
# See https://github.com/rails/turbolinks/issues/363
history
.
replaceState
{
turbolinks
:
true
,
url
:
new_state
},
''
,
new_state
showState
:
(
state
)
->
showState
:
(
state
)
->
$
(
'.automerge_widget'
).
hide
()
$
(
'.automerge_widget'
).
hide
()
...
@@ -161,7 +182,7 @@ class @MergeRequest
...
@@ -161,7 +182,7 @@ class @MergeRequest
loadDiff
:
(
event
)
->
loadDiff
:
(
event
)
->
$
.
ajax
$
.
ajax
type
:
'GET'
type
:
'GET'
url
:
this
.
$
(
'.merge-request-tabs .diffs-tab a'
).
data
(
'source
'
)
+
".json"
url
:
this
.
$
(
'.merge-request-tabs .diffs-tab a'
).
attr
(
'href
'
)
+
".json"
beforeSend
:
=>
beforeSend
:
=>
this
.
$
(
'.mr-loading-status .loading'
).
show
()
this
.
$
(
'.mr-loading-status .loading'
).
show
()
complete
:
=>
complete
:
=>
...
...
app/views/projects/merge_requests/_new_submit.html.haml
View file @
3f156ed4
...
@@ -20,12 +20,12 @@
...
@@ -20,12 +20,12 @@
.mr-compare.merge-request
.mr-compare.merge-request
%ul
.nav.nav-tabs.merge-request-tabs
%ul
.nav.nav-tabs.merge-request-tabs
%li
.commits-tab
%li
.commits-tab
=
link_to
'#commits'
,
data:
{
action:
'commits'
,
toggle:
'tab'
}
do
=
link_to
url_for
(
params
),
data:
{
target:
'#commits'
,
action:
'commits'
,
toggle:
'tab'
}
do
=
icon
(
'history'
)
=
icon
(
'history'
)
Commits
Commits
%span
.badge
=
@commits
.
size
%span
.badge
=
@commits
.
size
%li
.diffs-tab
%li
.diffs-tab
=
link_to
'#diffs'
,
data:
{
action:
'diffs'
,
toggle:
'tab'
}
do
=
link_to
url_for
(
params
),
data:
{
target:
'#diffs'
,
action:
'diffs'
,
toggle:
'tab'
}
do
=
icon
(
'list-alt'
)
=
icon
(
'list-alt'
)
Changes
Changes
%span
.badge
=
@diffs
.
size
%span
.badge
=
@diffs
.
size
...
@@ -56,7 +56,7 @@
...
@@ -56,7 +56,7 @@
:javascript
:javascript
var
merge_request
var
merge_request
merge_request
=
new
MergeRequest
({
merge_request
=
new
MergeRequest
({
action
:
'
diffs
'
,
action
:
'
new
'
,
diffs_loaded
:
true
,
diffs_loaded
:
true
,
commits_loaded
:
true
commits_loaded
:
true
});
});
...
...
app/views/projects/merge_requests/_show.html.haml
View file @
3f156ed4
...
@@ -38,17 +38,17 @@
...
@@ -38,17 +38,17 @@
-
if
@commits
.
present?
-
if
@commits
.
present?
%ul
.nav.nav-tabs.merge-request-tabs
%ul
.nav.nav-tabs.merge-request-tabs
%li
.notes-tab
%li
.notes-tab
=
link_to
'#notes'
,
data:
{
action:
'notes'
,
toggle:
'tab'
}
do
=
link_to
namespace_project_merge_request_path
(
@project
.
namespace
,
@project
,
@merge_request
),
data:
{
target:
'#notes'
,
action:
'notes'
,
toggle:
'tab'
}
do
=
icon
(
'comments'
)
=
icon
(
'comments'
)
Discussion
Discussion
%span
.badge
=
@merge_request
.
mr_and_commit_notes
.
user
.
count
%span
.badge
=
@merge_request
.
mr_and_commit_notes
.
user
.
count
%li
.commits-tab
%li
.commits-tab
=
link_to
'#commits'
,
data:
{
action:
'commits'
,
toggle:
'tab'
}
do
=
link_to
commits_namespace_project_merge_request_path
(
@project
.
namespace
,
@project
,
@merge_request
),
data:
{
target:
'#commits'
,
action:
'commits'
,
toggle:
'tab'
}
do
=
icon
(
'history'
)
=
icon
(
'history'
)
Commits
Commits
%span
.badge
=
@commits
.
size
%span
.badge
=
@commits
.
size
%li
.diffs-tab
%li
.diffs-tab
=
link_to
'#diffs'
,
data:
{
source:
diffs_namespace_project_merge_request_path
(
@project
.
namespace
,
@project
,
@merge_request
)
,
action:
'diffs'
,
toggle:
'tab'
}
do
=
link_to
diffs_namespace_project_merge_request_path
(
@project
.
namespace
,
@project
,
@merge_request
),
data:
{
target:
'#diffs'
,
action:
'diffs'
,
toggle:
'tab'
}
do
=
icon
(
'list-alt'
)
=
icon
(
'list-alt'
)
Changes
Changes
%span
.badge
=
@merge_request
.
diffs
.
size
%span
.badge
=
@merge_request
.
diffs
.
size
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment