@oliasoft-open-source/react-ui-library 1.0.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 (317) hide show
  1. package/.eslintignore +2 -0
  2. package/.eslintrc.js +125 -0
  3. package/.gitlab-ci.yml +45 -0
  4. package/.husky/pre-commit +4 -0
  5. package/.prettierignore +3 -0
  6. package/.prettierrc +4 -0
  7. package/.storybook/main.js +36 -0
  8. package/.storybook/preview.js +40 -0
  9. package/.storybook/storybook.less +8 -0
  10. package/LICENSE +21 -0
  11. package/README.md +5 -0
  12. package/babel.config.js +31 -0
  13. package/index.js +76 -0
  14. package/jest.config.js +9 -0
  15. package/package.json +136 -0
  16. package/src/components/accordion/accordion.jsx +132 -0
  17. package/src/components/accordion/accordion.module.less +66 -0
  18. package/src/components/accordion/accordion.stories.jsx +171 -0
  19. package/src/components/accordion/chevron/chevron.jsx +12 -0
  20. package/src/components/accordion/chevron/chevron.module.less +12 -0
  21. package/src/components/accordion/helpers/accordion-with-default-toggle.jsx +106 -0
  22. package/src/components/accordion/helpers/accordion-with-default-toggle.module.less +24 -0
  23. package/src/components/actions/actions.jsx +129 -0
  24. package/src/components/actions/actions.module.less +44 -0
  25. package/src/components/actions/actions.shape.js +32 -0
  26. package/src/components/actions/actions.stories.jsx +79 -0
  27. package/src/components/badge/badge.jsx +58 -0
  28. package/src/components/badge/badge.module.less +55 -0
  29. package/src/components/badge/badge.stories.jsx +31 -0
  30. package/src/components/breadcrumb/breadcrumb.jsx +49 -0
  31. package/src/components/breadcrumb/breadcrumb.module.less +39 -0
  32. package/src/components/breadcrumb/breadcrumb.stories.jsx +45 -0
  33. package/src/components/breadcrumb/link.jsx +31 -0
  34. package/src/components/button/button.jsx +156 -0
  35. package/src/components/button/button.module.less +300 -0
  36. package/src/components/button/button.stories.jsx +74 -0
  37. package/src/components/button-group/button-group.jsx +140 -0
  38. package/src/components/button-group/button-group.module.less +24 -0
  39. package/src/components/button-group/button-group.stories-data.jsx +67 -0
  40. package/src/components/button-group/button-group.stories.jsx +63 -0
  41. package/src/components/buttons-and-links.stories.mdx +55 -0
  42. package/src/components/card/card.jsx +51 -0
  43. package/src/components/card/card.module.less +48 -0
  44. package/src/components/card/card.stories.jsx +39 -0
  45. package/src/components/check-box/check-box.jsx +92 -0
  46. package/src/components/check-box/check-box.module.less +101 -0
  47. package/src/components/check-box/check-box.stories.jsx +27 -0
  48. package/src/components/color/color.stories-data.jsx +71 -0
  49. package/src/components/color/color.stories.mdx +37 -0
  50. package/src/components/dialog/dialog.jsx +64 -0
  51. package/src/components/dialog/dialog.module.less +76 -0
  52. package/src/components/divider/divider.jsx +40 -0
  53. package/src/components/divider/divider.module.less +28 -0
  54. package/src/components/divider/divider.stories.jsx +50 -0
  55. package/src/components/drawer/drawer-tabs.jsx +43 -0
  56. package/src/components/drawer/drawer.jsx +150 -0
  57. package/src/components/drawer/drawer.module.less +167 -0
  58. package/src/components/drawer/drawer.stories.jsx +156 -0
  59. package/src/components/empty/empty.jsx +52 -0
  60. package/src/components/empty/empty.module.less +17 -0
  61. package/src/components/empty/empty.stories.jsx +26 -0
  62. package/src/components/file-input/file-input.jsx +101 -0
  63. package/src/components/file-input/file-input.module.less +3 -0
  64. package/src/components/file-input/file-input.stories.jsx +109 -0
  65. package/src/components/form/field.jsx +96 -0
  66. package/src/components/form/field.stories.jsx +101 -0
  67. package/src/components/form/form.module.less +30 -0
  68. package/src/components/form/form.stories.jsx +191 -0
  69. package/src/components/heading/heading.jsx +105 -0
  70. package/src/components/heading/heading.module.less +59 -0
  71. package/src/components/heading/heading.stories.jsx +60 -0
  72. package/src/components/icon/deprecated-icon.jsx +97 -0
  73. package/src/components/icon/icon.jsx +71 -0
  74. package/src/components/icon/icon.module.less +33 -0
  75. package/src/components/icon/icon.stories.jsx +37 -0
  76. package/src/components/icon/icons.example.module.less +4 -0
  77. package/src/components/input/input.jsx +167 -0
  78. package/src/components/input/input.module.less +94 -0
  79. package/src/components/input/input.stories.jsx +28 -0
  80. package/src/components/input-group/input-group-addon/input-group-addon.jsx +36 -0
  81. package/src/components/input-group/input-group-addon/input-group-addon.module.less +31 -0
  82. package/src/components/input-group/input-group.jsx +51 -0
  83. package/src/components/input-group/input-group.module.less +10 -0
  84. package/src/components/input-group/input-group.stories.jsx +77 -0
  85. package/src/components/input-validation.stories.mdx +61 -0
  86. package/src/components/inputs.stories.mdx +201 -0
  87. package/src/components/label/label.jsx +115 -0
  88. package/src/components/label/label.module.less +43 -0
  89. package/src/components/label/label.stories.jsx +60 -0
  90. package/src/components/layout/column/column.jsx +85 -0
  91. package/src/components/layout/column/styles.js +45 -0
  92. package/src/components/layout/column.stories.jsx +60 -0
  93. package/src/components/layout/examples/afe.stories.jsx +180 -0
  94. package/src/components/layout/examples/blowout.stories.jsx +68 -0
  95. package/src/components/layout/examples/casing-loads.stories.jsx +297 -0
  96. package/src/components/layout/examples/formation.stories.jsx +110 -0
  97. package/src/components/layout/examples/projects.stories.jsx +108 -0
  98. package/src/components/layout/examples/reservoirs.stories.jsx +211 -0
  99. package/src/components/layout/examples/site.stories.jsx +263 -0
  100. package/src/components/layout/flex/flex.jsx +48 -0
  101. package/src/components/layout/flex/flex.stories.jsx +54 -0
  102. package/src/components/layout/form-row/form-row.jsx +15 -0
  103. package/src/components/layout/form-row/form-row.module.less +11 -0
  104. package/src/components/layout/grid/grid.jsx +62 -0
  105. package/src/components/layout/grid/grid.stories.jsx +65 -0
  106. package/src/components/layout/page/page.jsx +42 -0
  107. package/src/components/layout/page/page.module.less +27 -0
  108. package/src/components/layout/page.stories.jsx +93 -0
  109. package/src/components/layout/placeholder.jsx +2 -0
  110. package/src/components/layout/print-header/print-header.jsx +22 -0
  111. package/src/components/layout/print-header/print-header.module.less +9 -0
  112. package/src/components/layout/row/row.jsx +75 -0
  113. package/src/components/layout/row/row.module.less +7 -0
  114. package/src/components/layout/spacer/spacer.jsx +26 -0
  115. package/src/components/layout/spacer/spacer.stories.jsx +50 -0
  116. package/src/components/layout-forms.stories.mdx +104 -0
  117. package/src/components/layout-general.stories.mdx +215 -0
  118. package/src/components/list/list-row/item-content.jsx +15 -0
  119. package/src/components/list/list-row/label.jsx +11 -0
  120. package/src/components/list/list-row/list-heading.jsx +52 -0
  121. package/src/components/list/list-row/list-row.jsx +128 -0
  122. package/src/components/list/list-row/list-subheading.jsx +72 -0
  123. package/src/components/list/list-row/meta-content.jsx +24 -0
  124. package/src/components/list/list-row/meta-count.jsx +10 -0
  125. package/src/components/list/list-row/name.jsx +45 -0
  126. package/src/components/list/list.jsx +276 -0
  127. package/src/components/list/list.module.less +256 -0
  128. package/src/components/list/list.stories-data.jsx +287 -0
  129. package/src/components/list/list.stories.jsx +458 -0
  130. package/src/components/list/toggle-narrow.jsx +13 -0
  131. package/src/components/loader/loader.jsx +63 -0
  132. package/src/components/loader/loader.module.less +63 -0
  133. package/src/components/loader/loader.stories.jsx +155 -0
  134. package/src/components/menu/index.js +7 -0
  135. package/src/components/menu/layer/divider.jsx +4 -0
  136. package/src/components/menu/layer/heading.jsx +15 -0
  137. package/src/components/menu/layer/layer.jsx +82 -0
  138. package/src/components/menu/layer/option.jsx +77 -0
  139. package/src/components/menu/layer/path.js +44 -0
  140. package/src/components/menu/layer/placementOptions.js +6 -0
  141. package/src/components/menu/layer/section.jsx +66 -0
  142. package/src/components/menu/menu.jsx +359 -0
  143. package/src/components/menu/menu.module.less +241 -0
  144. package/src/components/menu/menu.stories-data.jsx +168 -0
  145. package/src/components/menu/menu.stories.jsx +126 -0
  146. package/src/components/menu/menu.test.js +58 -0
  147. package/src/components/menu/trigger/button.jsx +50 -0
  148. package/src/components/menu/trigger/component.jsx +14 -0
  149. package/src/components/menu/trigger/text.jsx +25 -0
  150. package/src/components/menu/trigger/trigger.jsx +86 -0
  151. package/src/components/message/dismiss.jsx +26 -0
  152. package/src/components/message/message.jsx +137 -0
  153. package/src/components/message/message.module.less +114 -0
  154. package/src/components/message/message.stories.jsx +84 -0
  155. package/src/components/modal/modal.jsx +50 -0
  156. package/src/components/modal/modal.module.less +35 -0
  157. package/src/components/modal/modal.stories.jsx +159 -0
  158. package/src/components/option-dropdown/heading.jsx +6 -0
  159. package/src/components/option-dropdown/layer.jsx +81 -0
  160. package/src/components/option-dropdown/option-dropdown.jsx +53 -0
  161. package/src/components/option-dropdown/option-dropdown.module.less +50 -0
  162. package/src/components/option-dropdown/option-dropdown.stories.jsx +35 -0
  163. package/src/components/option-dropdown/option.jsx +13 -0
  164. package/src/components/pagination/pagination.jsx +139 -0
  165. package/src/components/pagination/pagination.module.less +11 -0
  166. package/src/components/pagination/pagination.stories.jsx +78 -0
  167. package/src/components/pagination/pagination.test.js +92 -0
  168. package/src/components/pagination/pagination.viewdata.js +66 -0
  169. package/src/components/pop-confirm/content.jsx +25 -0
  170. package/src/components/pop-confirm/pop-confirm.jsx +61 -0
  171. package/src/components/pop-confirm/pop-confirm.module.less +18 -0
  172. package/src/components/pop-confirm/pop-confirm.stories.jsx +53 -0
  173. package/src/components/popover/popover.jsx +112 -0
  174. package/src/components/popover/popover.module.less +22 -0
  175. package/src/components/popover/popover.stories.jsx +59 -0
  176. package/src/components/portal/portal.jsx +16 -0
  177. package/src/components/portal/portal.stories.jsx +69 -0
  178. package/src/components/progress-bar/progress-bar.jsx +64 -0
  179. package/src/components/progress-bar/progress-bar.module.less +64 -0
  180. package/src/components/progress-bar/progress-bar.stories.jsx +23 -0
  181. package/src/components/radio-button/radio-button.jsx +139 -0
  182. package/src/components/radio-button/radio-button.module.less +135 -0
  183. package/src/components/radio-button/radio-button.stories.jsx +37 -0
  184. package/src/components/radio-button/radio-input.jsx +52 -0
  185. package/src/components/select/custom-select/custom-select.jsx +440 -0
  186. package/src/components/select/custom-select/custom-select.module.less +123 -0
  187. package/src/components/select/custom-select/custom-select.reducer.js +157 -0
  188. package/src/components/select/custom-select/layer/heading.jsx +13 -0
  189. package/src/components/select/custom-select/layer/layer.jsx +73 -0
  190. package/src/components/select/custom-select/layer/option.jsx +54 -0
  191. package/src/components/select/custom-select/layer/placementOptions.js +7 -0
  192. package/src/components/select/custom-select/layer/section.jsx +35 -0
  193. package/src/components/select/custom-select/trigger/input.jsx +100 -0
  194. package/src/components/select/custom-select/trigger/trigger.jsx +155 -0
  195. package/src/components/select/custom-select/trigger/trigger.module.less +289 -0
  196. package/src/components/select/native-select/native-select.jsx +198 -0
  197. package/src/components/select/native-select/native-select.module.less +107 -0
  198. package/src/components/select/select.input.js +146 -0
  199. package/src/components/select/select.jsx +207 -0
  200. package/src/components/select/select.stories-data.jsx +92 -0
  201. package/src/components/select/select.stories.jsx +135 -0
  202. package/src/components/select/select.test.js +519 -0
  203. package/src/components/side-bar/container.module.less +29 -0
  204. package/src/components/side-bar/link.jsx +83 -0
  205. package/src/components/side-bar/sections.jsx +23 -0
  206. package/src/components/side-bar/side-bar.jsx +102 -0
  207. package/src/components/side-bar/side-bar.module.less +137 -0
  208. package/src/components/side-bar/side-bar.stories.jsx +101 -0
  209. package/src/components/slider/rc-slider.less +47 -0
  210. package/src/components/slider/slider-tooltip.jsx +20 -0
  211. package/src/components/slider/slider.jsx +233 -0
  212. package/src/components/slider/slider.module.less +40 -0
  213. package/src/components/slider/slider.stories.jsx +110 -0
  214. package/src/components/spinner/spinner.jsx +37 -0
  215. package/src/components/spinner/spinner.module.less +115 -0
  216. package/src/components/spinner/spinner.stories.jsx +24 -0
  217. package/src/components/table/cell/cell.jsx +614 -0
  218. package/src/components/table/cell/cell.module.less +152 -0
  219. package/src/components/table/footer/footer.jsx +66 -0
  220. package/src/components/table/footer/footer.module.less +14 -0
  221. package/src/components/table/helper.js +64 -0
  222. package/src/components/table/helper.test.js +166 -0
  223. package/src/components/table/icon/icon.module.less +31 -0
  224. package/src/components/table/row/expanded-content-row.jsx +16 -0
  225. package/src/components/table/row/row.jsx +253 -0
  226. package/src/components/table/row/row.module.less +62 -0
  227. package/src/components/table/table-scroll-wrapper.jsx +48 -0
  228. package/src/components/table/table.jsx +232 -0
  229. package/src/components/table/table.module.less +145 -0
  230. package/src/components/table/table.stories-data.jsx +752 -0
  231. package/src/components/table/table.stories.jsx +814 -0
  232. package/src/components/table/table.test.js +30 -0
  233. package/src/components/table/table.variables.less +19 -0
  234. package/src/components/table/table.viewdata.js +26 -0
  235. package/src/components/table/title/title.jsx +30 -0
  236. package/src/components/table/title/title.module.less +9 -0
  237. package/src/components/tabs/content.jsx +14 -0
  238. package/src/components/tabs/label.jsx +50 -0
  239. package/src/components/tabs/tabs.jsx +191 -0
  240. package/src/components/tabs/tabs.module.less +73 -0
  241. package/src/components/tabs/tabs.stories.jsx +110 -0
  242. package/src/components/text/text.jsx +64 -0
  243. package/src/components/text/text.module.less +45 -0
  244. package/src/components/text/text.stories.jsx +31 -0
  245. package/src/components/text-link/text-link.jsx +23 -0
  246. package/src/components/text-link/text-link.stories.jsx +20 -0
  247. package/src/components/textarea/textarea.jsx +126 -0
  248. package/src/components/textarea/textarea.module.less +55 -0
  249. package/src/components/textarea/textarea.stories.jsx +26 -0
  250. package/src/components/toaster/toaster.jsx +39 -0
  251. package/src/components/toaster/toaster.less +17 -0
  252. package/src/components/toaster/toaster.stories.jsx +116 -0
  253. package/src/components/toggle/toggle.jsx +65 -0
  254. package/src/components/toggle/toggle.module.less +139 -0
  255. package/src/components/toggle/toggle.stories.jsx +26 -0
  256. package/src/components/tooltip/tooltip-layer.jsx +72 -0
  257. package/src/components/tooltip/tooltip.jsx +108 -0
  258. package/src/components/tooltip/tooltip.module.less +28 -0
  259. package/src/components/tooltip/tooltip.stories.jsx +71 -0
  260. package/src/components/top-bar/element/element.jsx +72 -0
  261. package/src/components/top-bar/element/link.jsx +29 -0
  262. package/src/components/top-bar/title.jsx +24 -0
  263. package/src/components/top-bar/top-bar.jsx +79 -0
  264. package/src/components/top-bar/top-bar.module.less +191 -0
  265. package/src/components/top-bar/top-bar.stories.jsx +137 -0
  266. package/src/components/top-bar/warning.jsx +6 -0
  267. package/src/components/tree/tree-item.jsx +79 -0
  268. package/src/components/tree/tree-placeholder.jsx +6 -0
  269. package/src/components/tree/tree.jsx +129 -0
  270. package/src/components/tree/tree.module.less +33 -0
  271. package/src/components/tree/tree.stories-data.jsx +89 -0
  272. package/src/components/tree/tree.stories.jsx +106 -0
  273. package/src/docs/components/page/page.jsx +16 -0
  274. package/src/docs/config/config.js +1 -0
  275. package/src/docs/html/favicon.png +0 -0
  276. package/src/docs/html/index.html +11 -0
  277. package/src/docs/navigation/footer/footer.jsx +48 -0
  278. package/src/docs/navigation/header/header.jsx +39 -0
  279. package/src/docs/navigation/header/header.module.less +32 -0
  280. package/src/docs/navigation/routes/routes.jsx +16 -0
  281. package/src/docs/start.jsx +12 -0
  282. package/src/docs/views/main/main.jsx +209 -0
  283. package/src/docs/views/main/main.module.less +14 -0
  284. package/src/docs/views/not-found/not-found.jsx +5 -0
  285. package/src/helpers/disabled-context.js +8 -0
  286. package/src/helpers/styles.js +68 -0
  287. package/src/helpers/text.js +6 -0
  288. package/src/helpers/types.js +5 -0
  289. package/src/hooks/index.js +3 -0
  290. package/src/hooks/use-focus.js +11 -0
  291. package/src/hooks/use-keyboard-event.js +16 -0
  292. package/src/hooks/use-window-width.js +20 -0
  293. package/src/images/icons/icon-drop.png +0 -0
  294. package/src/images/icons/icon-share.png +0 -0
  295. package/src/images/icons/icons8-junction.svg +4 -0
  296. package/src/images/logo.png +0 -0
  297. package/src/images/logo.svg +13 -0
  298. package/src/images/oliasoft-logo.svg +1 -0
  299. package/src/style/colors.less +26 -0
  300. package/src/style/external.less +10 -0
  301. package/src/style/fonts/lato/Lato-Bold.woff2 +0 -0
  302. package/src/style/fonts/lato/Lato-BoldItalic.woff2 +0 -0
  303. package/src/style/fonts/lato/Lato-Italic.woff2 +0 -0
  304. package/src/style/fonts/lato/Lato-Regular.woff2 +0 -0
  305. package/src/style/fonts.less +27 -0
  306. package/src/style/global.less +51 -0
  307. package/src/style/mixins.less +67 -0
  308. package/src/style/reset/reset.less +34 -0
  309. package/src/style/shared.less +25 -0
  310. package/src/style/theme.dark.less +37 -0
  311. package/src/style/theme.default.less +74 -0
  312. package/src/style/variables.less +49 -0
  313. package/webpack/webpack.common.js +39 -0
  314. package/webpack/webpack.common.rules.js +102 -0
  315. package/webpack/webpack.dev.js +22 -0
  316. package/webpack/webpack.prod.js +23 -0
  317. package/webpack/webpack.resolve.js +22 -0
@@ -0,0 +1,289 @@
1
+ @import '../../../../style/variables.less';
2
+ @import '../../../../style/mixins.less';
3
+
4
+ .trigger {
5
+ font-family: sans-serif !important;
6
+ font-weight: normal;
7
+ display: flex;
8
+ justify-content: space-between;
9
+ align-items: center;
10
+ border: 1px solid var(--color-border);
11
+ border-radius: @input_border_radius;
12
+ padding-right: 11px;
13
+ background: var(--color-background-input);
14
+ min-height: @input_height;
15
+ position: relative;
16
+
17
+ input {
18
+ border: none !important;
19
+ background: transparent !important;
20
+ }
21
+
22
+ &.isInTable {
23
+ .inputInTable();
24
+
25
+ .input {
26
+ background: transparent !important;
27
+ }
28
+
29
+ &.isOpen,
30
+ &:hover,
31
+ &:focus {
32
+ position: relative;
33
+ z-index: 2;
34
+ }
35
+ }
36
+
37
+ &:hover {
38
+ border-color: var(--color-border-hover);
39
+ cursor: pointer;
40
+ }
41
+
42
+ &.isOpen,
43
+ &:focus {
44
+ .inputFocus();
45
+ }
46
+
47
+ &.error {
48
+ .inputError();
49
+ }
50
+
51
+ &.warning {
52
+ .inputWarning();
53
+ }
54
+
55
+ &.disabled {
56
+ .inputDisabled();
57
+
58
+ .iconOpen {
59
+ background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='gray' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E");
60
+ }
61
+ }
62
+ }
63
+
64
+ .icons {
65
+ display: flex;
66
+ align-items: center;
67
+ flex-wrap: nowrap;
68
+ flex-shrink: 0;
69
+ position: relative;
70
+ z-index: 2;
71
+ font-size: 12px;
72
+
73
+ .clearAll {
74
+ color: var(--color-border);
75
+ padding: 5px;
76
+ margin-right: -5px;
77
+
78
+ &:hover,
79
+ &.focus {
80
+ color: var(--color-text);
81
+ outline: 0;
82
+ }
83
+ }
84
+
85
+ .iconOpen {
86
+ color: inherit;
87
+ display: block;
88
+ height: 12px;
89
+ width: 12px;
90
+ flex-shrink: 0;
91
+ background: transparent
92
+ url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='gray' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E")
93
+ no-repeat center;
94
+ background-size: 8px 10px;
95
+ }
96
+
97
+ svg {
98
+ display: block;
99
+ }
100
+ }
101
+
102
+ .triggerInputContainer {
103
+ display: flex;
104
+ align-items: center;
105
+ flex-wrap: wrap;
106
+ overflow: hidden;
107
+ position: relative;
108
+ z-index: 1;
109
+ flex-grow: 1;
110
+
111
+ .right & {
112
+ margin-right: 8px;
113
+ justify-content: flex-end;
114
+ text-align: right;
115
+
116
+ input {
117
+ padding-right: 0;
118
+ padding-left: 0;
119
+ text-align: right;
120
+ width: 0;
121
+
122
+ &:focus {
123
+ width: auto;
124
+ }
125
+ }
126
+ }
127
+ }
128
+
129
+ .multiOptions {
130
+ padding: 3px;
131
+ max-width: 100%;
132
+ display: flex;
133
+ flex-wrap: wrap;
134
+
135
+ &:empty {
136
+ display: none !important;
137
+ }
138
+
139
+ .multiOptionWrapper {
140
+ padding: 3px;
141
+ max-width: 100%;
142
+
143
+ .small & {
144
+ padding: 0;
145
+ }
146
+ }
147
+
148
+ .multiOption {
149
+ user-select: none;
150
+ display: inline-flex;
151
+ align-items: center;
152
+ border: 1px solid var(--color-border);
153
+ background-color: var(--color-background);
154
+
155
+ padding-left: 7px;
156
+ border-radius: 3px;
157
+ font-size: 12px;
158
+ line-height: 24px;
159
+ height: 24px;
160
+ color: var(--color-text);
161
+ max-width: 100%;
162
+
163
+ .label {
164
+ overflow: hidden;
165
+ text-overflow: ellipsis;
166
+ white-space: nowrap;
167
+ flex-grow: 1;
168
+ }
169
+
170
+ .closeMultiOption {
171
+ flex-shrink: 0;
172
+ display: flex;
173
+ align-items: center;
174
+ justify-content: center;
175
+ height: 100%;
176
+ width: 24px;
177
+ opacity: 0.25;
178
+
179
+ &:hover,
180
+ &.focus {
181
+ opacity: 1;
182
+ outline: 0;
183
+ }
184
+ }
185
+ }
186
+ }
187
+
188
+ .selectedSingleValue,
189
+ .placeHolder {
190
+ line-height: @input_height - 2px;
191
+ right: 0;
192
+ left: 0;
193
+ overflow: hidden;
194
+ white-space: nowrap;
195
+ text-overflow: ellipsis;
196
+ display: block;
197
+ margin-top: -0.5px; // Fix discrepancy between Webkit & FF
198
+
199
+ &.searchable {
200
+ position: absolute;
201
+ }
202
+ }
203
+
204
+ .selectedSingleValue,
205
+ .placeHolder,
206
+ .input {
207
+ padding-left: @input_padding_x;
208
+ }
209
+
210
+ .placeHolder {
211
+ color: var(--color-text-faint);
212
+ }
213
+
214
+ .input {
215
+ font-family: @default_font;
216
+ background-color: transparent;
217
+ border: none;
218
+ color: var(--color-text);
219
+
220
+ &.error {
221
+ color: var(--color-text-error) !important;
222
+ }
223
+
224
+ &:focus {
225
+ outline: none;
226
+ }
227
+ }
228
+
229
+ .small {
230
+ min-height: @input_height_small;
231
+ padding-right: @input_padding_small_x;
232
+ font-size: @input_font_size_small;
233
+
234
+ .selectedSingleValue,
235
+ .placeHolder,
236
+ .input {
237
+ padding-left: @input_padding_small_x;
238
+ height: @input_height_small - 2px;
239
+ line-height: @input_height_small - 2px;
240
+ }
241
+
242
+ .multiOptions {
243
+ padding: 1px;
244
+ }
245
+
246
+ .multiOption {
247
+ line-height: @input_height_small - 6px;
248
+ height: @input_height_small - 6px;
249
+ margin: 1px;
250
+ }
251
+ }
252
+
253
+ .groupOrderFirst,
254
+ .groupOrderMiddle,
255
+ .groupOrderLast {
256
+ .input:hover,
257
+ .input:focus {
258
+ z-index: 2;
259
+ }
260
+ }
261
+
262
+ .groupOrderFirst,
263
+ .groupOrderMiddle {
264
+ margin-right: -1px;
265
+ border-top-right-radius: 0 !important;
266
+ border-bottom-right-radius: 0 !important;
267
+ }
268
+
269
+ .groupOrderLast,
270
+ .groupOrderMiddle {
271
+ border-top-left-radius: 0 !important;
272
+ border-bottom-left-radius: 0 !important;
273
+ }
274
+
275
+ .detailedLabel {
276
+ width: 100%;
277
+
278
+ :first-child {
279
+ float: left;
280
+ position: absolute;
281
+ background-color: white;
282
+ padding-right: 5px;
283
+ }
284
+
285
+ :last-child {
286
+ float: right;
287
+ padding-right: 10px;
288
+ }
289
+ }
@@ -0,0 +1,198 @@
1
+ import React, { useContext } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import cx from 'classnames';
4
+ import styles from './native-select.module.less';
5
+ import { Tooltip } from '../../tooltip/tooltip';
6
+ import { isStringNumberOrNode } from '../../../helpers/types';
7
+ import { DisabledContext } from '../../../helpers/disabled-context';
8
+
9
+ export const NativeSelect = ({
10
+ disabled,
11
+ error,
12
+ tooltip,
13
+ options,
14
+ selectedOption,
15
+ right,
16
+ small,
17
+ width,
18
+ borderRadius,
19
+ onChange,
20
+ tabIndex,
21
+ warning,
22
+ onFocus,
23
+ onBlur,
24
+ maxTooltipWidth,
25
+ placeholder,
26
+ clearable,
27
+ hasNonExistentValue,
28
+ groupOrder,
29
+ testId,
30
+ isInTable,
31
+ }) => {
32
+ const disabledContext = useContext(DisabledContext);
33
+ const internalValue =
34
+ selectedOption === null
35
+ ? 'unselected'
36
+ : selectedOption.value === null
37
+ ? 'unselected'
38
+ : selectedOption.value; //null not allowed as a React prop to a select input
39
+ const isUnselected = internalValue === 'unselected';
40
+
41
+ const viewOptions = (
42
+ internalValue === 'unselected' || clearable
43
+ ? [
44
+ <option
45
+ key="unselected"
46
+ value="unselected"
47
+ disabled={!clearable}
48
+ hidden={!clearable}
49
+ >
50
+ {placeholder || 'Select...'}
51
+ </option>,
52
+ ]
53
+ : []
54
+ )
55
+ .concat(
56
+ hasNonExistentValue
57
+ ? [
58
+ <option
59
+ key="selectedNonExistentValue"
60
+ value={selectedOption.value}
61
+ disabled={disabled || disabledContext}
62
+ >
63
+ {selectedOption.label}
64
+ </option>,
65
+ ]
66
+ : [],
67
+ )
68
+ .concat(
69
+ options.map((option, i) => {
70
+ return (
71
+ <option key={i} value={option.value} data-testid={option.testId}>
72
+ {option.label}
73
+ </option>
74
+ );
75
+ }),
76
+ );
77
+
78
+ const order = (() => {
79
+ if (groupOrder) {
80
+ switch (groupOrder) {
81
+ case 'first':
82
+ return styles.groupOrderFirst;
83
+ case 'last':
84
+ return styles.groupOrderLast;
85
+ default:
86
+ return styles.groupOrderMiddle;
87
+ }
88
+ }
89
+ return '';
90
+ })();
91
+
92
+ return (
93
+ <Tooltip
94
+ error={!!error}
95
+ warning={!!warning}
96
+ text={tooltip || error || warning}
97
+ enabled={
98
+ (tooltip && isStringNumberOrNode(tooltip)) ||
99
+ (error && isStringNumberOrNode(error)) ||
100
+ (warning && isStringNumberOrNode(warning)) ||
101
+ false
102
+ }
103
+ maxWidth={maxTooltipWidth}
104
+ placement="bottom-center"
105
+ >
106
+ <select
107
+ className={cx(
108
+ styles.select,
109
+ isUnselected ? styles.unSelected : '',
110
+ error ? styles.error : warning ? styles.warning : '',
111
+ right ? styles.right : '',
112
+ small ? styles.small : '',
113
+ isInTable ? styles.isInTable : '',
114
+ order,
115
+ )}
116
+ style={{
117
+ width: width || '',
118
+ borderRadius: borderRadius || '',
119
+ }}
120
+ onChange={(evt) => {
121
+ const { value } = evt.target;
122
+ const nextValue =
123
+ value === 'unselected'
124
+ ? { value: null }
125
+ : options.find((o) => String(o.value) === String(value));
126
+ onChange(evt, nextValue);
127
+ }}
128
+ onFocus={onFocus}
129
+ onBlur={onBlur}
130
+ tabIndex={tabIndex}
131
+ value={internalValue}
132
+ disabled={disabled || disabledContext}
133
+ data-testid={testId}
134
+ >
135
+ {viewOptions}
136
+ </select>
137
+ </Tooltip>
138
+ );
139
+ };
140
+
141
+ export const selectOptionShape = {
142
+ label: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
143
+ value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
144
+ };
145
+
146
+ NativeSelect.defaultProps = {
147
+ borderRadius: null,
148
+ disabled: false,
149
+ error: null,
150
+ warning: null,
151
+ tooltip: null,
152
+ onChange: () => {},
153
+ onFocus: () => {},
154
+ onBlur: () => {},
155
+ right: false,
156
+ small: false,
157
+ tabIndex: 0,
158
+ selectedOption: null,
159
+ width: null,
160
+ groupOrder: null,
161
+ testId: undefined,
162
+ isInTable: false,
163
+ };
164
+
165
+ export const NativeSelectShape = {
166
+ borderRadius: PropTypes.number,
167
+ disabled: PropTypes.bool,
168
+ error: PropTypes.oneOfType([
169
+ PropTypes.string,
170
+ PropTypes.number,
171
+ PropTypes.node,
172
+ ]),
173
+ warning: PropTypes.oneOfType([
174
+ PropTypes.string,
175
+ PropTypes.number,
176
+ PropTypes.node,
177
+ ]),
178
+ tooltip: PropTypes.oneOfType([
179
+ PropTypes.string,
180
+ PropTypes.number,
181
+ PropTypes.node,
182
+ ]),
183
+ options: PropTypes.arrayOf(PropTypes.shape(selectOptionShape)).isRequired,
184
+ onChange: PropTypes.func,
185
+ onFocus: PropTypes.func,
186
+ onBlur: PropTypes.func,
187
+ right: PropTypes.bool,
188
+ small: PropTypes.bool,
189
+ tabIndex: PropTypes.number,
190
+ selectedOption: PropTypes.shape(selectOptionShape),
191
+ width: PropTypes.string,
192
+ groupOrder: PropTypes.string,
193
+ testId: PropTypes.string,
194
+ //private props (don't use)
195
+ isInTable: PropTypes.bool,
196
+ };
197
+
198
+ NativeSelect.propTypes = NativeSelectShape;
@@ -0,0 +1,107 @@
1
+ @import '../../../style/variables.less';
2
+ @import '../../../style/mixins.less';
3
+
4
+ .select {
5
+ appearance: none !important;
6
+ -webkit-appearance: none !important;
7
+ -moz-appearance: none !important;
8
+ display: inline-block;
9
+ width: 100%;
10
+ padding: 0.67857143em 12px;
11
+ padding-right: 30px;
12
+ line-height: 1.21428571em;
13
+ color: var(--color-text);
14
+ vertical-align: middle;
15
+ background: var(--color-background-input)
16
+ url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='gray' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E")
17
+ no-repeat right 12px center;
18
+ background-size: 8px 10px !important;
19
+ border: 1px solid var(--color-border);
20
+ border-radius: 0.28571429rem;
21
+ height: 38px;
22
+ font-family: sans-serif !important;
23
+
24
+ // Styles for option dropdown in browsers that support it (e.g. Windows/Chrome)
25
+ option {
26
+ background: var(--color-background-input);
27
+ color: var(--color-text);
28
+
29
+ &:focus {
30
+ background-color: var(--color-background-menuitem-active);
31
+ }
32
+ }
33
+
34
+ &:-moz-focusring {
35
+ color: transparent !important;
36
+ text-shadow: 0 0 0 #000 !important;
37
+ }
38
+
39
+ &:hover {
40
+ border-color: var(--color-border-hover);
41
+ }
42
+
43
+ &:focus {
44
+ .inputFocus();
45
+ }
46
+
47
+ &.isInTable {
48
+ .inputInTable();
49
+ }
50
+
51
+ &.unSelected {
52
+ color: var(--color-text-faint) !important;
53
+
54
+ &:-moz-focusring {
55
+ color: transparent !important;
56
+ text-shadow: 0 0 0 #000 !important;
57
+ }
58
+ }
59
+
60
+ &.error {
61
+ .inputError();
62
+ }
63
+
64
+ &.warning {
65
+ .inputWarning();
66
+ }
67
+
68
+ &.small {
69
+ font-size: @input_font_size_small;
70
+ height: @input_height_small;
71
+ padding: @input_padding_small_y @input_padding_small_x;
72
+ background-position: right 8px center !important;
73
+ padding-right: 28px;
74
+ }
75
+
76
+ &.right {
77
+ text-align: right;
78
+ text-align-last: right;
79
+ }
80
+
81
+ &[disabled] {
82
+ .inputDisabled();
83
+ background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='gray' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E");
84
+ }
85
+ }
86
+
87
+ .groupOrderFirst,
88
+ .groupOrderMiddle,
89
+ .groupOrderLast {
90
+ .input:hover,
91
+ .input:focus {
92
+ z-index: 2;
93
+ }
94
+ }
95
+
96
+ .groupOrderFirst,
97
+ .groupOrderMiddle {
98
+ margin-right: -1px;
99
+ border-top-right-radius: 0 !important;
100
+ border-bottom-right-radius: 0 !important;
101
+ }
102
+
103
+ .groupOrderLast,
104
+ .groupOrderMiddle {
105
+ border-top-left-radius: 0 !important;
106
+ border-bottom-left-radius: 0 !important;
107
+ }