@progressiveui/styles 10.30.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (265) hide show
  1. package/CHANGELOG.md +621 -0
  2. package/README.md +85 -0
  3. package/index-with-tokens.scss +26 -0
  4. package/index.scss +12 -0
  5. package/package.json +42 -0
  6. package/scss/_breakpoint.scss +2 -0
  7. package/scss/_config.scss +30 -0
  8. package/scss/_feature-flags.scss +1 -0
  9. package/scss/_font-face.scss +13 -0
  10. package/scss/_global-defaults.scss +14 -0
  11. package/scss/_grid.scss +32 -0
  12. package/scss/_motion.scss +67 -0
  13. package/scss/_reset.scss +172 -0
  14. package/scss/_spacing.scss +4 -0
  15. package/scss/_theme.scss +102 -0
  16. package/scss/_themes.scss +14 -0
  17. package/scss/_type.scss +143 -0
  18. package/scss/_zone.scss +26 -0
  19. package/scss/components/_index.scss +82 -0
  20. package/scss/components/accordion/_accordion.legacy.scss +348 -0
  21. package/scss/components/accordion/_accordion.scss +118 -0
  22. package/scss/components/accordion/_index.scss +4 -0
  23. package/scss/components/anchor-navigation/_anchor-navigation.scss +37 -0
  24. package/scss/components/anchor-navigation/_index.scss +4 -0
  25. package/scss/components/auth-layout/_auth-layout.scss +55 -0
  26. package/scss/components/auth-layout/_index.scss +11 -0
  27. package/scss/components/avatar/_avatar.scss +61 -0
  28. package/scss/components/avatar/_index.scss +4 -0
  29. package/scss/components/banner-navigation/_banner-navigation.scss +80 -0
  30. package/scss/components/banner-navigation/_index.scss +4 -0
  31. package/scss/components/blockquote/_blockquote.scss +156 -0
  32. package/scss/components/blockquote/_index.scss +4 -0
  33. package/scss/components/breadcrumb/_breadcrumb.scss +89 -0
  34. package/scss/components/breadcrumb/_index.scss +4 -0
  35. package/scss/components/button/_button.scss +520 -0
  36. package/scss/components/button/_index.scss +5 -0
  37. package/scss/components/button/_mixins.scss +92 -0
  38. package/scss/components/button/_vars.scss +69 -0
  39. package/scss/components/card/_card-external.scss +149 -0
  40. package/scss/components/card/_card.scss +138 -0
  41. package/scss/components/card/_index.scss +7 -0
  42. package/scss/components/checkbox/_checkbox.scss +195 -0
  43. package/scss/components/checkbox/_index.scss +11 -0
  44. package/scss/components/code-snippet/_code-snippet.scss +581 -0
  45. package/scss/components/code-snippet/_index.scss +11 -0
  46. package/scss/components/code-snippet/_mixins.scss +21 -0
  47. package/scss/components/col/_col.scss +54 -0
  48. package/scss/components/col/_index.scss +4 -0
  49. package/scss/components/combo-box/_combo-box.scss +45 -0
  50. package/scss/components/combo-box/_index.scss +11 -0
  51. package/scss/components/content-switcher/_content-switcher.scss +132 -0
  52. package/scss/components/content-switcher/_index.scss +11 -0
  53. package/scss/components/context-menu/_context-menu.scss +26 -0
  54. package/scss/components/context-menu/_index.scss +11 -0
  55. package/scss/components/credits/_credits.scss +30 -0
  56. package/scss/components/credits/_index.scss +11 -0
  57. package/scss/components/data-table/_data-table.scss +1005 -0
  58. package/scss/components/data-table/_index.scss +12 -0
  59. package/scss/components/data-table/_mixins.scss +38 -0
  60. package/scss/components/data-table/_vars.scss +13 -0
  61. package/scss/components/data-table/action/_data-table-action.scss +587 -0
  62. package/scss/components/data-table/action/_index.scss +11 -0
  63. package/scss/components/data-table/expandable/_data-table-expandable.scss +411 -0
  64. package/scss/components/data-table/expandable/_index.scss +11 -0
  65. package/scss/components/data-table/skeleton/_data-table-skeleton.scss +72 -0
  66. package/scss/components/data-table/skeleton/_index.scss +11 -0
  67. package/scss/components/data-table/sort/_data-table-sort.scss +245 -0
  68. package/scss/components/data-table/sort/_index.scss +11 -0
  69. package/scss/components/date-picker/_date-picker.scss +896 -0
  70. package/scss/components/date-picker/_flatpickr.scss +538 -0
  71. package/scss/components/date-picker/_index.scss +11 -0
  72. package/scss/components/date-picker-new/_date-picker-new.scss +100 -0
  73. package/scss/components/date-picker-new/_index.scss +4 -0
  74. package/scss/components/date-picker-new/react-datepicker/datepicker.scss +692 -0
  75. package/scss/components/date-picker-new/react-datepicker/mixins.scss +88 -0
  76. package/scss/components/date-picker-new/react-datepicker/variables.scss +20 -0
  77. package/scss/components/dropdown/_dropdown.scss +493 -0
  78. package/scss/components/dropdown/_index.scss +11 -0
  79. package/scss/components/empty/_empty.scss +105 -0
  80. package/scss/components/empty/_index.scss +11 -0
  81. package/scss/components/file-uploader/_file-uploader.scss +321 -0
  82. package/scss/components/file-uploader/_index.scss +11 -0
  83. package/scss/components/footer/_footer.scss +258 -0
  84. package/scss/components/footer/_footer_external.scss +153 -0
  85. package/scss/components/footer/_index.scss +14 -0
  86. package/scss/components/form/_form.scss +146 -0
  87. package/scss/components/form/_index.scss +4 -0
  88. package/scss/components/form-controls/_form-controls.scss +53 -0
  89. package/scss/components/form-controls/_index.scss +11 -0
  90. package/scss/components/form-error/_form-error.scss +25 -0
  91. package/scss/components/form-error/_index.scss +11 -0
  92. package/scss/components/form-group/_form-group.scss +109 -0
  93. package/scss/components/form-group/_index.scss +11 -0
  94. package/scss/components/form-hint/_form-hint.scss +28 -0
  95. package/scss/components/form-hint/_index.scss +11 -0
  96. package/scss/components/form-wizard/_form-wizard.scss +48 -0
  97. package/scss/components/form-wizard/_index.scss +11 -0
  98. package/scss/components/grid/_grid.scss +80 -0
  99. package/scss/components/grid/_index.scss +4 -0
  100. package/scss/components/hero/_hero-external.scss +84 -0
  101. package/scss/components/hero/_hero.scss +321 -0
  102. package/scss/components/hero/_index.scss +14 -0
  103. package/scss/components/icon/_icon.scss +19 -0
  104. package/scss/components/icon/_index.scss +11 -0
  105. package/scss/components/info-bar/_index.scss +11 -0
  106. package/scss/components/info-bar/_info-bar.scss +21 -0
  107. package/scss/components/inline-loading/_index.scss +11 -0
  108. package/scss/components/inline-loading/_inline-loading.scss +159 -0
  109. package/scss/components/inline-loading/_keyframes.scss +12 -0
  110. package/scss/components/input/_index.scss +11 -0
  111. package/scss/components/input/_input.scss +87 -0
  112. package/scss/components/input/_vars.scss +31 -0
  113. package/scss/components/item/_index.scss +11 -0
  114. package/scss/components/item/_item.scss +227 -0
  115. package/scss/components/link/_index.scss +11 -0
  116. package/scss/components/link/_link.scss +109 -0
  117. package/scss/components/list/_index.scss +4 -0
  118. package/scss/components/list/_list.scss +144 -0
  119. package/scss/components/list-box/_index.scss +11 -0
  120. package/scss/components/list-box/_list-box.scss +813 -0
  121. package/scss/components/loading/_animation.scss +39 -0
  122. package/scss/components/loading/_functions.scss +10 -0
  123. package/scss/components/loading/_index.scss +11 -0
  124. package/scss/components/loading/_keyframes.scss +48 -0
  125. package/scss/components/loading/_loading.scss +72 -0
  126. package/scss/components/loading/_mixins.scss +42 -0
  127. package/scss/components/loading/_vars.scss +26 -0
  128. package/scss/components/main-navigation/_index.scss +14 -0
  129. package/scss/components/main-navigation/_main-navigation.scss +360 -0
  130. package/scss/components/main-navigation/_main-navigation_external.scss +527 -0
  131. package/scss/components/menu/_index.scss +11 -0
  132. package/scss/components/menu/_menu.scss +143 -0
  133. package/scss/components/modal/_index.scss +11 -0
  134. package/scss/components/modal/_mixins.scss +10 -0
  135. package/scss/components/modal/_modal.scss +224 -0
  136. package/scss/components/module/_index.scss +4 -0
  137. package/scss/components/module/_module.scss +199 -0
  138. package/scss/components/multiselect/_index.scss +11 -0
  139. package/scss/components/multiselect/_multiselect.scss +103 -0
  140. package/scss/components/notification/_index.scss +21 -0
  141. package/scss/components/notification/_inline-notification.scss +321 -0
  142. package/scss/components/notification/_mixins.scss +41 -0
  143. package/scss/components/notification/_notification.scss +480 -0
  144. package/scss/components/notification/_toast-notification.scss +249 -0
  145. package/scss/components/notification/_tokens.scss +126 -0
  146. package/scss/components/number-input/_index.scss +11 -0
  147. package/scss/components/number-input/_number-input.scss +195 -0
  148. package/scss/components/overflow-menu/_index.scss +11 -0
  149. package/scss/components/overflow-menu/_overflow-menu.scss +351 -0
  150. package/scss/components/pagination/_index.scss +11 -0
  151. package/scss/components/pagination/_pagination.scss +214 -0
  152. package/scss/components/pagination-nav/_index.scss +11 -0
  153. package/scss/components/pagination-nav/_mixins.scss +38 -0
  154. package/scss/components/pagination-nav/_pagination-nav.scss +171 -0
  155. package/scss/components/popover/_index.scss +11 -0
  156. package/scss/components/popover/_popover.scss +323 -0
  157. package/scss/components/progress-bar/_index.scss +11 -0
  158. package/scss/components/progress-bar/_progress-bar.scss +82 -0
  159. package/scss/components/progress-indicator/_index.scss +11 -0
  160. package/scss/components/progress-indicator/_progress-indicator.scss +328 -0
  161. package/scss/components/radio-button/_index.scss +4 -0
  162. package/scss/components/radio-button/_radio-button.scss +239 -0
  163. package/scss/components/react-dropzone/_index.scss +11 -0
  164. package/scss/components/react-dropzone/_react-dropzone.scss +58 -0
  165. package/scss/components/react-select/_index.scss +11 -0
  166. package/scss/components/react-select/_react-select.scss +90 -0
  167. package/scss/components/read-more/_index.scss +11 -0
  168. package/scss/components/read-more/_read-more.scss +102 -0
  169. package/scss/components/search/_index.scss +4 -0
  170. package/scss/components/search/_search.scss +436 -0
  171. package/scss/components/secondary-navigation/_index.scss +4 -0
  172. package/scss/components/secondary-navigation/_secondary-navigation.scss +61 -0
  173. package/scss/components/select/_index.scss +11 -0
  174. package/scss/components/select/_select.scss +224 -0
  175. package/scss/components/sidebar/_index.scss +11 -0
  176. package/scss/components/sidebar/_sidebar.scss +118 -0
  177. package/scss/components/skeleton-text/_index.scss +4 -0
  178. package/scss/components/skeleton-text/_skeleton-text.scss +22 -0
  179. package/scss/components/slider/_index.scss +4 -0
  180. package/scss/components/slider/_slider.scss +274 -0
  181. package/scss/components/step-navigation/_index.scss +4 -0
  182. package/scss/components/step-navigation/_step-navigation.scss +136 -0
  183. package/scss/components/step-navigation-item/_index.scss +4 -0
  184. package/scss/components/step-navigation-item/_step-navigation-item.scss +377 -0
  185. package/scss/components/story/_index.scss +11 -0
  186. package/scss/components/story/_story.scss +519 -0
  187. package/scss/components/structured-list/_index.scss +11 -0
  188. package/scss/components/structured-list/_mixins.scss +59 -0
  189. package/scss/components/structured-list/_structured-list.scss +235 -0
  190. package/scss/components/sub-navigation/_index.scss +4 -0
  191. package/scss/components/sub-navigation/_sub-navigation.scss +113 -0
  192. package/scss/components/table/_index.scss +11 -0
  193. package/scss/components/table/table.scss +88 -0
  194. package/scss/components/tabs/_index.scss +4 -0
  195. package/scss/components/tabs/_tabs.scss +185 -0
  196. package/scss/components/tabs/_vars.scss +23 -0
  197. package/scss/components/tag/_index.scss +12 -0
  198. package/scss/components/tag/_mixins.scss +19 -0
  199. package/scss/components/tag/_tag.scss +137 -0
  200. package/scss/components/tag/_tokens.scss +702 -0
  201. package/scss/components/text-area/_index.scss +11 -0
  202. package/scss/components/text-area/_text-area.scss +120 -0
  203. package/scss/components/text-input/_index.scss +11 -0
  204. package/scss/components/text-input/_text-input.scss +19 -0
  205. package/scss/components/tile/_index.scss +11 -0
  206. package/scss/components/tile/_tile.scss +269 -0
  207. package/scss/components/time-picker/_index.scss +11 -0
  208. package/scss/components/time-picker/_time-picker.scss +94 -0
  209. package/scss/components/toggle/_index.scss +11 -0
  210. package/scss/components/toggle/_toggle.scss +192 -0
  211. package/scss/components/tooltip/_index.scss +11 -0
  212. package/scss/components/tooltip/_mixins.scss +107 -0
  213. package/scss/components/tooltip/_tooltip.scss +128 -0
  214. package/scss/components/tooltip/_vars.scss +6 -0
  215. package/scss/components/tooltip/animations/fade.scss +10 -0
  216. package/scss/components/tooltip/themes/light-border.scss +158 -0
  217. package/scss/components/tooltip/themes/light.scss +28 -0
  218. package/scss/components/treeview/_index.scss +11 -0
  219. package/scss/components/treeview/_treeview.scss +177 -0
  220. package/scss/components/ui-shell/_functions.scss +19 -0
  221. package/scss/components/ui-shell/_index.scss +11 -0
  222. package/scss/components/ui-shell/_mixins.scss +56 -0
  223. package/scss/components/ui-shell/_ui-shell.scss +23 -0
  224. package/scss/components/ui-shell/content/_content.scss +34 -0
  225. package/scss/components/ui-shell/content/_index.scss +11 -0
  226. package/scss/components/ui-shell/header/_header.scss +382 -0
  227. package/scss/components/ui-shell/header/_index.scss +11 -0
  228. package/scss/components/ui-shell/header-panel/_header-panel.scss +41 -0
  229. package/scss/components/ui-shell/header-panel/_index.scss +11 -0
  230. package/scss/components/ui-shell/side-nav/_index.scss +11 -0
  231. package/scss/components/ui-shell/side-nav/_side-nav.scss +526 -0
  232. package/scss/components/ui-shell/switcher/_index.scss +11 -0
  233. package/scss/components/ui-shell/switcher/_switcher.scss +78 -0
  234. package/scss/components/unit/_index.scss +11 -0
  235. package/scss/components/unit/_unit.scss +277 -0
  236. package/scss/components/user/_index.scss +11 -0
  237. package/scss/components/user/_user.scss +104 -0
  238. package/scss/components/value/_index.scss +11 -0
  239. package/scss/components/value/_value.scss +41 -0
  240. package/scss/components/wrapper/_index.scss +11 -0
  241. package/scss/components/wrapper/_wrapper.scss +71 -0
  242. package/scss/utilities/_box-shadow.scss +14 -0
  243. package/scss/utilities/_button-reset.scss +31 -0
  244. package/scss/utilities/_component-reset.scss +25 -0
  245. package/scss/utilities/_component-tokens.scss +27 -0
  246. package/scss/utilities/_convert.scss +41 -0
  247. package/scss/utilities/_custom-property.scss +56 -0
  248. package/scss/utilities/_focus-outline.scss +68 -0
  249. package/scss/utilities/_high-contrast-mode.scss +37 -0
  250. package/scss/utilities/_index.scss +24 -0
  251. package/scss/utilities/_input-base.scss +63 -0
  252. package/scss/utilities/_keyframes.scss +76 -0
  253. package/scss/utilities/_layer-set.scss +31 -0
  254. package/scss/utilities/_layer.scss +52 -0
  255. package/scss/utilities/_placeholder-colors.scss +10 -0
  256. package/scss/utilities/_read-only.scss +19 -0
  257. package/scss/utilities/_rotate.scss +19 -0
  258. package/scss/utilities/_rtl.scss +21 -0
  259. package/scss/utilities/_skeleton.scss +44 -0
  260. package/scss/utilities/_text-gradient.scss +20 -0
  261. package/scss/utilities/_text-overflow.scss +23 -0
  262. package/scss/utilities/_text-truncate.scss +29 -0
  263. package/scss/utilities/_visually-hidden.scss +38 -0
  264. package/scss/utilities/_z-index.scss +38 -0
  265. package/styles.css +1 -0
@@ -0,0 +1,526 @@
1
+ //
2
+ // Copyright IBM Corp. 2016, 2018
3
+ //
4
+ // This source code is licensed under the Apache-2.0 license found in the
5
+ // LICENSE file in the root directory of this source tree.
6
+ //
7
+
8
+ @use "../mixins" as *;
9
+ @use "../functions" as *;
10
+ @use "../../../breakpoint" as *;
11
+ @use "../../../config" as *;
12
+ @use "../../../motion" as *;
13
+ @use "../../../spacing" as *;
14
+ @use "../../../theme" as *;
15
+ @use "../../../type" as *;
16
+ @use "../../../utilities/button-reset";
17
+ @use "../../../utilities/convert" as *;
18
+ @use "../../../utilities/focus-outline" as *;
19
+ @use "../../../utilities/high-contrast-mode" as *;
20
+ @use "../../../utilities/z-index" as *;
21
+
22
+ /// UI shell side nav
23
+ /// @access private
24
+ /// @group ui-shell
25
+ @mixin side-nav {
26
+ //----------------------------------------------------------------------------
27
+ // Side-nav > Panel
28
+ //----------------------------------------------------------------------------.
29
+ .#{$prefix}--side-nav {
30
+ position: fixed;
31
+ z-index: z("header");
32
+ top: 0;
33
+ bottom: 0;
34
+ left: 0;
35
+ // Useful to toggle this property to see what's going on when not expanded
36
+ overflow: hidden;
37
+ width: mini-units(6);
38
+ max-width: mini-units(32);
39
+ background-color: $background-main;
40
+ color: $text-body-secondary;
41
+ // TODO: sync with motion work
42
+ transition: width 0.11s cubic-bezier(0.2, 0, 1, 0.9);
43
+ will-change: width;
44
+ }
45
+
46
+ .#{$prefix}--side-nav--ux {
47
+ top: $spacing-09;
48
+ width: mini-units(32);
49
+
50
+ @include breakpoint-down("lg") {
51
+ width: 0;
52
+ }
53
+ }
54
+
55
+ //----------------------------------------------------------------------------
56
+ // Rail
57
+ //---------------------------------------------------------------------------
58
+ // Used for rendering the actual side rail. There are two states that we have
59
+ // to style for, namely for when the rail is collapsed and expanded. When
60
+ // collapsed, the rail is intended to expand on mouse over. When expanded, it
61
+ // should have the same dimensions as when expanded on mouse over
62
+
63
+ .#{$prefix}--side-nav--rail {
64
+ width: mini-units(6);
65
+ }
66
+
67
+ .#{$prefix}--side-nav--hidden {
68
+ width: 0;
69
+ }
70
+
71
+ .#{$prefix}--side-nav.#{$prefix}--side-nav--rail:not(
72
+ .#{$prefix}--side-nav--fixed
73
+ ):hover,
74
+ .#{$prefix}--side-nav--expanded {
75
+ width: mini-units(32);
76
+ }
77
+
78
+ .#{$prefix}--side-nav__overlay {
79
+ position: fixed;
80
+ top: calcRem(48px);
81
+ left: 0;
82
+ width: 0;
83
+ height: 0;
84
+ background-color: transparent;
85
+ opacity: 0;
86
+ transition: opacity $transition--expansion $standard-easing,
87
+ background-color $transition--expansion $standard-easing;
88
+ }
89
+
90
+ .#{$prefix}--side-nav__overlay-active {
91
+ @include breakpoint-down("lg") {
92
+ width: 100vw;
93
+ height: 100vh;
94
+ background-color: $overlay;
95
+ opacity: 1;
96
+ transition: opacity $transition--expansion $standard-easing,
97
+ background-color $transition--expansion $standard-easing;
98
+ }
99
+ }
100
+
101
+ // When used alongside the header, we update the `top` positioning so that we
102
+ // can fit both widgets on the same page without overlapping.
103
+ .#{$prefix}--header ~ .#{$prefix}--side-nav {
104
+ top: mini-units(6);
105
+ height: calc(100% - 48px);
106
+ }
107
+
108
+ .#{$prefix}--side-nav--fixed {
109
+ width: mini-units(32);
110
+ }
111
+
112
+ .#{$prefix}--side-nav--collapsed {
113
+ width: mini-units(32);
114
+ transform: translateX(mini-units(-32));
115
+ }
116
+
117
+ //----------------------------------------------------------------------------
118
+ // Side-nav > Navigation
119
+ //----------------------------------------------------------------------------
120
+ .#{$prefix}--side-nav__navigation {
121
+ display: flex;
122
+ height: 100%;
123
+ flex-direction: column;
124
+ }
125
+
126
+ //----------------------------------------------------------------------------
127
+ // Side-nav > Navigation > Item(s)
128
+ //----------------------------------------------------------------------------
129
+ .#{$prefix}--side-nav__items {
130
+ overflow: hidden;
131
+ flex: 1 1 0%;
132
+ padding: 1rem 0 0;
133
+
134
+ @include expanded() {
135
+ overflow-y: auto;
136
+ }
137
+ }
138
+
139
+ .#{$prefix}--side-nav--ux .#{$prefix}--side-nav__items {
140
+ overflow-y: auto;
141
+ }
142
+
143
+ .#{$prefix}--side-nav__item {
144
+ overflow: hidden;
145
+ width: auto;
146
+ height: auto;
147
+ }
148
+
149
+ .#{$prefix}--side-nav--ux .#{$prefix}--side-nav__item {
150
+ width: auto;
151
+ height: auto;
152
+ }
153
+
154
+ .#{$prefix}--side-nav__item:not(.#{$prefix}--side-nav__item--active):hover
155
+ .#{$prefix}--side-nav__item:not(.#{$prefix}--side-nav__item--active)
156
+ > .#{$prefix}--side-nav__submenu:hover,
157
+ .#{$prefix}--side-nav__item:not(.#{$prefix}--side-nav__item--active)
158
+ > .#{$prefix}--side-nav__link:hover,
159
+ .#{$prefix}--side-nav__menu
160
+ a.#{$prefix}--side-nav__link:not(.#{$prefix}--side-nav__link--current):not(
161
+ [aria-current="page"]
162
+ ):hover,
163
+ .#{$prefix}--side-nav a.#{$prefix}--header__menu-item:hover,
164
+ .#{$prefix}--side-nav
165
+ .#{$prefix}--header__menu-title[aria-expanded="true"]:hover {
166
+ // TODO: sync color
167
+ background-color: $background-hover;
168
+ color: $text-body-default;
169
+ }
170
+
171
+ .#{$prefix}--side-nav__item:not(.#{$prefix}--side-nav__item--active)
172
+ > .#{$prefix}--side-nav__link:hover
173
+ > span,
174
+ .#{$prefix}--side-nav__item:not(.#{$prefix}--side-nav__item--active)
175
+ .#{$prefix}--side-nav__menu-item
176
+ > .#{$prefix}--side-nav__link:hover
177
+ > span {
178
+ color: $text-body-default;
179
+ }
180
+
181
+ .#{$prefix}--side-nav__item--large {
182
+ height: mini-units(6);
183
+ }
184
+
185
+ //----------------------------------------------------------------------------
186
+ // Side-nav > Navigation > Divider
187
+ //----------------------------------------------------------------------------
188
+ .#{$prefix}--side-nav__divider {
189
+ height: 1px;
190
+ margin: $spacing-03 $spacing-05;
191
+ background-color: $border-subtle;
192
+ }
193
+
194
+ //----------------------------------------------------------------------------
195
+ // Side-nav > Navigation > {Menu,Submenu}
196
+ //----------------------------------------------------------------------------
197
+ .#{$prefix}--side-nav__submenu {
198
+ @include button-reset.reset($width: true);
199
+ @include type-style("productive-heading-01");
200
+ @include focus-outline("reset");
201
+
202
+ display: flex;
203
+ height: mini-units(4);
204
+ align-items: center;
205
+
206
+ padding: 0 mini-units(2);
207
+ color: $text-body-secondary;
208
+ transition: color $duration-fast-02, background-color $duration-fast-02,
209
+ outline $duration-fast-02;
210
+ user-select: none;
211
+ }
212
+
213
+ .#{$prefix}--side-nav__submenu:hover {
214
+ background-color: $background-hover;
215
+ color: $text-body-default;
216
+ }
217
+
218
+ .#{$prefix}--side-nav__submenu:focus {
219
+ @include focus-outline("outline");
220
+ }
221
+
222
+ .#{$prefix}--side-nav__submenu-title {
223
+ @include text-overflow();
224
+
225
+ text-align: left;
226
+ }
227
+
228
+ .#{$prefix}--side-nav__icon.#{$prefix}--side-nav__submenu-chevron {
229
+ display: flex;
230
+ flex: 1;
231
+ justify-content: flex-end;
232
+ }
233
+
234
+ .#{$prefix}--side-nav__submenu-chevron > svg {
235
+ width: calcRem(16px);
236
+ height: calcRem(16px);
237
+ transition: transform $duration-fast-02;
238
+ }
239
+
240
+ .#{$prefix}--side-nav__submenu[aria-expanded="true"]
241
+ .#{$prefix}--side-nav__submenu-chevron
242
+ > svg {
243
+ transform: rotate(180deg);
244
+ }
245
+
246
+ .#{$prefix}--side-nav__item--large .#{$prefix}--side-nav__submenu {
247
+ height: mini-units(6);
248
+ }
249
+
250
+ .#{$prefix}--side-nav__item--active .#{$prefix}--side-nav__submenu:hover {
251
+ //the active className is used for selected styles, hence using the selected tokens
252
+ background-color: $background-selected;
253
+ color: $text-body-default;
254
+ }
255
+
256
+ .#{$prefix}--side-nav__item--active
257
+ .#{$prefix}--side-nav__submenu[aria-expanded="false"] {
258
+ position: relative;
259
+ background-color: $background-selected;
260
+ color: $text-body-default;
261
+ &::before {
262
+ position: absolute;
263
+ top: 0;
264
+ bottom: 0;
265
+ left: 0;
266
+ width: 3px;
267
+ background-color: $border-interactive;
268
+ content: "";
269
+ }
270
+ }
271
+
272
+ .#{$prefix}--side-nav__item--active .#{$prefix}--side-nav__submenu-title {
273
+ color: $text-body-default;
274
+ font-weight: 600;
275
+ }
276
+
277
+ .#{$prefix}--side-nav__item--active .#{$prefix}--side-nav__icon > svg {
278
+ fill: $icon-primary;
279
+ }
280
+
281
+ .#{$prefix}--side-nav__menu {
282
+ display: block;
283
+ max-height: 0;
284
+ visibility: hidden;
285
+ }
286
+
287
+ .#{$prefix}--side-nav__submenu[aria-expanded="true"]
288
+ + .#{$prefix}--side-nav__menu {
289
+ max-height: calcRem(1500px);
290
+ visibility: inherit;
291
+ }
292
+
293
+ .#{$prefix}--side-nav__menu a.#{$prefix}--side-nav__link {
294
+ height: mini-units(4);
295
+ min-height: mini-units(4);
296
+ padding-left: mini-units(4);
297
+ font-weight: 400;
298
+ }
299
+
300
+ .#{$prefix}--side-nav__item.#{$prefix}--side-nav__item--icon
301
+ a.#{$prefix}--side-nav__link {
302
+ padding-left: mini-units(9);
303
+ }
304
+ .#{$prefix}--side-nav__menu a.#{$prefix}--side-nav__link--current,
305
+ .#{$prefix}--side-nav__menu a.#{$prefix}--side-nav__link[aria-current="page"],
306
+ a.#{$prefix}--side-nav__link--current {
307
+ background-color: $background-selected;
308
+
309
+ > span {
310
+ color: $text-body-default;
311
+ font-weight: 600;
312
+ }
313
+ }
314
+
315
+ //----------------------------------------------------------------------------
316
+ // Side-nav > Link
317
+ //----------------------------------------------------------------------------
318
+ a.#{$prefix}--side-nav__link,
319
+ .#{$prefix}--side-nav a.#{$prefix}--header__menu-item,
320
+ .#{$prefix}--side-nav
321
+ .#{$prefix}--header__menu-title[aria-expanded="true"]
322
+ + .#{$prefix}--header__menu {
323
+ @include focus-outline("reset");
324
+ @include type-style("productive-heading-01");
325
+
326
+ position: relative;
327
+ display: flex;
328
+ min-height: mini-units(4);
329
+ align-items: center;
330
+ padding: 0 mini-units(2);
331
+ text-decoration: none;
332
+ transition: color $duration-fast-02, background-color $duration-fast-02,
333
+ outline $duration-fast-02;
334
+ }
335
+
336
+ .#{$prefix}--side-nav__item--large a.#{$prefix}--side-nav__link {
337
+ height: mini-units(6);
338
+ }
339
+
340
+ a.#{$prefix}--side-nav__link > .#{$prefix}--side-nav__link-text,
341
+ .#{$prefix}--side-nav
342
+ a.#{$prefix}--header__menu-item
343
+ .#{$prefix}--text-truncate-end {
344
+ @include text-overflow();
345
+
346
+ color: $text-body-secondary;
347
+ font-size: calcRem(14px);
348
+ letter-spacing: 0.1px;
349
+ line-height: 1.25rem;
350
+ user-select: none;
351
+ }
352
+
353
+ a.#{$prefix}--side-nav__link:focus,
354
+ .#{$prefix}--side-nav a.#{$prefix}--header__menu-item:focus {
355
+ @include focus-outline("outline");
356
+ }
357
+
358
+ a.#{$prefix}--side-nav__link[aria-current="page"],
359
+ a.#{$prefix}--side-nav__link--current {
360
+ background-color: $background-selected;
361
+ font-weight: 600;
362
+ }
363
+
364
+ a.#{$prefix}--side-nav__link[aria-current="page"]
365
+ .#{$prefix}--side-nav__link-text,
366
+ a.#{$prefix}--side-nav__link--current .#{$prefix}--side-nav__link-text {
367
+ color: $text-body-default;
368
+ }
369
+
370
+ a.#{$prefix}--side-nav__link[aria-current="page"]::before,
371
+ a.#{$prefix}--side-nav__link--current::before {
372
+ position: absolute;
373
+ top: 0;
374
+ bottom: 0;
375
+ left: 0;
376
+ width: 3px;
377
+ background-color: $border-interactive;
378
+ content: "";
379
+ }
380
+
381
+ //----------------------------------------------------------------------------
382
+ // Side-nav > Icons
383
+ //----------------------------------------------------------------------------
384
+ .#{$prefix}--side-nav__icon {
385
+ display: flex;
386
+ // Helpful in flex containers so the icon does not have less than the
387
+ // expected width
388
+ flex: 0 0 mini-units(2);
389
+ align-items: center;
390
+ justify-content: center;
391
+ }
392
+
393
+ .#{$prefix}--side-nav__icon:not(.#{$prefix}--side-nav__submenu-chevron) {
394
+ margin-right: mini-units(3);
395
+ }
396
+
397
+ .#{$prefix}--side-nav__icon > svg {
398
+ width: mini-units(2);
399
+ height: mini-units(2);
400
+ fill: $icon-secondary;
401
+ }
402
+
403
+ .#{$prefix}--side-nav__icon > svg.#{$prefix}--side-nav-collapse-icon {
404
+ display: none;
405
+ }
406
+
407
+ .#{$prefix}--side-nav--expanded
408
+ .#{$prefix}--side-nav__icon
409
+ > svg.#{$prefix}--side-nav-expand-icon {
410
+ display: none;
411
+ }
412
+
413
+ .#{$prefix}--side-nav--expanded
414
+ .#{$prefix}--side-nav__icon
415
+ > svg.#{$prefix}--side-nav-collapse-icon {
416
+ display: block;
417
+ }
418
+
419
+ //----------------------------------------------------------------------------
420
+ // Variants - Fixed
421
+ //----------------------------------------------------------------------------
422
+ .#{$prefix}--side-nav--fixed a.#{$prefix}--side-nav__link,
423
+ .#{$prefix}--side-nav--fixed .#{$prefix}--side-nav__submenu {
424
+ padding-left: mini-units(2);
425
+ }
426
+
427
+ .#{$prefix}--side-nav--fixed
428
+ .#{$prefix}--side-nav__item:not(.#{$prefix}--side-nav__item--icon)
429
+ .#{$prefix}--side-nav__menu
430
+ a.#{$prefix}--side-nav__link {
431
+ padding-left: mini-units(4);
432
+ }
433
+
434
+ //----------------------------------------------------------------------------
435
+ // Variants - Header Nav Links in Side Nav
436
+ //----------------------------------------------------------------------------
437
+ .#{$prefix}--side-nav .#{$prefix}--header__nav {
438
+ @include breakpoint-down("lg") {
439
+ display: block;
440
+ }
441
+ }
442
+
443
+ .#{$prefix}--side-nav__header-navigation {
444
+ display: none;
445
+
446
+ @include breakpoint-down("lg") {
447
+ position: relative;
448
+ display: block;
449
+ margin-bottom: calcRem(32px);
450
+ }
451
+ }
452
+
453
+ .#{$prefix}--side-nav__header-divider::after {
454
+ position: absolute;
455
+ bottom: calcRem(-16px);
456
+ left: calcRem(16px);
457
+ width: calc(100% - 32px);
458
+ height: calcRem(1px);
459
+ background: $border-subtle;
460
+ content: "";
461
+ }
462
+
463
+ //header menu items overrides
464
+ .#{$prefix}--side-nav a.#{$prefix}--header__menu-item {
465
+ justify-content: space-between;
466
+ color: $text-body-secondary;
467
+ white-space: nowrap;
468
+
469
+ &[aria-expanded="true"] {
470
+ background-color: transparent;
471
+ }
472
+ }
473
+
474
+ .#{$prefix}--side-nav
475
+ .#{$prefix}--header__menu-title[aria-expanded="true"]
476
+ + .#{$prefix}--header__menu {
477
+ bottom: inherit;
478
+ width: 100%;
479
+ padding: 0;
480
+ background-color: transparent;
481
+ box-shadow: none;
482
+ transform: none;
483
+
484
+ li {
485
+ width: 100%;
486
+ }
487
+
488
+ a.#{$prefix}--header__menu-item {
489
+ padding-left: 4.25rem;
490
+ font-weight: 400;
491
+ }
492
+
493
+ a.#{$prefix}--header__menu-item:hover {
494
+ background-color: $background-hover;
495
+ color: $text-body-default;
496
+ }
497
+ }
498
+
499
+ .#{$prefix}--side-nav
500
+ .#{$prefix}--header__menu
501
+ a.#{$prefix}--header__menu-item {
502
+ height: inherit;
503
+ }
504
+
505
+ .#{$prefix}--side-nav
506
+ a.#{$prefix}--header__menu-item:hover
507
+ .#{$prefix}--header__menu-arrow,
508
+ .#{$prefix}--side-nav
509
+ a.#{$prefix}--header__menu-item:focus
510
+ .#{$prefix}--header__menu-arrow,
511
+ .#{$prefix}--side-nav .#{$prefix}--header__menu-arrow {
512
+ fill: $icon-secondary;
513
+ }
514
+
515
+ // Windows HCM fix
516
+ .#{$prefix}--side-nav__icon > svg,
517
+ .#{$prefix}--side-nav
518
+ a.#{$prefix}--header__menu-item:hover
519
+ .#{$prefix}--header__menu-arrow,
520
+ .#{$prefix}--side-nav
521
+ a.#{$prefix}--header__menu-item:focus
522
+ .#{$prefix}--header__menu-arrow,
523
+ .#{$prefix}--side-nav .#{$prefix}--header__menu-arrow {
524
+ @include high-contrast-mode("icon-fill");
525
+ }
526
+ }
@@ -0,0 +1,11 @@
1
+ //
2
+ // Copyright IBM Corp. 2018, 2018
3
+ //
4
+ // This source code is licensed under the Apache-2.0 license found in the
5
+ // LICENSE file in the root directory of this source tree.
6
+ //
7
+
8
+ @forward 'switcher';
9
+ @use 'switcher';
10
+
11
+ @include switcher.switcher;
@@ -0,0 +1,78 @@
1
+ //
2
+ // Copyright IBM Corp. 2016, 2018
3
+ //
4
+ // This source code is licensed under the Apache-2.0 license found in the
5
+ // LICENSE file in the root directory of this source tree.
6
+ //
7
+
8
+ @use "../../../config" as *;
9
+ @use "../../../spacing" as *;
10
+ @use "../../../theme" as *;
11
+ @use "../../../type" as *;
12
+ @use "../../../utilities/convert" as *;
13
+
14
+ /// UI shell side nav
15
+ /// @access private
16
+ /// @group ui-shell
17
+ @mixin switcher {
18
+ //----------------------------------------------------------------------------
19
+ // Header Switcher
20
+ //----------------------------------------------------------------------------
21
+ .#{$prefix}--switcher {
22
+ display: flex;
23
+ flex-direction: column;
24
+ align-items: center;
25
+ justify-content: center;
26
+ color: $text-body-secondary;
27
+ }
28
+
29
+ .#{$prefix}--switcher__item {
30
+ width: 100%;
31
+ height: $spacing-07;
32
+ }
33
+
34
+ .#{$prefix}--switcher__item:nth-child(1) {
35
+ margin-top: $spacing-05;
36
+ }
37
+
38
+ .#{$prefix}--switcher__item--divider {
39
+ display: block;
40
+ width: calcRem(224px);
41
+ height: 1px;
42
+ border: none;
43
+ margin: $spacing-03 $spacing-05;
44
+ background: $border-subtle;
45
+ }
46
+
47
+ .#{$prefix}--switcher__item-link {
48
+ @include type-style("productive-heading-01");
49
+
50
+ display: block;
51
+ height: $spacing-07;
52
+ padding: calcRem(6px) $spacing-05;
53
+ color: $text-body-secondary;
54
+ text-decoration: none;
55
+
56
+ &:hover:not(.#{$prefix}--switcher__item-link--selected) {
57
+ background: $layer-hover;
58
+ color: $text-body-default;
59
+ cursor: pointer;
60
+ }
61
+
62
+ &:focus {
63
+ outline: 2px solid $focus;
64
+ outline-offset: -2px;
65
+ }
66
+
67
+ &:active {
68
+ background: $layer-active;
69
+ color: $text-body-default;
70
+ }
71
+ }
72
+
73
+ .#{$prefix}--switcher__item-link--selected {
74
+ //TO-DO: should we add a 3px left border-interactive here too? Doesn't currently have it, but specs have it
75
+ background: $layer-selected;
76
+ color: $text-body-default;
77
+ }
78
+ }
@@ -0,0 +1,11 @@
1
+ //
2
+ // Copyright IBM Corp. 2018, 2018
3
+ //
4
+ // This source code is licensed under the Apache-2.0 license found in the
5
+ // LICENSE file in the root directory of this source tree.
6
+ //
7
+
8
+ @forward 'unit';
9
+ @use 'unit';
10
+
11
+ @include unit.unit;