@skyux/core 5.9.4 → 6.0.0-beta.10

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 (267) hide show
  1. package/documentation.json +727 -503
  2. package/esm2020/index.mjs +64 -0
  3. package/esm2020/lib/modules/adapter-service/adapter.module.mjs +16 -0
  4. package/esm2020/lib/modules/adapter-service/adapter.service.mjs +225 -0
  5. package/esm2020/lib/modules/adapter-service/focusable-children-options.mjs +2 -0
  6. package/esm2020/lib/modules/affix/affix-auto-fit-context.mjs +12 -0
  7. package/esm2020/lib/modules/affix/affix-config.mjs +2 -0
  8. package/esm2020/lib/modules/affix/affix-horizontal-alignment.mjs +2 -0
  9. package/esm2020/lib/modules/affix/affix-offset-change.mjs +2 -0
  10. package/esm2020/lib/modules/affix/affix-offset.mjs +2 -0
  11. package/esm2020/lib/modules/affix/affix-placement-change.mjs +2 -0
  12. package/esm2020/lib/modules/affix/affix-placement.mjs +2 -0
  13. package/esm2020/lib/modules/affix/affix-utils.mjs +18 -0
  14. package/esm2020/lib/modules/affix/affix-vertical-alignment.mjs +2 -0
  15. package/esm2020/lib/modules/affix/affix.directive.mjs +100 -0
  16. package/esm2020/lib/modules/affix/affix.module.mjs +18 -0
  17. package/esm2020/lib/modules/affix/affix.service.mjs +24 -0
  18. package/esm2020/lib/modules/affix/affixer.mjs +346 -0
  19. package/esm2020/lib/modules/affix/dom-utils.mjs +77 -0
  20. package/esm2020/lib/modules/dock/dock-dom-adapter.service.mjs +80 -0
  21. package/esm2020/lib/modules/dock/dock-insert-component-config.mjs +2 -0
  22. package/esm2020/lib/modules/dock/dock-item-config.mjs +2 -0
  23. package/esm2020/lib/modules/dock/dock-item-reference.mjs +2 -0
  24. package/esm2020/lib/modules/dock/dock-item.mjs +29 -0
  25. package/esm2020/lib/modules/dock/dock-location.mjs +19 -0
  26. package/esm2020/lib/modules/dock/dock-options.mjs +2 -0
  27. package/esm2020/lib/modules/dock/dock.component.mjs +88 -0
  28. package/esm2020/lib/modules/dock/dock.module.mjs +19 -0
  29. package/esm2020/lib/modules/dock/dock.service.mjs +95 -0
  30. package/esm2020/lib/modules/dock/sort-by-stack-order.mjs +13 -0
  31. package/esm2020/lib/modules/dynamic-component/dynamic-component-location.mjs +27 -0
  32. package/esm2020/lib/modules/dynamic-component/dynamic-component-options.mjs +2 -0
  33. package/esm2020/lib/modules/dynamic-component/dynamic-component.module.mjs +17 -0
  34. package/esm2020/lib/modules/dynamic-component/dynamic-component.service.mjs +83 -0
  35. package/esm2020/lib/modules/format/app-format.mjs +18 -0
  36. package/esm2020/lib/modules/id/id.directive.mjs +34 -0
  37. package/esm2020/lib/modules/id/id.module.mjs +16 -0
  38. package/esm2020/lib/modules/log/log.module.mjs +16 -0
  39. package/esm2020/lib/modules/log/log.service.mjs +132 -0
  40. package/esm2020/lib/modules/log/types/log-deprecation-args.mjs +2 -0
  41. package/esm2020/lib/modules/log/types/log-level-token.mjs +6 -0
  42. package/esm2020/lib/modules/log/types/log-level.mjs +2 -0
  43. package/esm2020/lib/modules/media-query/media-breakpoints.mjs +20 -0
  44. package/esm2020/lib/modules/media-query/media-query-listener.mjs +2 -0
  45. package/esm2020/lib/modules/media-query/media-query.module.mjs +16 -0
  46. package/esm2020/lib/modules/media-query/media-query.service.mjs +121 -0
  47. package/esm2020/lib/modules/mutation/mutation-observer-service.mjs +16 -0
  48. package/esm2020/lib/modules/numeric/numeric-symbol.mjs +2 -0
  49. package/esm2020/lib/modules/numeric/numeric.module.mjs +20 -0
  50. package/esm2020/lib/modules/numeric/numeric.options.mjs +46 -0
  51. package/esm2020/lib/modules/numeric/numeric.pipe.mjs +80 -0
  52. package/esm2020/lib/modules/numeric/numeric.service.mjs +186 -0
  53. package/esm2020/lib/modules/overlay/overlay-adapter.service.mjs +41 -0
  54. package/esm2020/lib/modules/overlay/overlay-config.mjs +2 -0
  55. package/esm2020/lib/modules/overlay/overlay-context.mjs +10 -0
  56. package/esm2020/lib/modules/overlay/overlay-instance.mjs +55 -0
  57. package/esm2020/lib/modules/overlay/overlay.component.mjs +149 -0
  58. package/esm2020/lib/modules/overlay/overlay.module.mjs +17 -0
  59. package/esm2020/lib/modules/overlay/overlay.service.mjs +120 -0
  60. package/esm2020/lib/modules/percent-pipe/percent-pipe.module.mjs +20 -0
  61. package/esm2020/lib/modules/percent-pipe/percent.pipe.mjs +48 -0
  62. package/esm2020/lib/modules/resize-observer/resize-observer-media-query.service.mjs +117 -0
  63. package/esm2020/lib/modules/resize-observer/resize-observer.service.mjs +73 -0
  64. package/esm2020/lib/modules/scrollable-host/scrollable-host.service.mjs +184 -0
  65. package/esm2020/lib/modules/shared/number-format/number-format-utility.mjs +71 -0
  66. package/esm2020/lib/modules/shared/sky-core-resources.module.mjs +50 -0
  67. package/esm2020/lib/modules/title/set-title-args.mjs +2 -0
  68. package/esm2020/lib/modules/title/title.service.mjs +31 -0
  69. package/esm2020/lib/modules/ui-config/ui-config.service.mjs +21 -0
  70. package/esm2020/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +2 -0
  71. package/esm2020/lib/modules/viewkeeper/viewkeeper-fixed-styles.mjs +2 -0
  72. package/esm2020/lib/modules/viewkeeper/viewkeeper-host-options.mjs +10 -0
  73. package/esm2020/lib/modules/viewkeeper/viewkeeper-offset.mjs +2 -0
  74. package/esm2020/lib/modules/viewkeeper/viewkeeper-options.mjs +2 -0
  75. package/esm2020/lib/modules/viewkeeper/viewkeeper.directive.mjs +116 -0
  76. package/esm2020/lib/modules/viewkeeper/viewkeeper.mjs +251 -0
  77. package/esm2020/lib/modules/viewkeeper/viewkeeper.module.mjs +16 -0
  78. package/esm2020/lib/modules/viewkeeper/viewkeeper.service.mjs +39 -0
  79. package/esm2020/lib/modules/window/window-ref.mjs +30 -0
  80. package/esm2020/skyux-core.mjs +5 -0
  81. package/esm2020/testing/mock-media-query.service.mjs +41 -0
  82. package/esm2020/testing/mock-ui-config.service.mjs +59 -0
  83. package/esm2020/testing/public-api.mjs +3 -0
  84. package/esm2020/testing/skyux-core-testing.mjs +5 -0
  85. package/fesm2015/{skyux-core-testing.js → skyux-core-testing.mjs} +7 -7
  86. package/fesm2015/skyux-core-testing.mjs.map +1 -0
  87. package/fesm2015/skyux-core.mjs +3343 -0
  88. package/fesm2015/skyux-core.mjs.map +1 -0
  89. package/fesm2020/skyux-core-testing.mjs +103 -0
  90. package/fesm2020/skyux-core-testing.mjs.map +1 -0
  91. package/{fesm2015/skyux-core.js → fesm2020/skyux-core.mjs} +270 -178
  92. package/fesm2020/skyux-core.mjs.map +1 -0
  93. package/index.d.ts +2 -0
  94. package/lib/modules/log/log.service.d.ts +37 -3
  95. package/lib/modules/log/types/log-deprecation-args.d.ts +27 -0
  96. package/lib/modules/log/types/log-level-token.d.ts +6 -0
  97. package/lib/modules/log/types/log-level.d.ts +8 -0
  98. package/lib/modules/numeric/numeric.options.d.ts +6 -1
  99. package/lib/modules/numeric/numeric.pipe.d.ts +2 -4
  100. package/lib/modules/numeric/numeric.service.d.ts +2 -2
  101. package/lib/modules/resize-observer/resize-observer-media-query.service.d.ts +0 -1
  102. package/package.json +35 -11
  103. package/testing/package.json +5 -5
  104. package/bundles/skyux-core-testing.umd.js +0 -459
  105. package/bundles/skyux-core.umd.js +0 -3848
  106. package/esm2015/index.js +0 -62
  107. package/esm2015/index.js.map +0 -1
  108. package/esm2015/lib/modules/adapter-service/adapter.module.js +0 -16
  109. package/esm2015/lib/modules/adapter-service/adapter.module.js.map +0 -1
  110. package/esm2015/lib/modules/adapter-service/adapter.service.js +0 -226
  111. package/esm2015/lib/modules/adapter-service/adapter.service.js.map +0 -1
  112. package/esm2015/lib/modules/adapter-service/focusable-children-options.js +0 -2
  113. package/esm2015/lib/modules/adapter-service/focusable-children-options.js.map +0 -1
  114. package/esm2015/lib/modules/affix/affix-auto-fit-context.js +0 -12
  115. package/esm2015/lib/modules/affix/affix-auto-fit-context.js.map +0 -1
  116. package/esm2015/lib/modules/affix/affix-config.js +0 -2
  117. package/esm2015/lib/modules/affix/affix-config.js.map +0 -1
  118. package/esm2015/lib/modules/affix/affix-horizontal-alignment.js +0 -2
  119. package/esm2015/lib/modules/affix/affix-horizontal-alignment.js.map +0 -1
  120. package/esm2015/lib/modules/affix/affix-offset-change.js +0 -2
  121. package/esm2015/lib/modules/affix/affix-offset-change.js.map +0 -1
  122. package/esm2015/lib/modules/affix/affix-offset.js +0 -2
  123. package/esm2015/lib/modules/affix/affix-offset.js.map +0 -1
  124. package/esm2015/lib/modules/affix/affix-placement-change.js +0 -2
  125. package/esm2015/lib/modules/affix/affix-placement-change.js.map +0 -1
  126. package/esm2015/lib/modules/affix/affix-placement.js +0 -2
  127. package/esm2015/lib/modules/affix/affix-placement.js.map +0 -1
  128. package/esm2015/lib/modules/affix/affix-utils.js +0 -18
  129. package/esm2015/lib/modules/affix/affix-utils.js.map +0 -1
  130. package/esm2015/lib/modules/affix/affix-vertical-alignment.js +0 -2
  131. package/esm2015/lib/modules/affix/affix-vertical-alignment.js.map +0 -1
  132. package/esm2015/lib/modules/affix/affix.directive.js +0 -100
  133. package/esm2015/lib/modules/affix/affix.directive.js.map +0 -1
  134. package/esm2015/lib/modules/affix/affix.module.js +0 -18
  135. package/esm2015/lib/modules/affix/affix.module.js.map +0 -1
  136. package/esm2015/lib/modules/affix/affix.service.js +0 -24
  137. package/esm2015/lib/modules/affix/affix.service.js.map +0 -1
  138. package/esm2015/lib/modules/affix/affixer.js +0 -349
  139. package/esm2015/lib/modules/affix/affixer.js.map +0 -1
  140. package/esm2015/lib/modules/affix/dom-utils.js +0 -77
  141. package/esm2015/lib/modules/affix/dom-utils.js.map +0 -1
  142. package/esm2015/lib/modules/dock/dock-dom-adapter.service.js +0 -80
  143. package/esm2015/lib/modules/dock/dock-dom-adapter.service.js.map +0 -1
  144. package/esm2015/lib/modules/dock/dock-insert-component-config.js +0 -2
  145. package/esm2015/lib/modules/dock/dock-insert-component-config.js.map +0 -1
  146. package/esm2015/lib/modules/dock/dock-item-config.js +0 -2
  147. package/esm2015/lib/modules/dock/dock-item-config.js.map +0 -1
  148. package/esm2015/lib/modules/dock/dock-item-reference.js +0 -2
  149. package/esm2015/lib/modules/dock/dock-item-reference.js.map +0 -1
  150. package/esm2015/lib/modules/dock/dock-item.js +0 -29
  151. package/esm2015/lib/modules/dock/dock-item.js.map +0 -1
  152. package/esm2015/lib/modules/dock/dock-location.js +0 -19
  153. package/esm2015/lib/modules/dock/dock-location.js.map +0 -1
  154. package/esm2015/lib/modules/dock/dock-options.js +0 -2
  155. package/esm2015/lib/modules/dock/dock-options.js.map +0 -1
  156. package/esm2015/lib/modules/dock/dock.component.js +0 -95
  157. package/esm2015/lib/modules/dock/dock.component.js.map +0 -1
  158. package/esm2015/lib/modules/dock/dock.module.js +0 -20
  159. package/esm2015/lib/modules/dock/dock.module.js.map +0 -1
  160. package/esm2015/lib/modules/dock/dock.service.js +0 -95
  161. package/esm2015/lib/modules/dock/dock.service.js.map +0 -1
  162. package/esm2015/lib/modules/dock/sort-by-stack-order.js +0 -13
  163. package/esm2015/lib/modules/dock/sort-by-stack-order.js.map +0 -1
  164. package/esm2015/lib/modules/dynamic-component/dynamic-component-location.js +0 -27
  165. package/esm2015/lib/modules/dynamic-component/dynamic-component-location.js.map +0 -1
  166. package/esm2015/lib/modules/dynamic-component/dynamic-component-options.js +0 -2
  167. package/esm2015/lib/modules/dynamic-component/dynamic-component-options.js.map +0 -1
  168. package/esm2015/lib/modules/dynamic-component/dynamic-component.module.js +0 -17
  169. package/esm2015/lib/modules/dynamic-component/dynamic-component.module.js.map +0 -1
  170. package/esm2015/lib/modules/dynamic-component/dynamic-component.service.js +0 -83
  171. package/esm2015/lib/modules/dynamic-component/dynamic-component.service.js.map +0 -1
  172. package/esm2015/lib/modules/format/app-format.js +0 -18
  173. package/esm2015/lib/modules/format/app-format.js.map +0 -1
  174. package/esm2015/lib/modules/id/id.directive.js +0 -34
  175. package/esm2015/lib/modules/id/id.directive.js.map +0 -1
  176. package/esm2015/lib/modules/id/id.module.js +0 -16
  177. package/esm2015/lib/modules/id/id.module.js.map +0 -1
  178. package/esm2015/lib/modules/log/log.module.js +0 -16
  179. package/esm2015/lib/modules/log/log.module.js.map +0 -1
  180. package/esm2015/lib/modules/log/log.service.js +0 -23
  181. package/esm2015/lib/modules/log/log.service.js.map +0 -1
  182. package/esm2015/lib/modules/media-query/media-breakpoints.js +0 -20
  183. package/esm2015/lib/modules/media-query/media-breakpoints.js.map +0 -1
  184. package/esm2015/lib/modules/media-query/media-query-listener.js +0 -2
  185. package/esm2015/lib/modules/media-query/media-query-listener.js.map +0 -1
  186. package/esm2015/lib/modules/media-query/media-query.module.js +0 -16
  187. package/esm2015/lib/modules/media-query/media-query.module.js.map +0 -1
  188. package/esm2015/lib/modules/media-query/media-query.service.js +0 -121
  189. package/esm2015/lib/modules/media-query/media-query.service.js.map +0 -1
  190. package/esm2015/lib/modules/mutation/mutation-observer-service.js +0 -16
  191. package/esm2015/lib/modules/mutation/mutation-observer-service.js.map +0 -1
  192. package/esm2015/lib/modules/numeric/numeric-symbol.js +0 -2
  193. package/esm2015/lib/modules/numeric/numeric-symbol.js.map +0 -1
  194. package/esm2015/lib/modules/numeric/numeric.module.js +0 -20
  195. package/esm2015/lib/modules/numeric/numeric.module.js.map +0 -1
  196. package/esm2015/lib/modules/numeric/numeric.options.js +0 -41
  197. package/esm2015/lib/modules/numeric/numeric.options.js.map +0 -1
  198. package/esm2015/lib/modules/numeric/numeric.pipe.js +0 -83
  199. package/esm2015/lib/modules/numeric/numeric.pipe.js.map +0 -1
  200. package/esm2015/lib/modules/numeric/numeric.service.js +0 -189
  201. package/esm2015/lib/modules/numeric/numeric.service.js.map +0 -1
  202. package/esm2015/lib/modules/overlay/overlay-adapter.service.js +0 -41
  203. package/esm2015/lib/modules/overlay/overlay-adapter.service.js.map +0 -1
  204. package/esm2015/lib/modules/overlay/overlay-config.js +0 -2
  205. package/esm2015/lib/modules/overlay/overlay-config.js.map +0 -1
  206. package/esm2015/lib/modules/overlay/overlay-context.js +0 -10
  207. package/esm2015/lib/modules/overlay/overlay-context.js.map +0 -1
  208. package/esm2015/lib/modules/overlay/overlay-instance.js +0 -55
  209. package/esm2015/lib/modules/overlay/overlay-instance.js.map +0 -1
  210. package/esm2015/lib/modules/overlay/overlay.component.js +0 -154
  211. package/esm2015/lib/modules/overlay/overlay.component.js.map +0 -1
  212. package/esm2015/lib/modules/overlay/overlay.module.js +0 -18
  213. package/esm2015/lib/modules/overlay/overlay.module.js.map +0 -1
  214. package/esm2015/lib/modules/overlay/overlay.service.js +0 -120
  215. package/esm2015/lib/modules/overlay/overlay.service.js.map +0 -1
  216. package/esm2015/lib/modules/percent-pipe/percent-pipe.module.js +0 -20
  217. package/esm2015/lib/modules/percent-pipe/percent-pipe.module.js.map +0 -1
  218. package/esm2015/lib/modules/percent-pipe/percent.pipe.js +0 -48
  219. package/esm2015/lib/modules/percent-pipe/percent.pipe.js.map +0 -1
  220. package/esm2015/lib/modules/resize-observer/resize-observer-media-query.service.js +0 -117
  221. package/esm2015/lib/modules/resize-observer/resize-observer-media-query.service.js.map +0 -1
  222. package/esm2015/lib/modules/resize-observer/resize-observer.service.js +0 -73
  223. package/esm2015/lib/modules/resize-observer/resize-observer.service.js.map +0 -1
  224. package/esm2015/lib/modules/scrollable-host/scrollable-host.service.js +0 -184
  225. package/esm2015/lib/modules/scrollable-host/scrollable-host.service.js.map +0 -1
  226. package/esm2015/lib/modules/shared/number-format/number-format-utility.js +0 -72
  227. package/esm2015/lib/modules/shared/number-format/number-format-utility.js.map +0 -1
  228. package/esm2015/lib/modules/shared/sky-core-resources.module.js +0 -50
  229. package/esm2015/lib/modules/shared/sky-core-resources.module.js.map +0 -1
  230. package/esm2015/lib/modules/title/set-title-args.js +0 -2
  231. package/esm2015/lib/modules/title/set-title-args.js.map +0 -1
  232. package/esm2015/lib/modules/title/title.service.js +0 -31
  233. package/esm2015/lib/modules/title/title.service.js.map +0 -1
  234. package/esm2015/lib/modules/ui-config/ui-config.service.js +0 -21
  235. package/esm2015/lib/modules/ui-config/ui-config.service.js.map +0 -1
  236. package/esm2015/lib/modules/viewkeeper/viewkeeper-boundary-info.js +0 -2
  237. package/esm2015/lib/modules/viewkeeper/viewkeeper-boundary-info.js.map +0 -1
  238. package/esm2015/lib/modules/viewkeeper/viewkeeper-fixed-styles.js +0 -2
  239. package/esm2015/lib/modules/viewkeeper/viewkeeper-fixed-styles.js.map +0 -1
  240. package/esm2015/lib/modules/viewkeeper/viewkeeper-host-options.js +0 -10
  241. package/esm2015/lib/modules/viewkeeper/viewkeeper-host-options.js.map +0 -1
  242. package/esm2015/lib/modules/viewkeeper/viewkeeper-offset.js +0 -2
  243. package/esm2015/lib/modules/viewkeeper/viewkeeper-offset.js.map +0 -1
  244. package/esm2015/lib/modules/viewkeeper/viewkeeper-options.js +0 -2
  245. package/esm2015/lib/modules/viewkeeper/viewkeeper-options.js.map +0 -1
  246. package/esm2015/lib/modules/viewkeeper/viewkeeper.directive.js +0 -116
  247. package/esm2015/lib/modules/viewkeeper/viewkeeper.directive.js.map +0 -1
  248. package/esm2015/lib/modules/viewkeeper/viewkeeper.js +0 -251
  249. package/esm2015/lib/modules/viewkeeper/viewkeeper.js.map +0 -1
  250. package/esm2015/lib/modules/viewkeeper/viewkeeper.module.js +0 -16
  251. package/esm2015/lib/modules/viewkeeper/viewkeeper.module.js.map +0 -1
  252. package/esm2015/lib/modules/viewkeeper/viewkeeper.service.js +0 -39
  253. package/esm2015/lib/modules/viewkeeper/viewkeeper.service.js.map +0 -1
  254. package/esm2015/lib/modules/window/window-ref.js +0 -30
  255. package/esm2015/lib/modules/window/window-ref.js.map +0 -1
  256. package/esm2015/skyux-core.js +0 -5
  257. package/esm2015/skyux-core.js.map +0 -1
  258. package/esm2015/testing/mock-media-query.service.js +0 -41
  259. package/esm2015/testing/mock-media-query.service.js.map +0 -1
  260. package/esm2015/testing/mock-ui-config.service.js +0 -59
  261. package/esm2015/testing/mock-ui-config.service.js.map +0 -1
  262. package/esm2015/testing/public-api.js +0 -3
  263. package/esm2015/testing/public-api.js.map +0 -1
  264. package/esm2015/testing/skyux-core-testing.js +0 -5
  265. package/esm2015/testing/skyux-core-testing.js.map +0 -1
  266. package/fesm2015/skyux-core-testing.js.map +0 -1
  267. package/fesm2015/skyux-core.js.map +0 -1
@@ -0,0 +1,120 @@
1
+ import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector, } from '@angular/core';
2
+ import { SkyOverlayAdapterService } from './overlay-adapter.service';
3
+ import { SkyOverlayContext } from './overlay-context';
4
+ import { SkyOverlayInstance } from './overlay-instance';
5
+ import { SkyOverlayComponent } from './overlay.component';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "./overlay-adapter.service";
8
+ /**
9
+ * This service is used to create new overlays.
10
+ * @dynamic
11
+ */
12
+ export class SkyOverlayService {
13
+ constructor(applicationRef, componentFactoryResolver, injector, adapter) {
14
+ this.applicationRef = applicationRef;
15
+ this.componentFactoryResolver = componentFactoryResolver;
16
+ this.injector = injector;
17
+ this.adapter = adapter;
18
+ }
19
+ /**
20
+ * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.
21
+ * @param config Configuration for the overlay.
22
+ */
23
+ create(config) {
24
+ const settings = this.prepareConfig(config);
25
+ if (settings.enableScroll === false) {
26
+ this.adapter.restrictBodyScroll();
27
+ }
28
+ const componentRef = this.createOverlay(settings);
29
+ const instance = new SkyOverlayInstance(settings, componentRef);
30
+ instance.closed.subscribe(() => {
31
+ // Only execute the service's close method if the instance still exists.
32
+ // This is needed to address a race condition if the deprecated instance.close method is used instead.
33
+ if (SkyOverlayService.overlays.indexOf(instance) > -1) {
34
+ this.close(instance);
35
+ }
36
+ });
37
+ SkyOverlayService.overlays.push(instance);
38
+ return instance;
39
+ }
40
+ /**
41
+ * Closes (and destroys) an overlay instance.
42
+ * @param instance The instance to close.
43
+ */
44
+ close(instance) {
45
+ this.destroyOverlay(instance);
46
+ this.applicationRef.detachView(instance.componentRef.hostView);
47
+ instance.componentRef.destroy();
48
+ // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during
49
+ // unit tests. This can make querying difficult because the older DOM nodes still exist and
50
+ // produce inconsistent results.
51
+ // Angular Material's overlay appears to do the same thing:
52
+ // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145
53
+ // (Ignoring coverage since this branch will only be hit by consumer unit tests.)
54
+ const componentElement = instance.componentRef.location.nativeElement;
55
+ /* istanbul ignore if */
56
+ if (componentElement.parentNode !== null) {
57
+ componentElement.parentNode.removeChild(componentElement);
58
+ }
59
+ }
60
+ /**
61
+ * Closes all overlay instances.
62
+ */
63
+ closeAll() {
64
+ // The `close` event handler for each instance alters the array's length asynchronously,
65
+ // so the only "safe" index to call is zero.
66
+ while (SkyOverlayService.overlays.length > 0) {
67
+ this.close(SkyOverlayService.overlays[0]);
68
+ }
69
+ }
70
+ createOverlay(config) {
71
+ const injector = Injector.create({
72
+ parent: this.injector,
73
+ providers: [
74
+ {
75
+ provide: SkyOverlayContext,
76
+ useValue: new SkyOverlayContext(config),
77
+ },
78
+ ],
79
+ });
80
+ const componentRef = this.componentFactoryResolver
81
+ .resolveComponentFactory(SkyOverlayComponent)
82
+ .create(injector);
83
+ this.applicationRef.attachView(componentRef.hostView);
84
+ const domElem = componentRef.hostView
85
+ .rootNodes[0];
86
+ document.body.appendChild(domElem);
87
+ return componentRef;
88
+ }
89
+ prepareConfig(config) {
90
+ const defaults = {
91
+ closeOnNavigation: true,
92
+ enableClose: false,
93
+ enablePointerEvents: false,
94
+ enableScroll: true,
95
+ showBackdrop: false,
96
+ wrapperClass: '',
97
+ };
98
+ return { ...defaults, ...config };
99
+ }
100
+ destroyOverlay(instance) {
101
+ SkyOverlayService.overlays.splice(SkyOverlayService.overlays.indexOf(instance), 1);
102
+ if (instance.config.enableScroll === false) {
103
+ // Only release the body scroll if no other overlay wishes it to be disabled.
104
+ const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some((o) => !o.config.enableScroll);
105
+ if (!anotherOverlayDisablesScroll) {
106
+ this.adapter.releaseBodyScroll();
107
+ }
108
+ }
109
+ }
110
+ }
111
+ SkyOverlayService.overlays = [];
112
+ SkyOverlayService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayService, deps: [{ token: i0.ApplicationRef }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i1.SkyOverlayAdapterService }], target: i0.ɵɵFactoryTarget.Injectable });
113
+ SkyOverlayService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayService, providedIn: 'root' });
114
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyOverlayService, decorators: [{
115
+ type: Injectable,
116
+ args: [{
117
+ providedIn: 'root',
118
+ }]
119
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i1.SkyOverlayAdapterService }]; } });
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  EmbeddedViewRef,\n  Injectable,\n  Injector,\n} from '@angular/core';\n\nimport { SkyOverlayAdapterService } from './overlay-adapter.service';\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayInstance } from './overlay-instance';\nimport { SkyOverlayComponent } from './overlay.component';\n\n/**\n * This service is used to create new overlays.\n * @dynamic\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyOverlayService {\n  private static overlays: SkyOverlayInstance[] = [];\n\n  constructor(\n    private applicationRef: ApplicationRef,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private injector: Injector,\n    private adapter: SkyOverlayAdapterService\n  ) {}\n\n  /**\n   * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.\n   * @param config Configuration for the overlay.\n   */\n  public create(config?: SkyOverlayConfig): SkyOverlayInstance {\n    const settings = this.prepareConfig(config);\n\n    if (settings.enableScroll === false) {\n      this.adapter.restrictBodyScroll();\n    }\n\n    const componentRef = this.createOverlay(settings);\n    const instance = new SkyOverlayInstance(settings, componentRef);\n\n    instance.closed.subscribe(() => {\n      // Only execute the service's close method if the instance still exists.\n      // This is needed to address a race condition if the deprecated instance.close method is used instead.\n      if (SkyOverlayService.overlays.indexOf(instance) > -1) {\n        this.close(instance);\n      }\n    });\n\n    SkyOverlayService.overlays.push(instance);\n\n    return instance;\n  }\n\n  /**\n   * Closes (and destroys) an overlay instance.\n   * @param instance The instance to close.\n   */\n  public close(instance: SkyOverlayInstance): void {\n    this.destroyOverlay(instance);\n    this.applicationRef.detachView(instance.componentRef.hostView);\n    instance.componentRef.destroy();\n\n    // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during\n    // unit tests. This can make querying difficult because the older DOM nodes still exist and\n    // produce inconsistent results.\n    // Angular Material's overlay appears to do the same thing:\n    // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145\n    // (Ignoring coverage since this branch will only be hit by consumer unit tests.)\n    const componentElement = instance.componentRef.location.nativeElement;\n    /* istanbul ignore if */\n    if (componentElement.parentNode !== null) {\n      componentElement.parentNode.removeChild(componentElement);\n    }\n  }\n\n  /**\n   * Closes all overlay instances.\n   */\n  public closeAll(): void {\n    // The `close` event handler for each instance alters the array's length asynchronously,\n    // so the only \"safe\" index to call is zero.\n    while (SkyOverlayService.overlays.length > 0) {\n      this.close(SkyOverlayService.overlays[0]);\n    }\n  }\n\n  private createOverlay(\n    config?: SkyOverlayConfig\n  ): ComponentRef<SkyOverlayComponent> {\n    const injector = Injector.create({\n      parent: this.injector,\n      providers: [\n        {\n          provide: SkyOverlayContext,\n          useValue: new SkyOverlayContext(config),\n        },\n      ],\n    });\n\n    const componentRef = this.componentFactoryResolver\n      .resolveComponentFactory(SkyOverlayComponent)\n      .create(injector);\n\n    this.applicationRef.attachView(componentRef.hostView);\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n\n    document.body.appendChild(domElem);\n\n    return componentRef;\n  }\n\n  private prepareConfig(config: SkyOverlayConfig): SkyOverlayConfig {\n    const defaults: SkyOverlayConfig = {\n      closeOnNavigation: true,\n      enableClose: false,\n      enablePointerEvents: false,\n      enableScroll: true,\n      showBackdrop: false,\n      wrapperClass: '',\n    };\n\n    return { ...defaults, ...config };\n  }\n\n  private destroyOverlay(instance: SkyOverlayInstance): void {\n    SkyOverlayService.overlays.splice(\n      SkyOverlayService.overlays.indexOf(instance),\n      1\n    );\n\n    if (instance.config.enableScroll === false) {\n      // Only release the body scroll if no other overlay wishes it to be disabled.\n      const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some(\n        (o) => !o.config.enableScroll\n      );\n      if (!anotherOverlayDisablesScroll) {\n        this.adapter.releaseBodyScroll();\n      }\n    }\n  }\n}\n"]}
@@ -0,0 +1,20 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { SkyCoreResourcesModule } from '../shared/sky-core-resources.module';
4
+ import { SkyPercentPipe } from './percent.pipe';
5
+ import * as i0 from "@angular/core";
6
+ export class SkyPercentPipeModule {
7
+ }
8
+ SkyPercentPipeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ SkyPercentPipeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipeModule, declarations: [SkyPercentPipe], imports: [CommonModule, SkyCoreResourcesModule], exports: [SkyPercentPipe] });
10
+ SkyPercentPipeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipeModule, providers: [SkyPercentPipe], imports: [[CommonModule, SkyCoreResourcesModule]] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipeModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [SkyPercentPipe],
15
+ providers: [SkyPercentPipe],
16
+ imports: [CommonModule, SkyCoreResourcesModule],
17
+ exports: [SkyPercentPipe],
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyY2VudC1waXBlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9wZXJjZW50LXBpcGUvcGVyY2VudC1waXBlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUU3RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBUWhELE1BQU0sT0FBTyxvQkFBb0I7O2lIQUFwQixvQkFBb0I7a0hBQXBCLG9CQUFvQixpQkFMaEIsY0FBYyxhQUVuQixZQUFZLEVBQUUsc0JBQXNCLGFBQ3BDLGNBQWM7a0hBRWIsb0JBQW9CLGFBSnBCLENBQUMsY0FBYyxDQUFDLFlBQ2xCLENBQUMsWUFBWSxFQUFFLHNCQUFzQixDQUFDOzJGQUdwQyxvQkFBb0I7a0JBTmhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsY0FBYyxDQUFDO29CQUM5QixTQUFTLEVBQUUsQ0FBQyxjQUFjLENBQUM7b0JBQzNCLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxzQkFBc0IsQ0FBQztvQkFDL0MsT0FBTyxFQUFFLENBQUMsY0FBYyxDQUFDO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lDb3JlUmVzb3VyY2VzTW9kdWxlIH0gZnJvbSAnLi4vc2hhcmVkL3NreS1jb3JlLXJlc291cmNlcy5tb2R1bGUnO1xuXG5pbXBvcnQgeyBTa3lQZXJjZW50UGlwZSB9IGZyb20gJy4vcGVyY2VudC5waXBlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5UGVyY2VudFBpcGVdLFxuICBwcm92aWRlcnM6IFtTa3lQZXJjZW50UGlwZV0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFNreUNvcmVSZXNvdXJjZXNNb2R1bGVdLFxuICBleHBvcnRzOiBbU2t5UGVyY2VudFBpcGVdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lQZXJjZW50UGlwZU1vZHVsZSB7fVxuIl19
@@ -0,0 +1,48 @@
1
+ import { Pipe } from '@angular/core';
2
+ import { SkyAppLocaleProvider, SkyIntlNumberFormatStyle } from '@skyux/i18n';
3
+ import { Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import { SkyNumberFormatUtility } from '../shared/number-format/number-format-utility';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@skyux/i18n";
8
+ export class SkyPercentPipe {
9
+ constructor(localeProvider) {
10
+ this.localeProvider = localeProvider;
11
+ this.defaultFormat = '1.0-2';
12
+ this.defaultLocale = 'en-US';
13
+ this.ngUnsubscribe = new Subject();
14
+ this.localeProvider
15
+ .getLocaleInfo()
16
+ .pipe(takeUntil(this.ngUnsubscribe))
17
+ .subscribe((localeInfo) => {
18
+ this.defaultLocale = localeInfo.locale;
19
+ this.updateFormattedValue();
20
+ });
21
+ }
22
+ ngOnDestroy() {
23
+ this.ngUnsubscribe.next();
24
+ this.ngUnsubscribe.complete();
25
+ }
26
+ transform(value, format, locale) {
27
+ this.value = value;
28
+ this.format = format;
29
+ this.locale = locale;
30
+ this.updateFormattedValue();
31
+ return this.formattedValue;
32
+ }
33
+ updateFormattedValue() {
34
+ const locale = this.locale || this.defaultLocale;
35
+ const format = this.format || this.defaultFormat;
36
+ this.formattedValue = SkyNumberFormatUtility.formatNumber(locale, this.value, SkyIntlNumberFormatStyle.Percent, format);
37
+ }
38
+ }
39
+ SkyPercentPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipe, deps: [{ token: i1.SkyAppLocaleProvider }], target: i0.ɵɵFactoryTarget.Pipe });
40
+ SkyPercentPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipe, name: "skyPercent", pure: false });
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipe, decorators: [{
42
+ type: Pipe,
43
+ args: [{
44
+ name: 'skyPercent',
45
+ pure: false,
46
+ }]
47
+ }], ctorParameters: function () { return [{ type: i1.SkyAppLocaleProvider }]; } });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyY2VudC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3BlcmNlbnQtcGlwZS9wZXJjZW50LnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFhLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLHdCQUF3QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRTdFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTNDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLCtDQUErQyxDQUFDOzs7QUFNdkYsTUFBTSxPQUFPLGNBQWM7SUFlekIsWUFBb0IsY0FBb0M7UUFBcEMsbUJBQWMsR0FBZCxjQUFjLENBQXNCO1FBZGhELGtCQUFhLEdBQUcsT0FBTyxDQUFDO1FBSXhCLGtCQUFhLEdBQUcsT0FBTyxDQUFDO1FBUXhCLGtCQUFhLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUcxQyxJQUFJLENBQUMsY0FBYzthQUNoQixhQUFhLEVBQUU7YUFDZixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQzthQUNuQyxTQUFTLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtZQUN4QixJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUM7WUFDdkMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7UUFDOUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzFCLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLFNBQVMsQ0FBQyxLQUFhLEVBQUUsTUFBZSxFQUFFLE1BQWU7UUFDOUQsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFFckIsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7UUFFNUIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQzdCLENBQUM7SUFFTyxvQkFBb0I7UUFDMUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDO1FBQ2pELE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUVqRCxJQUFJLENBQUMsY0FBYyxHQUFHLHNCQUFzQixDQUFDLFlBQVksQ0FDdkQsTUFBTSxFQUNOLElBQUksQ0FBQyxLQUFLLEVBQ1Ysd0JBQXdCLENBQUMsT0FBTyxFQUNoQyxNQUFNLENBQ1AsQ0FBQztJQUNKLENBQUM7OzJHQWxEVSxjQUFjO3lHQUFkLGNBQWM7MkZBQWQsY0FBYztrQkFKMUIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsWUFBWTtvQkFDbEIsSUFBSSxFQUFFLEtBQUs7aUJBQ1oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPbkRlc3Ryb3ksIFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNreUFwcExvY2FsZVByb3ZpZGVyLCBTa3lJbnRsTnVtYmVyRm9ybWF0U3R5bGUgfSBmcm9tICdAc2t5dXgvaTE4bic7XG5cbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgU2t5TnVtYmVyRm9ybWF0VXRpbGl0eSB9IGZyb20gJy4uL3NoYXJlZC9udW1iZXItZm9ybWF0L251bWJlci1mb3JtYXQtdXRpbGl0eSc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3NreVBlcmNlbnQnLFxuICBwdXJlOiBmYWxzZSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UGVyY2VudFBpcGUgaW1wbGVtZW50cyBPbkRlc3Ryb3ksIFBpcGVUcmFuc2Zvcm0ge1xuICBwcml2YXRlIGRlZmF1bHRGb3JtYXQgPSAnMS4wLTInO1xuXG4gIHByaXZhdGUgZm9ybWF0OiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSBkZWZhdWx0TG9jYWxlID0gJ2VuLVVTJztcblxuICBwcml2YXRlIGxvY2FsZTogc3RyaW5nO1xuXG4gIHByaXZhdGUgdmFsdWU6IHN0cmluZztcblxuICBwcml2YXRlIGZvcm1hdHRlZFZhbHVlOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSBuZ1Vuc3Vic2NyaWJlID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGxvY2FsZVByb3ZpZGVyOiBTa3lBcHBMb2NhbGVQcm92aWRlcikge1xuICAgIHRoaXMubG9jYWxlUHJvdmlkZXJcbiAgICAgIC5nZXRMb2NhbGVJbmZvKClcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLm5nVW5zdWJzY3JpYmUpKVxuICAgICAgLnN1YnNjcmliZSgobG9jYWxlSW5mbykgPT4ge1xuICAgICAgICB0aGlzLmRlZmF1bHRMb2NhbGUgPSBsb2NhbGVJbmZvLmxvY2FsZTtcbiAgICAgICAgdGhpcy51cGRhdGVGb3JtYXR0ZWRWYWx1ZSgpO1xuICAgICAgfSk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5uZ1Vuc3Vic2NyaWJlLm5leHQoKTtcbiAgICB0aGlzLm5nVW5zdWJzY3JpYmUuY29tcGxldGUoKTtcbiAgfVxuXG4gIHB1YmxpYyB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZywgZm9ybWF0Pzogc3RyaW5nLCBsb2NhbGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcbiAgICB0aGlzLmZvcm1hdCA9IGZvcm1hdDtcbiAgICB0aGlzLmxvY2FsZSA9IGxvY2FsZTtcblxuICAgIHRoaXMudXBkYXRlRm9ybWF0dGVkVmFsdWUoKTtcblxuICAgIHJldHVybiB0aGlzLmZvcm1hdHRlZFZhbHVlO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVGb3JtYXR0ZWRWYWx1ZSgpOiB2b2lkIHtcbiAgICBjb25zdCBsb2NhbGUgPSB0aGlzLmxvY2FsZSB8fCB0aGlzLmRlZmF1bHRMb2NhbGU7XG4gICAgY29uc3QgZm9ybWF0ID0gdGhpcy5mb3JtYXQgfHwgdGhpcy5kZWZhdWx0Rm9ybWF0O1xuXG4gICAgdGhpcy5mb3JtYXR0ZWRWYWx1ZSA9IFNreU51bWJlckZvcm1hdFV0aWxpdHkuZm9ybWF0TnVtYmVyKFxuICAgICAgbG9jYWxlLFxuICAgICAgdGhpcy52YWx1ZSxcbiAgICAgIFNreUludGxOdW1iZXJGb3JtYXRTdHlsZS5QZXJjZW50LFxuICAgICAgZm9ybWF0XG4gICAgKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,117 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { ReplaySubject, Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { SkyMediaBreakpoints } from '../media-query/media-breakpoints';
5
+ import { SkyResizeObserverService } from './resize-observer.service';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "./resize-observer.service";
8
+ /**
9
+ * Acts like `SkyMediaQueryService` for a container element, emitting the same responsive breakpoints.
10
+ */
11
+ export class SkyResizeObserverMediaQueryService {
12
+ constructor(resizeObserverService) {
13
+ this.resizeObserverService = resizeObserverService;
14
+ this._breakpoints = [
15
+ {
16
+ check: (width) => width <= 767,
17
+ name: SkyMediaBreakpoints.xs,
18
+ },
19
+ {
20
+ check: (width) => width > 767 && width <= 991,
21
+ name: SkyMediaBreakpoints.sm,
22
+ },
23
+ {
24
+ check: (width) => width > 991 && width <= 1199,
25
+ name: SkyMediaBreakpoints.md,
26
+ },
27
+ {
28
+ check: (width) => width > 1199,
29
+ name: SkyMediaBreakpoints.lg,
30
+ },
31
+ ];
32
+ this._currentBreakpointObservable = new ReplaySubject(1);
33
+ this._stopListening = new Subject();
34
+ this._stopListening.subscribe(() => {
35
+ this._target = undefined;
36
+ this.updateBreakpoint(undefined);
37
+ });
38
+ }
39
+ /**
40
+ * Returns the current breakpoint.
41
+ */
42
+ get current() {
43
+ return this._currentBreakpoint;
44
+ }
45
+ ngOnDestroy() {
46
+ this._stopListening.next();
47
+ this._currentBreakpoint = undefined;
48
+ this._stopListening.complete();
49
+ this._currentBreakpointObservable.complete();
50
+ }
51
+ /**
52
+ * @internal
53
+ */
54
+ destroy() {
55
+ this.ngOnDestroy();
56
+ }
57
+ /**
58
+ * Sets the container element to watch. The `SkyResizeObserverMediaQueryService` will only observe one element at a
59
+ * time. Any previous subscriptions will be unsubscribed when a new element is observed.
60
+ */
61
+ observe(element) {
62
+ if (this._target) {
63
+ if (this._target === element) {
64
+ return this;
65
+ }
66
+ this._stopListening.next();
67
+ }
68
+ this._target = element;
69
+ const width = element.nativeElement.offsetWidth;
70
+ if (width) {
71
+ const breakpoint = this.checkBreakpoint(width);
72
+ this.updateBreakpoint(breakpoint);
73
+ }
74
+ this.resizeObserverService
75
+ .observe(element)
76
+ .pipe(takeUntil(this._stopListening))
77
+ .subscribe((value) => {
78
+ const breakpoint = this.checkBreakpoint(value.contentRect.width);
79
+ /* istanbul ignore else */
80
+ if (breakpoint !== this._currentBreakpoint) {
81
+ this.updateBreakpoint(breakpoint);
82
+ }
83
+ });
84
+ return this;
85
+ }
86
+ /**
87
+ * Stop watching the container element.
88
+ */
89
+ unobserve() {
90
+ this._stopListening.next();
91
+ }
92
+ /**
93
+ * Subscribes to element size changes that cross breakpoints.
94
+ */
95
+ subscribe(listener) {
96
+ return this._currentBreakpointObservable
97
+ .pipe(takeUntil(this._stopListening))
98
+ .subscribe(listener);
99
+ }
100
+ updateBreakpoint(breakpoint) {
101
+ this._currentBreakpoint = breakpoint;
102
+ this._currentBreakpointObservable.next(breakpoint);
103
+ }
104
+ checkBreakpoint(width) {
105
+ return this._breakpoints.find((breakpoint) => breakpoint.check(width))
106
+ ?.name;
107
+ }
108
+ }
109
+ SkyResizeObserverMediaQueryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverMediaQueryService, deps: [{ token: i1.SkyResizeObserverService }], target: i0.ɵɵFactoryTarget.Injectable });
110
+ SkyResizeObserverMediaQueryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverMediaQueryService, providedIn: 'any' });
111
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverMediaQueryService, decorators: [{
112
+ type: Injectable,
113
+ args: [{
114
+ providedIn: 'any',
115
+ }]
116
+ }], ctorParameters: function () { return [{ type: i1.SkyResizeObserverService }]; } });
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-observer-media-query.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/resize-observer/resize-observer-media-query.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable, OnDestroy } from '@angular/core';\n\nimport { ReplaySubject, Subject, Subscription } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyMediaBreakpoints } from '../media-query/media-breakpoints';\nimport { SkyMediaQueryListener } from '../media-query/media-query-listener';\n\nimport { SkyResizeObserverService } from './resize-observer.service';\n\n/**\n * Acts like `SkyMediaQueryService` for a container element, emitting the same responsive breakpoints.\n */\n@Injectable({\n  providedIn: 'any',\n})\nexport class SkyResizeObserverMediaQueryService implements OnDestroy {\n  /**\n   * Returns the current breakpoint.\n   */\n  public get current(): SkyMediaBreakpoints | undefined {\n    return this._currentBreakpoint;\n  }\n\n  private _breakpoints: {\n    check: (width: number) => boolean;\n    name: SkyMediaBreakpoints;\n  }[] = [\n    {\n      check: (width: number) => width <= 767,\n      name: SkyMediaBreakpoints.xs,\n    },\n    {\n      check: (width: number) => width > 767 && width <= 991,\n      name: SkyMediaBreakpoints.sm,\n    },\n    {\n      check: (width: number) => width > 991 && width <= 1199,\n      name: SkyMediaBreakpoints.md,\n    },\n    {\n      check: (width: number) => width > 1199,\n      name: SkyMediaBreakpoints.lg,\n    },\n  ];\n  private _currentBreakpointObservable = new ReplaySubject<\n    SkyMediaBreakpoints | undefined\n  >(1);\n  private _currentBreakpoint: SkyMediaBreakpoints;\n  private _stopListening = new Subject<void>();\n  private _target?: ElementRef;\n\n  constructor(private resizeObserverService: SkyResizeObserverService) {\n    this._stopListening.subscribe(() => {\n      this._target = undefined;\n      this.updateBreakpoint(undefined);\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this._stopListening.next();\n    this._currentBreakpoint = undefined;\n    this._stopListening.complete();\n    this._currentBreakpointObservable.complete();\n  }\n\n  /**\n   * @internal\n   */\n  public destroy(): void {\n    this.ngOnDestroy();\n  }\n\n  /**\n   * Sets the container element to watch. The `SkyResizeObserverMediaQueryService` will only observe one element at a\n   * time. Any previous subscriptions will be unsubscribed when a new element is observed.\n   */\n  public observe(element: ElementRef): SkyResizeObserverMediaQueryService {\n    if (this._target) {\n      if (this._target === element) {\n        return this;\n      }\n      this._stopListening.next();\n    }\n    this._target = element;\n    const width = (element.nativeElement as HTMLElement).offsetWidth;\n    if (width) {\n      const breakpoint = this.checkBreakpoint(width);\n      this.updateBreakpoint(breakpoint);\n    }\n    this.resizeObserverService\n      .observe(element)\n      .pipe(takeUntil(this._stopListening))\n      .subscribe((value) => {\n        const breakpoint = this.checkBreakpoint(value.contentRect.width);\n        /* istanbul ignore else */\n        if (breakpoint !== this._currentBreakpoint) {\n          this.updateBreakpoint(breakpoint);\n        }\n      });\n    return this;\n  }\n\n  /**\n   * Stop watching the container element.\n   */\n  public unobserve(): void {\n    this._stopListening.next();\n  }\n\n  /**\n   * Subscribes to element size changes that cross breakpoints.\n   */\n  public subscribe(listener: SkyMediaQueryListener): Subscription {\n    return this._currentBreakpointObservable\n      .pipe(takeUntil(this._stopListening))\n      .subscribe(listener);\n  }\n\n  private updateBreakpoint(breakpoint: SkyMediaBreakpoints) {\n    this._currentBreakpoint = breakpoint;\n    this._currentBreakpointObservable.next(breakpoint);\n  }\n\n  private checkBreakpoint(width: number): SkyMediaBreakpoints | undefined {\n    return this._breakpoints.find((breakpoint) => breakpoint.check(width))\n      ?.name;\n  }\n}\n"]}
@@ -0,0 +1,73 @@
1
+ import { Injectable, NgZone } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { finalize } from 'rxjs/operators';
4
+ import * as i0 from "@angular/core";
5
+ /**
6
+ * Service to create rxjs observables for changes to the content box dimensions of elements.
7
+ */
8
+ export class SkyResizeObserverService {
9
+ constructor(zone) {
10
+ this.zone = zone;
11
+ this._tracking = [];
12
+ this._resizeObserver = new ResizeObserver((entries) => {
13
+ entries.forEach((entry) => this.callback(entry));
14
+ });
15
+ }
16
+ ngOnDestroy() {
17
+ this._resizeObserver.disconnect();
18
+ }
19
+ /**
20
+ * Create rxjs observable to get size changes for an element ref.
21
+ */
22
+ observe(element) {
23
+ return this.observeAndTrack(element).subjectObservable;
24
+ }
25
+ observeAndTrack(element) {
26
+ const checkTracking = this._tracking.findIndex((value) => {
27
+ return !value.subject.closed && value.element === element.nativeElement;
28
+ });
29
+ if (checkTracking === -1) {
30
+ this._resizeObserver.observe(element.nativeElement);
31
+ }
32
+ const subject = new Subject();
33
+ const subjectObservable = subject.pipe(finalize(() => {
34
+ // Are there any other tracking entries still watching this element?
35
+ const checkTracking = this._tracking.findIndex((value) => {
36
+ return (value.subject !== subject &&
37
+ !value.subject.closed &&
38
+ value.element === element.nativeElement);
39
+ });
40
+ if (checkTracking === -1) {
41
+ this._resizeObserver.unobserve(element.nativeElement);
42
+ }
43
+ }));
44
+ const tracking = {
45
+ element: element.nativeElement,
46
+ subject,
47
+ subjectObservable,
48
+ };
49
+ this._tracking.push(tracking);
50
+ return tracking;
51
+ }
52
+ callback(entry) {
53
+ this._tracking
54
+ .filter((value) => !(value.subject.closed || value.subject.isStopped))
55
+ .forEach((value) => {
56
+ /* istanbul ignore else */
57
+ if (value.element === entry.target) {
58
+ this.zone.run(() => {
59
+ value.subject.next(entry);
60
+ });
61
+ }
62
+ });
63
+ }
64
+ }
65
+ SkyResizeObserverService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverService, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
66
+ SkyResizeObserverService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverService, providedIn: 'any' });
67
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverService, decorators: [{
68
+ type: Injectable,
69
+ args: [{
70
+ providedIn: 'any',
71
+ }]
72
+ }], ctorParameters: function () { return [{ type: i0.NgZone }]; } });
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzaXplLW9ic2VydmVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvcmVzaXplLW9ic2VydmVyL3Jlc2l6ZS1vYnNlcnZlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDM0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQVExQzs7R0FFRztBQUlILE1BQU0sT0FBTyx3QkFBd0I7SUFJbkMsWUFBb0IsSUFBWTtRQUFaLFNBQUksR0FBSixJQUFJLENBQVE7UUFGeEIsY0FBUyxHQUE2QixFQUFFLENBQUM7UUFHL0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLGNBQWMsQ0FDdkMsQ0FBQyxPQUE4QixFQUFFLEVBQUU7WUFDakMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ25ELENBQUMsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxPQUFPLENBQUMsT0FBbUI7UUFDaEMsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDLGlCQUFpQixDQUFDO0lBQ3pELENBQUM7SUFFTyxlQUFlLENBQUMsT0FBbUI7UUFDekMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUN2RCxPQUFPLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDLE9BQU8sS0FBSyxPQUFPLENBQUMsYUFBYSxDQUFDO1FBQzFFLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxhQUFhLEtBQUssQ0FBQyxDQUFDLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1NBQ3JEO1FBQ0QsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLEVBQXVCLENBQUM7UUFDbkQsTUFBTSxpQkFBaUIsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUNwQyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ1osb0VBQW9FO1lBQ3BFLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQ3ZELE9BQU8sQ0FDTCxLQUFLLENBQUMsT0FBTyxLQUFLLE9BQU87b0JBQ3pCLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNO29CQUNyQixLQUFLLENBQUMsT0FBTyxLQUFLLE9BQU8sQ0FBQyxhQUFhLENBQ3hDLENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQztZQUNILElBQUksYUFBYSxLQUFLLENBQUMsQ0FBQyxFQUFFO2dCQUN4QixJQUFJLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUM7YUFDdkQ7UUFDSCxDQUFDLENBQUMsQ0FDSCxDQUFDO1FBQ0YsTUFBTSxRQUFRLEdBQUc7WUFDZixPQUFPLEVBQUUsT0FBTyxDQUFDLGFBQWE7WUFDOUIsT0FBTztZQUNQLGlCQUFpQjtTQUNsQixDQUFDO1FBQ0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDOUIsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQUVPLFFBQVEsQ0FBQyxLQUEwQjtRQUN6QyxJQUFJLENBQUMsU0FBUzthQUNYLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDckUsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDakIsMEJBQTBCO1lBQzFCLElBQUksS0FBSyxDQUFDLE9BQU8sS0FBSyxLQUFLLENBQUMsTUFBTSxFQUFFO2dCQUNsQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUU7b0JBQ2pCLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUM1QixDQUFDLENBQUMsQ0FBQzthQUNKO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDOztxSEFsRVUsd0JBQXdCO3lIQUF4Qix3QkFBd0IsY0FGdkIsS0FBSzsyRkFFTix3QkFBd0I7a0JBSHBDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLEtBQUs7aUJBQ2xCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudFJlZiwgSW5qZWN0YWJsZSwgTmdab25lLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZmluYWxpemUgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbnR5cGUgUmVzaXplT2JzZXJ2ZXJUcmFja2luZyA9IHtcbiAgZWxlbWVudDogRWxlbWVudDtcbiAgc3ViamVjdDogU3ViamVjdDxSZXNpemVPYnNlcnZlckVudHJ5PjtcbiAgc3ViamVjdE9ic2VydmFibGU6IE9ic2VydmFibGU8UmVzaXplT2JzZXJ2ZXJFbnRyeT47XG59O1xuXG4vKipcbiAqIFNlcnZpY2UgdG8gY3JlYXRlIHJ4anMgb2JzZXJ2YWJsZXMgZm9yIGNoYW5nZXMgdG8gdGhlIGNvbnRlbnQgYm94IGRpbWVuc2lvbnMgb2YgZWxlbWVudHMuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ2FueScsXG59KVxuZXhwb3J0IGNsYXNzIFNreVJlc2l6ZU9ic2VydmVyU2VydmljZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgX3Jlc2l6ZU9ic2VydmVyOiBSZXNpemVPYnNlcnZlcjtcbiAgcHJpdmF0ZSBfdHJhY2tpbmc6IFJlc2l6ZU9ic2VydmVyVHJhY2tpbmdbXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgem9uZTogTmdab25lKSB7XG4gICAgdGhpcy5fcmVzaXplT2JzZXJ2ZXIgPSBuZXcgUmVzaXplT2JzZXJ2ZXIoXG4gICAgICAoZW50cmllczogUmVzaXplT2JzZXJ2ZXJFbnRyeVtdKSA9PiB7XG4gICAgICAgIGVudHJpZXMuZm9yRWFjaCgoZW50cnkpID0+IHRoaXMuY2FsbGJhY2soZW50cnkpKTtcbiAgICAgIH1cbiAgICApO1xuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX3Jlc2l6ZU9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgcnhqcyBvYnNlcnZhYmxlIHRvIGdldCBzaXplIGNoYW5nZXMgZm9yIGFuIGVsZW1lbnQgcmVmLlxuICAgKi9cbiAgcHVibGljIG9ic2VydmUoZWxlbWVudDogRWxlbWVudFJlZik6IE9ic2VydmFibGU8UmVzaXplT2JzZXJ2ZXJFbnRyeT4ge1xuICAgIHJldHVybiB0aGlzLm9ic2VydmVBbmRUcmFjayhlbGVtZW50KS5zdWJqZWN0T2JzZXJ2YWJsZTtcbiAgfVxuXG4gIHByaXZhdGUgb2JzZXJ2ZUFuZFRyYWNrKGVsZW1lbnQ6IEVsZW1lbnRSZWYpOiBSZXNpemVPYnNlcnZlclRyYWNraW5nIHtcbiAgICBjb25zdCBjaGVja1RyYWNraW5nID0gdGhpcy5fdHJhY2tpbmcuZmluZEluZGV4KCh2YWx1ZSkgPT4ge1xuICAgICAgcmV0dXJuICF2YWx1ZS5zdWJqZWN0LmNsb3NlZCAmJiB2YWx1ZS5lbGVtZW50ID09PSBlbGVtZW50Lm5hdGl2ZUVsZW1lbnQ7XG4gICAgfSk7XG4gICAgaWYgKGNoZWNrVHJhY2tpbmcgPT09IC0xKSB7XG4gICAgICB0aGlzLl9yZXNpemVPYnNlcnZlci5vYnNlcnZlKGVsZW1lbnQubmF0aXZlRWxlbWVudCk7XG4gICAgfVxuICAgIGNvbnN0IHN1YmplY3QgPSBuZXcgU3ViamVjdDxSZXNpemVPYnNlcnZlckVudHJ5PigpO1xuICAgIGNvbnN0IHN1YmplY3RPYnNlcnZhYmxlID0gc3ViamVjdC5waXBlKFxuICAgICAgZmluYWxpemUoKCkgPT4ge1xuICAgICAgICAvLyBBcmUgdGhlcmUgYW55IG90aGVyIHRyYWNraW5nIGVudHJpZXMgc3RpbGwgd2F0Y2hpbmcgdGhpcyBlbGVtZW50P1xuICAgICAgICBjb25zdCBjaGVja1RyYWNraW5nID0gdGhpcy5fdHJhY2tpbmcuZmluZEluZGV4KCh2YWx1ZSkgPT4ge1xuICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICB2YWx1ZS5zdWJqZWN0ICE9PSBzdWJqZWN0ICYmXG4gICAgICAgICAgICAhdmFsdWUuc3ViamVjdC5jbG9zZWQgJiZcbiAgICAgICAgICAgIHZhbHVlLmVsZW1lbnQgPT09IGVsZW1lbnQubmF0aXZlRWxlbWVudFxuICAgICAgICAgICk7XG4gICAgICAgIH0pO1xuICAgICAgICBpZiAoY2hlY2tUcmFja2luZyA9PT0gLTEpIHtcbiAgICAgICAgICB0aGlzLl9yZXNpemVPYnNlcnZlci51bm9ic2VydmUoZWxlbWVudC5uYXRpdmVFbGVtZW50KTtcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICApO1xuICAgIGNvbnN0IHRyYWNraW5nID0ge1xuICAgICAgZWxlbWVudDogZWxlbWVudC5uYXRpdmVFbGVtZW50LFxuICAgICAgc3ViamVjdCxcbiAgICAgIHN1YmplY3RPYnNlcnZhYmxlLFxuICAgIH07XG4gICAgdGhpcy5fdHJhY2tpbmcucHVzaCh0cmFja2luZyk7XG4gICAgcmV0dXJuIHRyYWNraW5nO1xuICB9XG5cbiAgcHJpdmF0ZSBjYWxsYmFjayhlbnRyeTogUmVzaXplT2JzZXJ2ZXJFbnRyeSkge1xuICAgIHRoaXMuX3RyYWNraW5nXG4gICAgICAuZmlsdGVyKCh2YWx1ZSkgPT4gISh2YWx1ZS5zdWJqZWN0LmNsb3NlZCB8fCB2YWx1ZS5zdWJqZWN0LmlzU3RvcHBlZCkpXG4gICAgICAuZm9yRWFjaCgodmFsdWUpID0+IHtcbiAgICAgICAgLyogaXN0YW5idWwgaWdub3JlIGVsc2UgKi9cbiAgICAgICAgaWYgKHZhbHVlLmVsZW1lbnQgPT09IGVudHJ5LnRhcmdldCkge1xuICAgICAgICAgIHRoaXMuem9uZS5ydW4oKCkgPT4ge1xuICAgICAgICAgICAgdmFsdWUuc3ViamVjdC5uZXh0KGVudHJ5KTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gIH1cbn1cbiJdfQ==