@dscout/particle 0.46.2 → 1.0.0-alpha.2

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 (401) hide show
  1. package/CHANGELOG.md +125 -11
  2. package/lib/components/advanced_options.js +92 -3
  3. package/lib/components/attribute_input.js +215 -0
  4. package/lib/components/attribute_selector.js +106 -22
  5. package/lib/components/avatar.js +98 -7
  6. package/lib/components/blitz.js +118 -8
  7. package/lib/components/button.js +261 -2
  8. package/lib/components/button_control.js +108 -2
  9. package/lib/components/button_icon.js +192 -0
  10. package/lib/components/button_mode.js +174 -2
  11. package/lib/components/button_plain.js +187 -0
  12. package/lib/components/card.js +237 -4
  13. package/lib/components/card_body.js +58 -1
  14. package/lib/components/card_footer.js +76 -2
  15. package/lib/components/cards.js +58 -1
  16. package/lib/components/checkbox_input.js +141 -6
  17. package/lib/components/chip.js +184 -0
  18. package/lib/components/collapsible.js +45 -10
  19. package/lib/components/collapsible_content.js +92 -9
  20. package/lib/components/collapsing_menu.js +102 -4
  21. package/lib/components/column.js +72 -1
  22. package/lib/components/common_button.js +172 -0
  23. package/lib/components/common_input.js +221 -18
  24. package/lib/components/common_menu_item.js +160 -9
  25. package/lib/components/container.js +65 -1
  26. package/lib/components/container_header.js +81 -1
  27. package/lib/components/container_inner.js +50 -1
  28. package/lib/components/controls.js +57 -0
  29. package/lib/components/drag_and_drop.js +173 -10
  30. package/lib/components/dropdown.js +228 -13
  31. package/lib/components/dropdown_input_toggle.js +127 -9
  32. package/lib/components/editing_container.js +157 -14
  33. package/lib/components/email_input.js +207 -0
  34. package/lib/components/file_input.js +125 -3
  35. package/lib/components/flex.js +216 -28
  36. package/lib/components/focus_intent.js +84 -10
  37. package/lib/components/focus_trap.js +103 -2
  38. package/lib/components/footnote.js +60 -1
  39. package/lib/components/formatted_text.js +61 -0
  40. package/lib/components/heading.js +219 -3
  41. package/lib/components/input_addon.js +115 -0
  42. package/lib/components/input_group.js +81 -0
  43. package/lib/components/input_group_item.js +132 -0
  44. package/lib/components/list.js +92 -3
  45. package/lib/components/list_inline.js +91 -3
  46. package/lib/components/media_query.js +52 -5
  47. package/lib/components/menu.js +91 -2
  48. package/lib/components/menu_item.js +116 -1
  49. package/lib/components/menu_item_li.js +152 -11
  50. package/lib/components/menu_link.js +162 -1
  51. package/lib/components/menu_list.js +79 -4
  52. package/lib/components/menu_section.js +66 -2
  53. package/lib/components/menu_title.js +58 -1
  54. package/lib/components/modal.js +223 -22
  55. package/lib/components/modifier.js +241 -14
  56. package/lib/components/number_input.js +215 -0
  57. package/lib/components/password_input.js +207 -0
  58. package/lib/components/pill.js +96 -1
  59. package/lib/components/radio_input.js +133 -5
  60. package/lib/components/range_input.js +128 -5
  61. package/lib/components/row.js +86 -1
  62. package/lib/components/search_input.js +175 -0
  63. package/lib/components/segmented_controls.js +58 -1
  64. package/lib/components/select_input.js +173 -15
  65. package/lib/components/separator.js +137 -6
  66. package/lib/components/speech_bubble.js +126 -8
  67. package/lib/components/swappable_content.js +99 -9
  68. package/lib/components/tags_input.js +199 -15
  69. package/lib/components/text_input.js +207 -0
  70. package/lib/components/textarea.js +187 -11
  71. package/lib/components/theme_provider.js +172 -0
  72. package/lib/components/thumbnail.js +94 -8
  73. package/lib/components/togglable_fieldset.js +110 -14
  74. package/lib/components/toggle.js +93 -1
  75. package/lib/components/tooltip.js +144 -4
  76. package/lib/components/tooltip_container.js +144 -5
  77. package/lib/components/with_addons.js +121 -0
  78. package/lib/icons/alert.js +6 -0
  79. package/lib/icons/amazing_emoticon.js +6 -0
  80. package/lib/icons/analysis.js +6 -0
  81. package/lib/icons/approve_payment.js +6 -0
  82. package/lib/icons/archive.js +6 -0
  83. package/lib/icons/arrow_up.js +6 -0
  84. package/lib/icons/autotag.js +88 -0
  85. package/lib/icons/bell.js +6 -0
  86. package/lib/icons/bookmark.js +26 -2
  87. package/lib/icons/camera.js +6 -0
  88. package/lib/icons/checkbox_check.js +44 -2
  89. package/lib/icons/checkbox_indeterminate.js +44 -2
  90. package/lib/icons/checkmark.js +6 -0
  91. package/lib/icons/{speaker_on.js → checkpoint.js} +14 -13
  92. package/lib/icons/chevron.js +6 -0
  93. package/lib/icons/choice.js +6 -0
  94. package/lib/icons/circle.js +6 -0
  95. package/lib/icons/circle_checkmark.js +88 -0
  96. package/lib/icons/circle_chevron.js +6 -0
  97. package/lib/icons/circle_clone.js +6 -0
  98. package/lib/icons/circle_i.js +6 -0
  99. package/lib/icons/circle_minus.js +6 -0
  100. package/lib/icons/circle_plus.js +6 -0
  101. package/lib/icons/circle_question.js +6 -0
  102. package/lib/icons/circle_x.js +6 -0
  103. package/lib/icons/clip.js +122 -34
  104. package/lib/icons/clock.js +93 -1
  105. package/lib/icons/clone.js +6 -0
  106. package/lib/icons/column.js +81 -0
  107. package/lib/icons/common_svg.js +172 -19
  108. package/lib/icons/download.js +6 -0
  109. package/lib/icons/drag_dots.js +6 -0
  110. package/lib/icons/dscout.js +6 -0
  111. package/lib/icons/edit.js +6 -0
  112. package/lib/icons/email.js +6 -0
  113. package/lib/icons/export.js +6 -0
  114. package/lib/icons/express_mission.js +11 -1
  115. package/lib/icons/express_mission_card.js +6 -0
  116. package/lib/icons/external_link.js +6 -0
  117. package/lib/icons/eye.js +95 -0
  118. package/lib/icons/file_type_text.js +6 -0
  119. package/lib/icons/filter.js +6 -0
  120. package/lib/icons/fit.js +6 -0
  121. package/lib/icons/folder.js +88 -0
  122. package/lib/icons/good_emoticon.js +6 -0
  123. package/lib/icons/grid.js +6 -0
  124. package/lib/icons/grip.js +6 -0
  125. package/lib/icons/heart.js +95 -0
  126. package/lib/icons/highlighter.js +6 -0
  127. package/lib/icons/icon_with_count.js +82 -5
  128. package/lib/icons/image_file.js +6 -0
  129. package/lib/icons/key.js +6 -0
  130. package/lib/icons/knockout.js +6 -0
  131. package/lib/icons/link.js +6 -0
  132. package/lib/icons/live_mission.js +11 -1
  133. package/lib/icons/live_mission_card.js +6 -0
  134. package/lib/icons/live_notes.js +88 -0
  135. package/lib/icons/location.js +88 -0
  136. package/lib/icons/lock.js +88 -0
  137. package/lib/icons/map.js +6 -0
  138. package/lib/icons/media.js +6 -0
  139. package/lib/icons/media_upload.js +6 -0
  140. package/lib/icons/mic.js +95 -0
  141. package/lib/icons/minus.js +6 -0
  142. package/lib/icons/mission.js +11 -1
  143. package/lib/icons/mission_card.js +6 -0
  144. package/lib/icons/mobile.js +88 -0
  145. package/lib/icons/more.js +6 -0
  146. package/lib/icons/note.js +88 -0
  147. package/lib/icons/number.js +6 -0
  148. package/lib/icons/observer.js +6 -0
  149. package/lib/icons/open_ended.js +6 -0
  150. package/lib/icons/payment.js +6 -0
  151. package/lib/icons/pen.js +6 -0
  152. package/lib/icons/pin.js +88 -0
  153. package/lib/icons/play.js +6 -0
  154. package/lib/icons/plus.js +6 -0
  155. package/lib/icons/poor_emoticon.js +6 -0
  156. package/lib/icons/power.js +6 -0
  157. package/lib/icons/profile.js +6 -0
  158. package/lib/icons/prop_types.js +9 -6
  159. package/lib/icons/quotation_mark.js +6 -0
  160. package/lib/icons/radio_circle.js +87 -0
  161. package/lib/icons/randomize.js +6 -0
  162. package/lib/icons/remote.js +6 -0
  163. package/lib/icons/responses.js +6 -0
  164. package/lib/icons/rocket.js +6 -0
  165. package/lib/icons/round_arrow_down_left.js +6 -0
  166. package/lib/icons/round_arrow_right.js +6 -0
  167. package/lib/icons/row.js +81 -0
  168. package/lib/icons/scale.js +6 -0
  169. package/lib/icons/screen.js +95 -0
  170. package/lib/icons/screen_share.js +6 -0
  171. package/lib/icons/screener.js +11 -1
  172. package/lib/icons/screener_card.js +6 -0
  173. package/lib/icons/screener_small.js +6 -0
  174. package/lib/icons/send_payment.js +6 -0
  175. package/lib/icons/settings.js +6 -0
  176. package/lib/icons/settings_alt.js +6 -0
  177. package/lib/icons/share.js +6 -0
  178. package/lib/icons/sidebar.js +6 -0
  179. package/lib/icons/skip_end.js +6 -0
  180. package/lib/icons/sort_asc.js +6 -0
  181. package/lib/icons/sort_desc.js +6 -0
  182. package/lib/icons/speech_bubble.js +95 -0
  183. package/lib/icons/spinner.js +88 -0
  184. package/lib/icons/spinner_progress.js +6 -0
  185. package/lib/icons/spreadsheet_file.js +6 -0
  186. package/lib/icons/stacked_missions.js +6 -0
  187. package/lib/icons/star.js +95 -0
  188. package/lib/icons/stim.js +88 -0
  189. package/lib/icons/summary.js +6 -0
  190. package/lib/icons/tag.js +95 -0
  191. package/lib/icons/tag_group.js +81 -0
  192. package/lib/icons/team.js +6 -0
  193. package/lib/icons/thumbs_down.js +6 -0
  194. package/lib/icons/thumbs_up.js +6 -0
  195. package/lib/icons/translate.js +6 -0
  196. package/lib/icons/trash.js +6 -0
  197. package/lib/icons/triangle_inverted.js +90 -0
  198. package/lib/icons/type_video.js +6 -0
  199. package/lib/icons/upload.js +6 -0
  200. package/lib/icons/video_fast_forward.js +85 -0
  201. package/lib/icons/video_next.js +85 -0
  202. package/lib/icons/video_pause.js +85 -0
  203. package/lib/icons/video_play.js +85 -0
  204. package/lib/icons/video_skip.js +85 -0
  205. package/lib/icons/videocamera.js +95 -0
  206. package/lib/icons/wand.js +6 -0
  207. package/lib/icons/wifi.js +6 -0
  208. package/lib/icons/x.js +6 -0
  209. package/lib/index.js +64 -68
  210. package/lib/stylesheets/particle.css +3710 -4065
  211. package/lib/stylesheets/particle.min.css +1 -2
  212. package/lib/stylesheets/particle.min.css.gz +0 -0
  213. package/lib/utils/class_names.js +8 -4
  214. package/lib/utils/dom.js +8 -4
  215. package/lib/utils/props.js +26 -2
  216. package/lib/utils/strings.js +6 -0
  217. package/lib/utils/types.js +1 -1
  218. package/package.json +10 -6
  219. package/styles/_base.scss +57 -9
  220. package/styles/_mixins.scss +10 -290
  221. package/styles/_reset.scss +12 -21
  222. package/styles/_theme_builder.scss +356 -0
  223. package/styles/_variables.scss +67 -36
  224. package/styles/components/_focus-intent.scss +3 -3
  225. package/styles/components/_icons.scss +0 -7
  226. package/styles/components/_links.scss +0 -36
  227. package/styles/components/attribute_selector/_base.scss +60 -0
  228. package/styles/components/attribute_selector/themes/_bandit.scss +18 -0
  229. package/styles/components/attribute_selector/themes/_researcher.scss +6 -0
  230. package/styles/components/attribute_selector/themes/_theme_builder.scss +33 -0
  231. package/styles/components/{_avatar.scss → avatar/_base.scss} +8 -10
  232. package/styles/components/avatar/themes/_bandit.scss +5 -0
  233. package/styles/components/avatar/themes/_researcher.scss +5 -0
  234. package/styles/components/avatar/themes/_theme_builder.scss +7 -0
  235. package/styles/components/{_blitz.scss → blitz/_base.scss} +14 -10
  236. package/styles/components/blitz/themes/_bandit.scss +5 -0
  237. package/styles/components/blitz/themes/_researcher.scss +6 -0
  238. package/styles/components/blitz/themes/_theme_builder.scss +1 -0
  239. package/styles/components/buttons/_base.scss +510 -0
  240. package/styles/components/buttons/themes/_bandit.scss +25 -0
  241. package/styles/components/buttons/themes/_researcher.scss +6 -0
  242. package/styles/components/buttons/themes/_theme_builder.scss +89 -0
  243. package/styles/components/card/_base.scss +88 -0
  244. package/styles/components/card/themes/_bandit.scss +5 -0
  245. package/styles/components/card/themes/_researcher.scss +5 -0
  246. package/styles/components/card/themes/_theme_builder.scss +25 -0
  247. package/styles/components/chip/_base.scss +38 -0
  248. package/styles/components/chip/themes/_bandit.scss +12 -0
  249. package/styles/components/chip/themes/_researcher.scss +5 -0
  250. package/styles/components/chip/themes/_theme_builder.scss +19 -0
  251. package/styles/components/collapsible/_base.scss +33 -0
  252. package/styles/components/collapsible/themes/_bandit.scss +5 -0
  253. package/styles/components/collapsible/themes/_researcher.scss +5 -0
  254. package/styles/components/collapsible/themes/_theme_builder.scss +1 -0
  255. package/styles/components/container/_base.scss +49 -0
  256. package/styles/components/container/themes/_bandit.scss +6 -0
  257. package/styles/components/container/themes/_researcher.scss +6 -0
  258. package/styles/components/container/themes/_theme_builder.scss +15 -0
  259. package/styles/components/drag_and_drop/_base.scss +46 -0
  260. package/styles/components/drag_and_drop/themes/_bandit.scss +7 -0
  261. package/styles/components/drag_and_drop/themes/_researcher.scss +6 -0
  262. package/styles/components/drag_and_drop/themes/_theme_builder.scss +21 -0
  263. package/styles/components/dropdown/_base.scss +62 -0
  264. package/styles/components/dropdown/themes/_bandit.scss +7 -0
  265. package/styles/components/dropdown/themes/_researcher.scss +6 -0
  266. package/styles/components/dropdown/themes/_theme_builder.scss +5 -0
  267. package/styles/components/footnote/_base.scss +11 -0
  268. package/styles/components/footnote/themes/_bandit.scss +5 -0
  269. package/styles/components/footnote/themes/_researcher.scss +5 -0
  270. package/styles/components/footnote/themes/_theme_builder.scss +1 -0
  271. package/styles/components/grid/_base.scss +41 -0
  272. package/styles/components/grid/themes/_bandit.scss +5 -0
  273. package/styles/components/grid/themes/_researcher.scss +5 -0
  274. package/styles/components/grid/themes/_theme_builder.scss +1 -0
  275. package/styles/components/input_group/_base.scss +74 -0
  276. package/styles/components/input_group/themes/_bandit.scss +7 -0
  277. package/styles/components/input_group/themes/_researcher.scss +6 -0
  278. package/styles/components/input_group/themes/_theme_builder.scss +5 -0
  279. package/styles/components/inputs/_base.scss +84 -0
  280. package/styles/components/inputs/themes/_bandit.scss +30 -0
  281. package/styles/components/inputs/themes/_researcher.scss +6 -0
  282. package/styles/components/inputs/themes/_theme_builder.scss +62 -0
  283. package/styles/components/{_list.scss → list/_base.scss} +39 -47
  284. package/styles/components/list/themes/_bandit.scss +5 -0
  285. package/styles/components/list/themes/_researcher.scss +6 -0
  286. package/styles/components/list/themes/_theme_builder.scss +1 -0
  287. package/styles/components/menu/_base.scss +184 -0
  288. package/styles/components/menu/themes/_bandit.scss +6 -0
  289. package/styles/components/menu/themes/_researcher.scss +6 -0
  290. package/styles/components/menu/themes/_theme_builder.scss +13 -0
  291. package/styles/components/modal/base.scss +69 -0
  292. package/styles/components/modal/themes/_bandit.scss +5 -0
  293. package/styles/components/modal/themes/_researcher.scss +6 -0
  294. package/styles/components/modal/themes/_theme_builder.scss +9 -0
  295. package/styles/components/pill/_base.scss +42 -0
  296. package/styles/components/pill/themes/_bandit.scss +6 -0
  297. package/styles/components/pill/themes/_researcher.scss +6 -0
  298. package/styles/components/pill/themes/_theme_builder.scss +11 -0
  299. package/styles/components/range/_base.scss +85 -0
  300. package/styles/components/range/themes/_bandit.scss +15 -0
  301. package/styles/components/range/themes/_researcher.scss +6 -0
  302. package/styles/components/range/themes/_theme_builder.scss +35 -0
  303. package/styles/components/segmented_controls/_base.scss +71 -0
  304. package/styles/components/segmented_controls/themes/_bandit.scss +6 -0
  305. package/styles/components/segmented_controls/themes/_researcher.scss +6 -0
  306. package/styles/components/segmented_controls/themes/_theme_builder.scss +1 -0
  307. package/styles/components/selectors/_base.scss +153 -0
  308. package/styles/components/selectors/themes/_bandit.scss +49 -0
  309. package/styles/components/selectors/themes/_researcher.scss +6 -0
  310. package/styles/components/selectors/themes/_theme_builder.scss +93 -0
  311. package/styles/components/separator/_base.scss +11 -0
  312. package/styles/components/separator/themes/_bandit.scss +5 -0
  313. package/styles/components/separator/themes/_researcher.scss +6 -0
  314. package/styles/components/separator/themes/_theme_builder.scss +1 -0
  315. package/styles/components/speech_bubble/_base.scss +34 -0
  316. package/styles/components/speech_bubble/themes/_bandit.scss +5 -0
  317. package/styles/components/speech_bubble/themes/_researcher.scss +6 -0
  318. package/styles/components/speech_bubble/themes/_theme_builder.scss +1 -0
  319. package/styles/components/swappable/_base.scss +41 -0
  320. package/styles/components/swappable/themes/_bandit.scss +5 -0
  321. package/styles/components/swappable/themes/_researcher.scss +6 -0
  322. package/styles/components/swappable/themes/_theme_builder.scss +1 -0
  323. package/styles/components/tags/_base.scss +27 -0
  324. package/styles/components/tags/themes/_bandit.scss +5 -0
  325. package/styles/components/tags/themes/_researcher.scss +6 -0
  326. package/styles/components/tags/themes/_theme_builder.scss +1 -0
  327. package/styles/components/thumbnail/_base.scss +32 -0
  328. package/styles/components/thumbnail/themes/_bandit.scss +5 -0
  329. package/styles/components/thumbnail/themes/_researcher.scss +5 -0
  330. package/styles/components/thumbnail/themes/_theme_builder.scss +5 -0
  331. package/styles/components/toggle/_base.scss +83 -0
  332. package/styles/components/toggle/themes/_bandit.scss +26 -0
  333. package/styles/components/toggle/themes/_researcher.scss +6 -0
  334. package/styles/components/toggle/themes/_theme_builder.scss +51 -0
  335. package/styles/components/tooltip/_base.scss +127 -0
  336. package/styles/components/tooltip/themes/_bandit.scss +5 -0
  337. package/styles/components/tooltip/themes/_researcher.scss +6 -0
  338. package/styles/components/tooltip/themes/_theme_builder.scss +1 -0
  339. package/styles/css_variables/_bandit.scss +45 -0
  340. package/styles/css_variables/_researcher.scss +5 -0
  341. package/styles/particle.scss +48 -36
  342. package/styles/themes/_bandit.scss +9 -0
  343. package/styles/themes/_researcher.scss +9 -0
  344. package/styles/utilities/_alignment.scss +199 -0
  345. package/styles/utilities/_borders.scss +50 -0
  346. package/styles/utilities/_colors.scss +606 -0
  347. package/styles/utilities/_dimensions.scss +265 -0
  348. package/styles/utilities/_display.scss +71 -0
  349. package/styles/utilities/_overflow.scss +74 -0
  350. package/styles/utilities/_position.scss +107 -0
  351. package/styles/utilities/_radii.scss +70 -0
  352. package/styles/utilities/_resizing.scss +42 -0
  353. package/styles/utilities/_shadows.scss +74 -0
  354. package/styles/utilities/_spacing.scss +579 -0
  355. package/styles/utilities/_typography.scss +409 -0
  356. package/styles/utilities/_visibility.scss +36 -0
  357. package/styles/utilities/_z_index.scss +24 -0
  358. package/lib/components/bug.js +0 -61
  359. package/lib/components/button_group.js +0 -55
  360. package/lib/components/button_link.js +0 -70
  361. package/lib/components/button_primary.js +0 -112
  362. package/lib/components/button_secondary.js +0 -93
  363. package/lib/components/fieldset.js +0 -59
  364. package/lib/components/scene.js +0 -68
  365. package/lib/components/validation_message.js +0 -49
  366. package/lib/components/with_affix.js +0 -114
  367. package/lib/icons/checkpoint/_checkpoint_filled.js +0 -32
  368. package/lib/icons/checkpoint/_checkpoint_unfilled.js +0 -29
  369. package/lib/icons/checkpoint/checkpoint.js +0 -57
  370. package/lib/utils/colors.js +0 -32
  371. package/styles/_borders.scss +0 -204
  372. package/styles/_colors.scss +0 -847
  373. package/styles/_helpers.scss +0 -660
  374. package/styles/_spacing.scss +0 -753
  375. package/styles/_typography.scss +0 -340
  376. package/styles/components/_affix.scss +0 -74
  377. package/styles/components/_attribute-selector.scss +0 -38
  378. package/styles/components/_bug.scss +0 -285
  379. package/styles/components/_buttons.scss +0 -1366
  380. package/styles/components/_card.scss +0 -113
  381. package/styles/components/_collapsible.scss +0 -30
  382. package/styles/components/_container.scss +0 -62
  383. package/styles/components/_drag_and_drop.scss +0 -42
  384. package/styles/components/_dropdown-input.scss +0 -45
  385. package/styles/components/_dropdown.scss +0 -31
  386. package/styles/components/_file-input.scss +0 -11
  387. package/styles/components/_flex.scss +0 -130
  388. package/styles/components/_footnote.scss +0 -15
  389. package/styles/components/_forms.scss +0 -474
  390. package/styles/components/_grid.scss +0 -90
  391. package/styles/components/_menu.scss +0 -183
  392. package/styles/components/_modal.scss +0 -74
  393. package/styles/components/_pill.scss +0 -101
  394. package/styles/components/_preview.scss +0 -30
  395. package/styles/components/_scene.scss +0 -46
  396. package/styles/components/_segmented-controls.scss +0 -51
  397. package/styles/components/_separator.scss +0 -48
  398. package/styles/components/_speech-bubble.scss +0 -29
  399. package/styles/components/_swappable.scss +0 -38
  400. package/styles/components/_tags.scss +0 -20
  401. package/styles/components/_tooltip.scss +0 -135
@@ -0,0 +1,5 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--researcher {
4
+ @include generate-grid-theme-variables()
5
+ }
@@ -0,0 +1 @@
1
+ @mixin generate-grid-theme-variables() {}
@@ -0,0 +1,74 @@
1
+ @import "../../mixins";
2
+
3
+ @import 'themes/bandit';
4
+ @import 'themes/researcher';
5
+
6
+ .Input-Group {
7
+ align-items: stretch;
8
+ display: flex;
9
+ }
10
+
11
+ .Input-Group__Item {
12
+ margin-bottom: 0;
13
+
14
+ &:not(:first-child) {
15
+ margin-left: var(--Input-Group__Item____left-offset);
16
+ }
17
+
18
+ &:focus-within {
19
+ z-index: 1;
20
+ }
21
+
22
+ .Input-Group__Addon,
23
+ .Input,
24
+ .btn {
25
+ border-radius: 0;
26
+ height: 100%;
27
+ position: relative;
28
+ }
29
+
30
+ &:first-child {
31
+ .Input-Group__Addon,
32
+ .Input,
33
+ .btn {
34
+ @include rounded-left(var(--Input____radius));
35
+ }
36
+ }
37
+
38
+ &:last-child {
39
+ .Input-Group__Addon,
40
+ .Input,
41
+ .btn {
42
+ @include rounded-right(var(--Input____radius));
43
+ }
44
+ }
45
+
46
+ }
47
+
48
+ .Input-Group__Addon {
49
+ align-items: center;
50
+ background-color: var(--Input--Affix____bg-color);
51
+ border: 1px solid var(--Input--Affix____border-color);
52
+ color: var(--Input--Affix____color);
53
+ display: flex;
54
+ flex-shrink: 0;
55
+ font-family: inherit;
56
+ font-size: inherit;
57
+ line-height: var(--Input____line-height);
58
+ margin-bottom: 0;
59
+ padding: var(--Input____padding);
60
+ transition: color var(--Input____transition-duration), border var(--Input____transition-duration);
61
+
62
+ &--mini {
63
+ padding: var(--Input--mini____padding);
64
+ }
65
+
66
+ &--disabled {
67
+ opacity: 0.3;
68
+ pointer-events: none;
69
+ }
70
+
71
+ &--filled {
72
+ border-color: var(--Input--filled____border-color);
73
+ }
74
+ }
@@ -0,0 +1,7 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--bandit {
4
+ @include generate-input-group-theme-variables(
5
+ $Input-Group__Item____left-offset: 0
6
+ )
7
+ }
@@ -0,0 +1,6 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--researcher {
4
+ // The Researcher theme uses the default variables
5
+ @include generate-input-group-theme-variables()
6
+ }
@@ -0,0 +1,5 @@
1
+ @mixin generate-input-group-theme-variables(
2
+ $Input-Group__Item____left-offset: calc(-1 * var(--Input____border-width)),
3
+ ) {
4
+ --Input-Group__Item____left-offset: #{$Input-Group__Item____left-offset};
5
+ }
@@ -0,0 +1,84 @@
1
+ @import 'themes/bandit';
2
+ @import 'themes/researcher';
3
+
4
+ .Input {
5
+ appearance: none;
6
+ background-color: var(--Input____bg-color);
7
+ border: solid var(--Input____border-width) var(--Input____border-color);
8
+ border-radius: var(--Input____radius);
9
+ display: block;
10
+ color: var(--Input____color);
11
+ font-family: inherit;
12
+ font-size: inherit;
13
+ line-height: var(--Input____line-height);
14
+ margin: 0;
15
+ padding: var(--Input____padding);
16
+ text-align: left;
17
+ transition-property: background-color, border, color, opacity;
18
+ transition-duration: var(--Input____transition-duration);
19
+ width: 100%;
20
+
21
+ &::placeholder {
22
+ color: var(--Input--Placeholder____color);
23
+ transition-property: color;
24
+ transition-duration: var(--Input____transition-duration);
25
+ -moz-font-smoothing: antialiased;
26
+ -webkit-font-smoothing: antialiased;
27
+ }
28
+
29
+ &::-webkit-inner-spin-button {
30
+ opacity: 1; // visible number controls in chrome
31
+ }
32
+
33
+ &[type="search"] {
34
+ appearance: textfield;
35
+ border-radius: var(--Input--Search____radius);
36
+ }
37
+
38
+ &[type="search"]::-webkit-search-decoration {
39
+ appearance: none;
40
+ }
41
+ }
42
+
43
+ .Input:disabled,
44
+ .Input--disabled {
45
+ opacity: .3;
46
+ pointer-events: none;
47
+ }
48
+
49
+ .Input--filled {
50
+ background-color: var(--Input--filled____bg-color);
51
+ border: var(--Input____border-width) solid var(--Input--filled____border-color);
52
+ color: var(--Input--filled____color);
53
+ }
54
+
55
+ .Input:invalid,
56
+ .Input--invalid {
57
+ background-color: var(--Input--invalid____bg-color);
58
+ border-color: var(--Input--invalid____border-color);
59
+ color: var(--Input--invalid____color);
60
+ }
61
+
62
+ .Input:focus,
63
+ .Input--focused {
64
+ background-color: var(--Input--focused____bg-color);
65
+ border: var(--Input____border-width) solid var(--Input--focused____border-color);
66
+ color: var(--Input--focused____color);
67
+ outline: none;
68
+ }
69
+
70
+ .Input--mini {
71
+ padding: var(--Input--mini____padding);
72
+ }
73
+
74
+ .File-Input {
75
+ appearance: none;
76
+ left: -1000em;
77
+ position: absolute;
78
+
79
+ &:focus {
80
+ + .File-Input__Label {
81
+ outline: var(--color--dscout) auto 5px;
82
+ }
83
+ }
84
+ }
@@ -0,0 +1,30 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--bandit {
4
+ @include generate-input-theme-variables(
5
+ $Input____bg-color: rgba(var(--color--main-rgb), .06125),
6
+ $Input--focused____bg-color: var(--color--invert),
7
+ $Input--filled____bg-color: rgba(var(--color--main-rgb), .06125),
8
+ $Input--invalid____bg-color: var(--color--invert),
9
+
10
+ $Input____border-color: rgba(var(--color--dscout-rgb), 0),
11
+ $Input--focused____border-color: rgba(var(--color--dscout-rgb), 1),
12
+ $Input--filled____border-color: rgba(var(--color--dscout-rgb), 0),
13
+ $Input--invalid____border-color: rgba(var(--color--alert-rgb), 1),
14
+ $Input____border-width: 2px,
15
+
16
+ $Input____color: var(--color--main),
17
+ $Input--focused____color: var(--color--main),
18
+ $Input--filled____color: var(--color--main),
19
+ $Input--invalid____color: var(--color--main),
20
+ $Input--Placeholder____color: var(--color--gray-2),
21
+
22
+ $Input____padding: .625em .75em,
23
+ $Input____radius: var(--radius--med),
24
+
25
+ $Input--Affix____color: var(--color--gray-1),
26
+ $Input--Affix____bg-color: var(--color--gray-4),
27
+
28
+ $Input--Search____radius: var(--radius--med)
29
+ )
30
+ }
@@ -0,0 +1,6 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--researcher {
4
+ // The Researcher theme uses the default variables
5
+ @include generate-input-theme-variables()
6
+ }
@@ -0,0 +1,62 @@
1
+ @mixin generate-input-theme-variables(
2
+ $Input____bg-color: rgba(var(--color--main-rgb), .02),
3
+ $Input--focused____bg-color: rgba(var(--color--main-rgb), .01),
4
+ $Input--filled____bg-color: rgba(var(--color--main-rgb), .01),
5
+ $Input--invalid____bg-color: rgba(var(--color--alert-rgb), .02),
6
+
7
+ $Input____border-color: var(--color--gray-4),
8
+ $Input--focused____border-color: var(--color--dscout-outline),
9
+ $Input--filled____border-color: var(--color--gray-5),
10
+ $Input--invalid____border-color: var(--color--alert-outline),
11
+ $Input____border-width: 1px,
12
+
13
+ $Input____color: rgba(var(--color--main-rgb), .8),
14
+ $Input--focused____color: rgba(var(--color--main-rgb), .8),
15
+ $Input--filled____color: rgba(var(--color--main-rgb), .8),
16
+ $Input--invalid____color: rgba(var(--color--main-rgb), .8),
17
+
18
+ $Input____line-height: var(--line-height--copy),
19
+ $Input____radius: var(--radius--tiny),
20
+ $Input____transition-duration: var(--timing--hover),
21
+
22
+ $Input____padding: .75em,
23
+ $Input--mini____padding: .25em .75em,
24
+
25
+ $Input--Affix____color: var(--Input____color),
26
+ $Input--Affix____bg-color: var(--color--gray-6),
27
+ $Input--Affix____border-color: $Input____border-color,
28
+
29
+ $Input--Placeholder____color: var(--color--gray-1),
30
+
31
+ $Input--Search____radius: var(--radius--pill)
32
+ ) {
33
+ --Input____bg-color: #{$Input____bg-color};
34
+ --Input--focused____bg-color: #{$Input--focused____bg-color};
35
+ --Input--filled____bg-color: #{$Input--filled____bg-color};
36
+ --Input--invalid____bg-color: #{$Input--invalid____bg-color};
37
+
38
+ --Input____border-color: #{$Input____border-color};
39
+ --Input--focused____border-color: #{$Input--focused____border-color};
40
+ --Input--filled____border-color: #{$Input--filled____border-color};
41
+ --Input--invalid____border-color: #{$Input--invalid____border-color};
42
+ --Input____border-width: #{$Input____border-width};
43
+
44
+ --Input____color: #{$Input____color};
45
+ --Input--focused____color: #{$Input--focused____color};
46
+ --Input--filled____color: #{$Input--filled____color};
47
+ --Input--invalid____color: #{$Input--invalid____color};
48
+
49
+ --Input____line-height: #{$Input____line-height};
50
+ --Input____radius: #{$Input____radius};
51
+ --Input____transition-duration: #{$Input____transition-duration};
52
+
53
+ --Input____padding: #{$Input____padding};
54
+ --Input--mini____padding: #{$Input--mini____padding};
55
+
56
+ --Input--Affix____bg-color: #{$Input--Affix____bg-color};
57
+ --Input--Affix____border-color: #{$Input--Affix____border-color};
58
+
59
+ --Input--Placeholder____color: #{$Input--Placeholder____color};
60
+
61
+ --Input--Search____radius: #{$Input--Search____radius};
62
+ }
@@ -1,36 +1,28 @@
1
- @import '../variables';
2
- @import '../mixins';
1
+ @import 'themes/bandit';
2
+ @import 'themes/researcher';
3
3
 
4
4
  $unicode-space: '\00a0';
5
+ $middot: '\00b7';
5
6
 
6
7
  // === LISTS === //
7
8
 
8
- ul.list,
9
- ol.list,
10
- .list ul,
11
- .list ol {
12
- list-style: none;
13
- padding: 0;
14
- }
15
-
16
- li > ul,
17
- li > ol {
18
- margin-top: $space--s;
19
-
20
- &:first-child {
21
- margin-top: $space--s;
9
+ .List {
10
+ li > ul,
11
+ li > ol {
12
+ margin-top: 0.75em;
13
+
14
+ &:first-child {
15
+ margin-top: 0.75em;
16
+ }
22
17
  }
23
18
  }
24
19
 
25
- .text-align--c ul,
26
- .text-align--c ol,
27
- ul.text-align--c,
28
- ol.text-align--c {
29
- list-style-position: inside;
30
- padding-left: $space--none;
20
+ .List--plain {
21
+ list-style: none;
22
+ padding: 0;
31
23
  }
32
24
 
33
- .list--inline {
25
+ .List--inline {
34
26
  li {
35
27
  display: inline-block;
36
28
  margin-bottom: 0;
@@ -45,7 +37,7 @@ ol.text-align--c {
45
37
  }
46
38
  }
47
39
 
48
- .list--divided-comma {
40
+ .List--divided-comma {
49
41
  li {
50
42
  &::after {
51
43
  content: ',' + $unicode-space;
@@ -57,9 +49,7 @@ ol.text-align--c {
57
49
  }
58
50
  }
59
51
 
60
- .list--divided-custom {
61
- $middot: '\00b7';
62
-
52
+ .List--divided-custom {
63
53
  li {
64
54
  &::after {
65
55
  content: $unicode-space + $middot + $unicode-space;
@@ -73,60 +63,62 @@ ol.text-align--c {
73
63
  }
74
64
  }
75
65
 
76
- .list--fancy {
66
+ .List--fancy {
67
+ padding: 0;
68
+
77
69
  li {
78
70
  list-style: none;
79
- padding-left: grid-units(6);
80
- text-indent: grid-units(-6);
71
+ padding-left: 1.5em;
72
+ text-indent: -1.5em;
81
73
  }
82
74
  }
83
75
 
84
- ul.list--fancy {
76
+ ul.List--fancy {
85
77
  li {
86
78
  &:before {
87
- border-radius: $radius--circle;
88
- box-shadow: inset 0 0 0 $space--1px rgba($color--dscout, .8);
79
+ border-radius: var(--radius--circle);
80
+ box-shadow: inset 0 0 0 1px rgba(var(--color--dscout-rgb), .8);
89
81
  content: '';
90
82
  display: inline-block;
91
- height: grid-units(2);
92
- margin-right: grid-units(4);
83
+ height: .5em;
84
+ margin-right: 1em;
93
85
  transform: translateY(-20%);
94
- width: grid-units(2);
86
+ width: .5em;
95
87
  }
96
88
 
97
89
  ul {
98
90
  padding-left: 0;
99
91
 
100
92
  li:before {
101
- background-color: rgba($color--dscout, .8);
93
+ background-color: rgba(var(--color--dscout-rgb), .8);
102
94
  box-shadow: none;
103
- height: grid-units(1.5);
95
+ height: .375em;
104
96
  transform: translateY(-50%);
105
- width: grid-units(1.5);
97
+ width: .375em;
106
98
  }
107
99
  }
108
100
  }
109
101
  }
110
102
 
111
- ol.list--fancy {
103
+ ol.List--fancy {
112
104
  counter-reset: li;
113
105
 
114
106
  li {
115
107
  &:before {
116
- border: $space--1px solid rgba($color--dscout, .5);
117
- border-radius: $radius--circle;
118
- color: $color--dscout;
108
+ border: 1px solid rgba(var(--color--dscout-rgb), .5);
109
+ border-radius: var(--radius--circle);
110
+ color: var(--color--dscout);
119
111
  content: counter(li);
120
112
  counter-increment: li;
121
113
  display: inline-block;
122
- font-size: $font-size--xxs;
123
- height: $space--base;
114
+ font-size: var(--font-size--xxs);
115
+ height: 2em;
124
116
  line-height: 1.8;
125
- margin-right: grid-units(4);
117
+ margin-right: 1em;
126
118
  text-align: center;
127
119
  text-indent: 0;
128
120
  transform: translateY(-15%);
129
- width: $space--base;
121
+ width: 2em;
130
122
  }
131
123
 
132
124
  ol {
@@ -0,0 +1,5 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--bandit {
4
+ @include generate-list-theme-variables()
5
+ }
@@ -0,0 +1,6 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--researcher {
4
+ // The Researcher theme uses the default variables
5
+ @include generate-list-theme-variables()
6
+ }
@@ -0,0 +1 @@
1
+ @mixin generate-list-theme-variables() {}
@@ -0,0 +1,184 @@
1
+ @import 'themes/bandit';
2
+ @import 'themes/researcher';
3
+
4
+ .Menu {
5
+ li,
6
+ ul {
7
+ margin-bottom: 0;
8
+ }
9
+
10
+ &--contained {
11
+ background-color: var(--Menu____bg-color);
12
+ border-radius: var(--Menu____radius);
13
+ box-shadow: var(--Menu____box-shadow);
14
+ padding: 0.25em 0;
15
+ }
16
+ }
17
+
18
+ .Menu__Divider {
19
+ border-top: 1px solid var(--color--gray-4);
20
+ margin: 0.25em 0;
21
+ padding: 0;
22
+ }
23
+
24
+ .Menu__List {
25
+ list-style: none;
26
+ padding: 0;
27
+ }
28
+
29
+ .Menu__Section {
30
+ margin-bottom: 0;
31
+ }
32
+
33
+ .Menu__Title {
34
+ font-size: var(--font-size--base);
35
+ font-weight: var(--font-weight--bold);
36
+ margin: 0;
37
+ }
38
+
39
+ .Menu__Subtitle {
40
+ background-color: var(--color--gray-6);
41
+ color: var(--color--gray-2);
42
+ font-size: var(--font-size--s);
43
+ font-weight: var(--font-weight--6);
44
+ letter-spacing: var(--tracked--looser);
45
+ margin: 0.25em 0;
46
+ padding: 1em;
47
+ text-transform: uppercase;
48
+ }
49
+
50
+ .Menu__Toggle {
51
+ color: inherit;
52
+ cursor: pointer;
53
+ }
54
+
55
+ // These styles normalize some default properties on buttons, but to keep the
56
+ // specificity as low as possible, `button` is left out of the selector.
57
+ .Menu__Item,
58
+ .Menu__Toggle {
59
+ appearance: none;
60
+ background-color: transparent;
61
+ font-family: inherit;
62
+ font-size: inherit;
63
+ line-height: var(--line-height--copy);
64
+ position: relative;
65
+ text-align: left;
66
+ width: 100%;
67
+
68
+ &:active {
69
+ color: inherit;
70
+ }
71
+
72
+ &[disabled],
73
+ &--disabled {
74
+ opacity: 0.3;
75
+ pointer-events: none;
76
+ }
77
+ }
78
+
79
+ .Menu__Item {
80
+ border-bottom: var(--Menu__Item____border-bottom);
81
+ color: inherit;
82
+ cursor: pointer;
83
+ display: block;
84
+ margin-bottom: 0;
85
+ position: relative;
86
+ transition: background var(--timing--hover);
87
+
88
+ &:hover {
89
+ background-color: var(--Menu__Item--hovered____bg-color);
90
+ border-bottom: var(--Menu__Item____border-bottom);
91
+ }
92
+
93
+ &--selected {
94
+ background-color: var(--Menu__Item--hovered____bg-color);
95
+ }
96
+
97
+ &--active:before {
98
+ background-color: var(--color--dscout);
99
+ content: '';
100
+ display: block;
101
+ height: 100%;
102
+ left: 0;
103
+ position: absolute;
104
+ top: 0px;
105
+ width: 2px;
106
+ }
107
+
108
+ // Menu components do not at this time directly apply the .Menu__Item__dragging and
109
+ // .Menu__Item__ghost classes, as Particle does not provide sorting or drag-n-drop
110
+ // functionality. These classes exist for 3rd party sorting libraries to apply.
111
+
112
+ &--dragging {
113
+ background-color: var(--color--invert);
114
+ box-shadow: var(--shadow--s);
115
+ // Opacity may be applied with inline styles, so we need to use !important
116
+ // to control the opacity of dragging menu items ourselves.
117
+ opacity: 1 !important;
118
+ }
119
+
120
+ &--ghost {
121
+ opacity: 0.3;
122
+ z-index: 1;
123
+ }
124
+ }
125
+
126
+ .Menu--loose {
127
+ --Menu__Item____padding: 1em 2em;
128
+ --Menu__Divider____margin-left: 5.5em;
129
+ }
130
+
131
+ .Menu--tight {
132
+ --Menu__Item____padding: 0.75em 1em;
133
+ --Menu__Divider____margin-left: 4.75em;
134
+ }
135
+
136
+ .Menu__Item,
137
+ .Menu__Title,
138
+ .Menu__Toggle,
139
+ .Menu__Subtitle {
140
+ padding: var(--Menu__Item____padding);
141
+ }
142
+
143
+ .Menu__List--icon-first {
144
+ .Menu__Divider {
145
+ margin-left: var(--Menu__Divider____margin-left);
146
+ }
147
+ }
148
+
149
+ .Menu__List--icon-first {
150
+ .Menu__Item {
151
+ align-items: center;
152
+ display: flex;
153
+
154
+ > .icon {
155
+ margin-right: 2em;
156
+ }
157
+ }
158
+ }
159
+
160
+ .Menu__List--striped {
161
+ --Menu__Item____border-bottom: 1px solid var(--color--gray-4);
162
+ }
163
+
164
+ .Menu__List--striped {
165
+ li:last-child {
166
+ &.Menu__Item,
167
+ .Menu__Item {
168
+ border-bottom: none;
169
+ }
170
+ }
171
+ }
172
+
173
+ .Menu__Toggle {
174
+ .Toggle__Icon {
175
+ color: var(--color--gray-2);
176
+ transition: color var(--timing--hover);
177
+ }
178
+
179
+ &:hover {
180
+ .Toggle__Icon {
181
+ color: var(--color--dscout);
182
+ }
183
+ }
184
+ }
@@ -0,0 +1,6 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--bandit {
4
+ // The Bandit theme uses the default variables
5
+ @include generate-menu-theme-variables();
6
+ }
@@ -0,0 +1,6 @@
1
+ @import 'theme_builder';
2
+
3
+ .theme--researcher {
4
+ // The Researcher theme uses the default variables
5
+ @include generate-menu-theme-variables();
6
+ }
@@ -0,0 +1,13 @@
1
+ @mixin generate-menu-theme-variables(
2
+ $Menu____bg-color: var(--color--invert),
3
+ $Menu____box-shadow: var(--shadow--s),
4
+ $Menu____radius: var(--radius--med),
5
+
6
+ $Menu__Item--hovered____bg-color: rgba(var(--color--main-rgb), .03)
7
+ ) {
8
+ --Menu____bg-color: #{$Menu____bg-color};
9
+ --Menu____box-shadow: #{$Menu____box-shadow};
10
+ --Menu____radius: #{$Menu____radius};
11
+
12
+ --Menu__Item--hovered____bg-color: #{$Menu__Item--hovered____bg-color};
13
+ }