@jetbrains/ring-ui 4.1.0-beta.9 → 4.1.1

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 (354) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +17 -15
  3. package/babel.config.js +3 -2
  4. package/components/alert/alert.js +9 -3
  5. package/components/alert/container.css +1 -1
  6. package/components/alert-service/alert-service.examples.css +18 -0
  7. package/components/alert-service/alert-service.examples.js +21 -0
  8. package/components/alert-service/alert-service.js +10 -3
  9. package/components/analytics/analytics__fus-plugin.js +1 -1
  10. package/components/auth/auth.test.js +14 -7
  11. package/components/auth/auth__core.js +64 -33
  12. package/components/auth-dialog/auth-dialog.js +1 -0
  13. package/components/avatar/avatar.css +4 -1
  14. package/components/avatar/avatar.examples.js +3 -2
  15. package/components/avatar/avatar.js +31 -6
  16. package/components/avatar/fallback-avatar.js +136 -0
  17. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  18. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  19. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  20. package/components/button/button.css +2 -2
  21. package/components/button/button.js +4 -1
  22. package/components/button-group/button-group.js +1 -1
  23. package/components/button-group/caption.js +1 -1
  24. package/components/button-ng/button-ng.js +1 -1
  25. package/components/button-set-ng/button-set-ng.js +3 -1
  26. package/components/checkbox/checkbox.css +1 -1
  27. package/components/code/code.js +1 -1
  28. package/components/confirm/confirm.js +1 -0
  29. package/components/confirm-service/confirm-service.js +5 -5
  30. package/components/content-layout/content-layout.css +1 -1
  31. package/components/data-list/data-list.css +1 -1
  32. package/components/date-picker/date-input.js +5 -4
  33. package/components/date-picker/date-picker.css +34 -22
  34. package/components/date-picker/date-picker.js +16 -14
  35. package/components/date-picker/date-popup.js +22 -7
  36. package/components/date-picker/month-names.js +8 -5
  37. package/components/date-picker/month.js +6 -2
  38. package/components/date-picker/weekdays.js +10 -2
  39. package/components/dialog/dialog.examples.js +3 -1
  40. package/components/dialog/dialog.js +5 -2
  41. package/components/dialog/dialog.test.js +1 -1
  42. package/components/dialog/dialog__body-scroll-preventer.js +2 -2
  43. package/components/dialog-ng/dialog-ng.js +7 -8
  44. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  45. package/components/dropdown/dropdown.examples.js +36 -1
  46. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  47. package/components/dropdown-menu/dropdown-menu.js +117 -0
  48. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  49. package/components/error-bubble/error-bubble-legacy.css +1 -1
  50. package/components/error-bubble/error-bubble.css +1 -1
  51. package/components/error-bubble/error-bubble.examples.js +1 -1
  52. package/components/error-page/error-page.css +2 -2
  53. package/components/footer-ng/footer-ng.js +13 -3
  54. package/components/form/form.css +2 -2
  55. package/components/form-ng/form-ng.js +3 -1
  56. package/components/global/global.css +1 -1
  57. package/components/global/theme.js +1 -1
  58. package/components/global/variables.css +8 -1
  59. package/components/grid/grid.css +10 -9
  60. package/components/header/header.css +1 -1
  61. package/components/header/header.examples.js +7 -8
  62. package/components/header/profile.js +10 -11
  63. package/components/http/http.js +1 -1
  64. package/components/icon/icon.css +5 -4
  65. package/components/island/island.css +4 -3
  66. package/components/island-legacy/island-legacy.css +3 -1
  67. package/components/list/list.js +6 -1
  68. package/components/list/list__custom.js +9 -3
  69. package/components/list/list__item.js +8 -2
  70. package/components/list/list__link.js +2 -1
  71. package/components/loader-inline/loader-inline.css +1 -1
  72. package/components/loader-screen/loader-screen.css +1 -1
  73. package/components/message/message.css +1 -1
  74. package/components/message/message.examples.js +8 -5
  75. package/components/pager/pager.js +5 -3
  76. package/components/permissions/permissions.js +1 -1
  77. package/components/progress-bar/progress-bar.css +1 -1
  78. package/components/progress-bar/progress-bar.examples.js +3 -3
  79. package/components/progress-bar/progress-bar.js +5 -2
  80. package/components/progress-bar/progress-bar.test.js +12 -13
  81. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  82. package/components/query-assist/query-assist.css +13 -3
  83. package/components/query-assist/query-assist.examples.js +3 -1
  84. package/components/query-assist/query-assist.js +56 -12
  85. package/components/query-assist/query-assist.test.js +37 -5
  86. package/components/save-field-ng/save-field-ng.css +0 -3
  87. package/components/save-field-ng/save-field-ng.js +3 -1
  88. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  89. package/components/select/select.css +12 -7
  90. package/components/select/select.examples.js +13 -0
  91. package/components/select/select.js +30 -43
  92. package/components/select/select.test.js +4 -5
  93. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  94. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  95. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  96. package/components/sidebar/sidebar.css +1 -0
  97. package/components/sidebar-ng/sidebar-ng.js +6 -2
  98. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  99. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  100. package/components/table/row.js +2 -1
  101. package/components/table/table.css +2 -1
  102. package/components/table-legacy/table-legacy.css +2 -2
  103. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  104. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  105. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  106. package/components/tabs/collapsible-tab.js +2 -2
  107. package/components/tabs/collapsible-tabs.js +4 -8
  108. package/components/tabs/tab-link.js +4 -2
  109. package/components/tabs/tabs.css +27 -0
  110. package/components/tabs-ng/tabs-ng.js +4 -2
  111. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  112. package/components/tag/tag.css +5 -2
  113. package/components/tag/tag.examples.js +3 -0
  114. package/components/tag/tag.js +19 -16
  115. package/components/tags-input/tag-input.examples.js +1 -1
  116. package/components/tags-input/tags-input.js +5 -2
  117. package/components/template-ng/template-ng.js +1 -1
  118. package/components/tooltip/tooltip.js +7 -2
  119. package/components/user-agreement/user-agreement.css +1 -1
  120. package/components/user-agreement/user-agreement.examples.js +7 -4
  121. package/components/user-agreement/user-agreement.js +1 -0
  122. package/package.json +75 -78
  123. package/webpack.config.js +14 -10
  124. package/components/button-set-ng/button-set-ng.html +0 -1
  125. package/components/footer-ng/footer-ng.html +0 -13
  126. package/components/form-ng/form-ng__error-bubble.html +0 -3
  127. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  128. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  129. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  130. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  131. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  132. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  133. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -127
  134. package/dist/_helpers/anchor.js +0 -33
  135. package/dist/_helpers/badge.js +0 -3
  136. package/dist/_helpers/button__classes.js +0 -39
  137. package/dist/_helpers/caption.js +0 -25
  138. package/dist/_helpers/card.js +0 -77
  139. package/dist/_helpers/date-picker.js +0 -3
  140. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -56
  141. package/dist/_helpers/grid.js +0 -3
  142. package/dist/_helpers/header.js +0 -3
  143. package/dist/_helpers/icon__svg.js +0 -83
  144. package/dist/_helpers/inject-styles.js +0 -22
  145. package/dist/_helpers/island.js +0 -3
  146. package/dist/_helpers/list.js +0 -3
  147. package/dist/_helpers/query-assist__suggestions.js +0 -95
  148. package/dist/_helpers/select__filter.js +0 -78
  149. package/dist/_helpers/services-link.js +0 -42
  150. package/dist/_helpers/sidebar.js +0 -127
  151. package/dist/_helpers/table.js +0 -3
  152. package/dist/_helpers/tabs.js +0 -3
  153. package/dist/_helpers/title.js +0 -99
  154. package/dist/alert/alert.js +0 -254
  155. package/dist/alert/container.js +0 -50
  156. package/dist/alert-service/alert-service.js +0 -159
  157. package/dist/analytics/analytics.js +0 -116
  158. package/dist/analytics/analytics__custom-plugin.js +0 -127
  159. package/dist/analytics/analytics__fus-plugin.js +0 -101
  160. package/dist/analytics/analytics__ga-plugin.js +0 -66
  161. package/dist/analytics/analytics__plugin-utils.js +0 -79
  162. package/dist/auth/auth.js +0 -90
  163. package/dist/auth/auth__core.js +0 -987
  164. package/dist/auth/background-flow.js +0 -123
  165. package/dist/auth/down-notification.js +0 -111
  166. package/dist/auth/iframe-flow.js +0 -147
  167. package/dist/auth/landing-entry.js +0 -5
  168. package/dist/auth/landing.js +0 -84
  169. package/dist/auth/request-builder.js +0 -75
  170. package/dist/auth/response-parser.js +0 -117
  171. package/dist/auth/storage.js +0 -279
  172. package/dist/auth/token-validator.js +0 -176
  173. package/dist/auth/window-flow.js +0 -133
  174. package/dist/auth-dialog/auth-dialog.js +0 -132
  175. package/dist/auth-dialog-service/auth-dialog-service.js +0 -67
  176. package/dist/avatar/avatar-example-datauri.js +0 -26
  177. package/dist/avatar/avatar.js +0 -155
  178. package/dist/badge/badge.js +0 -52
  179. package/dist/button/button.js +0 -117
  180. package/dist/button/button__classes.js +0 -5
  181. package/dist/button-group/button-group.js +0 -30
  182. package/dist/button-group/caption.js +0 -5
  183. package/dist/button-set/button-set.js +0 -27
  184. package/dist/button-toolbar/button-toolbar.js +0 -30
  185. package/dist/caret/caret.js +0 -264
  186. package/dist/checkbox/checkbox.js +0 -110
  187. package/dist/confirm/confirm.js +0 -122
  188. package/dist/confirm-service/confirm-service.js +0 -112
  189. package/dist/content-layout/content-layout.js +0 -67
  190. package/dist/content-layout/sidebar.js +0 -6
  191. package/dist/contenteditable/contenteditable.js +0 -81
  192. package/dist/data-list/data-list.js +0 -203
  193. package/dist/data-list/data-list.mock.js +0 -190
  194. package/dist/data-list/item.js +0 -225
  195. package/dist/data-list/selection.js +0 -101
  196. package/dist/data-list/title.js +0 -16
  197. package/dist/date-picker/consts.js +0 -70
  198. package/dist/date-picker/date-input.js +0 -169
  199. package/dist/date-picker/date-picker.js +0 -356
  200. package/dist/date-picker/date-popup.js +0 -459
  201. package/dist/date-picker/day.js +0 -119
  202. package/dist/date-picker/formats.js +0 -3
  203. package/dist/date-picker/month-names.js +0 -92
  204. package/dist/date-picker/month-slider.js +0 -83
  205. package/dist/date-picker/month.js +0 -48
  206. package/dist/date-picker/months.js +0 -121
  207. package/dist/date-picker/weekdays.js +0 -24
  208. package/dist/date-picker/years.js +0 -109
  209. package/dist/dialog/dialog.js +0 -197
  210. package/dist/dialog/dialog__body-scroll-preventer.js +0 -2
  211. package/dist/dropdown/anchor.js +0 -16
  212. package/dist/dropdown/dropdown.js +0 -236
  213. package/dist/error-bubble/error-bubble.js +0 -59
  214. package/dist/error-message/error-message.js +0 -55
  215. package/dist/footer/footer.js +0 -127
  216. package/dist/global/angular-component-factory.js +0 -83
  217. package/dist/global/compose.js +0 -9
  218. package/dist/global/composeRefs.js +0 -15
  219. package/dist/global/conic-gradient.js +0 -37
  220. package/dist/global/create-stateful-context.js +0 -54
  221. package/dist/global/data-tests.js +0 -22
  222. package/dist/global/dom.js +0 -124
  223. package/dist/global/focus-sensor-hoc.js +0 -147
  224. package/dist/global/fuzzy-highlight.js +0 -67
  225. package/dist/global/get-event-key.js +0 -111
  226. package/dist/global/get-uid.js +0 -15
  227. package/dist/global/inject-styles.js +0 -17
  228. package/dist/global/linear-function.js +0 -18
  229. package/dist/global/listeners.js +0 -42
  230. package/dist/global/memoize.js +0 -18
  231. package/dist/global/normalize-indent.js +0 -28
  232. package/dist/global/promise-with-timeout.js +0 -13
  233. package/dist/global/radial-gradient-mask.js +0 -49
  234. package/dist/global/react-dom-renderer.js +0 -45
  235. package/dist/global/rerender-hoc.js +0 -53
  236. package/dist/global/ring-angular-component.js +0 -24
  237. package/dist/global/schedule-raf.js +0 -31
  238. package/dist/global/sniffer.js +0 -6
  239. package/dist/global/supports-css.js +0 -20
  240. package/dist/global/theme.js +0 -56
  241. package/dist/global/trivial-template-tag.js +0 -15
  242. package/dist/global/url.js +0 -163
  243. package/dist/global/variables_dark.js +0 -57
  244. package/dist/grid/col.js +0 -62
  245. package/dist/grid/grid.js +0 -35
  246. package/dist/grid/row.js +0 -66
  247. package/dist/group/group.js +0 -34
  248. package/dist/header/header.js +0 -144
  249. package/dist/header/logo.js +0 -39
  250. package/dist/header/profile.js +0 -212
  251. package/dist/header/services-link.js +0 -10
  252. package/dist/header/services.js +0 -135
  253. package/dist/header/smart-profile.js +0 -227
  254. package/dist/header/smart-services.js +0 -159
  255. package/dist/header/tray-icon.js +0 -45
  256. package/dist/header/tray.js +0 -33
  257. package/dist/heading/heading.js +0 -76
  258. package/dist/http/http.js +0 -216
  259. package/dist/http/http.mock.js +0 -65
  260. package/dist/hub-source/hub-source.js +0 -130
  261. package/dist/hub-source/hub-source__user.js +0 -28
  262. package/dist/hub-source/hub-source__users-groups.js +0 -62
  263. package/dist/icon/icon.js +0 -105
  264. package/dist/icon/icon__constants.js +0 -33
  265. package/dist/icon/icon__svg.js +0 -6
  266. package/dist/icon/index.js +0 -9
  267. package/dist/input/input.js +0 -231
  268. package/dist/island/adaptive-island-hoc.js +0 -48
  269. package/dist/island/content.js +0 -158
  270. package/dist/island/header.js +0 -85
  271. package/dist/island/island.js +0 -53
  272. package/dist/island-legacy/content-legacy.js +0 -28
  273. package/dist/island-legacy/header-legacy.js +0 -30
  274. package/dist/island-legacy/island-legacy.js +0 -30
  275. package/dist/link/clickableLink.js +0 -65
  276. package/dist/link/link.js +0 -118
  277. package/dist/list/consts.js +0 -26
  278. package/dist/list/list.js +0 -800
  279. package/dist/list/list__custom.js +0 -82
  280. package/dist/list/list__hint.js +0 -26
  281. package/dist/list/list__item.js +0 -197
  282. package/dist/list/list__link.js +0 -65
  283. package/dist/list/list__separator.js +0 -30
  284. package/dist/list/list__title.js +0 -39
  285. package/dist/list/list__users-groups-source.js +0 -124
  286. package/dist/loader/loader.js +0 -72
  287. package/dist/loader/loader__core.js +0 -272
  288. package/dist/loader-inline/inject-styles.js +0 -11
  289. package/dist/loader-inline/loader-inline.js +0 -58
  290. package/dist/loader-screen/loader-screen.js +0 -46
  291. package/dist/login-dialog/login-dialog.js +0 -184
  292. package/dist/login-dialog/service.js +0 -67
  293. package/dist/message/message.js +0 -232
  294. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  295. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  296. package/dist/old-browsers-message/white-list.js +0 -34
  297. package/dist/pager/pager.js +0 -352
  298. package/dist/panel/panel.js +0 -34
  299. package/dist/permissions/permissions.js +0 -200
  300. package/dist/permissions/permissions__cache.js +0 -272
  301. package/dist/popup/popup.consts.js +0 -41
  302. package/dist/popup/popup.js +0 -389
  303. package/dist/popup/popup.target.js +0 -27
  304. package/dist/popup/position.js +0 -280
  305. package/dist/popup-menu/popup-menu.js +0 -108
  306. package/dist/progress-bar/progress-bar.js +0 -111
  307. package/dist/proxy-attrs/proxy-attrs.js +0 -19
  308. package/dist/query-assist/query-assist.js +0 -1023
  309. package/dist/query-assist/query-assist__suggestions.js +0 -43
  310. package/dist/radio/radio.js +0 -39
  311. package/dist/radio/radio__item.js +0 -82
  312. package/dist/select/select.js +0 -1335
  313. package/dist/select/select__filter.js +0 -49
  314. package/dist/select/select__popup.js +0 -541
  315. package/dist/shortcuts/core.js +0 -245
  316. package/dist/shortcuts/shortcut-title.js +0 -51
  317. package/dist/shortcuts/shortcuts-hoc.js +0 -43
  318. package/dist/shortcuts/shortcuts.js +0 -72
  319. package/dist/storage/storage.js +0 -55
  320. package/dist/storage/storage__fallback.js +0 -214
  321. package/dist/storage/storage__local.js +0 -150
  322. package/dist/style.css +0 -1
  323. package/dist/tab-trap/tab-trap.js +0 -178
  324. package/dist/table/cell.js +0 -25
  325. package/dist/table/disable-hover-hoc.js +0 -53
  326. package/dist/table/header-cell.js +0 -91
  327. package/dist/table/header.js +0 -189
  328. package/dist/table/multitable.js +0 -140
  329. package/dist/table/row-with-focus-sensor.js +0 -79
  330. package/dist/table/row.js +0 -270
  331. package/dist/table/selection-adapter.js +0 -14
  332. package/dist/table/selection-shortcuts-hoc.js +0 -212
  333. package/dist/table/selection.js +0 -221
  334. package/dist/table/smart-table.js +0 -113
  335. package/dist/table/table.js +0 -405
  336. package/dist/tabs/collapsible-more.js +0 -193
  337. package/dist/tabs/collapsible-tab.js +0 -90
  338. package/dist/tabs/collapsible-tabs.js +0 -361
  339. package/dist/tabs/custom-item.js +0 -13
  340. package/dist/tabs/dumb-tabs.js +0 -159
  341. package/dist/tabs/smart-tabs.js +0 -102
  342. package/dist/tabs/tab-link.js +0 -35
  343. package/dist/tabs/tab.js +0 -32
  344. package/dist/tabs/tabs.js +0 -65
  345. package/dist/tag/tag.js +0 -190
  346. package/dist/tags-input/tags-input.js +0 -474
  347. package/dist/tags-list/tags-list.js +0 -94
  348. package/dist/text/text.js +0 -38
  349. package/dist/toggle/toggle.js +0 -80
  350. package/dist/tooltip/tooltip.js +0 -205
  351. package/dist/user-card/card.js +0 -14
  352. package/dist/user-card/smart-user-card-tooltip.js +0 -112
  353. package/dist/user-card/tooltip.js +0 -91
  354. package/dist/user-card/user-card.js +0 -46
@@ -1,231 +0,0 @@
1
- import { _ as _defineProperty, a as _objectWithoutProperties, b as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import closeIcon from '@jetbrains/icons/close';
6
- import { withTheme } from '../global/theme.js';
7
- export { default as Theme } from '../global/theme.js';
8
- import Button from '../button/button.js';
9
- import getUID from '../global/get-uid.js';
10
- import Icon from '../icon/icon.js';
11
- import 'focus-visible';
12
- import '@jetbrains/icons/chevron-10px';
13
- import '../link/clickableLink.js';
14
- import '../_helpers/button__classes.js';
15
- import '../icon/icon__constants.js';
16
- import 'util-deprecate';
17
- import '../_helpers/icon__svg.js';
18
- import '../global/memoize.js';
19
-
20
- var modules_88cfaf40 = {"unit":"8px","iconOffset":"22px","input":"input_input__74bd3acf","container":"input_container__74bd3acf global_fontLower__0f8f4370 global_font__0f8f4370","compact":"input_compact__74bd3acf","clearable":"input_clearable__74bd3acf","light":"input_light__74bd3acf","dark":"input_dark__74bd3acf","withIcon":"input_withIcon__74bd3acf","label":"input_label__74bd3acf","icon":"input_icon__74bd3acf","clear":"input_clear__74bd3acf","empty":"input_empty__74bd3acf","active":"input_active__74bd3acf","noLabel":"input_noLabel__74bd3acf","error":"input_error__74bd3acf","underline":"input_underline__74bd3acf","focusUnderline":"input_focusUnderline__74bd3acf","errorUnderline":"input_errorUnderline__74bd3acf","errorText":"input_errorText__74bd3acf","sizeS":"input_sizeS__74bd3acf","sizeM":"input_sizeM__74bd3acf","sizeL":"input_sizeL__74bd3acf","sizeFULL":"input_sizeFULL__74bd3acf"};
21
-
22
- function noop() {}
23
- /**
24
- * @name Input
25
- */
26
-
27
-
28
- const Size = {
29
- AUTO: 'Auto',
30
- S: 'S',
31
- M: 'M',
32
- L: 'L',
33
- FULL: 'FULL'
34
- };
35
- class Input extends PureComponent {
36
- constructor() {
37
- super(...arguments);
38
-
39
- _defineProperty(this, "state", {
40
- empty: true
41
- });
42
-
43
- _defineProperty(this, "id", getUID('ring-input-'));
44
-
45
- _defineProperty(this, "underlineRef", el => {
46
- this.underlineNode = el;
47
- });
48
-
49
- _defineProperty(this, "inputRef", el => {
50
- const {
51
- inputRef
52
- } = this.props;
53
- this.input = el;
54
-
55
- if (typeof inputRef === 'function') {
56
- inputRef(el);
57
- } else {
58
- inputRef.current = el;
59
- }
60
- });
61
-
62
- _defineProperty(this, "clear", e => {
63
- this.props.onClear && this.props.onClear(e);
64
- });
65
-
66
- _defineProperty(this, "handleChange", e => {
67
- this.props.onChange(e);
68
- this.checkValue(e.target);
69
- });
70
- }
71
-
72
- componentDidMount() {
73
- this.adapt();
74
- }
75
-
76
- componentDidUpdate() {
77
- this.adapt();
78
- }
79
-
80
- getId() {
81
- return this.props.id || this.id;
82
- }
83
-
84
- checkValue() {
85
- this.setState({
86
- empty: !this.input.value
87
- });
88
-
89
- if (this.props.multiline && this.input.scrollHeight > this.input.clientHeight) {
90
- this.stretch(this.input);
91
- }
92
- }
93
-
94
- stretch(el) {
95
- if (!el || !el.style) {
96
- return;
97
- }
98
-
99
- el.style.height = `${el.scrollHeight}px`;
100
- }
101
-
102
- adapt() {
103
- this.checkValue();
104
- this.stretch(this.underlineNode);
105
- }
106
-
107
- render() {
108
- const _this$props = this.props,
109
- {
110
- // Modifiers
111
- theme,
112
- size,
113
- active,
114
- multiline,
115
- borderless,
116
- compact,
117
- // Props
118
- label,
119
- error,
120
- className,
121
- inputClassName,
122
- children,
123
- value,
124
- onClear,
125
- disabled,
126
- inputRef,
127
- onChange,
128
- enableShortcuts,
129
- id,
130
- placeholder,
131
- icon,
132
- renderUnderline
133
- } = _this$props,
134
- restProps = _objectWithoutProperties(_this$props, ["theme", "size", "active", "multiline", "borderless", "compact", "label", "error", "className", "inputClassName", "children", "value", "onClear", "disabled", "inputRef", "onChange", "enableShortcuts", "id", "placeholder", "icon", "renderUnderline"]);
135
-
136
- const minimizeMargins = compact || borderless;
137
- const {
138
- empty
139
- } = this.state;
140
- const clearable = !!onClear;
141
- const classes = classNames(modules_88cfaf40.container, className, modules_88cfaf40[theme], [modules_88cfaf40[`size${size}`]], {
142
- 'ring-js-shortcuts': enableShortcuts === true,
143
- [modules_88cfaf40.active]: active,
144
- [modules_88cfaf40.error]: error != null,
145
- [modules_88cfaf40.empty]: empty,
146
- [modules_88cfaf40.noLabel]: !this.props.label,
147
- [modules_88cfaf40.withIcon]: icon != null,
148
- [modules_88cfaf40.clearable]: clearable,
149
- [modules_88cfaf40.compact]: minimizeMargins
150
- });
151
- const inputClasses = classNames(modules_88cfaf40.input, inputClassName);
152
- const TagName = multiline ? 'textarea' : 'input';
153
- const text = value != null ? value : children;
154
- return /*#__PURE__*/React.createElement("div", {
155
- className: classes,
156
- "data-test": "ring-input"
157
- }, icon && /*#__PURE__*/React.createElement(Icon, {
158
- glyph: icon,
159
- className: modules_88cfaf40.icon
160
- }), /*#__PURE__*/React.createElement(TagName, _extends({
161
- ref: this.inputRef,
162
- onChange: this.handleChange,
163
- className: inputClasses,
164
- value: text,
165
- rows: multiline ? 1 : null,
166
- disabled: disabled,
167
- id: this.getId(),
168
- placeholder: placeholder,
169
- "aria-label": typeof label === 'string' && label ? label : placeholder,
170
- "data-enabled-shortcuts": Array.isArray(enableShortcuts) ? enableShortcuts.join(',') : null
171
- }, restProps)), clearable && !disabled && /*#__PURE__*/React.createElement(Button, {
172
- title: "Clear input",
173
- "data-test": "ring-input-clear",
174
- className: modules_88cfaf40.clear,
175
- icon: closeIcon,
176
- onClick: this.clear
177
- }), !minimizeMargins && /*#__PURE__*/React.createElement("label", {
178
- htmlFor: this.getId(),
179
- className: modules_88cfaf40.label
180
- }, label), !borderless && /*#__PURE__*/React.createElement("div", {
181
- className: modules_88cfaf40.underline
182
- }), !borderless && /*#__PURE__*/React.createElement("div", {
183
- className: modules_88cfaf40.focusUnderline
184
- }), !minimizeMargins && /*#__PURE__*/React.createElement("div", {
185
- className: modules_88cfaf40.errorUnderline
186
- }), !minimizeMargins && renderUnderline(this.underlineRef, error));
187
- }
188
-
189
- }
190
-
191
- _defineProperty(Input, "propTypes", {
192
- value: PropTypes.string,
193
- theme: PropTypes.string,
194
- className: PropTypes.string,
195
- inputClassName: PropTypes.string,
196
- size: PropTypes.string,
197
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),
198
- active: PropTypes.bool,
199
- error: PropTypes.string,
200
- multiline: PropTypes.bool,
201
- borderless: PropTypes.bool,
202
- compact: PropTypes.bool,
203
- onChange: PropTypes.func,
204
- onClear: PropTypes.func,
205
- inputRef: PropTypes.oneOfType([PropTypes.func, PropTypes.shape({
206
- current: PropTypes.instanceOf(HTMLInputElement)
207
- })]),
208
- children: PropTypes.string,
209
- enableShortcuts: PropTypes.oneOfType([PropTypes.bool, PropTypes.arrayOf(PropTypes.string)]),
210
- disabled: PropTypes.bool,
211
- id: PropTypes.string,
212
- placeholder: PropTypes.string,
213
- icon: PropTypes.oneOfType([PropTypes.string, PropTypes.elementType]),
214
- renderUnderline: PropTypes.func
215
- });
216
-
217
- _defineProperty(Input, "defaultProps", {
218
- size: Size.M,
219
- onChange: noop,
220
- inputRef: noop,
221
- enableShortcuts: ['esc'],
222
- renderUnderline: (underlineRef, errorText) => /*#__PURE__*/React.createElement("div", {
223
- className: modules_88cfaf40.errorText,
224
- ref: underlineRef
225
- }, errorText)
226
- });
227
-
228
- var Input$1 = withTheme()(Input);
229
-
230
- export default Input$1;
231
- export { Input, Size };
@@ -1,48 +0,0 @@
1
- import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { createContext, Component } from 'react';
3
- import { interpolateLinear } from '../global/linear-function.js';
4
-
5
- const TITLE_RESIZE_END = 20;
6
- const TITLE_RESIZE_THRESHOLD = 36;
7
- const PhaseContext = /*#__PURE__*/createContext();
8
- const ScrollHandlerContext = /*#__PURE__*/createContext();
9
- function adaptiveIslandHOC(ComposedComponent) {
10
- var _class, _temp;
11
-
12
- return _temp = _class = class AdaptiveIsland extends Component {
13
- constructor() {
14
- super(...arguments);
15
-
16
- _defineProperty(this, "state", {
17
- phase: 0
18
- });
19
-
20
- _defineProperty(this, "onContentScroll", _ref => {
21
- let {
22
- scrollTop,
23
- scrollHeight,
24
- clientHeight
25
- } = _ref;
26
-
27
- if (scrollHeight - clientHeight >= interpolateLinear(TITLE_RESIZE_THRESHOLD, TITLE_RESIZE_END, this.state.phase)) {
28
- const phase = Math.min(1, scrollTop / TITLE_RESIZE_END);
29
- this.setState({
30
- phase
31
- });
32
- }
33
- });
34
- }
35
-
36
- render() {
37
- return /*#__PURE__*/React.createElement(PhaseContext.Provider, {
38
- value: this.state.phase
39
- }, /*#__PURE__*/React.createElement(ScrollHandlerContext.Provider, {
40
- value: this.onContentScroll
41
- }, /*#__PURE__*/React.createElement(ComposedComponent, this.props)));
42
- }
43
-
44
- }, _defineProperty(_class, "propTypes", ComposedComponent.propTypes), _temp;
45
- }
46
-
47
- export default adaptiveIslandHOC;
48
- export { PhaseContext, ScrollHandlerContext };
@@ -1,158 +0,0 @@
1
- import { _ as _defineProperty, b as _extends, a as _objectWithoutProperties } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import createResizeDetector from 'element-resize-detector';
6
- import scheduleRAF from '../global/schedule-raf.js';
7
- import { m as modules_e6a056e1 } from '../_helpers/island.js';
8
- import { ScrollHandlerContext } from './adaptive-island-hoc.js';
9
- import '../global/linear-function.js';
10
-
11
- const scheduleScrollAction = scheduleRAF();
12
-
13
- const noop = () => {};
14
-
15
- const END_DISTANCE = 16;
16
-
17
- class Content extends Component {
18
- constructor() {
19
- super(...arguments);
20
-
21
- _defineProperty(this, "state", {
22
- scrolledToTop: true,
23
- scrolledToBottom: false
24
- });
25
-
26
- _defineProperty(this, "resizeDetector", createResizeDetector({
27
- strategy: 'scroll'
28
- }));
29
-
30
- _defineProperty(this, "setWrapper", node => {
31
- if (!node) {
32
- return;
33
- }
34
-
35
- this.wrapperNode = node;
36
- this.resizeDetector.listenTo(node, this.calculateScrollPosition);
37
- });
38
-
39
- _defineProperty(this, "calculateScrollPosition", () => scheduleScrollAction(() => {
40
- const {
41
- scrollableNode
42
- } = this;
43
-
44
- if (!scrollableNode) {
45
- return;
46
- }
47
-
48
- const {
49
- scrollTop,
50
- scrollHeight,
51
- offsetHeight
52
- } = scrollableNode;
53
- const scrolledToTop = scrollTop === 0;
54
- const scrolledToBottom = offsetHeight + scrollTop >= scrollHeight - END_DISTANCE;
55
-
56
- if (scrolledToBottom) {
57
- this.props.onScrollToBottom();
58
- }
59
-
60
- this.setState({
61
- scrolledToTop,
62
- scrolledToBottom
63
- });
64
- }));
65
-
66
- _defineProperty(this, "onScroll", () => {
67
- this.props.onScroll(this.scrollableNode);
68
- this.calculateScrollPosition();
69
- });
70
-
71
- _defineProperty(this, "setScrollableNodeAndCalculatePosition", node => {
72
- if (!node) {
73
- return;
74
- }
75
-
76
- this.scrollableNode = node;
77
- this.calculateScrollPosition();
78
- });
79
- }
80
-
81
- componentWillUnmount() {
82
- this.scrollableNode = null;
83
-
84
- if (!this.wrapperNode) {
85
- return;
86
- }
87
-
88
- this.resizeDetector.removeAllListeners(this.wrapperNode);
89
- }
90
-
91
- render() {
92
- const _this$props = this.props,
93
- {
94
- children,
95
- className,
96
- bottomBorder,
97
- scrollableWrapperClassName,
98
- onScroll,
99
- onScrollToBottom,
100
- fade
101
- } = _this$props,
102
- restProps = _objectWithoutProperties(_this$props, ["children", "className", "bottomBorder", "scrollableWrapperClassName", "onScroll", "onScrollToBottom", "fade"]);
103
-
104
- const {
105
- scrolledToTop,
106
- scrolledToBottom
107
- } = this.state;
108
- const classes = classNames(modules_e6a056e1.content, className, {
109
- [modules_e6a056e1.contentWithTopFade]: fade && !scrolledToTop,
110
- [modules_e6a056e1.contentWithBottomFade]: fade && !scrolledToBottom,
111
- [modules_e6a056e1.withTransparentBottomBorder]: bottomBorder,
112
- [modules_e6a056e1.withBottomBorder]: bottomBorder && !scrolledToBottom
113
- });
114
- const scrollableWrapperClasses = classNames(modules_e6a056e1.scrollableWrapper, scrollableWrapperClassName);
115
- return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
116
- "data-test": "ring-island-content",
117
- className: classes
118
- }), /*#__PURE__*/React.createElement("div", {
119
- // it has to be focusable because it can be scrollable
120
- // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
121
- tabIndex: 0,
122
- "data-scrollable-container": true,
123
- className: scrollableWrapperClasses,
124
- ref: this.setScrollableNodeAndCalculatePosition,
125
- onScroll: fade ? this.onScroll : noop
126
- }, fade && /*#__PURE__*/React.createElement("div", {
127
- ref: this.setWrapper
128
- }, children), !fade && children));
129
- }
130
-
131
- }
132
-
133
- _defineProperty(Content, "propTypes", {
134
- children: PropTypes.node,
135
- className: PropTypes.string,
136
- scrollableWrapperClassName: PropTypes.string,
137
- fade: PropTypes.bool,
138
- bottomBorder: PropTypes.bool,
139
- onScroll: PropTypes.func,
140
- onScrollToBottom: PropTypes.func
141
- });
142
-
143
- _defineProperty(Content, "defaultProps", {
144
- fade: true,
145
- bottomBorder: false,
146
- onScroll: noop,
147
- onScrollToBottom: noop
148
- });
149
-
150
- const ContentWrapper = props => /*#__PURE__*/React.createElement(ScrollHandlerContext.Consumer, null, onScroll => {
151
- const addProps = onScroll != null ? {
152
- onScroll,
153
- bottomBorder: true
154
- } : {};
155
- return /*#__PURE__*/React.createElement(Content, _extends({}, props, addProps));
156
- });
157
-
158
- export default ContentWrapper;
@@ -1,85 +0,0 @@
1
- import { _ as _defineProperty, b as _extends, a as _objectWithoutProperties } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import { interpolateLinear } from '../global/linear-function.js';
6
- import { m as modules_e6a056e1 } from '../_helpers/island.js';
7
- import { PhaseContext } from './adaptive-island-hoc.js';
8
-
9
- const Start = {
10
- FONT_SIZE: 24,
11
- LINE_HEIGHT: 28,
12
- PADDING: 16
13
- };
14
- const End = {
15
- FONT_SIZE: 13,
16
- LINE_HEIGHT: 28,
17
- // Compensation
18
- X: 0.4,
19
- Y: 0.1,
20
- SPACING: 1.09
21
- };
22
- const BORDER_APPEAR_PHASE = 0.5;
23
-
24
- class Header extends Component {
25
- style(name) {
26
- return interpolateLinear(Start[name] || 0, End[name] || 0, this.props.phase);
27
- }
28
-
29
- render() {
30
- const _this$props = this.props,
31
- {
32
- children,
33
- className,
34
- wrapWithTitle,
35
- border,
36
- phase
37
- } = _this$props,
38
- restProps = _objectWithoutProperties(_this$props, ["children", "className", "wrapWithTitle", "border", "phase"]);
39
-
40
- const classes = classNames(modules_e6a056e1.header, className, {
41
- [modules_e6a056e1.withBottomBorder]: border || phase >= BORDER_APPEAR_PHASE
42
- });
43
- const headerStyle = phase != null ? {
44
- lineHeight: `${this.style('LINE_HEIGHT')}px`,
45
- // need to append px because number is a valid line-height value
46
- paddingTop: this.style('PADDING')
47
- } : null;
48
- const scaleFont = phase != null && this.style('FONT_SIZE') / Start.FONT_SIZE;
49
- const titleStyle = phase != null && phase < 1 ? {
50
- fontSize: Start.FONT_SIZE,
51
- transform: `translate(${this.style('X')}px, ${this.style('Y')}px) scale(${scaleFont})`,
52
- letterSpacing: this.style('SPACING')
53
- } : null;
54
- return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
55
- "data-test": "ring-island-header",
56
- className: classes,
57
- style: headerStyle
58
- }), wrapWithTitle && /*#__PURE__*/React.createElement("h2", {
59
- className: modules_e6a056e1.title,
60
- style: titleStyle
61
- }, children), !wrapWithTitle && children);
62
- }
63
-
64
- }
65
-
66
- _defineProperty(Header, "propTypes", {
67
- children: PropTypes.node,
68
- className: PropTypes.string,
69
- border: PropTypes.bool,
70
- wrapWithTitle: PropTypes.bool,
71
- phase: PropTypes.number
72
- });
73
-
74
- _defineProperty(Header, "defaultProps", {
75
- wrapWithTitle: true
76
- });
77
-
78
- const HeaderWrapper = props => /*#__PURE__*/React.createElement(PhaseContext.Consumer, null, phase => {
79
- const addProps = phase != null ? {
80
- phase
81
- } : {};
82
- return /*#__PURE__*/React.createElement(Header, _extends({}, props, addProps));
83
- });
84
-
85
- export default HeaderWrapper;
@@ -1,53 +0,0 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import joinDataTestAttributes from '../global/data-tests.js';
6
- import adaptiveIslandHOC from './adaptive-island-hoc.js';
7
- import { m as modules_e6a056e1 } from '../_helpers/island.js';
8
- export { default as Header } from './header.js';
9
- export { default as Content } from './content.js';
10
- import '../global/linear-function.js';
11
- import 'element-resize-detector';
12
- import '../global/schedule-raf.js';
13
-
14
- /**
15
- * @name Island
16
- */
17
-
18
- class Island extends Component {
19
- render() {
20
- const _this$props = this.props,
21
- {
22
- children,
23
- className,
24
- narrow,
25
- withoutPaddings,
26
- 'data-test': dataTest
27
- } = _this$props,
28
- restProps = _objectWithoutProperties(_this$props, ["children", "className", "narrow", "withoutPaddings", "data-test"]);
29
-
30
- const classes = classNames(modules_e6a056e1.island, className, {
31
- [modules_e6a056e1.narrowIsland]: narrow,
32
- [modules_e6a056e1.withoutPaddings]: withoutPaddings
33
- });
34
- return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
35
- className: classes,
36
- "data-test": joinDataTestAttributes('ring-island', dataTest)
37
- }), children);
38
- }
39
-
40
- }
41
-
42
- _defineProperty(Island, "propTypes", {
43
- children: PropTypes.node,
44
- className: PropTypes.string,
45
- narrow: PropTypes.bool,
46
- withoutPaddings: PropTypes.bool,
47
- 'data-test': PropTypes.string
48
- });
49
-
50
- const AdaptiveIsland = adaptiveIslandHOC(Island);
51
-
52
- export default Island;
53
- export { AdaptiveIsland };
@@ -1,28 +0,0 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
-
6
- class Content extends PureComponent {
7
- render() {
8
- const _this$props = this.props,
9
- {
10
- children,
11
- className
12
- } = _this$props,
13
- restProps = _objectWithoutProperties(_this$props, ["children", "className"]);
14
-
15
- const classes = classNames('ring-island__content', className);
16
- return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
17
- className: classes
18
- }), children);
19
- }
20
-
21
- }
22
-
23
- _defineProperty(Content, "propTypes", {
24
- className: PropTypes.string,
25
- children: PropTypes.node
26
- });
27
-
28
- export default Content;
@@ -1,30 +0,0 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
-
6
- class Header extends PureComponent {
7
- render() {
8
- const _this$props = this.props,
9
- {
10
- children,
11
- className
12
- } = _this$props,
13
- restProps = _objectWithoutProperties(_this$props, ["children", "className"]);
14
-
15
- const classes = classNames('ring-island__header', className);
16
- return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
17
- className: classes
18
- }), /*#__PURE__*/React.createElement("div", {
19
- className: "ring-island__title"
20
- }, children));
21
- }
22
-
23
- }
24
-
25
- _defineProperty(Header, "propTypes", {
26
- className: PropTypes.string,
27
- children: PropTypes.node
28
- });
29
-
30
- export default Header;
@@ -1,30 +0,0 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- export { default as Header } from './header-legacy.js';
6
- export { default as Content } from './content-legacy.js';
7
-
8
- class Island extends PureComponent {
9
- render() {
10
- const _this$props = this.props,
11
- {
12
- children,
13
- className
14
- } = _this$props,
15
- restProps = _objectWithoutProperties(_this$props, ["children", "className"]);
16
-
17
- const classes = classNames('ring-island', className);
18
- return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
19
- className: classes
20
- }), children);
21
- }
22
-
23
- }
24
-
25
- _defineProperty(Island, "propTypes", {
26
- className: PropTypes.string,
27
- children: PropTypes.node
28
- });
29
-
30
- export default Island;