@recursyve/nice-ui-kit.v2 15.0.0-beta.131 → 16.0.0-beta.134

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 (400) hide show
  1. package/esm2022/lib/animations/defaults.mjs +32 -0
  2. package/{esm2020 → esm2022}/lib/api/interceptors/transform-response.interceptor.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/components/alert/alert.component.mjs +4 -4
  4. package/{esm2020 → esm2022}/lib/components/alert/alert.module.mjs +9 -9
  5. package/{esm2020 → esm2022}/lib/components/alert/alert.service.mjs +4 -4
  6. package/esm2022/lib/components/assets-carousel/assets-carousel.component.mjs +283 -0
  7. package/{esm2020 → esm2022}/lib/components/assets-carousel/assets-carousel.module.mjs +19 -19
  8. package/{esm2020 → esm2022}/lib/components/assets-carousel/directives/assets-carousel-active-content.directive.mjs +4 -4
  9. package/esm2022/lib/components/async-typeahead/async-typeahead.component.mjs +451 -0
  10. package/{esm2020 → esm2022}/lib/components/async-typeahead/async-typeahead.module.mjs +21 -21
  11. package/{esm2020 → esm2022}/lib/components/async-typeahead/providers/async-typeahead.service.mjs +4 -4
  12. package/{esm2020 → esm2022}/lib/components/base-form/base-form.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/components/base-form/base-form.module.mjs +5 -5
  14. package/{esm2020 → esm2022}/lib/components/base-form/form-submit.directive.mjs +4 -4
  15. package/{esm2020 → esm2022}/lib/components/card/card.component.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/components/card/card.module.mjs +5 -5
  17. package/{esm2020 → esm2022}/lib/components/carousel/carousel.component.mjs +4 -4
  18. package/esm2022/lib/components/carousel/carousel.module.mjs +40 -0
  19. package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/picture-modal.component.mjs +4 -4
  20. package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/picture-modal.service.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/components/carousel/pipe/carousel-layout.pipe.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/components/collapsable/collapsable.component.mjs +4 -4
  23. package/{esm2020 → esm2022}/lib/components/collapsable/collapsable.module.mjs +7 -7
  24. package/{esm2020 → esm2022}/lib/components/date-range-picker/components/header/header.component.mjs +4 -4
  25. package/{esm2020 → esm2022}/lib/components/date-range-picker/components/range-preset/range-preset.component.mjs +4 -4
  26. package/esm2022/lib/components/date-range-picker/date-range-picker.component.mjs +95 -0
  27. package/{esm2020 → esm2022}/lib/components/date-range-picker/date-range-picker.module.mjs +21 -21
  28. package/{esm2020 → esm2022}/lib/components/date-range-picker/providers/date-range-picker.service.mjs +4 -4
  29. package/{esm2020 → esm2022}/lib/components/drawer/drawer.component.mjs +4 -4
  30. package/{esm2020 → esm2022}/lib/components/drawer/drawer.module.mjs +7 -7
  31. package/{esm2020 → esm2022}/lib/components/drawer/drawer.service.mjs +4 -4
  32. package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/export-bottom-sheet.component.mjs +4 -4
  33. package/esm2022/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +45 -0
  34. package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/providers/export-bottom-sheet.service.mjs +7 -7
  35. package/{esm2020 → esm2022}/lib/components/form-error/control-status.directive.mjs +4 -4
  36. package/esm2022/lib/components/form-error/form-error.component.mjs +53 -0
  37. package/{esm2020 → esm2022}/lib/components/form-error/form-error.module.mjs +5 -5
  38. package/esm2022/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +34 -0
  39. package/{esm2020 → esm2022}/lib/components/horizontal-stepper/horizontal-stepper.module.mjs +9 -9
  40. package/{esm2020 → esm2022}/lib/components/horizontal-stepper/step.component.mjs +6 -6
  41. package/esm2022/lib/components/image-cropper/image-cropper.component.mjs +1269 -0
  42. package/{esm2020 → esm2022}/lib/components/image-cropper/image-cropper.module.mjs +5 -5
  43. package/{esm2020 → esm2022}/lib/components/layout/layout.component.mjs +4 -4
  44. package/{esm2020 → esm2022}/lib/components/layout/layout.module.mjs +5 -5
  45. package/{esm2020 → esm2022}/lib/components/loading-spinner/loading-spinner.component.mjs +4 -4
  46. package/{esm2020 → esm2022}/lib/components/loading-spinner/loading-spinner.module.mjs +9 -9
  47. package/{esm2020 → esm2022}/lib/components/loading-spinner/loading.directive.mjs +4 -4
  48. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.component.mjs +4 -4
  49. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.directive.mjs +4 -4
  50. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.module.mjs +5 -5
  51. package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.service.mjs +4 -4
  52. package/{esm2020 → esm2022}/lib/components/lottie/lottie.component.mjs +4 -4
  53. package/{esm2020 → esm2022}/lib/components/lottie/lottie.module.mjs +5 -5
  54. package/{esm2020 → esm2022}/lib/components/navigation/components/hint-component-base.mjs +4 -4
  55. package/{esm2020 → esm2022}/lib/components/navigation/directives/show-hint.directive.mjs +4 -4
  56. package/esm2022/lib/components/navigation/horizontal/components/basic/basic.component.mjs +62 -0
  57. package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/branch/branch.component.mjs +7 -7
  58. package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/divider/divider.component.mjs +4 -4
  59. package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/spacer/spacer.component.mjs +4 -4
  60. package/esm2022/lib/components/navigation/horizontal/horizontal.component.mjs +50 -0
  61. package/esm2022/lib/components/navigation/navigation.component.mjs +83 -0
  62. package/esm2022/lib/components/navigation/navigation.module.mjs +108 -0
  63. package/{esm2020 → esm2022}/lib/components/navigation/navigation.service.mjs +4 -4
  64. package/{esm2020 → esm2022}/lib/components/navigation/pipes/should-hide.pipe.mjs +4 -4
  65. package/{esm2020 → esm2022}/lib/components/navigation/pipes/should-show-hint.pipe.mjs +4 -4
  66. package/esm2022/lib/components/navigation/pipes/translate-with-context.pipe.mjs +25 -0
  67. package/{esm2020 → esm2022}/lib/components/navigation/providers/hint.service.mjs +4 -4
  68. package/esm2022/lib/components/navigation/providers/translation-context.service.mjs +16 -0
  69. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/aside/aside.component.mjs +6 -6
  70. package/esm2022/lib/components/navigation/vertical/components/basic/basic.component.mjs +76 -0
  71. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/collapsable/collapsable.component.mjs +8 -8
  72. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/divider/divider.component.mjs +4 -4
  73. package/esm2022/lib/components/navigation/vertical/components/group/group.component.mjs +75 -0
  74. package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/spacer/spacer.component.mjs +4 -4
  75. package/esm2022/lib/components/navigation/vertical/vertical.component.mjs +599 -0
  76. package/esm2022/lib/components/search-bar/search-bar.component.mjs +76 -0
  77. package/{esm2020 → esm2022}/lib/components/search-bar/search-bar.module.mjs +13 -13
  78. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.component.mjs +4 -4
  79. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.directive.mjs +4 -4
  80. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.module.mjs +5 -5
  81. package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.service.mjs +4 -4
  82. package/{esm2020 → esm2022}/lib/components/toast/toast.component.mjs +4 -4
  83. package/{esm2020 → esm2022}/lib/components/toast/toast.module.mjs +5 -5
  84. package/{esm2020 → esm2022}/lib/components/toast/toast.service.mjs +4 -4
  85. package/esm2022/lib/components/toggle-button-group/toggle-button-group.component.mjs +134 -0
  86. package/{esm2020 → esm2022}/lib/components/toggle-button-group/toggle-button-group.module.mjs +7 -7
  87. package/{esm2020 → esm2022}/lib/components/toggle-button-group/toggle-button.component.mjs +4 -4
  88. package/esm2022/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +38 -0
  89. package/esm2022/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +26 -0
  90. package/{esm2020 → esm2022}/lib/components/translation-form/components/translation-form.component.mjs +4 -4
  91. package/{esm2020 → esm2022}/lib/components/translation-form/components/translation-form.module.mjs +19 -19
  92. package/{esm2020 → esm2022}/lib/components/translation-form/directives/translation-context.directive.mjs +4 -4
  93. package/{esm2020 → esm2022}/lib/components/translation-form/providers/nice-translation-form.service.mjs +4 -4
  94. package/{esm2020 → esm2022}/lib/components/translation-form/toggle/translation-toggle.component.mjs +4 -4
  95. package/{esm2020 → esm2022}/lib/components/translation-form/validators/require-for-languages.validator.mjs +4 -4
  96. package/{esm2020 → esm2022}/lib/components/typeahead/directives/options-scroll.directive.mjs +4 -4
  97. package/{esm2020 → esm2022}/lib/components/typeahead/directives/options-scroll.module.mjs +5 -5
  98. package/{esm2020 → esm2022}/lib/components/typeahead/typeahead.component.mjs +9 -9
  99. package/{esm2020 → esm2022}/lib/components/typeahead/typeahead.module.mjs +25 -25
  100. package/{esm2020 → esm2022}/lib/directives/autofocus/autofocus.directive.mjs +4 -4
  101. package/{esm2020 → esm2022}/lib/directives/autofocus/autofocus.module.mjs +5 -5
  102. package/{esm2020 → esm2022}/lib/directives/autogrow/autogrow.directive.mjs +4 -4
  103. package/{esm2020 → esm2022}/lib/directives/autogrow/autogrow.module.mjs +5 -5
  104. package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.mjs +4 -4
  105. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.mjs +4 -4
  106. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list-items/chip-list-items.component.mjs +4 -4
  107. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.directive.mjs +4 -4
  108. package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.module.mjs +5 -5
  109. package/{esm2020 → esm2022}/lib/directives/draggable-list/draggable-list.directive.mjs +4 -4
  110. package/{esm2020 → esm2022}/lib/directives/draggable-list/draggable-list.module.mjs +5 -5
  111. package/{esm2020 → esm2022}/lib/directives/dropzone/dropzone.directive.mjs +4 -4
  112. package/{esm2020 → esm2022}/lib/directives/dropzone/dropzone.module.mjs +5 -5
  113. package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/image-error-placeholder.directive.mjs +4 -4
  114. package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/image-error-placeholder.module.mjs +5 -5
  115. package/{esm2020 → esm2022}/lib/directives/material/material.module.mjs +7 -7
  116. package/{esm2020 → esm2022}/lib/directives/material/nice-material-style.directive.mjs +4 -4
  117. package/{esm2020 → esm2022}/lib/directives/material/nice-rounded-style.directive.mjs +4 -4
  118. package/{esm2020 → esm2022}/lib/directives/modals/modal-on-click.directive.mjs +4 -4
  119. package/{esm2020 → esm2022}/lib/directives/modals/modal-opener.directive.mjs +4 -4
  120. package/{esm2020 → esm2022}/lib/directives/rerender/rerender.directive.mjs +4 -4
  121. package/{esm2020 → esm2022}/lib/directives/resolve/resolve.directive.mjs +4 -4
  122. package/{esm2020 → esm2022}/lib/directives/scroll-reset/scroll-reset.directive.mjs +4 -4
  123. package/{esm2020 → esm2022}/lib/directives/scroll-reset/scroll-reset.module.mjs +5 -5
  124. package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.directive.mjs +4 -4
  125. package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.module.mjs +5 -5
  126. package/{esm2020 → esm2022}/lib/directives/stop-propagation/click-stop-propagation.directive.mjs +4 -4
  127. package/{esm2020 → esm2022}/lib/directives/stop-propagation/stop-propagation.module.mjs +5 -5
  128. package/{esm2020 → esm2022}/lib/directives/window/prevent-close-window.directive.mjs +4 -4
  129. package/{esm2020 → esm2022}/lib/directives/window/window-directive.module.mjs +5 -5
  130. package/esm2022/lib/nice.module.mjs +124 -0
  131. package/{esm2020 → esm2022}/lib/pipes/boolean.pipe.mjs +4 -4
  132. package/{esm2020 → esm2022}/lib/pipes/capitalize-first-letter.pipe.mjs +4 -4
  133. package/{esm2020 → esm2022}/lib/pipes/ceil.pipe.mjs +4 -4
  134. package/{esm2020 → esm2022}/lib/pipes/entries.pipe.mjs +4 -4
  135. package/{esm2020 → esm2022}/lib/pipes/find-by-key.pipe.mjs +4 -4
  136. package/{esm2020 → esm2022}/lib/pipes/first-letter.pipe.mjs +4 -4
  137. package/{esm2020 → esm2022}/lib/pipes/floor.pipe.mjs +4 -4
  138. package/{esm2020 → esm2022}/lib/pipes/join-if-defined.pipe.mjs +4 -4
  139. package/{esm2020 → esm2022}/lib/pipes/link.pipe.mjs +4 -4
  140. package/{esm2020 → esm2022}/lib/pipes/localized-boolean.pipe.mjs +4 -4
  141. package/{esm2020 → esm2022}/lib/pipes/localized-currency.pipe.mjs +4 -4
  142. package/{esm2020 → esm2022}/lib/pipes/localized-date-only.pipe.mjs +4 -4
  143. package/{esm2020 → esm2022}/lib/pipes/localized-date.pipe.mjs +4 -4
  144. package/{esm2020 → esm2022}/lib/pipes/minutes-to-time.pipe.mjs +4 -4
  145. package/{esm2020 → esm2022}/lib/pipes/number-to-ordinal-indicator.pipe.mjs +4 -4
  146. package/{esm2020 → esm2022}/lib/pipes/pad.pipe.mjs +4 -4
  147. package/{esm2020 → esm2022}/lib/pipes/phone.pipe.mjs +4 -4
  148. package/{esm2020 → esm2022}/lib/pipes/pipes.module.mjs +72 -72
  149. package/{esm2020 → esm2022}/lib/pipes/postal-code.pipe.mjs +4 -4
  150. package/{esm2020 → esm2022}/lib/pipes/range.pipe.mjs +4 -4
  151. package/{esm2020 → esm2022}/lib/pipes/round.pipe.mjs +4 -4
  152. package/{esm2020 → esm2022}/lib/pipes/sanitize-bypass.pipe.mjs +4 -4
  153. package/{esm2020 → esm2022}/lib/pipes/seconds-to-time.pipe.mjs +4 -4
  154. package/{esm2020 → esm2022}/lib/pipes/track-by-prop.pipe.mjs +4 -4
  155. package/{esm2020 → esm2022}/lib/providers/config/config.module.mjs +5 -5
  156. package/{esm2020 → esm2022}/lib/providers/config/config.service.mjs +4 -4
  157. package/{esm2020 → esm2022}/lib/providers/media-watcher/media-watcher.module.mjs +7 -7
  158. package/{esm2020 → esm2022}/lib/providers/media-watcher/media-watcher.service.mjs +4 -4
  159. package/{esm2020 → esm2022}/lib/providers/overlay/dynamic-overlay-container.service.mjs +4 -4
  160. package/{esm2020 → esm2022}/lib/providers/overlay/dynamic-overlay.service.mjs +4 -4
  161. package/{esm2020 → esm2022}/lib/providers/splash-screen/splash-screen.module.mjs +7 -7
  162. package/{esm2020 → esm2022}/lib/providers/splash-screen/splash-screen.service.mjs +4 -4
  163. package/{esm2020 → esm2022}/lib/providers/utils/utils.module.mjs +5 -5
  164. package/{esm2020 → esm2022}/lib/providers/utils/utils.service.mjs +4 -4
  165. package/esm2022/lib/utils/regex.utils.mjs +11 -0
  166. package/{fesm2020 → fesm2022}/recursyve-nice-ui-kit.v2.mjs +948 -905
  167. package/fesm2022/recursyve-nice-ui-kit.v2.mjs.map +1 -0
  168. package/lib/components/alert/alert.component.d.ts +1 -1
  169. package/lib/components/assets-carousel/assets-carousel.component.d.ts +1 -1
  170. package/lib/components/async-typeahead/async-typeahead.component.d.ts +1 -1
  171. package/lib/components/base-form/base-form.component.d.ts +1 -1
  172. package/lib/components/base-form/form-submit.directive.d.ts +1 -1
  173. package/lib/components/card/card.component.d.ts +1 -1
  174. package/lib/components/carousel/carousel.component.d.ts +1 -1
  175. package/lib/components/collapsable/collapsable.component.d.ts +1 -1
  176. package/lib/components/date-range-picker/date-range-picker.component.d.ts +1 -1
  177. package/lib/components/drawer/drawer.component.d.ts +1 -1
  178. package/lib/components/form-error/form-error.component.d.ts +1 -1
  179. package/lib/components/image-cropper/image-cropper.component.d.ts +2 -2
  180. package/lib/components/loading-spinner/loading-spinner.component.d.ts +1 -1
  181. package/lib/components/loading-spinner/loading.directive.d.ts +1 -1
  182. package/lib/components/loading-toast/loading-toast.component.d.ts +1 -1
  183. package/lib/components/loading-toast/loading-toast.directive.d.ts +1 -1
  184. package/lib/components/lottie/lottie.component.d.ts +1 -1
  185. package/lib/components/navigation/directives/show-hint.directive.d.ts +1 -1
  186. package/lib/components/navigation/horizontal/components/basic/basic.component.d.ts +1 -1
  187. package/lib/components/navigation/horizontal/components/branch/branch.component.d.ts +1 -1
  188. package/lib/components/navigation/horizontal/components/divider/divider.component.d.ts +1 -1
  189. package/lib/components/navigation/horizontal/components/spacer/spacer.component.d.ts +1 -1
  190. package/lib/components/navigation/horizontal/horizontal.component.d.ts +4 -2
  191. package/lib/components/navigation/navigation.component.d.ts +3 -1
  192. package/lib/components/navigation/navigation.module.d.ts +12 -11
  193. package/lib/components/navigation/pipes/translate-with-context.pipe.d.ts +12 -0
  194. package/lib/components/navigation/providers/translation-context.service.d.ts +8 -0
  195. package/lib/components/navigation/vertical/components/aside/aside.component.d.ts +1 -1
  196. package/lib/components/navigation/vertical/components/basic/basic.component.d.ts +1 -1
  197. package/lib/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +1 -1
  198. package/lib/components/navigation/vertical/components/divider/divider.component.d.ts +1 -1
  199. package/lib/components/navigation/vertical/components/group/group.component.d.ts +1 -1
  200. package/lib/components/navigation/vertical/components/spacer/spacer.component.d.ts +1 -1
  201. package/lib/components/navigation/vertical/vertical.component.d.ts +4 -2
  202. package/lib/components/search-bar/search-bar.component.d.ts +1 -1
  203. package/lib/components/sweet-alert/sweet-alert.directive.d.ts +1 -1
  204. package/lib/components/toggle-button-group/toggle-button-group.component.d.ts +1 -1
  205. package/lib/components/toggle-button-group/toggle-button.component.d.ts +1 -1
  206. package/lib/components/translation-form/components/textarea/translation-form-textarea.component.d.ts +1 -1
  207. package/lib/components/translation-form/components/translation-form.component.d.ts +1 -1
  208. package/lib/components/translation-form/validators/require-for-languages.validator.d.ts +1 -1
  209. package/lib/components/typeahead/directives/options-scroll.directive.d.ts +1 -1
  210. package/lib/components/typeahead/typeahead.component.d.ts +1 -1
  211. package/lib/directives/autogrow/autogrow.directive.d.ts +1 -1
  212. package/lib/directives/chip-list/chip-list-items/chip-list-items.component.d.ts +1 -1
  213. package/lib/directives/chip-list/chip-list.directive.d.ts +1 -1
  214. package/lib/directives/draggable-list/draggable-list.directive.d.ts +1 -1
  215. package/lib/directives/image-error-placeholder/image-error-placeholder.directive.d.ts +1 -1
  216. package/lib/directives/modals/modal-opener.directive.d.ts +1 -1
  217. package/lib/directives/rerender/rerender.directive.d.ts +1 -1
  218. package/lib/directives/resolve/resolve.directive.d.ts +1 -1
  219. package/lib/directives/scrollbar/scrollbar.directive.d.ts +1 -1
  220. package/package.json +12 -19
  221. package/esm2020/lib/animations/defaults.mjs +0 -32
  222. package/esm2020/lib/components/assets-carousel/assets-carousel.component.mjs +0 -283
  223. package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +0 -451
  224. package/esm2020/lib/components/carousel/carousel.module.mjs +0 -41
  225. package/esm2020/lib/components/date-range-picker/date-range-picker.component.mjs +0 -95
  226. package/esm2020/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +0 -45
  227. package/esm2020/lib/components/form-error/form-error.component.mjs +0 -53
  228. package/esm2020/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +0 -34
  229. package/esm2020/lib/components/image-cropper/image-cropper.component.mjs +0 -1269
  230. package/esm2020/lib/components/navigation/horizontal/components/basic/basic.component.mjs +0 -62
  231. package/esm2020/lib/components/navigation/horizontal/horizontal.component.mjs +0 -46
  232. package/esm2020/lib/components/navigation/navigation.component.mjs +0 -76
  233. package/esm2020/lib/components/navigation/navigation.module.mjs +0 -105
  234. package/esm2020/lib/components/navigation/vertical/components/basic/basic.component.mjs +0 -76
  235. package/esm2020/lib/components/navigation/vertical/components/group/group.component.mjs +0 -75
  236. package/esm2020/lib/components/navigation/vertical/vertical.component.mjs +0 -595
  237. package/esm2020/lib/components/search-bar/search-bar.component.mjs +0 -76
  238. package/esm2020/lib/components/toggle-button-group/toggle-button-group.component.mjs +0 -134
  239. package/esm2020/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +0 -38
  240. package/esm2020/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +0 -26
  241. package/esm2020/lib/nice.module.mjs +0 -124
  242. package/esm2020/lib/utils/regex.utils.mjs +0 -11
  243. package/fesm2015/recursyve-nice-ui-kit.v2.mjs +0 -11867
  244. package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +0 -1
  245. package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +0 -1
  246. /package/{esm2020 → esm2022}/lib/animations/expand-collapse.mjs +0 -0
  247. /package/{esm2020 → esm2022}/lib/animations/fade.mjs +0 -0
  248. /package/{esm2020 → esm2022}/lib/animations/index.mjs +0 -0
  249. /package/{esm2020 → esm2022}/lib/animations/public-api.mjs +0 -0
  250. /package/{esm2020 → esm2022}/lib/animations/shake.mjs +0 -0
  251. /package/{esm2020 → esm2022}/lib/animations/slide.mjs +0 -0
  252. /package/{esm2020 → esm2022}/lib/animations/zoom.mjs +0 -0
  253. /package/{esm2020 → esm2022}/lib/api/exceptions/api.exception.mjs +0 -0
  254. /package/{esm2020 → esm2022}/lib/api/exceptions/exception.factory.mjs +0 -0
  255. /package/{esm2020 → esm2022}/lib/api/index.mjs +0 -0
  256. /package/{esm2020 → esm2022}/lib/api/nice.api.mjs +0 -0
  257. /package/{esm2020 → esm2022}/lib/api/public-api.mjs +0 -0
  258. /package/{esm2020 → esm2022}/lib/components/alert/alert.types.mjs +0 -0
  259. /package/{esm2020 → esm2022}/lib/components/alert/index.mjs +0 -0
  260. /package/{esm2020 → esm2022}/lib/components/alert/public-api.mjs +0 -0
  261. /package/{esm2020 → esm2022}/lib/components/assets-carousel/assets-carousel.constant.mjs +0 -0
  262. /package/{esm2020 → esm2022}/lib/components/assets-carousel/index.mjs +0 -0
  263. /package/{esm2020 → esm2022}/lib/components/assets-carousel/public-api.mjs +0 -0
  264. /package/{esm2020 → esm2022}/lib/components/async-typeahead/async-typeahead.constant.mjs +0 -0
  265. /package/{esm2020 → esm2022}/lib/components/async-typeahead/index.mjs +0 -0
  266. /package/{esm2020 → esm2022}/lib/components/async-typeahead/providers/async-typeahead.provider.mjs +0 -0
  267. /package/{esm2020 → esm2022}/lib/components/async-typeahead/public-api.mjs +0 -0
  268. /package/{esm2020 → esm2022}/lib/components/base-form/index.mjs +0 -0
  269. /package/{esm2020 → esm2022}/lib/components/base-form/nice-base.form.mjs +0 -0
  270. /package/{esm2020 → esm2022}/lib/components/base-form/public-api.mjs +0 -0
  271. /package/{esm2020 → esm2022}/lib/components/card/card.types.mjs +0 -0
  272. /package/{esm2020 → esm2022}/lib/components/card/index.mjs +0 -0
  273. /package/{esm2020 → esm2022}/lib/components/card/public-api.mjs +0 -0
  274. /package/{esm2020 → esm2022}/lib/components/carousel/index.mjs +0 -0
  275. /package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/index.mjs +0 -0
  276. /package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/public-api.mjs +0 -0
  277. /package/{esm2020 → esm2022}/lib/components/carousel/public-api.mjs +0 -0
  278. /package/{esm2020 → esm2022}/lib/components/collapsable/index.mjs +0 -0
  279. /package/{esm2020 → esm2022}/lib/components/collapsable/public-api.mjs +0 -0
  280. /package/{esm2020 → esm2022}/lib/components/date-range-picker/index.mjs +0 -0
  281. /package/{esm2020 → esm2022}/lib/components/date-range-picker/public-api.mjs +0 -0
  282. /package/{esm2020 → esm2022}/lib/components/drawer/drawer.types.mjs +0 -0
  283. /package/{esm2020 → esm2022}/lib/components/drawer/index.mjs +0 -0
  284. /package/{esm2020 → esm2022}/lib/components/drawer/public-api.mjs +0 -0
  285. /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/index.mjs +0 -0
  286. /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/models/export-strategy.model.mjs +0 -0
  287. /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/public-api.mjs +0 -0
  288. /package/{esm2020 → esm2022}/lib/components/form-error/index.mjs +0 -0
  289. /package/{esm2020 → esm2022}/lib/components/form-error/public-api.mjs +0 -0
  290. /package/{esm2020 → esm2022}/lib/components/horizontal-stepper/index.mjs +0 -0
  291. /package/{esm2020 → esm2022}/lib/components/horizontal-stepper/public-api.mjs +0 -0
  292. /package/{esm2020 → esm2022}/lib/components/image-cropper/index.mjs +0 -0
  293. /package/{esm2020 → esm2022}/lib/components/image-cropper/public-api.mjs +0 -0
  294. /package/{esm2020 → esm2022}/lib/components/image-cropper/resize-canvas.mjs +0 -0
  295. /package/{esm2020 → esm2022}/lib/components/index.mjs +0 -0
  296. /package/{esm2020 → esm2022}/lib/components/layout/index.mjs +0 -0
  297. /package/{esm2020 → esm2022}/lib/components/layout/public-api.mjs +0 -0
  298. /package/{esm2020 → esm2022}/lib/components/loading-spinner/index.mjs +0 -0
  299. /package/{esm2020 → esm2022}/lib/components/loading-spinner/loading.constant.mjs +0 -0
  300. /package/{esm2020 → esm2022}/lib/components/loading-spinner/public-api.mjs +0 -0
  301. /package/{esm2020 → esm2022}/lib/components/loading-toast/index.mjs +0 -0
  302. /package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.constant.mjs +0 -0
  303. /package/{esm2020 → esm2022}/lib/components/loading-toast/public-api.mjs +0 -0
  304. /package/{esm2020 → esm2022}/lib/components/loading-toast/rxjs/show-loading-toast.operator.mjs +0 -0
  305. /package/{esm2020 → esm2022}/lib/components/lottie/index.mjs +0 -0
  306. /package/{esm2020 → esm2022}/lib/components/lottie/public-api.mjs +0 -0
  307. /package/{esm2020 → esm2022}/lib/components/navigation/index.mjs +0 -0
  308. /package/{esm2020 → esm2022}/lib/components/navigation/navigation.types.mjs +0 -0
  309. /package/{esm2020 → esm2022}/lib/components/navigation/providers/hide-item.resolver.mjs +0 -0
  310. /package/{esm2020 → esm2022}/lib/components/navigation/providers/hint.resolver.mjs +0 -0
  311. /package/{esm2020 → esm2022}/lib/components/navigation/public-api.mjs +0 -0
  312. /package/{esm2020 → esm2022}/lib/components/public-api.mjs +0 -0
  313. /package/{esm2020 → esm2022}/lib/components/search-bar/index.mjs +0 -0
  314. /package/{esm2020 → esm2022}/lib/components/search-bar/public-api.mjs +0 -0
  315. /package/{esm2020 → esm2022}/lib/components/sweet-alert/index.mjs +0 -0
  316. /package/{esm2020 → esm2022}/lib/components/sweet-alert/public-api.mjs +0 -0
  317. /package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.constant.mjs +0 -0
  318. /package/{esm2020 → esm2022}/lib/components/toast/index.mjs +0 -0
  319. /package/{esm2020 → esm2022}/lib/components/toast/public-api.mjs +0 -0
  320. /package/{esm2020 → esm2022}/lib/components/toast/rxjs/show-success-or-error-toast.operator.mjs +0 -0
  321. /package/{esm2020 → esm2022}/lib/components/toast/rxjs/show-toast.operator.mjs +0 -0
  322. /package/{esm2020 → esm2022}/lib/components/toast/toast.constant.mjs +0 -0
  323. /package/{esm2020 → esm2022}/lib/components/toggle-button-group/index.mjs +0 -0
  324. /package/{esm2020 → esm2022}/lib/components/toggle-button-group/public-api.mjs +0 -0
  325. /package/{esm2020 → esm2022}/lib/components/translation-form/decorators/translation-form-group.decorator.mjs +0 -0
  326. /package/{esm2020 → esm2022}/lib/components/translation-form/index.mjs +0 -0
  327. /package/{esm2020 → esm2022}/lib/components/translation-form/public-api.mjs +0 -0
  328. /package/{esm2020 → esm2022}/lib/components/translation-form/translation.form.mjs +0 -0
  329. /package/{esm2020 → esm2022}/lib/components/typeahead/index.mjs +0 -0
  330. /package/{esm2020 → esm2022}/lib/components/typeahead/public-api.mjs +0 -0
  331. /package/{esm2020 → esm2022}/lib/directives/autofocus/index.mjs +0 -0
  332. /package/{esm2020 → esm2022}/lib/directives/autofocus/public-api.mjs +0 -0
  333. /package/{esm2020 → esm2022}/lib/directives/autogrow/index.mjs +0 -0
  334. /package/{esm2020 → esm2022}/lib/directives/autogrow/public-api.mjs +0 -0
  335. /package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/index.mjs +0 -0
  336. /package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/public-api.mjs +0 -0
  337. /package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.constant.mjs +0 -0
  338. /package/{esm2020 → esm2022}/lib/directives/chip-list/index.mjs +0 -0
  339. /package/{esm2020 → esm2022}/lib/directives/chip-list/public-api.mjs +0 -0
  340. /package/{esm2020 → esm2022}/lib/directives/draggable-list/index.mjs +0 -0
  341. /package/{esm2020 → esm2022}/lib/directives/draggable-list/public-api.mjs +0 -0
  342. /package/{esm2020 → esm2022}/lib/directives/dropzone/index.mjs +0 -0
  343. /package/{esm2020 → esm2022}/lib/directives/dropzone/public-api.mjs +0 -0
  344. /package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/index.mjs +0 -0
  345. /package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/public-api.mjs +0 -0
  346. /package/{esm2020 → esm2022}/lib/directives/index.mjs +0 -0
  347. /package/{esm2020 → esm2022}/lib/directives/material/index.mjs +0 -0
  348. /package/{esm2020 → esm2022}/lib/directives/material/public-api.mjs +0 -0
  349. /package/{esm2020 → esm2022}/lib/directives/modals/index.mjs +0 -0
  350. /package/{esm2020 → esm2022}/lib/directives/modals/public-api.mjs +0 -0
  351. /package/{esm2020 → esm2022}/lib/directives/public-api.mjs +0 -0
  352. /package/{esm2020 → esm2022}/lib/directives/rerender/index.mjs +0 -0
  353. /package/{esm2020 → esm2022}/lib/directives/rerender/public-api.mjs +0 -0
  354. /package/{esm2020 → esm2022}/lib/directives/resolve/index.mjs +0 -0
  355. /package/{esm2020 → esm2022}/lib/directives/resolve/public-api.mjs +0 -0
  356. /package/{esm2020 → esm2022}/lib/directives/scroll-reset/index.mjs +0 -0
  357. /package/{esm2020 → esm2022}/lib/directives/scroll-reset/public-api.mjs +0 -0
  358. /package/{esm2020 → esm2022}/lib/directives/scrollbar/index.mjs +0 -0
  359. /package/{esm2020 → esm2022}/lib/directives/scrollbar/public-api.mjs +0 -0
  360. /package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.types.mjs +0 -0
  361. /package/{esm2020 → esm2022}/lib/directives/stop-propagation/index.mjs +0 -0
  362. /package/{esm2020 → esm2022}/lib/directives/stop-propagation/public-api.mjs +0 -0
  363. /package/{esm2020 → esm2022}/lib/directives/window/index.mjs +0 -0
  364. /package/{esm2020 → esm2022}/lib/directives/window/public-api.mjs +0 -0
  365. /package/{esm2020 → esm2022}/lib/pipes/index.mjs +0 -0
  366. /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
  367. /package/{esm2020 → esm2022}/lib/providers/config/config.constants.mjs +0 -0
  368. /package/{esm2020 → esm2022}/lib/providers/config/config.model.mjs +0 -0
  369. /package/{esm2020 → esm2022}/lib/providers/config/index.mjs +0 -0
  370. /package/{esm2020 → esm2022}/lib/providers/config/public-api.mjs +0 -0
  371. /package/{esm2020 → esm2022}/lib/providers/index.mjs +0 -0
  372. /package/{esm2020 → esm2022}/lib/providers/media-watcher/index.mjs +0 -0
  373. /package/{esm2020 → esm2022}/lib/providers/media-watcher/public-api.mjs +0 -0
  374. /package/{esm2020 → esm2022}/lib/providers/public-api.mjs +0 -0
  375. /package/{esm2020 → esm2022}/lib/providers/splash-screen/index.mjs +0 -0
  376. /package/{esm2020 → esm2022}/lib/providers/splash-screen/public-api.mjs +0 -0
  377. /package/{esm2020 → esm2022}/lib/providers/utils/index.mjs +0 -0
  378. /package/{esm2020 → esm2022}/lib/providers/utils/public-api.mjs +0 -0
  379. /package/{esm2020 → esm2022}/lib/types/constructor.mjs +0 -0
  380. /package/{esm2020 → esm2022}/lib/utils/array.utils.mjs +0 -0
  381. /package/{esm2020 → esm2022}/lib/utils/case.utils.mjs +0 -0
  382. /package/{esm2020 → esm2022}/lib/utils/colors.utils.mjs +0 -0
  383. /package/{esm2020 → esm2022}/lib/utils/date.utils.mjs +0 -0
  384. /package/{esm2020 → esm2022}/lib/utils/file.utils.mjs +0 -0
  385. /package/{esm2020 → esm2022}/lib/utils/font-awesome.utils.mjs +0 -0
  386. /package/{esm2020 → esm2022}/lib/utils/form-data.utils.mjs +0 -0
  387. /package/{esm2020 → esm2022}/lib/utils/http-status.utils.mjs +0 -0
  388. /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
  389. /package/{esm2020 → esm2022}/lib/utils/keyboard.utils.mjs +0 -0
  390. /package/{esm2020 → esm2022}/lib/utils/lexorank.utils.mjs +0 -0
  391. /package/{esm2020 → esm2022}/lib/utils/modal.utils.mjs +0 -0
  392. /package/{esm2020 → esm2022}/lib/utils/number.utils.mjs +0 -0
  393. /package/{esm2020 → esm2022}/lib/utils/object.utils.mjs +0 -0
  394. /package/{esm2020 → esm2022}/lib/utils/promise.utils.mjs +0 -0
  395. /package/{esm2020 → esm2022}/lib/utils/public-api.mjs +0 -0
  396. /package/{esm2020 → esm2022}/lib/utils/query-params.utils.mjs +0 -0
  397. /package/{esm2020 → esm2022}/lib/utils/type.utils.mjs +0 -0
  398. /package/{esm2020 → esm2022}/lib/utils/url.utils.mjs +0 -0
  399. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  400. /package/{esm2020 → esm2022}/recursyve-nice-ui-kit.v2.mjs +0 -0
@@ -0,0 +1,1269 @@
1
+ /**
2
+ * Adapted from https://github.com/A-l-y-l-e/Alyle-UI/tree/10.5.3/src/lib/image-cropper
3
+ */
4
+ import { normalizePassiveListenerOptions } from "@angular/cdk/platform";
5
+ import { ViewportRuler } from "@angular/cdk/scrolling";
6
+ import { DOCUMENT } from "@angular/common";
7
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, Inject, Input, NgZone, Output, Renderer2, ViewChild, ViewEncapsulation } from "@angular/core";
8
+ import { Observable, Subject } from "rxjs";
9
+ import { take, takeUntil } from "rxjs/operators";
10
+ import { resizeCanvas } from "./resize-canvas";
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/cdk/scrolling";
13
+ import * as i2 from "@angular/common";
14
+ import * as i3 from "@angular/material/button";
15
+ import * as i4 from "@angular/material/icon";
16
+ const activeEventOptions = normalizePassiveListenerOptions({ passive: false });
17
+ /** Image Cropper Config */
18
+ export class ImgCropperConfig {
19
+ constructor() {
20
+ /** Cropper area width */
21
+ this.width = 250;
22
+ /** Cropper area height */
23
+ this.height = 200;
24
+ this.minWidth = 40;
25
+ this.minHeight = 40;
26
+ /**
27
+ * Set anti-aliased (default: true)
28
+ * @deprecated this is not necessary as the cropper will automatically resize the image
29
+ * to the best quality
30
+ */
31
+ this.antiAliased = true;
32
+ this.output = ImgResolution.Default;
33
+ }
34
+ }
35
+ /** Image output */
36
+ export var ImgResolution;
37
+ (function (ImgResolution) {
38
+ /**
39
+ * The output image will be equal to the initial size of the cropper area.
40
+ */
41
+ ImgResolution[ImgResolution["Default"] = 0] = "Default";
42
+ /** Just crop the image without resizing */
43
+ ImgResolution[ImgResolution["OriginalImage"] = 1] = "OriginalImage";
44
+ })(ImgResolution || (ImgResolution = {}));
45
+ /** Image output */
46
+ export var ImgCropperError;
47
+ (function (ImgCropperError) {
48
+ /** The loaded image exceeds the size limit set. */
49
+ ImgCropperError[ImgCropperError["Size"] = 0] = "Size";
50
+ /** The file loaded is not image. */
51
+ ImgCropperError[ImgCropperError["Type"] = 1] = "Type";
52
+ /** When the image has not been loaded. */
53
+ ImgCropperError[ImgCropperError["Other"] = 2] = "Other";
54
+ })(ImgCropperError || (ImgCropperError = {}));
55
+ export class NiceImageCropperComponent {
56
+ static { this.и = "NiceImageCropper"; }
57
+ set config(val) {
58
+ this._config = mergeDeep({}, new ImgCropperConfig(), val);
59
+ this._configPrimary = mergeDeep({}, this._config);
60
+ this._primaryAreaWidth = this.config.width;
61
+ this._primaryAreaHeight = this.config.height;
62
+ if (this._config.round
63
+ && this.config.width !== this.config.height) {
64
+ throw new Error(`${NiceImageCropperComponent.и}: Both width and height must be equal when using \`ImgCropperConfig.round = true\``);
65
+ }
66
+ const maxFileSize = this._config.maxFileSize;
67
+ if (maxFileSize) {
68
+ this.maxFileSize = maxFileSize;
69
+ }
70
+ }
71
+ get config() {
72
+ return this._config;
73
+ }
74
+ /** Set scale */
75
+ set scale(val) {
76
+ this.setScale(val);
77
+ }
78
+ get scale() {
79
+ return this._scale;
80
+ }
81
+ /** Get min scale */
82
+ get minScale() {
83
+ return this._minScale;
84
+ }
85
+ constructor(_renderer, _elementRef, cd, _ngZone, _document, viewPortRuler) {
86
+ this._renderer = _renderer;
87
+ this._elementRef = _elementRef;
88
+ this.cd = cd;
89
+ this._ngZone = _ngZone;
90
+ this._imgRect = {};
91
+ this._rotation = 0;
92
+ this.scaleChange = new EventEmitter();
93
+ /** Emits minimum supported image scale */
94
+ // tslint:disable-next-line:no-output-rename
95
+ this.minScaleChange = new EventEmitter();
96
+ /** Emits maximum supported image scale */
97
+ // tslint:disable-next-line:no-output-rename
98
+ this.maxScaleChange = new EventEmitter();
99
+ /** Emits when the image is loaded */
100
+ this.imageLoaded = new EventEmitter();
101
+ /** Emits when the cropper is ready to be interacted */
102
+ this.ready = new EventEmitter();
103
+ /** On crop new image */
104
+ this.cropped = new EventEmitter();
105
+ /** Emits when the cropper is cleaned */
106
+ this.cleaned = new EventEmitter();
107
+ /** Emit an error when the loaded image is not valid */
108
+ // tslint:disable-next-line: no-output-native
109
+ this.error = new EventEmitter();
110
+ /** Emits whenever the component is destroyed. */
111
+ this._destroy = new Subject();
112
+ this._pointerDown = (event) => {
113
+ // Don't do anything if the
114
+ // user is using anything other than the main mouse button.
115
+ if (this._isSliding || (!isTouchEvent(event) && event.button !== 0)) {
116
+ return;
117
+ }
118
+ this._ngZone.run(() => {
119
+ this._isSliding = true;
120
+ this.offset = {
121
+ x: this._imgRect.x,
122
+ y: this._imgRect.y,
123
+ left: this._imgRect.xc,
124
+ top: this._imgRect.yc
125
+ };
126
+ this._lastPointerEvent = event;
127
+ this._startPointerEvent = getGesturePointFromEvent(event);
128
+ event.preventDefault();
129
+ this._bindGlobalEvents(event);
130
+ });
131
+ };
132
+ /**
133
+ * Called when the user has moved their pointer after
134
+ * starting to drag.
135
+ */
136
+ this._pointerMove = (event) => {
137
+ if (this._isSliding) {
138
+ event.preventDefault();
139
+ this._lastPointerEvent = event;
140
+ let x;
141
+ let y;
142
+ const canvas = this._imgCanvas.nativeElement;
143
+ const scaleFix = this._scal3Fix;
144
+ const config = this.config;
145
+ const startP = this.offset;
146
+ const point = getGesturePointFromEvent(event);
147
+ const deltaX = point.x - this._startPointerEvent.x;
148
+ const deltaY = point.y - this._startPointerEvent.y;
149
+ if (!scaleFix || !startP) {
150
+ return;
151
+ }
152
+ const isMinScaleY = canvas.height * scaleFix < config.height && config.extraZoomOut;
153
+ const isMinScaleX = canvas.width * scaleFix < config.width && config.extraZoomOut;
154
+ const limitLeft = (config.width / 2 / scaleFix) >= startP.left - (deltaX / scaleFix);
155
+ const limitRight = (config.width / 2 / scaleFix) +
156
+ (canvas.width) - (startP.left - (deltaX / scaleFix)) <= config.width / scaleFix;
157
+ const limitTop = ((config.height / 2 / scaleFix) >= (startP.top - (deltaY / scaleFix)));
158
+ const limitBottom = (((config.height / 2 / scaleFix) + (canvas.height) - (startP.top - (deltaY / scaleFix))) <= (config.height / scaleFix));
159
+ // Limit for left
160
+ if ((limitLeft && !isMinScaleX) || (!limitLeft && isMinScaleX)) {
161
+ x = startP.x + (startP.left) - (config.width / 2 / scaleFix);
162
+ }
163
+ // Limit for right
164
+ if ((limitRight && !isMinScaleX) || (!limitRight && isMinScaleX)) {
165
+ x = startP.x + (startP.left) + (config.width / 2 / scaleFix) - canvas.width;
166
+ }
167
+ // Limit for top
168
+ if ((limitTop && !isMinScaleY) || (!limitTop && isMinScaleY)) {
169
+ y = startP.y + (startP.top) - (config.height / 2 / scaleFix);
170
+ }
171
+ // Limit for bottom
172
+ if ((limitBottom && !isMinScaleY) || (!limitBottom && isMinScaleY)) {
173
+ y = startP.y + (startP.top) + (config.height / 2 / scaleFix) - canvas.height;
174
+ }
175
+ // When press shiftKey, deprecated
176
+ // if (event.srcEvent && event.srcEvent.shiftKey) {
177
+ // if (Math.abs(event.deltaX) === Math.max(Math.abs(event.deltaX), Math.abs(event.deltaY))) {
178
+ // y = this.offset.top;
179
+ // } else {
180
+ // x = this.offset.left;
181
+ // }
182
+ // }
183
+ if (x === void 0) {
184
+ x = (deltaX / scaleFix) + (startP.x);
185
+ }
186
+ if (y === void 0) {
187
+ y = (deltaY / scaleFix) + (startP.y);
188
+ }
189
+ this._setStylesForContImg({
190
+ x, y
191
+ });
192
+ }
193
+ };
194
+ /** Called when the user has lifted their pointer. */
195
+ this._pointerUp = (event) => {
196
+ if (this._isSliding) {
197
+ event.preventDefault();
198
+ this._removeGlobalEvents();
199
+ this._isSliding = false;
200
+ this._startPointerEvent = null;
201
+ this._cropIfAutoCrop();
202
+ }
203
+ };
204
+ /** Called when the window has lost focus. */
205
+ this._windowBlur = () => {
206
+ // If the window is blurred while dragging we need to stop dragging because the
207
+ // browser won't dispatch the `mouseup` and `touchend` events anymore.
208
+ if (this._lastPointerEvent) {
209
+ this._pointerUp(this._lastPointerEvent);
210
+ }
211
+ };
212
+ this._document = _document;
213
+ viewPortRuler.change()
214
+ .pipe(takeUntil(this._destroy))
215
+ .subscribe(() => this._ngZone.run(() => this.updateCropperPosition()));
216
+ }
217
+ ngOnInit() {
218
+ this._ngZone.runOutsideAngular(() => {
219
+ const element = this._imgContainer.nativeElement;
220
+ element.addEventListener("mousedown", this._pointerDown, activeEventOptions);
221
+ element.addEventListener("touchstart", this._pointerDown, activeEventOptions);
222
+ });
223
+ }
224
+ ngOnDestroy() {
225
+ this._destroy.next();
226
+ this._destroy.complete();
227
+ const element = this._imgContainer.nativeElement;
228
+ this._lastPointerEvent = null;
229
+ this._removeGlobalEvents();
230
+ element.removeEventListener("mousedown", this._pointerDown, activeEventOptions);
231
+ element.removeEventListener("touchstart", this._pointerDown, activeEventOptions);
232
+ }
233
+ /** Load image with canvas */
234
+ _imgLoaded(imgElement) {
235
+ if (imgElement) {
236
+ this._img = imgElement;
237
+ const canvas = this._imgCanvas.nativeElement;
238
+ canvas.width = imgElement.width;
239
+ canvas.height = imgElement.height;
240
+ const ctx = canvas.getContext("2d");
241
+ ctx.clearRect(0, 0, imgElement.width, imgElement.height);
242
+ ctx.drawImage(imgElement, 0, 0);
243
+ /** set min scale */
244
+ this._updateMinScale(canvas);
245
+ this._updateMaxScale();
246
+ }
247
+ }
248
+ _setStylesForContImg(values) {
249
+ const newStyles = {};
250
+ if (values.x != null && values.y != null) {
251
+ const rootRect = this._rootRect();
252
+ const x = rootRect.width / 2 - (values.x);
253
+ const y = rootRect.height / 2 - (values.y);
254
+ this._imgRect.x = (values.x);
255
+ this._imgRect.y = (values.y);
256
+ this._imgRect.xc = (x);
257
+ this._imgRect.yc = (y);
258
+ }
259
+ newStyles.transform = `translate3d(${(this._imgRect.x)}px,${(this._imgRect.y)}px, 0)`;
260
+ newStyles.transform += `scale(${this._scal3Fix})`;
261
+ newStyles.transformOrigin = `${this._imgRect.xc}px ${this._imgRect.yc}px 0`;
262
+ newStyles["-webkit-transform"] = newStyles.transform;
263
+ newStyles["-webkit-transform-origin"] = newStyles.transformOrigin;
264
+ for (const key in newStyles) {
265
+ if (newStyles.hasOwnProperty(key)) {
266
+ this._renderer.setStyle(this._imgContainer.nativeElement, key, newStyles[key]);
267
+ }
268
+ }
269
+ }
270
+ /**
271
+ * Update area and image position only if needed,
272
+ * this is used when window resize
273
+ */
274
+ updateCropperPosition() {
275
+ if (this.isLoaded) {
276
+ this.updatePosition();
277
+ this._updateAreaIfNeeded();
278
+ }
279
+ }
280
+ /** Load Image from input event */
281
+ selectInputEvent(img) {
282
+ this._currentInputElement = img.target;
283
+ const _img = img.target;
284
+ if (_img.files && _img.files.length !== 1) {
285
+ return;
286
+ }
287
+ const fileSize = _img.files[0].size;
288
+ const fileName = _img.value.replace(/.*(\/|\\)/, "");
289
+ if (this.maxFileSize && fileSize > this.maxFileSize) {
290
+ const cropEvent = {
291
+ name: fileName,
292
+ type: _img.files[0].type,
293
+ size: fileSize,
294
+ error: ImgCropperError.Size
295
+ };
296
+ this.clean();
297
+ this.error.emit(cropEvent);
298
+ return;
299
+ }
300
+ new Observable(observer => {
301
+ const reader = new FileReader();
302
+ reader.onerror = err => observer.error(err);
303
+ reader.onabort = err => observer.error(err);
304
+ reader.onload = (ev) => setTimeout(() => {
305
+ observer.next(ev);
306
+ observer.complete();
307
+ });
308
+ reader.readAsDataURL(_img.files[0]);
309
+ })
310
+ .pipe(take(1), takeUntil(this._destroy))
311
+ .subscribe((loadEvent) => {
312
+ const originalDataURL = loadEvent.target.result;
313
+ this.loadImage({
314
+ name: fileName,
315
+ size: _img.files[0].size,
316
+ type: this.config.type || _img.files[0].type,
317
+ originalDataURL
318
+ });
319
+ this.cd.markForCheck();
320
+ }, () => {
321
+ const cropEvent = {
322
+ name: fileName,
323
+ size: fileSize,
324
+ error: ImgCropperError.Other,
325
+ errorMsg: "The File could not be loaded.",
326
+ type: _img.files[0].type
327
+ };
328
+ this.clean();
329
+ this.error.emit(cropEvent);
330
+ });
331
+ }
332
+ /** Set the size of the image, the values can be 0 between 1, where 1 is the original size */
333
+ setScale(size, noAutoCrop) {
334
+ // fix min scale
335
+ const newSize = size >= this.minScale && size <= 1 ? size : this.minScale;
336
+ // check
337
+ const changed = size != null && size !== this.scale && newSize !== this.scale;
338
+ this._scale = size;
339
+ if (!changed) {
340
+ return;
341
+ }
342
+ this._scal3Fix = newSize;
343
+ this._updateAbsoluteScale();
344
+ if (this.isLoaded) {
345
+ if (changed) {
346
+ const originPosition = { ...this._imgRect };
347
+ this.offset = {
348
+ x: originPosition.x,
349
+ y: originPosition.y,
350
+ left: originPosition.xc,
351
+ top: originPosition.yc
352
+ };
353
+ this._setStylesForContImg({});
354
+ this._simulatePointerMove();
355
+ }
356
+ else {
357
+ return;
358
+ }
359
+ }
360
+ else if (this.minScale) {
361
+ this._setStylesForContImg({
362
+ ...this._getCenterPoints()
363
+ });
364
+ }
365
+ else {
366
+ return;
367
+ }
368
+ this.scaleChange.emit(size);
369
+ if (!noAutoCrop) {
370
+ this._cropIfAutoCrop();
371
+ }
372
+ }
373
+ _getCenterPoints() {
374
+ const root = this._elementRef.nativeElement;
375
+ const img = this._imgCanvas.nativeElement;
376
+ const x = (root.offsetWidth - (img.width)) / 2;
377
+ const y = (root.offsetHeight - (img.height)) / 2;
378
+ return {
379
+ x,
380
+ y
381
+ };
382
+ }
383
+ /**
384
+ * Fit to screen
385
+ */
386
+ fitToScreen() {
387
+ const container = this._elementRef.nativeElement;
388
+ const min = {
389
+ width: container.offsetWidth,
390
+ height: container.offsetHeight
391
+ };
392
+ const { width, height } = this._img;
393
+ const minScale = {
394
+ width: min.width / width,
395
+ height: min.height / height
396
+ };
397
+ const result = Math.max(minScale.width, minScale.height);
398
+ this.setScale(result);
399
+ }
400
+ fit() {
401
+ this.setScale(this.minScale);
402
+ }
403
+ /**
404
+ * Simulate pointerMove with clientX = 0 and clientY = 0,
405
+ * this is used by `setScale` and `rotate`
406
+ */
407
+ _simulatePointerMove() {
408
+ this._isSliding = true;
409
+ this._startPointerEvent = {
410
+ x: 0,
411
+ y: 0
412
+ };
413
+ this._pointerMove({
414
+ clientX: 0,
415
+ clientY: 0,
416
+ type: "n",
417
+ preventDefault: () => { }
418
+ });
419
+ this._isSliding = false;
420
+ this._startPointerEvent = null;
421
+ }
422
+ _markForCheck() {
423
+ this.cd.markForCheck();
424
+ }
425
+ updatePosition(xOrigin, yOrigin) {
426
+ const hostRect = this._rootRect();
427
+ const areaRect = this._areaCropperRect();
428
+ const areaWidth = areaRect.width > hostRect.width
429
+ ? hostRect.width
430
+ : areaRect.width;
431
+ const areaHeight = areaRect.height > hostRect.height
432
+ ? hostRect.height
433
+ : areaRect.height;
434
+ let x;
435
+ let y;
436
+ if (xOrigin == null && yOrigin == null) {
437
+ xOrigin = this._imgRect.xc;
438
+ yOrigin = this._imgRect.yc;
439
+ }
440
+ x = (areaRect.left - hostRect.left);
441
+ y = (areaRect.top - hostRect.top);
442
+ x -= (xOrigin - (areaWidth / 2));
443
+ y -= (yOrigin - (areaHeight / 2));
444
+ this._setStylesForContImg({
445
+ x, y
446
+ });
447
+ }
448
+ _slideEnd() {
449
+ this._cropIfAutoCrop();
450
+ }
451
+ _cropIfAutoCrop() {
452
+ if (this.config.autoCrop) {
453
+ this.crop();
454
+ }
455
+ }
456
+ /** + */
457
+ zoomIn() {
458
+ const scale = this._scal3Fix + .05;
459
+ if (scale > this.minScale && scale <= this._maxScale) {
460
+ this.setScale(scale);
461
+ }
462
+ else {
463
+ this.setScale(this._maxScale);
464
+ }
465
+ }
466
+ /** Clean the img cropper */
467
+ clean() {
468
+ // fix choosing the same image does not load
469
+ if (this._currentInputElement) {
470
+ this._currentInputElement.value = "";
471
+ this._currentInputElement = null;
472
+ }
473
+ if (this.isLoaded) {
474
+ this._imgRect = {};
475
+ this.offset = undefined;
476
+ this.scale = undefined;
477
+ this._scal3Fix = undefined;
478
+ this._rotation = 0;
479
+ this._minScale = undefined;
480
+ this._isLoadedImg = false;
481
+ this.isLoaded = false;
482
+ this.isCropped = false;
483
+ this._currentLoadConfig = undefined;
484
+ this.config = this._configPrimary;
485
+ const canvas = this._imgCanvas.nativeElement;
486
+ canvas.width = 0;
487
+ canvas.height = 0;
488
+ this.cleaned.emit(null);
489
+ this.cd.markForCheck();
490
+ }
491
+ }
492
+ /** - */
493
+ zoomOut() {
494
+ const scale = this._scal3Fix - .05;
495
+ if (scale > this.minScale && scale <= this._maxScale) {
496
+ this.setScale(scale);
497
+ }
498
+ else {
499
+ this.fit();
500
+ }
501
+ }
502
+ center() {
503
+ const newStyles = {
504
+ ...this._getCenterPoints()
505
+ };
506
+ this._setStylesForContImg(newStyles);
507
+ this._cropIfAutoCrop();
508
+ }
509
+ /**
510
+ * load an image from a given configuration,
511
+ * or from the result of a cropped image
512
+ */
513
+ loadImage(config, fn) {
514
+ this.clean();
515
+ const _config = this._currentLoadConfig = typeof config === "string"
516
+ ? { originalDataURL: config }
517
+ : { ...config };
518
+ let src = _config.originalDataURL;
519
+ this._primaryAreaWidth = this._configPrimary.width;
520
+ this._primaryAreaHeight = this._configPrimary.height;
521
+ if (_config.areaWidth && _config.areaHeight) {
522
+ this.config.width = _config.areaWidth;
523
+ this.config.height = _config.areaHeight;
524
+ }
525
+ src = normalizeSVG(src);
526
+ const img = createHtmlImg(src);
527
+ const cropEvent = { ..._config };
528
+ new Observable(observer => {
529
+ img.onerror = err => observer.error(err);
530
+ img.onabort = err => observer.error(err);
531
+ img.onload = () => observer.next(null);
532
+ })
533
+ .pipe(take(1), takeUntil(this._destroy))
534
+ .subscribe(() => {
535
+ this._imgLoaded(img);
536
+ this._isLoadedImg = true;
537
+ this.imageLoaded.emit(cropEvent);
538
+ this.cd.markForCheck();
539
+ this._ngZone.runOutsideAngular(() => {
540
+ this._ngZone
541
+ .onStable
542
+ .asObservable()
543
+ .pipe(take(1), takeUntil(this._destroy))
544
+ .subscribe(() => setTimeout(() => this._ngZone.run(() => this._positionImg(cropEvent, fn))));
545
+ });
546
+ }, () => {
547
+ const error = {
548
+ name: _config.name,
549
+ error: ImgCropperError.Type,
550
+ type: _config.type,
551
+ size: _config.size
552
+ };
553
+ this.error.emit(error);
554
+ });
555
+ }
556
+ _updateAreaIfNeeded() {
557
+ if (!this._config.responsiveArea) {
558
+ return;
559
+ }
560
+ const rootRect = this._rootRect();
561
+ const areaRect = this._areaCropperRect();
562
+ const minWidth = this.config.minWidth || 1;
563
+ const minHeight = this.config.minHeight || 1;
564
+ if (!(areaRect.width > rootRect.width
565
+ || areaRect.height > rootRect.height
566
+ || areaRect.width < this._primaryAreaWidth
567
+ || areaRect.height < this._primaryAreaHeight)) {
568
+ return;
569
+ }
570
+ const areaWidthConf = Math.max(this.config.width, minWidth);
571
+ const areaWidthMax = Math.max(rootRect.width, minWidth);
572
+ const minHost = Math.min(Math.max(rootRect.width, minWidth), Math.max(rootRect.height, minHeight));
573
+ const currentScale = this._scal3Fix;
574
+ let newScale = 0;
575
+ const roundConf = this.config.round;
576
+ if (roundConf) {
577
+ this.config.width = this.config.height = minHost;
578
+ }
579
+ else {
580
+ if (areaWidthConf === areaRect.width) {
581
+ if (areaWidthMax > this._primaryAreaWidth) {
582
+ this.config.width = this._primaryAreaWidth;
583
+ this.config.height = (this._primaryAreaWidth * areaRect.height) / areaRect.width;
584
+ newScale = (currentScale * this._primaryAreaWidth) / areaRect.width;
585
+ }
586
+ else {
587
+ this.config.width = areaWidthMax;
588
+ this.config.height = (areaWidthMax * areaRect.height) / areaRect.width;
589
+ newScale = (currentScale * areaWidthMax) / areaRect.width;
590
+ }
591
+ this._updateMinScale();
592
+ this._updateMaxScale();
593
+ this.setScale(newScale, true);
594
+ this._markForCheck();
595
+ }
596
+ }
597
+ }
598
+ _updateAbsoluteScale() {
599
+ const scale = this._scal3Fix / (this.config.width / this._primaryAreaWidth);
600
+ this._absoluteScale = scale;
601
+ }
602
+ /**
603
+ * Load Image from URL
604
+ * @deprecated Use `loadImage` instead of `setImageUrl`
605
+ * @param src URL
606
+ * @param fn function that will be called before emit the event loaded
607
+ */
608
+ setImageUrl(src, fn) {
609
+ this.loadImage(src, fn);
610
+ }
611
+ _positionImg(cropEvent, fn) {
612
+ const loadConfig = this._currentLoadConfig;
613
+ this._updateMinScale(this._imgCanvas.nativeElement);
614
+ this._updateMaxScale();
615
+ this.isLoaded = false;
616
+ if (fn) {
617
+ fn();
618
+ }
619
+ else {
620
+ if (loadConfig.scale) {
621
+ this.setScale(loadConfig.scale, true);
622
+ }
623
+ else {
624
+ this.setScale(this.minScale, true);
625
+ }
626
+ this.rotate(loadConfig.rotation || 0);
627
+ this._updateAreaIfNeeded();
628
+ this._markForCheck();
629
+ this._ngZone.runOutsideAngular(() => {
630
+ this._ngZone
631
+ .onStable
632
+ .asObservable()
633
+ .pipe(take(1), takeUntil(this._destroy))
634
+ .subscribe(() => {
635
+ if (loadConfig.xOrigin != null && loadConfig.yOrigin != null) {
636
+ this.updatePosition(loadConfig.xOrigin, loadConfig.yOrigin);
637
+ }
638
+ this._updateAreaIfNeeded();
639
+ this.isLoaded = true;
640
+ this._cropIfAutoCrop();
641
+ this._ngZone.run(() => {
642
+ this._markForCheck();
643
+ this.ready.emit(cropEvent);
644
+ });
645
+ });
646
+ });
647
+ }
648
+ }
649
+ rotate(degrees) {
650
+ let validDegrees = _normalizeDegrees(degrees);
651
+ // If negative convert to positive
652
+ if (validDegrees < 0) {
653
+ validDegrees += 360;
654
+ }
655
+ const newRotation = _normalizeDegrees((this._rotation || 0) + validDegrees);
656
+ if (newRotation === this._rotation) {
657
+ return;
658
+ }
659
+ const degreesRad = validDegrees * Math.PI / 180;
660
+ const canvas = this._imgCanvas.nativeElement;
661
+ const canvasClon = createCanvasImg(canvas);
662
+ const ctx = canvas.getContext("2d");
663
+ this._rotation = newRotation;
664
+ // clear
665
+ ctx.clearRect(0, 0, canvasClon.width, canvasClon.height);
666
+ // rotate canvas image
667
+ const transform = `rotate(${validDegrees}deg) scale(${1 / this._scal3Fix})`;
668
+ const transformOrigin = `${this._imgRect.xc}px ${this._imgRect.yc}px 0`;
669
+ canvas.style.transform = transform;
670
+ // tslint:disable-next-line: deprecation
671
+ canvas.style.webkitTransform = transform;
672
+ canvas.style.transformOrigin = transformOrigin;
673
+ // tslint:disable-next-line: deprecation
674
+ canvas.style.webkitTransformOrigin = transformOrigin;
675
+ const { left, top } = canvas.getBoundingClientRect();
676
+ // save rect
677
+ const canvasRect = canvas.getBoundingClientRect();
678
+ // remove rotate styles
679
+ canvas.removeAttribute("style");
680
+ // set w & h
681
+ const w = canvasRect.width;
682
+ const h = canvasRect.height;
683
+ ctx.canvas.width = w;
684
+ ctx.canvas.height = h;
685
+ // clear
686
+ ctx.clearRect(0, 0, w, h);
687
+ // translate and rotate
688
+ ctx.translate(w / 2, h / 2);
689
+ ctx.rotate(degreesRad);
690
+ ctx.drawImage(canvasClon, -canvasClon.width / 2, -canvasClon.height / 2);
691
+ // Update min scale
692
+ this._updateMinScale(canvas);
693
+ this._updateMaxScale();
694
+ // set the minimum scale, only if necessary
695
+ if (this.scale < this.minScale) {
696
+ this.setScale(0, true);
697
+ } // ↑ no AutoCrop
698
+ const rootRect = this._rootRect();
699
+ this._setStylesForContImg({
700
+ x: (left - rootRect.left),
701
+ y: (top - rootRect.top)
702
+ });
703
+ // keep image inside the frame
704
+ const originPosition = { ...this._imgRect };
705
+ this.offset = {
706
+ x: originPosition.x,
707
+ y: originPosition.y,
708
+ left: originPosition.xc,
709
+ top: originPosition.yc
710
+ };
711
+ this._setStylesForContImg({});
712
+ this._simulatePointerMove();
713
+ this._cropIfAutoCrop();
714
+ }
715
+ _updateMinScale(canvas) {
716
+ if (!canvas) {
717
+ canvas = this._imgCanvas.nativeElement;
718
+ }
719
+ const config = this.config;
720
+ const minScale = (config.extraZoomOut ? Math.min : Math.max)(config.width / canvas.width, config.height / canvas.height);
721
+ this._minScale = minScale;
722
+ this.minScaleChange.emit(minScale);
723
+ }
724
+ _updateMaxScale() {
725
+ const maxScale = (this.config.width / this._primaryAreaWidth);
726
+ this._maxScale = maxScale;
727
+ this.maxScaleChange.emit(maxScale);
728
+ }
729
+ /**
730
+ * Resize & crop image
731
+ */
732
+ crop(config) {
733
+ const newConfig = config
734
+ ? mergeDeep({}, this.config || new ImgCropperConfig(), config) : this.config;
735
+ const cropEvent = this._imgCrop(newConfig);
736
+ this.cd.markForCheck();
737
+ return cropEvent;
738
+ }
739
+ /**
740
+ * @docs-private
741
+ */
742
+ _imgCrop(myConfig) {
743
+ const canvasElement = document.createElement("canvas");
744
+ const areaRect = this._areaCropperRect();
745
+ const canvasRect = this._canvasRect();
746
+ const scaleFix = this._scal3Fix;
747
+ const left = (areaRect.left - canvasRect.left) / scaleFix;
748
+ const top = (areaRect.top - canvasRect.top) / scaleFix;
749
+ const { output } = myConfig;
750
+ const currentImageLoadConfig = this._currentLoadConfig;
751
+ const area = {
752
+ width: myConfig.width,
753
+ height: myConfig.height
754
+ };
755
+ canvasElement.width = area.width / scaleFix;
756
+ canvasElement.height = area.height / scaleFix;
757
+ const ctx = canvasElement.getContext("2d");
758
+ if (myConfig.fill) {
759
+ ctx.fillStyle = myConfig.fill;
760
+ ctx.fillRect(0, 0, canvasElement.width, canvasElement.height);
761
+ }
762
+ ctx.drawImage(this._imgCanvas.nativeElement, -(left), -(top));
763
+ const result = canvasElement;
764
+ if (myConfig.output === ImgResolution.Default) {
765
+ resizeCanvas(result, this._configPrimary.width, this._configPrimary.height);
766
+ }
767
+ else if (typeof output === "object") {
768
+ if (output.width && output.height) {
769
+ resizeCanvas(result, output.width, output.height);
770
+ }
771
+ else if (output.width) {
772
+ const newHeight = area.height * output.width / area.width;
773
+ resizeCanvas(result, output.width, newHeight);
774
+ }
775
+ else if (output.height) {
776
+ const newWidth = area.width * output.height / area.height;
777
+ resizeCanvas(result, newWidth, output.height);
778
+ }
779
+ }
780
+ const type = currentImageLoadConfig.originalDataURL.startsWith("http")
781
+ ? currentImageLoadConfig.type || myConfig.type
782
+ : myConfig.type || currentImageLoadConfig.type;
783
+ const dataURL = result.toDataURL(type);
784
+ const cropEvent = {
785
+ dataURL,
786
+ type,
787
+ name: currentImageLoadConfig.name,
788
+ areaWidth: this._primaryAreaWidth,
789
+ areaHeight: this._primaryAreaHeight,
790
+ width: result.width,
791
+ height: result.height,
792
+ originalDataURL: currentImageLoadConfig.originalDataURL,
793
+ scale: this._absoluteScale,
794
+ rotation: this._rotation,
795
+ left: (areaRect.left - canvasRect.left) / this._scal3Fix,
796
+ top: (areaRect.top - canvasRect.top) / this._scal3Fix,
797
+ size: currentImageLoadConfig.size,
798
+ xOrigin: this._imgRect.xc,
799
+ yOrigin: this._imgRect.yc,
800
+ position: {
801
+ x: this._imgRect.xc,
802
+ y: this._imgRect.yc
803
+ }
804
+ };
805
+ this.isCropped = true;
806
+ this.cropped.emit(cropEvent);
807
+ return cropEvent;
808
+ }
809
+ _rootRect() {
810
+ return this._elementRef.nativeElement.getBoundingClientRect();
811
+ }
812
+ _areaCropperRect() {
813
+ return this._areaRef.nativeElement.getBoundingClientRect();
814
+ }
815
+ _canvasRect() {
816
+ return this._imgCanvas.nativeElement.getBoundingClientRect();
817
+ }
818
+ _bindGlobalEvents(triggerEvent) {
819
+ const element = this._document;
820
+ const isTouch = isTouchEvent(triggerEvent);
821
+ const moveEventName = isTouch ? "touchmove" : "mousemove";
822
+ const endEventName = isTouch ? "touchend" : "mouseup";
823
+ element.addEventListener(moveEventName, this._pointerMove, activeEventOptions);
824
+ element.addEventListener(endEventName, this._pointerUp, activeEventOptions);
825
+ if (isTouch) {
826
+ element.addEventListener("touchcancel", this._pointerUp, activeEventOptions);
827
+ }
828
+ const window = this._getWindow();
829
+ if (typeof window !== "undefined" && window) {
830
+ window.addEventListener("blur", this._windowBlur);
831
+ }
832
+ }
833
+ /** Removes any global event listeners that we may have added. */
834
+ _removeGlobalEvents() {
835
+ const element = this._document;
836
+ element.removeEventListener("mousemove", this._pointerMove, activeEventOptions);
837
+ element.removeEventListener("mouseup", this._pointerUp, activeEventOptions);
838
+ element.removeEventListener("touchmove", this._pointerMove, activeEventOptions);
839
+ element.removeEventListener("touchend", this._pointerUp, activeEventOptions);
840
+ element.removeEventListener("touchcancel", this._pointerUp, activeEventOptions);
841
+ const window = this._getWindow();
842
+ if (typeof window !== "undefined" && window) {
843
+ window.removeEventListener("blur", this._windowBlur);
844
+ }
845
+ }
846
+ /** Use defaultView of injected document if available or fallback to global window reference */
847
+ _getWindow() {
848
+ return this._document.defaultView || window;
849
+ }
850
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NiceImageCropperComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: DOCUMENT }, { token: i1.ViewportRuler }], target: i0.ɵɵFactoryTarget.Component }); }
851
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.5", type: NiceImageCropperComponent, selector: "nice-img-cropper, nice-image-cropper", inputs: { config: "config", scale: "scale", maxFileSize: "maxFileSize" }, outputs: { scaleChange: "scaleChange", minScaleChange: "minScale", maxScaleChange: "maxScale", imageLoaded: "imageLoaded", ready: "ready", cropped: "cropped", cleaned: "cleaned", error: "error" }, viewQueries: [{ propertyName: "_imgContainer", first: true, predicate: ["_imgContainer"], descendants: true, static: true }, { propertyName: "_areaRef", first: true, predicate: ["_area"], descendants: true, read: ElementRef }, { propertyName: "_imgCanvas", first: true, predicate: ["_imgCanvas"], descendants: true, static: true }], ngImport: i0, template: "<!-- (selectstart): On Safari starting to slide temporarily triggers text selection mode which\nshow the wrong cursor. We prevent it by stopping the `selectstart` event. -->\n<div class=\"image-container\" #_imgContainer\n (selectstart)=\"$event.preventDefault()\"\n>\n <canvas #_imgCanvas></canvas>\n</div>\n<nice-cropper-area\n #_area\n *ngIf=\"_isLoadedImg\"\n [round]=\"!!config.round\"\n [resizableArea]=\"!!config.resizableArea\"\n [keepAspectRatio]=\"!!config.keepAspectRatio\"\n [ngStyle]=\"{\n width: config.width + 'px',\n height: config.height + 'px'\n }\"\n></nice-cropper-area>\n<button class=\"close-button\" mat-icon-button *ngIf=\"_isLoadedImg\" (click)=\"clean()\">\n <mat-icon>arrow_back</mat-icon>\n</button>\n", styles: ["nice-image-cropper,nice-img-cropper{-webkit-user-select:none;user-select:none;display:flex;overflow:hidden;position:relative;justify-content:center;align-items:center}nice-image-cropper .image-container,nice-img-cropper .image-container{cursor:move;position:absolute;top:0;left:0;display:flex;touch-action:none}nice-image-cropper .image-container>canvas,nice-img-cropper .image-container>canvas{display:block}nice-image-cropper .close-button,nice-img-cropper .close-button{position:absolute;top:8px;left:8px;background-color:#fff!important;border-radius:4px;height:20px;width:20px;min-height:20px}nice-image-cropper .close-button .mat-icon,nice-img-cropper .close-button .mat-icon{height:14px!important;width:14px!important;font-size:14px!important;line-height:14px!important}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(function () { return i3.MatIconButton; }), selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i0.forwardRef(function () { return i4.MatIcon; }), selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i0.forwardRef(function () { return NiceCropperAreaComponent; }), selector: "nice-cropper-area", inputs: ["keepAspectRatio", "round", "resizableArea"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
852
+ }
853
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NiceImageCropperComponent, decorators: [{
854
+ type: Component,
855
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, selector: "nice-img-cropper, nice-image-cropper", encapsulation: ViewEncapsulation.None, template: "<!-- (selectstart): On Safari starting to slide temporarily triggers text selection mode which\nshow the wrong cursor. We prevent it by stopping the `selectstart` event. -->\n<div class=\"image-container\" #_imgContainer\n (selectstart)=\"$event.preventDefault()\"\n>\n <canvas #_imgCanvas></canvas>\n</div>\n<nice-cropper-area\n #_area\n *ngIf=\"_isLoadedImg\"\n [round]=\"!!config.round\"\n [resizableArea]=\"!!config.resizableArea\"\n [keepAspectRatio]=\"!!config.keepAspectRatio\"\n [ngStyle]=\"{\n width: config.width + 'px',\n height: config.height + 'px'\n }\"\n></nice-cropper-area>\n<button class=\"close-button\" mat-icon-button *ngIf=\"_isLoadedImg\" (click)=\"clean()\">\n <mat-icon>arrow_back</mat-icon>\n</button>\n", styles: ["nice-image-cropper,nice-img-cropper{-webkit-user-select:none;user-select:none;display:flex;overflow:hidden;position:relative;justify-content:center;align-items:center}nice-image-cropper .image-container,nice-img-cropper .image-container{cursor:move;position:absolute;top:0;left:0;display:flex;touch-action:none}nice-image-cropper .image-container>canvas,nice-img-cropper .image-container>canvas{display:block}nice-image-cropper .close-button,nice-img-cropper .close-button{position:absolute;top:8px;left:8px;background-color:#fff!important;border-radius:4px;height:20px;width:20px;min-height:20px}nice-image-cropper .close-button .mat-icon,nice-img-cropper .close-button .mat-icon{height:14px!important;width:14px!important;font-size:14px!important;line-height:14px!important}\n"] }]
856
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
857
+ type: Inject,
858
+ args: [DOCUMENT]
859
+ }] }, { type: i1.ViewportRuler }]; }, propDecorators: { _imgContainer: [{
860
+ type: ViewChild,
861
+ args: ["_imgContainer", { static: true }]
862
+ }], _areaRef: [{
863
+ type: ViewChild,
864
+ args: ["_area", { read: ElementRef }]
865
+ }], _imgCanvas: [{
866
+ type: ViewChild,
867
+ args: ["_imgCanvas", { static: true }]
868
+ }], config: [{
869
+ type: Input
870
+ }], scale: [{
871
+ type: Input
872
+ }], maxFileSize: [{
873
+ type: Input
874
+ }], scaleChange: [{
875
+ type: Output
876
+ }], minScaleChange: [{
877
+ type: Output,
878
+ args: ["minScale"]
879
+ }], maxScaleChange: [{
880
+ type: Output,
881
+ args: ["maxScale"]
882
+ }], imageLoaded: [{
883
+ type: Output
884
+ }], ready: [{
885
+ type: Output
886
+ }], cropped: [{
887
+ type: Output
888
+ }], cleaned: [{
889
+ type: Output
890
+ }], error: [{
891
+ type: Output
892
+ }] } });
893
+ /**
894
+ * Normalize degrees for cropper rotation
895
+ * @docs-private
896
+ */
897
+ export function _normalizeDegrees(n) {
898
+ const de = n % 360;
899
+ if (de % 90) {
900
+ throw new Error(`LyCropper: Invalid \`${n}\` degree, only accepted values: 0, 90, 180, 270 & 360.`);
901
+ }
902
+ return de;
903
+ }
904
+ /**
905
+ * @docs-private
906
+ */
907
+ function createCanvasImg(img) {
908
+ // create a new canvas
909
+ const newCanvas = document.createElement("canvas");
910
+ const context = newCanvas.getContext("2d");
911
+ // set dimensions
912
+ newCanvas.width = img.width;
913
+ newCanvas.height = img.height;
914
+ // apply the old canvas to the new one
915
+ context.drawImage(img, 0, 0);
916
+ // return the new canvas
917
+ return newCanvas;
918
+ }
919
+ const DATA_IMAGE_SVG_PREFIX = "data:image/svg+xml;base64,";
920
+ function normalizeSVG(dataURL) {
921
+ if (window.atob && isSvgImage(dataURL)) {
922
+ const len = dataURL.length / 5;
923
+ const text = window.atob(dataURL.replace(DATA_IMAGE_SVG_PREFIX, ""));
924
+ const span = document.createElement("span");
925
+ span.innerHTML = text;
926
+ const svg = span.querySelector("svg");
927
+ span.setAttribute("style", "display:none");
928
+ document.body.appendChild(span);
929
+ const width = parseFloat(getComputedStyle(svg).width) || 1;
930
+ const height = parseFloat(getComputedStyle(svg).height) || 1;
931
+ const max = Math.max(width, height);
932
+ svg.setAttribute("width", `${len / (width / max)}px`);
933
+ svg.setAttribute("height", `${len / (height / max)}px`);
934
+ const result = DATA_IMAGE_SVG_PREFIX + window.btoa(span.innerHTML);
935
+ document.body.removeChild(span);
936
+ return result;
937
+ }
938
+ return dataURL;
939
+ }
940
+ function isSvgImage(dataUrl) {
941
+ return dataUrl.startsWith(DATA_IMAGE_SVG_PREFIX);
942
+ }
943
+ function createHtmlImg(src) {
944
+ const img = new Image();
945
+ img.crossOrigin = "anonymous";
946
+ img.src = src;
947
+ return img;
948
+ }
949
+ function getGesturePointFromEvent(event) {
950
+ // `touches` will be empty for start/end events so we have to fall back to `changedTouches`.
951
+ const point = isTouchEvent(event)
952
+ ? (event.touches[0] || event.changedTouches[0])
953
+ : event;
954
+ return {
955
+ x: point.clientX,
956
+ y: point.clientY
957
+ };
958
+ }
959
+ /** Returns whether an event is a touch event. */
960
+ function isTouchEvent(event) {
961
+ return event.type[0] === "t";
962
+ }
963
+ export function round(n) {
964
+ return Math.round(n);
965
+ }
966
+ /**
967
+ * Simple object check.
968
+ * @param item
969
+ */
970
+ function isObject(item) {
971
+ return (item && typeof item === "object" && !Array.isArray(item));
972
+ }
973
+ /**
974
+ * Deep merge two objects.
975
+ * @param target
976
+ * @param ...sources
977
+ */
978
+ export function mergeDeep(target, ...sources) {
979
+ if (!sources.length) {
980
+ return target;
981
+ }
982
+ const source = sources.shift();
983
+ if (isObject(target) && isObject(source)) {
984
+ for (const key in source) {
985
+ if (isObject(source[key])) {
986
+ if (!target[key]) {
987
+ Object.assign(target, { [key]: {} });
988
+ }
989
+ mergeDeep(target[key], source[key]);
990
+ }
991
+ else {
992
+ Object.assign(target, { [key]: source[key] });
993
+ }
994
+ }
995
+ }
996
+ return mergeDeep(target, ...sources);
997
+ }
998
+ /**
999
+ * We have the cropper area in the same file to fix the build
1000
+ */
1001
+ export class NiceCropperAreaComponent {
1002
+ constructor(_document, _elementRef, _cropper, _ngZone) {
1003
+ this._elementRef = _elementRef;
1004
+ this._cropper = _cropper;
1005
+ this._ngZone = _ngZone;
1006
+ this._pointerDown = (event) => {
1007
+ // Don't do anything if the
1008
+ // user is using anything other than the main mouse button.
1009
+ if (this._isSliding || (!isTouchEvent(event) && event.button !== 0)) {
1010
+ return;
1011
+ }
1012
+ event.preventDefault();
1013
+ this._ngZone.run(() => {
1014
+ this._isSliding = true;
1015
+ this._lastPointerEvent = event;
1016
+ this._startPointerEvent = getGesturePointFromEvent(event);
1017
+ this._startAreaRect = this._cropper._areaCropperRect();
1018
+ this._startImgRect = this._cropper._canvasRect();
1019
+ event.preventDefault();
1020
+ this._bindGlobalEvents(event);
1021
+ });
1022
+ };
1023
+ this._pointerMove = (event) => {
1024
+ if (this._isSliding) {
1025
+ event.preventDefault();
1026
+ this._lastPointerEvent = event;
1027
+ const element = this._elementRef.nativeElement;
1028
+ const { width, height, minWidth, minHeight } = this._cropper.config;
1029
+ const point = getGesturePointFromEvent(event);
1030
+ const deltaX = point.x - this._startPointerEvent.x;
1031
+ const deltaY = point.y - this._startPointerEvent.y;
1032
+ const startAreaRect = this._startAreaRect;
1033
+ const startImgRect = this._startImgRect;
1034
+ const isRound = this.round;
1035
+ const keepAspectRatio = this._cropper.config.keepAspectRatio || event.shiftKey;
1036
+ let newWidth = 0;
1037
+ let newHeight = 0;
1038
+ const rootRect = this._cropper._rootRect();
1039
+ if (isRound) {
1040
+ // The distance from the center of the cropper area to the pointer
1041
+ const originX = ((width / 2 / Math.sqrt(2)) + deltaX);
1042
+ const originY = ((height / 2 / Math.sqrt(2)) + deltaY);
1043
+ // Leg
1044
+ const side = Math.sqrt(originX ** 2 + originY ** 2);
1045
+ newWidth = newHeight = side * 2;
1046
+ }
1047
+ else if (keepAspectRatio) {
1048
+ newWidth = width + deltaX * 2;
1049
+ newHeight = height + deltaY * 2;
1050
+ if (width !== height) {
1051
+ if (width > height) {
1052
+ newHeight = height / (width / newWidth);
1053
+ }
1054
+ else if (height > width) {
1055
+ newWidth = width / (height / newHeight);
1056
+ }
1057
+ }
1058
+ else {
1059
+ newWidth = newHeight = Math.max(newWidth, newHeight);
1060
+ }
1061
+ }
1062
+ else {
1063
+ newWidth = width + deltaX * 2;
1064
+ newHeight = height + deltaY * 2;
1065
+ }
1066
+ // To min width
1067
+ if (newWidth < minWidth) {
1068
+ newWidth = minWidth;
1069
+ }
1070
+ // To min height
1071
+ if (newHeight < minHeight) {
1072
+ newHeight = minHeight;
1073
+ }
1074
+ // Do not overflow the cropper area
1075
+ const centerX = startAreaRect.x + startAreaRect.width / 2;
1076
+ const centerY = startAreaRect.y + startAreaRect.height / 2;
1077
+ const topOverflow = startImgRect.y > centerY - (newHeight / 2);
1078
+ const bottomOverflow = centerY + (newHeight / 2) > startImgRect.bottom;
1079
+ const minHeightOnOverflow = Math.min((centerY - startImgRect.y) * 2, (startImgRect.bottom - centerY) * 2);
1080
+ const leftOverflow = startImgRect.x > centerX - (newWidth / 2);
1081
+ const rightOverflow = centerX + (newWidth / 2) > startImgRect.right;
1082
+ const minWidthOnOverflow = Math.min((centerX - startImgRect.x) * 2, (startImgRect.right - centerX) * 2);
1083
+ const minOnOverflow = Math.min(minWidthOnOverflow, minHeightOnOverflow);
1084
+ if (round) {
1085
+ if (topOverflow || bottomOverflow || leftOverflow || rightOverflow) {
1086
+ newHeight = newWidth = minOnOverflow;
1087
+ }
1088
+ }
1089
+ else if (keepAspectRatio) {
1090
+ const newNewWidth = [];
1091
+ const newNewHeight = [];
1092
+ if ((topOverflow || bottomOverflow) && Math.min()) {
1093
+ newHeight = minHeightOnOverflow;
1094
+ newNewHeight.push(newHeight);
1095
+ newWidth = width / (height / minHeightOnOverflow);
1096
+ newNewWidth.push(newWidth);
1097
+ }
1098
+ if ((leftOverflow || rightOverflow)) {
1099
+ newWidth = minWidthOnOverflow;
1100
+ newNewWidth.push(newWidth);
1101
+ newHeight = height / (width / minWidthOnOverflow);
1102
+ newNewHeight.push(newHeight);
1103
+ }
1104
+ if (newNewWidth.length === 2) {
1105
+ newWidth = Math.min(...newNewWidth);
1106
+ }
1107
+ if (newNewHeight.length === 2) {
1108
+ newHeight = Math.min(...newNewHeight);
1109
+ }
1110
+ }
1111
+ else {
1112
+ if (topOverflow || bottomOverflow) {
1113
+ newHeight = minHeightOnOverflow;
1114
+ }
1115
+ if (leftOverflow || rightOverflow) {
1116
+ newWidth = minWidthOnOverflow;
1117
+ }
1118
+ }
1119
+ // Do not overflow the container
1120
+ if (round) {
1121
+ const min = Math.min(rootRect.width, rootRect.height);
1122
+ if (newWidth > min) {
1123
+ newWidth = newHeight = min;
1124
+ }
1125
+ else if (newHeight > min) {
1126
+ newWidth = newHeight = min;
1127
+ }
1128
+ }
1129
+ else if (keepAspectRatio) {
1130
+ if (newWidth > rootRect.width) {
1131
+ newWidth = rootRect.width;
1132
+ newHeight = height / (width / rootRect.width);
1133
+ }
1134
+ else if (newHeight > rootRect.height) {
1135
+ newWidth = width / (height / rootRect.height);
1136
+ newHeight = rootRect.height;
1137
+ }
1138
+ }
1139
+ else {
1140
+ if (newWidth > rootRect.width) {
1141
+ newWidth = rootRect.width;
1142
+ }
1143
+ else if (newHeight > rootRect.height) {
1144
+ newHeight = rootRect.height;
1145
+ }
1146
+ }
1147
+ // round values
1148
+ newWidth = Math.round(newWidth);
1149
+ newHeight = Math.round(newHeight);
1150
+ element.style.width = `${newWidth}px`;
1151
+ element.style.height = `${newHeight}px`;
1152
+ this._currentWidth = newWidth;
1153
+ this._currentHeight = newHeight;
1154
+ }
1155
+ };
1156
+ /** Called when the user has lifted their pointer. */
1157
+ this._pointerUp = (event) => {
1158
+ if (this._isSliding) {
1159
+ event.preventDefault();
1160
+ this._removeGlobalEvents();
1161
+ this._cropper._primaryAreaWidth = this._cropper.config.width = this._currentWidth;
1162
+ this._cropper._primaryAreaHeight = this._cropper.config.height = this._currentHeight;
1163
+ this._cropper.config = this._cropper.config;
1164
+ this._cropper._updateMinScale();
1165
+ this._isSliding = false;
1166
+ this._startPointerEvent = null;
1167
+ }
1168
+ };
1169
+ /** Called when the window has lost focus. */
1170
+ this._windowBlur = () => {
1171
+ // If the window is blurred while dragging we need to stop dragging because the
1172
+ // browser won't dispatch the `mouseup` and `touchend` events anymore.
1173
+ if (this._lastPointerEvent) {
1174
+ this._pointerUp(this._lastPointerEvent);
1175
+ }
1176
+ };
1177
+ this._document = _document;
1178
+ }
1179
+ set resizableArea(val) {
1180
+ if (val !== this._resizableArea) {
1181
+ this._resizableArea = val;
1182
+ Promise.resolve(null).then(() => {
1183
+ if (val) {
1184
+ this._removeResizableArea();
1185
+ this._addResizableArea();
1186
+ }
1187
+ else {
1188
+ this._removeResizableArea();
1189
+ }
1190
+ });
1191
+ }
1192
+ }
1193
+ get resizableArea() {
1194
+ return this._resizableArea;
1195
+ }
1196
+ ngOnDestroy() {
1197
+ this._removeResizableArea();
1198
+ }
1199
+ _addResizableArea() {
1200
+ this._ngZone.runOutsideAngular(() => {
1201
+ const element = this._resizer.nativeElement;
1202
+ element.addEventListener("mousedown", this._pointerDown, activeEventOptions);
1203
+ element.addEventListener("touchstart", this._pointerDown, activeEventOptions);
1204
+ });
1205
+ }
1206
+ _removeResizableArea() {
1207
+ const element = this._resizer?.nativeElement;
1208
+ if (element) {
1209
+ this._lastPointerEvent = null;
1210
+ this._removeGlobalEvents();
1211
+ element.removeEventListener("mousedown", this._pointerDown, activeEventOptions);
1212
+ element.removeEventListener("touchstart", this._pointerDown, activeEventOptions);
1213
+ }
1214
+ }
1215
+ _bindGlobalEvents(triggerEvent) {
1216
+ const element = this._document;
1217
+ const isTouch = isTouchEvent(triggerEvent);
1218
+ const moveEventName = isTouch ? "touchmove" : "mousemove";
1219
+ const endEventName = isTouch ? "touchend" : "mouseup";
1220
+ element.addEventListener(moveEventName, this._pointerMove, activeEventOptions);
1221
+ element.addEventListener(endEventName, this._pointerUp, activeEventOptions);
1222
+ if (isTouch) {
1223
+ element.addEventListener("touchcancel", this._pointerUp, activeEventOptions);
1224
+ }
1225
+ const window = this._getWindow();
1226
+ if (typeof window !== "undefined" && window) {
1227
+ window.addEventListener("blur", this._windowBlur);
1228
+ }
1229
+ }
1230
+ /** Removes any global event listeners that we may have added. */
1231
+ _removeGlobalEvents() {
1232
+ const element = this._document;
1233
+ element.removeEventListener("mousemove", this._pointerMove, activeEventOptions);
1234
+ element.removeEventListener("mouseup", this._pointerUp, activeEventOptions);
1235
+ element.removeEventListener("touchmove", this._pointerMove, activeEventOptions);
1236
+ element.removeEventListener("touchend", this._pointerUp, activeEventOptions);
1237
+ element.removeEventListener("touchcancel", this._pointerUp, activeEventOptions);
1238
+ const window = this._getWindow();
1239
+ if (typeof window !== "undefined" && window) {
1240
+ window.removeEventListener("blur", this._windowBlur);
1241
+ }
1242
+ }
1243
+ /** Use defaultView of injected document if available or fallback to global window reference */
1244
+ _getWindow() {
1245
+ return this._document.defaultView || window;
1246
+ }
1247
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NiceCropperAreaComponent, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: NiceImageCropperComponent }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
1248
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.5", type: NiceCropperAreaComponent, selector: "nice-cropper-area", inputs: { keepAspectRatio: "keepAspectRatio", round: "round", resizableArea: "resizableArea" }, host: { properties: { "class.round": "this.round" } }, viewQueries: [{ propertyName: "_resizer", first: true, predicate: ["resizer"], descendants: true }], ngImport: i0, template: "<div class=\"resizer\" #resizer *ngIf=\"resizableArea\"></div>\n", styles: ["nice-cropper-area{pointer-events:none;box-shadow:0 0 0 20000px #0006;margin:auto;position:absolute;inset:0}nice-cropper-area.round{border-radius:50%}nice-cropper-area:before,nice-cropper-area:after{position:absolute;inset:0;content:\"\"}nice-cropper-area:before{width:0;height:0;margin:auto;border-radius:50%;background:#fff;border:solid 2px rgb(255,255,255)}nice-cropper-area:after{border:solid 2px rgb(255,255,255);border-radius:inherit}nice-cropper-area .resizer{width:10px;height:10px;background:#fff;border-radius:3px;position:absolute;touch-action:none;bottom:0;pointer-events:all}nice-cropper-area .resizer:before{content:\"\";width:20px;height:20px;transform:translate(-25%,-25%)}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
1249
+ }
1250
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NiceCropperAreaComponent, decorators: [{
1251
+ type: Component,
1252
+ args: [{ selector: "nice-cropper-area", encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"resizer\" #resizer *ngIf=\"resizableArea\"></div>\n", styles: ["nice-cropper-area{pointer-events:none;box-shadow:0 0 0 20000px #0006;margin:auto;position:absolute;inset:0}nice-cropper-area.round{border-radius:50%}nice-cropper-area:before,nice-cropper-area:after{position:absolute;inset:0;content:\"\"}nice-cropper-area:before{width:0;height:0;margin:auto;border-radius:50%;background:#fff;border:solid 2px rgb(255,255,255)}nice-cropper-area:after{border:solid 2px rgb(255,255,255);border-radius:inherit}nice-cropper-area .resizer{width:10px;height:10px;background:#fff;border-radius:3px;position:absolute;touch-action:none;bottom:0;pointer-events:all}nice-cropper-area .resizer:before{content:\"\";width:20px;height:20px;transform:translate(-25%,-25%)}\n"] }]
1253
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1254
+ type: Inject,
1255
+ args: [DOCUMENT]
1256
+ }] }, { type: i0.ElementRef }, { type: NiceImageCropperComponent }, { type: i0.NgZone }]; }, propDecorators: { _resizer: [{
1257
+ type: ViewChild,
1258
+ args: ["resizer"]
1259
+ }], keepAspectRatio: [{
1260
+ type: Input
1261
+ }], round: [{
1262
+ type: Input
1263
+ }, {
1264
+ type: HostBinding,
1265
+ args: ["class.round"]
1266
+ }], resizableArea: [{
1267
+ type: Input
1268
+ }] } });
1269
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/image-cropper/image-cropper.component.ts","../../../../../../projects/nice-ui-kit-v2/src/lib/components/image-cropper/image-cropper.template.html","../../../../../../projects/nice-ui-kit-v2/src/lib/components/image-cropper/image-cropper-area.template.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Adapted from https://github.com/A-l-y-l-e/Alyle-UI/tree/10.5.3/src/lib/image-cropper\n */\n\nimport { normalizePassiveListenerOptions } from \"@angular/cdk/platform\";\nimport { ViewportRuler } from \"@angular/cdk/scrolling\";\nimport { DOCUMENT } from \"@angular/common\";\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter, HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation\n} from \"@angular/core\";\nimport { Observable, Subject } from \"rxjs\";\nimport { take, takeUntil } from \"rxjs/operators\";\nimport { resizeCanvas } from \"./resize-canvas\";\n\nconst activeEventOptions = normalizePassiveListenerOptions({ passive: false });\n\n/** Image Cropper Config */\nexport class ImgCropperConfig {\n    /** Cropper area width */\n    width = 250;\n    /** Cropper area height */\n    height = 200;\n    minWidth = 40;\n    minHeight = 40;\n    /** If this is not defined, the new image will be automatically defined. */\n    type?: string;\n    /** Background color( default: null), if is null in png is transparent but not in jpg. */\n    fill?: string | null;\n    /**\n     * Set anti-aliased (default: true)\n     * @deprecated this is not necessary as the cropper will automatically resize the image\n     * to the best quality\n     */\n    antiAliased = true;\n    autoCrop?: boolean;\n    output?: ImgOutput | ImgResolution = ImgResolution.Default;\n    /**\n     * Zoom out until the entire image fits into the cropping area.\n     * default: false\n     */\n    extraZoomOut?: boolean;\n    /**\n     * Emit event `error` if the file size in bytes for the limit.\n     * Note: It only works when the image is received from the `<input>` event.\n     */\n    maxFileSize?: number | null;\n    /**\n     * Whether the cropper area will be round.\n     * This implies that the cropper area will maintain its aspect ratio.\n     * default: false\n     */\n    round?: boolean;\n    /**\n     * Whether the cropper area is resizable.\n     * default: false\n     */\n    resizableArea?: boolean;\n    /**\n     * Keep the width and height of the growing area the same according\n     * to `ImgCropperConfig.width` and `ImgCropperConfig.height`\n     * default: false\n     */\n    keepAspectRatio?: boolean;\n    /**\n     * Whether the cropper area is responsive.\n     * By default, the width and height of the cropper area is fixed,\n     * so can use when the cropper area is larger than its container,\n     * otherwise this will bring problems when cropping.\n     */\n    responsiveArea?: boolean;\n}\n\n/**\n * The output image\n * With this option you can resize the output image.\n * If `width` or `height` are 0, this will be set automatically.\n * Both cannot be 0.\n */\nexport interface ImgOutput {\n    /**\n     * The cropped image will be resized to this `width`.\n     */\n    width: number;\n    /**\n     * Cropped image will be resized to this `height`.\n     */\n    height: number;\n}\n\n/** Image output */\nexport enum ImgResolution {\n    /**\n     * The output image will be equal to the initial size of the cropper area.\n     */\n    Default,\n    /** Just crop the image without resizing */\n    OriginalImage\n}\n\n/** Image output */\nexport enum ImgCropperError {\n    /** The loaded image exceeds the size limit set. */\n    Size,\n    /** The file loaded is not image. */\n    Type,\n    /** When the image has not been loaded. */\n    Other\n}\n\nexport interface ImgCropperEvent {\n    /** Cropped image data URL */\n    dataURL?: string;\n    name: string | null;\n    /** Filetype */\n    type?: string;\n    /** Cropped area width */\n    areaWidth: number;\n    /** Cropped area height */\n    areaHeight: number;\n    /** Cropped image width */\n    width: number;\n    /** Cropped image height */\n    height: number;\n    /** Original Image data URL */\n    originalDataURL?: string;\n    scale: number;\n    /** Current rotation in degrees */\n    rotation: number;\n    /** Size of the image in bytes */\n    size: number;\n    /** Scaled offset from the left edge of the image */\n    left: number;\n    /** Scaled offset from the top edge of the image */\n    top: number;\n    /**\n     * Scaled offset from the left edge of the image to center of area\n     * Can be used to set image position\n     */\n    xOrigin: number;\n    /**\n     * Scaled offset from the top edge of the image to center of area\n     * Can be used to set image position\n     */\n    yOrigin: number;\n    /** @deprecated Use `xOrigin & yOrigin` instead. */\n    position?: {\n        x: number\n        y: number\n    };\n}\n\nexport interface ImgCropperErrorEvent {\n    name?: string;\n    /** Size of the image in bytes */\n    size: number;\n    /** Filetype */\n    type: string;\n    /** Type of error */\n    error: ImgCropperError;\n    errorMsg?: string;\n}\n\ninterface ImgRect {\n    x: number;\n    y: number;\n    xc: number;\n    yc: number;\n    /** transform with */\n    wt: number;\n    ht: number;\n}\n\nexport interface ImgCropperLoaderConfig {\n    name?: string | null;\n    /** Filetype */\n    type?: string;\n    /** Cropped area width */\n    areaWidth?: number;\n    /** Cropped area height */\n    areaHeight?: number;\n    /** Cropped image width */\n    width?: number;\n    /** Cropped image height */\n    height?: number;\n    /** Original Image data URL */\n    originalDataURL: string;\n    scale?: number;\n    /** Current rotation in degrees */\n    rotation?: number;\n    /** Size of the image in bytes */\n    size?: number;\n    /** Offset from the left edge of the image to center of area */\n    xOrigin?: number;\n    /** Offset from the top edge of the image to center of area */\n    yOrigin?: number;\n}\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: \"nice-img-cropper, nice-image-cropper\",\n    templateUrl: \"image-cropper.template.html\",\n    styleUrls: [\"image-cropper.style.scss\"],\n    encapsulation: ViewEncapsulation.None\n})\nexport class NiceImageCropperComponent implements OnInit, OnDestroy {\n    static readonly и = \"NiceImageCropper\";\n\n    private _currentLoadConfig?: ImgCropperLoaderConfig;\n\n    /** Original image */\n    private _img: HTMLImageElement;\n    private offset?: {\n        x: number\n        y: number\n        left: number\n        top: number\n    };\n    private _scale?: number;\n    private _scal3Fix?: number;\n    private _minScale?: number;\n    private _maxScale?: number;\n    /** Initial config */\n    private _configPrimary: ImgCropperConfig;\n    private _config: ImgCropperConfig;\n    private _imgRect: ImgRect = {} as any;\n    private _rotation = 0;\n    // private _sizeInBytes: number | null;\n    private _isSliding: boolean;\n    /** Keeps track of the last pointer event that was captured by the crop area. */\n    private _lastPointerEvent: MouseEvent | TouchEvent | null;\n    private _startPointerEvent: {\n        x: number\n        y: number\n    } | null;\n    public _primaryAreaWidth: number;\n    public _primaryAreaHeight: number;\n\n    public _absoluteScale: number;\n\n    /**\n     * When is loaded image\n     * @internal\n     */\n    public _isLoadedImg: boolean;\n\n    /** When is loaded image & ready for crop */\n    public isLoaded: boolean;\n    /** When the cropper is ready to be interacted  */\n    public isReady: boolean;\n    public isCropped: boolean;\n\n    @ViewChild(\"_imgContainer\", { static: true })\n    private _imgContainer: ElementRef;\n\n    @ViewChild(\"_area\", { read: ElementRef })\n    private _areaRef: ElementRef;\n    @ViewChild(\"_imgCanvas\", { static: true })\n    private _imgCanvas: ElementRef<HTMLCanvasElement>;\n\n    @Input()\n    public set config(val: ImgCropperConfig) {\n        this._config = mergeDeep({}, new ImgCropperConfig(), val);\n        this._configPrimary = mergeDeep({}, this._config);\n        this._primaryAreaWidth = this.config.width;\n        this._primaryAreaHeight = this.config.height;\n        if (\n            this._config.round\n            && this.config.width !== this.config.height\n        ) {\n            throw new Error(`${NiceImageCropperComponent.и}: Both width and height must be equal when using \\`ImgCropperConfig.round = true\\``);\n        }\n        const maxFileSize = this._config.maxFileSize;\n        if (maxFileSize) {\n            this.maxFileSize = maxFileSize;\n        }\n    }\n    public get config(): ImgCropperConfig {\n        return this._config;\n    }\n    /** Set scale */\n    @Input()\n    public set scale(val: number | undefined) {\n        this.setScale(val);\n    }\n    public get scale(): number | undefined {\n        return this._scale;\n    }\n\n    /**\n     * Emit event `error` if the file size for the limit.\n     * Note: It only works when the image is received from the `<input>` event.\n     */\n    @Input()\n    public maxFileSize: number;\n\n    /** Get min scale */\n    public get minScale(): number | undefined {\n        return this._minScale;\n    }\n\n    @Output()\n    private readonly scaleChange = new EventEmitter<number>();\n\n    /** Emits minimum supported image scale */\n    // tslint:disable-next-line:no-output-rename\n    @Output(\"minScale\")\n    private readonly minScaleChange = new EventEmitter<number>();\n\n    /** Emits maximum supported image scale */\n    // tslint:disable-next-line:no-output-rename\n    @Output(\"maxScale\")\n    private readonly maxScaleChange = new EventEmitter<number>();\n\n    /** Emits when the image is loaded */\n    @Output()\n    private readonly imageLoaded = new EventEmitter<ImgCropperEvent>();\n\n    /** Emits when the cropper is ready to be interacted */\n    @Output()\n    private readonly ready = new EventEmitter<ImgCropperEvent>();\n\n    /** On crop new image */\n    @Output()\n    private readonly cropped = new EventEmitter<ImgCropperEvent>();\n\n    /** Emits when the cropper is cleaned */\n    @Output()\n    private readonly cleaned = new EventEmitter<void>();\n\n    /** Emit an error when the loaded image is not valid */\n    // tslint:disable-next-line: no-output-native\n    @Output()\n    private readonly error = new EventEmitter<ImgCropperErrorEvent>();\n\n    private _currentInputElement?: HTMLInputElement;\n\n    /** Emits whenever the component is destroyed. */\n    private readonly _destroy = new Subject<void>();\n\n    /** Used to subscribe to global move and end events */\n    protected _document: Document;\n\n    constructor(\n        private _renderer: Renderer2,\n        readonly _elementRef: ElementRef<HTMLElement>,\n        private cd: ChangeDetectorRef,\n        private _ngZone: NgZone,\n        @Inject(DOCUMENT) _document: any,\n        viewPortRuler: ViewportRuler\n    ) {\n        this._document = _document;\n        viewPortRuler.change()\n            .pipe(takeUntil(this._destroy))\n            .subscribe(() =>\n                this._ngZone.run(() => this.updateCropperPosition())\n            );\n    }\n\n    public ngOnInit(): void {\n        this._ngZone.runOutsideAngular(() => {\n            const element = this._imgContainer.nativeElement;\n            element.addEventListener(\"mousedown\", this._pointerDown, activeEventOptions);\n            element.addEventListener(\"touchstart\", this._pointerDown, activeEventOptions);\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this._destroy.next();\n        this._destroy.complete();\n        const element = this._imgContainer.nativeElement;\n        this._lastPointerEvent = null;\n        this._removeGlobalEvents();\n        element.removeEventListener(\"mousedown\", this._pointerDown, activeEventOptions);\n        element.removeEventListener(\"touchstart\", this._pointerDown, activeEventOptions);\n    }\n\n    /** Load image with canvas */\n    private _imgLoaded(imgElement: HTMLImageElement): void {\n        if (imgElement) {\n            this._img = imgElement;\n            const canvas = this._imgCanvas.nativeElement;\n            canvas.width = imgElement.width;\n            canvas.height = imgElement.height;\n            const ctx = canvas.getContext(\"2d\");\n            ctx.clearRect(0, 0, imgElement.width, imgElement.height);\n            ctx.drawImage(imgElement, 0, 0);\n\n            /** set min scale */\n            this._updateMinScale(canvas);\n            this._updateMaxScale();\n        }\n    }\n\n    private _setStylesForContImg(values: { x?: number, y?: number }) {\n        const newStyles = { } as any;\n        if (values.x != null && values.y != null) {\n            const rootRect = this._rootRect();\n            const x = rootRect.width / 2 - (values.x);\n            const y = rootRect.height / 2 - (values.y);\n\n            this._imgRect.x = (values.x);\n            this._imgRect.y = (values.y);\n            this._imgRect.xc = (x);\n            this._imgRect.yc = (y);\n\n        }\n        newStyles.transform = `translate3d(${(this._imgRect.x)}px,${(this._imgRect.y)}px, 0)`;\n        newStyles.transform += `scale(${this._scal3Fix})`;\n        newStyles.transformOrigin = `${this._imgRect.xc}px ${this._imgRect.yc}px 0`;\n        newStyles[\"-webkit-transform\"] = newStyles.transform;\n        newStyles[\"-webkit-transform-origin\"] = newStyles.transformOrigin;\n        for (const key in newStyles) {\n            if (newStyles.hasOwnProperty(key)) {\n                this._renderer.setStyle(this._imgContainer.nativeElement, key, newStyles[key]);\n            }\n        }\n    }\n    /**\n     * Update area and image position only if needed,\n     * this is used when window resize\n     */\n    public updateCropperPosition(): void {\n        if (this.isLoaded) {\n            this.updatePosition();\n            this._updateAreaIfNeeded();\n        }\n    }\n\n    /** Load Image from input event */\n    public selectInputEvent(img: Event) {\n        this._currentInputElement = img.target as HTMLInputElement;\n        const _img = img.target as HTMLInputElement;\n        if (_img.files && _img.files.length !== 1) {\n            return;\n        }\n        const fileSize = _img.files[0].size;\n        const fileName = _img.value.replace(/.*(\\/|\\\\)/, \"\");\n\n        if (this.maxFileSize && fileSize > this.maxFileSize) {\n            const cropEvent: ImgCropperErrorEvent = {\n                name: fileName,\n                type: _img.files[0].type,\n                size: fileSize,\n                error: ImgCropperError.Size\n            };\n            this.clean();\n            this.error.emit(cropEvent as ImgCropperErrorEvent);\n            return;\n        }\n\n        new Observable<ProgressEvent>(observer => {\n\n            const reader = new FileReader();\n\n            reader.onerror = err => observer.error(err);\n            reader.onabort = err => observer.error(err);\n            reader.onload = (ev) => setTimeout(() => {\n                observer.next(ev);\n                observer.complete();\n            });\n\n            reader.readAsDataURL(_img.files[0]);\n        })\n            .pipe(take(1), takeUntil(this._destroy))\n            .subscribe(\n                (loadEvent) => {\n                    const originalDataURL = (loadEvent.target as FileReader).result as string;\n\n                    this.loadImage({\n                        name: fileName,\n                        size: _img.files[0].size, // size in bytes\n                        type: this.config.type || _img.files[0].type,\n                        originalDataURL\n                    });\n\n                    this.cd.markForCheck();\n                },\n                () => {\n                    const cropEvent: ImgCropperErrorEvent = {\n                        name: fileName,\n                        size: fileSize,\n                        error: ImgCropperError.Other,\n                        errorMsg: \"The File could not be loaded.\",\n                        type: _img.files[0].type\n                    };\n                    this.clean();\n                    this.error.emit(cropEvent as ImgCropperErrorEvent);\n                }\n            );\n\n    }\n\n    /** Set the size of the image, the values can be 0 between 1, where 1 is the original size */\n    public setScale(size?: number, noAutoCrop?: boolean) {\n        // fix min scale\n        const newSize = size >= this.minScale && size <= 1 ? size : this.minScale;\n\n        // check\n        const changed = size != null && size !== this.scale && newSize !== this.scale;\n        this._scale = size;\n        if (!changed) {\n            return;\n        }\n        this._scal3Fix = newSize;\n        this._updateAbsoluteScale();\n        if (this.isLoaded) {\n            if (changed) {\n                const originPosition = {...this._imgRect};\n                this.offset = {\n                    x: originPosition.x,\n                    y: originPosition.y,\n                    left: originPosition.xc,\n                    top: originPosition.yc\n                };\n                this._setStylesForContImg({});\n                this._simulatePointerMove();\n            } else {\n                return;\n            }\n        } else if (this.minScale) {\n            this._setStylesForContImg({\n                ...this._getCenterPoints()\n            });\n        } else {\n            return;\n        }\n\n        this.scaleChange.emit(size);\n        if (!noAutoCrop) {\n            this._cropIfAutoCrop();\n        }\n\n    }\n\n    private _getCenterPoints() {\n        const root = this._elementRef.nativeElement as HTMLElement;\n        const img = this._imgCanvas.nativeElement;\n        const x = (root.offsetWidth - (img.width)) / 2;\n        const y = (root.offsetHeight - (img.height)) / 2;\n        return {\n            x,\n            y\n        };\n    }\n\n    /**\n     * Fit to screen\n     */\n    public fitToScreen() {\n        const container = this._elementRef.nativeElement as HTMLElement;\n        const min = {\n            width: container.offsetWidth,\n            height: container.offsetHeight\n        };\n        const { width, height } = this._img;\n        const minScale = {\n            width: min.width / width,\n            height: min.height / height\n        };\n        const result = Math.max(minScale.width, minScale.height);\n        this.setScale(result);\n    }\n\n    public fit() {\n        this.setScale(this.minScale);\n    }\n\n    private _pointerDown = (event: TouchEvent | MouseEvent) => {\n        // Don't do anything if the\n        // user is using anything other than the main mouse button.\n        if (this._isSliding || (!isTouchEvent(event) && event.button !== 0)) {\n            return;\n        }\n\n        this._ngZone.run(() => {\n            this._isSliding = true;\n            this.offset = {\n                x: this._imgRect.x,\n                y: this._imgRect.y,\n                left: this._imgRect.xc,\n                top: this._imgRect.yc\n            };\n            this._lastPointerEvent = event;\n            this._startPointerEvent = getGesturePointFromEvent(event);\n            event.preventDefault();\n            this._bindGlobalEvents(event);\n        });\n\n    }\n\n    /**\n     * Simulate pointerMove with clientX = 0 and clientY = 0,\n     * this is used by `setScale` and `rotate`\n     */\n    private _simulatePointerMove() {\n        this._isSliding = true;\n        this._startPointerEvent = {\n            x: 0,\n            y: 0\n        };\n        this._pointerMove({\n            clientX: 0,\n            clientY: 0,\n            type: \"n\",\n            preventDefault: () => {}\n        } as MouseEvent);\n        this._isSliding = false;\n        this._startPointerEvent = null;\n    }\n\n    public _markForCheck() {\n        this.cd.markForCheck();\n    }\n\n    /**\n     * Called when the user has moved their pointer after\n     * starting to drag.\n     */\n    private _pointerMove = (event: TouchEvent | MouseEvent) => {\n        if (this._isSliding) {\n            event.preventDefault();\n            this._lastPointerEvent = event;\n            let x: number | undefined;\n            let y: number | undefined;\n            const canvas = this._imgCanvas.nativeElement;\n            const scaleFix = this._scal3Fix;\n            const config = this.config;\n            const startP = this.offset;\n            const point = getGesturePointFromEvent(event);\n            const deltaX = point.x - this._startPointerEvent.x;\n            const deltaY = point.y - this._startPointerEvent.y;\n            if (!scaleFix || !startP) {\n                return;\n            }\n\n            const isMinScaleY = canvas.height * scaleFix < config.height && config.extraZoomOut;\n            const isMinScaleX = canvas.width * scaleFix < config.width && config.extraZoomOut;\n\n            const limitLeft = (config.width / 2 / scaleFix) >= startP.left - (deltaX / scaleFix);\n            const limitRight = (config.width / 2 / scaleFix) +\n                (canvas.width) - (startP.left - (deltaX / scaleFix)) <= config.width / scaleFix;\n            const limitTop = ((config.height / 2 / scaleFix) >= (startP.top - (deltaY / scaleFix)));\n            const limitBottom = (\n                ((config.height / 2 / scaleFix) + (canvas.height) - (startP.top - (deltaY / scaleFix))) <= (config.height / scaleFix)\n            );\n\n            // Limit for left\n            if ((limitLeft && !isMinScaleX) || (!limitLeft && isMinScaleX)) {\n                x = startP.x + (startP.left) - (config.width / 2 / scaleFix);\n            }\n\n            // Limit for right\n            if ((limitRight && !isMinScaleX) || (!limitRight && isMinScaleX)) {\n                x = startP.x + (startP.left) + (config.width / 2 / scaleFix) - canvas.width;\n            }\n\n            // Limit for top\n            if ((limitTop && !isMinScaleY) || (!limitTop && isMinScaleY)) {\n                y = startP.y + (startP.top) - (config.height / 2 / scaleFix);\n            }\n\n            // Limit for bottom\n            if ((limitBottom && !isMinScaleY) || (!limitBottom && isMinScaleY)) {\n                y = startP.y + (startP.top) + (config.height / 2 / scaleFix) - canvas.height;\n            }\n\n            // When press shiftKey, deprecated\n            // if (event.srcEvent && event.srcEvent.shiftKey) {\n            //   if (Math.abs(event.deltaX) === Math.max(Math.abs(event.deltaX), Math.abs(event.deltaY))) {\n            //     y = this.offset.top;\n            //   } else {\n            //     x = this.offset.left;\n            //   }\n            // }\n\n            if (x === void 0) { x = (deltaX / scaleFix) + (startP.x); }\n            if (y === void 0) { y = (deltaY / scaleFix) + (startP.y); }\n            this._setStylesForContImg({\n                x, y\n            });\n        }\n    }\n\n    public updatePosition(): void;\n    public updatePosition(xOrigin: number, yOrigin: number): void;\n    public updatePosition(xOrigin?: number, yOrigin?: number): void {\n        const hostRect = this._rootRect();\n        const areaRect = this._areaCropperRect();\n        const areaWidth = areaRect.width > hostRect.width\n            ? hostRect.width\n            : areaRect.width;\n        const areaHeight = areaRect.height > hostRect.height\n            ? hostRect.height\n            : areaRect.height;\n        let x: number;\n        let y: number;\n        if (xOrigin == null && yOrigin == null) {\n            xOrigin = this._imgRect.xc;\n            yOrigin = this._imgRect.yc;\n        }\n        x = (areaRect.left - hostRect.left);\n        y = (areaRect.top - hostRect.top);\n        x -= (xOrigin - (areaWidth / 2));\n        y -= (yOrigin - (areaHeight / 2));\n\n        this._setStylesForContImg({\n            x, y\n        });\n    }\n\n    public _slideEnd() {\n        this._cropIfAutoCrop();\n    }\n\n    private _cropIfAutoCrop() {\n        if (this.config.autoCrop) {\n            this.crop();\n        }\n    }\n\n    /** + */\n    public zoomIn() {\n        const scale = this._scal3Fix + .05;\n        if (scale > this.minScale && scale <= this._maxScale) {\n            this.setScale(scale);\n        } else {\n            this.setScale(this._maxScale);\n        }\n    }\n\n    /** Clean the img cropper */\n    public clean() {\n        // fix choosing the same image does not load\n        if (this._currentInputElement) {\n            this._currentInputElement.value = \"\";\n            this._currentInputElement = null;\n        }\n        if (this.isLoaded) {\n            this._imgRect = { } as any;\n            this.offset = undefined;\n            this.scale = undefined as any;\n            this._scal3Fix = undefined;\n            this._rotation = 0;\n            this._minScale = undefined;\n            this._isLoadedImg = false;\n            this.isLoaded = false;\n            this.isCropped = false;\n            this._currentLoadConfig = undefined;\n            this.config = this._configPrimary;\n            const canvas = this._imgCanvas.nativeElement;\n            canvas.width = 0;\n            canvas.height = 0;\n            this.cleaned.emit(null);\n            this.cd.markForCheck();\n        }\n    }\n\n    /** - */\n    public zoomOut() {\n        const scale = this._scal3Fix - .05;\n        if (scale > this.minScale && scale <= this._maxScale) {\n            this.setScale(scale);\n        } else {\n            this.fit();\n        }\n    }\n    public center() {\n        const newStyles = {\n            ...this._getCenterPoints()\n        };\n        this._setStylesForContImg(newStyles);\n        this._cropIfAutoCrop();\n    }\n    /**\n     * load an image from a given configuration,\n     * or from the result of a cropped image\n     */\n    public loadImage(config: ImgCropperLoaderConfig | string, fn?: () => void) {\n        this.clean();\n        const _config = this._currentLoadConfig = typeof config === \"string\"\n            ? { originalDataURL: config }\n            : { ...config };\n        let src = _config.originalDataURL;\n        this._primaryAreaWidth = this._configPrimary.width;\n        this._primaryAreaHeight = this._configPrimary.height;\n        if (_config.areaWidth && _config.areaHeight) {\n            this.config.width = _config.areaWidth;\n            this.config.height = _config.areaHeight;\n        }\n        src = normalizeSVG(src);\n\n        const img = createHtmlImg(src);\n\n        const cropEvent = { ..._config } as ImgCropperEvent;\n\n        new Observable<void>(observer => {\n\n            img.onerror = err => observer.error(err);\n            img.onabort = err => observer.error(err);\n            img.onload = () => observer.next(null);\n        })\n            .pipe(take(1), takeUntil(this._destroy))\n            .subscribe(\n                () => {\n                    this._imgLoaded(img);\n                    this._isLoadedImg = true;\n                    this.imageLoaded.emit(cropEvent);\n                    this.cd.markForCheck();\n                    this._ngZone.runOutsideAngular(() => {\n                        this._ngZone\n                            .onStable\n                            .asObservable()\n                            .pipe(take(1), takeUntil(this._destroy))\n                            .subscribe(\n                                () => setTimeout(() => this._ngZone.run(() => this._positionImg(cropEvent, fn)))\n                            );\n                    });\n                },\n                () => {\n                    const error: ImgCropperErrorEvent = {\n                        name: _config.name,\n                        error: ImgCropperError.Type,\n                        type: _config.type,\n                        size: _config.size\n                    };\n                    this.error.emit(error);\n                }\n            );\n    }\n\n    private _updateAreaIfNeeded() {\n        if (!this._config.responsiveArea) {\n            return;\n        }\n\n        const rootRect = this._rootRect();\n        const areaRect = this._areaCropperRect();\n        const minWidth = this.config.minWidth || 1;\n        const minHeight = this.config.minHeight || 1;\n        if (!(\n            areaRect.width > rootRect.width\n            || areaRect.height > rootRect.height\n            || areaRect.width < this._primaryAreaWidth\n            || areaRect.height < this._primaryAreaHeight\n        )) {\n            return;\n        }\n        const areaWidthConf = Math.max(this.config.width, minWidth);\n        const areaWidthMax = Math.max(rootRect.width, minWidth);\n        const minHost = Math.min(\n            Math.max(rootRect.width, minWidth), Math.max(rootRect.height, minHeight)\n        );\n        const currentScale = this._scal3Fix;\n        let newScale = 0;\n        const roundConf = this.config.round;\n\n        if (roundConf) {\n            this.config.width = this.config.height = minHost;\n        } else {\n            if (areaWidthConf === areaRect.width) {\n                if (areaWidthMax > this._primaryAreaWidth) {\n                    this.config.width = this._primaryAreaWidth;\n                    this.config.height = (this._primaryAreaWidth * areaRect.height) / areaRect.width;\n                    newScale = (currentScale * this._primaryAreaWidth) / areaRect.width;\n                } else {\n                    this.config.width = areaWidthMax;\n                    this.config.height = (areaWidthMax * areaRect.height) / areaRect.width;\n                    newScale = (currentScale * areaWidthMax) / areaRect.width;\n                }\n                this._updateMinScale();\n                this._updateMaxScale();\n                this.setScale(newScale, true);\n                this._markForCheck();\n            }\n        }\n    }\n\n    private _updateAbsoluteScale() {\n        const scale = this._scal3Fix / (this.config.width / this._primaryAreaWidth);\n        this._absoluteScale = scale;\n    }\n\n    /**\n     * Load Image from URL\n     * @deprecated Use `loadImage` instead of `setImageUrl`\n     * @param src URL\n     * @param fn function that will be called before emit the event loaded\n     */\n    public setImageUrl(src: string, fn?: () => void) {\n        this.loadImage(src, fn);\n    }\n\n    private _positionImg(cropEvent: ImgCropperEvent, fn?: () => void) {\n        const loadConfig = this._currentLoadConfig;\n        this._updateMinScale(this._imgCanvas.nativeElement);\n        this._updateMaxScale();\n        this.isLoaded = false;\n        if (fn) {\n            fn();\n        } else {\n            if (loadConfig.scale) {\n                this.setScale(loadConfig.scale, true);\n            } else {\n                this.setScale(this.minScale, true);\n            }\n            this.rotate(loadConfig.rotation || 0);\n            this._updateAreaIfNeeded();\n            this._markForCheck();\n            this._ngZone.runOutsideAngular(() => {\n                this._ngZone\n                    .onStable\n                    .asObservable()\n                    .pipe(take(1), takeUntil(this._destroy))\n                    .subscribe(() => {\n                        if (loadConfig.xOrigin != null && loadConfig.yOrigin != null) {\n                            this.updatePosition(loadConfig.xOrigin, loadConfig.yOrigin);\n                        }\n                        this._updateAreaIfNeeded();\n                        this.isLoaded = true;\n                        this._cropIfAutoCrop();\n                        this._ngZone.run(() => {\n                            this._markForCheck();\n                            this.ready.emit(cropEvent);\n                        });\n                    });\n            });\n        }\n    }\n\n    public rotate(degrees: number) {\n        let validDegrees = _normalizeDegrees(degrees);\n        // If negative convert to positive\n        if (validDegrees < 0) {\n            validDegrees += 360;\n        }\n        const newRotation = _normalizeDegrees((this._rotation || 0) + validDegrees);\n        if (newRotation === this._rotation) {\n            return;\n        }\n        const degreesRad = validDegrees * Math.PI / 180;\n        const canvas = this._imgCanvas.nativeElement;\n        const canvasClon = createCanvasImg(canvas);\n        const ctx = canvas.getContext(\"2d\");\n        this._rotation = newRotation;\n\n        // clear\n        ctx.clearRect(0, 0, canvasClon.width, canvasClon.height);\n\n        // rotate canvas image\n        const transform = `rotate(${validDegrees}deg) scale(${1 / this._scal3Fix})`;\n        const transformOrigin = `${this._imgRect.xc}px ${this._imgRect.yc}px 0`;\n        canvas.style.transform = transform;\n        // tslint:disable-next-line: deprecation\n        canvas.style.webkitTransform = transform;\n        canvas.style.transformOrigin = transformOrigin;\n        // tslint:disable-next-line: deprecation\n        canvas.style.webkitTransformOrigin = transformOrigin;\n\n        const { left, top } = canvas.getBoundingClientRect() as DOMRect;\n\n        // save rect\n        const canvasRect = canvas.getBoundingClientRect();\n\n        // remove rotate styles\n        canvas.removeAttribute(\"style\");\n\n        // set w & h\n        const w = canvasRect.width;\n        const h = canvasRect.height;\n        ctx.canvas.width = w;\n        ctx.canvas.height = h;\n\n        // clear\n        ctx.clearRect(0, 0, w, h);\n\n        // translate and rotate\n        ctx.translate(w / 2, h / 2);\n        ctx.rotate(degreesRad);\n        ctx.drawImage(canvasClon, -canvasClon.width / 2, -canvasClon.height / 2);\n\n        // Update min scale\n        this._updateMinScale(canvas);\n        this._updateMaxScale();\n\n        // set the minimum scale, only if necessary\n        if (this.scale < this.minScale) {\n            this.setScale(0, true);\n        } //                ↑ no AutoCrop\n\n        const rootRect = this._rootRect();\n\n        this._setStylesForContImg({\n            x: (left - rootRect.left),\n            y: (top - rootRect.top)\n        });\n\n        // keep image inside the frame\n        const originPosition = {...this._imgRect};\n        this.offset = {\n            x: originPosition.x,\n            y: originPosition.y,\n            left: originPosition.xc,\n            top: originPosition.yc\n        };\n        this._setStylesForContImg({});\n        this._simulatePointerMove();\n\n        this._cropIfAutoCrop();\n    }\n\n    public _updateMinScale(canvas?: HTMLCanvasElement) {\n        if (!canvas) {\n            canvas = this._imgCanvas.nativeElement;\n        }\n        const config = this.config;\n        const minScale = (config.extraZoomOut ? Math.min : Math.max)(\n            config.width / canvas.width,\n            config.height / canvas.height);\n        this._minScale = minScale;\n        this.minScaleChange.emit(minScale);\n    }\n\n    private _updateMaxScale() {\n        const maxScale = (this.config.width / this._primaryAreaWidth);\n        this._maxScale = maxScale;\n        this.maxScaleChange.emit(maxScale);\n    }\n\n    /**\n     * Resize & crop image\n     */\n    public crop(config?: ImgCropperConfig): ImgCropperEvent {\n        const newConfig = config\n            ? mergeDeep({ }, this.config || new ImgCropperConfig(), config) : this.config;\n        const cropEvent = this._imgCrop(newConfig);\n        this.cd.markForCheck();\n        return cropEvent;\n    }\n\n    /**\n     * @docs-private\n     */\n    private _imgCrop(myConfig: ImgCropperConfig) {\n        const canvasElement: HTMLCanvasElement = document.createElement(\"canvas\");\n        const areaRect = this._areaCropperRect();\n        const canvasRect = this._canvasRect();\n        const scaleFix = this._scal3Fix;\n        const left = (areaRect.left - canvasRect.left) / scaleFix;\n        const top = (areaRect.top - canvasRect.top) / scaleFix;\n        const { output } = myConfig;\n        const currentImageLoadConfig = this._currentLoadConfig;\n        const area = {\n            width: myConfig.width,\n            height: myConfig.height\n        };\n        canvasElement.width = area.width / scaleFix;\n        canvasElement.height = area.height / scaleFix;\n        const ctx = canvasElement.getContext(\"2d\");\n        if (myConfig.fill) {\n            ctx.fillStyle = myConfig.fill;\n            ctx.fillRect(0, 0, canvasElement.width, canvasElement.height);\n        }\n        ctx.drawImage(this._imgCanvas.nativeElement,\n            -(left), -(top),\n        );\n        const result = canvasElement;\n        if (myConfig.output === ImgResolution.Default) {\n            resizeCanvas(\n                result,\n                this._configPrimary.width,\n                this._configPrimary.height);\n        } else if (typeof output === \"object\") {\n            if (output.width && output.height) {\n                resizeCanvas(result, output.width, output.height);\n            } else if (output.width) {\n                const newHeight = area.height * output.width / area.width;\n                resizeCanvas(result, output.width, newHeight);\n            } else if (output.height) {\n                const newWidth = area.width * output.height / area.height;\n                resizeCanvas(result, newWidth, output.height);\n            }\n        }\n        const type = currentImageLoadConfig.originalDataURL.startsWith(\"http\")\n            ? currentImageLoadConfig.type || myConfig.type\n            : myConfig.type || currentImageLoadConfig.type;\n        const dataURL = result.toDataURL(type);\n        const cropEvent: ImgCropperEvent = {\n            dataURL,\n            type,\n            name: currentImageLoadConfig.name,\n            areaWidth: this._primaryAreaWidth,\n            areaHeight: this._primaryAreaHeight,\n            width: result.width,\n            height: result.height,\n            originalDataURL: currentImageLoadConfig.originalDataURL,\n            scale: this._absoluteScale,\n            rotation: this._rotation,\n            left: (areaRect.left - canvasRect.left) / this._scal3Fix,\n            top: (areaRect.top - canvasRect.top) / this._scal3Fix,\n            size: currentImageLoadConfig.size,\n            xOrigin: this._imgRect.xc,\n            yOrigin: this._imgRect.yc,\n            position: {\n                x: this._imgRect.xc,\n                y: this._imgRect.yc\n            }\n        };\n\n        this.isCropped = true;\n        this.cropped.emit(cropEvent);\n        return cropEvent;\n    }\n\n    public _rootRect(): DOMRect {\n        return this._elementRef.nativeElement.getBoundingClientRect() as DOMRect;\n    }\n\n    public _areaCropperRect(): DOMRect {\n        return this._areaRef.nativeElement.getBoundingClientRect() as DOMRect;\n    }\n\n    public _canvasRect(): DOMRect {\n        return this._imgCanvas.nativeElement.getBoundingClientRect();\n    }\n\n\n    /** Called when the user has lifted their pointer. */\n    private _pointerUp = (event: TouchEvent | MouseEvent) => {\n        if (this._isSliding) {\n            event.preventDefault();\n            this._removeGlobalEvents();\n            this._isSliding = false;\n            this._startPointerEvent = null;\n            this._cropIfAutoCrop();\n        }\n    }\n\n    /** Called when the window has lost focus. */\n    private _windowBlur = () => {\n        // If the window is blurred while dragging we need to stop dragging because the\n        // browser won't dispatch the `mouseup` and `touchend` events anymore.\n        if (this._lastPointerEvent) {\n            this._pointerUp(this._lastPointerEvent);\n        }\n    }\n\n    private _bindGlobalEvents(triggerEvent: TouchEvent | MouseEvent) {\n        const element = this._document;\n        const isTouch = isTouchEvent(triggerEvent);\n        const moveEventName = isTouch ? \"touchmove\" : \"mousemove\";\n        const endEventName = isTouch ? \"touchend\" : \"mouseup\";\n        element.addEventListener(moveEventName, this._pointerMove, activeEventOptions);\n        element.addEventListener(endEventName, this._pointerUp, activeEventOptions);\n\n        if (isTouch) {\n            element.addEventListener(\"touchcancel\", this._pointerUp, activeEventOptions);\n        }\n\n        const window = this._getWindow();\n\n        if (typeof window !== \"undefined\" && window) {\n            window.addEventListener(\"blur\", this._windowBlur);\n        }\n    }\n\n    /** Removes any global event listeners that we may have added. */\n    private _removeGlobalEvents() {\n        const element = this._document;\n        element.removeEventListener(\"mousemove\", this._pointerMove, activeEventOptions);\n        element.removeEventListener(\"mouseup\", this._pointerUp, activeEventOptions);\n        element.removeEventListener(\"touchmove\", this._pointerMove, activeEventOptions);\n        element.removeEventListener(\"touchend\", this._pointerUp, activeEventOptions);\n        element.removeEventListener(\"touchcancel\", this._pointerUp, activeEventOptions);\n\n        const window = this._getWindow();\n\n        if (typeof window !== \"undefined\" && window) {\n            window.removeEventListener(\"blur\", this._windowBlur);\n        }\n    }\n\n    /** Use defaultView of injected document if available or fallback to global window reference */\n    private _getWindow(): Window {\n        return this._document.defaultView || window;\n    }\n\n}\n\n/**\n * Normalize degrees for cropper rotation\n * @docs-private\n */\nexport function _normalizeDegrees(n: number) {\n    const de = n % 360;\n    if (de % 90) {\n        throw new Error(`LyCropper: Invalid \\`${n}\\` degree, only accepted values: 0, 90, 180, 270 & 360.`);\n    }\n    return de;\n}\n\n/**\n * @docs-private\n */\nfunction createCanvasImg(img: HTMLCanvasElement | HTMLImageElement) {\n\n    // create a new canvas\n    const newCanvas = document.createElement(\"canvas\");\n    const context = newCanvas.getContext(\"2d\");\n\n    // set dimensions\n    newCanvas.width = img.width;\n    newCanvas.height = img.height;\n\n    // apply the old canvas to the new one\n    context.drawImage(img, 0, 0);\n\n    // return the new canvas\n    return newCanvas;\n}\n\n\nconst DATA_IMAGE_SVG_PREFIX = \"data:image/svg+xml;base64,\";\n\nfunction normalizeSVG(dataURL: string) {\n    if (window.atob && isSvgImage(dataURL)) {\n        const len = dataURL.length / 5;\n        const text = window.atob(dataURL.replace(DATA_IMAGE_SVG_PREFIX, \"\"));\n        const span = document.createElement(\"span\");\n        span.innerHTML = text;\n        const svg = span.querySelector(\"svg\");\n        span.setAttribute(\"style\", \"display:none\");\n        document.body.appendChild(span);\n        const width = parseFloat(getComputedStyle(svg).width) || 1;\n        const height = parseFloat(getComputedStyle(svg).height) || 1;\n        const max = Math.max(width, height);\n\n        svg.setAttribute(\"width\", `${len / (width / max)}px`);\n        svg.setAttribute(\"height\", `${len / (height / max)}px`);\n        const result = DATA_IMAGE_SVG_PREFIX + window.btoa(span.innerHTML);\n        document.body.removeChild(span);\n        return result;\n    }\n    return dataURL;\n}\n\nfunction isSvgImage(dataUrl: string) {\n    return dataUrl.startsWith(DATA_IMAGE_SVG_PREFIX);\n}\n\nfunction createHtmlImg(src: string) {\n    const img = new Image();\n    img.crossOrigin = \"anonymous\";\n    img.src = src;\n    return img;\n}\n\n\nfunction getGesturePointFromEvent(event: TouchEvent | MouseEvent) {\n\n    // `touches` will be empty for start/end events so we have to fall back to `changedTouches`.\n    const point = isTouchEvent(event)\n        ? (event.touches[0] || event.changedTouches[0])\n        : event;\n\n    return {\n        x: point.clientX,\n        y: point.clientY\n    };\n}\n\n/** Returns whether an event is a touch event. */\nfunction isTouchEvent(event: MouseEvent | TouchEvent): event is TouchEvent {\n    return event.type[0] === \"t\";\n}\n\nexport function round(n: number) {\n    return Math.round(n);\n}\n\n/**\n * Simple object check.\n * @param item\n */\nfunction isObject(item) {\n    return (item && typeof item === \"object\" && !Array.isArray(item));\n}\n\nexport function mergeDeep<T, U>(target: T, source: U): T & U;\nexport function mergeDeep<T, U, V>(target: T, source1: U, source2: V): T & U & V;\nexport function mergeDeep<T, U, V, W>(target: T, source1: U, source2: V, source3: W): T & U & V & W;\nexport function mergeDeep(target: object, ...sources: any[]): any;\n\n/**\n * Deep merge two objects.\n * @param target\n * @param ...sources\n */\nexport function mergeDeep(target: any, ...sources: any[]) {\n    if (!sources.length) { return target; }\n    const source = sources.shift();\n\n    if (isObject(target) && isObject(source)) {\n        for (const key in source) {\n            if (isObject(source[key])) {\n                if (!target[key]) { Object.assign(target, { [key]: {} }); }\n                mergeDeep(target[key], source[key]);\n            } else {\n                Object.assign(target, { [key]: source[key] });\n            }\n        }\n    }\n\n    return mergeDeep(target, ...sources);\n}\n\n\n/**\n * We have the cropper area in the same file to fix the build\n */\n\n@Component({\n    selector: \"nice-cropper-area\",\n    templateUrl: \"./image-cropper-area.template.html\",\n    styleUrls: [\"./image-cropper-area.style.scss\"],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NiceCropperAreaComponent implements OnDestroy {\n    @ViewChild(\"resizer\")\n    private readonly _resizer?: ElementRef;\n\n    @Input()\n    public keepAspectRatio: boolean;\n\n    @Input()\n    @HostBinding(\"class.round\")\n    public round: boolean;\n\n    /** Used to subscribe to global move and end events */\n    protected _document: Document;\n    private _isSliding: boolean;\n\n    /** Keeps track of the last pointer event that was captured by the crop area. */\n    private _lastPointerEvent: MouseEvent | TouchEvent | null;\n    private _startPointerEvent: {\n        x: number\n        y: number\n    } | null;\n    private _currentWidth: number;\n    private _currentHeight: number;\n    private _startAreaRect: DOMRect;\n    private _startImgRect: DOMRect;\n\n    constructor(\n        @Inject(DOCUMENT) _document: any,\n        private readonly _elementRef: ElementRef,\n        private readonly _cropper: NiceImageCropperComponent,\n        private readonly _ngZone: NgZone,\n    ) {\n        this._document = _document;\n    }\n\n    private _resizableArea: boolean;\n\n    @Input()\n    public set resizableArea(val: boolean) {\n        if (val !== this._resizableArea) {\n            this._resizableArea = val;\n            Promise.resolve(null).then(() => {\n                if (val) {\n                    this._removeResizableArea();\n                    this._addResizableArea();\n                } else {\n                    this._removeResizableArea();\n                }\n            });\n        }\n    }\n    public get resizableArea() {\n        return this._resizableArea;\n    }\n\n    public ngOnDestroy() {\n        this._removeResizableArea();\n    }\n\n    private _addResizableArea() {\n        this._ngZone.runOutsideAngular(() => {\n            const element = this._resizer.nativeElement;\n            element.addEventListener(\"mousedown\", this._pointerDown, activeEventOptions);\n            element.addEventListener(\"touchstart\", this._pointerDown, activeEventOptions);\n        });\n    }\n\n    private _removeResizableArea() {\n        const element = this._resizer?.nativeElement;\n        if (element) {\n            this._lastPointerEvent = null;\n            this._removeGlobalEvents();\n            element.removeEventListener(\"mousedown\", this._pointerDown, activeEventOptions);\n            element.removeEventListener(\"touchstart\", this._pointerDown, activeEventOptions);\n        }\n    }\n\n    private _pointerDown = (event: MouseEvent | TouchEvent) => {\n        // Don't do anything if the\n        // user is using anything other than the main mouse button.\n        if (this._isSliding || (!isTouchEvent(event) && event.button !== 0)) {\n            return;\n        }\n\n        event.preventDefault();\n\n        this._ngZone.run(() => {\n            this._isSliding = true;\n            this._lastPointerEvent = event;\n            this._startPointerEvent = getGesturePointFromEvent(event);\n            this._startAreaRect = this._cropper._areaCropperRect();\n            this._startImgRect = this._cropper._canvasRect();\n            event.preventDefault();\n            this._bindGlobalEvents(event);\n        });\n    }\n\n    private _pointerMove = (event: MouseEvent | TouchEvent) => {\n        if (this._isSliding) {\n            event.preventDefault();\n            this._lastPointerEvent = event;\n            const element: HTMLDivElement = this._elementRef.nativeElement;\n            const {width, height, minWidth, minHeight} = this._cropper.config;\n            const point = getGesturePointFromEvent(event);\n            const deltaX = point.x - this._startPointerEvent.x;\n            const deltaY = point.y - this._startPointerEvent.y;\n            const startAreaRect = this._startAreaRect;\n            const startImgRect = this._startImgRect;\n            const isRound = this.round;\n            const keepAspectRatio = this._cropper.config.keepAspectRatio || event.shiftKey;\n            let newWidth = 0;\n            let newHeight = 0;\n            const rootRect = this._cropper._rootRect();\n\n            if (isRound) {\n                // The distance from the center of the cropper area to the pointer\n                const originX = ((width / 2 / Math.sqrt(2)) + deltaX);\n                const originY = ((height / 2 / Math.sqrt(2)) + deltaY);\n\n                // Leg\n                const side = Math.sqrt(originX ** 2 + originY ** 2);\n                newWidth = newHeight = side * 2;\n\n            } else if (keepAspectRatio) {\n                newWidth = width + deltaX * 2;\n                newHeight = height + deltaY * 2;\n                if (width !== height) {\n                    if (width > height) {\n                        newHeight = height / (width / newWidth);\n                    } else if (height > width) {\n                        newWidth = width / (height / newHeight);\n                    }\n                } else {\n                    newWidth = newHeight = Math.max(newWidth, newHeight);\n                }\n            } else {\n                newWidth = width + deltaX * 2;\n                newHeight = height + deltaY * 2;\n            }\n\n            // To min width\n            if (newWidth < minWidth) {\n                newWidth = minWidth;\n            }\n            // To min height\n            if (newHeight < minHeight) {\n                newHeight = minHeight;\n            }\n\n            // Do not overflow the cropper area\n            const centerX = startAreaRect.x + startAreaRect.width / 2;\n            const centerY = startAreaRect.y + startAreaRect.height / 2;\n            const topOverflow = startImgRect.y > centerY - (newHeight / 2);\n            const bottomOverflow = centerY + (newHeight / 2) > startImgRect.bottom;\n            const minHeightOnOverflow = Math.min((centerY - startImgRect.y) * 2, (startImgRect.bottom - centerY) * 2);\n            const leftOverflow = startImgRect.x > centerX - (newWidth / 2);\n            const rightOverflow = centerX + (newWidth / 2) > startImgRect.right;\n            const minWidthOnOverflow = Math.min((centerX - startImgRect.x) * 2, (startImgRect.right - centerX) * 2);\n            const minOnOverflow = Math.min(minWidthOnOverflow, minHeightOnOverflow);\n            if (round) {\n                if (topOverflow || bottomOverflow || leftOverflow || rightOverflow) {\n                    newHeight = newWidth = minOnOverflow;\n                }\n            } else if (keepAspectRatio) {\n                const newNewWidth: number[] = [];\n                const newNewHeight: number[] = [];\n                if ((topOverflow || bottomOverflow) && Math.min()) {\n                    newHeight = minHeightOnOverflow;\n                    newNewHeight.push(newHeight);\n                    newWidth = width / (height / minHeightOnOverflow);\n                    newNewWidth.push(newWidth);\n                }\n                if ((leftOverflow || rightOverflow)) {\n                    newWidth = minWidthOnOverflow;\n                    newNewWidth.push(newWidth);\n                    newHeight = height / (width / minWidthOnOverflow);\n                    newNewHeight.push(newHeight);\n                }\n                if (newNewWidth.length === 2) {\n                    newWidth = Math.min(...newNewWidth);\n                }\n                if (newNewHeight.length === 2) {\n                    newHeight = Math.min(...newNewHeight);\n                }\n            } else {\n                if (topOverflow || bottomOverflow) {\n                    newHeight = minHeightOnOverflow;\n                }\n                if (leftOverflow || rightOverflow) {\n                    newWidth = minWidthOnOverflow;\n                }\n            }\n\n            // Do not overflow the container\n            if (round) {\n                const min = Math.min(rootRect.width, rootRect.height);\n                if (newWidth > min) {\n                    newWidth = newHeight = min;\n                } else if (newHeight > min) {\n                    newWidth = newHeight = min;\n                }\n            } else if (keepAspectRatio) {\n                if (newWidth > rootRect.width) {\n                    newWidth = rootRect.width;\n                    newHeight = height / (width / rootRect.width);\n                } else if (newHeight > rootRect.height) {\n                    newWidth = width / (height / rootRect.height);\n                    newHeight = rootRect.height;\n                }\n            } else {\n                if (newWidth > rootRect.width) {\n                    newWidth = rootRect.width;\n                } else if (newHeight > rootRect.height) {\n                    newHeight = rootRect.height;\n                }\n            }\n\n\n            // round values\n            newWidth = Math.round(newWidth);\n            newHeight = Math.round(newHeight);\n\n            element.style.width = `${newWidth}px`;\n            element.style.height = `${newHeight}px`;\n            this._currentWidth = newWidth;\n            this._currentHeight = newHeight;\n        }\n    }\n\n    /** Called when the user has lifted their pointer. */\n    private _pointerUp = (event: TouchEvent | MouseEvent) => {\n        if (this._isSliding) {\n            event.preventDefault();\n            this._removeGlobalEvents();\n            this._cropper._primaryAreaWidth = this._cropper.config.width = this._currentWidth;\n            this._cropper._primaryAreaHeight = this._cropper.config.height = this._currentHeight;\n            this._cropper.config = this._cropper.config;\n            this._cropper._updateMinScale();\n            this._isSliding = false;\n            this._startPointerEvent = null;\n        }\n    }\n\n    /** Called when the window has lost focus. */\n    private _windowBlur = () => {\n        // If the window is blurred while dragging we need to stop dragging because the\n        // browser won't dispatch the `mouseup` and `touchend` events anymore.\n        if (this._lastPointerEvent) {\n            this._pointerUp(this._lastPointerEvent);\n        }\n    }\n\n    private _bindGlobalEvents(triggerEvent: TouchEvent | MouseEvent) {\n        const element = this._document;\n        const isTouch = isTouchEvent(triggerEvent);\n        const moveEventName = isTouch ? \"touchmove\" : \"mousemove\";\n        const endEventName = isTouch ? \"touchend\" : \"mouseup\";\n        element.addEventListener(moveEventName, this._pointerMove, activeEventOptions);\n        element.addEventListener(endEventName, this._pointerUp, activeEventOptions);\n\n        if (isTouch) {\n            element.addEventListener(\"touchcancel\", this._pointerUp, activeEventOptions);\n        }\n\n        const window = this._getWindow();\n\n        if (typeof window !== \"undefined\" && window) {\n            window.addEventListener(\"blur\", this._windowBlur);\n        }\n    }\n\n    /** Removes any global event listeners that we may have added. */\n    private _removeGlobalEvents() {\n        const element = this._document;\n        element.removeEventListener(\"mousemove\", this._pointerMove, activeEventOptions);\n        element.removeEventListener(\"mouseup\", this._pointerUp, activeEventOptions);\n        element.removeEventListener(\"touchmove\", this._pointerMove, activeEventOptions);\n        element.removeEventListener(\"touchend\", this._pointerUp, activeEventOptions);\n        element.removeEventListener(\"touchcancel\", this._pointerUp, activeEventOptions);\n\n        const window = this._getWindow();\n\n        if (typeof window !== \"undefined\" && window) {\n            window.removeEventListener(\"blur\", this._windowBlur);\n        }\n    }\n\n    /** Use defaultView of injected document if available or fallback to global window reference */\n    private _getWindow(): Window {\n        return this._document.defaultView || window;\n    }\n}\n","<!-- (selectstart): On Safari starting to slide temporarily triggers text selection mode which\nshow the wrong cursor. We prevent it by stopping the `selectstart` event. -->\n<div class=\"image-container\" #_imgContainer\n     (selectstart)=\"$event.preventDefault()\"\n>\n    <canvas #_imgCanvas></canvas>\n</div>\n<nice-cropper-area\n    #_area\n    *ngIf=\"_isLoadedImg\"\n    [round]=\"!!config.round\"\n    [resizableArea]=\"!!config.resizableArea\"\n    [keepAspectRatio]=\"!!config.keepAspectRatio\"\n    [ngStyle]=\"{\n        width: config.width + 'px',\n        height: config.height + 'px'\n    }\"\n></nice-cropper-area>\n<button class=\"close-button\" mat-icon-button *ngIf=\"_isLoadedImg\" (click)=\"clean()\">\n    <mat-icon>arrow_back</mat-icon>\n</button>\n","<div class=\"resizer\" #resizer *ngIf=\"resizableArea\"></div>\n"]}