@jetbrains/ring-ui 4.2.3 → 4.2.6

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/components/list/list.js +20 -11
  2. package/components/select-ng/select-ng__lazy.js +1 -1
  3. package/package.json +2 -2
  4. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -34
  5. package/dist/_helpers/anchor.js +0 -33
  6. package/dist/_helpers/badge.js +0 -3
  7. package/dist/_helpers/button-group.js +0 -3
  8. package/dist/_helpers/button-set.js +0 -3
  9. package/dist/_helpers/button-toolbar.js +0 -3
  10. package/dist/_helpers/button__classes.js +0 -39
  11. package/dist/_helpers/card.js +0 -75
  12. package/dist/_helpers/checkbox.js +0 -3
  13. package/dist/_helpers/date-picker.js +0 -3
  14. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -58
  15. package/dist/_helpers/error-message.js +0 -3
  16. package/dist/_helpers/footer.js +0 -121
  17. package/dist/_helpers/grid.js +0 -3
  18. package/dist/_helpers/group.js +0 -3
  19. package/dist/_helpers/header.js +0 -3
  20. package/dist/_helpers/icon.js +0 -3
  21. package/dist/_helpers/inject-styles.js +0 -22
  22. package/dist/_helpers/input.js +0 -3
  23. package/dist/_helpers/island.js +0 -3
  24. package/dist/_helpers/link.js +0 -3
  25. package/dist/_helpers/list.js +0 -3
  26. package/dist/_helpers/loader-screen.js +0 -3
  27. package/dist/_helpers/panel.js +0 -3
  28. package/dist/_helpers/query-assist__suggestions.js +0 -95
  29. package/dist/_helpers/radio.js +0 -3
  30. package/dist/_helpers/select__filter.js +0 -77
  31. package/dist/_helpers/services-link.js +0 -40
  32. package/dist/_helpers/sidebar.js +0 -126
  33. package/dist/_helpers/table.js +0 -3
  34. package/dist/_helpers/tabs.js +0 -3
  35. package/dist/_helpers/title.js +0 -100
  36. package/dist/alert/alert.js +0 -262
  37. package/dist/alert/container.js +0 -48
  38. package/dist/alert-service/alert-service.js +0 -173
  39. package/dist/analytics/analytics.js +0 -118
  40. package/dist/analytics/analytics__custom-plugin.js +0 -128
  41. package/dist/analytics/analytics__fus-plugin.js +0 -102
  42. package/dist/analytics/analytics__ga-plugin.js +0 -75
  43. package/dist/analytics/analytics__plugin-utils.js +0 -80
  44. package/dist/analytics-ng/analytics-ng.js +0 -95
  45. package/dist/auth/auth.js +0 -96
  46. package/dist/auth/auth__core.js +0 -1059
  47. package/dist/auth/background-flow.js +0 -123
  48. package/dist/auth/down-notification.js +0 -117
  49. package/dist/auth/iframe-flow.js +0 -153
  50. package/dist/auth/landing-entry.js +0 -5
  51. package/dist/auth/landing.js +0 -90
  52. package/dist/auth/request-builder.js +0 -76
  53. package/dist/auth/response-parser.js +0 -118
  54. package/dist/auth/storage.js +0 -283
  55. package/dist/auth/token-validator.js +0 -178
  56. package/dist/auth/window-flow.js +0 -134
  57. package/dist/auth-dialog/auth-dialog.js +0 -180
  58. package/dist/auth-dialog-service/auth-dialog-service.js +0 -71
  59. package/dist/auth-ng/auth-ng.js +0 -206
  60. package/dist/auth-ng/auth-ng.mock.js +0 -33
  61. package/dist/autofocus-ng/autofocus-ng.js +0 -51
  62. package/dist/avatar/avatar-example-datauri.js +0 -4
  63. package/dist/avatar/avatar.js +0 -163
  64. package/dist/avatar/fallback-avatar.js +0 -142
  65. package/dist/avatar-editor-ng/avatar-editor-ng.js +0 -167
  66. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +0 -3
  67. package/dist/avatar-ng/avatar-ng.js +0 -21
  68. package/dist/badge/badge.js +0 -51
  69. package/dist/badge-ng/badge-ng.js +0 -18
  70. package/dist/breadcrumb-ng/breadcrumb-ng.js +0 -37
  71. package/dist/button/button.js +0 -125
  72. package/dist/button/button__classes.js +0 -5
  73. package/dist/button-group/button-group.js +0 -30
  74. package/dist/button-group/caption.js +0 -24
  75. package/dist/button-group-ng/button-group-ng.js +0 -39
  76. package/dist/button-ng/button-ng.js +0 -217
  77. package/dist/button-set/button-set.js +0 -26
  78. package/dist/button-set-ng/button-set-ng.js +0 -19
  79. package/dist/button-toolbar/button-toolbar.js +0 -29
  80. package/dist/button-toolbar-ng/button-toolbar-ng.js +0 -24
  81. package/dist/caret/caret.js +0 -266
  82. package/dist/checkbox/checkbox.js +0 -110
  83. package/dist/checkbox-ng/checkbox-ng.js +0 -38
  84. package/dist/code/code.js +0 -137
  85. package/dist/compiler-ng/compiler-ng.js +0 -53
  86. package/dist/confirm/confirm.js +0 -127
  87. package/dist/confirm-ng/confirm-ng.js +0 -69
  88. package/dist/confirm-service/confirm-service.js +0 -117
  89. package/dist/content-layout/content-layout.js +0 -66
  90. package/dist/content-layout/sidebar.js +0 -7
  91. package/dist/contenteditable/contenteditable.js +0 -78
  92. package/dist/data-list/data-list.js +0 -208
  93. package/dist/data-list/data-list.mock.js +0 -191
  94. package/dist/data-list/item.js +0 -229
  95. package/dist/data-list/selection.js +0 -102
  96. package/dist/data-list/title.js +0 -20
  97. package/dist/data-list-ng/data-list-ng.js +0 -62
  98. package/dist/date-picker/consts.js +0 -69
  99. package/dist/date-picker/date-input.js +0 -175
  100. package/dist/date-picker/date-picker.js +0 -367
  101. package/dist/date-picker/date-popup.js +0 -483
  102. package/dist/date-picker/day.js +0 -120
  103. package/dist/date-picker/formats.js +0 -3
  104. package/dist/date-picker/month-names.js +0 -100
  105. package/dist/date-picker/month-slider.js +0 -84
  106. package/dist/date-picker/month.js +0 -55
  107. package/dist/date-picker/months.js +0 -122
  108. package/dist/date-picker/weekdays.js +0 -32
  109. package/dist/date-picker/years.js +0 -110
  110. package/dist/dialog/dialog.js +0 -202
  111. package/dist/dialog/dialog__body-scroll-preventer.js +0 -3
  112. package/dist/dialog-ng/dialog-ng.js +0 -604
  113. package/dist/dialog-ng/dialog-ng__template.js +0 -3
  114. package/dist/docked-panel-ng/docked-panel-ng.js +0 -171
  115. package/dist/dropdown/anchor.js +0 -19
  116. package/dist/dropdown/dropdown.js +0 -236
  117. package/dist/dropdown-menu/dropdown-menu.js +0 -177
  118. package/dist/error-bubble/error-bubble.js +0 -59
  119. package/dist/error-message/error-message.js +0 -57
  120. package/dist/error-message-ng/error-message-ng.js +0 -35
  121. package/dist/footer/footer.js +0 -12
  122. package/dist/footer-ng/footer-ng.js +0 -64
  123. package/dist/form-ng/form-ng.js +0 -167
  124. package/dist/global/angular-component-factory.js +0 -84
  125. package/dist/global/compose.js +0 -9
  126. package/dist/global/composeRefs.js +0 -15
  127. package/dist/global/conic-gradient.js +0 -35
  128. package/dist/global/create-stateful-context.js +0 -55
  129. package/dist/global/data-tests.js +0 -24
  130. package/dist/global/dom.js +0 -125
  131. package/dist/global/focus-sensor-hoc.js +0 -146
  132. package/dist/global/fuzzy-highlight.js +0 -67
  133. package/dist/global/get-event-key.js +0 -111
  134. package/dist/global/get-uid.js +0 -15
  135. package/dist/global/inject-styles.js +0 -15
  136. package/dist/global/linear-function.js +0 -17
  137. package/dist/global/listeners.js +0 -44
  138. package/dist/global/memoize.js +0 -20
  139. package/dist/global/normalize-indent.js +0 -30
  140. package/dist/global/promise-with-timeout.js +0 -17
  141. package/dist/global/radial-gradient-mask.js +0 -38
  142. package/dist/global/react-dom-renderer.js +0 -46
  143. package/dist/global/react-render-adapter.js +0 -41
  144. package/dist/global/rerender-hoc.js +0 -55
  145. package/dist/global/ring-angular-component.js +0 -24
  146. package/dist/global/schedule-raf.js +0 -31
  147. package/dist/global/sniffer.js +0 -6
  148. package/dist/global/supports-css.js +0 -22
  149. package/dist/global/theme.js +0 -54
  150. package/dist/global/trivial-template-tag.js +0 -17
  151. package/dist/global/url.js +0 -165
  152. package/dist/global/variables_dark.js +0 -57
  153. package/dist/grid/col.js +0 -60
  154. package/dist/grid/grid.js +0 -33
  155. package/dist/grid/row.js +0 -64
  156. package/dist/group/group.js +0 -31
  157. package/dist/group-ng/group-ng.js +0 -11
  158. package/dist/header/header.js +0 -150
  159. package/dist/header/logo.js +0 -40
  160. package/dist/header/profile.js +0 -219
  161. package/dist/header/services-link.js +0 -12
  162. package/dist/header/services.js +0 -138
  163. package/dist/header/smart-profile.js +0 -233
  164. package/dist/header/smart-services.js +0 -163
  165. package/dist/header/tray-icon.js +0 -47
  166. package/dist/header/tray.js +0 -31
  167. package/dist/heading/heading.js +0 -73
  168. package/dist/http/http.js +0 -218
  169. package/dist/http/http.mock.js +0 -67
  170. package/dist/hub-source/hub-source.js +0 -130
  171. package/dist/hub-source/hub-source__user.js +0 -30
  172. package/dist/hub-source/hub-source__users-groups.js +0 -63
  173. package/dist/icon/icon.js +0 -105
  174. package/dist/icon/icon__constants.js +0 -33
  175. package/dist/icon/icon__svg.js +0 -83
  176. package/dist/icon/index.js +0 -12
  177. package/dist/icon-ng/icon-ng.js +0 -91
  178. package/dist/input/input.js +0 -230
  179. package/dist/input-ng/input-ng.js +0 -111
  180. package/dist/island/adaptive-island-hoc.js +0 -48
  181. package/dist/island/content.js +0 -160
  182. package/dist/island/header.js +0 -84
  183. package/dist/island/island.js +0 -51
  184. package/dist/island-legacy/content-legacy.js +0 -26
  185. package/dist/island-legacy/header-legacy.js +0 -28
  186. package/dist/island-legacy/island-legacy.js +0 -28
  187. package/dist/island-ng/island-content-ng.js +0 -42
  188. package/dist/island-ng/island-header-ng.js +0 -26
  189. package/dist/island-ng/island-ng-class-fixer.js +0 -11
  190. package/dist/island-ng/island-ng.js +0 -25
  191. package/dist/link/clickableLink.js +0 -64
  192. package/dist/link/link.js +0 -115
  193. package/dist/link-ng/link-ng.js +0 -22
  194. package/dist/list/consts.js +0 -26
  195. package/dist/list/list.js +0 -818
  196. package/dist/list/list__custom.js +0 -86
  197. package/dist/list/list__hint.js +0 -26
  198. package/dist/list/list__item.js +0 -206
  199. package/dist/list/list__link.js +0 -65
  200. package/dist/list/list__separator.js +0 -30
  201. package/dist/list/list__title.js +0 -39
  202. package/dist/list/list__users-groups-source.js +0 -130
  203. package/dist/loader/loader.js +0 -71
  204. package/dist/loader/loader__core.js +0 -273
  205. package/dist/loader-inline/inject-styles.js +0 -13
  206. package/dist/loader-inline/loader-inline.js +0 -58
  207. package/dist/loader-inline-ng/loader-inline-ng.js +0 -44
  208. package/dist/loader-ng/loader-ng.js +0 -44
  209. package/dist/loader-screen/loader-screen.js +0 -44
  210. package/dist/loader-screen-ng/loader-screen-ng.js +0 -95
  211. package/dist/login-dialog/login-dialog.js +0 -188
  212. package/dist/login-dialog/service.js +0 -72
  213. package/dist/markdown/code.js +0 -31
  214. package/dist/markdown/heading.js +0 -23
  215. package/dist/markdown/link.js +0 -31
  216. package/dist/markdown/markdown.js +0 -74
  217. package/dist/message/message.js +0 -235
  218. package/dist/message-bundle-ng/message-bundle-ng.js +0 -111
  219. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  220. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  221. package/dist/old-browsers-message/white-list.js +0 -34
  222. package/dist/pager/pager.js +0 -365
  223. package/dist/pager-ng/pager-ng.js +0 -100
  224. package/dist/panel/panel.js +0 -31
  225. package/dist/panel-ng/panel-ng.js +0 -17
  226. package/dist/permissions/permissions.js +0 -200
  227. package/dist/permissions/permissions__cache.js +0 -272
  228. package/dist/permissions-ng/permissions-ng.js +0 -277
  229. package/dist/place-under-ng/place-under-ng.js +0 -158
  230. package/dist/popup/popup.consts.js +0 -41
  231. package/dist/popup/popup.js +0 -396
  232. package/dist/popup/popup.target.js +0 -26
  233. package/dist/popup/position.js +0 -280
  234. package/dist/popup-menu/popup-menu.js +0 -117
  235. package/dist/progress-bar/progress-bar.js +0 -114
  236. package/dist/progress-bar-ng/progress-bar-ng.js +0 -17
  237. package/dist/promised-click-ng/promised-click-ng.js +0 -128
  238. package/dist/proxy-attrs/proxy-attrs.js +0 -21
  239. package/dist/query-assist/query-assist.js +0 -1096
  240. package/dist/query-assist/query-assist__suggestions.js +0 -49
  241. package/dist/query-assist-ng/query-assist-ng.js +0 -86
  242. package/dist/radio/radio.js +0 -42
  243. package/dist/radio/radio__item.js +0 -78
  244. package/dist/radio-ng/radio-ng.js +0 -47
  245. package/dist/save-field-ng/save-field-ng.js +0 -337
  246. package/dist/save-field-ng/save-field-ng__template.js +0 -3
  247. package/dist/select/select.js +0 -1357
  248. package/dist/select/select__filter.js +0 -56
  249. package/dist/select/select__popup.js +0 -553
  250. package/dist/select-ng/select-ng.js +0 -637
  251. package/dist/select-ng/select-ng__lazy.js +0 -169
  252. package/dist/select-ng/select-ng__options.js +0 -145
  253. package/dist/shortcuts/core.js +0 -245
  254. package/dist/shortcuts/shortcut-title.js +0 -51
  255. package/dist/shortcuts/shortcuts-hoc.js +0 -42
  256. package/dist/shortcuts/shortcuts.js +0 -72
  257. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +0 -123
  258. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +0 -3
  259. package/dist/shortcuts-ng/shortcuts-ng.js +0 -262
  260. package/dist/sidebar-ng/sidebar-ng.js +0 -113
  261. package/dist/sidebar-ng/sidebar-ng__button-template.js +0 -3
  262. package/dist/sidebar-ng/sidebar-ng__template.js +0 -3
  263. package/dist/storage/storage.js +0 -59
  264. package/dist/storage/storage__fallback.js +0 -215
  265. package/dist/storage/storage__local.js +0 -154
  266. package/dist/style.css +0 -1
  267. package/dist/tab-trap/tab-trap.js +0 -177
  268. package/dist/table/cell.js +0 -26
  269. package/dist/table/disable-hover-hoc.js +0 -54
  270. package/dist/table/header-cell.js +0 -92
  271. package/dist/table/header.js +0 -193
  272. package/dist/table/multitable.js +0 -141
  273. package/dist/table/row-with-focus-sensor.js +0 -83
  274. package/dist/table/row.js +0 -273
  275. package/dist/table/selection-adapter.js +0 -16
  276. package/dist/table/selection-shortcuts-hoc.js +0 -215
  277. package/dist/table/selection.js +0 -223
  278. package/dist/table/smart-table.js +0 -125
  279. package/dist/table/table.js +0 -406
  280. package/dist/table-legacy-ng/table-legacy-ng.js +0 -468
  281. package/dist/table-legacy-ng/table-legacy-ng__pager.js +0 -120
  282. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +0 -123
  283. package/dist/table-legacy-ng/table-legacy-ng__selection.js +0 -179
  284. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +0 -57
  285. package/dist/table-ng/smart-table-ng.js +0 -68
  286. package/dist/table-ng/table-ng.js +0 -67
  287. package/dist/tabs/collapsible-more.js +0 -198
  288. package/dist/tabs/collapsible-tab.js +0 -91
  289. package/dist/tabs/collapsible-tabs.js +0 -362
  290. package/dist/tabs/custom-item.js +0 -13
  291. package/dist/tabs/dumb-tabs.js +0 -164
  292. package/dist/tabs/smart-tabs.js +0 -106
  293. package/dist/tabs/tab-link.js +0 -42
  294. package/dist/tabs/tab.js +0 -33
  295. package/dist/tabs/tabs.js +0 -71
  296. package/dist/tabs-ng/tabs-ng.js +0 -194
  297. package/dist/tabs-ng/tabs-ng__template.js +0 -3
  298. package/dist/tag/tag.js +0 -197
  299. package/dist/tags-input/tags-input.js +0 -482
  300. package/dist/tags-input-ng/tags-input-ng.js +0 -93
  301. package/dist/tags-list/tags-list.js +0 -95
  302. package/dist/template-ng/template-ng.js +0 -71
  303. package/dist/text/text.js +0 -36
  304. package/dist/theme-ng/theme-ng.js +0 -45
  305. package/dist/title-ng/title-ng.js +0 -114
  306. package/dist/toggle/toggle.js +0 -78
  307. package/dist/toggle-ng/toggle-ng.js +0 -18
  308. package/dist/tooltip/tooltip.js +0 -209
  309. package/dist/tooltip-ng/tooltip-ng.js +0 -104
  310. package/dist/user-agreement/service.js +0 -412
  311. package/dist/user-agreement/toolbox.eula.js +0 -3
  312. package/dist/user-agreement/user-agreement.js +0 -169
  313. package/dist/user-card/card.js +0 -19
  314. package/dist/user-card/smart-user-card-tooltip.js +0 -114
  315. package/dist/user-card/tooltip.js +0 -95
  316. package/dist/user-card/user-card.js +0 -51
  317. package/dist/user-card-ng/user-card-ng.js +0 -62
@@ -1,637 +0,0 @@
1
- import { a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import angular from 'angular';
3
- import React from 'react';
4
- import { unmountComponentAtNode, render } from '../global/react-render-adapter.js';
5
- import getEventKey from '../global/get-event-key.js';
6
- import Select, { RerenderableSelect } from '../select/select.js';
7
- import MessageBundle from '../message-bundle-ng/message-bundle-ng.js';
8
- import SelectNgOptions from './select-ng__options.js';
9
- import SelectLazy from './select-ng__lazy.js';
10
- import 'core-js/modules/web.dom-collections.iterator.js';
11
- import 'react-dom';
12
- import 'core-js/modules/es.string.replace.js';
13
- import 'classnames';
14
- import 'prop-types';
15
- import '@jetbrains/icons/chevron-10px';
16
- import '@jetbrains/icons/close';
17
- import 'deep-equal';
18
- import '../dropdown/dropdown.js';
19
- import '../global/data-tests.js';
20
- import '../_helpers/anchor.js';
21
- import '../icon/icon.js';
22
- import 'util-deprecate';
23
- import '../icon/icon__constants.js';
24
- import '../_helpers/icon.js';
25
- import '../icon/icon__svg.js';
26
- import '../global/memoize.js';
27
- import '../button/button.js';
28
- import 'focus-visible';
29
- import '../global/theme.js';
30
- import '../link/clickableLink.js';
31
- import '../_helpers/button__classes.js';
32
- import '../avatar/avatar.js';
33
- import '../global/url.js';
34
- import '../global/dom.js';
35
- import '../avatar/fallback-avatar.js';
36
- import '../global/get-uid.js';
37
- import '../popup/popup.js';
38
- import '../global/schedule-raf.js';
39
- import '../shortcuts/shortcuts.js';
40
- import '../shortcuts/core.js';
41
- import 'combokeys';
42
- import '../global/sniffer.js';
43
- import 'sniffr';
44
- import '../tab-trap/tab-trap.js';
45
- import '../popup/position.js';
46
- import '../popup/popup.consts.js';
47
- import '../popup/popup.target.js';
48
- import '../list/list.js';
49
- import 'react-virtualized/dist/es/List';
50
- import 'react-virtualized/dist/es/AutoSizer';
51
- import 'react-virtualized/dist/es/WindowScroller';
52
- import 'react-virtualized/dist/es/CellMeasurer';
53
- import 'memoize-one';
54
- import '../global/create-stateful-context.js';
55
- import '../list/list__link.js';
56
- import '../link/link.js';
57
- import '../_helpers/link.js';
58
- import '../_helpers/list.js';
59
- import '../list/list__item.js';
60
- import '../checkbox/checkbox.js';
61
- import '@jetbrains/icons/checkmark';
62
- import '@jetbrains/icons/remove-10px';
63
- import '../_helpers/checkbox.js';
64
- import '../list/list__custom.js';
65
- import '../list/list__title.js';
66
- import '../list/list__separator.js';
67
- import '../list/list__hint.js';
68
- import '../list/consts.js';
69
- import '../input/input.js';
70
- import '../_helpers/input.js';
71
- import '../global/rerender-hoc.js';
72
- import '../global/composeRefs.js';
73
- import '../global/fuzzy-highlight.js';
74
- import '../select/select__popup.js';
75
- import '@jetbrains/icons/search';
76
- import '../loader-inline/loader-inline.js';
77
- import '../_helpers/inject-styles.js';
78
- import '../global/conic-gradient.js';
79
- import 'conic-gradient';
80
- import '../global/supports-css.js';
81
- import '../global/inject-styles.js';
82
- import '../global/radial-gradient-mask.js';
83
- import '../shortcuts/shortcuts-hoc.js';
84
- import '../tags-list/tags-list.js';
85
- import '../tag/tag.js';
86
- import '../caret/caret.js';
87
- import '../text/text.js';
88
- import '../_helpers/select__filter.js';
89
-
90
- const LOADER_DELAY = 150; // delay to show loader in ms
91
-
92
- const INFINITE_SCROLL_PACK_SIZE = 50;
93
- const DIALOG_NG_SELECTOR = '[data-anchor=dialog-container][data-in-sidebar=false]';
94
- /**
95
- * @name Select Ng
96
- */
97
-
98
- const angularModule = angular.module('Ring.select', [SelectNgOptions, MessageBundle]);
99
- angularModule.directive('rgSelect', function rgSelectDirective() {
100
- const types = {
101
- input: Select.Type.INPUT,
102
- button: Select.Type.BUTTON,
103
- material: Select.Type.MATERIAL,
104
- dropdown: Select.Type.CUSTOM,
105
- suggest: Select.Type.INPUT
106
- };
107
- const sizes = {
108
- FULL: Select.Size.FULL,
109
- S: Select.Size.S,
110
- M: Select.Size.M,
111
- L: Select.Size.L
112
- };
113
- return {
114
- /**
115
- * @property {Object} scope
116
- * @property {Object} scope.ngModel
117
- * @property {String} scope.selectType - select type. Can be "button" (default), "input" or "dropdown"
118
- * @property {String} scope.lazy - Load options lazily. "true" by default.
119
- * @property {Boolean} scope.withInfiniteScroll - If true, rgSelect calls getOptions with skip parameter when the list is scrolled to the bottom
120
- * @property {String} scope.options - query for options
121
- * @property {Boolean} scope.externalFilter - whether or not to use the options function as a filter.
122
- * "filter" property should not be passed in that case.
123
- * @property {Boolean} scope.multiple - toggles multiple selection
124
- * @property {Function} scope.onSelect - callback to call on item selection
125
- * Receives "selected" property (<rg-select on-select='doSomethingWith(selected)'>)
126
- * @property {Function} scope.onDeselect - callback to call on item deselection
127
- * Receives "deselected" property (<rg-select on-deselect='doSomethingWith(deselected)'>)
128
- * @property {Function} scope.onOpen - callback to call on select popup opening
129
- * @property {Function} scope.onClose - callback to call on select popup closing
130
- * @property {Function} scope.onChange - callback to call on selection change
131
- * Receives "selected" property (<rg-select on-change='doSomethingWith(selected)'>)
132
- * @property {String} scope.label - Label to place on empty select button
133
- * @property {String} scope.selectedLabel - Label to replace any selected item/items with
134
- * @property {String} scope.notFoundMessage - message to display if no options found
135
- * @property {String} scope.loadingMessage - message to display while loading
136
- * @property {Object} scope.config - hash to pass to react select component
137
- * @property {Boolean} scope.configAutoUpdate - whether or not to watch for configuration updates
138
- * @property {String} scope.size - select size. Can be "S", "M" (default), or "L".
139
- */
140
- scope: {
141
- ngModel: '=',
142
- selectType: '@',
143
- lazy: '=?',
144
- withInfiniteScroll: '=?',
145
- // NB: Deprecated! Use infinite-scroll-pack-size="50" instead
146
- infiniteScrollPackSize: '@',
147
- options: '@',
148
- optionsScope: '=',
149
- label: '@',
150
- selectedLabel: '@',
151
- externalFilter: '=?',
152
- filter: '=?',
153
- tags: '=?',
154
- multiple: '=?',
155
- clear: '=?',
156
- onSelect: '&',
157
- onDeselect: '&',
158
- onOpen: '&',
159
- onClose: '&',
160
- onChange: '&',
161
- notFoundMessage: '@',
162
- loadingMessage: '@',
163
- config: '=?',
164
- configAutoUpdate: '=',
165
- selectInstance: '=?',
166
- size: '@',
167
- dir: '@'
168
- },
169
- bindToController: true,
170
- controllerAs: 'selectCtrl',
171
- require: ['?ngModel', 'rgSelect'],
172
- link: function link(scope, iElement, iAttrs, ctrls) {
173
- const ngModelCtrl = ctrls[0];
174
- const rgSelectCtrl = ctrls[1];
175
- rgSelectCtrl.setNgModelCtrl(ngModelCtrl);
176
- },
177
- controller: ["$q", "$scope", "$element", "$attrs", "$timeout", "SelectOptions", "RingMessageBundle", function controller($q, $scope, $element, $attrs, $timeout, SelectOptions, RingMessageBundle) {
178
- /*eslint-disable consistent-this*/
179
- const ctrl = this;
180
- /*eslint-enable consistent-this*/
181
-
182
- const element = $element[0];
183
- const container = document.createElement('span');
184
- const infiniteScrollPackSize = Number(ctrl.infiniteScrollPackSize) || (ctrl.withInfiniteScroll ? INFINITE_SCROLL_PACK_SIZE : 0);
185
- /**
186
- * Properties
187
- */
188
-
189
- ctrl.selectInstance = null;
190
- ctrl.ngModelCtrl = null;
191
- ctrl.query = null;
192
- ctrl.dataReceived = false;
193
- ctrl.skipNextModelSync = false;
194
- const scope = ctrl.optionsScope ? ctrl.optionsScope : $scope.$parent;
195
-
196
- ctrl.setNgModelCtrl = ngModelCtrl => {
197
- ctrl.ngModelCtrl = ngModelCtrl;
198
- };
199
- /**
200
- * @param {Array} options
201
- */
202
-
203
-
204
- function memorizeOptions(options, skip) {
205
- if (ctrl.loadedOptions && skip > 0) {
206
- ctrl.loadedOptions = ctrl.loadedOptions.concat(options);
207
- ctrl.stopLoadingNewOptions = options.length === 0 && infiniteScrollPackSize;
208
- } else {
209
- ctrl.loadedOptions = options;
210
- }
211
-
212
- ctrl.lastSkip = skip;
213
- return ctrl.loadedOptions;
214
- }
215
-
216
- function resetMemorizedOptions() {
217
- ctrl.lastSkip = -1;
218
- ctrl.loadedOptions = [];
219
- ctrl.stopLoadingNewOptions = false;
220
- }
221
-
222
- function getType() {
223
- // $attrs.type as fallback, not recommended to use because of native "type" attribute
224
- return ctrl.selectType || $attrs.type;
225
- }
226
-
227
- function getCurrentSkipParameter(query, prevQuery) {
228
- if (!infiniteScrollPackSize || query !== prevQuery || !ctrl.loadedOptions) {
229
- return 0;
230
- }
231
-
232
- return ctrl.lastSkip < 0 ? 0 : ctrl.lastSkip + infiniteScrollPackSize;
233
- }
234
-
235
- function isInDialog() {
236
- const dialogContainer = document.querySelector(DIALOG_NG_SELECTOR);
237
- return dialogContainer && dialogContainer.contains(element);
238
- }
239
-
240
- ctrl.syncSelectToNgModel = selectedValue => {
241
- function valueOf(option) {
242
- if (option && option.originalModel) {
243
- return ctrl.optionsParser.getValue(option.originalModel);
244
- }
245
-
246
- return ctrl.optionsParser.getValue(option);
247
- }
248
-
249
- if (ctrl.ngModelCtrl) {
250
- ctrl.skipNextModelSync = true;
251
-
252
- if (getType() === 'suggest') {
253
- ctrl.ngModelCtrl.$setViewValue(selectedValue.label);
254
- } else if (Array.isArray(selectedValue)) {
255
- ctrl.ngModelCtrl.$setViewValue(selectedValue.map(valueOf));
256
- } else {
257
- ctrl.ngModelCtrl.$setViewValue(valueOf(selectedValue));
258
- }
259
- }
260
- };
261
-
262
- ctrl.convertNgModelToSelect = model => {
263
- function convertItem(modelValue) {
264
- let item = ctrl.optionsParser.getOptionByValue(modelValue, ctrl.loadedOptions || []); // could happen when lazily fetching the data
265
-
266
- if (item === undefined) {
267
- item = modelValue;
268
- }
269
-
270
- return angular.extend({
271
- key: ctrl.optionsParser.getKey(item),
272
- label: ctrl.optionsParser.getLabel(item),
273
- selectedLabel: ctrl.optionsParser.getSelectedLabel(item),
274
- description: ctrl.optionsParser.getDescription(item),
275
- originalModel: item
276
- }, typeof item === 'object' ? item : null);
277
- }
278
-
279
- if (model !== undefined && model !== null) {
280
- if (Array.isArray(model)) {
281
- return model.map(convertItem);
282
- } else {
283
- return convertItem(model);
284
- }
285
- }
286
-
287
- return undefined;
288
- };
289
-
290
- let lastQuery = null;
291
- let inProcessQueries = 0;
292
-
293
- ctrl.getOptions = (query, skip) => $q.when(ctrl.optionsParser.getOptions(query, skip));
294
-
295
- let loaderDelayTimeout = null;
296
-
297
- ctrl.showLoader = () => {
298
- if (getType() !== 'suggest') {
299
- reRenderSelect({
300
- loading: true
301
- });
302
- }
303
- };
304
-
305
- ctrl.loadOptionsToSelect = query => {
306
- if (ctrl.stopLoadingNewOptions && query === lastQuery) {
307
- return $q.resolve();
308
- }
309
-
310
- ctrl.stopLoadingNewOptions = false;
311
- const skip = getCurrentSkipParameter(query, lastQuery);
312
- lastQuery = query;
313
- $timeout.cancel(loaderDelayTimeout); // Delay loader only when there is some data
314
- // Otherwise, user can notice the "not found" message
315
-
316
- if (ctrl.dataReceived) {
317
- loaderDelayTimeout = $timeout(ctrl.showLoader, LOADER_DELAY);
318
- } else {
319
- ctrl.showLoader();
320
- }
321
-
322
- inProcessQueries++;
323
- return ctrl.getOptions(query, skip).then(results => {
324
- inProcessQueries--;
325
-
326
- if (query !== lastQuery) {
327
- return; // do not process the result if queries don't match
328
- }
329
-
330
- if (skip && ctrl.lastSkip !== -1 && skip !== ctrl.lastSkip + infiniteScrollPackSize && ctrl.infiniteScrollPackSize) {
331
- return; // do not process the result if skips not match
332
- }
333
-
334
- const items = memorizeOptions(results.data || results, skip).map(ctrl.convertNgModelToSelect);
335
- $timeout.cancel(loaderDelayTimeout);
336
- ctrl.dataReceived = true;
337
- reRenderSelect({
338
- data: items,
339
- loading: false
340
- });
341
- }).catch(error => {
342
- inProcessQueries--;
343
- $timeout.cancel(loaderDelayTimeout);
344
- reRenderSelect({
345
- loading: false
346
- });
347
- return $q.reject(error);
348
- });
349
- };
350
-
351
- function setSelectModel(newValue) {
352
- if (ctrl.skipNextModelSync) {
353
- ctrl.skipNextModelSync = false;
354
- return;
355
- }
356
-
357
- if (ctrl.ngModelCtrl) {
358
- reRenderSelect({
359
- selected: ctrl.convertNgModelToSelect(newValue)
360
- });
361
- }
362
- }
363
-
364
- function syncNgModelToSelect() {
365
- $scope.$watch(() => ctrl.ngModelCtrl && ctrl.ngModelCtrl.$modelValue, setSelectModel, true);
366
- }
367
-
368
- function syncDisabled() {
369
- $attrs.$observe('disabled', newValue => {
370
- reRenderSelect({
371
- disabled: newValue
372
- });
373
- });
374
- }
375
-
376
- function syncMultiple() {
377
- $scope.$watch(() => ctrl.multiple, () => {
378
- if (angular.isDefined(ctrl.multiple)) {
379
- reRenderSelect({
380
- multiple: ctrl.multiple
381
- });
382
- }
383
- });
384
- }
385
-
386
- function syncConfig() {
387
- $scope.$watchCollection(() => ctrl.config, (config, old) => {
388
- if (config !== old) {
389
- reRenderSelect(config);
390
- }
391
- });
392
- }
393
-
394
- function isSelectPopupOpen() {
395
- return ctrl.selectInstance._popup.isVisible();
396
- }
397
-
398
- function attachDropdownIfNeeded() {
399
- if (getType() === 'dropdown') {
400
- const handler = () => {
401
- ctrl.selectInstance._clickHandler();
402
- };
403
-
404
- element.addEventListener('click', handler);
405
- element.addEventListener('keydown', event => {
406
- const key = getEventKey(event);
407
- const modifier = event.ctrlKey || event.altKey || event.metaKey || event.shiftKey;
408
-
409
- if (key === 'Enter' && !modifier || key === ' ') {
410
- if (!isSelectPopupOpen()) {
411
- handler(); // XXX: preventDefault is needed because some controls (button, input, etc)
412
- // have an activation behaviour which fires a `click` event on `keypress`
413
- // @see https://www.w3.org/TR/2017/PR-html51-20170803/editing.html#activation
414
-
415
- event.preventDefault(); // XXX: stopPropagation is needed because when a React component is rendered with
416
- // shortcuts, document-level handlers are added. For example, `enter` that leads
417
- // to this handler being called right after current function's call, which
418
- // leads to the popup being closed immediately after opening.
419
- // @see https://www.w3.org/TR/uievents/#Event_dispatch_and_DOM_event_flow
420
-
421
- event.stopPropagation();
422
- }
423
- }
424
- });
425
- }
426
- }
427
-
428
- function listenToRouteChanges() {
429
- $scope.$on('$locationChangeSuccess', () => {
430
- if (isSelectPopupOpen()) {
431
- ctrl.selectInstance._hidePopup();
432
- }
433
- });
434
- }
435
-
436
- function getSelectType() {
437
- return types[getType()] || types.material;
438
- }
439
-
440
- function getSelectSize() {
441
- return sizes[ctrl.size] || sizes.FULL;
442
- }
443
-
444
- function selectRef(instance) {
445
- if (instance != null) {
446
- ctrl.selectInstance = instance;
447
- }
448
- }
449
-
450
- function reRenderSelect(props) {
451
- var _ctrl$selectInstance;
452
-
453
- if ((_ctrl$selectInstance = ctrl.selectInstance) !== null && _ctrl$selectInstance !== void 0 && _ctrl$selectInstance.node) {
454
- ctrl.selectInstance.rerender({ ...props,
455
- ref: selectRef
456
- });
457
- }
458
- }
459
- /**
460
- * @param {newValue} newValue New value of options
461
- * @param {value} value Previous value of options
462
- */
463
-
464
-
465
- function optionsWatcher(newValue, value) {
466
- memorizeOptions(newValue, 0);
467
-
468
- if (newValue === value) {
469
- return;
470
- }
471
-
472
- if (ctrl.ngModelCtrl) {
473
- setSelectModel(ctrl.ngModelCtrl.$modelValue);
474
- }
475
- }
476
-
477
- function createDefaultConfig() {
478
- const defaultConfig = {
479
- label: ctrl.label || RingMessageBundle.select_label(),
480
- selectedLabel: ctrl.selectedLabel,
481
- allowAny: getType() === 'suggest',
482
- hideArrow: getType() === 'suggest',
483
- filter: ctrl.filter,
484
- tags: ctrl.tags,
485
- dir: ctrl.dir,
486
- multiple: ctrl.multiple,
487
- popupClassName: $attrs.popupClass,
488
- clear: ctrl.clear,
489
- ringPopupTarget: isInDialog() ? 'dialog-ng-popup-container' : null,
490
- renderOptimization: getType() !== 'dropdown',
491
- type: getSelectType(),
492
- loadingMessage: ctrl.loadingMessage || RingMessageBundle.select_loading(),
493
- notFoundMessage: ctrl.notFoundMessage || RingMessageBundle.select_options_not_found(),
494
- targetElement: getType() === 'dropdown' ? element : null,
495
- size: getSelectSize(),
496
- onBeforeOpen: () => {
497
- resetMemorizedOptions();
498
- ctrl.loadOptionsToSelect(ctrl.query);
499
- $scope.$evalAsync(() => {});
500
- },
501
- onOpen: () => {
502
- $scope.$evalAsync(() => {
503
- ctrl.onOpen();
504
- });
505
- },
506
- onClose: () => {
507
- ctrl.query = null;
508
- $scope.$evalAsync(() => {
509
- ctrl.onClose();
510
- });
511
- },
512
- onSelect: (selected, event) => {
513
- $scope.$evalAsync(() => {
514
- ctrl.onSelect({
515
- selected,
516
- event
517
- });
518
- });
519
- },
520
- onDeselect: (deselected, event) => {
521
- $scope.$evalAsync(() => {
522
- ctrl.onDeselect({
523
- deselected,
524
- event
525
- });
526
- });
527
- },
528
- onChange: (selected, event) => {
529
- ctrl.syncSelectToNgModel(selected);
530
- $scope.$evalAsync(() => {
531
- ctrl.onChange({
532
- selected,
533
- event
534
- });
535
- });
536
- },
537
- onFilter: query => {
538
- $scope.$evalAsync(() => {
539
- ctrl.query = query;
540
-
541
- if (ctrl.externalFilter) {
542
- ctrl.loadOptionsToSelect(query);
543
- }
544
-
545
- if (ctrl.onFilter) {
546
- ctrl.onFilter(query);
547
- }
548
- });
549
- },
550
- reloadOptions: query => {
551
- $scope.$evalAsync(() => {
552
- ctrl.loadOptionsToSelect(query || ctrl.query);
553
- });
554
- },
555
- getLoadedOptions: () => ctrl.loadedOptions
556
- };
557
-
558
- if (infiniteScrollPackSize) {
559
- defaultConfig.onLoadMore = () => {
560
- if (inProcessQueries === 0) {
561
- $scope.$evalAsync(() => {
562
- ctrl.loadOptionsToSelect(ctrl.query);
563
- });
564
- }
565
- };
566
- }
567
-
568
- return defaultConfig;
569
- }
570
-
571
- function removeDefaultConfigPropFromUserConfig() {
572
- if (!ctrl.defaultConfig || !ctrl.config) {
573
- return;
574
- }
575
-
576
- Object.keys(ctrl.defaultConfig).filter(propName => ctrl.config[propName] === ctrl.defaultConfig[propName]).forEach(propName => {
577
- delete ctrl.config[propName];
578
- });
579
- }
580
-
581
- ctrl.$onDestroy = () => {
582
- unmountComponentAtNode(container);
583
- removeDefaultConfigPropFromUserConfig();
584
- };
585
-
586
- ctrl.$onInit = () => {
587
- ctrl.optionsParser = new SelectOptions(scope, ctrl.options);
588
- ctrl.lazy = ctrl.hasOwnProperty('lazy') ? ctrl.lazy : true;
589
- /**
590
- * Provide specific filter function if externalFilter is enabled
591
- */
592
-
593
- if (ctrl.externalFilter) {
594
- ctrl.filter = ctrl.filter || {};
595
-
596
- ctrl.filter.fn = () => true;
597
- }
598
-
599
- ctrl.defaultConfig = createDefaultConfig();
600
- ctrl.config = angular.extend({}, ctrl.defaultConfig, ctrl.config || {});
601
-
602
- if (getType() === 'suggest' || getType() === 'input') {
603
- render( /*#__PURE__*/React.createElement(RerenderableSelect, _extends({
604
- ref: selectRef
605
- }, ctrl.config)), container);
606
- } else {
607
- ctrl.selectInstance = new SelectLazy(container, ctrl.config, ctrl, getType(), selectRef);
608
- } // Preserve existing contents of the directive
609
-
610
-
611
- element.appendChild(container);
612
-
613
- if (!ctrl.lazy) {
614
- if (!ctrl.optionsParser.datasourceIsFunction) {
615
- $scope.$watch(() => ctrl.optionsParser.getOptions(ctrl.query, 0), optionsWatcher, true);
616
- } else {
617
- ctrl.loadOptionsToSelect(ctrl.query);
618
- }
619
- }
620
-
621
- syncNgModelToSelect();
622
- syncDisabled();
623
- syncMultiple();
624
-
625
- if (ctrl.configAutoUpdate) {
626
- syncConfig();
627
- }
628
-
629
- attachDropdownIfNeeded();
630
- listenToRouteChanges();
631
- };
632
- }]
633
- };
634
- });
635
- var selectNg = angularModule.name;
636
-
637
- export { selectNg as default };