@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
@@ -12,14 +12,12 @@ import List, {ActiveItemContext} from '../list/list';
12
12
  import Input, {Size} from '../input/input';
13
13
  import Shortcuts from '../shortcuts/shortcuts';
14
14
  import Button from '../button/button';
15
- import buttonStyles from '../button/button.css';
16
15
  import dataTests from '../global/data-tests';
17
16
  import getUID from '../global/get-uid';
18
17
  import rerenderHOC from '../global/rerender-hoc';
19
18
  import fuzzyHighlight from '../global/fuzzy-highlight';
20
- import Theme, {ThemeContext} from '../global/theme';
19
+ import Theme from '../global/theme';
21
20
  import memoize from '../global/memoize';
22
- import getEventKey from '../global/get-event-key';
23
21
 
24
22
  import SelectPopup from './select__popup';
25
23
  import styles from './select.css';
@@ -222,6 +220,7 @@ export default class Select extends Component {
222
220
 
223
221
  static propTypes = {
224
222
  className: PropTypes.string,
223
+ buttonClassName: PropTypes.string,
225
224
  id: PropTypes.string,
226
225
  multiple: PropTypes.oneOfType([PropTypes.bool, PropTypes.object]),
227
226
  allowAny: PropTypes.bool,
@@ -523,10 +522,6 @@ export default class Select extends Component {
523
522
  return getSelectedIndex(selected, data, this.props.multiple);
524
523
  }
525
524
 
526
- popupRef = el => {
527
- this._popup = el;
528
- };
529
-
530
525
  _getResetOption() {
531
526
  const isOptionsSelected = this.state.selected && this.state.selected.length;
532
527
  const hasTagsResetProp = this.props.tags && this.props.tags.reset;
@@ -743,13 +738,6 @@ export default class Select extends Component {
743
738
  }
744
739
  };
745
740
 
746
- _selectButtonKeyboardHack = event => {
747
- const key = getEventKey(event);
748
- if (key === 'Enter' || key === ' ') {
749
- this._clickHandler();
750
- }
751
- };
752
-
753
741
  _filterChangeHandler = e => {
754
742
  this._setFilter(e.target.value, e);
755
743
  };
@@ -1004,6 +992,7 @@ export default class Select extends Component {
1004
992
  type="button"
1005
993
  className={styles.selectedIcon}
1006
994
  key="selected"
995
+ disabled={this.props.disabled}
1007
996
  onClick={this._clickHandler}
1008
997
  style={{backgroundImage: `url(${selected.icon})`}}
1009
998
  />
@@ -1017,6 +1006,7 @@ export default class Select extends Component {
1017
1006
  data-test="ring-clear-select"
1018
1007
  className={styles.clearIcon}
1019
1008
  key="close"
1009
+ disabled={this.props.disabled}
1020
1010
  onClick={this.clear}
1021
1011
  icon={closeIcon}
1022
1012
  />
@@ -1031,6 +1021,7 @@ export default class Select extends Component {
1031
1021
  iconClassName={styles.chevronIcon}
1032
1022
  icon={chevronDownIcon}
1033
1023
  key="hide"
1024
+ disabled={this.props.disabled}
1034
1025
  onClick={this._clickHandler}
1035
1026
  />
1036
1027
  );
@@ -1040,10 +1031,12 @@ export default class Select extends Component {
1040
1031
  }
1041
1032
 
1042
1033
  _getAvatar() {
1043
- return this.state.selected && this.state.selected.avatar && (
1034
+ return this.state.selected &&
1035
+ (this.state.selected.avatar || this.state.selected.showGeneratedAvatar) && (
1044
1036
  <Avatar
1045
1037
  className={styles.avatar}
1046
1038
  url={this.state.selected.avatar}
1039
+ username={this.state.selected.username}
1047
1040
  size={AvatarSize.Size20}
1048
1041
  />
1049
1042
  );
@@ -1152,33 +1145,27 @@ export default class Select extends Component {
1152
1145
  scope={this.shortcutsScope}
1153
1146
  />
1154
1147
  )}
1155
- <ThemeContext.Consumer>
1156
- {contextTheme => (
1157
- <div
1158
- {...ariaProps}
1159
- id={this.props.id}
1160
- onClick={this._clickHandler}
1161
- onKeyPress={this._selectButtonKeyboardHack}
1162
- className={classNames(
1163
- buttonStyles.button,
1164
- buttonStyles[this.props.theme || contextTheme || Theme.LIGHT],
1165
- styles.buttonValue,
1166
- {
1167
- [styles.buttonValueOpen]: this.state.showPopup
1168
- })
1169
- }
1170
- role="button"
1171
- tabIndex={0}
1172
- disabled={this.props.disabled}
1173
- style={style}
1174
- data-test="ring-select__button ring-select__focus"
1175
- >
1176
- {this._getAvatar()}
1177
- {this._selectionIsEmpty() ? this._getLabel() : this._getSelectedString()}
1178
- {iconsNode}
1179
- </div>
1180
- )}
1181
- </ThemeContext.Consumer>
1148
+ <div className={styles.buttonContainer}>
1149
+ <Button
1150
+ {...ariaProps}
1151
+ id={this.props.id}
1152
+ onClick={this._clickHandler}
1153
+ className={classNames(
1154
+ this.props.buttonClassName,
1155
+ styles.buttonValue,
1156
+ {
1157
+ [styles.buttonValueOpen]: this.state.showPopup
1158
+ })
1159
+ }
1160
+ disabled={this.props.disabled}
1161
+ style={style}
1162
+ data-test="ring-select__button ring-select__focus"
1163
+ >
1164
+ {this._getAvatar()}
1165
+ {this._selectionIsEmpty() ? this._getLabel() : this._getSelectedString()}
1166
+ </Button>
1167
+ {iconsNode}
1168
+ </div>
1182
1169
  {this._renderPopup()}
1183
1170
  </div>
1184
1171
  );
@@ -1205,7 +1192,7 @@ export default class Select extends Component {
1205
1192
  onClick={this._clickHandler}
1206
1193
  type="button"
1207
1194
  disabled={this.props.disabled}
1208
- className={classNames(styles.value, {
1195
+ className={classNames(this.props.buttonClassName, styles.value, {
1209
1196
  [styles.open]: this.state.showPopup,
1210
1197
  [styles.label]: this._selectionIsEmpty()
1211
1198
  })}
@@ -1,6 +1,5 @@
1
- /* eslint-disable no-magic-numbers, react/no-find-dom-node */
1
+ /* eslint-disable no-magic-numbers*/
2
2
  import React from 'react';
3
- import {findDOMNode} from 'react-dom';
4
3
  import {Simulate} from 'react-dom/test-utils';
5
4
  import {shallow, mount} from 'enzyme';
6
5
 
@@ -212,7 +211,7 @@ describe('Select', () => {
212
211
  const instance = wrapper.instance();
213
212
  instance._showPopup();
214
213
 
215
- Simulate.mouseDown(findDOMNode(instance._popup.list));
214
+ Simulate.mouseDown(instance._popup.list.container);
216
215
  Simulate.blur(instance.filter);
217
216
  sandbox.clock.tick();
218
217
  instance._popup.props.hidden.should.be.false;
@@ -623,7 +622,7 @@ describe('Select', () => {
623
622
  const instance = wrapper.instance();
624
623
  instance._showPopup();
625
624
  instance.filterValue('test');
626
- findDOMNode(instance._popup.filter).value.should.equal('test');
625
+ instance._popup.filter.value.should.equal('test');
627
626
  });
628
627
 
629
628
  it('Should set target input value in input mode', () => {
@@ -642,7 +641,7 @@ describe('Select', () => {
642
641
  instance._showPopup();
643
642
  instance._hidePopup();
644
643
  instance._showPopup();
645
- findDOMNode(instance._popup.filter).value.should.equal('');
644
+ instance._popup.filter.value.should.equal('');
646
645
  });
647
646
  });
648
647
 
@@ -43,7 +43,7 @@
43
43
 
44
44
  height: calc(unit / 2);
45
45
 
46
- content: '';
46
+ content: "";
47
47
  }
48
48
 
49
49
  :global(.shortcuts-hint__search-input-wrapper) {
@@ -10,7 +10,7 @@ import IconNg from '../icon-ng/icon-ng';
10
10
  import InputNg from '../input-ng/input-ng';
11
11
  import {getShortcutTitle} from '../shortcuts/shortcut-title';
12
12
 
13
- import HintPopupTpl from './shortcuts-hint-ng.html';
13
+ import HintPopupTpl from './shortcuts-hint-ng__template';
14
14
  import './shortcuts-hint-ng.css';
15
15
 
16
16
  /**
@@ -1,4 +1,4 @@
1
- <div class="shortcuts-hint">
1
+ export default `<div class="shortcuts-hint">
2
2
 
3
3
  <div class="shortcuts-hint__search-input-wrapper">
4
4
  <rg-input
@@ -45,4 +45,4 @@
45
45
 
46
46
  <div rg-template="hintPopupCtrl.tailTemplate"></div>
47
47
 
48
- </div>
48
+ </div>`;
@@ -63,6 +63,7 @@
63
63
  width: calc(6 * unit);
64
64
  height: calc(6 * unit);
65
65
  object-fit: contain;
66
+
66
67
  padding: 0 calc(2 * unit) 0 calc(4 * unit);
67
68
  }
68
69
 
@@ -10,6 +10,10 @@ import ButtonNG from '../button-ng/button-ng';
10
10
 
11
11
  import '../sidebar/sidebar.css';
12
12
 
13
+ import template from './sidebar-ng__template';
14
+
15
+ import buttonTemplate from './sidebar-ng__button-template';
16
+
13
17
  /**
14
18
  * @name Sidebar Ng
15
19
  */
@@ -66,7 +70,7 @@ function rgSidebarDirective() {
66
70
  topOffset: '=?',
67
71
  dialogIsActive: '=?'
68
72
  },
69
- template: require('./sidebar-ng.html'),
73
+ template,
70
74
  controllerAs: 'sidebar'
71
75
  };
72
76
  }
@@ -85,7 +89,7 @@ function rgSidebarToggleButtonDirective() {
85
89
  model: '=',
86
90
  dialogIsActive: '=?'
87
91
  },
88
- template: require('./sidebar-ng__button.html'),
92
+ template: buttonTemplate,
89
93
  controllerAs: 'button'
90
94
  };
91
95
  }
@@ -1,4 +1,4 @@
1
- <span>
1
+ export default `<span>
2
2
  <rg-button
3
3
  ng-click="button.model = !button.model"
4
4
  ng-disabled="button.dialogIsActive"
@@ -15,4 +15,4 @@
15
15
 
16
16
  <span ng-transclude></span>
17
17
  </rg-button>
18
- </span>
18
+ </span>`;
@@ -1,4 +1,4 @@
1
- <div
1
+ export default `<div
2
2
  class="ring-sidebar"
3
3
  rg-place-under="{{sidebar.placeUnderSibling}}"
4
4
  place-top-offset="{{sidebar.topOffset}}"
@@ -7,4 +7,4 @@
7
7
  >
8
8
  <rg-dialog in-sidebar="true" active="sidebar.dialogIsActive"></rg-dialog>
9
9
  <div class="ring-sidebar__content" ng-transclude ng-if="!sidebar.dialogIsActive"></div>
10
- </div>
10
+ </div>`;
@@ -214,10 +214,11 @@ export default class Row extends PureComponent {
214
214
  const getDataTest = column.getDataTest || (() => column.id);
215
215
  const value = getValue(item, column);
216
216
  const cellClasses = classNames({[style.cellRight]: column.rightAlign}, column.className);
217
+ const showMetaColumn = draggable || selectable || showDisabledSelection || !!level;
217
218
 
218
219
  return (
219
220
  <Cell key={column.id} className={cellClasses} data-test={getDataTest(item, column)}>
220
- {index === 0 && (draggable || selectable || showDisabledSelection) && metaColumn}
221
+ {index === 0 && (showMetaColumn) && metaColumn}
221
222
  {value}
222
223
  </Cell>
223
224
  );
@@ -137,7 +137,8 @@
137
137
  line-height: compensated;
138
138
  }
139
139
 
140
- @nest .table:not(.disabledHover) &:hover .row {
140
+ /* stylelint-disable-next-line selector-max-specificity */
141
+ .table:not(.disabledHover) .row:hover {
141
142
  background-color: var(--ring-hover-background-color);
142
143
  }
143
144
 
@@ -75,7 +75,7 @@
75
75
  }
76
76
 
77
77
  :global(.ring-table__title_border::after) {
78
- content: '';
78
+ content: "";
79
79
  }
80
80
 
81
81
  :global(.ring-table__title_nested) {
@@ -239,7 +239,7 @@
239
239
  }
240
240
 
241
241
  :global(.ring-table__column-list:not(:last-child)::after) {
242
- content: ', ';
242
+ content: ", ";
243
243
  }
244
244
 
245
245
  :global(.ring-table__row) {
@@ -17,9 +17,9 @@
17
17
 
18
18
  background: inherit;
19
19
 
20
- &.ring-table__toolbar-controls_fixed {
20
+ &:global(.ring-table__toolbar-controls_fixed) {
21
21
  position: fixed;
22
- z-index: calc(var(--ring-fixed-z-index) + 1px);
22
+ z-index: calc(var(--ring-fixed-z-index) + 1);
23
23
  top: 0;
24
24
  right: 0;
25
25
  left: 0;
@@ -26,7 +26,7 @@ angularModule.directive('rgLegacyTable', function rgLegacyTableDirective() {
26
26
  return {
27
27
  restrict: 'E',
28
28
  transclude: true,
29
- template: require('./table-legacy-ng.html'),
29
+ template: '<div><table class="ring-table" ng-transclude></table></div>',
30
30
  controllerAs: 'ctrl',
31
31
 
32
32
  /**
@@ -79,7 +79,10 @@ angularModule.directive('rgLegacyTableHeader',
79
79
 
80
80
  return {
81
81
  restrict: 'E',
82
- template: require('./table-legacy-ng__header.html'),
82
+ template: `<thead>
83
+ <tr class="ring-table__header" ng-transclude></tr>
84
+ <tr class="ring-table__header ring-table__header_sticky" rg-place-under="{{stickToSelector}}" ng-transclude></tr>
85
+ </thead>`,
83
86
  transclude: true,
84
87
  replace: true,
85
88
  link: function link(scope, iElement, iAttrs) {
@@ -156,7 +159,18 @@ angularModule.directive('rgLegacyTableBody', function rgLegacyTableBodyDirective
156
159
 
157
160
  angularModule.directive('rgLegacyTableRow', function rgLegacyTableRowDirective() {
158
161
  return {
159
- template: require('./table-legacy-ng__row.html'),
162
+ template: `<tr ng-click="rowCtrl.setActiveItem(rowCtrl.rowItem)"
163
+ ng-mouseover="rowCtrl.onMouseOver(rowCtrl.rowItem)"
164
+ ng-mouseout="rowCtrl.onMouseOut(rowCtrl.rowItem)"
165
+ class="ring-table__row" ng-class="{
166
+ 'ring-table__row_active': rowCtrl.rowItem.active,
167
+ 'ring-table__row_checked': rowCtrl.rowItem.checked,
168
+ 'ring-table__row_active-checked': rowCtrl.rowItem.active && !rowCtrl.hasCheckedItems(),
169
+ 'ring-table__row_implicit': rowCtrl.rowItem.implicit,
170
+ 'ring-table__row_expanded': rowCtrl.rowItem.expanded,
171
+ 'ring-table__row_unselectable': rowCtrl.rowItem.unselectable
172
+ }" ng-transclude>
173
+ </tr>`,
160
174
  restrict: 'E',
161
175
  transclude: true,
162
176
  replace: true,
@@ -333,7 +347,15 @@ angularModule.directive('rgLegacyTableTitle', function rgLegacyTableTitleDirecti
333
347
  transclude: true,
334
348
  replace: true,
335
349
  scope: true,
336
- template: require('./table-legacy-ng__title.html'),
350
+ template: `<th class="ring-table__title"
351
+ ng-class="{
352
+ 'ring-table__title_border': isBorder,
353
+ 'ring-table__title_active': isActive,
354
+ 'ring-table__column_snuggle-right': isPullRight,
355
+ 'ring-table__column_snuggle-left': isPullLeft,
356
+ 'ring-table__column_align-right' : isAlignRight
357
+ }" ng-transclude>
358
+ </th>`,
337
359
 
338
360
  link: function link(scope, iElement, iAttrs) {
339
361
  /**
@@ -362,7 +384,18 @@ angularModule.directive('rgLegacyTableColumn', function rgLegacyTableColumnDirec
362
384
  transclude: true,
363
385
  replace: true,
364
386
  scope: true,
365
- template: require('./table-legacy-ng__column.html'),
387
+ template: `<td class="ring-table__column"
388
+ ng-class="{
389
+ 'ring-table__column_limited': isLimited,
390
+ 'ring-table__column_unlimited': isUnlimited,
391
+ 'ring-table__column_right': isAlignRight,
392
+ 'ring-table__avatar': isAvatar,
393
+ 'ring-table__column_wide': isWide,
394
+ 'ring-table__column_gray': isGray,
395
+ 'ring-table__column_snuggle-right': isPullRight,
396
+ 'ring-table__column_snuggle-left': isPullLeft
397
+ }" ng-transclude>
398
+ </td>`,
366
399
 
367
400
  link: function link(scope, iElement, iAttrs) {
368
401
  const element = iElement[0];
@@ -7,7 +7,13 @@ const angularModule = angular.module('Ring.table-legacy.pager', [MessageBundle,
7
7
  angularModule.directive('rgLegacyTablePager', function rgLegacyTablePagerDirective() {
8
8
  return {
9
9
  restrict: 'E',
10
- template: require('./table-legacy-ng__pager.html'),
10
+ template: `<rg-pager
11
+ total="pagerCtrl.total"
12
+ current-page="pagerCtrl.getPage()"
13
+ page-size="pagerCtrl.top"
14
+ on-page-change="pagerCtrl.onPageChange"
15
+ disable-page-size-selector="true"
16
+ ></rg-pager>`,
11
17
  scope: {},
12
18
  bindToController: {
13
19
  skip: '=',
@@ -10,13 +10,13 @@ import {CustomItem} from './custom-item';
10
10
 
11
11
  function noop() {}
12
12
 
13
- const TabTitle = React.memo(({
13
+ const TabTitle = React.memo(function TabTitle({
14
14
  selected,
15
15
  child,
16
16
  handleSelect = noop,
17
17
  collapsed = false,
18
18
  tabIndex
19
- }) => {
19
+ }) {
20
20
  if (child == null || typeof child !== 'object' || child.type === CustomItem) {
21
21
  return child;
22
22
  }
@@ -199,7 +199,7 @@ export const CollapsibleTabs = ({
199
199
  // Initial measure for tabs and more button sizes
200
200
  React.useEffect(() => {
201
201
  if (measureRef.current == null) {
202
- return;
202
+ return undefined;
203
203
  }
204
204
 
205
205
  const measureTask = fastdom.measure(() => {
@@ -220,10 +220,8 @@ export const CollapsibleTabs = ({
220
220
  return width + +marginLeft.replace('px', '') + +marginRight.replace('px', '');
221
221
  });
222
222
 
223
- // eslint-disable-next-line no-param-reassign
224
- const newSummaryWidth = tabsWidth.reduce((acc, curr) => (acc += curr), 0);
225
- // eslint-disable-next-line no-param-reassign
226
- const oldSummaryWidth = elements.sizes.tabs.reduce((acc, curr) => (acc += curr), 0);
223
+ const newSummaryWidth = tabsWidth.reduce((acc, curr) => (acc + curr), 0);
224
+ const oldSummaryWidth = elements.sizes.tabs.reduce((acc, curr) => (acc + curr), 0);
227
225
 
228
226
  if (elements.sizes.more !== moreButtonWidth || newSummaryWidth !== oldSummaryWidth) {
229
227
  fastdom.mutate(() =>
@@ -232,7 +230,6 @@ export const CollapsibleTabs = ({
232
230
  }
233
231
  });
234
232
 
235
- // eslint-disable-next-line consistent-return
236
233
  return () => {
237
234
  fastdom.clear(measureTask);
238
235
  };
@@ -244,7 +241,7 @@ export const CollapsibleTabs = ({
244
241
  let resizeObserver = null;
245
242
 
246
243
  if (measureRef.current === null) {
247
- return;
244
+ return undefined;
248
245
  }
249
246
 
250
247
  resizeObserver = new ResizeObserver(entries => {
@@ -256,7 +253,6 @@ export const CollapsibleTabs = ({
256
253
 
257
254
  resizeObserver.observe(measureRef.current);
258
255
 
259
- // eslint-disable-next-line consistent-return
260
256
  return () => {
261
257
  fastdom.clear(measureTask);
262
258
  resizeObserver.disconnect();
@@ -13,11 +13,13 @@ function TabLink({isSelected, title, collapsed, ...restProps}) {
13
13
  return (
14
14
  <Link {...restProps}>
15
15
  {() => (
16
- <>
16
+ <div className={styles.container}>
17
17
  <span className={styles.visible}>{renderedTitle}</span>
18
18
  {/* hack for preserving constant tab width*/}
19
19
  <span className={styles.hidden}>{renderedTitle}</span>
20
- </>
20
+ <span className={styles.hiddenBold}>{renderedTitle}</span>
21
+ <span className={styles.hiddenRegular}>{renderedTitle}</span>
22
+ </div>
21
23
  )}
22
24
  </Link>
23
25
  );
@@ -66,6 +66,11 @@
66
66
  }
67
67
  }
68
68
 
69
+ .title.titleLegacy {
70
+ display: inline-flex;
71
+ flex-direction: column;
72
+ }
73
+
69
74
  .title + .title {
70
75
  margin-left: calc(unit * 3);
71
76
  }
@@ -112,12 +117,34 @@
112
117
  text-align: center;
113
118
  }
114
119
 
120
+ .container {
121
+ display: flex;
122
+ flex-direction: column;
123
+ }
124
+
115
125
  .hidden {
126
+ display: flex;
116
127
  visibility: hidden;
128
+ }
129
+
130
+ .hiddenBold {
131
+ display: flex;
132
+ visibility: hidden;
133
+
134
+ height: 0;
117
135
 
118
136
  font-weight: bold;
119
137
  }
120
138
 
139
+ .hiddenRegular {
140
+ display: flex;
141
+ visibility: hidden;
142
+
143
+ height: 0;
144
+
145
+ font-weight: normal;
146
+ }
147
+
121
148
  .tabCounter {
122
149
  padding-left: 8px;
123
150
 
@@ -5,6 +5,8 @@ import className from 'classnames';
5
5
  import styles from '../tabs/tabs.css';
6
6
  import Theme from '../global/theme';
7
7
 
8
+ import template from './tabs-ng__template';
9
+
8
10
  /**
9
11
  * @name Tabs Ng
10
12
  */
@@ -15,7 +17,7 @@ angularModule.directive('rgTabs', function rgTabsDirective($location, $rootScope
15
17
  return {
16
18
  restrict: 'E',
17
19
  transclude: true,
18
- template: require('./tabs-ng.html'),
20
+ template,
19
21
  replace: true,
20
22
 
21
23
  scope: {
@@ -161,7 +163,7 @@ angularModule.directive('rgTabs', function rgTabsDirective($location, $rootScope
161
163
  // I think this bug depends on the frequency of addTab calls (actually on digests)
162
164
  // and ng-class detection of added and removed classes becomes broken.
163
165
  // @maxim.erekhinskiy
164
- $scope.tabClass = pane => className(styles.title, {
166
+ $scope.tabClass = pane => className(styles.title, styles.titleLegacy, {
165
167
  [styles.selected]: pane.selected
166
168
  });
167
169
 
@@ -1,4 +1,4 @@
1
- <div
1
+ export default `<div
2
2
  ng-class=":: [styles.tabs, styles[theme]]"
3
3
  rg-shortcuts="ring-tabs"
4
4
  shortcuts-map="keyMap"
@@ -26,9 +26,13 @@
26
26
  hack for preserving constant tab width
27
27
  --><span ng-class=":: styles.hidden">{{pane.title}}<span
28
28
  ng-class=":: styles.tabCounter" ng-show="pane.counter !== undefined">{{ pane.counter }}</span></span>
29
+ <span ng-class=":: styles.hiddenBold">{{pane.title}}<span
30
+ ng-class=":: styles.tabCounter" ng-show="pane.counter !== undefined">{{ pane.counter }}</span></span>
31
+ <span ng-class=":: styles.hiddenRegular">{{pane.title}}<span
32
+ ng-class=":: styles.tabCounter" ng-show="pane.counter !== undefined">{{ pane.counter }}</span></span>
29
33
  </button>
30
34
  </div>
31
35
 
32
36
  <div ng-transclude></div>
33
37
 
34
- </div>
38
+ </div>`;
@@ -56,7 +56,10 @@
56
56
  }
57
57
 
58
58
  .tagAngled {
59
- margin-bottom: -5px !important; /* it needs to fix vertical alignment broken by "overflow: hidden". Remove this class, when IE11 will be deprecated */
59
+ /* it needs to fix vertical alignment broken by "overflow: hidden". Remove this class, when IE11 will be deprecated */
60
+
61
+ margin-bottom: -5px !important;
62
+
60
63
  margin-left: unit;
61
64
  padding-left: calc(unit / 2);
62
65
 
@@ -73,7 +76,7 @@
73
76
  width: 12px;
74
77
  height: 12px;
75
78
 
76
- content: '';
79
+ content: "";
77
80
  transform: scaleY(1.177) rotate(45deg);
78
81
  transform-origin: 0 0;
79
82
 
@@ -36,6 +36,9 @@ export const demo = () => {
36
36
  <Tag avatar={avatarUrl} readOnly={false}>
37
37
  With avatar
38
38
  </Tag>
39
+ <Tag render={({children, ...restProps}) => <a href="/" {...restProps}>{children}</a>}>
40
+ With custom render
41
+ </Tag>
39
42
  </div>
40
43
  );
41
44
  }