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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
1b8a2fca
Commit
1b8a2fca
authored
Jun 07, 2018
by
Kushal Pandya
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Roadmap MonthsHeaderSubItem Component
parent
76923d9c
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
177 additions
and
0 deletions
+177
-0
ee/app/assets/javascripts/roadmap/components/preset_months/months_header_sub_item.vue
...admap/components/preset_months/months_header_sub_item.vue
+83
-0
spec/javascripts/roadmap/components/preset_months/months_header_sub_item_spec.js
...p/components/preset_months/months_header_sub_item_spec.js
+94
-0
No files found.
ee/app/assets/javascripts/roadmap/components/preset_months/months_header_sub_item.vue
0 → 100644
View file @
1b8a2fca
<
script
>
import
{
getSundays
}
from
'
~/lib/utils/datetime_utility
'
;
import
{
PRESET_TYPES
}
from
'
../../constants
'
;
import
timelineTodayIndicator
from
'
../timeline_today_indicator.vue
'
;
export
default
{
presetType
:
PRESET_TYPES
.
MONTHS
,
components
:
{
timelineTodayIndicator
,
},
props
:
{
currentDate
:
{
type
:
Date
,
required
:
true
,
},
timeframeItem
:
{
type
:
Date
,
required
:
true
,
},
},
computed
:
{
headerSubItems
()
{
return
getSundays
(
this
.
timeframeItem
);
},
headerSubItemClass
()
{
const
currentYear
=
this
.
currentDate
.
getFullYear
();
const
currentMonth
=
this
.
currentDate
.
getMonth
();
const
timeframeYear
=
this
.
timeframeItem
.
getFullYear
();
const
timeframeMonth
=
this
.
timeframeItem
.
getMonth
();
// Show dark color text only for dates from current month and future months.
return
timeframeYear
>=
currentYear
&&
timeframeMonth
>=
currentMonth
?
'
label-dark
'
:
''
;
},
hasToday
()
{
const
timeframeYear
=
this
.
timeframeItem
.
getFullYear
();
const
timeframeMonth
=
this
.
timeframeItem
.
getMonth
();
return
this
.
currentDate
.
getMonth
()
===
timeframeMonth
&&
this
.
currentDate
.
getFullYear
()
===
timeframeYear
;
},
},
methods
:
{
getSubItemValueClass
(
subItem
)
{
const
daysToClosestWeek
=
this
.
currentDate
.
getDate
()
-
subItem
.
getDate
();
// Show dark color text only for upcoming dates
// and current week date
if
(
daysToClosestWeek
<=
6
&&
this
.
currentDate
.
getDate
()
>=
subItem
.
getDate
()
&&
this
.
currentDate
.
getFullYear
()
===
subItem
.
getFullYear
()
&&
this
.
currentDate
.
getMonth
()
===
subItem
.
getMonth
())
{
return
'
label-dark label-bold
'
;
}
else
if
(
subItem
>=
this
.
currentDate
)
{
return
'
label-dark
'
;
}
return
''
;
},
},
};
</
script
>
<
template
>
<div
class=
"item-sublabel"
:class=
"headerSubItemClass"
>
<span
v-for=
"(subItem, index) in headerSubItems"
:key=
"index"
class=
"sublabel-value"
:class=
"getSubItemValueClass(subItem)"
>
{{
subItem
.
getDate
()
}}
</span>
<timeline-today-indicator
v-if=
"hasToday"
:preset-type=
"$options.presetType"
:current-date=
"currentDate"
:timeframe-item=
"timeframeItem"
/>
</div>
</
template
>
spec/javascripts/roadmap/components/preset_months/months_header_sub_item_spec.js
0 → 100644
View file @
1b8a2fca
import
Vue
from
'
vue
'
;
import
MonthsHeaderSubItemComponent
from
'
ee/roadmap/components/preset_months/months_header_sub_item.vue
'
;
import
mountComponent
from
'
spec/helpers/vue_mount_component_helper
'
;
import
{
mockTimeframeMonths
}
from
'
../../mock_data
'
;
const
createComponent
=
({
currentDate
=
mockTimeframeMonths
[
0
],
timeframeItem
=
mockTimeframeMonths
[
0
],
})
=>
{
const
Component
=
Vue
.
extend
(
MonthsHeaderSubItemComponent
);
return
mountComponent
(
Component
,
{
currentDate
,
timeframeItem
,
});
};
describe
(
'
MonthsHeaderSubItemComponent
'
,
()
=>
{
let
vm
;
afterEach
(()
=>
{
vm
.
$destroy
();
});
describe
(
'
computed
'
,
()
=>
{
describe
(
'
headerSubItems
'
,
()
=>
{
it
(
'
returns array of dates containing Sundays from timeframeItem
'
,
()
=>
{
vm
=
createComponent
({});
expect
(
Array
.
isArray
(
vm
.
headerSubItems
)).
toBe
(
true
);
vm
.
headerSubItems
.
forEach
(
subItem
=>
{
expect
(
subItem
instanceof
Date
).
toBe
(
true
);
});
});
});
describe
(
'
headerSubItemClass
'
,
()
=>
{
it
(
'
returns string containing `label-dark` when timeframe year and month are greater than current year and month
'
,
()
=>
{
vm
=
createComponent
({});
expect
(
vm
.
headerSubItemClass
).
toBe
(
'
label-dark
'
);
});
it
(
'
returns empty string when timeframe year and month are less than current year and month
'
,
()
=>
{
vm
=
createComponent
({
currentDate
:
new
Date
(
2017
,
10
,
1
),
// Nov 1, 2017
timeframeItem
:
new
Date
(
2018
,
0
,
1
),
// Jan 1, 2018
});
expect
(
vm
.
headerSubItemClass
).
toBe
(
''
);
});
});
describe
(
'
hasToday
'
,
()
=>
{
it
(
'
returns true when current month and year is same as timeframe month and year
'
,
()
=>
{
vm
=
createComponent
({});
expect
(
vm
.
hasToday
).
toBe
(
true
);
});
it
(
'
returns false when current month and year is different from timeframe month and year
'
,
()
=>
{
vm
=
createComponent
({
currentDate
:
new
Date
(
2017
,
10
,
1
),
// Nov 1, 2017
timeframeItem
:
new
Date
(
2018
,
0
,
1
),
// Jan 1, 2018
});
expect
(
vm
.
hasToday
).
toBe
(
false
);
});
});
});
describe
(
'
methods
'
,
()
=>
{
describe
(
'
getSubItemValueClass
'
,
()
=>
{
it
(
'
returns string containing `label-dark` when provided subItem is greater than current date
'
,
()
=>
{
vm
=
createComponent
({
currentDate
:
new
Date
(
2018
,
0
,
1
),
// Jan 1, 2018
});
const
subItem
=
new
Date
(
2018
,
0
,
15
);
// Jan 15, 2018
expect
(
vm
.
getSubItemValueClass
(
subItem
)).
toBe
(
'
label-dark
'
);
});
});
});
describe
(
'
template
'
,
()
=>
{
beforeEach
(()
=>
{
vm
=
createComponent
({});
});
it
(
'
renders component container element with class `item-sublabel`
'
,
()
=>
{
expect
(
vm
.
$el
.
classList
.
contains
(
'
item-sublabel
'
)).
toBe
(
true
);
});
it
(
'
renders sub item element with class `sublabel-value`
'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'
.sublabel-value
'
)).
not
.
toBeNull
();
});
});
});
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