_sidebar.scss 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. //
  2. // Sidebar
  3. //
  4. ._sidebar {
  5. position: absolute;
  6. z-index: var(--sidebarZ);
  7. top: 0;
  8. bottom: 0;
  9. left: 0;
  10. overflow-x: hidden;
  11. overflow-y: scroll;
  12. padding-top: var(--headerHeight);
  13. background: var(--sidebarBackground);
  14. background-clip: content-box;
  15. -webkit-overflow-scrolling: touch;
  16. -ms-overflow-style: none; // IE 10 doesn't support pointer-events
  17. @extend %border-box;
  18. @extend %user-select-none;
  19. &:focus { outline: none; }
  20. ._overlay-scrollbars & {
  21. padding-top: 0;
  22. top: var(--headerHeight);
  23. }
  24. body:not(._native-scrollbars) & {
  25. &::-webkit-scrollbar { width: 10px; }
  26. &::-webkit-scrollbar-track {
  27. background: var(--contentBackground);
  28. border: 0;
  29. }
  30. &::-webkit-scrollbar-thumb {
  31. border-width: 3px;
  32. &:hover, &:active { border-width: 2px; }
  33. }
  34. }
  35. ._sidebar-hidden & {
  36. transform: translateX(-95%);
  37. transform: translateX(calc(.5rem - 100%));
  38. opacity: 0;
  39. }
  40. &:hover:not(.no-hover),
  41. &.show {
  42. transform: none;
  43. opacity: 1;
  44. }
  45. }
  46. ._resizer {
  47. position: absolute;
  48. z-index: var(--headerZ);
  49. top: var(--headerHeight);
  50. bottom: var(--headerHeight);
  51. left: var(--sidebarWidth);
  52. margin-left: -2px;
  53. width: 3px;
  54. cursor: col-resize;
  55. ._sidebar-hidden & { display: none; }
  56. ._sidebar-hidden ._sidebar.show ~ & { display: block; }
  57. }
  58. //
  59. // List
  60. //
  61. ._list {
  62. margin: 0;
  63. padding: 0;
  64. list-style: none;
  65. width: var(--sidebarWidth);
  66. box-shadow: inset -1px 0 var(--sidebarBorder);
  67. @extend %border-box;
  68. @include mobile { width: var(--sidebarMediumWidth); }
  69. ._sidebar > & { min-height: 100%; }
  70. a:focus { outline: 0; }
  71. }
  72. ._list-title {
  73. position: relative;
  74. margin: .5rem 0 0;
  75. padding: 0 .75rem 0 2.125rem;
  76. line-height: 2rem;
  77. font-size: .75rem;
  78. color: var(--textColorLight);
  79. text-transform: uppercase;
  80. cursor: default;
  81. }
  82. ._list-title-link {
  83. display: none;
  84. float: right;
  85. font-weight: normal;
  86. text-transform: none;
  87. ._list-title:hover > & { display: block; }
  88. }
  89. ._list-item {
  90. display: block;
  91. position: relative;
  92. padding: .25rem .75rem;
  93. line-height: 1.5rem;
  94. font-size: .875rem;
  95. cursor: default;
  96. background: var(--sidebarBackground);
  97. box-shadow: inset -1px 0 var(--sidebarBorder);
  98. @extend %truncate-text;
  99. &, &:hover {
  100. color: inherit;
  101. text-decoration: none;
  102. }
  103. &.focus,
  104. &.focus:hover,
  105. &.active,
  106. &.active:hover {
  107. color: var(--focusText);
  108. background: var(--focusBackground);
  109. box-shadow: inset -1px 0 var(--focusBorder);
  110. }
  111. &.active,
  112. &.active:hover {
  113. color: var(--selectionText);
  114. background: var(--selectionBackground);
  115. box-shadow: inset -1px 0 var(--selectionBorder);
  116. }
  117. &:before {
  118. float: left;
  119. margin: .25rem .625rem 0 0;
  120. @extend %doc-icon;
  121. }
  122. }
  123. ._list-text {
  124. display: block;
  125. pointer-events: none;
  126. @extend %truncate-text;
  127. }
  128. ._list-count, ._list-enable {
  129. float: right;
  130. font-size: .75rem;
  131. margin-left: .375rem;
  132. .focus > &,
  133. .active > & {
  134. color: inherit;
  135. }
  136. }
  137. ._list-count {
  138. color: var(--textColorLighter);
  139. pointer-events: none;
  140. ._list-disabled:hover > & { display: none; }
  141. }
  142. ._list-enable {
  143. display: none;
  144. color: var(--linkColor);
  145. cursor: pointer;
  146. &:hover { text-decoration: underline; }
  147. ._list-disabled:hover > &, ._list-result > & { display: block; }
  148. ._list-result.active > & { margin-right: -1rem; }
  149. }
  150. //
  151. // List hierarchy
  152. //
  153. ._list-dir:not(._list-rdir),
  154. %_list-dir {
  155. padding-left: 2.125rem;
  156. }
  157. ._list-disabled {
  158. @extend %_list-dir;
  159. &, &:hover { color: var(--textColorLight); }
  160. &:before { opacity: .7; }
  161. }
  162. ._list-arrow {
  163. position: absolute;
  164. top: 0;
  165. left: .25rem;
  166. padding: .5rem .375rem .5rem .5rem;
  167. width: 1rem;
  168. height: 1rem;
  169. cursor: pointer;
  170. fill: var(--absolute);
  171. opacity: .4;
  172. &:hover { opacity: .65; }
  173. ._list-rdir > & {
  174. left: auto;
  175. right: .25rem;
  176. }
  177. .open > &, .open-title > & {
  178. -webkit-transform: rotate(90deg);
  179. transform: rotate(90deg);
  180. }
  181. }
  182. ._list-sub {
  183. display: none;
  184. .open + & { display: block; }
  185. > ._list-item { padding-left: 2.375rem; }
  186. > ._list-dir, > ._list-sub > ._list-item { padding-left: 2.75rem; }
  187. > ._list-disabled { padding-left: 3.75rem; }
  188. > ._list-item:before { content: none; }
  189. > ._list-dir { line-height: 1.375rem; }
  190. ._list-arrow {
  191. left: 1rem;
  192. padding: .4375rem;
  193. }
  194. }
  195. //
  196. // List pagination
  197. //
  198. ._list-pagelink {
  199. color: var(--linkColor);
  200. cursor: pointer;
  201. &:hover {
  202. color: var(--linkColorHover);
  203. text-decoration: underline;
  204. }
  205. }
  206. //
  207. // Search results
  208. //
  209. ._list-result.active {
  210. padding-right: 1.75rem;
  211. > ._list-reveal { display: block; }
  212. > ._list-count { display: none; }
  213. }
  214. ._list-reveal {
  215. display: none;
  216. position: absolute;
  217. top: 0;
  218. bottom: 0;
  219. right: 0;
  220. width: 2rem;
  221. cursor: pointer;
  222. &:before {
  223. content: '';
  224. position: absolute;
  225. bottom: 50%;
  226. left: .75rem;
  227. width: .75rem;
  228. height: 1px;
  229. background: var(--transparentSelectionText);
  230. box-shadow: 0 -3px var(--transparentSelectionText), // top line
  231. 0 3px var(--transparentSelectionText); // bottom line
  232. }
  233. }
  234. //
  235. // List note
  236. //
  237. ._list-note {
  238. padding: .5rem .75rem;
  239. line-height: 1.25rem;
  240. font-size: .8125rem;
  241. color: var(--textColorLight);
  242. & + & { padding-top: 0; }
  243. }
  244. ._list-note-link { cursor: pointer; }
  245. //
  246. // List hover clone
  247. //
  248. ._list-hover.clone {
  249. position: fixed;
  250. overflow: visible;
  251. z-index: var(--hoverZ);
  252. left: 0;
  253. min-width: var(--sidebarWidth);
  254. padding: .25rem .75rem;
  255. pointer-events: none;
  256. -webkit-font-smoothing: subpixel-antialiased;
  257. -webkit-transform: translate3d(0, 0, 0);
  258. transform: translate3d(0, 0, 0);
  259. @extend %border-box;
  260. @include mobile { min-width: var(--sidebarMediumWidth); }
  261. > ._list-text { display: inline; }
  262. &:not(._list-result) {
  263. padding-left: 2.75rem;
  264. &:before { content: none; }
  265. }
  266. ._list-reveal, ._list-enable { display: none; }
  267. }
  268. //
  269. // List picker
  270. //
  271. ._list-picker {
  272. ._list-item { cursor: pointer; }
  273. ._list-sub > ._list-item { padding-left: 2.375rem; }
  274. }
  275. ._list-picker-head {
  276. display: flex;
  277. justify-content: space-between;
  278. position: -webkit-sticky;
  279. position: sticky;
  280. top: 0;
  281. z-index: 1;
  282. margin-right: 1px;
  283. padding: .5rem .75rem .25rem .75rem;
  284. line-height: 1.5rem;
  285. font-size: .75rem;
  286. font-weight: var(--bolderFontWeight);
  287. color: var(--textColorLight);
  288. text-transform: uppercase;
  289. background: linear-gradient(to bottom, var(--sidebarBackground), var(--sidebarBackground) 75%, var(--transparentSidebarBackground));
  290. cursor: default;
  291. }
  292. ._list-checkbox {
  293. position: absolute;
  294. top: .5rem;
  295. right: .75rem;
  296. }
  297. ._list-link {
  298. display: block;
  299. padding: .75rem 0;
  300. font-size: .8125rem;
  301. text-align: center;
  302. @extend %external-link;
  303. &:after { visibility: hidden; }
  304. &:hover:after { visibility: visible; }
  305. }