@covalent/core 6.3.0 → 7.0.0

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 (269) hide show
  1. package/breadcrumbs/breadcrumbs.component.d.ts +1 -1
  2. package/dialogs/window-dialog/window-dialog.component.d.ts +1 -1
  3. package/dynamic-menu/dynamic-menu-item/dynamic-menu-item.component.d.ts +1 -1
  4. package/dynamic-menu/dynamic-menu-item/dynamic-menu-link/dynamic-menu-link.component.d.ts +1 -1
  5. package/dynamic-menu/dynamic-menu.component.d.ts +1 -1
  6. package/esm2022/breadcrumbs/breadcrumb/breadcrumb.component.mjs +94 -0
  7. package/esm2022/breadcrumbs/breadcrumbs.component.mjs +135 -0
  8. package/{esm2020 → esm2022}/breadcrumbs/breadcrumbs.module.mjs +5 -5
  9. package/esm2022/common/behaviors/control-value-accesor.mixin.mjs +43 -0
  10. package/esm2022/common/behaviors/disable-ripple.mixin.mjs +24 -0
  11. package/{esm2020 → esm2022}/common/behaviors/disabled.mixin.mjs +2 -2
  12. package/{esm2020 → esm2022}/common/common.module.mjs +17 -17
  13. package/esm2022/common/directives/fullscreen/fullscreen.directive.mjs +87 -0
  14. package/esm2022/common/forms/auto-trim/auto-trim.directive.mjs +37 -0
  15. package/esm2022/common/functions/convert.mjs +84 -0
  16. package/esm2022/common/functions/download.mjs +75 -0
  17. package/esm2022/common/pipes/bytes/bytes.pipe.mjs +42 -0
  18. package/esm2022/common/pipes/decimal-bytes/decimal-bytes.pipe.mjs +42 -0
  19. package/esm2022/common/pipes/digits/digits.pipe.mjs +41 -0
  20. package/{esm2020 → esm2022}/common/pipes/time-ago/time-ago.pipe.mjs +4 -4
  21. package/{esm2020 → esm2022}/common/pipes/time-difference/time-difference.pipe.mjs +4 -4
  22. package/{esm2020 → esm2022}/common/pipes/time-until/time-until.pipe.mjs +4 -4
  23. package/esm2022/common/pipes/truncate/truncate.pipe.mjs +27 -0
  24. package/esm2022/common/services/icon.service.mjs +1087 -0
  25. package/esm2022/common/services/router-path.service.mjs +30 -0
  26. package/esm2022/dialogs/alert-dialog/alert-dialog.component.mjs +26 -0
  27. package/esm2022/dialogs/confirm-dialog/confirm-dialog.component.mjs +31 -0
  28. package/esm2022/dialogs/dialog.component.mjs +60 -0
  29. package/{esm2020 → esm2022}/dialogs/dialogs.module.mjs +39 -39
  30. package/esm2022/dialogs/prompt-dialog/prompt-dialog.component.mjs +84 -0
  31. package/esm2022/dialogs/resizable-draggable-dialog/resizable-draggable-dialog.mjs +220 -0
  32. package/esm2022/dialogs/services/dialog.service.mjs +179 -0
  33. package/esm2022/dialogs/window-dialog/window-dialog.component.mjs +40 -0
  34. package/esm2022/dynamic-menu/dynamic-menu-item/dynamic-menu-item.component.mjs +30 -0
  35. package/esm2022/dynamic-menu/dynamic-menu-item/dynamic-menu-link/dynamic-menu-link.component.mjs +23 -0
  36. package/esm2022/dynamic-menu/dynamic-menu.component.mjs +28 -0
  37. package/{esm2020 → esm2022}/dynamic-menu/dynamic-menu.module.mjs +19 -19
  38. package/esm2022/file/directives/file-drop.directive.mjs +145 -0
  39. package/esm2022/file/directives/file-select.directive.mjs +78 -0
  40. package/esm2022/file/file-input/file-input.component.mjs +146 -0
  41. package/esm2022/file/file-upload/file-upload.component.mjs +185 -0
  42. package/{esm2020 → esm2022}/file/file.module.mjs +21 -21
  43. package/esm2022/file/services/file.service.mjs +66 -0
  44. package/esm2022/json-formatter/json-formatter.component.mjs +222 -0
  45. package/{esm2020 → esm2022}/json-formatter/json-formatter.module.mjs +5 -5
  46. package/esm2022/layout/layout-card-over/layout-card-over.component.mjs +50 -0
  47. package/esm2022/layout/layout-footer/layout-footer.component.mjs +36 -0
  48. package/esm2022/layout/layout-manage-list/layout-manage-list.component.mjs +92 -0
  49. package/{esm2020 → esm2022}/layout/layout-manage-list/layout-manage-list.directives.mjs +10 -10
  50. package/esm2022/layout/layout-nav/layout-nav.component.mjs +76 -0
  51. package/esm2022/layout/layout-nav-list/layout-nav-list.component.mjs +154 -0
  52. package/{esm2020 → esm2022}/layout/layout-nav-list/layout-nav-list.directives.mjs +10 -10
  53. package/esm2022/layout/layout-toggle.class.mjs +96 -0
  54. package/esm2022/layout/layout.component.mjs +91 -0
  55. package/{esm2020 → esm2022}/layout/layout.directives.mjs +10 -10
  56. package/{esm2020 → esm2022}/layout/layout.module.mjs +55 -55
  57. package/esm2022/layout/navigation-drawer/navigation-drawer.component.mjs +221 -0
  58. package/esm2022/loading/directives/loading.directive.mjs +133 -0
  59. package/esm2022/loading/loading.component.mjs +193 -0
  60. package/{esm2020 → esm2022}/loading/loading.module.mjs +13 -13
  61. package/esm2022/loading/services/loading.factory.mjs +210 -0
  62. package/esm2022/loading/services/loading.service.mjs +219 -0
  63. package/{esm2020 → esm2022}/menu/menu.component.mjs +4 -4
  64. package/{esm2020 → esm2022}/menu/menu.module.mjs +5 -5
  65. package/esm2022/message/message.component.mjs +222 -0
  66. package/{esm2020 → esm2022}/message/message.module.mjs +7 -7
  67. package/esm2022/search/search-box/search-box.component.mjs +198 -0
  68. package/esm2022/search/search-input/search-input.component.mjs +214 -0
  69. package/{esm2020 → esm2022}/search/search.module.mjs +13 -13
  70. package/esm2022/side-sheet/side-sheet-container.mjs +285 -0
  71. package/esm2022/side-sheet/side-sheet-ref.mjs +30 -0
  72. package/{esm2020 → esm2022}/side-sheet/side-sheet.config.mjs +2 -5
  73. package/esm2022/side-sheet/side-sheet.content-directives.mjs +206 -0
  74. package/esm2022/side-sheet/side-sheet.mjs +236 -0
  75. package/{esm2020 → esm2022}/side-sheet/side-sheet.module.mjs +14 -14
  76. package/esm2022/user-profile/user-profile-menu/user-profile-menu.component.mjs +25 -0
  77. package/esm2022/user-profile/user-profile.component.mjs +21 -0
  78. package/{esm2020 → esm2022}/user-profile/user-profile.module.mjs +15 -15
  79. package/{fesm2015 → fesm2022}/covalent-core-breadcrumbs.mjs +28 -22
  80. package/{fesm2015 → fesm2022}/covalent-core-breadcrumbs.mjs.map +1 -1
  81. package/{fesm2020 → fesm2022}/covalent-core-common.mjs +1131 -1125
  82. package/fesm2022/covalent-core-common.mjs.map +1 -0
  83. package/{fesm2020 → fesm2022}/covalent-core-dialogs.mjs +109 -80
  84. package/{fesm2020 → fesm2022}/covalent-core-dialogs.mjs.map +1 -1
  85. package/fesm2022/covalent-core-dynamic-menu.mjs +125 -0
  86. package/{fesm2015 → fesm2022}/covalent-core-dynamic-menu.mjs.map +1 -1
  87. package/{fesm2020 → fesm2022}/covalent-core-file.mjs +148 -110
  88. package/{fesm2020 → fesm2022}/covalent-core-file.mjs.map +1 -1
  89. package/{fesm2020 → fesm2022}/covalent-core-json-formatter.mjs +26 -21
  90. package/{fesm2020 → fesm2022}/covalent-core-json-formatter.mjs.map +1 -1
  91. package/{fesm2020 → fesm2022}/covalent-core-layout.mjs +396 -271
  92. package/{fesm2015 → fesm2022}/covalent-core-layout.mjs.map +1 -1
  93. package/{fesm2020 → fesm2022}/covalent-core-loading.mjs +100 -78
  94. package/{fesm2020 → fesm2022}/covalent-core-loading.mjs.map +1 -1
  95. package/{fesm2015 → fesm2022}/covalent-core-menu.mjs +7 -7
  96. package/{fesm2015 → fesm2022}/covalent-core-menu.mjs.map +1 -1
  97. package/{fesm2020 → fesm2022}/covalent-core-message.mjs +42 -23
  98. package/{fesm2020 → fesm2022}/covalent-core-message.mjs.map +1 -1
  99. package/fesm2022/covalent-core-search.mjs +438 -0
  100. package/fesm2022/covalent-core-search.mjs.map +1 -0
  101. package/{fesm2020 → fesm2022}/covalent-core-side-sheet.mjs +124 -99
  102. package/{fesm2020 → fesm2022}/covalent-core-side-sheet.mjs.map +1 -1
  103. package/fesm2022/covalent-core-user-profile.mjs +87 -0
  104. package/fesm2022/covalent-core-user-profile.mjs.map +1 -0
  105. package/file/directives/file-drop.directive.d.ts +1 -1
  106. package/file/directives/file-select.directive.d.ts +1 -1
  107. package/file/file-input/file-input.component.d.ts +1 -1
  108. package/file/file-upload/file-upload.component.d.ts +1 -1
  109. package/json-formatter/json-formatter.component.d.ts +1 -1
  110. package/layout/layout-card-over/layout-card-over.component.d.ts +1 -1
  111. package/layout/layout-footer/layout-footer.component.d.ts +1 -1
  112. package/layout/layout-manage-list/layout-manage-list.component.d.ts +1 -1
  113. package/layout/layout-manage-list/layout-manage-list.directives.d.ts +3 -3
  114. package/layout/layout-nav/layout-nav.component.d.ts +1 -1
  115. package/layout/layout-nav-list/layout-nav-list.component.d.ts +1 -1
  116. package/layout/layout-nav-list/layout-nav-list.directives.d.ts +3 -3
  117. package/layout/layout-toggle.class.d.ts +1 -1
  118. package/layout/layout.component.d.ts +1 -1
  119. package/layout/layout.directives.d.ts +3 -3
  120. package/layout/navigation-drawer/navigation-drawer.component.d.ts +1 -1
  121. package/loading/directives/loading.directive.d.ts +1 -1
  122. package/message/message.component.d.ts +1 -1
  123. package/package.json +55 -91
  124. package/search/search-box/search-box.component.d.ts +1 -1
  125. package/search/search-input/search-input.component.d.ts +1 -1
  126. package/side-sheet/side-sheet.content-directives.d.ts +2 -2
  127. package/user-profile/user-profile-menu/user-profile-menu.component.d.ts +1 -1
  128. package/user-profile/user-profile.component.d.ts +1 -1
  129. package/common/styles/font/README.md +0 -11
  130. package/dialogs/src/README.md +0 -223
  131. package/esm2020/breadcrumbs/breadcrumb/breadcrumb.component.mjs +0 -92
  132. package/esm2020/breadcrumbs/breadcrumbs.component.mjs +0 -131
  133. package/esm2020/common/behaviors/control-value-accesor.mixin.mjs +0 -41
  134. package/esm2020/common/behaviors/disable-ripple.mixin.mjs +0 -24
  135. package/esm2020/common/directives/fullscreen/fullscreen.directive.mjs +0 -85
  136. package/esm2020/common/forms/auto-trim/auto-trim.directive.mjs +0 -36
  137. package/esm2020/common/functions/convert.mjs +0 -84
  138. package/esm2020/common/functions/download.mjs +0 -75
  139. package/esm2020/common/pipes/bytes/bytes.pipe.mjs +0 -42
  140. package/esm2020/common/pipes/decimal-bytes/decimal-bytes.pipe.mjs +0 -42
  141. package/esm2020/common/pipes/digits/digits.pipe.mjs +0 -39
  142. package/esm2020/common/pipes/truncate/truncate.pipe.mjs +0 -27
  143. package/esm2020/common/services/icon.service.mjs +0 -1089
  144. package/esm2020/common/services/router-path.service.mjs +0 -29
  145. package/esm2020/dialogs/alert-dialog/alert-dialog.component.mjs +0 -23
  146. package/esm2020/dialogs/confirm-dialog/confirm-dialog.component.mjs +0 -28
  147. package/esm2020/dialogs/dialog.component.mjs +0 -57
  148. package/esm2020/dialogs/prompt-dialog/prompt-dialog.component.mjs +0 -75
  149. package/esm2020/dialogs/resizable-draggable-dialog/resizable-draggable-dialog.mjs +0 -216
  150. package/esm2020/dialogs/services/dialog.service.mjs +0 -174
  151. package/esm2020/dialogs/window-dialog/window-dialog.component.mjs +0 -38
  152. package/esm2020/dynamic-menu/dynamic-menu-item/dynamic-menu-item.component.mjs +0 -30
  153. package/esm2020/dynamic-menu/dynamic-menu-item/dynamic-menu-link/dynamic-menu-link.component.mjs +0 -24
  154. package/esm2020/dynamic-menu/dynamic-menu.component.mjs +0 -28
  155. package/esm2020/file/directives/file-drop.directive.mjs +0 -139
  156. package/esm2020/file/directives/file-select.directive.mjs +0 -77
  157. package/esm2020/file/file-input/file-input.component.mjs +0 -128
  158. package/esm2020/file/file-upload/file-upload.component.mjs +0 -174
  159. package/esm2020/file/services/file.service.mjs +0 -64
  160. package/esm2020/json-formatter/json-formatter.component.mjs +0 -217
  161. package/esm2020/layout/layout-card-over/layout-card-over.component.mjs +0 -40
  162. package/esm2020/layout/layout-footer/layout-footer.component.mjs +0 -33
  163. package/esm2020/layout/layout-manage-list/layout-manage-list.component.mjs +0 -93
  164. package/esm2020/layout/layout-nav/layout-nav.component.mjs +0 -50
  165. package/esm2020/layout/layout-nav-list/layout-nav-list.component.mjs +0 -128
  166. package/esm2020/layout/layout-toggle.class.mjs +0 -92
  167. package/esm2020/layout/layout.component.mjs +0 -92
  168. package/esm2020/layout/navigation-drawer/navigation-drawer.component.mjs +0 -163
  169. package/esm2020/loading/directives/loading.directive.mjs +0 -126
  170. package/esm2020/loading/loading.component.mjs +0 -187
  171. package/esm2020/loading/services/loading.factory.mjs +0 -207
  172. package/esm2020/loading/services/loading.service.mjs +0 -213
  173. package/esm2020/message/message.component.mjs +0 -203
  174. package/esm2020/search/search-box/search-box.component.mjs +0 -194
  175. package/esm2020/search/search-input/search-input.component.mjs +0 -207
  176. package/esm2020/side-sheet/side-sheet-container.mjs +0 -274
  177. package/esm2020/side-sheet/side-sheet-ref.mjs +0 -26
  178. package/esm2020/side-sheet/side-sheet.content-directives.mjs +0 -201
  179. package/esm2020/side-sheet/side-sheet.mjs +0 -228
  180. package/esm2020/user-profile/user-profile-menu/user-profile-menu.component.mjs +0 -23
  181. package/esm2020/user-profile/user-profile.component.mjs +0 -19
  182. package/fesm2015/covalent-core-common.mjs +0 -2281
  183. package/fesm2015/covalent-core-common.mjs.map +0 -1
  184. package/fesm2015/covalent-core-dialogs.mjs +0 -668
  185. package/fesm2015/covalent-core-dialogs.mjs.map +0 -1
  186. package/fesm2015/covalent-core-dynamic-menu.mjs +0 -126
  187. package/fesm2015/covalent-core-file.mjs +0 -621
  188. package/fesm2015/covalent-core-file.mjs.map +0 -1
  189. package/fesm2015/covalent-core-json-formatter.mjs +0 -298
  190. package/fesm2015/covalent-core-json-formatter.mjs.map +0 -1
  191. package/fesm2015/covalent-core-layout.mjs +0 -1024
  192. package/fesm2015/covalent-core-loading.mjs +0 -766
  193. package/fesm2015/covalent-core-loading.mjs.map +0 -1
  194. package/fesm2015/covalent-core-message.mjs +0 -284
  195. package/fesm2015/covalent-core-message.mjs.map +0 -1
  196. package/fesm2015/covalent-core-search.mjs +0 -430
  197. package/fesm2015/covalent-core-search.mjs.map +0 -1
  198. package/fesm2015/covalent-core-side-sheet.mjs +0 -784
  199. package/fesm2015/covalent-core-side-sheet.mjs.map +0 -1
  200. package/fesm2015/covalent-core-user-profile.mjs +0 -83
  201. package/fesm2015/covalent-core-user-profile.mjs.map +0 -1
  202. package/fesm2020/covalent-core-breadcrumbs.mjs +0 -243
  203. package/fesm2020/covalent-core-breadcrumbs.mjs.map +0 -1
  204. package/fesm2020/covalent-core-common.mjs.map +0 -1
  205. package/fesm2020/covalent-core-dynamic-menu.mjs +0 -126
  206. package/fesm2020/covalent-core-dynamic-menu.mjs.map +0 -1
  207. package/fesm2020/covalent-core-layout.mjs.map +0 -1
  208. package/fesm2020/covalent-core-menu.mjs +0 -37
  209. package/fesm2020/covalent-core-menu.mjs.map +0 -1
  210. package/fesm2020/covalent-core-search.mjs +0 -427
  211. package/fesm2020/covalent-core-search.mjs.map +0 -1
  212. package/fesm2020/covalent-core-user-profile.mjs +0 -83
  213. package/fesm2020/covalent-core-user-profile.mjs.map +0 -1
  214. package/fesm2020/covalent-core.mjs +0 -4
  215. package/fesm2020/covalent-core.mjs.map +0 -1
  216. package/file/src/file-input/README.md +0 -147
  217. package/file/src/file-upload/README.md +0 -136
  218. package/layout/src/layout-card-over/README.md +0 -43
  219. package/layout/src/layout-manage-list/README.md +0 -80
  220. package/layout/src/layout-nav/README.md +0 -50
  221. package/layout/src/layout-nav-list/README.md +0 -105
  222. package/search/src/search-box/README.md +0 -73
  223. package/search/src/search-input/README.md +0 -74
  224. /package/{esm2020 → esm2022}/breadcrumbs/covalent-core-breadcrumbs.mjs +0 -0
  225. /package/{esm2020 → esm2022}/breadcrumbs/public_api.mjs +0 -0
  226. /package/{esm2020 → esm2022}/common/animations/bounce/bounce.animation.mjs +0 -0
  227. /package/{esm2020 → esm2022}/common/animations/collapse/collapse.animation.mjs +0 -0
  228. /package/{esm2020 → esm2022}/common/animations/common/interfaces.mjs +0 -0
  229. /package/{esm2020 → esm2022}/common/animations/fade/fadeInOut.animation.mjs +0 -0
  230. /package/{esm2020 → esm2022}/common/animations/flash/flash.animation.mjs +0 -0
  231. /package/{esm2020 → esm2022}/common/animations/headshake/headshake.animation.mjs +0 -0
  232. /package/{esm2020 → esm2022}/common/animations/jello/jello.animation.mjs +0 -0
  233. /package/{esm2020 → esm2022}/common/animations/pulse/pulse.animation.mjs +0 -0
  234. /package/{esm2020 → esm2022}/common/animations/rotate/rotate.animation.mjs +0 -0
  235. /package/{esm2020 → esm2022}/common/covalent-core-common.mjs +0 -0
  236. /package/{esm2020 → esm2022}/common/forms/validators/validators.mjs +0 -0
  237. /package/{esm2020 → esm2022}/common/functions/clipboard.mjs +0 -0
  238. /package/{esm2020 → esm2022}/common/functions/file.mjs +0 -0
  239. /package/{esm2020 → esm2022}/common/public_api.mjs +0 -0
  240. /package/{esm2020 → esm2022}/covalent-core.mjs +0 -0
  241. /package/{esm2020 → esm2022}/dialogs/covalent-core-dialogs.mjs +0 -0
  242. /package/{esm2020 → esm2022}/dialogs/public_api.mjs +0 -0
  243. /package/{esm2020 → esm2022}/dynamic-menu/covalent-core-dynamic-menu.mjs +0 -0
  244. /package/{esm2020 → esm2022}/dynamic-menu/dynamic-menu.menu.mjs +0 -0
  245. /package/{esm2020 → esm2022}/dynamic-menu/public_api.mjs +0 -0
  246. /package/{esm2020 → esm2022}/file/covalent-core-file.mjs +0 -0
  247. /package/{esm2020 → esm2022}/file/public_api.mjs +0 -0
  248. /package/{esm2020 → esm2022}/json-formatter/collapse.animation.mjs +0 -0
  249. /package/{esm2020 → esm2022}/json-formatter/covalent-core-json-formatter.mjs +0 -0
  250. /package/{esm2020 → esm2022}/json-formatter/public_api.mjs +0 -0
  251. /package/{esm2020 → esm2022}/layout/covalent-core-layout.mjs +0 -0
  252. /package/{esm2020 → esm2022}/layout/public_api.mjs +0 -0
  253. /package/{esm2020 → esm2022}/loading/covalent-core-loading.mjs +0 -0
  254. /package/{esm2020 → esm2022}/loading/public_api.mjs +0 -0
  255. /package/{esm2020 → esm2022}/menu/covalent-core-menu.mjs +0 -0
  256. /package/{esm2020 → esm2022}/menu/public_api.mjs +0 -0
  257. /package/{esm2020 → esm2022}/message/collapse.animation.mjs +0 -0
  258. /package/{esm2020 → esm2022}/message/covalent-core-message.mjs +0 -0
  259. /package/{esm2020 → esm2022}/message/public_api.mjs +0 -0
  260. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  261. /package/{esm2020 → esm2022}/search/covalent-core-search.mjs +0 -0
  262. /package/{esm2020 → esm2022}/search/public_api.mjs +0 -0
  263. /package/{esm2020 → esm2022}/side-sheet/covalent-core-side-sheet.mjs +0 -0
  264. /package/{esm2020 → esm2022}/side-sheet/public_api.mjs +0 -0
  265. /package/{esm2020 → esm2022}/side-sheet/side-sheet.animation.mjs +0 -0
  266. /package/{esm2020 → esm2022}/user-profile/covalent-core-user-profile.mjs +0 -0
  267. /package/{esm2020 → esm2022}/user-profile/public_api.mjs +0 -0
  268. /package/{fesm2015 → fesm2022}/covalent-core.mjs +0 -0
  269. /package/{fesm2015 → fesm2022}/covalent-core.mjs.map +0 -0
@@ -1,126 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import { ViewContainerRef, TemplateRef } from '@angular/core';
3
- import { LoadingType, LoadingMode, LoadingStrategy, } from '../loading.component';
4
- import { TdLoadingService } from '../services/loading.service';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "../services/loading.service";
7
- /**
8
- * Context class for variable reference
9
- */
10
- export class TdLoadingContext {
11
- constructor() {
12
- this.$implicit = undefined;
13
- this.tdLoading = undefined;
14
- }
15
- }
16
- // Constant for generation of the id for the next component
17
- let TD_LOADING_NEXT_ID = 0;
18
- export class TdLoadingDirective {
19
- /**
20
- * tdLoadingUntil?: any
21
- * If its null, undefined or false it will be used to register requests to the mask.
22
- * Else if its any value that can be resolved as true, it will resolve the mask.
23
- * [name] is optional when using [until], but can still be used to register/resolve it manually.
24
- */
25
- set until(until) {
26
- if (!this.name) {
27
- this.name = 'td-loading-until-' + TD_LOADING_NEXT_ID++;
28
- }
29
- this._context.$implicit = this._context.tdLoading = until;
30
- if (!until) {
31
- this._loadingService.register(this.name);
32
- }
33
- else {
34
- this._loadingService.resolveAll(this.name);
35
- }
36
- }
37
- constructor(_viewContainerRef, _templateRef, _loadingService) {
38
- this._viewContainerRef = _viewContainerRef;
39
- this._templateRef = _templateRef;
40
- this._loadingService = _loadingService;
41
- this._context = new TdLoadingContext();
42
- /**
43
- * tdLoadingType?: LoadingType or ['linear' | 'circular']
44
- * Sets the type of loading mask depending on value.
45
- * Defaults to [LoadingType.Circular | 'circular'].
46
- */
47
- this.type = LoadingType.Circular;
48
- /**
49
- * tdLoadingMode?: LoadingMode or ['determinate' | 'indeterminate']
50
- * Sets the mode of loading mask depending on value.
51
- * Defaults to [LoadingMode.Indeterminate | 'indeterminate'].
52
- */
53
- this.mode = LoadingMode.Indeterminate;
54
- /**
55
- * tdLoadingStrategy?: LoadingStrategy or ['replace' | 'overlay']
56
- * Sets the strategy of loading mask depending on value.
57
- * Defaults to [LoadingMode.Replace | 'replace'].
58
- */
59
- this.strategy = LoadingStrategy.Replace;
60
- /**
61
- * tdLoadingColor?: "primary" | "accent" | "warn"
62
- * Sets the theme color of the loading component. Defaults to "primary"
63
- */
64
- this.color = 'primary';
65
- }
66
- /**
67
- * Registers component in the DOM, so it will be available when calling resolve/register.
68
- */
69
- ngOnInit() {
70
- this._registerComponent();
71
- }
72
- /**
73
- * Remove component when directive is destroyed.
74
- */
75
- ngOnDestroy() {
76
- this._loadingService.removeComponent(this.name);
77
- this._loadingRef = undefined;
78
- }
79
- /**
80
- * Creates [TdLoadingComponent] and attaches it to this directive's [ViewContainerRef].
81
- * Passes this directive's [TemplateRef] to modify DOM depending on loading `strategy`.
82
- */
83
- _registerComponent() {
84
- if (!this.name) {
85
- throw new Error('Name is needed to register loading directive');
86
- }
87
- // Check if `TdLoadingComponent` has been created before trying to add one again.
88
- // There is a weird edge case when using `[routerLinkActive]` that calls the `ngOnInit` twice in a row
89
- if (!this._loadingRef) {
90
- this._loadingRef = this._loadingService.createComponent({
91
- name: this.name,
92
- type: this.type,
93
- mode: this.mode,
94
- color: this.color,
95
- strategy: this.strategy,
96
- }, this._viewContainerRef, this._templateRef, this._context);
97
- }
98
- }
99
- }
100
- TdLoadingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i1.TdLoadingService }], target: i0.ɵɵFactoryTarget.Directive });
101
- TdLoadingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: TdLoadingDirective, selector: "[tdLoading]", inputs: { name: ["tdLoading", "name"], until: ["tdLoadingUntil", "until"], type: ["tdLoadingType", "type"], mode: ["tdLoadingMode", "mode"], strategy: ["tdLoadingStrategy", "strategy"], color: ["tdLoadingColor", "color"] }, ngImport: i0 });
102
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingDirective, decorators: [{
103
- type: Directive,
104
- args: [{
105
- selector: '[tdLoading]',
106
- }]
107
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i1.TdLoadingService }]; }, propDecorators: { name: [{
108
- type: Input,
109
- args: ['tdLoading']
110
- }], until: [{
111
- type: Input,
112
- args: ['tdLoadingUntil']
113
- }], type: [{
114
- type: Input,
115
- args: ['tdLoadingType']
116
- }], mode: [{
117
- type: Input,
118
- args: ['tdLoadingMode']
119
- }], strategy: [{
120
- type: Input,
121
- args: ['tdLoadingStrategy']
122
- }], color: [{
123
- type: Input,
124
- args: ['tdLoadingColor']
125
- }] } });
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular/loading/src/directives/loading.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, OnDestroy } from '@angular/core';\nimport { ViewContainerRef, TemplateRef } from '@angular/core';\n\nimport {\n  LoadingType,\n  LoadingMode,\n  LoadingStrategy,\n} from '../loading.component';\nimport { TdLoadingService } from '../services/loading.service';\nimport { ILoadingRef } from '../services/loading.factory';\n\n/**\n * Context class for variable reference\n */\nexport class TdLoadingContext {\n  public $implicit: any = undefined;\n  public tdLoading: any = undefined;\n}\n\n// Constant for generation of the id for the next component\nlet TD_LOADING_NEXT_ID = 0;\n\n@Directive({\n  selector: '[tdLoading]',\n})\nexport class TdLoadingDirective implements OnInit, OnDestroy {\n  private _context: TdLoadingContext = new TdLoadingContext();\n  private _loadingRef?: ILoadingRef;\n\n  /**\n   * tdLoading: string\n   * Name reference of the loading mask, used to register/resolve requests to the mask.\n   */\n  @Input('tdLoading')\n  name!: string;\n\n  /**\n   * tdLoadingUntil?: any\n   * If its null, undefined or false it will be used to register requests to the mask.\n   * Else if its any value that can be resolved as true, it will resolve the mask.\n   * [name] is optional when using [until], but can still be used to register/resolve it manually.\n   */\n  @Input('tdLoadingUntil')\n  set until(until: any) {\n    if (!this.name) {\n      this.name = 'td-loading-until-' + TD_LOADING_NEXT_ID++;\n    }\n    this._context.$implicit = this._context.tdLoading = until;\n    if (!until) {\n      this._loadingService.register(this.name);\n    } else {\n      this._loadingService.resolveAll(this.name);\n    }\n  }\n\n  /**\n   * tdLoadingType?: LoadingType or ['linear' | 'circular']\n   * Sets the type of loading mask depending on value.\n   * Defaults to [LoadingType.Circular | 'circular'].\n   */\n  @Input('tdLoadingType')\n  type: LoadingType = LoadingType.Circular;\n\n  /**\n   * tdLoadingMode?: LoadingMode or ['determinate' | 'indeterminate']\n   * Sets the mode of loading mask depending on value.\n   * Defaults to [LoadingMode.Indeterminate | 'indeterminate'].\n   */\n  @Input('tdLoadingMode') mode: LoadingMode = LoadingMode.Indeterminate;\n\n  /**\n   * tdLoadingStrategy?: LoadingStrategy or ['replace' | 'overlay']\n   * Sets the strategy of loading mask depending on value.\n   * Defaults to [LoadingMode.Replace | 'replace'].\n   */\n  @Input('tdLoadingStrategy')\n  strategy: LoadingStrategy.Overlay | LoadingStrategy.Replace =\n    LoadingStrategy.Replace;\n\n  /**\n   * tdLoadingColor?: \"primary\" | \"accent\" | \"warn\"\n   * Sets the theme color of the loading component. Defaults to \"primary\"\n   */\n  @Input('tdLoadingColor') color: 'primary' | 'accent' | 'warn' = 'primary';\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _templateRef: TemplateRef<TdLoadingContext>,\n    private _loadingService: TdLoadingService\n  ) {}\n\n  /**\n   * Registers component in the DOM, so it will be available when calling resolve/register.\n   */\n  ngOnInit(): void {\n    this._registerComponent();\n  }\n\n  /**\n   * Remove component when directive is destroyed.\n   */\n  ngOnDestroy(): void {\n    this._loadingService.removeComponent(this.name);\n    this._loadingRef = undefined;\n  }\n\n  /**\n   * Creates [TdLoadingComponent] and attaches it to this directive's [ViewContainerRef].\n   * Passes this directive's [TemplateRef] to modify DOM depending on loading `strategy`.\n   */\n  private _registerComponent(): void {\n    if (!this.name) {\n      throw new Error('Name is needed to register loading directive');\n    }\n    // Check if `TdLoadingComponent` has been created before trying to add one again.\n    // There is a weird edge case when using `[routerLinkActive]` that calls the `ngOnInit` twice in a row\n    if (!this._loadingRef) {\n      this._loadingRef = this._loadingService.createComponent(\n        {\n          name: this.name,\n          type: this.type,\n          mode: this.mode,\n          color: this.color,\n          strategy: this.strategy,\n        },\n        this._viewContainerRef,\n        this._templateRef,\n        this._context\n      );\n    }\n  }\n}\n"]}
@@ -1,187 +0,0 @@
1
- import { Component, ChangeDetectorRef, ElementRef, } from '@angular/core';
2
- import { tdFadeInOutAnimation } from '@covalent/core/common';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "@angular/material/progress-bar";
6
- import * as i3 from "@angular/material/progress-spinner";
7
- import * as i4 from "@angular/cdk/portal";
8
- export var LoadingType;
9
- (function (LoadingType) {
10
- LoadingType["Circular"] = "circular";
11
- LoadingType["Linear"] = "linear";
12
- })(LoadingType || (LoadingType = {}));
13
- export var LoadingMode;
14
- (function (LoadingMode) {
15
- LoadingMode["Determinate"] = "determinate";
16
- LoadingMode["Indeterminate"] = "indeterminate";
17
- })(LoadingMode || (LoadingMode = {}));
18
- export var LoadingStrategy;
19
- (function (LoadingStrategy) {
20
- LoadingStrategy["Overlay"] = "overlay";
21
- LoadingStrategy["Replace"] = "replace";
22
- })(LoadingStrategy || (LoadingStrategy = {}));
23
- export var LoadingStyle;
24
- (function (LoadingStyle) {
25
- LoadingStyle["FullScreen"] = "fullscreen";
26
- LoadingStyle["Overlay"] = "overlay";
27
- LoadingStyle["None"] = "none";
28
- })(LoadingStyle || (LoadingStyle = {}));
29
- export const TD_CIRCLE_DIAMETER = 40;
30
- export class TdLoadingComponent {
31
- /**
32
- * Sets mode of [TdLoadingComponent] to LoadingMode.Determinate or LoadingMode.Indeterminate
33
- */
34
- set mode(mode) {
35
- this._defaultMode = mode;
36
- }
37
- get mode() {
38
- return this._mode;
39
- }
40
- /**
41
- * Sets value of [TdLoadingComponent] if mode is 'LoadingMode.Determinate'
42
- */
43
- set value(value) {
44
- this._value = value;
45
- // Check for changes for `OnPush` change detection
46
- this._changeDetectorRef.markForCheck();
47
- }
48
- get value() {
49
- return this._value;
50
- }
51
- constructor(_elementRef, _changeDetectorRef) {
52
- this._elementRef = _elementRef;
53
- this._changeDetectorRef = _changeDetectorRef;
54
- this._mode = LoadingMode.Indeterminate;
55
- this._defaultMode = LoadingMode.Indeterminate;
56
- this._value = 0;
57
- this._circleDiameter = TD_CIRCLE_DIAMETER;
58
- /**
59
- * Flag for animation
60
- */
61
- this.animation = false;
62
- this.style = LoadingStyle.None;
63
- /**
64
- * height: number
65
- * Sets height of [TdLoadingComponent].
66
- */
67
- this.height = 100;
68
- /**
69
- * type: LoadingType
70
- * Sets type of [TdLoadingComponent] rendered.
71
- */
72
- this.type = LoadingType.Circular;
73
- /**
74
- * color: primary' | 'accent' | 'warn'
75
- * Sets theme color of [TdLoadingComponent] rendered.
76
- */
77
- this.color = 'primary';
78
- }
79
- ngDoCheck() {
80
- // When overlay is used and the host width has a value greater than 1px
81
- // set the circle diameter when possible incase the loading component was rendered in a hidden state
82
- if (this.isOverlay() && this._hostHeight() > 1 && this.animation) {
83
- this._setCircleDiameter();
84
- this._changeDetectorRef.markForCheck();
85
- }
86
- }
87
- getHeight() {
88
- // Ignore height if style is `overlay` or `fullscreen`.
89
- // Add height if child elements have a height and style is `none`, else return default height.
90
- if (this.isOverlay() || this.isFullScreen()) {
91
- return undefined;
92
- }
93
- else {
94
- return this.height ? `${this.height}px` : '150px';
95
- }
96
- }
97
- getCircleDiameter() {
98
- return this._circleDiameter;
99
- }
100
- getCircleStrokeWidth() {
101
- // we calculate the stroke width by setting it as 10% of its diameter
102
- const strokeWidth = this.getCircleDiameter() / 10;
103
- return Math.abs(strokeWidth);
104
- }
105
- isCircular() {
106
- return this.type === LoadingType.Circular;
107
- }
108
- isLinear() {
109
- return this.type === LoadingType.Linear;
110
- }
111
- isFullScreen() {
112
- return this.style === LoadingStyle.FullScreen;
113
- }
114
- isOverlay() {
115
- return this.style === LoadingStyle.Overlay;
116
- }
117
- /**
118
- * Starts in animation and returns an observable for completition event.
119
- */
120
- show() {
121
- /* need to switch back to the selected mode, so we have saved it in another variable
122
- * and then recover it. (issue with protractor)
123
- */
124
- this._mode = this._defaultMode;
125
- // Set values before the animations starts
126
- this._setCircleDiameter();
127
- // Check for changes for `OnPush` change detection
128
- this.animation = true;
129
- this._changeDetectorRef.markForCheck();
130
- }
131
- /**
132
- * Starts out animation and returns an observable for completition event.
133
- */
134
- hide() {
135
- this.animation = false;
136
- /* need to switch back and forth from determinate/indeterminate so the setInterval()
137
- * inside mat-progress-spinner stops and protractor doesnt timeout waiting to sync.
138
- */
139
- this._mode = LoadingMode.Determinate;
140
- // Check for changes for `OnPush` change detection
141
- /* little hack to reset the loader value and animation before removing it from DOM
142
- * else, the loader will appear with prev value when its registered again
143
- * and will do an animation going prev value to 0.
144
- */
145
- this.value = 0;
146
- // Check for changes for `OnPush` change detection
147
- this._changeDetectorRef.markForCheck();
148
- }
149
- /**
150
- * Calculate the proper diameter for the circle and set it
151
- */
152
- _setCircleDiameter() {
153
- // we set a default diameter of 100 since this is the default in material
154
- let diameter = TD_CIRCLE_DIAMETER;
155
- // if height is provided, then we take that as diameter
156
- if (this.height) {
157
- diameter = this.height;
158
- // else if its not provided, then we take the host height
159
- }
160
- else if (this.height === undefined) {
161
- diameter = this._hostHeight();
162
- }
163
- // if the diameter is over TD_CIRCLE_DIAMETER, we set TD_CIRCLE_DIAMETER
164
- if (diameter <= TD_CIRCLE_DIAMETER) {
165
- this._circleDiameter = Math.floor(diameter);
166
- }
167
- else {
168
- this._circleDiameter = TD_CIRCLE_DIAMETER;
169
- }
170
- }
171
- /**
172
- * Returns the host height of the loading component
173
- */
174
- _hostHeight() {
175
- if (this._elementRef.nativeElement) {
176
- return (this._elementRef.nativeElement).getBoundingClientRect().height;
177
- }
178
- return 0;
179
- }
180
- }
181
- TdLoadingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
182
- TdLoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: TdLoadingComponent, selector: "td-loading", ngImport: i0, template: "<div\n class=\"td-loading-wrapper\"\n [style.min-height]=\"getHeight()\"\n [class.td-overlay-circular]=\"(isOverlay() || isFullScreen()) && !isLinear()\"\n [class.td-overlay]=\"isOverlay() || isFullScreen()\"\n [class.td-fullscreen]=\"isFullScreen()\"\n>\n <div\n [@tdFadeInOut]=\"animation\"\n [style.min-height]=\"getHeight()\"\n class=\"td-loading\"\n >\n <mat-progress-spinner\n *ngIf=\"isCircular()\"\n [mode]=\"mode\"\n [value]=\"value\"\n [color]=\"color\"\n [diameter]=\"getCircleDiameter()\"\n [strokeWidth]=\"getCircleStrokeWidth()\"\n ></mat-progress-spinner>\n <mat-progress-bar\n *ngIf=\"isLinear()\"\n [mode]=\"mode\"\n [value]=\"value\"\n [color]=\"color\"\n ></mat-progress-bar>\n </div>\n <ng-template [cdkPortalOutlet]=\"content\"></ng-template>\n</div>\n", styles: [".td-loading-wrapper{position:relative;display:block}.td-loading-wrapper.td-fullscreen{position:inherit}.td-loading-wrapper .td-loading{box-sizing:border-box;display:flex;flex-direction:row;align-items:center;align-content:center;max-width:100%;justify-content:center;flex:1}.td-loading-wrapper.td-overlay .td-loading{position:absolute;margin:0;top:0;left:0;right:0;z-index:1000}.td-loading-wrapper.td-overlay .td-loading mat-progress-bar{position:absolute;top:0;left:0;right:0}.td-loading-wrapper.td-overlay-circular .td-loading{bottom:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i3.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i4.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [tdFadeInOutAnimation] });
183
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingComponent, decorators: [{
184
- type: Component,
185
- args: [{ selector: 'td-loading', animations: [tdFadeInOutAnimation], template: "<div\n class=\"td-loading-wrapper\"\n [style.min-height]=\"getHeight()\"\n [class.td-overlay-circular]=\"(isOverlay() || isFullScreen()) && !isLinear()\"\n [class.td-overlay]=\"isOverlay() || isFullScreen()\"\n [class.td-fullscreen]=\"isFullScreen()\"\n>\n <div\n [@tdFadeInOut]=\"animation\"\n [style.min-height]=\"getHeight()\"\n class=\"td-loading\"\n >\n <mat-progress-spinner\n *ngIf=\"isCircular()\"\n [mode]=\"mode\"\n [value]=\"value\"\n [color]=\"color\"\n [diameter]=\"getCircleDiameter()\"\n [strokeWidth]=\"getCircleStrokeWidth()\"\n ></mat-progress-spinner>\n <mat-progress-bar\n *ngIf=\"isLinear()\"\n [mode]=\"mode\"\n [value]=\"value\"\n [color]=\"color\"\n ></mat-progress-bar>\n </div>\n <ng-template [cdkPortalOutlet]=\"content\"></ng-template>\n</div>\n", styles: [".td-loading-wrapper{position:relative;display:block}.td-loading-wrapper.td-fullscreen{position:inherit}.td-loading-wrapper .td-loading{box-sizing:border-box;display:flex;flex-direction:row;align-items:center;align-content:center;max-width:100%;justify-content:center;flex:1}.td-loading-wrapper.td-overlay .td-loading{position:absolute;margin:0;top:0;left:0;right:0;z-index:1000}.td-loading-wrapper.td-overlay .td-loading mat-progress-bar{position:absolute;top:0;left:0;right:0}.td-loading-wrapper.td-overlay-circular .td-loading{bottom:0}\n"] }]
186
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; } });
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.component.js","sourceRoot":"","sources":["../../../../../libs/angular/loading/src/loading.component.ts","../../../../../libs/angular/loading/src/loading.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EACjB,UAAU,GAEX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;;;;;;AAG7D,MAAM,CAAN,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,gCAAiB,CAAA;AACnB,CAAC,EAHW,WAAW,KAAX,WAAW,QAGtB;AAED,MAAM,CAAN,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,0CAA2B,CAAA;IAC3B,8CAA+B,CAAA;AACjC,CAAC,EAHW,WAAW,KAAX,WAAW,QAGtB;AAED,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,sCAAmB,CAAA;IACnB,sCAAmB,CAAA;AACrB,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AAED,MAAM,CAAN,IAAY,YAIX;AAJD,WAAY,YAAY;IACtB,yCAAyB,CAAA;IACzB,mCAAmB,CAAA;IACnB,6BAAa,CAAA;AACf,CAAC,EAJW,YAAY,KAAZ,YAAY,QAIvB;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,EAAE,CAAC;AAQrC,MAAM,OAAO,kBAAkB;IAgB7B;;OAEG;IACH,IAAI,IAAI,CAAC,IAAiB;QACxB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IACD,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;OAEG;IACH,IAAI,KAAK,CAAC,KAAa;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,kDAAkD;QAClD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAsBD,YACU,WAAuB,EACvB,kBAAqC;QADrC,gBAAW,GAAX,WAAW,CAAY;QACvB,uBAAkB,GAAlB,kBAAkB,CAAmB;QA3DvC,UAAK,GAAgB,WAAW,CAAC,aAAa,CAAC;QAC/C,iBAAY,GAAgB,WAAW,CAAC,aAAa,CAAC;QACtD,WAAM,GAAG,CAAC,CAAC;QACX,oBAAe,GAAW,kBAAkB,CAAC;QAErD;;WAEG;QACH,cAAS,GAAG,KAAK,CAAC;QA6BlB,UAAK,GAAiB,YAAY,CAAC,IAAI,CAAC;QAExC;;;WAGG;QACH,WAAM,GAAG,GAAG,CAAC;QAEb;;;WAGG;QACH,SAAI,GAAgB,WAAW,CAAC,QAAQ,CAAC;QAEzC;;;WAGG;QACH,UAAK,GAAkC,SAAS,CAAC;IAK9C,CAAC;IAEJ,SAAS;QACP,uEAAuE;QACvE,oGAAoG;QACpG,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;YAChE,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;SACxC;IACH,CAAC;IAED,SAAS;QACP,uDAAuD;QACvD,8FAA8F;QAC9F,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE;YAC3C,OAAO,SAAS,CAAC;SAClB;aAAM;YACL,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;SACnD;IACH,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,oBAAoB;QAClB,qEAAqE;QACrE,MAAM,WAAW,GAAW,IAAI,CAAC,iBAAiB,EAAE,GAAG,EAAE,CAAC;QAC1D,OAAO,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAC/B,CAAC;IAED,UAAU;QACR,OAAO,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC,QAAQ,CAAC;IAC5C,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC,MAAM,CAAC;IAC1C,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,UAAU,CAAC;IAChD,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,OAAO,CAAC;IAC7C,CAAC;IAED;;OAEG;IACH,IAAI;QACF;;WAEG;QACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC;QAC/B,0CAA0C;QAC1C,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,kDAAkD;QAClD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,IAAI;QACF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB;;WAEG;QACH,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC;QACrC,kDAAkD;QAClD;;;WAGG;QACH,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,kDAAkD;QAClD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED;;OAEG;IACK,kBAAkB;QACxB,yEAAyE;QACzE,IAAI,QAAQ,GAAW,kBAAkB,CAAC;QAC1C,uDAAuD;QACvD,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,yDAAyD;SAC1D;aAAM,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;YACpC,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;SAC/B;QACD,wEAAwE;QACxE,IAAI,QAAQ,IAAI,kBAAkB,EAAE;YAClC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;SAC7C;aAAM;YACL,IAAI,CAAC,eAAe,GAAG,kBAAkB,CAAC;SAC3C;IACH,CAAC;IAED;;OAEG;IACK,WAAW;QACjB,IAAiB,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;YAC/C,OAAqB,CACnB,IAAI,CAAC,WAAW,CAAC,aAAa,CAC9B,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;SACnC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;;+GA7KU,kBAAkB;mGAAlB,kBAAkB,kDCtC/B,u1BA6BA,6sCDOc,CAAC,oBAAoB,CAAC;2FAEvB,kBAAkB;kBAN9B,SAAS;+BACE,YAAY,cAGV,CAAC,oBAAoB,CAAC","sourcesContent":["import {\n  Component,\n  ChangeDetectorRef,\n  ElementRef,\n  DoCheck,\n} from '@angular/core';\nimport { tdFadeInOutAnimation } from '@covalent/core/common';\nimport { TemplatePortal } from '@angular/cdk/portal';\n\nexport enum LoadingType {\n  Circular = 'circular',\n  Linear = 'linear',\n}\n\nexport enum LoadingMode {\n  Determinate = 'determinate',\n  Indeterminate = 'indeterminate',\n}\n\nexport enum LoadingStrategy {\n  Overlay = 'overlay',\n  Replace = 'replace',\n}\n\nexport enum LoadingStyle {\n  FullScreen = 'fullscreen',\n  Overlay = 'overlay',\n  None = 'none',\n}\n\nexport const TD_CIRCLE_DIAMETER = 40;\n\n@Component({\n  selector: 'td-loading',\n  styleUrls: ['./loading.component.scss'],\n  templateUrl: './loading.component.html',\n  animations: [tdFadeInOutAnimation],\n})\nexport class TdLoadingComponent implements DoCheck {\n  private _mode: LoadingMode = LoadingMode.Indeterminate;\n  private _defaultMode: LoadingMode = LoadingMode.Indeterminate;\n  private _value = 0;\n  private _circleDiameter: number = TD_CIRCLE_DIAMETER;\n\n  /**\n   * Flag for animation\n   */\n  animation = false;\n\n  /**\n   * Content injected into loading component.\n   */\n  content!: TemplatePortal<any>;\n\n  /**\n   * Sets mode of [TdLoadingComponent] to LoadingMode.Determinate or LoadingMode.Indeterminate\n   */\n  set mode(mode: LoadingMode) {\n    this._defaultMode = mode;\n  }\n  get mode(): LoadingMode {\n    return this._mode;\n  }\n\n  /**\n   * Sets value of [TdLoadingComponent] if mode is 'LoadingMode.Determinate'\n   */\n  set value(value: number) {\n    this._value = value;\n    // Check for changes for `OnPush` change detection\n    this._changeDetectorRef.markForCheck();\n  }\n  get value(): number {\n    return this._value;\n  }\n\n  style: LoadingStyle = LoadingStyle.None;\n\n  /**\n   * height: number\n   * Sets height of [TdLoadingComponent].\n   */\n  height = 100;\n\n  /**\n   * type: LoadingType\n   * Sets type of [TdLoadingComponent] rendered.\n   */\n  type: LoadingType = LoadingType.Circular;\n\n  /**\n   * color: primary' | 'accent' | 'warn'\n   * Sets theme color of [TdLoadingComponent] rendered.\n   */\n  color: 'primary' | 'accent' | 'warn' = 'primary';\n\n  constructor(\n    private _elementRef: ElementRef,\n    private _changeDetectorRef: ChangeDetectorRef\n  ) {}\n\n  ngDoCheck(): void {\n    // When overlay is used and the host width has a value greater than 1px\n    // set the circle diameter when possible incase the loading component was rendered in a hidden state\n    if (this.isOverlay() && this._hostHeight() > 1 && this.animation) {\n      this._setCircleDiameter();\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  getHeight(): string | undefined {\n    // Ignore height if style is `overlay` or `fullscreen`.\n    // Add height if child elements have a height and style is `none`, else return default height.\n    if (this.isOverlay() || this.isFullScreen()) {\n      return undefined;\n    } else {\n      return this.height ? `${this.height}px` : '150px';\n    }\n  }\n\n  getCircleDiameter(): number {\n    return this._circleDiameter;\n  }\n\n  getCircleStrokeWidth(): number {\n    // we calculate the stroke width by setting it as 10% of its diameter\n    const strokeWidth: number = this.getCircleDiameter() / 10;\n    return Math.abs(strokeWidth);\n  }\n\n  isCircular(): boolean {\n    return this.type === LoadingType.Circular;\n  }\n\n  isLinear(): boolean {\n    return this.type === LoadingType.Linear;\n  }\n\n  isFullScreen(): boolean {\n    return this.style === LoadingStyle.FullScreen;\n  }\n\n  isOverlay(): boolean {\n    return this.style === LoadingStyle.Overlay;\n  }\n\n  /**\n   * Starts in animation and returns an observable for completition event.\n   */\n  show(): void {\n    /* need to switch back to the selected mode, so we have saved it in another variable\n     *  and then recover it. (issue with protractor)\n     */\n    this._mode = this._defaultMode;\n    // Set values before the animations starts\n    this._setCircleDiameter();\n    // Check for changes for `OnPush` change detection\n    this.animation = true;\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /**\n   * Starts out animation and returns an observable for completition event.\n   */\n  hide(): void {\n    this.animation = false;\n    /* need to switch back and forth from determinate/indeterminate so the setInterval()\n     * inside mat-progress-spinner stops and protractor doesnt timeout waiting to sync.\n     */\n    this._mode = LoadingMode.Determinate;\n    // Check for changes for `OnPush` change detection\n    /* little hack to reset the loader value and animation before removing it from DOM\n     * else, the loader will appear with prev value when its registered again\n     * and will do an animation going prev value to 0.\n     */\n    this.value = 0;\n    // Check for changes for `OnPush` change detection\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /**\n   * Calculate the proper diameter for the circle and set it\n   */\n  private _setCircleDiameter(): void {\n    // we set a default diameter of 100 since this is the default in material\n    let diameter: number = TD_CIRCLE_DIAMETER;\n    // if height is provided, then we take that as diameter\n    if (this.height) {\n      diameter = this.height;\n      // else if its not provided, then we take the host height\n    } else if (this.height === undefined) {\n      diameter = this._hostHeight();\n    }\n    // if the diameter is over TD_CIRCLE_DIAMETER, we set TD_CIRCLE_DIAMETER\n    if (diameter <= TD_CIRCLE_DIAMETER) {\n      this._circleDiameter = Math.floor(diameter);\n    } else {\n      this._circleDiameter = TD_CIRCLE_DIAMETER;\n    }\n  }\n\n  /**\n   * Returns the host height of the loading component\n   */\n  private _hostHeight(): number {\n    if (<HTMLElement>this._elementRef.nativeElement) {\n      return (<HTMLElement>(\n        this._elementRef.nativeElement\n      )).getBoundingClientRect().height;\n    }\n    return 0;\n  }\n}\n","<div\n  class=\"td-loading-wrapper\"\n  [style.min-height]=\"getHeight()\"\n  [class.td-overlay-circular]=\"(isOverlay() || isFullScreen()) && !isLinear()\"\n  [class.td-overlay]=\"isOverlay() || isFullScreen()\"\n  [class.td-fullscreen]=\"isFullScreen()\"\n>\n  <div\n    [@tdFadeInOut]=\"animation\"\n    [style.min-height]=\"getHeight()\"\n    class=\"td-loading\"\n  >\n    <mat-progress-spinner\n      *ngIf=\"isCircular()\"\n      [mode]=\"mode\"\n      [value]=\"value\"\n      [color]=\"color\"\n      [diameter]=\"getCircleDiameter()\"\n      [strokeWidth]=\"getCircleStrokeWidth()\"\n    ></mat-progress-spinner>\n    <mat-progress-bar\n      *ngIf=\"isLinear()\"\n      [mode]=\"mode\"\n      [value]=\"value\"\n      [color]=\"color\"\n    ></mat-progress-bar>\n  </div>\n  <ng-template [cdkPortalOutlet]=\"content\"></ng-template>\n</div>\n"]}
@@ -1,207 +0,0 @@
1
- import { Injectable, ComponentFactoryResolver, SkipSelf, Optional, } from '@angular/core';
2
- import { Injector, } from '@angular/core';
3
- import { TemplatePortal, ComponentPortal } from '@angular/cdk/portal';
4
- import { Overlay, OverlayConfig } from '@angular/cdk/overlay';
5
- import { Subject } from 'rxjs';
6
- import { distinctUntilChanged } from 'rxjs/operators';
7
- import { TdLoadingComponent, LoadingStyle } from '../loading.component';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/cdk/overlay";
10
- /**
11
- * NOTE: @internal usage only.
12
- */
13
- export class TdLoadingFactory {
14
- constructor(_componentFactoryResolver, _overlay, _injector) {
15
- this._componentFactoryResolver = _componentFactoryResolver;
16
- this._overlay = _overlay;
17
- this._injector = _injector;
18
- }
19
- /**
20
- * Uses material `Overlay` services to create a DOM element and attach the loading component
21
- * into it. Leveraging the state and configuration from it.
22
- *
23
- * Saves a reference in context to be called when registering/resolving the loading element.
24
- */
25
- createFullScreenComponent(options) {
26
- options.height = undefined;
27
- options.style = LoadingStyle.FullScreen;
28
- const loadingRef = this._initializeContext();
29
- let loading = false;
30
- let overlayRef;
31
- loadingRef.observable
32
- .pipe(distinctUntilChanged())
33
- .subscribe((registered) => {
34
- if (registered > 0 && !loading) {
35
- loading = true;
36
- overlayRef = this._createOverlay();
37
- loadingRef.componentRef = overlayRef.attach(new ComponentPortal(TdLoadingComponent));
38
- this._mapOptions(options, loadingRef.componentRef?.instance);
39
- loadingRef.componentRef?.instance.show();
40
- loadingRef.componentRef?.changeDetectorRef.detectChanges();
41
- }
42
- else if (registered <= 0 && loading) {
43
- loading = false;
44
- loadingRef.componentRef?.instance.hide();
45
- loadingRef.componentRef?.destroy();
46
- overlayRef.detach();
47
- overlayRef.dispose();
48
- }
49
- });
50
- return loadingRef;
51
- }
52
- /**
53
- * Creates a loading component dynamically and attaches it into the given viewContainerRef.
54
- * Leverages TemplatePortals from material to inject the template inside of it so it fits
55
- * perfectly when overlaying it.
56
- *
57
- * Saves a reference in context to be called when registering/resolving the loading element.
58
- */
59
- createOverlayComponent(options, viewContainerRef, templateRef) {
60
- options.height = undefined;
61
- options.style = LoadingStyle.Overlay;
62
- const loadingRef = this._createComponent(options);
63
- let loading = false;
64
- if (loadingRef.componentRef) {
65
- loadingRef.componentRef.instance.content = new TemplatePortal(templateRef, viewContainerRef);
66
- viewContainerRef.clear();
67
- viewContainerRef.insert(loadingRef.componentRef?.hostView, 0);
68
- }
69
- loadingRef.observable
70
- .pipe(distinctUntilChanged())
71
- .subscribe((registered) => {
72
- if (registered > 0 && !loading) {
73
- loading = true;
74
- loadingRef.componentRef?.instance.show();
75
- }
76
- else if (registered <= 0 && loading) {
77
- loading = false;
78
- loadingRef.componentRef?.instance.hide();
79
- }
80
- });
81
- return loadingRef;
82
- }
83
- /**
84
- * Creates a loading component dynamically and attaches it into the given viewContainerRef.
85
- * Replaces the template with the loading component depending if it was registered or resolved.
86
- *
87
- * Saves a reference in context to be called when registering/resolving the loading element.
88
- */
89
- createReplaceComponent(options, viewContainerRef, templateRef, context) {
90
- const nativeElement = (templateRef.elementRef.nativeElement);
91
- options.height = nativeElement.nextElementSibling
92
- ? nativeElement.nextElementSibling.scrollHeight
93
- : undefined;
94
- options.style = LoadingStyle.None;
95
- const loadingRef = this._createComponent(options);
96
- let loading = false;
97
- // passing context so when the template is attached, we can keep the reference of the variables
98
- const contentRef = viewContainerRef.createEmbeddedView(templateRef, context);
99
- loadingRef.observable
100
- .pipe(distinctUntilChanged())
101
- .subscribe((registered) => {
102
- if (registered > 0 && !loading && loadingRef.componentRef) {
103
- loading = true;
104
- // detach the content and attach the loader if loader is there
105
- const index = viewContainerRef.indexOf(loadingRef.componentRef.hostView);
106
- if (index < 0) {
107
- viewContainerRef.detach(viewContainerRef.indexOf(contentRef));
108
- viewContainerRef.insert(loadingRef.componentRef.hostView, 0);
109
- }
110
- loadingRef.componentRef?.instance.show();
111
- }
112
- else if (registered <= 0 && loading && loadingRef.componentRef) {
113
- loading = false;
114
- loadingRef.componentRef?.instance.hide();
115
- // detach loader and attach the content if content is there
116
- const index = viewContainerRef.indexOf(contentRef);
117
- if (index < 0) {
118
- viewContainerRef.detach(viewContainerRef.indexOf(loadingRef.componentRef.hostView));
119
- viewContainerRef.insert(contentRef, 0);
120
- }
121
- /**
122
- * Need to call "markForCheck" and "detectChanges" on attached template, so its detected by parent component when attached
123
- * with "OnPush" change detection
124
- */
125
- contentRef.detectChanges();
126
- contentRef.markForCheck();
127
- }
128
- });
129
- return loadingRef;
130
- }
131
- /**
132
- * Creates a fullscreen overlay for the loading usage.
133
- */
134
- _createOverlay() {
135
- const state = new OverlayConfig();
136
- state.hasBackdrop = false;
137
- state.positionStrategy = this._overlay
138
- .position()
139
- .global()
140
- .centerHorizontally()
141
- .centerVertically();
142
- return this._overlay.create(state);
143
- }
144
- /**
145
- * Creates a generic component dynamically waiting to be attached to a viewContainerRef.
146
- */
147
- _createComponent(options) {
148
- const compRef = this._initializeContext();
149
- compRef.componentRef = this._componentFactoryResolver
150
- .resolveComponentFactory(TdLoadingComponent)
151
- .create(this._injector);
152
- this._mapOptions(options, compRef.componentRef.instance);
153
- return compRef;
154
- }
155
- /**
156
- * Initialize context for loading component.
157
- */
158
- _initializeContext() {
159
- const subject = new Subject();
160
- return {
161
- observable: subject.asObservable(),
162
- subject,
163
- componentRef: undefined,
164
- times: 0,
165
- };
166
- }
167
- /**
168
- * Maps configuration to the loading component instance.
169
- */
170
- _mapOptions(options, instance) {
171
- if (options.style) {
172
- instance.style = options.style;
173
- }
174
- if (options.type !== undefined) {
175
- instance.type = options.type;
176
- }
177
- if (options.height !== undefined) {
178
- instance.height = options.height;
179
- }
180
- if (options.mode !== undefined) {
181
- instance.mode = options.mode;
182
- }
183
- if (options.color !== undefined) {
184
- instance.color = options.color;
185
- }
186
- }
187
- }
188
- TdLoadingFactory.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingFactory, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.Overlay }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
189
- TdLoadingFactory.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingFactory });
190
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdLoadingFactory, decorators: [{
191
- type: Injectable
192
- }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.Overlay }, { type: i0.Injector }]; } });
193
- export function LOADING_FACTORY_PROVIDER_FACTORY(parent, componentFactoryResolver, overlay, injector) {
194
- return (parent || new TdLoadingFactory(componentFactoryResolver, overlay, injector));
195
- }
196
- export const LOADING_FACTORY_PROVIDER = {
197
- // If there is already a service available, use that. Otherwise, provide a new one.
198
- provide: TdLoadingFactory,
199
- deps: [
200
- [new Optional(), new SkipSelf(), TdLoadingFactory],
201
- ComponentFactoryResolver,
202
- Overlay,
203
- Injector,
204
- ],
205
- useFactory: LOADING_FACTORY_PROVIDER_FACTORY,
206
- };
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.factory.js","sourceRoot":"","sources":["../../../../../../libs/angular/loading/src/services/loading.factory.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  ComponentFactoryResolver,\n  Provider,\n  SkipSelf,\n  Optional,\n  EmbeddedViewRef,\n} from '@angular/core';\nimport {\n  Injector,\n  ComponentRef,\n  ViewContainerRef,\n  TemplateRef,\n} from '@angular/core';\nimport { TemplatePortal, ComponentPortal } from '@angular/cdk/portal';\nimport { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\n\nimport { Observable, Subject } from 'rxjs';\nimport { distinctUntilChanged } from 'rxjs/operators';\n\nimport { TdLoadingContext } from '../directives/loading.directive';\nimport { TdLoadingComponent, LoadingStyle } from '../loading.component';\nimport { ITdLoadingConfig } from './loading.service';\n\nexport interface IInternalLoadingOptions extends ITdLoadingConfig {\n  height?: number;\n  style?: LoadingStyle;\n}\n\nexport interface ILoadingRef {\n  observable: Observable<any>;\n  componentRef?: ComponentRef<any>;\n  subject: Subject<any>;\n  times: number;\n}\n\n/**\n * NOTE: @internal usage only.\n */\n@Injectable()\nexport class TdLoadingFactory {\n  constructor(\n    private _componentFactoryResolver: ComponentFactoryResolver,\n    private _overlay: Overlay,\n    private _injector: Injector\n  ) {}\n\n  /**\n   * Uses material `Overlay` services to create a DOM element and attach the loading component\n   * into it. Leveraging the state and configuration from it.\n   *\n   * Saves a reference in context to be called when registering/resolving the loading element.\n   */\n  public createFullScreenComponent(options: ITdLoadingConfig): ILoadingRef {\n    (<IInternalLoadingOptions>options).height = undefined;\n    (<IInternalLoadingOptions>options).style = LoadingStyle.FullScreen;\n    const loadingRef: ILoadingRef = this._initializeContext();\n    let loading = false;\n    let overlayRef: OverlayRef;\n    loadingRef.observable\n      .pipe(distinctUntilChanged())\n      .subscribe((registered: number) => {\n        if (registered > 0 && !loading) {\n          loading = true;\n          overlayRef = this._createOverlay();\n          loadingRef.componentRef = overlayRef.attach(\n            new ComponentPortal(TdLoadingComponent)\n          );\n          this._mapOptions(options, loadingRef.componentRef?.instance);\n          loadingRef.componentRef?.instance.show();\n          loadingRef.componentRef?.changeDetectorRef.detectChanges();\n        } else if (registered <= 0 && loading) {\n          loading = false;\n          loadingRef.componentRef?.instance.hide();\n          loadingRef.componentRef?.destroy();\n          overlayRef.detach();\n          overlayRef.dispose();\n        }\n      });\n    return loadingRef;\n  }\n\n  /**\n   * Creates a loading component dynamically and attaches it into the given viewContainerRef.\n   * Leverages TemplatePortals from material to inject the template inside of it so it fits\n   * perfectly when overlaying it.\n   *\n   * Saves a reference in context to be called when registering/resolving the loading element.\n   */\n  public createOverlayComponent(\n    options: ITdLoadingConfig,\n    viewContainerRef: ViewContainerRef,\n    templateRef: TemplateRef<object>\n  ): ILoadingRef {\n    (<IInternalLoadingOptions>options).height = undefined;\n    (<IInternalLoadingOptions>options).style = LoadingStyle.Overlay;\n    const loadingRef: ILoadingRef = this._createComponent(options);\n    let loading = false;\n\n    if (loadingRef.componentRef) {\n      loadingRef.componentRef.instance.content = new TemplatePortal(\n        templateRef,\n        viewContainerRef\n      );\n      viewContainerRef.clear();\n      viewContainerRef.insert(loadingRef.componentRef?.hostView, 0);\n    }\n\n    loadingRef.observable\n      .pipe(distinctUntilChanged())\n      .subscribe((registered: number) => {\n        if (registered > 0 && !loading) {\n          loading = true;\n          loadingRef.componentRef?.instance.show();\n        } else if (registered <= 0 && loading) {\n          loading = false;\n          loadingRef.componentRef?.instance.hide();\n        }\n      });\n    return loadingRef;\n  }\n\n  /**\n   * Creates a loading component dynamically and attaches it into the given viewContainerRef.\n   * Replaces the template with the loading component depending if it was registered or resolved.\n   *\n   * Saves a reference in context to be called when registering/resolving the loading element.\n   */\n  public createReplaceComponent(\n    options: ITdLoadingConfig,\n    viewContainerRef: ViewContainerRef,\n    templateRef: TemplateRef<object>,\n    context: TdLoadingContext\n  ): ILoadingRef {\n    const nativeElement: HTMLElement = <HTMLElement>(\n      templateRef.elementRef.nativeElement\n    );\n    (<IInternalLoadingOptions>options).height = nativeElement.nextElementSibling\n      ? nativeElement.nextElementSibling.scrollHeight\n      : undefined;\n    (<IInternalLoadingOptions>options).style = LoadingStyle.None;\n    const loadingRef: ILoadingRef = this._createComponent(options);\n    let loading = false;\n    // passing context so when the template is attached, we can keep the reference of the variables\n    const contentRef: EmbeddedViewRef<object> =\n      viewContainerRef.createEmbeddedView(templateRef, context);\n    loadingRef.observable\n      .pipe(distinctUntilChanged())\n      .subscribe((registered: number) => {\n        if (registered > 0 && !loading && loadingRef.componentRef) {\n          loading = true;\n          // detach the content and attach the loader if loader is there\n          const index: number = viewContainerRef.indexOf(\n            loadingRef.componentRef.hostView\n          );\n          if (index < 0) {\n            viewContainerRef.detach(viewContainerRef.indexOf(contentRef));\n            viewContainerRef.insert(loadingRef.componentRef.hostView, 0);\n          }\n          loadingRef.componentRef?.instance.show();\n        } else if (registered <= 0 && loading && loadingRef.componentRef) {\n          loading = false;\n          loadingRef.componentRef?.instance.hide();\n          // detach loader and attach the content if content is there\n          const index: number = viewContainerRef.indexOf(contentRef);\n          if (index < 0) {\n            viewContainerRef.detach(\n              viewContainerRef.indexOf(loadingRef.componentRef.hostView)\n            );\n            viewContainerRef.insert(contentRef, 0);\n          }\n          /**\n           * Need to call \"markForCheck\" and \"detectChanges\" on attached template, so its detected by parent component when attached\n           * with \"OnPush\" change detection\n           */\n          contentRef.detectChanges();\n          contentRef.markForCheck();\n        }\n      });\n    return loadingRef;\n  }\n\n  /**\n   * Creates a fullscreen overlay for the loading usage.\n   */\n  private _createOverlay(): OverlayRef {\n    const state: OverlayConfig = new OverlayConfig();\n    state.hasBackdrop = false;\n    state.positionStrategy = this._overlay\n      .position()\n      .global()\n      .centerHorizontally()\n      .centerVertically();\n    return this._overlay.create(state);\n  }\n\n  /**\n   * Creates a generic component dynamically waiting to be attached to a viewContainerRef.\n   */\n  private _createComponent(options: IInternalLoadingOptions): ILoadingRef {\n    const compRef: ILoadingRef = this._initializeContext();\n    compRef.componentRef = this._componentFactoryResolver\n      .resolveComponentFactory(TdLoadingComponent)\n      .create(this._injector);\n    this._mapOptions(options, compRef.componentRef.instance);\n    return compRef;\n  }\n\n  /**\n   * Initialize context for loading component.\n   */\n  private _initializeContext(): ILoadingRef {\n    const subject: Subject<any> = new Subject<any>();\n    return {\n      observable: subject.asObservable(),\n      subject,\n      componentRef: undefined,\n      times: 0,\n    };\n  }\n\n  /**\n   * Maps configuration to the loading component instance.\n   */\n  private _mapOptions(\n    options: IInternalLoadingOptions,\n    instance: TdLoadingComponent\n  ): void {\n    if (options.style) {\n      instance.style = options.style;\n    }\n\n    if (options.type !== undefined) {\n      instance.type = options.type;\n    }\n    if (options.height !== undefined) {\n      instance.height = options.height;\n    }\n    if (options.mode !== undefined) {\n      instance.mode = options.mode;\n    }\n    if (options.color !== undefined) {\n      instance.color = options.color;\n    }\n  }\n}\n\nexport function LOADING_FACTORY_PROVIDER_FACTORY(\n  parent: TdLoadingFactory,\n  componentFactoryResolver: ComponentFactoryResolver,\n  overlay: Overlay,\n  injector: Injector\n): TdLoadingFactory {\n  return (\n    parent || new TdLoadingFactory(componentFactoryResolver, overlay, injector)\n  );\n}\n\nexport const LOADING_FACTORY_PROVIDER: Provider = {\n  // If there is already a service available, use that. Otherwise, provide a new one.\n  provide: TdLoadingFactory,\n  deps: [\n    [new Optional(), new SkipSelf(), TdLoadingFactory],\n    ComponentFactoryResolver,\n    Overlay,\n    Injector,\n  ],\n  useFactory: LOADING_FACTORY_PROVIDER_FACTORY,\n};\n"]}