@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,581 @@
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 "../../motion" as *;
10
+ @use "../../spacing" as *;
11
+ @use "../../theme" as *;
12
+ @use "../../type" as *;
13
+ @use "../copy-button";
14
+ @use "../../utilities/convert" as *;
15
+ @use "../../utilities/focus-outline" as *;
16
+ @use "../../utilities/high-contrast-mode" as *;
17
+ @use "../../utilities/keyframes" as *;
18
+ @use "../../utilities/skeleton" as *;
19
+ @use "../../utilities/tooltip" as *;
20
+ @use "../../utilities/z-index" as *;
21
+ @use "mixins" as *;
22
+
23
+ /// @type Color
24
+ /// @access public
25
+ /// @group copy-button
26
+ $copy-active: $layer-active !default;
27
+
28
+ /// @type Color
29
+ /// @access public
30
+ /// @group copy-button
31
+ $copy-btn-feedback: $background-inverse !default;
32
+
33
+ @mixin code-snippet {
34
+ .#{$prefix}--snippet {
35
+ @include reset;
36
+ }
37
+
38
+ .#{$prefix}--snippet--disabled,
39
+ .#{$prefix}--snippet--disabled
40
+ .#{$prefix}--btn.#{$prefix}--snippet-btn--expand {
41
+ background-color: $layer-disabled;
42
+ color: $text-disabled;
43
+ }
44
+
45
+ .#{$prefix}--snippet--disabled .#{$prefix}--snippet-btn--expand:hover,
46
+ .#{$prefix}--snippet--disabled .#{$prefix}--copy-btn:hover {
47
+ background-color: $layer-disabled;
48
+ color: $text-disabled;
49
+ cursor: not-allowed;
50
+ }
51
+
52
+ .#{$prefix}--snippet--disabled .#{$prefix}--snippet__icon,
53
+ .#{$prefix}--snippet--disabled
54
+ .#{$prefix}--snippet-btn--expand
55
+ .#{$prefix}--icon-chevron--down {
56
+ fill: $icon-disabled;
57
+ }
58
+
59
+ .#{$prefix}--snippet code {
60
+ @include type-style("code-01");
61
+ }
62
+
63
+ // Inline Code Snippet
64
+ .#{$prefix}--snippet--inline {
65
+ @include reset;
66
+
67
+ position: relative;
68
+ display: inline;
69
+ padding: 0;
70
+ border: 2px solid transparent;
71
+ background-color: $fill-field;
72
+ border-radius: 4px;
73
+ color: $text-body-default;
74
+ cursor: pointer;
75
+
76
+ &:hover {
77
+ background-color: $layer-accent;
78
+ }
79
+
80
+ &:active {
81
+ background-color: $copy-active;
82
+ }
83
+
84
+ &:focus {
85
+ border: 2px solid $focus;
86
+ outline: none;
87
+ }
88
+
89
+ &::before {
90
+ @include tooltip--caret;
91
+
92
+ display: none;
93
+ }
94
+
95
+ .#{$prefix}--copy-btn__feedback {
96
+ @include tooltip--content("icon");
97
+
98
+ display: none;
99
+ overflow: visible;
100
+ box-sizing: content-box;
101
+ margin: auto;
102
+ clip: auto;
103
+ }
104
+
105
+ @include tooltip--placement("icon", "bottom", "center");
106
+ }
107
+
108
+ .#{$prefix}--snippet--inline.#{$prefix}--copy-btn--animating::before,
109
+ .#{$prefix}--snippet--inline.#{$prefix}--copy-btn--animating
110
+ .#{$prefix}--copy-btn__feedback {
111
+ display: block;
112
+ }
113
+
114
+ .#{$prefix}--snippet--inline.#{$prefix}--copy-btn--animating.#{$prefix}--copy-btn--fade-out::before,
115
+ .#{$prefix}--snippet--inline.#{$prefix}--copy-btn--animating.#{$prefix}--copy-btn--fade-out
116
+ .#{$prefix}--copy-btn__feedback {
117
+ animation: $duration-fast-02 motion(standard, productive) hide-feedback;
118
+ }
119
+
120
+ .#{$prefix}--snippet--inline.#{$prefix}--copy-btn--animating.#{$prefix}--copy-btn--fade-in::before,
121
+ .#{$prefix}--snippet--inline.#{$prefix}--copy-btn--animating.#{$prefix}--copy-btn--fade-in
122
+ .#{$prefix}--copy-btn__feedback {
123
+ animation: $duration-fast-02 motion(standard, productive) show-feedback;
124
+ }
125
+
126
+ .#{$prefix}--snippet--inline code {
127
+ padding: 0 $spacing-03;
128
+ }
129
+
130
+ .#{$prefix}--snippet--inline.#{$prefix}--snippet--no-copy {
131
+ display: inline-block;
132
+
133
+ &:hover {
134
+ background-color: $fill-field;
135
+ cursor: auto;
136
+ }
137
+ }
138
+
139
+ .#{$prefix}--snippet--light.#{$prefix}--snippet--inline.#{$prefix}--snippet--no-copy:hover {
140
+ //TODO: background-color: $field-02;
141
+ cursor: auto;
142
+ }
143
+
144
+ // Single Line Snippet
145
+ .#{$prefix}--snippet--single {
146
+ @include bx--snippet;
147
+
148
+ display: flex;
149
+ height: $spacing-08;
150
+ align-items: center;
151
+ padding-right: $spacing-08;
152
+ }
153
+
154
+ .#{$prefix}--snippet--single.#{$prefix}--snippet--no-copy {
155
+ padding: 0;
156
+
157
+ &::after {
158
+ right: $spacing-05;
159
+ }
160
+ }
161
+
162
+ .#{$prefix}--snippet--single .#{$prefix}--snippet-container {
163
+ position: relative;
164
+ display: flex;
165
+ height: 100%;
166
+ align-items: center;
167
+ padding-left: $spacing-05;
168
+ overflow-x: auto;
169
+
170
+ &:focus {
171
+ @include focus-outline("outline");
172
+ }
173
+ }
174
+
175
+ .#{$prefix}--snippet--single pre {
176
+ @include type-style("code-01");
177
+
178
+ padding-right: $spacing-03;
179
+ }
180
+
181
+ // Preserve whitespace, but don't allow wrapping for inline and single
182
+ .#{$prefix}--snippet--single pre,
183
+ .#{$prefix}--snippet--inline code {
184
+ white-space: pre;
185
+ }
186
+
187
+ // Multi Line Snippet
188
+ .#{$prefix}--snippet--multi {
189
+ @include bx--snippet;
190
+
191
+ display: flex;
192
+ padding: $spacing-05;
193
+ }
194
+
195
+ //collapsed snippet container
196
+ .#{$prefix}--snippet--multi .#{$prefix}--snippet-container {
197
+ position: relative;
198
+ min-height: 100%;
199
+ max-height: 100%;
200
+ order: 1;
201
+ overflow-y: auto;
202
+ transition: max-height $duration-moderate-01 motion(standard, productive);
203
+ }
204
+
205
+ // expanded snippet container
206
+ .#{$prefix}--snippet--multi.#{$prefix}--snippet--expand
207
+ .#{$prefix}--snippet-container {
208
+ padding-bottom: $spacing-05;
209
+ transition: max-height $duration-moderate-01 motion(standard, productive);
210
+ }
211
+
212
+ .#{$prefix}--snippet--multi.#{$prefix}--snippet--wraptext pre {
213
+ white-space: pre-wrap;
214
+ word-wrap: break-word;
215
+ }
216
+
217
+ // collapsed pre
218
+ .#{$prefix}--snippet--multi .#{$prefix}--snippet-container pre {
219
+ padding-right: $spacing-08;
220
+ padding-bottom: calcRem(24px);
221
+ overflow-x: auto;
222
+ }
223
+
224
+ .#{$prefix}--snippet--multi.#{$prefix}--snippet--no-copy
225
+ .#{$prefix}--snippet-container
226
+ pre {
227
+ padding-right: 0;
228
+ }
229
+
230
+ // expanded pre
231
+ .#{$prefix}--snippet--multi.#{$prefix}--snippet--expand
232
+ .#{$prefix}--snippet-container
233
+ pre {
234
+ overflow-x: auto;
235
+ }
236
+
237
+ .#{$prefix}--snippet--multi .#{$prefix}--snippet-container pre::after {
238
+ position: absolute;
239
+ top: 0;
240
+ right: 0;
241
+ width: calcRem(16px);
242
+ height: 100%;
243
+ // Safari interprets `transparent` differently, so make color token value transparent instead:
244
+ background-image: linear-gradient(to right, rgba($field, 0), $field);
245
+ content: "";
246
+ }
247
+
248
+ .#{$prefix}--snippet--multi .#{$prefix}--snippet-container pre code {
249
+ overflow: hidden;
250
+ }
251
+
252
+ //Copy Button
253
+ .#{$prefix}--snippet__icon {
254
+ width: calcRem(16px);
255
+ height: calcRem(16px);
256
+ fill: $icon-primary;
257
+ transition: all $duration-fast-01 motion(standard, productive);
258
+ }
259
+
260
+ .#{$prefix}--snippet-button {
261
+ @include reset;
262
+
263
+ position: absolute;
264
+ top: 0;
265
+ right: 0;
266
+ display: flex;
267
+ overflow: visible;
268
+ width: $spacing-08;
269
+ height: $spacing-08;
270
+ align-items: center;
271
+ justify-content: center;
272
+ padding: 0;
273
+ border: none;
274
+ background-color: $fill-field;
275
+ cursor: pointer;
276
+ outline: none;
277
+
278
+ &:focus {
279
+ @include focus-outline("outline");
280
+
281
+ outline-color: $focus;
282
+ }
283
+ }
284
+
285
+ .#{$prefix}--snippet--multi .#{$prefix}--snippet-button {
286
+ top: $spacing-03;
287
+ right: $spacing-03;
288
+ width: $spacing-07;
289
+ height: $spacing-07;
290
+ }
291
+
292
+ .#{$prefix}--snippet-button:hover {
293
+ background: $field-hover;
294
+ }
295
+
296
+ .#{$prefix}--snippet-button:active {
297
+ background-color: $copy-active;
298
+ }
299
+
300
+ .#{$prefix}--btn--copy__feedback {
301
+ @include type-style("body-short");
302
+ @include font-family("sans");
303
+
304
+ z-index: z("overlay");
305
+ top: 0.75rem;
306
+ right: 1.25rem;
307
+ left: inherit;
308
+ font-weight: 400;
309
+ }
310
+
311
+ .#{$prefix}--btn--copy__feedback::before,
312
+ .#{$prefix}--btn--copy__feedback::after {
313
+ background: $copy-btn-feedback;
314
+ }
315
+
316
+ .#{$prefix}--btn--copy__feedback::after {
317
+ border: none;
318
+ }
319
+
320
+ // TODO: remove copy button styles above
321
+ .#{$prefix}--snippet .#{$prefix}--copy-btn {
322
+ @include font-family("sans");
323
+
324
+ position: absolute;
325
+ top: 0;
326
+ right: 0;
327
+ }
328
+
329
+ // Show more / less button
330
+ .#{$prefix}--snippet-btn--expand {
331
+ @include type-style("body-short");
332
+ @include font-family("sans");
333
+
334
+ position: absolute;
335
+ z-index: 10;
336
+ right: 0;
337
+ bottom: 0;
338
+ display: inline-flex;
339
+ align-items: center;
340
+
341
+ padding: $spacing-03 $spacing-05;
342
+ border: 0;
343
+ background-color: $fill-field;
344
+ color: $text-body-default;
345
+ }
346
+
347
+ .#{$prefix}--snippet-btn--expand .#{$prefix}--snippet-btn--text {
348
+ position: relative;
349
+ top: calcRem(-1px);
350
+ }
351
+
352
+ .#{$prefix}--snippet-btn--expand--hide.#{$prefix}--snippet-btn--expand {
353
+ display: none;
354
+ }
355
+
356
+ .#{$prefix}--snippet-btn--expand .#{$prefix}--icon-chevron--down {
357
+ margin-left: $spacing-03;
358
+ fill: $icon-primary;
359
+ transform: rotate(0deg);
360
+ transition: $duration-moderate-01 motion(standard, productive);
361
+ }
362
+
363
+ .#{$prefix}--snippet-btn--expand:hover {
364
+ background: $field-hover;
365
+ color: $text-body-default;
366
+ }
367
+
368
+ .#{$prefix}--snippet-btn--expand:active {
369
+ background-color: $copy-active;
370
+ }
371
+
372
+ .#{$prefix}--snippet-btn--expand:focus {
373
+ @include focus-outline("outline");
374
+
375
+ border-color: transparent;
376
+ }
377
+
378
+ .#{$prefix}--snippet--expand
379
+ .#{$prefix}--snippet-btn--expand
380
+ .#{$prefix}--icon-chevron--down {
381
+ transform: rotate(180deg);
382
+ transition: transform $transition--expansion;
383
+ }
384
+
385
+ // Light version
386
+ .#{$prefix}--snippet--light,
387
+ .#{$prefix}--snippet--light .#{$prefix}--snippet-button,
388
+ .#{$prefix}--snippet--light .#{$prefix}--btn.#{$prefix}--snippet-btn--expand,
389
+ .#{$prefix}--snippet--light .#{$prefix}--copy-btn {
390
+ //TODO: background-color: $field-02;
391
+ }
392
+
393
+ .#{$prefix}--snippet--light.#{$prefix}--snippet--inline:hover,
394
+ .#{$prefix}--snippet--light .#{$prefix}--snippet-button:hover,
395
+ .#{$prefix}--snippet--light
396
+ .#{$prefix}--btn.#{$prefix}--snippet-btn--expand:hover,
397
+ .#{$prefix}--snippet--light .#{$prefix}--copy-btn:hover {
398
+ background-color: $hover-light-ui;
399
+ }
400
+
401
+ .#{$prefix}--snippet--light.#{$prefix}--snippet--inline:active,
402
+ .#{$prefix}--snippet--light .#{$prefix}--snippet-button:active,
403
+ .#{$prefix}--snippet--light
404
+ .#{$prefix}--btn.#{$prefix}--snippet-btn--expand:active,
405
+ .#{$prefix}--snippet--light .#{$prefix}--copy-btn:active {
406
+ background-color: $active-light-ui;
407
+ }
408
+
409
+ .#{$prefix}--snippet--light.#{$prefix}--snippet--single::after,
410
+ .#{$prefix}--snippet--light.#{$prefix}--snippet--multi
411
+ .#{$prefix}--snippet-container
412
+ pre::after {
413
+ // Safari interprets `transparent` differently, so make color token value transparent instead:
414
+ background-image: linear-gradient(to right, rgba($field-02, 0), $field-02);
415
+ }
416
+
417
+ // Skeleton State
418
+ .#{$prefix}--snippet.#{$prefix}--skeleton .#{$prefix}--snippet-container {
419
+ width: 100%;
420
+ height: 100%;
421
+ }
422
+
423
+ .#{$prefix}--snippet-button .#{$prefix}--btn--copy__feedback {
424
+ // (The height of button) + (The height of the tooltip's triangle) + 4px
425
+ top: calcRem(50.8px);
426
+ right: auto;
427
+ left: 50%;
428
+
429
+ &::before {
430
+ top: 0;
431
+ }
432
+
433
+ &::after {
434
+ top: calcRem(-4px);
435
+ }
436
+ }
437
+
438
+ .#{$prefix}--snippet--multi .#{$prefix}--copy-btn {
439
+ z-index: 10;
440
+ top: $spacing-03;
441
+ right: $spacing-03;
442
+ width: $spacing-07;
443
+ height: $spacing-07;
444
+ }
445
+
446
+ .#{$prefix}--snippet--multi
447
+ .#{$prefix}--snippet-button
448
+ .#{$prefix}--btn--copy__feedback {
449
+ // (The height of button) + (The height of the tooltip's triangle) + 4px
450
+ top: calcRem(42.8px);
451
+ }
452
+
453
+ .#{$prefix}--snippet--inline .#{$prefix}--btn--copy__feedback {
454
+ // TODO: use updated global tooltip mixins under the hood
455
+ // since all of the positioning values for the copy button tooltip are arbitrary hard coded rem values, we need this arbitrary 4px offset to keep the proper tooltip spacing according to the spec
456
+ top: calc(100% - #{rem(4px)});
457
+ right: auto;
458
+ left: 50%;
459
+ }
460
+
461
+ // Overflow Indicator
462
+ .#{$prefix}--snippet__overflow-indicator--left,
463
+ .#{$prefix}--snippet__overflow-indicator--right {
464
+ z-index: 1;
465
+ width: $spacing-05;
466
+ flex: 1 0 auto;
467
+ }
468
+
469
+ .#{$prefix}--snippet__overflow-indicator--left {
470
+ order: 0;
471
+ margin-right: -$spacing-05;
472
+ background-image: linear-gradient(to left, transparent, $field);
473
+ }
474
+
475
+ .#{$prefix}--snippet__overflow-indicator--right {
476
+ order: 2;
477
+ margin-left: -$spacing-05;
478
+ background-image: linear-gradient(to right, transparent, $field);
479
+ }
480
+
481
+ .#{$prefix}--snippet--single .#{$prefix}--snippet__overflow-indicator--right,
482
+ .#{$prefix}--snippet--single .#{$prefix}--snippet__overflow-indicator--left {
483
+ position: absolute;
484
+ width: $spacing-07;
485
+ height: calc(100% - #{$spacing-02});
486
+ }
487
+
488
+ .#{$prefix}--snippet--single .#{$prefix}--snippet__overflow-indicator--right {
489
+ right: $spacing-08;
490
+ }
491
+
492
+ .#{$prefix}--snippet--single.#{$prefix}--snippet--no-copy
493
+ .#{$prefix}--snippet__overflow-indicator--right {
494
+ right: 0;
495
+ }
496
+
497
+ .#{$prefix}--snippet--single
498
+ .#{$prefix}--snippet-container:focus
499
+ ~ .#{$prefix}--snippet__overflow-indicator--right {
500
+ right: calc(#{$spacing-08} + #{rem(2px)});
501
+ }
502
+
503
+ .#{$prefix}--snippet--single
504
+ .#{$prefix}--snippet-container:focus
505
+ + .#{$prefix}--snippet__overflow-indicator--left {
506
+ left: calcRem(2px);
507
+ }
508
+
509
+ .#{$prefix}--snippet--light .#{$prefix}--snippet__overflow-indicator--left {
510
+ background-image: linear-gradient(to left, transparent, $field-02);
511
+ }
512
+
513
+ .#{$prefix}--snippet--light .#{$prefix}--snippet__overflow-indicator--right {
514
+ background-image: linear-gradient(to right, transparent, $field-02);
515
+ }
516
+
517
+ // Safari-only media query
518
+ // since fades won't appear correctly with CSS custom properties
519
+ // see: tabs, code snippet, and modal overflow indicators
520
+ @media not all and (min-resolution: 0.001dpcm) {
521
+ @supports (-webkit-appearance: none) and (stroke-color: transparent) {
522
+ .#{$prefix}--snippet__overflow-indicator--left {
523
+ background-image: linear-gradient(to left, rgba($field, 0), $field);
524
+ }
525
+
526
+ .#{$prefix}--snippet__overflow-indicator--right {
527
+ background-image: linear-gradient(to right, rgba($field, 0), $field);
528
+ }
529
+ }
530
+ }
531
+
532
+ .#{$prefix}--snippet--multi.#{$prefix}--skeleton {
533
+ height: calcRem(98px);
534
+ }
535
+
536
+ .#{$prefix}--snippet--single.#{$prefix}--skeleton {
537
+ height: calcRem(56px);
538
+ }
539
+
540
+ .#{$prefix}--snippet.#{$prefix}--skeleton span {
541
+ @include skeleton;
542
+
543
+ display: block;
544
+ width: 100%;
545
+ height: 1rem;
546
+ margin-top: 0.5rem;
547
+
548
+ &:first-child {
549
+ margin: 0;
550
+ }
551
+
552
+ &:nth-child(2) {
553
+ width: 85%;
554
+ }
555
+
556
+ &:nth-child(3) {
557
+ width: 95%;
558
+ }
559
+ }
560
+
561
+ .#{$prefix}--snippet--single.#{$prefix}--skeleton
562
+ .#{$prefix}--snippet-container {
563
+ padding-bottom: 0;
564
+ }
565
+
566
+ // Windows HCM fix
567
+ /* stylelint-disable */
568
+ .#{$prefix}--snippet__icon {
569
+ @include high-contrast-mode("icon-fill");
570
+ }
571
+
572
+ .#{$prefix}--snippet--inline:focus {
573
+ @include high-contrast-mode("focus");
574
+ }
575
+
576
+ .#{$prefix}--snippet--single,
577
+ .#{$prefix}--snippet--multi {
578
+ @include high-contrast-mode("outline");
579
+ }
580
+ /* stylelint-enable */
581
+ }
@@ -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 'code-snippet';
9
+ @use 'code-snippet';
10
+
11
+ @include code-snippet.code-snippet;
@@ -0,0 +1,21 @@
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 "../../theme" as *;
9
+ @use "../../type" as *;
10
+
11
+ /// Code snippet base styles
12
+ /// @access private
13
+ /// @group code-snippet
14
+ @mixin bx--snippet {
15
+ @include type-style("code-01");
16
+
17
+ position: relative;
18
+ width: 100%;
19
+ max-width: calcRem(768px);
20
+ background-color: $fill-field;
21
+ }
@@ -0,0 +1,54 @@
1
+ //-----------------------------
2
+ // Grid.col
3
+ //-----------------------------
4
+
5
+ // @use '../../config' as *;
6
+ // @use '../../spacing' as *;
7
+ // @use '../../theme' as *;
8
+ // @use '../../type' as *;
9
+ @use "sass:math";
10
+ @use '../../grid' as *;
11
+ @use '../../breakpoint' as *;
12
+ @use '../../config' as *;
13
+
14
+ // @use '../../utilities/focus-outline';
15
+ // @use '../../utilities/high-contrast-mode' as *;
16
+ // @use '../../utilities/skeleton' as *;
17
+ // @use '../../utilities/rtl' as *;
18
+ // @use '../../utilities/tooltip' as *;
19
+ // @use '../../utilities/visually-hidden' as *;
20
+
21
+ @mixin col {
22
+ .#{$prefix}--grid-col {
23
+ height: 100%;
24
+ box-sizing: border-box;
25
+ -webkit-box-flex: 0;
26
+ }
27
+
28
+ @for $i from 1 through 12 {
29
+ .#{$prefix}--col--span-#{$i},
30
+ .#{$prefix}--col--lg--#{$i} {
31
+ @include column-span($i);
32
+ }
33
+ }
34
+
35
+ // 8 columns on small(768) screen
36
+ @include breakpoint-down('md') {
37
+ @for $i from 1 through 8 {
38
+ .#{$prefix}--col--span-#{$i},
39
+ .#{$prefix}--col--lg--#{$i} {
40
+ @include column-span($i, 8);
41
+ }
42
+ }
43
+ }
44
+
45
+ // 8 columns on small(500) screen
46
+ @include breakpoint-down('sm') {
47
+ @for $i from 1 through 4 {
48
+ .#{$prefix}--col--span-#{$i},
49
+ .#{$prefix}--col--lg--#{$i} {
50
+ @include column-span($i, 4);
51
+ }
52
+ }
53
+ }
54
+ }
@@ -0,0 +1,4 @@
1
+ @forward 'col';
2
+ @use 'col';
3
+
4
+ @include col.col;
@@ -0,0 +1,45 @@
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 "../list-box";
9
+ @use "../../config" as *;
10
+ @use "../../theme" as *;
11
+
12
+ /// Combo box styles
13
+ /// @access public
14
+ /// @group combo-box
15
+ @mixin combo-box {
16
+ .#{$prefix}--combo-box:hover {
17
+ background-color: $fill-field;
18
+ }
19
+
20
+ // V11: Possibly deprecate
21
+ .#{$prefix}--combo-box.#{$prefix}--list-box--light:hover {
22
+ //TODO: background-color: $field-02;
23
+ }
24
+
25
+ .#{$prefix}--combo-box .#{$prefix}--text-input::-ms-clear {
26
+ display: none;
27
+ }
28
+
29
+ .#{$prefix}--combo-box.#{$prefix}--list-box--expanded
30
+ .#{$prefix}--text-input {
31
+ border-bottom-color: $border-subtle;
32
+ }
33
+
34
+ .#{$prefix}--combo-box .#{$prefix}--list-box__field,
35
+ .#{$prefix}--combo-box.#{$prefix}--list-box[data-invalid]
36
+ .#{$prefix}--list-box__field,
37
+ .#{$prefix}--combo-box.#{$prefix}--list-box--warning
38
+ .#{$prefix}--list-box__field,
39
+ .#{$prefix}--combo-box.#{$prefix}--list-box--disabled.#{$prefix}--list-box[data-invalid]
40
+ .#{$prefix}--list-box__field,
41
+ .#{$prefix}--combo-box.#{$prefix}--list-box--disabled.#{$prefix}--list-box--warning
42
+ .#{$prefix}--list-box__field {
43
+ padding: 0;
44
+ }
45
+ }