@jetbrains/ring-ui 4.2.2 → 4.2.5

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 (316) hide show
  1. package/components/select-ng/select-ng__lazy.js +8 -2
  2. package/package.json +2 -2
  3. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -34
  4. package/dist/_helpers/anchor.js +0 -33
  5. package/dist/_helpers/badge.js +0 -3
  6. package/dist/_helpers/button-group.js +0 -3
  7. package/dist/_helpers/button-set.js +0 -3
  8. package/dist/_helpers/button-toolbar.js +0 -3
  9. package/dist/_helpers/button__classes.js +0 -39
  10. package/dist/_helpers/card.js +0 -75
  11. package/dist/_helpers/checkbox.js +0 -3
  12. package/dist/_helpers/date-picker.js +0 -3
  13. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -58
  14. package/dist/_helpers/error-message.js +0 -3
  15. package/dist/_helpers/footer.js +0 -121
  16. package/dist/_helpers/grid.js +0 -3
  17. package/dist/_helpers/group.js +0 -3
  18. package/dist/_helpers/header.js +0 -3
  19. package/dist/_helpers/icon.js +0 -3
  20. package/dist/_helpers/inject-styles.js +0 -22
  21. package/dist/_helpers/input.js +0 -3
  22. package/dist/_helpers/island.js +0 -3
  23. package/dist/_helpers/link.js +0 -3
  24. package/dist/_helpers/list.js +0 -3
  25. package/dist/_helpers/loader-screen.js +0 -3
  26. package/dist/_helpers/panel.js +0 -3
  27. package/dist/_helpers/query-assist__suggestions.js +0 -95
  28. package/dist/_helpers/radio.js +0 -3
  29. package/dist/_helpers/select__filter.js +0 -77
  30. package/dist/_helpers/services-link.js +0 -40
  31. package/dist/_helpers/sidebar.js +0 -126
  32. package/dist/_helpers/table.js +0 -3
  33. package/dist/_helpers/tabs.js +0 -3
  34. package/dist/_helpers/title.js +0 -100
  35. package/dist/alert/alert.js +0 -262
  36. package/dist/alert/container.js +0 -48
  37. package/dist/alert-service/alert-service.js +0 -173
  38. package/dist/analytics/analytics.js +0 -118
  39. package/dist/analytics/analytics__custom-plugin.js +0 -128
  40. package/dist/analytics/analytics__fus-plugin.js +0 -102
  41. package/dist/analytics/analytics__ga-plugin.js +0 -75
  42. package/dist/analytics/analytics__plugin-utils.js +0 -80
  43. package/dist/analytics-ng/analytics-ng.js +0 -95
  44. package/dist/auth/auth.js +0 -96
  45. package/dist/auth/auth__core.js +0 -1059
  46. package/dist/auth/background-flow.js +0 -123
  47. package/dist/auth/down-notification.js +0 -117
  48. package/dist/auth/iframe-flow.js +0 -153
  49. package/dist/auth/landing-entry.js +0 -5
  50. package/dist/auth/landing.js +0 -90
  51. package/dist/auth/request-builder.js +0 -76
  52. package/dist/auth/response-parser.js +0 -118
  53. package/dist/auth/storage.js +0 -283
  54. package/dist/auth/token-validator.js +0 -178
  55. package/dist/auth/window-flow.js +0 -134
  56. package/dist/auth-dialog/auth-dialog.js +0 -180
  57. package/dist/auth-dialog-service/auth-dialog-service.js +0 -71
  58. package/dist/auth-ng/auth-ng.js +0 -206
  59. package/dist/auth-ng/auth-ng.mock.js +0 -33
  60. package/dist/autofocus-ng/autofocus-ng.js +0 -51
  61. package/dist/avatar/avatar-example-datauri.js +0 -4
  62. package/dist/avatar/avatar.js +0 -163
  63. package/dist/avatar/fallback-avatar.js +0 -142
  64. package/dist/avatar-editor-ng/avatar-editor-ng.js +0 -167
  65. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +0 -3
  66. package/dist/avatar-ng/avatar-ng.js +0 -21
  67. package/dist/badge/badge.js +0 -51
  68. package/dist/badge-ng/badge-ng.js +0 -18
  69. package/dist/breadcrumb-ng/breadcrumb-ng.js +0 -37
  70. package/dist/button/button.js +0 -125
  71. package/dist/button/button__classes.js +0 -5
  72. package/dist/button-group/button-group.js +0 -30
  73. package/dist/button-group/caption.js +0 -24
  74. package/dist/button-group-ng/button-group-ng.js +0 -39
  75. package/dist/button-ng/button-ng.js +0 -217
  76. package/dist/button-set/button-set.js +0 -26
  77. package/dist/button-set-ng/button-set-ng.js +0 -19
  78. package/dist/button-toolbar/button-toolbar.js +0 -29
  79. package/dist/button-toolbar-ng/button-toolbar-ng.js +0 -24
  80. package/dist/caret/caret.js +0 -266
  81. package/dist/checkbox/checkbox.js +0 -110
  82. package/dist/checkbox-ng/checkbox-ng.js +0 -38
  83. package/dist/code/code.js +0 -137
  84. package/dist/compiler-ng/compiler-ng.js +0 -53
  85. package/dist/confirm/confirm.js +0 -127
  86. package/dist/confirm-ng/confirm-ng.js +0 -69
  87. package/dist/confirm-service/confirm-service.js +0 -117
  88. package/dist/content-layout/content-layout.js +0 -66
  89. package/dist/content-layout/sidebar.js +0 -7
  90. package/dist/contenteditable/contenteditable.js +0 -78
  91. package/dist/data-list/data-list.js +0 -208
  92. package/dist/data-list/data-list.mock.js +0 -191
  93. package/dist/data-list/item.js +0 -229
  94. package/dist/data-list/selection.js +0 -102
  95. package/dist/data-list/title.js +0 -20
  96. package/dist/data-list-ng/data-list-ng.js +0 -62
  97. package/dist/date-picker/consts.js +0 -69
  98. package/dist/date-picker/date-input.js +0 -175
  99. package/dist/date-picker/date-picker.js +0 -367
  100. package/dist/date-picker/date-popup.js +0 -483
  101. package/dist/date-picker/day.js +0 -120
  102. package/dist/date-picker/formats.js +0 -3
  103. package/dist/date-picker/month-names.js +0 -100
  104. package/dist/date-picker/month-slider.js +0 -84
  105. package/dist/date-picker/month.js +0 -55
  106. package/dist/date-picker/months.js +0 -122
  107. package/dist/date-picker/weekdays.js +0 -32
  108. package/dist/date-picker/years.js +0 -110
  109. package/dist/dialog/dialog.js +0 -202
  110. package/dist/dialog/dialog__body-scroll-preventer.js +0 -3
  111. package/dist/dialog-ng/dialog-ng.js +0 -604
  112. package/dist/dialog-ng/dialog-ng__template.js +0 -3
  113. package/dist/docked-panel-ng/docked-panel-ng.js +0 -171
  114. package/dist/dropdown/anchor.js +0 -19
  115. package/dist/dropdown/dropdown.js +0 -236
  116. package/dist/dropdown-menu/dropdown-menu.js +0 -177
  117. package/dist/error-bubble/error-bubble.js +0 -59
  118. package/dist/error-message/error-message.js +0 -57
  119. package/dist/error-message-ng/error-message-ng.js +0 -35
  120. package/dist/footer/footer.js +0 -12
  121. package/dist/footer-ng/footer-ng.js +0 -64
  122. package/dist/form-ng/form-ng.js +0 -167
  123. package/dist/global/angular-component-factory.js +0 -84
  124. package/dist/global/compose.js +0 -9
  125. package/dist/global/composeRefs.js +0 -15
  126. package/dist/global/conic-gradient.js +0 -35
  127. package/dist/global/create-stateful-context.js +0 -55
  128. package/dist/global/data-tests.js +0 -24
  129. package/dist/global/dom.js +0 -125
  130. package/dist/global/focus-sensor-hoc.js +0 -146
  131. package/dist/global/fuzzy-highlight.js +0 -67
  132. package/dist/global/get-event-key.js +0 -111
  133. package/dist/global/get-uid.js +0 -15
  134. package/dist/global/inject-styles.js +0 -15
  135. package/dist/global/linear-function.js +0 -17
  136. package/dist/global/listeners.js +0 -44
  137. package/dist/global/memoize.js +0 -20
  138. package/dist/global/normalize-indent.js +0 -30
  139. package/dist/global/promise-with-timeout.js +0 -17
  140. package/dist/global/radial-gradient-mask.js +0 -38
  141. package/dist/global/react-dom-renderer.js +0 -46
  142. package/dist/global/react-render-adapter.js +0 -41
  143. package/dist/global/rerender-hoc.js +0 -55
  144. package/dist/global/ring-angular-component.js +0 -24
  145. package/dist/global/schedule-raf.js +0 -31
  146. package/dist/global/sniffer.js +0 -6
  147. package/dist/global/supports-css.js +0 -22
  148. package/dist/global/theme.js +0 -54
  149. package/dist/global/trivial-template-tag.js +0 -17
  150. package/dist/global/url.js +0 -165
  151. package/dist/global/variables_dark.js +0 -57
  152. package/dist/grid/col.js +0 -60
  153. package/dist/grid/grid.js +0 -33
  154. package/dist/grid/row.js +0 -64
  155. package/dist/group/group.js +0 -31
  156. package/dist/group-ng/group-ng.js +0 -11
  157. package/dist/header/header.js +0 -150
  158. package/dist/header/logo.js +0 -40
  159. package/dist/header/profile.js +0 -219
  160. package/dist/header/services-link.js +0 -12
  161. package/dist/header/services.js +0 -138
  162. package/dist/header/smart-profile.js +0 -233
  163. package/dist/header/smart-services.js +0 -163
  164. package/dist/header/tray-icon.js +0 -47
  165. package/dist/header/tray.js +0 -31
  166. package/dist/heading/heading.js +0 -73
  167. package/dist/http/http.js +0 -218
  168. package/dist/http/http.mock.js +0 -67
  169. package/dist/hub-source/hub-source.js +0 -130
  170. package/dist/hub-source/hub-source__user.js +0 -30
  171. package/dist/hub-source/hub-source__users-groups.js +0 -63
  172. package/dist/icon/icon.js +0 -105
  173. package/dist/icon/icon__constants.js +0 -33
  174. package/dist/icon/icon__svg.js +0 -83
  175. package/dist/icon/index.js +0 -12
  176. package/dist/icon-ng/icon-ng.js +0 -91
  177. package/dist/input/input.js +0 -230
  178. package/dist/input-ng/input-ng.js +0 -111
  179. package/dist/island/adaptive-island-hoc.js +0 -48
  180. package/dist/island/content.js +0 -160
  181. package/dist/island/header.js +0 -84
  182. package/dist/island/island.js +0 -51
  183. package/dist/island-legacy/content-legacy.js +0 -26
  184. package/dist/island-legacy/header-legacy.js +0 -28
  185. package/dist/island-legacy/island-legacy.js +0 -28
  186. package/dist/island-ng/island-content-ng.js +0 -42
  187. package/dist/island-ng/island-header-ng.js +0 -26
  188. package/dist/island-ng/island-ng-class-fixer.js +0 -11
  189. package/dist/island-ng/island-ng.js +0 -25
  190. package/dist/link/clickableLink.js +0 -64
  191. package/dist/link/link.js +0 -115
  192. package/dist/link-ng/link-ng.js +0 -22
  193. package/dist/list/consts.js +0 -26
  194. package/dist/list/list.js +0 -818
  195. package/dist/list/list__custom.js +0 -86
  196. package/dist/list/list__hint.js +0 -26
  197. package/dist/list/list__item.js +0 -206
  198. package/dist/list/list__link.js +0 -65
  199. package/dist/list/list__separator.js +0 -30
  200. package/dist/list/list__title.js +0 -39
  201. package/dist/list/list__users-groups-source.js +0 -130
  202. package/dist/loader/loader.js +0 -71
  203. package/dist/loader/loader__core.js +0 -273
  204. package/dist/loader-inline/inject-styles.js +0 -13
  205. package/dist/loader-inline/loader-inline.js +0 -58
  206. package/dist/loader-inline-ng/loader-inline-ng.js +0 -44
  207. package/dist/loader-ng/loader-ng.js +0 -44
  208. package/dist/loader-screen/loader-screen.js +0 -44
  209. package/dist/loader-screen-ng/loader-screen-ng.js +0 -95
  210. package/dist/login-dialog/login-dialog.js +0 -188
  211. package/dist/login-dialog/service.js +0 -72
  212. package/dist/markdown/code.js +0 -31
  213. package/dist/markdown/heading.js +0 -23
  214. package/dist/markdown/link.js +0 -31
  215. package/dist/markdown/markdown.js +0 -74
  216. package/dist/message/message.js +0 -235
  217. package/dist/message-bundle-ng/message-bundle-ng.js +0 -111
  218. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  219. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  220. package/dist/old-browsers-message/white-list.js +0 -34
  221. package/dist/pager/pager.js +0 -365
  222. package/dist/pager-ng/pager-ng.js +0 -100
  223. package/dist/panel/panel.js +0 -31
  224. package/dist/panel-ng/panel-ng.js +0 -17
  225. package/dist/permissions/permissions.js +0 -200
  226. package/dist/permissions/permissions__cache.js +0 -272
  227. package/dist/permissions-ng/permissions-ng.js +0 -277
  228. package/dist/place-under-ng/place-under-ng.js +0 -158
  229. package/dist/popup/popup.consts.js +0 -41
  230. package/dist/popup/popup.js +0 -396
  231. package/dist/popup/popup.target.js +0 -26
  232. package/dist/popup/position.js +0 -280
  233. package/dist/popup-menu/popup-menu.js +0 -117
  234. package/dist/progress-bar/progress-bar.js +0 -114
  235. package/dist/progress-bar-ng/progress-bar-ng.js +0 -17
  236. package/dist/promised-click-ng/promised-click-ng.js +0 -128
  237. package/dist/proxy-attrs/proxy-attrs.js +0 -21
  238. package/dist/query-assist/query-assist.js +0 -1096
  239. package/dist/query-assist/query-assist__suggestions.js +0 -49
  240. package/dist/query-assist-ng/query-assist-ng.js +0 -86
  241. package/dist/radio/radio.js +0 -42
  242. package/dist/radio/radio__item.js +0 -78
  243. package/dist/radio-ng/radio-ng.js +0 -47
  244. package/dist/save-field-ng/save-field-ng.js +0 -337
  245. package/dist/save-field-ng/save-field-ng__template.js +0 -3
  246. package/dist/select/select.js +0 -1357
  247. package/dist/select/select__filter.js +0 -56
  248. package/dist/select/select__popup.js +0 -553
  249. package/dist/select-ng/select-ng.js +0 -637
  250. package/dist/select-ng/select-ng__lazy.js +0 -159
  251. package/dist/select-ng/select-ng__options.js +0 -145
  252. package/dist/shortcuts/core.js +0 -245
  253. package/dist/shortcuts/shortcut-title.js +0 -51
  254. package/dist/shortcuts/shortcuts-hoc.js +0 -42
  255. package/dist/shortcuts/shortcuts.js +0 -72
  256. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +0 -123
  257. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +0 -3
  258. package/dist/shortcuts-ng/shortcuts-ng.js +0 -262
  259. package/dist/sidebar-ng/sidebar-ng.js +0 -113
  260. package/dist/sidebar-ng/sidebar-ng__button-template.js +0 -3
  261. package/dist/sidebar-ng/sidebar-ng__template.js +0 -3
  262. package/dist/storage/storage.js +0 -59
  263. package/dist/storage/storage__fallback.js +0 -215
  264. package/dist/storage/storage__local.js +0 -154
  265. package/dist/style.css +0 -1
  266. package/dist/tab-trap/tab-trap.js +0 -177
  267. package/dist/table/cell.js +0 -26
  268. package/dist/table/disable-hover-hoc.js +0 -54
  269. package/dist/table/header-cell.js +0 -92
  270. package/dist/table/header.js +0 -193
  271. package/dist/table/multitable.js +0 -141
  272. package/dist/table/row-with-focus-sensor.js +0 -83
  273. package/dist/table/row.js +0 -273
  274. package/dist/table/selection-adapter.js +0 -16
  275. package/dist/table/selection-shortcuts-hoc.js +0 -215
  276. package/dist/table/selection.js +0 -223
  277. package/dist/table/smart-table.js +0 -125
  278. package/dist/table/table.js +0 -406
  279. package/dist/table-legacy-ng/table-legacy-ng.js +0 -468
  280. package/dist/table-legacy-ng/table-legacy-ng__pager.js +0 -120
  281. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +0 -123
  282. package/dist/table-legacy-ng/table-legacy-ng__selection.js +0 -179
  283. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +0 -57
  284. package/dist/table-ng/smart-table-ng.js +0 -68
  285. package/dist/table-ng/table-ng.js +0 -67
  286. package/dist/tabs/collapsible-more.js +0 -198
  287. package/dist/tabs/collapsible-tab.js +0 -91
  288. package/dist/tabs/collapsible-tabs.js +0 -362
  289. package/dist/tabs/custom-item.js +0 -13
  290. package/dist/tabs/dumb-tabs.js +0 -164
  291. package/dist/tabs/smart-tabs.js +0 -106
  292. package/dist/tabs/tab-link.js +0 -42
  293. package/dist/tabs/tab.js +0 -33
  294. package/dist/tabs/tabs.js +0 -71
  295. package/dist/tabs-ng/tabs-ng.js +0 -194
  296. package/dist/tabs-ng/tabs-ng__template.js +0 -3
  297. package/dist/tag/tag.js +0 -197
  298. package/dist/tags-input/tags-input.js +0 -482
  299. package/dist/tags-input-ng/tags-input-ng.js +0 -93
  300. package/dist/tags-list/tags-list.js +0 -95
  301. package/dist/template-ng/template-ng.js +0 -71
  302. package/dist/text/text.js +0 -36
  303. package/dist/theme-ng/theme-ng.js +0 -45
  304. package/dist/title-ng/title-ng.js +0 -114
  305. package/dist/toggle/toggle.js +0 -78
  306. package/dist/toggle-ng/toggle-ng.js +0 -18
  307. package/dist/tooltip/tooltip.js +0 -209
  308. package/dist/tooltip-ng/tooltip-ng.js +0 -104
  309. package/dist/user-agreement/service.js +0 -412
  310. package/dist/user-agreement/toolbox.eula.js +0 -3
  311. package/dist/user-agreement/user-agreement.js +0 -169
  312. package/dist/user-card/card.js +0 -19
  313. package/dist/user-card/smart-user-card-tooltip.js +0 -114
  314. package/dist/user-card/tooltip.js +0 -95
  315. package/dist/user-card/user-card.js +0 -51
  316. 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 };