@jetbrains/ring-ui 4.1.1 → 4.1.2

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