BigW Consortium Gitlab
Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
gitlab-ce
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Forest Godfrey
gitlab-ce
Commits
3d89a03e
Unverified
Commit
3d89a03e
authored
Feb 01, 2018
by
Filipa Lacerda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Moves widget header into a vue file
parent
1533cf10
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
154 additions
and
114 deletions
+154
-114
mr_widget_header.vue
.../vue_merge_request_widget/components/mr_widget_header.vue
+128
-106
mr_widget_merge_help.vue
..._merge_request_widget/components/mr_widget_merge_help.vue
+2
-2
dependencies.js
...sets/javascripts/vue_merge_request_widget/dependencies.js
+1
-1
mr_widget_header_spec.js
...scripts/vue_mr_widget/components/mr_widget_header_spec.js
+0
-0
mr_widget_merge_help_spec.js
...pts/vue_mr_widget/components/mr_widget_merge_help_spec.js
+23
-5
No files found.
app/assets/javascripts/vue_merge_request_widget/components/mr_widget_header.
js
→
app/assets/javascripts/vue_merge_request_widget/components/mr_widget_header.
vue
View file @
3d89a03e
import
tooltip
from
'../../vue_shared/directives/tooltip'
;
import
{
pluralize
}
from
'../../lib/utils/text_utility'
;
import
icon
from
'../../vue_shared/components/icon.vue'
;
<
script
>
import
tooltip
from
'~/vue_shared/directives/tooltip'
;
import
{
n__
}
from
'~/locale'
;
import
icon
from
'~/vue_shared/components/icon.vue'
;
import
clipboardButton
from
'~/vue_shared/components/clipboard_button.vue'
;
export
default
{
name
:
'MRWidgetHeader'
,
props
:
{
mr
:
{
type
:
Object
,
required
:
true
},
},
directives
:
{
tooltip
,
},
components
:
{
icon
,
},
computed
:
{
shouldShowCommitsBehindText
()
{
return
this
.
mr
.
divergedCommitsCount
>
0
;
export
default
{
name
:
'MRWidgetHeader'
,
directives
:
{
tooltip
,
},
commitsText
()
{
return
pluralize
(
'commit'
,
this
.
mr
.
divergedCommitsCount
);
components
:
{
icon
,
clipboardButton
,
},
branchNameClipboardData
()
{
// This supports code in app/assets/javascripts/copy_to_clipboard.js that
// works around ClipboardJS limitations to allow the context-specific
// copy/pasting of plain text or GFM.
return
JSON
.
stringify
({
text
:
this
.
mr
.
sourceBranch
,
gfm
:
`\`
${
this
.
mr
.
sourceBranch
}
\``
,
});
props
:
{
mr
:
{
type
:
Object
,
required
:
true
,
},
},
},
methods
:
{
isBranchTitleLong
(
branchTitle
)
{
return
branchTitle
.
length
>
32
;
computed
:
{
shouldShowCommitsBehindText
()
{
return
this
.
mr
.
divergedCommitsCount
>
0
;
},
commitsText
()
{
return
n__
(
'commit behind'
,
'commits behind'
,
this
.
mr
.
divergedCommitsCount
);
},
branchNameClipboardData
()
{
// This supports code in app/assets/javascripts/copy_to_clipboard.js that
// works around ClipboardJS limitations to allow the context-specific
// copy/pasting of plain text or GFM.
return
JSON
.
stringify
({
text
:
this
.
mr
.
sourceBranch
,
gfm
:
`\`
${
this
.
mr
.
sourceBranch
}
\``
,
});
},
},
},
template
:
`
<div class="mr-source-target">
<div class="normal">
<strong>
Request to merge
<span
class="label-branch"
:class="{'label-truncated': isBranchTitleLong(mr.sourceBranch)}"
:title="isBranchTitleLong(mr.sourceBranch) ? mr.sourceBranch : ''"
data-placement="bottom"
:v-tooltip="isBranchTitleLong(mr.sourceBranch)"
v-html="mr.sourceBranchLink"></span>
<button
v-tooltip
class="btn btn-transparent btn-clipboard"
data-title="Copy branch name to clipboard"
:data-clipboard-text="branchNameClipboardData">
<i
aria-hidden="true"
class="fa fa-clipboard"></i>
</button>
into
<span
class="label-branch"
:v-tooltip="isBranchTitleLong(mr.sourceBranch)"
:class="{'label-truncatedtooltip': isBranchTitleLong(mr.targetBranch)}"
:title="isBranchTitleLong(mr.targetBranch) ? mr.targetBranch : ''"
data-placement="bottom">
<a :href="mr.targetBranchTreePath">{{mr.targetBranch}}</a>
</span>
</strong>
methods
:
{
isBranchTitleLong
(
branchTitle
)
{
return
branchTitle
.
length
>
32
;
},
},
};
</
script
>
<
template
>
<div
class=
"mr-source-target"
>
<div
class=
"normal"
>
<strong>
{{
s__
(
"mrWidget|Request to merge"
)
}}
<span
v-if="shouldShowCommitsBehindText"
class="diverged-commits-count">
(<a :href="mr.targetBranchPath">{{mr.divergedCommitsCount}} {{commitsText}} behind</a>)
class=
"label-branch js-source-branch"
:class=
"
{ 'label-truncated': isBranchTitleLong(mr.sourceBranch) }"
:title="isBranchTitleLong(mr.sourceBranch) ? mr.sourceBranch : ''"
data-placement="bottom"
:v-tooltip="isBranchTitleLong(mr.sourceBranch)"
v-html="mr.sourceBranchLink"
>
</span>
</div>
<div v-if="mr.isOpen">
<a
href="#modal_merge_info"
data-toggle="modal"
:disabled="mr.sourceBranchRemoved"
class="btn btn-sm inline">
Check out branch
</a>
<span class="dropdown prepend-left-10">
<clipboardButton
:text=
"branchNameClipboardData"
:title=
"__('Copy branch name to clipboard')"
/>
{{
s__
(
"mrWidget|into"
)
}}
<span
class=
"label-branch"
:v-tooltip=
"isBranchTitleLong(mr.sourceBranch)"
:class=
"
{ 'label-truncatedtooltip': isBranchTitleLong(mr.targetBranch) }"
:title="isBranchTitleLong(mr.targetBranch) ? mr.targetBranch : ''"
data-placement="bottom"
>
<a
class="btn btn-sm inline dropdown-toggle"
data-toggle="dropdown"
aria-label="Download as"
role="button">
<icon
name="download">
</icon>
<i
class="fa fa-caret-down"
aria-hidden="true">
</i>
:href=
"mr.targetBranchTreePath"
class=
"js-target-branch"
>
{{
mr
.
targetBranch
}}
</a>
<ul class="dropdown-menu dropdown-menu-align-right">
<li>
<a
:href="mr.emailPatchesPath"
download>
Email patches
</a>
</li>
<li>
<a
:href="mr.plainDiffPath"
download>
Plain diff
</a>
</li>
</ul>
</span>
</div>
</strong>
<span
v-if=
"shouldShowCommitsBehindText"
class=
"diverged-commits-count"
>
(
<a
:href=
"mr.targetBranchPath"
>
{{
mr
.
divergedCommitsCount
}}
{{
commitsText
}}
</a>
)
</span>
</div>
<div
v-if=
"mr.isOpen"
>
<button
data-target=
"#modal_merge_info"
data-toggle=
"modal"
:disabled=
"mr.sourceBranchRemoved"
class=
"btn btn-sm inline js-check-out-branch"
type=
"button"
>
{{
s__
(
"mrWidget|Check out branch"
)
}}
</button>
<span
class=
"dropdown prepend-left-10"
>
<button
type=
"button"
class=
"btn btn-sm inline dropdown-toggle"
data-toggle=
"dropdown"
aria-label=
"Download as"
aria-haspopup=
"true"
aria-expanded=
"false"
>
<icon
name=
"download"
/>
<i
class=
"fa fa-caret-down"
aria-hidden=
"true"
>
</i>
</button>
<ul
class=
"dropdown-menu dropdown-menu-align-right"
>
<li>
<a
class=
"js-download-email-patches"
:href=
"mr.emailPatchesPath"
download
>
{{
s__
(
"mrWidget|Email patches"
)
}}
</a>
</li>
<li>
<a
class=
"js-download-plain-diff"
:href=
"mr.plainDiffPath"
download
>
{{
s__
(
"mrWidget|Plain diff"
)
}}
</a>
</li>
</ul>
</span>
</div>
`
,
};
</div>
</
template
>
app/assets/javascripts/vue_merge_request_widget/components/mr_widget_merge_help.vue
View file @
3d89a03e
...
...
@@ -7,14 +7,14 @@
missingBranch
:
{
type
:
String
,
required
:
false
,
default
:
''
default
:
''
,
},
},
computed
:
{
missingBranchInfo
()
{
return
sprintf
(
s__
(
'mrWidget|If the %{branch} branch exists in your local repository, you can merge this merge request manually using the'
),
{
branch
:
this
.
missingBranch
}
{
branch
:
this
.
missingBranch
}
,
);
},
},
...
...
app/assets/javascripts/vue_merge_request_widget/dependencies.js
View file @
3d89a03e
...
...
@@ -11,7 +11,7 @@
export
{
default
as
Vue
}
from
'vue'
;
export
{
default
as
SmartInterval
}
from
'~/smart_interval'
;
export
{
default
as
WidgetHeader
}
from
'./components/mr_widget_header'
;
export
{
default
as
WidgetHeader
}
from
'./components/mr_widget_header
.vue
'
;
export
{
default
as
WidgetMergeHelp
}
from
'./components/mr_widget_merge_help.vue'
;
export
{
default
as
WidgetPipeline
}
from
'./components/mr_widget_pipeline.vue'
;
export
{
default
as
WidgetDeployment
}
from
'./components/mr_widget_deployment'
;
...
...
spec/javascripts/vue_mr_widget/components/mr_widget_header_spec.js
View file @
3d89a03e
This diff is collapsed.
Click to expand it.
spec/javascripts/vue_mr_widget/components/mr_widget_merge_help_spec.js
View file @
3d89a03e
...
...
@@ -2,9 +2,6 @@ import Vue from 'vue';
import
mergeHelpComponent
from
'~/vue_merge_request_widget/components/mr_widget_merge_help.vue'
;
import
mountComponent
from
'../../helpers/vue_mount_component_helper'
;
const
text
=
`If the
${
props
.
missingBranch
}
branch exists in your local repository`
;
describe
(
'MRWidgetMergeHelp'
,
()
=>
{
let
vm
;
let
Component
;
...
...
@@ -17,7 +14,7 @@ describe('MRWidgetMergeHelp', () => {
vm
.
$destroy
();
});
f
describe
(
'with missing branch'
,
()
=>
{
describe
(
'with missing branch'
,
()
=>
{
beforeEach
(()
=>
{
vm
=
mountComponent
(
Component
,
{
missingBranch
:
'this-is-not-the-branch-you-are-looking-for'
,
...
...
@@ -25,8 +22,16 @@ describe('MRWidgetMergeHelp', () => {
});
it
(
'renders missing branch information'
,
()
=>
{
console
.
log
(
''
,
vm
.
$el
);
expect
(
vm
.
$el
.
textContent
.
trim
().
replace
(
/
[\r\n]
+/g
,
' '
).
replace
(
/
\s\s
+/g
,
' '
),
).
toEqual
(
'If the this-is-not-the-branch-you-are-looking-for branch exists in your local repository, you can merge this merge request manually using the command line'
,
);
});
it
(
'renders element to open a modal'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'a'
).
getAttribute
(
'href'
)).
toEqual
(
'#modal_merge_info'
);
expect
(
vm
.
$el
.
querySelector
(
'a'
).
getAttribute
(
'data-toggle'
)).
toEqual
(
'modal'
);
});
});
...
...
@@ -34,5 +39,18 @@ describe('MRWidgetMergeHelp', () => {
beforeEach
(()
=>
{
vm
=
mountComponent
(
Component
);
});
it
(
'renders information about how to merge manually'
,
()
=>
{
expect
(
vm
.
$el
.
textContent
.
trim
().
replace
(
/
[\r\n]
+/g
,
' '
).
replace
(
/
\s\s
+/g
,
' '
),
).
toEqual
(
'You can merge this merge request manually using the command line'
,
);
});
it
(
'renders element to open a modal'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'a'
).
getAttribute
(
'href'
)).
toEqual
(
'#modal_merge_info'
);
expect
(
vm
.
$el
.
querySelector
(
'a'
).
getAttribute
(
'data-toggle'
)).
toEqual
(
'modal'
);
});
});
});
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