@recursyve/nice-ui-kit.v2 15.0.0-beta.131 → 16.0.0-beta.132
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.
- package/esm2022/lib/animations/defaults.mjs +32 -0
- package/{esm2020 → esm2022}/lib/api/interceptors/transform-response.interceptor.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/alert/alert.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/alert/alert.module.mjs +9 -9
- package/{esm2020 → esm2022}/lib/components/alert/alert.service.mjs +4 -4
- package/esm2022/lib/components/assets-carousel/assets-carousel.component.mjs +283 -0
- package/{esm2020 → esm2022}/lib/components/assets-carousel/assets-carousel.module.mjs +19 -19
- package/{esm2020 → esm2022}/lib/components/assets-carousel/directives/assets-carousel-active-content.directive.mjs +4 -4
- package/esm2022/lib/components/async-typeahead/async-typeahead.component.mjs +451 -0
- package/{esm2020 → esm2022}/lib/components/async-typeahead/async-typeahead.module.mjs +21 -21
- package/{esm2020 → esm2022}/lib/components/async-typeahead/providers/async-typeahead.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/base-form/base-form.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/base-form/base-form.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/base-form/form-submit.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/card/card.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/card/card.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/carousel/carousel.component.mjs +4 -4
- package/esm2022/lib/components/carousel/carousel.module.mjs +40 -0
- package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/picture-modal.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/picture-modal.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/carousel/pipe/carousel-layout.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/collapsable/collapsable.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/collapsable/collapsable.module.mjs +7 -7
- package/{esm2020 → esm2022}/lib/components/date-range-picker/components/header/header.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/date-range-picker/components/range-preset/range-preset.component.mjs +4 -4
- package/esm2022/lib/components/date-range-picker/date-range-picker.component.mjs +95 -0
- package/{esm2020 → esm2022}/lib/components/date-range-picker/date-range-picker.module.mjs +21 -21
- package/{esm2020 → esm2022}/lib/components/date-range-picker/providers/date-range-picker.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/drawer/drawer.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/drawer/drawer.module.mjs +7 -7
- package/{esm2020 → esm2022}/lib/components/drawer/drawer.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/export-bottom-sheet.component.mjs +4 -4
- package/esm2022/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +45 -0
- package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/providers/export-bottom-sheet.service.mjs +7 -7
- package/{esm2020 → esm2022}/lib/components/form-error/control-status.directive.mjs +4 -4
- package/esm2022/lib/components/form-error/form-error.component.mjs +53 -0
- package/{esm2020 → esm2022}/lib/components/form-error/form-error.module.mjs +5 -5
- package/esm2022/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +34 -0
- package/{esm2020 → esm2022}/lib/components/horizontal-stepper/horizontal-stepper.module.mjs +9 -9
- package/{esm2020 → esm2022}/lib/components/horizontal-stepper/step.component.mjs +6 -6
- package/esm2022/lib/components/image-cropper/image-cropper.component.mjs +1269 -0
- package/{esm2020 → esm2022}/lib/components/image-cropper/image-cropper.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/layout/layout.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/layout/layout.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/loading-spinner/loading-spinner.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/loading-spinner/loading-spinner.module.mjs +9 -9
- package/{esm2020 → esm2022}/lib/components/loading-spinner/loading.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/lottie/lottie.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/lottie/lottie.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/navigation/components/hint-component-base.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/directives/show-hint.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/basic/basic.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/branch/branch.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/divider/divider.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/horizontal/components/spacer/spacer.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/horizontal/horizontal.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/navigation.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/navigation.module.mjs +37 -37
- package/{esm2020 → esm2022}/lib/components/navigation/navigation.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/pipes/should-hide.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/pipes/should-show-hint.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/providers/hint.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/aside/aside.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/basic/basic.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/collapsable/collapsable.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/divider/divider.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/group/group.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/components/spacer/spacer.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/navigation/vertical/vertical.component.mjs +4 -4
- package/esm2022/lib/components/search-bar/search-bar.component.mjs +76 -0
- package/{esm2020 → esm2022}/lib/components/search-bar/search-bar.module.mjs +13 -13
- package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/toast/toast.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/toast/toast.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/toast/toast.service.mjs +4 -4
- package/esm2022/lib/components/toggle-button-group/toggle-button-group.component.mjs +134 -0
- package/{esm2020 → esm2022}/lib/components/toggle-button-group/toggle-button-group.module.mjs +7 -7
- package/{esm2020 → esm2022}/lib/components/toggle-button-group/toggle-button.component.mjs +4 -4
- package/esm2022/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +38 -0
- package/esm2022/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +26 -0
- package/{esm2020 → esm2022}/lib/components/translation-form/components/translation-form.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/translation-form/components/translation-form.module.mjs +19 -19
- package/{esm2020 → esm2022}/lib/components/translation-form/directives/translation-context.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/translation-form/providers/nice-translation-form.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/translation-form/toggle/translation-toggle.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/translation-form/validators/require-for-languages.validator.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/typeahead/directives/options-scroll.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/typeahead/directives/options-scroll.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/typeahead/typeahead.component.mjs +9 -9
- package/{esm2020 → esm2022}/lib/components/typeahead/typeahead.module.mjs +25 -25
- package/{esm2020 → esm2022}/lib/directives/autofocus/autofocus.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/autofocus/autofocus.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/autogrow/autogrow.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/autogrow/autogrow.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list-items/chip-list-items.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/draggable-list/draggable-list.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/draggable-list/draggable-list.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/dropzone/dropzone.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/dropzone/dropzone.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/image-error-placeholder.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/image-error-placeholder.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/material/material.module.mjs +7 -7
- package/{esm2020 → esm2022}/lib/directives/material/nice-material-style.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/material/nice-rounded-style.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/modals/modal-on-click.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/modals/modal-opener.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/rerender/rerender.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/resolve/resolve.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/scroll-reset/scroll-reset.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/scroll-reset/scroll-reset.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/stop-propagation/click-stop-propagation.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/stop-propagation/stop-propagation.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/directives/window/prevent-close-window.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/directives/window/window-directive.module.mjs +5 -5
- package/esm2022/lib/nice.module.mjs +124 -0
- package/{esm2020 → esm2022}/lib/pipes/boolean.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/capitalize-first-letter.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/ceil.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/entries.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/find-by-key.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/first-letter.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/floor.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/join-if-defined.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/link.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/localized-boolean.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/localized-currency.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/localized-date-only.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/localized-date.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/minutes-to-time.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/number-to-ordinal-indicator.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/pad.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/phone.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/pipes.module.mjs +72 -72
- package/{esm2020 → esm2022}/lib/pipes/postal-code.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/range.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/round.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/sanitize-bypass.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/seconds-to-time.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/pipes/track-by-prop.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/providers/config/config.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/providers/config/config.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/providers/media-watcher/media-watcher.module.mjs +7 -7
- package/{esm2020 → esm2022}/lib/providers/media-watcher/media-watcher.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/providers/overlay/dynamic-overlay-container.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/providers/overlay/dynamic-overlay.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/providers/splash-screen/splash-screen.module.mjs +7 -7
- package/{esm2020 → esm2022}/lib/providers/splash-screen/splash-screen.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/providers/utils/utils.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/providers/utils/utils.service.mjs +4 -4
- package/esm2022/lib/utils/regex.utils.mjs +11 -0
- package/{fesm2020 → fesm2022}/recursyve-nice-ui-kit.v2.mjs +888 -889
- package/fesm2022/recursyve-nice-ui-kit.v2.mjs.map +1 -0
- package/lib/components/alert/alert.component.d.ts +1 -1
- package/lib/components/assets-carousel/assets-carousel.component.d.ts +1 -1
- package/lib/components/async-typeahead/async-typeahead.component.d.ts +1 -1
- package/lib/components/base-form/base-form.component.d.ts +1 -1
- package/lib/components/base-form/form-submit.directive.d.ts +1 -1
- package/lib/components/card/card.component.d.ts +1 -1
- package/lib/components/carousel/carousel.component.d.ts +1 -1
- package/lib/components/collapsable/collapsable.component.d.ts +1 -1
- package/lib/components/date-range-picker/date-range-picker.component.d.ts +1 -1
- package/lib/components/drawer/drawer.component.d.ts +1 -1
- package/lib/components/form-error/form-error.component.d.ts +1 -1
- package/lib/components/image-cropper/image-cropper.component.d.ts +2 -2
- package/lib/components/loading-spinner/loading-spinner.component.d.ts +1 -1
- package/lib/components/loading-spinner/loading.directive.d.ts +1 -1
- package/lib/components/loading-toast/loading-toast.component.d.ts +1 -1
- package/lib/components/loading-toast/loading-toast.directive.d.ts +1 -1
- package/lib/components/lottie/lottie.component.d.ts +1 -1
- package/lib/components/navigation/directives/show-hint.directive.d.ts +1 -1
- package/lib/components/navigation/horizontal/components/basic/basic.component.d.ts +1 -1
- package/lib/components/navigation/horizontal/components/branch/branch.component.d.ts +1 -1
- package/lib/components/navigation/horizontal/components/divider/divider.component.d.ts +1 -1
- package/lib/components/navigation/horizontal/components/spacer/spacer.component.d.ts +1 -1
- package/lib/components/navigation/horizontal/horizontal.component.d.ts +1 -1
- package/lib/components/navigation/vertical/components/aside/aside.component.d.ts +1 -1
- package/lib/components/navigation/vertical/components/basic/basic.component.d.ts +1 -1
- package/lib/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +1 -1
- package/lib/components/navigation/vertical/components/divider/divider.component.d.ts +1 -1
- package/lib/components/navigation/vertical/components/group/group.component.d.ts +1 -1
- package/lib/components/navigation/vertical/components/spacer/spacer.component.d.ts +1 -1
- package/lib/components/navigation/vertical/vertical.component.d.ts +1 -1
- package/lib/components/search-bar/search-bar.component.d.ts +1 -1
- package/lib/components/sweet-alert/sweet-alert.directive.d.ts +1 -1
- package/lib/components/toggle-button-group/toggle-button-group.component.d.ts +1 -1
- package/lib/components/toggle-button-group/toggle-button.component.d.ts +1 -1
- package/lib/components/translation-form/components/textarea/translation-form-textarea.component.d.ts +1 -1
- package/lib/components/translation-form/components/translation-form.component.d.ts +1 -1
- package/lib/components/translation-form/validators/require-for-languages.validator.d.ts +1 -1
- package/lib/components/typeahead/directives/options-scroll.directive.d.ts +1 -1
- package/lib/components/typeahead/typeahead.component.d.ts +1 -1
- package/lib/directives/autogrow/autogrow.directive.d.ts +1 -1
- package/lib/directives/chip-list/chip-list-items/chip-list-items.component.d.ts +1 -1
- package/lib/directives/chip-list/chip-list.directive.d.ts +1 -1
- package/lib/directives/draggable-list/draggable-list.directive.d.ts +1 -1
- package/lib/directives/image-error-placeholder/image-error-placeholder.directive.d.ts +1 -1
- package/lib/directives/modals/modal-opener.directive.d.ts +1 -1
- package/lib/directives/rerender/rerender.directive.d.ts +1 -1
- package/lib/directives/resolve/resolve.directive.d.ts +1 -1
- package/lib/directives/scrollbar/scrollbar.directive.d.ts +1 -1
- package/package.json +13 -19
- package/esm2020/lib/animations/defaults.mjs +0 -32
- package/esm2020/lib/components/assets-carousel/assets-carousel.component.mjs +0 -283
- package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +0 -451
- package/esm2020/lib/components/carousel/carousel.module.mjs +0 -41
- package/esm2020/lib/components/date-range-picker/date-range-picker.component.mjs +0 -95
- package/esm2020/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +0 -45
- package/esm2020/lib/components/form-error/form-error.component.mjs +0 -53
- package/esm2020/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +0 -34
- package/esm2020/lib/components/image-cropper/image-cropper.component.mjs +0 -1269
- package/esm2020/lib/components/search-bar/search-bar.component.mjs +0 -76
- package/esm2020/lib/components/toggle-button-group/toggle-button-group.component.mjs +0 -134
- package/esm2020/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +0 -38
- package/esm2020/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +0 -26
- package/esm2020/lib/nice.module.mjs +0 -124
- package/esm2020/lib/utils/regex.utils.mjs +0 -11
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs +0 -11867
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +0 -1
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +0 -1
- /package/{esm2020 → esm2022}/lib/animations/expand-collapse.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/animations/fade.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/animations/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/animations/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/animations/shake.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/animations/slide.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/animations/zoom.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/exceptions/api.exception.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/exceptions/exception.factory.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/nice.api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/api/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/alert/alert.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/alert/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/alert/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/assets-carousel/assets-carousel.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/assets-carousel/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/assets-carousel/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/async-typeahead/async-typeahead.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/async-typeahead/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/async-typeahead/providers/async-typeahead.provider.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/async-typeahead/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/base-form/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/base-form/nice-base.form.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/base-form/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/card/card.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/card/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/card/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/carousel/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/carousel/picture-modal/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/carousel/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/collapsable/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/collapsable/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/date-range-picker/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/date-range-picker/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/drawer/drawer.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/drawer/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/drawer/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/models/export-strategy.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/export-bottom-sheet/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form-error/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/form-error/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/horizontal-stepper/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/horizontal-stepper/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/image-cropper/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/image-cropper/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/image-cropper/resize-canvas.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/layout/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/layout/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-spinner/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-spinner/loading.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-spinner/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-toast/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-toast/loading-toast.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-toast/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/loading-toast/rxjs/show-loading-toast.operator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/lottie/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/lottie/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/navigation/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/navigation/navigation.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/navigation/providers/hide-item.resolver.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/navigation/providers/hint.resolver.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/navigation/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/search-bar/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/search-bar/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/sweet-alert/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/sweet-alert/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/sweet-alert/sweet-alert.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toast/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toast/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toast/rxjs/show-success-or-error-toast.operator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toast/rxjs/show-toast.operator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toast/toast.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toggle-button-group/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/toggle-button-group/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/translation-form/decorators/translation-form-group.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/translation-form/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/translation-form/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/translation-form/translation.form.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/typeahead/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/typeahead/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/autofocus/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/autofocus/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/autogrow/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/autogrow/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/chip-async-typeahead/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/chip-list/chip-list.constant.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/chip-list/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/chip-list/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/draggable-list/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/draggable-list/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/dropzone/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/dropzone/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/image-error-placeholder/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/material/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/material/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/modals/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/modals/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/rerender/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/rerender/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/resolve/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/resolve/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-reset/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-reset/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scrollbar/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scrollbar/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scrollbar/scrollbar.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/stop-propagation/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/stop-propagation/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/window/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/window/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/config/config.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/config/config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/config/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/config/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/media-watcher/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/media-watcher/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/splash-screen/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/splash-screen/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/providers/utils/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/constructor.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/array.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/case.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/colors.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/date.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/file.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/font-awesome.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/form-data.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/http-status.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/keyboard.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/lexorank.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/modal.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/number.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/object.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/promise.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/query-params.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/type.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/url.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /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":"AAAA;;GAEG;AAEH,OAAO,EAAE,+BAA+B,EAAE,MAAM,uBAAuB,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EAAE,WAAW,EACzB,MAAM,EACN,KAAK,EACL,MAAM,EAGN,MAAM,EACN,SAAS,EACT,SAAS,EACT,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAE/C,MAAM,kBAAkB,GAAG,+BAA+B,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;AAE/E,2BAA2B;AAC3B,MAAM,OAAO,gBAAgB;IAA7B;QACI,yBAAyB;QACzB,UAAK,GAAG,GAAG,CAAC;QACZ,0BAA0B;QAC1B,WAAM,GAAG,GAAG,CAAC;QACb,aAAQ,GAAG,EAAE,CAAC;QACd,cAAS,GAAG,EAAE,CAAC;QAKf;;;;WAIG;QACH,gBAAW,GAAG,IAAI,CAAC;QAEnB,WAAM,GAA+B,aAAa,CAAC,OAAO,CAAC;IAmC/D,CAAC;CAAA;AAmBD,mBAAmB;AACnB,MAAM,CAAN,IAAY,aAOX;AAPD,WAAY,aAAa;IACrB;;OAEG;IACH,uDAAO,CAAA;IACP,2CAA2C;IAC3C,mEAAa,CAAA;AACjB,CAAC,EAPW,aAAa,KAAb,aAAa,QAOxB;AAED,mBAAmB;AACnB,MAAM,CAAN,IAAY,eAOX;AAPD,WAAY,eAAe;IACvB,mDAAmD;IACnD,qDAAI,CAAA;IACJ,oCAAoC;IACpC,qDAAI,CAAA;IACJ,0CAA0C;IAC1C,uDAAK,CAAA;AACT,CAAC,EAPW,eAAe,KAAf,eAAe,QAO1B;AAkGD,MAAM,OAAO,yBAAyB;aAClB,MAAC,GAAG,kBAAkB,CAAC;IAsDvC,IACW,MAAM,CAAC,GAAqB;QACnC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,EAAE,EAAE,IAAI,gBAAgB,EAAE,EAAE,GAAG,CAAC,CAAC;QAC1D,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAClD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAC3C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAC7C,IACI,IAAI,CAAC,OAAO,CAAC,KAAK;eACf,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC,MAAM,EAC7C;YACE,MAAM,IAAI,KAAK,CAAC,GAAG,yBAAyB,CAAC,CAAC,oFAAoF,CAAC,CAAC;SACvI;QACD,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;QAC7C,IAAI,WAAW,EAAE;YACb,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;SAClC;IACL,CAAC;IACD,IAAW,MAAM;QACb,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IACD,gBAAgB;IAChB,IACW,KAAK,CAAC,GAAuB;QACpC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACvB,CAAC;IACD,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IASD,oBAAoB;IACpB,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IA4CD,YACY,SAAoB,EACnB,WAAoC,EACrC,EAAqB,EACrB,OAAe,EACL,SAAc,EAChC,aAA4B;QALpB,cAAS,GAAT,SAAS,CAAW;QACnB,gBAAW,GAAX,WAAW,CAAyB;QACrC,OAAE,GAAF,EAAE,CAAmB;QACrB,YAAO,GAAP,OAAO,CAAQ;QA1HnB,aAAQ,GAAY,EAAS,CAAC;QAC9B,cAAS,GAAG,CAAC,CAAC;QA4EL,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAE1D,0CAA0C;QAC1C,4CAA4C;QAE3B,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAE7D,0CAA0C;QAC1C,4CAA4C;QAE3B,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAE7D,qCAAqC;QAEpB,gBAAW,GAAG,IAAI,YAAY,EAAmB,CAAC;QAEnE,uDAAuD;QAEtC,UAAK,GAAG,IAAI,YAAY,EAAmB,CAAC;QAE7D,wBAAwB;QAEP,YAAO,GAAG,IAAI,YAAY,EAAmB,CAAC;QAE/D,wCAAwC;QAEvB,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEpD,uDAAuD;QACvD,6CAA6C;QAE5B,UAAK,GAAG,IAAI,YAAY,EAAwB,CAAC;QAIlE,iDAAiD;QAChC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAsOxC,iBAAY,GAAG,CAAC,KAA8B,EAAE,EAAE;YACtD,2BAA2B;YAC3B,2DAA2D;YAC3D,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE;gBACjE,OAAO;aACV;YAED,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE;gBAClB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,MAAM,GAAG;oBACV,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAClB,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAClB,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;oBACtB,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;iBACxB,CAAC;gBACF,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,kBAAkB,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;gBAC1D,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAClC,CAAC,CAAC,CAAC;QAEP,CAAC,CAAA;QA0BD;;;WAGG;QACK,iBAAY,GAAG,CAAC,KAA8B,EAAE,EAAE;YACtD,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAqB,CAAC;gBAC1B,IAAI,CAAqB,CAAC;gBAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;gBAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;gBAChC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC3B,MAAM,KAAK,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;gBAC9C,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;gBACnD,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;gBACnD,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM,EAAE;oBACtB,OAAO;iBACV;gBAED,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,GAAG,QAAQ,GAAG,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,YAAY,CAAC;gBACpF,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,YAAY,CAAC;gBAElF,MAAM,SAAS,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,GAAG,QAAQ,CAAC,IAAI,MAAM,CAAC,IAAI,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAC;gBACrF,MAAM,UAAU,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,GAAG,QAAQ,CAAC;oBAC5C,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,GAAG,QAAQ,CAAC;gBACpF,MAAM,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;gBACxF,MAAM,WAAW,GAAG,CAChB,CAAC,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,QAAQ,CAAC,CACxH,CAAC;gBAEF,iBAAiB;gBACjB,IAAI,CAAC,SAAS,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,SAAS,IAAI,WAAW,CAAC,EAAE;oBAC5D,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAC;iBAChE;gBAED,kBAAkB;gBAClB,IAAI,CAAC,UAAU,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,UAAU,IAAI,WAAW,CAAC,EAAE;oBAC9D,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,GAAG,QAAQ,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC;iBAC/E;gBAED,gBAAgB;gBAChB,IAAI,CAAC,QAAQ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,QAAQ,IAAI,WAAW,CAAC,EAAE;oBAC1D,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAC;iBAChE;gBAED,mBAAmB;gBACnB,IAAI,CAAC,WAAW,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,WAAW,IAAI,WAAW,CAAC,EAAE;oBAChE,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,QAAQ,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC;iBAChF;gBAED,kCAAkC;gBAClC,mDAAmD;gBACnD,+FAA+F;gBAC/F,2BAA2B;gBAC3B,aAAa;gBACb,4BAA4B;gBAC5B,MAAM;gBACN,IAAI;gBAEJ,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE;oBAAE,CAAC,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;iBAAE;gBAC3D,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE;oBAAE,CAAC,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;iBAAE;gBAC3D,IAAI,CAAC,oBAAoB,CAAC;oBACtB,CAAC,EAAE,CAAC;iBACP,CAAC,CAAC;aACN;QACL,CAAC,CAAA;QA6bD,qDAAqD;QAC7C,eAAU,GAAG,CAAC,KAA8B,EAAE,EAAE;YACpD,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;gBAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;aAC1B;QACL,CAAC,CAAA;QAED,6CAA6C;QACrC,gBAAW,GAAG,GAAG,EAAE;YACvB,+EAA+E;YAC/E,sEAAsE;YACtE,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;aAC3C;QACL,CAAC,CAAA;QA1xBG,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,aAAa,CAAC,MAAM,EAAE;aACjB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,GAAG,EAAE,CACZ,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CACvD,CAAC;IACV,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;YACjD,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;YAC7E,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAClF,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;QACjD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAChF,OAAO,CAAC,mBAAmB,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;IACrF,CAAC;IAED,6BAA6B;IACrB,UAAU,CAAC,UAA4B;QAC3C,IAAI,UAAU,EAAE;YACZ,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;YACvB,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YAC7C,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC;YAChC,MAAM,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;YAClC,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACpC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;YACzD,GAAG,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAEhC,oBAAoB;YACpB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;IACL,CAAC;IAEO,oBAAoB,CAAC,MAAkC;QAC3D,MAAM,SAAS,GAAG,EAAU,CAAC;QAC7B,IAAI,MAAM,CAAC,CAAC,IAAI,IAAI,IAAI,MAAM,CAAC,CAAC,IAAI,IAAI,EAAE;YACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAClC,MAAM,CAAC,GAAG,QAAQ,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC1C,MAAM,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAE3C,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;SAE1B;QACD,SAAS,CAAC,SAAS,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC;QACtF,SAAS,CAAC,SAAS,IAAI,SAAS,IAAI,CAAC,SAAS,GAAG,CAAC;QAClD,SAAS,CAAC,eAAe,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAC5E,SAAS,CAAC,mBAAmB,CAAC,GAAG,SAAS,CAAC,SAAS,CAAC;QACrD,SAAS,CAAC,0BAA0B,CAAC,GAAG,SAAS,CAAC,eAAe,CAAC;QAClE,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE;YACzB,IAAI,SAAS,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;gBAC/B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;aAClF;SACJ;IACL,CAAC;IACD;;;OAGG;IACI,qBAAqB;QACxB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;IACL,CAAC;IAED,kCAAkC;IAC3B,gBAAgB,CAAC,GAAU;QAC9B,IAAI,CAAC,oBAAoB,GAAG,GAAG,CAAC,MAA0B,CAAC;QAC3D,MAAM,IAAI,GAAG,GAAG,CAAC,MAA0B,CAAC;QAC5C,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACvC,OAAO;SACV;QACD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QAErD,IAAI,IAAI,CAAC,WAAW,IAAI,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE;YACjD,MAAM,SAAS,GAAyB;gBACpC,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI;gBACxB,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,eAAe,CAAC,IAAI;aAC9B,CAAC;YACF,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAiC,CAAC,CAAC;YACnD,OAAO;SACV;QAED,IAAI,UAAU,CAAgB,QAAQ,CAAC,EAAE;YAErC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAEhC,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5C,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5C,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE;gBACpC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAClB,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACxB,CAAC,CAAC,CAAC;YAEH,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC,CAAC;aACG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACvC,SAAS,CACN,CAAC,SAAS,EAAE,EAAE;YACV,MAAM,eAAe,GAAI,SAAS,CAAC,MAAqB,CAAC,MAAgB,CAAC;YAE1E,IAAI,CAAC,SAAS,CAAC;gBACX,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI;gBACxB,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI;gBAC5C,eAAe;aAClB,CAAC,CAAC;YAEH,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;QAC3B,CAAC,EACD,GAAG,EAAE;YACD,MAAM,SAAS,GAAyB;gBACpC,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,eAAe,CAAC,KAAK;gBAC5B,QAAQ,EAAE,+BAA+B;gBACzC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI;aAC3B,CAAC;YACF,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAiC,CAAC,CAAC;QACvD,CAAC,CACJ,CAAC;IAEV,CAAC;IAED,6FAA6F;IACtF,QAAQ,CAAC,IAAa,EAAE,UAAoB;QAC/C,gBAAgB;QAChB,MAAM,OAAO,GAAG,IAAI,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;QAE1E,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,KAAK,IAAI,CAAC,KAAK,IAAI,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC;QAC9E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,OAAO,EAAE;YACV,OAAO;SACV;QACD,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC;QACzB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,OAAO,EAAE;gBACT,MAAM,cAAc,GAAG,EAAC,GAAG,IAAI,CAAC,QAAQ,EAAC,CAAC;gBAC1C,IAAI,CAAC,MAAM,GAAG;oBACV,CAAC,EAAE,cAAc,CAAC,CAAC;oBACnB,CAAC,EAAE,cAAc,CAAC,CAAC;oBACnB,IAAI,EAAE,cAAc,CAAC,EAAE;oBACvB,GAAG,EAAE,cAAc,CAAC,EAAE;iBACzB,CAAC;gBACF,IAAI,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC;gBAC9B,IAAI,CAAC,oBAAoB,EAAE,CAAC;aAC/B;iBAAM;gBACH,OAAO;aACV;SACJ;aAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,oBAAoB,CAAC;gBACtB,GAAG,IAAI,CAAC,gBAAgB,EAAE;aAC7B,CAAC,CAAC;SACN;aAAM;YACH,OAAO;SACV;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE;YACb,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;IAEL,CAAC;IAEO,gBAAgB;QACpB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,aAA4B,CAAC;QAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAC1C,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;QAC/C,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;QACjD,OAAO;YACH,CAAC;YACD,CAAC;SACJ,CAAC;IACN,CAAC;IAED;;OAEG;IACI,WAAW;QACd,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,aAA4B,CAAC;QAChE,MAAM,GAAG,GAAG;YACR,KAAK,EAAE,SAAS,CAAC,WAAW;YAC5B,MAAM,EAAE,SAAS,CAAC,YAAY;SACjC,CAAC;QACF,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC;QACpC,MAAM,QAAQ,GAAG;YACb,KAAK,EAAE,GAAG,CAAC,KAAK,GAAG,KAAK;YACxB,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,MAAM;SAC9B,CAAC;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAEM,GAAG;QACN,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAyBD;;;OAGG;IACK,oBAAoB;QACxB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,kBAAkB,GAAG;YACtB,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;SACP,CAAC;QACF,IAAI,CAAC,YAAY,CAAC;YACd,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC;YACV,IAAI,EAAE,GAAG;YACT,cAAc,EAAE,GAAG,EAAE,GAAE,CAAC;SACb,CAAC,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACnC,CAAC;IAEM,aAAa;QAChB,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAyEM,cAAc,CAAC,OAAgB,EAAE,OAAgB;QACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACzC,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK;YAC7C,CAAC,CAAC,QAAQ,CAAC,KAAK;YAChB,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;QACrB,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM;YAChD,CAAC,CAAC,QAAQ,CAAC,MAAM;YACjB,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC;QACtB,IAAI,CAAS,CAAC;QACd,IAAI,CAAS,CAAC;QACd,IAAI,OAAO,IAAI,IAAI,IAAI,OAAO,IAAI,IAAI,EAAE;YACpC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC3B,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;SAC9B;QACD,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;QACpC,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC;QAElC,IAAI,CAAC,oBAAoB,CAAC;YACtB,CAAC,EAAE,CAAC;SACP,CAAC,CAAC;IACP,CAAC;IAEM,SAAS;QACZ,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAEO,eAAe;QACnB,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,IAAI,EAAE,CAAC;SACf;IACL,CAAC;IAED,QAAQ;IACD,MAAM;QACT,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACnC,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE;YAClD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxB;aAAM;YACH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACjC;IACL,CAAC;IAED,4BAA4B;IACrB,KAAK;QACR,4CAA4C;QAC5C,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3B,IAAI,CAAC,oBAAoB,CAAC,KAAK,GAAG,EAAE,CAAC;YACrC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;SACpC;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,QAAQ,GAAG,EAAU,CAAC;YAC3B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;YACxB,IAAI,CAAC,KAAK,GAAG,SAAgB,CAAC;YAC9B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;YACnB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;YACpC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC;YAClC,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YAC7C,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;YACjB,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;YAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;SAC1B;IACL,CAAC;IAED,QAAQ;IACD,OAAO;QACV,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACnC,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE;YAClD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxB;aAAM;YACH,IAAI,CAAC,GAAG,EAAE,CAAC;SACd;IACL,CAAC;IACM,MAAM;QACT,MAAM,SAAS,GAAG;YACd,GAAG,IAAI,CAAC,gBAAgB,EAAE;SAC7B,CAAC;QACF,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;QACrC,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IACD;;;OAGG;IACI,SAAS,CAAC,MAAuC,EAAE,EAAe;QACrE,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,GAAG,OAAO,MAAM,KAAK,QAAQ;YAChE,CAAC,CAAC,EAAE,eAAe,EAAE,MAAM,EAAE;YAC7B,CAAC,CAAC,EAAE,GAAG,MAAM,EAAE,CAAC;QACpB,IAAI,GAAG,GAAG,OAAO,CAAC,eAAe,CAAC;QAClC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;QACnD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;QACrD,IAAI,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,UAAU,EAAE;YACzC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,SAAS,CAAC;YACtC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;SAC3C;QACD,GAAG,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC;QAExB,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;QAE/B,MAAM,SAAS,GAAG,EAAE,GAAG,OAAO,EAAqB,CAAC;QAEpD,IAAI,UAAU,CAAO,QAAQ,CAAC,EAAE;YAE5B,GAAG,CAAC,OAAO,GAAG,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACzC,GAAG,CAAC,OAAO,GAAG,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACzC,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3C,CAAC,CAAC;aACG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACvC,SAAS,CACN,GAAG,EAAE;YACD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACjC,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAChC,IAAI,CAAC,OAAO;qBACP,QAAQ;qBACR,YAAY,EAAE;qBACd,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;qBACvC,SAAS,CACN,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CACnF,CAAC;YACV,CAAC,CAAC,CAAC;QACP,CAAC,EACD,GAAG,EAAE;YACD,MAAM,KAAK,GAAyB;gBAChC,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,KAAK,EAAE,eAAe,CAAC,IAAI;gBAC3B,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,IAAI,EAAE,OAAO,CAAC,IAAI;aACrB,CAAC;YACF,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC,CACJ,CAAC;IACV,CAAC;IAEO,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE;YAC9B,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,CACD,QAAQ,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK;eAC5B,QAAQ,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM;eACjC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB;eACvC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAC/C,EAAE;YACC,OAAO;SACV;QACD,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC5D,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACxD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CACpB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE,SAAS,CAAC,CAC3E,CAAC;QACF,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC;QACpC,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAEpC,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,OAAO,CAAC;SACpD;aAAM;YACH,IAAI,aAAa,KAAK,QAAQ,CAAC,KAAK,EAAE;gBAClC,IAAI,YAAY,GAAG,IAAI,CAAC,iBAAiB,EAAE;oBACvC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC;oBAC3C,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;oBACjF,QAAQ,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;iBACvE;qBAAM;oBACH,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,YAAY,CAAC;oBACjC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;oBACvE,QAAQ,GAAG,CAAC,YAAY,GAAG,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;iBAC7D;gBACD,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;gBAC9B,IAAI,CAAC,aAAa,EAAE,CAAC;aACxB;SACJ;IACL,CAAC;IAEO,oBAAoB;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC5E,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAChC,CAAC;IAED;;;;;OAKG;IACI,WAAW,CAAC,GAAW,EAAE,EAAe;QAC3C,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IAC5B,CAAC;IAEO,YAAY,CAAC,SAA0B,EAAE,EAAe;QAC5D,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAC3C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QACpD,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,EAAE,EAAE;YACJ,EAAE,EAAE,CAAC;SACR;aAAM;YACH,IAAI,UAAU,CAAC,KAAK,EAAE;gBAClB,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;aACzC;iBAAM;gBACH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;aACtC;YACD,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC;YACtC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAChC,IAAI,CAAC,OAAO;qBACP,QAAQ;qBACR,YAAY,EAAE;qBACd,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;qBACvC,SAAS,CAAC,GAAG,EAAE;oBACZ,IAAI,UAAU,CAAC,OAAO,IAAI,IAAI,IAAI,UAAU,CAAC,OAAO,IAAI,IAAI,EAAE;wBAC1D,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;qBAC/D;oBACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;oBACrB,IAAI,CAAC,eAAe,EAAE,CAAC;oBACvB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE;wBAClB,IAAI,CAAC,aAAa,EAAE,CAAC;wBACrB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;oBAC/B,CAAC,CAAC,CAAC;gBACP,CAAC,CAAC,CAAC;YACX,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAEM,MAAM,CAAC,OAAe;QACzB,IAAI,YAAY,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAC9C,kCAAkC;QAClC,IAAI,YAAY,GAAG,CAAC,EAAE;YAClB,YAAY,IAAI,GAAG,CAAC;SACvB;QACD,MAAM,WAAW,GAAG,iBAAiB,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC;QAC5E,IAAI,WAAW,KAAK,IAAI,CAAC,SAAS,EAAE;YAChC,OAAO;SACV;QACD,MAAM,UAAU,GAAG,YAAY,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;QAChD,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAC7C,MAAM,UAAU,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC;QAE7B,QAAQ;QACR,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;QAEzD,sBAAsB;QACtB,MAAM,SAAS,GAAG,UAAU,YAAY,cAAc,CAAC,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC;QAC5E,MAAM,eAAe,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QACxE,MAAM,CAAC,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;QACnC,wCAAwC;QACxC,MAAM,CAAC,KAAK,CAAC,eAAe,GAAG,SAAS,CAAC;QACzC,MAAM,CAAC,KAAK,CAAC,eAAe,GAAG,eAAe,CAAC;QAC/C,wCAAwC;QACxC,MAAM,CAAC,KAAK,CAAC,qBAAqB,GAAG,eAAe,CAAC;QAErD,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,MAAM,CAAC,qBAAqB,EAAa,CAAC;QAEhE,YAAY;QACZ,MAAM,UAAU,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC;QAElD,uBAAuB;QACvB,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAEhC,YAAY;QACZ,MAAM,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC;QAC3B,MAAM,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC;QAC5B,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;QACrB,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QAEtB,QAAQ;QACR,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE1B,uBAAuB;QACvB,GAAG,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAC5B,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACvB,GAAG,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEzE,mBAAmB;QACnB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,2CAA2C;QAC3C,IAAI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE;YAC5B,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SAC1B,CAAC,+BAA+B;QAEjC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAElC,IAAI,CAAC,oBAAoB,CAAC;YACtB,CAAC,EAAE,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;YACzB,CAAC,EAAE,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC;SAC1B,CAAC,CAAC;QAEH,8BAA8B;QAC9B,MAAM,cAAc,GAAG,EAAC,GAAG,IAAI,CAAC,QAAQ,EAAC,CAAC;QAC1C,IAAI,CAAC,MAAM,GAAG;YACV,CAAC,EAAE,cAAc,CAAC,CAAC;YACnB,CAAC,EAAE,cAAc,CAAC,CAAC;YACnB,IAAI,EAAE,cAAc,CAAC,EAAE;YACvB,GAAG,EAAE,cAAc,CAAC,EAAE;SACzB,CAAC;QACF,IAAI,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC;QAC9B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAEM,eAAe,CAAC,MAA0B;QAC7C,IAAI,CAAC,MAAM,EAAE;YACT,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;SAC1C;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC3B,MAAM,QAAQ,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACxD,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,EAC3B,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IAEO,eAAe;QACnB,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC9D,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,IAAI,CAAC,MAAyB;QACjC,MAAM,SAAS,GAAG,MAAM;YACpB,CAAC,CAAC,SAAS,CAAC,EAAG,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,gBAAgB,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;QAClF,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAC3C,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;QACvB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED;;OAEG;IACK,QAAQ,CAAC,QAA0B;QACvC,MAAM,aAAa,GAAsB,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC1E,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACzC,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,MAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC;QAC1D,MAAM,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC;QACvD,MAAM,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC;QAC5B,MAAM,sBAAsB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QACvD,MAAM,IAAI,GAAG;YACT,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,MAAM,EAAE,QAAQ,CAAC,MAAM;SAC1B,CAAC;QACF,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;QAC5C,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC;QAC9C,MAAM,GAAG,GAAG,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAI,QAAQ,CAAC,IAAI,EAAE;YACf,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC9B,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,aAAa,CAAC,KAAK,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;SACjE;QACD,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EACvC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAClB,CAAC;QACF,MAAM,MAAM,GAAG,aAAa,CAAC;QAC7B,IAAI,QAAQ,CAAC,MAAM,KAAK,aAAa,CAAC,OAAO,EAAE;YAC3C,YAAY,CACR,MAAM,EACN,IAAI,CAAC,cAAc,CAAC,KAAK,EACzB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;SACnC;aAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;YACnC,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE;gBAC/B,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;aACrD;iBAAM,IAAI,MAAM,CAAC,KAAK,EAAE;gBACrB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;gBAC1D,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;aACjD;iBAAM,IAAI,MAAM,CAAC,MAAM,EAAE;gBACtB,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC1D,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;aACjD;SACJ;QACD,MAAM,IAAI,GAAG,sBAAsB,CAAC,eAAe,CAAC,UAAU,CAAC,MAAM,CAAC;YAClE,CAAC,CAAC,sBAAsB,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI;YAC9C,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,sBAAsB,CAAC,IAAI,CAAC;QACnD,MAAM,OAAO,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,SAAS,GAAoB;YAC/B,OAAO;YACP,IAAI;YACJ,IAAI,EAAE,sBAAsB,CAAC,IAAI;YACjC,SAAS,EAAE,IAAI,CAAC,iBAAiB;YACjC,UAAU,EAAE,IAAI,CAAC,kBAAkB;YACnC,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,eAAe,EAAE,sBAAsB,CAAC,eAAe;YACvD,KAAK,EAAE,IAAI,CAAC,cAAc;YAC1B,QAAQ,EAAE,IAAI,CAAC,SAAS;YACxB,IAAI,EAAE,CAAC,QAAQ,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS;YACxD,GAAG,EAAE,CAAC,QAAQ,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS;YACrD,IAAI,EAAE,sBAAsB,CAAC,IAAI;YACjC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;YACzB,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;YACzB,QAAQ,EAAE;gBACN,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;gBACnB,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;aACtB;SACJ,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7B,OAAO,SAAS,CAAC;IACrB,CAAC;IAEM,SAAS;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,qBAAqB,EAAa,CAAC;IAC7E,CAAC;IAEM,gBAAgB;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,qBAAqB,EAAa,CAAC;IAC1E,CAAC;IAEM,WAAW;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;IACjE,CAAC;IAuBO,iBAAiB,CAAC,YAAqC;QAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAC/B,MAAM,OAAO,GAAG,YAAY,CAAC,YAAY,CAAC,CAAC;QAC3C,MAAM,aAAa,GAAG,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC;QAC1D,MAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;QACtD,OAAO,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAC/E,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAE5E,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;SAChF;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAEjC,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,EAAE;YACzC,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SACrD;IACL,CAAC;IAED,iEAAiE;IACzD,mBAAmB;QACvB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAC/B,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAChF,OAAO,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAC5E,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAChF,OAAO,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAC7E,OAAO,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAEhF,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAEjC,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,EAAE;YACzC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SACxD;IACL,CAAC;IAED,+FAA+F;IACvF,UAAU;QACd,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,MAAM,CAAC;IAChD,CAAC;8GAp9BQ,yBAAyB,4HA+ItB,QAAQ;kGA/IX,yBAAyB,whBAkDN,UAAU,sIC5Q1C,wwBAqBA,8+CDwyCa,wBAAwB;;2FAnmCxB,yBAAyB;kBARrC,SAAS;sCACW,uBAAuB,CAAC,MAAM,uBAC1B,KAAK,YAChB,sCAAsC,iBAGjC,iBAAiB,CAAC,IAAI;;0BAiJhC,MAAM;2BAAC,QAAQ;wEA/FZ,aAAa;sBADpB,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAIpC,QAAQ;sBADf,SAAS;uBAAC,OAAO,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAGhC,UAAU;sBADjB,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI9B,MAAM;sBADhB,KAAK;gBAsBK,KAAK;sBADf,KAAK;gBAaC,WAAW;sBADjB,KAAK;gBASW,WAAW;sBAD3B,MAAM;gBAMU,cAAc;sBAD9B,MAAM;uBAAC,UAAU;gBAMD,cAAc;sBAD9B,MAAM;uBAAC,UAAU;gBAKD,WAAW;sBAD3B,MAAM;gBAKU,KAAK;sBADrB,MAAM;gBAKU,OAAO;sBADvB,MAAM;gBAKU,OAAO;sBADvB,MAAM;gBAMU,KAAK;sBADrB,MAAM;;AAy1BX;;;GAGG;AACH,MAAM,UAAU,iBAAiB,CAAC,CAAS;IACvC,MAAM,EAAE,GAAG,CAAC,GAAG,GAAG,CAAC;IACnB,IAAI,EAAE,GAAG,EAAE,EAAE;QACT,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,yDAAyD,CAAC,CAAC;KACvG;IACD,OAAO,EAAE,CAAC;AACd,CAAC;AAED;;GAEG;AACH,SAAS,eAAe,CAAC,GAAyC;IAE9D,sBAAsB;IACtB,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAE3C,iBAAiB;IACjB,SAAS,CAAC,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC;IAC5B,SAAS,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;IAE9B,sCAAsC;IACtC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAE7B,wBAAwB;IACxB,OAAO,SAAS,CAAC;AACrB,CAAC;AAGD,MAAM,qBAAqB,GAAG,4BAA4B,CAAC;AAE3D,SAAS,YAAY,CAAC,OAAe;IACjC,IAAI,MAAM,CAAC,IAAI,IAAI,UAAU,CAAC,OAAO,CAAC,EAAE;QACpC,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;QAC/B,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,qBAAqB,EAAE,EAAE,CAAC,CAAC,CAAC;QACrE,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACtC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;QAC3C,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAChC,MAAM,KAAK,GAAG,UAAU,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC3D,MAAM,MAAM,GAAG,UAAU,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC7D,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAEpC,GAAG,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,GAAG,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;QACtD,GAAG,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG,GAAG,GAAG,CAAC,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,qBAAqB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACnE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAChC,OAAO,MAAM,CAAC;KACjB;IACD,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,SAAS,UAAU,CAAC,OAAe;IAC/B,OAAO,OAAO,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC;AACrD,CAAC;AAED,SAAS,aAAa,CAAC,GAAW;IAC9B,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;IACxB,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC;IAC9B,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC;IACd,OAAO,GAAG,CAAC;AACf,CAAC;AAGD,SAAS,wBAAwB,CAAC,KAA8B;IAE5D,4FAA4F;IAC5F,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;QAC7B,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QAC/C,CAAC,CAAC,KAAK,CAAC;IAEZ,OAAO;QACH,CAAC,EAAE,KAAK,CAAC,OAAO;QAChB,CAAC,EAAE,KAAK,CAAC,OAAO;KACnB,CAAC;AACN,CAAC;AAED,iDAAiD;AACjD,SAAS,YAAY,CAAC,KAA8B;IAChD,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;AACjC,CAAC;AAED,MAAM,UAAU,KAAK,CAAC,CAAS;IAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACzB,CAAC;AAED;;;GAGG;AACH,SAAS,QAAQ,CAAC,IAAI;IAClB,OAAO,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;AACtE,CAAC;AAOD;;;;GAIG;AACH,MAAM,UAAU,SAAS,CAAC,MAAW,EAAE,GAAG,OAAc;IACpD,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IACvC,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAE/B,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE;QACtC,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;YACtB,IAAI,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE;gBACvB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;oBAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;iBAAE;gBAC3D,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;aACvC;iBAAM;gBACH,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aACjD;SACJ;KACJ;IAED,OAAO,SAAS,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC;AACzC,CAAC;AAGD;;GAEG;AASH,MAAM,OAAO,wBAAwB;IA0BjC,YACsB,SAAc,EACf,WAAuB,EACvB,QAAmC,EACnC,OAAe;QAFf,gBAAW,GAAX,WAAW,CAAY;QACvB,aAAQ,GAAR,QAAQ,CAA2B;QACnC,YAAO,GAAP,OAAO,CAAQ;QA+C5B,iBAAY,GAAG,CAAC,KAA8B,EAAE,EAAE;YACtD,2BAA2B;YAC3B,2DAA2D;YAC3D,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE;gBACjE,OAAO;aACV;YAED,KAAK,CAAC,cAAc,EAAE,CAAC;YAEvB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE;gBAClB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,kBAAkB,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;gBAC1D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;gBACvD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;gBACjD,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAClC,CAAC,CAAC,CAAC;QACP,CAAC,CAAA;QAEO,iBAAY,GAAG,CAAC,KAA8B,EAAE,EAAE;YACtD,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,MAAM,OAAO,GAAmB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;gBAC/D,MAAM,EAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAClE,MAAM,KAAK,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;gBAC9C,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;gBACnD,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;gBACnD,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC;gBAC1C,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;gBACxC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC;gBAC3B,MAAM,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,eAAe,IAAI,KAAK,CAAC,QAAQ,CAAC;gBAC/E,IAAI,QAAQ,GAAG,CAAC,CAAC;gBACjB,IAAI,SAAS,GAAG,CAAC,CAAC;gBAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;gBAE3C,IAAI,OAAO,EAAE;oBACT,kEAAkE;oBAClE,MAAM,OAAO,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;oBACtD,MAAM,OAAO,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;oBAEvD,MAAM;oBACN,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,CAAC,CAAC;oBACpD,QAAQ,GAAG,SAAS,GAAG,IAAI,GAAG,CAAC,CAAC;iBAEnC;qBAAM,IAAI,eAAe,EAAE;oBACxB,QAAQ,GAAG,KAAK,GAAG,MAAM,GAAG,CAAC,CAAC;oBAC9B,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,CAAC,CAAC;oBAChC,IAAI,KAAK,KAAK,MAAM,EAAE;wBAClB,IAAI,KAAK,GAAG,MAAM,EAAE;4BAChB,SAAS,GAAG,MAAM,GAAG,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;yBAC3C;6BAAM,IAAI,MAAM,GAAG,KAAK,EAAE;4BACvB,QAAQ,GAAG,KAAK,GAAG,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC;yBAC3C;qBACJ;yBAAM;wBACH,QAAQ,GAAG,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;qBACxD;iBACJ;qBAAM;oBACH,QAAQ,GAAG,KAAK,GAAG,MAAM,GAAG,CAAC,CAAC;oBAC9B,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,CAAC,CAAC;iBACnC;gBAED,eAAe;gBACf,IAAI,QAAQ,GAAG,QAAQ,EAAE;oBACrB,QAAQ,GAAG,QAAQ,CAAC;iBACvB;gBACD,gBAAgB;gBAChB,IAAI,SAAS,GAAG,SAAS,EAAE;oBACvB,SAAS,GAAG,SAAS,CAAC;iBACzB;gBAED,mCAAmC;gBACnC,MAAM,OAAO,GAAG,aAAa,CAAC,CAAC,GAAG,aAAa,CAAC,KAAK,GAAG,CAAC,CAAC;gBAC1D,MAAM,OAAO,GAAG,aAAa,CAAC,CAAC,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;gBAC3D,MAAM,WAAW,GAAG,YAAY,CAAC,CAAC,GAAG,OAAO,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;gBAC/D,MAAM,cAAc,GAAG,OAAO,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC;gBACvE,MAAM,mBAAmB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,YAAY,CAAC,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC1G,MAAM,YAAY,GAAG,YAAY,CAAC,CAAC,GAAG,OAAO,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;gBAC/D,MAAM,aAAa,GAAG,OAAO,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC;gBACpE,MAAM,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,YAAY,CAAC,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;gBACxG,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,kBAAkB,EAAE,mBAAmB,CAAC,CAAC;gBACxE,IAAI,KAAK,EAAE;oBACP,IAAI,WAAW,IAAI,cAAc,IAAI,YAAY,IAAI,aAAa,EAAE;wBAChE,SAAS,GAAG,QAAQ,GAAG,aAAa,CAAC;qBACxC;iBACJ;qBAAM,IAAI,eAAe,EAAE;oBACxB,MAAM,WAAW,GAAa,EAAE,CAAC;oBACjC,MAAM,YAAY,GAAa,EAAE,CAAC;oBAClC,IAAI,CAAC,WAAW,IAAI,cAAc,CAAC,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE;wBAC/C,SAAS,GAAG,mBAAmB,CAAC;wBAChC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;wBAC7B,QAAQ,GAAG,KAAK,GAAG,CAAC,MAAM,GAAG,mBAAmB,CAAC,CAAC;wBAClD,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;qBAC9B;oBACD,IAAI,CAAC,YAAY,IAAI,aAAa,CAAC,EAAE;wBACjC,QAAQ,GAAG,kBAAkB,CAAC;wBAC9B,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBAC3B,SAAS,GAAG,MAAM,GAAG,CAAC,KAAK,GAAG,kBAAkB,CAAC,CAAC;wBAClD,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;qBAChC;oBACD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;wBAC1B,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,CAAC;qBACvC;oBACD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;wBAC3B,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC,CAAC;qBACzC;iBACJ;qBAAM;oBACH,IAAI,WAAW,IAAI,cAAc,EAAE;wBAC/B,SAAS,GAAG,mBAAmB,CAAC;qBACnC;oBACD,IAAI,YAAY,IAAI,aAAa,EAAE;wBAC/B,QAAQ,GAAG,kBAAkB,CAAC;qBACjC;iBACJ;gBAED,gCAAgC;gBAChC,IAAI,KAAK,EAAE;oBACP,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;oBACtD,IAAI,QAAQ,GAAG,GAAG,EAAE;wBAChB,QAAQ,GAAG,SAAS,GAAG,GAAG,CAAC;qBAC9B;yBAAM,IAAI,SAAS,GAAG,GAAG,EAAE;wBACxB,QAAQ,GAAG,SAAS,GAAG,GAAG,CAAC;qBAC9B;iBACJ;qBAAM,IAAI,eAAe,EAAE;oBACxB,IAAI,QAAQ,GAAG,QAAQ,CAAC,KAAK,EAAE;wBAC3B,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC;wBAC1B,SAAS,GAAG,MAAM,GAAG,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;qBACjD;yBAAM,IAAI,SAAS,GAAG,QAAQ,CAAC,MAAM,EAAE;wBACpC,QAAQ,GAAG,KAAK,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;wBAC9C,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC;qBAC/B;iBACJ;qBAAM;oBACH,IAAI,QAAQ,GAAG,QAAQ,CAAC,KAAK,EAAE;wBAC3B,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC;qBAC7B;yBAAM,IAAI,SAAS,GAAG,QAAQ,CAAC,MAAM,EAAE;wBACpC,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC;qBAC/B;iBACJ;gBAGD,eAAe;gBACf,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAChC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAElC,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,QAAQ,IAAI,CAAC;gBACtC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,SAAS,IAAI,CAAC;gBACxC,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;gBAC9B,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;aACnC;QACL,CAAC,CAAA;QAED,qDAAqD;QAC7C,eAAU,GAAG,CAAC,KAA8B,EAAE,EAAE;YACpD,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,IAAI,CAAC,QAAQ,CAAC,iBAAiB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;gBAClF,IAAI,CAAC,QAAQ,CAAC,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC;gBACrF,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAC5C,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE,CAAC;gBAChC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;aAClC;QACL,CAAC,CAAA;QAED,6CAA6C;QACrC,gBAAW,GAAG,GAAG,EAAE;YACvB,+EAA+E;YAC/E,sEAAsE;YACtE,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;aAC3C;QACL,CAAC,CAAA;QA1NG,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,CAAC;IAID,IACW,aAAa,CAAC,GAAY;QACjC,IAAI,GAAG,KAAK,IAAI,CAAC,cAAc,EAAE;YAC7B,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC;YAC1B,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC5B,IAAI,GAAG,EAAE;oBACL,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBAC5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;iBAC5B;qBAAM;oBACH,IAAI,CAAC,oBAAoB,EAAE,CAAC;iBAC/B;YACL,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IACD,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;YAC5C,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;YAC7E,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAClF,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,oBAAoB;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC;QAC7C,IAAI,OAAO,EAAE;YACT,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAC9B,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;YAChF,OAAO,CAAC,mBAAmB,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;SACpF;IACL,CAAC;IAiLO,iBAAiB,CAAC,YAAqC;QAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAC/B,MAAM,OAAO,GAAG,YAAY,CAAC,YAAY,CAAC,CAAC;QAC3C,MAAM,aAAa,GAAG,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC;QAC1D,MAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;QACtD,OAAO,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAC/E,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAE5E,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;SAChF;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAEjC,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,EAAE;YACzC,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SACrD;IACL,CAAC;IAED,iEAAiE;IACzD,mBAAmB;QACvB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAC/B,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAChF,OAAO,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAC5E,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAChF,OAAO,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAC7E,OAAO,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;QAEhF,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAEjC,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,EAAE;YACzC,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SACxD;IACL,CAAC;IAED,+FAA+F;IACvF,UAAU;QACd,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,MAAM,CAAC;IAChD,CAAC;8GAlSQ,wBAAwB,kBA2BrB,QAAQ;kGA3BX,wBAAwB,qTE7zCrC,kEACA;;2FF4zCa,wBAAwB;kBAPpC,SAAS;+BACI,mBAAmB,iBAGd,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BA6B1C,MAAM;2BAAC,QAAQ;+HAzBH,QAAQ;sBADxB,SAAS;uBAAC,SAAS;gBAIb,eAAe;sBADrB,KAAK;gBAKC,KAAK;sBAFX,KAAK;;sBACL,WAAW;uBAAC,aAAa;gBA8Bf,aAAa;sBADvB,KAAK","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"]}
|