forked from swiftlang/swift-docc-render
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathNavMenuItemBase.vue
101 lines (93 loc) · 2.55 KB
/
NavMenuItemBase.vue
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<!--
This source file is part of the Swift.org open source project
Copyright (c) 2021 Apple Inc. and the Swift project authors
Licensed under Apache License v2.0 with Runtime Library Exception
See https://swift.org/LICENSE.txt for license information
See https://swift.org/CONTRIBUTORS.txt for Swift project authors
-->
<template>
<li
class="nav-menu-item"
:class="{ 'nav-menu-item--animated': animate }"
>
<slot />
</li>
</template>
<script>
export default {
name: 'NavMenuItemBase',
props: {
/**
* Adds the animated css class to a menu item.
* Works when nested inside the NavMenuItems component.
*/
animate: {
type: Boolean,
default: true,
},
},
};
</script>
<style lang='scss' scoped>
@import "docc-render/styles/_core.scss";
.nav-menu-item {
margin-left: $nav-menu-item-left-margin;
list-style: none;
min-width: 0;
@include nav-in-breakpoint {
margin-left: 0;
width: 100%;
min-height: rem(42px);
// remove the first border of the first element
&:first-child {
:deep(.nav-menu-link) {
border-top: 0;
}
}
}
}
// To see the animation, a `NavMenuItemBase` component
// must have the `animated` prop as well,
// as be used inside a `NavMenuItems` component.
.nav-menu-item--animated {
@include nav-in-breakpoint {
opacity: 0;
transform: $nav-menu-item-displacement;
transition: 0.5s ease;
transition-property: transform, opacity;
// add expanded styles
@include nav-is-open($nested: true) {
opacity: 1;
transform: translate3d(0, 0, 0);
transition-delay: $nav-menu-item-stagger-delay;
}
}
// create a staggered effect, only each settings element (language toggle, API changes)
@for $i from 0 to 8 {
// describes how many items the previous menu children had
[data-previous-menu-children-count='#{$i}'] & {
@for $j from 1 to 8 {
// each child should delay its removal
&:nth-child(#{$j}) {
// this is way down here, otherwise parent selectors get broken.
@include nav-in-breakpoint {
transition-delay: $nav-menu-item-stagger-delay * ($j + $i);
}
}
}
// when collapsed
@include nav-in-breakpoint {
// and expanded
@include nav-is-open($nested: true) {
@for $k from 1 to 8 {
// each child should delay its reveal
&:nth-child(#{$k}) {
transition-delay: $nav-menu-item-stagger-delay * (9 - ($k + $i));
}
}
}
}
}
}
}
</style>