Commit bfb5ebd6 authored by Bryce Johnson's avatar Bryce Johnson

Use help_page_path to generate correct time tracking docs url.

parent 28412f81
//= require lib/utils/pretty_time //= require lib/utils/pretty_time
((app) => { (() => {
const PrettyTime = gl.PrettyTime; const PrettyTime = gl.PrettyTime;
app.collapsedState = { gl.IssuableTimeTrackingApp.collapsedState = {
name: 'time-tracking-collapsed-state', name: 'time-tracking-collapsed-state',
props: [ props: [
'showComparisonState', 'showComparisonState',
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
'showNoTimeTrackingState', 'showNoTimeTrackingState',
'timeSpentHuman', 'timeSpentHuman',
'timeEstimateHuman', 'timeEstimateHuman',
'stopwatchSvg' 'stopwatchSvg',
], ],
methods: { methods: {
abbreviateTime(timeStr) { abbreviateTime(timeStr) {
......
//= require lib/utils/pretty_time //= require lib/utils/pretty_time
((app) => { (() => {
const PrettyTime = gl.PrettyTime; const PrettyTime = gl.PrettyTime;
app.comparisonPane = { gl.IssuableTimeTrackingApp.comparisonPane = {
name: 'time-tracking-comparison-pane', name: 'time-tracking-comparison-pane',
props: [ props: [
'timeSpent', 'timeSpent',
'timeEstimate', 'timeEstimate',
'timeSpentHuman', 'timeSpentHuman',
'timeEstimateHuman' 'timeEstimateHuman',
], ],
computed: { computed: {
parsedRemaining() { parsedRemaining() {
......
((app) => { (() => {
app.estimateOnlyPane = { gl.IssuableTimeTrackingApp.estimateOnlyPane = {
name: 'time-tracking-estimate-only-pane', name: 'time-tracking-estimate-only-pane',
props: ['timeEstimateHuman'], props: ['timeEstimateHuman'],
template: ` template: `
......
((app) => { (() => {
app.helpState = { gl.IssuableTimeTrackingApp.helpState = {
name: 'time-tracking-help-state', name: 'time-tracking-help-state',
data() { props: ['docsUrl'],
return {
docsUrl: '/help/workflow/time_tracking.md',
};
},
template: ` template: `
<div class='time-tracking-help-state'> <div class='time-tracking-help-state'>
<div class='time-tracking-info'> <div class='time-tracking-info'>
......
((app) => { (() => {
app.noTrackingPane = { gl.IssuableTimeTrackingApp.noTrackingPane = {
name: 'time-tracking-no-tracking-pane', name: 'time-tracking-no-tracking-pane',
template: ` template: `
<div class='time-tracking-no-tracking-pane'> <div class='time-tracking-no-tracking-pane'>
......
((app) => { (() => {
app.spentOnlyPane = { gl.IssuableTimeTrackingApp.spentOnlyPane = {
name: 'time-tracking-spent-only-pane', name: 'time-tracking-spent-only-pane',
props: ['timeSpentHuman'], props: ['timeSpentHuman'],
template: ` template: `
......
((app) => { (() => {
const app = gl.IssuableTimeTrackingApp;
gl.IssuableTimeTracker = Vue.component('issuable-time-tracker', { gl.IssuableTimeTracker = Vue.component('issuable-time-tracker', {
name: 'issuable-time-tracker', name: 'issuable-time-tracker',
props: [ props: [
...@@ -6,7 +7,8 @@ ...@@ -6,7 +7,8 @@
'time_spent', 'time_spent',
'human_time_estimate', 'human_time_estimate',
'human_time_spent', 'human_time_spent',
'stopwatchSvg' 'stopwatchSvg',
'docsUrl',
], ],
data() { data() {
return { return {
...@@ -98,7 +100,8 @@ ...@@ -98,7 +100,8 @@
</time-tracking-comparison-pane> </time-tracking-comparison-pane>
<transition name='help-state-toggle'> <transition name='help-state-toggle'>
<time-tracking-help-state <time-tracking-help-state
v-if='showHelpState'> v-if='showHelpState'
:docs-url='docsUrl'>
</time-tracking-help-state> </time-tracking-help-state>
</transition> </transition>
</div> </div>
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
//= require smart_interval //= require smart_interval
//= require subbable_resource //= require subbable_resource
((gl) => { (() => {
/* This Vue instance represents what will become the parent instance for the /* This Vue instance represents what will become the parent instance for the
* sidebar. It will be responsible for managing `issuable` state and propagating * sidebar. It will be responsible for managing `issuable` state and propagating
* changes to sidebar components. * changes to sidebar components.
......
...@@ -76,7 +76,7 @@ ...@@ -76,7 +76,7 @@
= dropdown_tag('Milestone', options: { title: 'Assign milestone', toggle_class: 'js-milestone-select js-extra-options', filter: true, dropdown_class: 'dropdown-menu-selectable', placeholder: 'Search milestones', data: { show_no: true, field_name: "#{issuable.to_ability_name}[milestone_id]", project_id: @project.id, issuable_id: issuable.id, milestones: namespace_project_milestones_path(@project.namespace, @project, :json), ability_name: issuable.to_ability_name, issue_update: issuable_json_path(issuable), use_id: true }}) = dropdown_tag('Milestone', options: { title: 'Assign milestone', toggle_class: 'js-milestone-select js-extra-options', filter: true, dropdown_class: 'dropdown-menu-selectable', placeholder: 'Search milestones', data: { show_no: true, field_name: "#{issuable.to_ability_name}[milestone_id]", project_id: @project.id, issuable_id: issuable.id, milestones: namespace_project_milestones_path(@project.namespace, @project, :json), ability_name: issuable.to_ability_name, issue_update: issuable_json_path(issuable), use_id: true }})
- if issuable.has_attribute?(:time_estimate) - if issuable.has_attribute?(:time_estimate)
#issuable-time-tracker.block #issuable-time-tracker.block
%issuable-time-tracker{ ':time_estimate' => 'issuable.time_estimate', ':time_spent' => 'issuable.total_time_spent', ':human_time_estimate' => 'issuable.human_time_estimate', ':human_time_spent' => 'issuable.human_total_time_spent', 'stopwatch-svg' => custom_icon('icon_stopwatch') } %issuable-time-tracker{ ':time_estimate' => 'issuable.time_estimate', ':time_spent' => 'issuable.total_time_spent', ':human_time_estimate' => 'issuable.human_time_estimate', ':human_time_spent' => 'issuable.human_total_time_spent', 'stopwatch-svg' => custom_icon('icon_stopwatch'), 'docs-url' => help_page_path('workflow/time_tracking.md')}
// Fallback while content is loading // Fallback while content is loading
.title.hide-collapsed .title.hide-collapsed
Time tracking Time tracking
......
...@@ -65,6 +65,14 @@ shared_examples 'issuable time tracker' do ...@@ -65,6 +65,14 @@ shared_examples 'issuable time tracker' do
expect(page).not_to have_content 'Learn more' expect(page).not_to have_content 'Learn more'
end end
end end
it 'displays the correct help url' do
page.within '#issuable-time-tracker' do
find('.help-button').click
expect(find_link('Learn more')[:href]).to eq('/help/workflow/time_tracking.md')
end
end
end end
def submit_time(slash_command) def submit_time(slash_command)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment