@recursyve/nice-ui-kit.v2 14.0.0-beta.99 → 15.0.0-beta.120
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/esm2020/lib/api/interceptors/transform-response.interceptor.mjs +3 -3
- package/esm2020/lib/components/alert/alert.component.mjs +4 -4
- package/esm2020/lib/components/alert/alert.module.mjs +4 -4
- package/esm2020/lib/components/alert/alert.service.mjs +3 -3
- package/esm2020/lib/components/assets-carousel/assets-carousel.component.mjs +78 -49
- package/esm2020/lib/components/assets-carousel/assets-carousel.module.mjs +15 -10
- package/esm2020/lib/components/assets-carousel/directives/assets-carousel-active-content.directive.mjs +14 -0
- package/esm2020/lib/components/assets-carousel/public-api.mjs +2 -1
- package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +48 -35
- package/esm2020/lib/components/async-typeahead/async-typeahead.module.mjs +4 -4
- package/esm2020/lib/components/async-typeahead/providers/async-typeahead.service.mjs +15 -4
- package/esm2020/lib/components/async-typeahead/public-api.mjs +2 -1
- package/esm2020/lib/components/base-form/base-form.component.mjs +3 -3
- package/esm2020/lib/components/base-form/base-form.module.mjs +4 -4
- package/esm2020/lib/components/base-form/form-submit.directive.mjs +3 -3
- package/esm2020/lib/components/card/card.component.mjs +3 -3
- package/esm2020/lib/components/card/card.module.mjs +4 -4
- package/esm2020/lib/components/carousel/carousel.component.mjs +7 -7
- package/esm2020/lib/components/carousel/carousel.module.mjs +4 -4
- package/esm2020/lib/components/carousel/picture-modal/picture-modal.component.mjs +3 -3
- package/esm2020/lib/components/carousel/picture-modal/picture-modal.service.mjs +3 -3
- package/esm2020/lib/components/carousel/pipe/carousel-layout.pipe.mjs +3 -3
- package/esm2020/lib/components/collapsable/collapsable.component.mjs +36 -0
- package/esm2020/lib/components/collapsable/collapsable.module.mjs +25 -0
- package/esm2020/lib/components/collapsable/index.mjs +2 -0
- package/esm2020/lib/components/collapsable/public-api.mjs +3 -0
- package/esm2020/lib/components/date-range-picker/components/header/header.component.mjs +57 -0
- package/esm2020/lib/components/date-range-picker/components/range-preset/range-preset.component.mjs +107 -0
- package/esm2020/lib/components/date-range-picker/date-range-picker.component.mjs +74 -0
- package/esm2020/lib/components/date-range-picker/date-range-picker.module.mjs +56 -0
- package/esm2020/lib/components/date-range-picker/index.mjs +2 -0
- package/esm2020/lib/components/date-range-picker/providers/date-range-picker.service.mjs +17 -0
- package/esm2020/lib/components/date-range-picker/public-api.mjs +3 -0
- package/esm2020/lib/components/drawer/drawer.component.mjs +3 -3
- package/esm2020/lib/components/drawer/drawer.module.mjs +4 -4
- package/esm2020/lib/components/drawer/drawer.service.mjs +3 -3
- package/esm2020/lib/components/export-bottom-sheet/export-bottom-sheet.component.mjs +6 -7
- package/esm2020/lib/components/export-bottom-sheet/export-bottom-sheet.module.mjs +4 -4
- package/esm2020/lib/components/export-bottom-sheet/providers/export-bottom-sheet.service.mjs +6 -6
- package/esm2020/lib/components/form-error/control-status.directive.mjs +31 -11
- package/esm2020/lib/components/form-error/form-error.component.mjs +12 -21
- package/esm2020/lib/components/form-error/form-error.module.mjs +6 -7
- package/esm2020/lib/components/horizontal-stepper/horizontal-stepper.component.mjs +3 -3
- package/esm2020/lib/components/horizontal-stepper/horizontal-stepper.module.mjs +4 -4
- package/esm2020/lib/components/horizontal-stepper/step.component.mjs +3 -3
- package/esm2020/lib/components/image-cropper/image-cropper.component.mjs +35 -35
- package/esm2020/lib/components/image-cropper/image-cropper.module.mjs +4 -4
- package/esm2020/lib/components/layout/layout.component.mjs +3 -3
- package/esm2020/lib/components/layout/layout.module.mjs +4 -4
- package/esm2020/lib/components/loading-spinner/loading-spinner.component.mjs +3 -3
- package/esm2020/lib/components/loading-spinner/loading-spinner.module.mjs +4 -4
- package/esm2020/lib/components/loading-spinner/loading.directive.mjs +10 -10
- package/esm2020/lib/components/lottie/lottie.component.mjs +3 -3
- package/esm2020/lib/components/lottie/lottie.module.mjs +4 -4
- package/esm2020/lib/components/navigation/components/hint-component-base.mjs +120 -0
- package/esm2020/lib/components/navigation/directives/show-hint.directive.mjs +187 -0
- package/esm2020/lib/components/navigation/horizontal/components/basic/basic.component.mjs +3 -3
- package/esm2020/lib/components/navigation/horizontal/components/branch/branch.component.mjs +6 -5
- package/esm2020/lib/components/navigation/horizontal/components/divider/divider.component.mjs +3 -3
- package/esm2020/lib/components/navigation/horizontal/components/spacer/spacer.component.mjs +3 -3
- package/esm2020/lib/components/navigation/horizontal/horizontal.component.mjs +13 -12
- package/esm2020/lib/components/navigation/navigation.component.mjs +3 -3
- package/esm2020/lib/components/navigation/navigation.module.mjs +18 -7
- package/esm2020/lib/components/navigation/navigation.service.mjs +3 -3
- package/esm2020/lib/components/navigation/navigation.types.mjs +1 -1
- package/esm2020/lib/components/navigation/pipes/should-hide.pipe.mjs +31 -0
- package/esm2020/lib/components/navigation/pipes/should-show-hint.pipe.mjs +32 -0
- package/esm2020/lib/components/navigation/providers/hide-item.resolver.mjs +3 -0
- package/esm2020/lib/components/navigation/providers/hint.resolver.mjs +3 -0
- package/esm2020/lib/components/navigation/providers/hint.service.mjs +20 -0
- package/esm2020/lib/components/navigation/public-api.mjs +4 -1
- package/esm2020/lib/components/navigation/vertical/components/aside/aside.component.mjs +3 -3
- package/esm2020/lib/components/navigation/vertical/components/basic/basic.component.mjs +8 -6
- package/esm2020/lib/components/navigation/vertical/components/collapsable/collapsable.component.mjs +7 -5
- package/esm2020/lib/components/navigation/vertical/components/divider/divider.component.mjs +3 -3
- package/esm2020/lib/components/navigation/vertical/components/group/group.component.mjs +6 -5
- package/esm2020/lib/components/navigation/vertical/components/spacer/spacer.component.mjs +3 -3
- package/esm2020/lib/components/navigation/vertical/vertical.component.mjs +47 -24
- package/esm2020/lib/components/public-api.mjs +4 -1
- package/esm2020/lib/components/search-bar/search-bar.component.mjs +5 -5
- package/esm2020/lib/components/search-bar/search-bar.module.mjs +4 -4
- package/esm2020/lib/components/sweet-alert/sweet-alert.component.mjs +3 -3
- package/esm2020/lib/components/sweet-alert/sweet-alert.directive.mjs +3 -3
- package/esm2020/lib/components/sweet-alert/sweet-alert.module.mjs +4 -4
- package/esm2020/lib/components/sweet-alert/sweet-alert.service.mjs +3 -3
- package/esm2020/lib/components/toast/toast.component.mjs +4 -4
- package/esm2020/lib/components/toast/toast.module.mjs +4 -4
- package/esm2020/lib/components/toast/toast.service.mjs +3 -3
- package/esm2020/lib/components/toggle-button-group/toggle-button-group.component.mjs +5 -5
- package/esm2020/lib/components/toggle-button-group/toggle-button-group.module.mjs +4 -4
- package/esm2020/lib/components/toggle-button-group/toggle-button.component.mjs +3 -3
- package/esm2020/lib/components/translation-form/components/textarea/translation-form-textarea.component.mjs +37 -0
- package/esm2020/lib/components/translation-form/components/textfield/translation-form-textfield.component.mjs +25 -0
- package/esm2020/lib/components/translation-form/components/translation-form.component.mjs +164 -0
- package/esm2020/lib/components/translation-form/components/translation-form.module.mjs +71 -0
- package/esm2020/lib/components/translation-form/decorators/translation-form.decorator.mjs +4 -0
- package/esm2020/lib/components/translation-form/directives/translation-context.directive.mjs +34 -0
- package/esm2020/lib/components/translation-form/index.mjs +2 -0
- package/esm2020/lib/components/translation-form/providers/translation-form.service.mjs +46 -0
- package/esm2020/lib/components/translation-form/public-api.mjs +10 -0
- package/esm2020/lib/components/translation-form/toggle/translation-toggle.component.mjs +26 -0
- package/esm2020/lib/components/translation-form/translation.form.mjs +6 -0
- package/esm2020/lib/components/translation-form/validators/require-for-languages.validator.mjs +42 -0
- package/esm2020/lib/components/typeahead/directives/options-scroll.directive.mjs +3 -3
- package/esm2020/lib/components/typeahead/directives/options-scroll.module.mjs +4 -4
- package/esm2020/lib/components/typeahead/typeahead.component.mjs +60 -60
- package/esm2020/lib/components/typeahead/typeahead.module.mjs +4 -4
- package/esm2020/lib/directives/autofocus/autofocus.directive.mjs +3 -3
- package/esm2020/lib/directives/autofocus/autofocus.module.mjs +4 -4
- package/esm2020/lib/directives/autogrow/autogrow.directive.mjs +3 -3
- package/esm2020/lib/directives/autogrow/autogrow.module.mjs +4 -4
- package/esm2020/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.mjs +3 -3
- package/esm2020/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.mjs +3 -3
- package/esm2020/lib/directives/chip-list/chip-list-items/chip-list-items.component.mjs +22 -8
- package/esm2020/lib/directives/chip-list/chip-list.constant.mjs +3 -0
- package/esm2020/lib/directives/chip-list/chip-list.directive.mjs +44 -17
- package/esm2020/lib/directives/chip-list/chip-list.module.mjs +24 -5
- package/esm2020/lib/directives/draggable-list/draggable-list.directive.mjs +94 -0
- package/esm2020/lib/directives/draggable-list/draggable-list.module.mjs +18 -0
- package/esm2020/lib/directives/draggable-list/index.mjs +2 -0
- package/esm2020/lib/directives/draggable-list/public-api.mjs +3 -0
- package/esm2020/lib/directives/dropzone/dropzone.directive.mjs +3 -3
- package/esm2020/lib/directives/dropzone/dropzone.module.mjs +4 -4
- package/esm2020/lib/directives/image-error-placeholder/image-error-placeholder.directive.mjs +3 -3
- package/esm2020/lib/directives/image-error-placeholder/image-error-placeholder.module.mjs +4 -4
- package/esm2020/lib/directives/material/material.module.mjs +4 -4
- package/esm2020/lib/directives/material/nice-material-style.directive.mjs +4 -4
- package/esm2020/lib/directives/material/nice-rounded-style.directive.mjs +4 -4
- package/esm2020/lib/directives/modals/modal-on-click.directive.mjs +3 -3
- package/esm2020/lib/directives/modals/modal-opener.directive.mjs +3 -3
- package/esm2020/lib/directives/public-api.mjs +4 -1
- package/esm2020/lib/directives/rerender/index.mjs +2 -0
- package/esm2020/lib/directives/rerender/public-api.mjs +2 -0
- package/esm2020/lib/directives/rerender/rerender.directive.mjs +22 -0
- package/esm2020/lib/directives/resolve/index.mjs +2 -0
- package/esm2020/lib/directives/resolve/public-api.mjs +2 -0
- package/esm2020/lib/directives/resolve/resolve.directive.mjs +32 -0
- package/esm2020/lib/directives/scroll-reset/scroll-reset.directive.mjs +3 -3
- package/esm2020/lib/directives/scroll-reset/scroll-reset.module.mjs +4 -4
- package/esm2020/lib/directives/scrollbar/scrollbar.directive.mjs +3 -3
- package/esm2020/lib/directives/scrollbar/scrollbar.module.mjs +4 -4
- package/esm2020/lib/directives/stop-propagation/click-stop-propagation.directive.mjs +3 -3
- package/esm2020/lib/directives/stop-propagation/stop-propagation.module.mjs +4 -4
- package/esm2020/lib/directives/window/prevent-close-window.directive.mjs +3 -3
- package/esm2020/lib/directives/window/window-directive.module.mjs +4 -4
- package/esm2020/lib/nice.module.mjs +57 -5
- package/esm2020/lib/pipes/boolean.pipe.mjs +3 -3
- package/esm2020/lib/pipes/capitalize-first-letter.pipe.mjs +3 -3
- package/esm2020/lib/pipes/ceil.pipe.mjs +3 -3
- package/esm2020/lib/pipes/entries.pipe.mjs +3 -3
- package/esm2020/lib/pipes/find-by-key.pipe.mjs +3 -3
- package/esm2020/lib/pipes/first-letter.pipe.mjs +3 -3
- package/esm2020/lib/pipes/floor.pipe.mjs +3 -3
- package/esm2020/lib/pipes/join-if-defined.pipe.mjs +3 -3
- package/esm2020/lib/pipes/link.pipe.mjs +3 -3
- package/esm2020/lib/pipes/localized-boolean.pipe.mjs +3 -3
- package/esm2020/lib/pipes/localized-currency.pipe.mjs +3 -3
- package/esm2020/lib/pipes/localized-date-only.pipe.mjs +3 -3
- package/esm2020/lib/pipes/localized-date.pipe.mjs +3 -3
- package/esm2020/lib/pipes/minutes-to-time.pipe.mjs +3 -3
- package/esm2020/lib/pipes/number-to-ordinal-indicator.pipe.mjs +3 -3
- package/esm2020/lib/pipes/pad.pipe.mjs +3 -3
- package/esm2020/lib/pipes/phone.pipe.mjs +9 -9
- package/esm2020/lib/pipes/pipes.module.mjs +14 -9
- package/esm2020/lib/pipes/postal-code.pipe.mjs +9 -9
- package/esm2020/lib/pipes/public-api.mjs +2 -1
- package/esm2020/lib/pipes/range.pipe.mjs +3 -3
- package/esm2020/lib/pipes/round.pipe.mjs +3 -3
- package/esm2020/lib/pipes/sanitize-bypass.pipe.mjs +3 -3
- package/esm2020/lib/pipes/seconds-to-time.pipe.mjs +3 -3
- package/esm2020/lib/pipes/track-by-prop.pipe.mjs +14 -0
- package/esm2020/lib/providers/config/config.module.mjs +4 -4
- package/esm2020/lib/providers/config/config.service.mjs +3 -3
- package/esm2020/lib/providers/media-watcher/media-watcher.module.mjs +4 -4
- package/esm2020/lib/providers/media-watcher/media-watcher.service.mjs +3 -3
- package/esm2020/lib/providers/overlay/dynamic-overlay-container.service.mjs +3 -3
- package/esm2020/lib/providers/overlay/dynamic-overlay.service.mjs +3 -3
- package/esm2020/lib/providers/splash-screen/splash-screen.module.mjs +4 -4
- package/esm2020/lib/providers/splash-screen/splash-screen.service.mjs +3 -3
- package/esm2020/lib/providers/utils/utils.module.mjs +4 -4
- package/esm2020/lib/providers/utils/utils.service.mjs +3 -3
- package/esm2020/lib/utils/case.utils.mjs +7 -5
- package/esm2020/lib/utils/keyboard.utils.mjs +2 -1
- package/esm2020/lib/utils/lexorank.utils.mjs +28 -0
- package/esm2020/lib/utils/public-api.mjs +2 -1
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs +3130 -1631
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs +3069 -1578
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/lib/api/nice.api.d.ts +1 -1
- package/lib/components/alert/alert.component.d.ts +1 -1
- package/lib/components/alert/alert.types.d.ts +3 -3
- package/lib/components/assets-carousel/assets-carousel.component.d.ts +9 -3
- package/lib/components/assets-carousel/assets-carousel.module.d.ts +10 -8
- package/lib/components/assets-carousel/directives/assets-carousel-active-content.directive.d.ts +8 -0
- package/lib/components/assets-carousel/public-api.d.ts +1 -0
- package/lib/components/async-typeahead/async-typeahead.component.d.ts +5 -1
- package/lib/components/async-typeahead/public-api.d.ts +1 -0
- 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/card/card.types.d.ts +1 -1
- package/lib/components/carousel/carousel.component.d.ts +1 -1
- package/lib/components/carousel/picture-modal/picture-modal.component.d.ts +1 -1
- package/lib/components/collapsable/collapsable.component.d.ts +15 -0
- package/lib/components/collapsable/collapsable.module.d.ts +9 -0
- package/lib/components/collapsable/index.d.ts +1 -0
- package/lib/components/collapsable/public-api.d.ts +2 -0
- package/lib/components/date-range-picker/components/header/header.component.d.ts +20 -0
- package/lib/components/date-range-picker/components/range-preset/range-preset.component.d.ts +23 -0
- package/lib/components/date-range-picker/date-range-picker.component.d.ts +29 -0
- package/lib/components/date-range-picker/date-range-picker.module.d.ts +18 -0
- package/lib/components/date-range-picker/index.d.ts +1 -0
- package/lib/components/date-range-picker/providers/date-range-picker.service.d.ts +8 -0
- package/lib/components/date-range-picker/public-api.d.ts +2 -0
- package/lib/components/drawer/drawer.component.d.ts +1 -1
- package/lib/components/drawer/drawer.types.d.ts +2 -2
- package/lib/components/export-bottom-sheet/export-bottom-sheet.component.d.ts +1 -1
- package/lib/components/export-bottom-sheet/models/export-strategy.model.d.ts +1 -1
- package/lib/components/form-error/control-status.directive.d.ts +1 -1
- package/lib/components/form-error/form-error.component.d.ts +1 -1
- package/lib/components/horizontal-stepper/horizontal-stepper.component.d.ts +1 -1
- package/lib/components/horizontal-stepper/step.component.d.ts +1 -1
- package/lib/components/image-cropper/image-cropper.component.d.ts +2 -2
- package/lib/components/layout/layout.component.d.ts +1 -1
- 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/lottie/lottie.component.d.ts +1 -1
- package/lib/components/navigation/components/hint-component-base.d.ts +65 -0
- package/lib/components/navigation/directives/show-hint.directive.d.ts +39 -0
- 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/navigation.component.d.ts +1 -1
- package/lib/components/navigation/navigation.module.d.ts +13 -10
- package/lib/components/navigation/navigation.types.d.ts +12 -5
- package/lib/components/navigation/pipes/should-hide.pipe.d.ts +11 -0
- package/lib/components/navigation/pipes/should-show-hint.pipe.d.ts +12 -0
- package/lib/components/navigation/providers/hide-item.resolver.d.ts +5 -0
- package/lib/components/navigation/providers/hint.resolver.d.ts +4 -0
- package/lib/components/navigation/providers/hint.service.d.ts +9 -0
- package/lib/components/navigation/public-api.d.ts +3 -0
- 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 +8 -2
- package/lib/components/public-api.d.ts +3 -0
- package/lib/components/search-bar/search-bar.component.d.ts +1 -1
- package/lib/components/sweet-alert/sweet-alert.component.d.ts +1 -1
- package/lib/components/sweet-alert/sweet-alert.directive.d.ts +1 -1
- package/lib/components/toast/toast.component.d.ts +1 -1
- package/lib/components/toggle-button-group/toggle-button-group.component.d.ts +2 -2
- 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 +9 -0
- package/lib/components/translation-form/components/textfield/translation-form-textfield.component.d.ts +6 -0
- package/lib/components/translation-form/components/translation-form.component.d.ts +55 -0
- package/lib/components/translation-form/components/translation-form.module.d.ts +16 -0
- package/lib/components/translation-form/decorators/translation-form.decorator.d.ts +1 -0
- package/lib/components/translation-form/directives/translation-context.directive.d.ts +15 -0
- package/lib/components/translation-form/index.d.ts +1 -0
- package/lib/components/translation-form/providers/translation-form.service.d.ts +12 -0
- package/lib/components/translation-form/public-api.d.ts +9 -0
- package/lib/components/translation-form/toggle/translation-toggle.component.d.ts +14 -0
- package/lib/components/translation-form/translation.form.d.ts +5 -0
- package/lib/components/translation-form/validators/require-for-languages.validator.d.ts +14 -0
- 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/autofocus/autofocus.directive.d.ts +1 -1
- package/lib/directives/autogrow/autogrow.directive.d.ts +1 -1
- package/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.d.ts +1 -1
- package/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.d.ts +1 -1
- package/lib/directives/chip-list/chip-list-items/chip-list-items.component.d.ts +14 -2
- package/lib/directives/chip-list/chip-list.constant.d.ts +2 -0
- package/lib/directives/chip-list/chip-list.directive.d.ts +7 -4
- package/lib/directives/chip-list/chip-list.module.d.ts +3 -0
- package/lib/directives/draggable-list/draggable-list.directive.d.ts +24 -0
- package/lib/directives/draggable-list/draggable-list.module.d.ts +8 -0
- package/lib/directives/draggable-list/index.d.ts +1 -0
- package/lib/directives/draggable-list/public-api.d.ts +2 -0
- package/lib/directives/dropzone/dropzone.directive.d.ts +1 -1
- package/lib/directives/image-error-placeholder/image-error-placeholder.directive.d.ts +1 -1
- package/lib/directives/material/nice-material-style.directive.d.ts +1 -1
- package/lib/directives/material/nice-rounded-style.directive.d.ts +1 -1
- package/lib/directives/modals/modal-on-click.directive.d.ts +1 -1
- package/lib/directives/modals/modal-opener.directive.d.ts +1 -1
- package/lib/directives/public-api.d.ts +3 -0
- package/lib/directives/rerender/index.d.ts +1 -0
- package/lib/directives/rerender/public-api.d.ts +1 -0
- package/lib/directives/rerender/rerender.directive.d.ts +10 -0
- package/lib/directives/resolve/index.d.ts +1 -0
- package/lib/directives/resolve/public-api.d.ts +1 -0
- package/lib/directives/resolve/resolve.directive.d.ts +18 -0
- package/lib/directives/scroll-reset/scroll-reset.directive.d.ts +1 -1
- package/lib/directives/scrollbar/scrollbar.directive.d.ts +1 -1
- package/lib/directives/stop-propagation/click-stop-propagation.directive.d.ts +1 -1
- package/lib/directives/window/prevent-close-window.directive.d.ts +1 -1
- package/lib/pipes/phone.pipe.d.ts +3 -3
- package/lib/pipes/pipes.module.d.ts +2 -1
- package/lib/pipes/postal-code.pipe.d.ts +3 -3
- package/lib/pipes/public-api.d.ts +1 -0
- package/lib/pipes/track-by-prop.pipe.d.ts +7 -0
- package/lib/providers/config/config.model.d.ts +3 -3
- package/lib/types/constructor.d.ts +2 -2
- package/lib/utils/array.utils.d.ts +1 -1
- package/lib/utils/keyboard.utils.d.ts +2 -1
- package/lib/utils/lexorank.utils.d.ts +6 -0
- package/lib/utils/public-api.d.ts +1 -0
- package/package.json +10 -10
- package/src/lib/components/assets-carousel/assets-carousel.theme.scss +21 -15
- package/src/lib/components/collapsable/collapsable.theme.scss +48 -0
- package/src/lib/components/date-range-picker/date-range-picker.theme.scss +47 -0
- package/src/lib/components/navigation/vertical/styles/appearances/default.theme.scss +38 -0
- package/src/lib/components/navigation/vertical/styles/appearances/dense.theme.scss +2 -2
- package/src/lib/directives/chip-list/chip-list-items/chip-list-items.theme.scss +5 -1
- package/src/lib/nice.theme.scss +26 -9
- package/styles/main.scss +1 -4
- package/styles/overrides/angular-material.scss +505 -766
- package/styles/overrides/quill.scss +42 -5
- package/styles/tailwind.scss +47 -1
- package/styles/core/tailwind-config.scss +0 -6
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { Component, ElementRef, EventEmitter, forwardRef, Inject, Input, Optional, Output, QueryList, ViewChild, ViewChildren, ViewEncapsulation } from "@angular/core";
|
|
1
|
+
import { Component, ContentChild, ElementRef, EventEmitter, forwardRef, Inject, Input, Optional, Output, QueryList, TemplateRef, ViewChild, ViewChildren, ViewEncapsulation, } from "@angular/core";
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
3
|
import { niceAnimations } from "../../animations";
|
|
4
4
|
import { FileUtils } from "../../utils";
|
|
5
5
|
import { NICE_ASSETS_CAROUSEL_OPTIONS } from "./assets-carousel.constant";
|
|
6
|
+
import { NiceAssetsCarouselActiveContentDirective } from "./directives/assets-carousel-active-content.directive";
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common";
|
|
8
9
|
import * as i2 from "@angular/material/icon";
|
|
@@ -10,8 +11,42 @@ import * as i3 from "@angular/material/button";
|
|
|
10
11
|
import * as i4 from "@angular/material/menu";
|
|
11
12
|
import * as i5 from "@angular/material/core";
|
|
12
13
|
import * as i6 from "../../directives/dropzone/dropzone.directive";
|
|
13
|
-
import * as i7 from "@
|
|
14
|
+
import * as i7 from "@angular/material/progress-spinner";
|
|
15
|
+
import * as i8 from "@ngx-translate/core";
|
|
14
16
|
export class NiceAssetsCarouselComponent {
|
|
17
|
+
set activeVideoElement(activeVideoElement) {
|
|
18
|
+
this._activeVideoElement = activeVideoElement;
|
|
19
|
+
if (!this._activeVideoElement || !this._assetsElement) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
this.startSyncVideo();
|
|
23
|
+
}
|
|
24
|
+
set assetsElement(assetsElement) {
|
|
25
|
+
this._assetsElement = assetsElement;
|
|
26
|
+
if (!this._activeVideoElement || !this._assetsElement) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
this.startSyncVideo();
|
|
30
|
+
}
|
|
31
|
+
set assets(assets) {
|
|
32
|
+
this.writeValue(assets ?? []);
|
|
33
|
+
}
|
|
34
|
+
set activeTranslationPosition(position) {
|
|
35
|
+
this._activeTranslationPosition = position;
|
|
36
|
+
this.listStyle.transform = `translateX(calc((var(--nice-assets-carousel-asset-width) + var(--nice-assets-carousel-asset-gap)) * ${position}))`;
|
|
37
|
+
}
|
|
38
|
+
set activeAsset(position) {
|
|
39
|
+
if (position < 0) {
|
|
40
|
+
position = 0;
|
|
41
|
+
}
|
|
42
|
+
this._active = position;
|
|
43
|
+
this._activeAsset = this._assets[this._active];
|
|
44
|
+
this._lastAsset = this._active === this._assets.length - 1 || !this._assets.length;
|
|
45
|
+
this._shouldTransform
|
|
46
|
+
= ((this.edit && this.showAddAssetContainer) && this._active >= (this.visiblePreviewAsset - 1))
|
|
47
|
+
|| this._active >= this.visiblePreviewAsset;
|
|
48
|
+
this.activeChange.emit(this._active);
|
|
49
|
+
}
|
|
15
50
|
constructor(options) {
|
|
16
51
|
this.options = options;
|
|
17
52
|
this._activeTranslationPosition = 0;
|
|
@@ -22,11 +57,14 @@ export class NiceAssetsCarouselComponent {
|
|
|
22
57
|
this.defaultColor = "primary";
|
|
23
58
|
this.color = this.defaultColor;
|
|
24
59
|
this.edit = false;
|
|
60
|
+
this.loading = false;
|
|
25
61
|
this.accept = ["image/*"];
|
|
26
62
|
this.customActions = [];
|
|
27
63
|
this.multipleUpload = false;
|
|
64
|
+
this.visiblePreviewAsset = 4;
|
|
28
65
|
this.showAddAssetContainer = true;
|
|
29
66
|
this.activeChange = new EventEmitter();
|
|
67
|
+
this.removedAsset = new EventEmitter();
|
|
30
68
|
this.listStyle = { transform: "translateX(0px)" };
|
|
31
69
|
if (!this.options) {
|
|
32
70
|
this.options = {
|
|
@@ -56,45 +94,15 @@ export class NiceAssetsCarouselComponent {
|
|
|
56
94
|
};
|
|
57
95
|
}
|
|
58
96
|
}
|
|
59
|
-
set activeVideoElement(activeVideoElement) {
|
|
60
|
-
this._activeVideoElement = activeVideoElement;
|
|
61
|
-
if (!this._activeVideoElement || !this._assetsElement) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
this.startSyncVideo();
|
|
65
|
-
}
|
|
66
|
-
set assetsElement(assetsElement) {
|
|
67
|
-
this._assetsElement = assetsElement;
|
|
68
|
-
if (!this._activeVideoElement || !this._assetsElement) {
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
this.startSyncVideo();
|
|
72
|
-
}
|
|
73
|
-
set assets(assets) {
|
|
74
|
-
this.writeValue(assets ?? []);
|
|
75
|
-
}
|
|
76
|
-
set activeTranslationPosition(position) {
|
|
77
|
-
this._activeTranslationPosition = position;
|
|
78
|
-
this.listStyle.transform = `translateX(${position}px)`;
|
|
79
|
-
}
|
|
80
|
-
set activeAsset(position) {
|
|
81
|
-
if (position < 0) {
|
|
82
|
-
position = 0;
|
|
83
|
-
}
|
|
84
|
-
this._active = position;
|
|
85
|
-
this._activeAsset = this._assets[this._active];
|
|
86
|
-
this._lastAsset = this._active === this._assets.length - 1 || !this._assets.length;
|
|
87
|
-
this._shouldTransform = (this.edit && this._active >= 3) || this._active >= 4;
|
|
88
|
-
this.activeChange.emit(this._active);
|
|
89
|
-
}
|
|
90
97
|
writeValue(assets) {
|
|
91
98
|
this._assets = assets ?? [];
|
|
92
|
-
if (this._assets
|
|
93
|
-
this._activeAsset =
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
99
|
+
if (this._assets.length === 0) {
|
|
100
|
+
this._activeAsset = null;
|
|
96
101
|
this._lastAsset = true;
|
|
97
102
|
}
|
|
103
|
+
else if (this._assets.length > 0) {
|
|
104
|
+
this._activeAsset = this._assets[this._active];
|
|
105
|
+
}
|
|
98
106
|
}
|
|
99
107
|
registerOnChange(fn) {
|
|
100
108
|
this.propagate = fn;
|
|
@@ -105,7 +113,7 @@ export class NiceAssetsCarouselComponent {
|
|
|
105
113
|
this.activeAsset = this._active - 1;
|
|
106
114
|
}
|
|
107
115
|
if (this._activeTranslationPosition < 0) {
|
|
108
|
-
this.activeTranslationPosition = this._activeTranslationPosition +
|
|
116
|
+
this.activeTranslationPosition = this._activeTranslationPosition + 1;
|
|
109
117
|
}
|
|
110
118
|
}
|
|
111
119
|
clickRight() {
|
|
@@ -114,23 +122,26 @@ export class NiceAssetsCarouselComponent {
|
|
|
114
122
|
}
|
|
115
123
|
this.activeAsset = this._active + 1;
|
|
116
124
|
if (this._shouldTransform) {
|
|
117
|
-
this.activeTranslationPosition = this._activeTranslationPosition -
|
|
125
|
+
this.activeTranslationPosition = this._activeTranslationPosition - 1;
|
|
118
126
|
}
|
|
119
127
|
}
|
|
120
128
|
clickAsset(index) {
|
|
121
|
-
let visibleAssets = this.edit ? 2 :
|
|
129
|
+
let visibleAssets = (this.edit && this.showAddAssetContainer) ? (this.visiblePreviewAsset - 2) : (this.visiblePreviewAsset - 1);
|
|
122
130
|
if (index < visibleAssets) {
|
|
123
131
|
visibleAssets = index;
|
|
124
132
|
}
|
|
125
133
|
if (index >= 0) {
|
|
126
|
-
this.activeTranslationPosition = (index - visibleAssets) * -
|
|
134
|
+
this.activeTranslationPosition = (index - visibleAssets) * -1;
|
|
127
135
|
}
|
|
128
136
|
this.activeAsset = index;
|
|
129
137
|
}
|
|
130
138
|
async onFilesChange(event) {
|
|
131
|
-
|
|
139
|
+
let files = event.target?.files;
|
|
140
|
+
if (this.imagesProcessor) {
|
|
141
|
+
files = await this.getProcessedFiles(files);
|
|
142
|
+
}
|
|
132
143
|
await this.onFilesDrop(files);
|
|
133
|
-
this.inputElement.nativeElement.
|
|
144
|
+
this.inputElement.nativeElement.value = "";
|
|
134
145
|
}
|
|
135
146
|
async onFilesDrop(files) {
|
|
136
147
|
if (!files?.length) {
|
|
@@ -160,6 +171,7 @@ export class NiceAssetsCarouselComponent {
|
|
|
160
171
|
}
|
|
161
172
|
}
|
|
162
173
|
clickRemove() {
|
|
174
|
+
this.removedAsset.emit(this._assets[this._active]);
|
|
163
175
|
this._assets.splice(this._active, 1);
|
|
164
176
|
if (this._lastAsset) {
|
|
165
177
|
this.clickAsset(this._assets.length - 1);
|
|
@@ -179,16 +191,22 @@ export class NiceAssetsCarouselComponent {
|
|
|
179
191
|
await this._activeVideoElement.nativeElement.play();
|
|
180
192
|
await this._assetsElement.get(this._active).nativeElement.firstElementChild.play();
|
|
181
193
|
}
|
|
194
|
+
async getProcessedFiles(files) {
|
|
195
|
+
try {
|
|
196
|
+
return await this.imagesProcessor(files);
|
|
197
|
+
}
|
|
198
|
+
catch (e) { }
|
|
199
|
+
}
|
|
182
200
|
}
|
|
183
|
-
NiceAssetsCarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
184
|
-
NiceAssetsCarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
201
|
+
NiceAssetsCarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselComponent, deps: [{ token: NICE_ASSETS_CAROUSEL_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
202
|
+
NiceAssetsCarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NiceAssetsCarouselComponent, selector: "nice-assets-carousel", inputs: { color: "color", edit: "edit", loading: "loading", accept: "accept", customActions: "customActions", imagesProcessor: "imagesProcessor", multipleUpload: "multipleUpload", visiblePreviewAsset: "visiblePreviewAsset", showAddAssetContainer: "showAddAssetContainer", assets: "assets" }, outputs: { activeChange: "activeChange", removedAsset: "removedAsset" }, providers: [
|
|
185
203
|
{
|
|
186
204
|
provide: NG_VALUE_ACCESSOR,
|
|
187
205
|
useExisting: forwardRef(() => NiceAssetsCarouselComponent),
|
|
188
206
|
multi: true
|
|
189
207
|
}
|
|
190
|
-
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["fileInput"], descendants: true }, { propertyName: "activeVideoElement", first: true, predicate: ["activeVideo"], descendants: true }, { propertyName: "assetsElement", predicate: ["assets"], descendants: true }], ngImport: i0, template: "<div class=\"carousel-container\" niceDropzone (filesDropped)=\"onFilesDrop($event)\">\n <div
|
|
191
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
208
|
+
], queries: [{ propertyName: "activeContent", first: true, predicate: NiceAssetsCarouselActiveContentDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["fileInput"], descendants: true }, { propertyName: "activeVideoElement", first: true, predicate: ["activeVideo"], descendants: true }, { propertyName: "assetsElement", predicate: ["assets"], descendants: true }], ngImport: i0, template: "<div class=\"carousel-container\" niceDropzone (filesDropped)=\"onFilesDrop($event)\">\n <div\n class=\"active-image\"\n matRipple\n [class.empty-state]=\"!_activeAsset\"\n (click)=\"edit && fileInput.click();\n $event.stopPropagation()\"\n >\n <div *ngIf=\"loading\" class=\"flex flex-row justify-center items-center h-full\">\n <mat-spinner [diameter]=\"32\"></mat-spinner>\n </div>\n <ng-container *ngIf=\"!loading\">\n <ng-container\n *ngIf=\"_activeAsset && activeContent\"\n [ngTemplateOutlet]=\"activeContent\"\n [ngTemplateOutletContext]=\"{ $implicit: _activeAsset}\"\n ></ng-container>\n <img\n *ngIf=\"_activeAsset?.type === 'image'\"\n (mouseover)=\"showOverlay=true\"\n [src]=\"_activeAsset.url ?? _activeAsset.base64\"\n draggable=\"false\"\n class=\"relative\"\n alt=\"active-image\"\n >\n <video #activeVideo *ngIf=\"_activeAsset?.type === 'video'\" draggable=\"false\" loop [src]=\"_activeAsset.url ?? _activeAsset.base64\"></video>\n\n <div class=\"empty-state-content\" *ngIf=\"!_activeAsset\">\n <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n <div class=\"text\">\n {{ \"nice_ui_kit.assets_carousel.upload_here\" | translate }}\n </div>\n </div>\n\n <div *ngIf=\"_activeAsset && showOverlay && edit\" class=\"active-image-overlay\">\n <div\n (mouseout)=\"showOverlay=false\"\n class=\"flex flex-col justify-center items-center w-full h-full\"\n >\n <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n </div>\n </div>\n\n <div *ngIf=\"edit\" class=\"active-buttons\">\n <button mat-icon-button (click)=\"fileInput.click(); $event.stopPropagation()\">\n <mat-icon *ngIf=\"options.actionButtons.addPhoto.matIcon\">{{ options.actionButtons.addPhoto.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.actionButtons.addPhoto.svgIcon\" [svgIcon]=\"options.actionButtons.addPhoto.svgIcon\"></mat-icon>\n </button>\n <button mat-icon-button [matMenuTriggerFor]=\"assetActions\" (click)=\"$event.stopPropagation()\" [disabled]=\"!_activeAsset\">\n <mat-icon *ngIf=\"options.actionButtons.moreOptions.matIcon\">{{ options.actionButtons.moreOptions.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.actionButtons.moreOptions.svgIcon\" [svgIcon]=\"options.actionButtons.moreOptions.svgIcon\"></mat-icon>\n </button>\n <mat-menu class=\"nice-asset-options-menu\" [xPosition]=\"'before'\" #assetActions=\"matMenu\">\n <button\n mat-menu-item\n *ngFor=\"let action of customActions\"\n (click)=\"clickCustom(action)\"\n >\n <mat-icon *ngIf=\"action.icon.matIcon\">{{ action.icon.matIcon }}</mat-icon>\n <mat-icon [svgIcon]=\"action.icon.svgIcon\" *ngIf=\"action.icon.svgIcon\"></mat-icon>\n <span>{{ action.name | translate }}</span>\n </button>\n <button mat-menu-item (click)=\"clickRemove()\">\n <mat-icon *ngIf=\"options.actionButtons.remove.matIcon\">{{ options.actionButtons.remove.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.actionButtons.remove.svgIcon\" [svgIcon]=\"options.actionButtons.remove.svgIcon\"></mat-icon>\n <span>{{ \"nice_ui_kit.assets_carousel.delete\" | translate }}</span>\n </button>\n </mat-menu>\n </div>\n </ng-container>\n </div>\n\n <div class=\"carousel\">\n <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button left-arrow\" mat-icon-button [disabled]=\"!_active\" (click)=\"clickLeft()\">\n <mat-icon *ngIf=\"options.leftArrow.matIcon\">{{ options.leftArrow.matIcon }}</mat-icon>\n <mat-icon class=\"arrows\" *ngIf=\"options.leftArrow.svgIcon\" [svgIcon]=\"options.leftArrow.svgIcon\"></mat-icon>\n </button>\n <div class=\"asset-list-container\">\n <div *ngIf=\"showAddAssetContainer && edit\" class=\"add-asset-container\">\n <div class=\"add-asset\" matRipple (click)=\"fileInput.click()\">\n <mat-icon *ngIf=\"options.addPhoto.matIcon\">{{ options.addPhoto.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.addPhoto.svgIcon\" [svgIcon]=\"options.addPhoto.svgIcon\"></mat-icon>\n </div>\n </div>\n <div class=\"asset-list\" [ngStyle]=\"listStyle\">\n <div\n #assets\n class=\"asset\"\n *ngFor=\"let asset of _assets; let i = index\"\n (click)=\"clickAsset(i)\"\n [ngClass]=\"color\"\n [class.active]=\"_active === i\"\n >\n <ng-container>\n <img\n *ngIf=\"asset.type === 'image'\"\n draggable=\"false\"\n [src]=\"asset.url ?? asset.base64\"\n alt=\"add-image\"\n />\n <video\n *ngIf=\"asset.type === 'video'\"\n draggable=\"false\"\n loop\n [src]=\"asset.url ?? asset.base64\"\n ></video>\n </ng-container>\n </div>\n </div>\n </div>\n <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button right-arrow\" mat-icon-button [disabled]=\"_lastAsset\" (click)=\"clickRight()\">\n <mat-icon *ngIf=\"options.rightArrow.matIcon\">{{ options.rightArrow.matIcon }}</mat-icon>\n <mat-icon class=\"arrows\" *ngIf=\"options.rightArrow.svgIcon\" [svgIcon]=\"options.rightArrow.svgIcon\"></mat-icon>\n </button>\n </div>\n</div>\n\n<input #fileInput type=\"file\" hidden [accept]=\"accept\" (change)=\"onFilesChange($event)\" [multiple]=\"multipleUpload\">\n", styles: [":root{--nice-assets-carousel-asset-width: 90px;--nice-assets-carousel-asset-height: 60px;--nice-assets-carousel-asset-gap: .75rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i5.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i6.NiceDropzoneDirective, selector: "[niceDropzone]", outputs: ["filesDropped"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], animations: niceAnimations, encapsulation: i0.ViewEncapsulation.None });
|
|
209
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselComponent, decorators: [{
|
|
192
210
|
type: Component,
|
|
193
211
|
args: [{ selector: "nice-assets-carousel", encapsulation: ViewEncapsulation.None, animations: niceAnimations, providers: [
|
|
194
212
|
{
|
|
@@ -196,7 +214,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
|
|
|
196
214
|
useExisting: forwardRef(() => NiceAssetsCarouselComponent),
|
|
197
215
|
multi: true
|
|
198
216
|
}
|
|
199
|
-
], template: "<div class=\"carousel-container\" niceDropzone (filesDropped)=\"onFilesDrop($event)\">\n <div
|
|
217
|
+
], template: "<div class=\"carousel-container\" niceDropzone (filesDropped)=\"onFilesDrop($event)\">\n <div\n class=\"active-image\"\n matRipple\n [class.empty-state]=\"!_activeAsset\"\n (click)=\"edit && fileInput.click();\n $event.stopPropagation()\"\n >\n <div *ngIf=\"loading\" class=\"flex flex-row justify-center items-center h-full\">\n <mat-spinner [diameter]=\"32\"></mat-spinner>\n </div>\n <ng-container *ngIf=\"!loading\">\n <ng-container\n *ngIf=\"_activeAsset && activeContent\"\n [ngTemplateOutlet]=\"activeContent\"\n [ngTemplateOutletContext]=\"{ $implicit: _activeAsset}\"\n ></ng-container>\n <img\n *ngIf=\"_activeAsset?.type === 'image'\"\n (mouseover)=\"showOverlay=true\"\n [src]=\"_activeAsset.url ?? _activeAsset.base64\"\n draggable=\"false\"\n class=\"relative\"\n alt=\"active-image\"\n >\n <video #activeVideo *ngIf=\"_activeAsset?.type === 'video'\" draggable=\"false\" loop [src]=\"_activeAsset.url ?? _activeAsset.base64\"></video>\n\n <div class=\"empty-state-content\" *ngIf=\"!_activeAsset\">\n <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n <div class=\"text\">\n {{ \"nice_ui_kit.assets_carousel.upload_here\" | translate }}\n </div>\n </div>\n\n <div *ngIf=\"_activeAsset && showOverlay && edit\" class=\"active-image-overlay\">\n <div\n (mouseout)=\"showOverlay=false\"\n class=\"flex flex-col justify-center items-center w-full h-full\"\n >\n <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n </div>\n </div>\n\n <div *ngIf=\"edit\" class=\"active-buttons\">\n <button mat-icon-button (click)=\"fileInput.click(); $event.stopPropagation()\">\n <mat-icon *ngIf=\"options.actionButtons.addPhoto.matIcon\">{{ options.actionButtons.addPhoto.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.actionButtons.addPhoto.svgIcon\" [svgIcon]=\"options.actionButtons.addPhoto.svgIcon\"></mat-icon>\n </button>\n <button mat-icon-button [matMenuTriggerFor]=\"assetActions\" (click)=\"$event.stopPropagation()\" [disabled]=\"!_activeAsset\">\n <mat-icon *ngIf=\"options.actionButtons.moreOptions.matIcon\">{{ options.actionButtons.moreOptions.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.actionButtons.moreOptions.svgIcon\" [svgIcon]=\"options.actionButtons.moreOptions.svgIcon\"></mat-icon>\n </button>\n <mat-menu class=\"nice-asset-options-menu\" [xPosition]=\"'before'\" #assetActions=\"matMenu\">\n <button\n mat-menu-item\n *ngFor=\"let action of customActions\"\n (click)=\"clickCustom(action)\"\n >\n <mat-icon *ngIf=\"action.icon.matIcon\">{{ action.icon.matIcon }}</mat-icon>\n <mat-icon [svgIcon]=\"action.icon.svgIcon\" *ngIf=\"action.icon.svgIcon\"></mat-icon>\n <span>{{ action.name | translate }}</span>\n </button>\n <button mat-menu-item (click)=\"clickRemove()\">\n <mat-icon *ngIf=\"options.actionButtons.remove.matIcon\">{{ options.actionButtons.remove.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.actionButtons.remove.svgIcon\" [svgIcon]=\"options.actionButtons.remove.svgIcon\"></mat-icon>\n <span>{{ \"nice_ui_kit.assets_carousel.delete\" | translate }}</span>\n </button>\n </mat-menu>\n </div>\n </ng-container>\n </div>\n\n <div class=\"carousel\">\n <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button left-arrow\" mat-icon-button [disabled]=\"!_active\" (click)=\"clickLeft()\">\n <mat-icon *ngIf=\"options.leftArrow.matIcon\">{{ options.leftArrow.matIcon }}</mat-icon>\n <mat-icon class=\"arrows\" *ngIf=\"options.leftArrow.svgIcon\" [svgIcon]=\"options.leftArrow.svgIcon\"></mat-icon>\n </button>\n <div class=\"asset-list-container\">\n <div *ngIf=\"showAddAssetContainer && edit\" class=\"add-asset-container\">\n <div class=\"add-asset\" matRipple (click)=\"fileInput.click()\">\n <mat-icon *ngIf=\"options.addPhoto.matIcon\">{{ options.addPhoto.matIcon }}</mat-icon>\n <mat-icon *ngIf=\"options.addPhoto.svgIcon\" [svgIcon]=\"options.addPhoto.svgIcon\"></mat-icon>\n </div>\n </div>\n <div class=\"asset-list\" [ngStyle]=\"listStyle\">\n <div\n #assets\n class=\"asset\"\n *ngFor=\"let asset of _assets; let i = index\"\n (click)=\"clickAsset(i)\"\n [ngClass]=\"color\"\n [class.active]=\"_active === i\"\n >\n <ng-container>\n <img\n *ngIf=\"asset.type === 'image'\"\n draggable=\"false\"\n [src]=\"asset.url ?? asset.base64\"\n alt=\"add-image\"\n />\n <video\n *ngIf=\"asset.type === 'video'\"\n draggable=\"false\"\n loop\n [src]=\"asset.url ?? asset.base64\"\n ></video>\n </ng-container>\n </div>\n </div>\n </div>\n <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button right-arrow\" mat-icon-button [disabled]=\"_lastAsset\" (click)=\"clickRight()\">\n <mat-icon *ngIf=\"options.rightArrow.matIcon\">{{ options.rightArrow.matIcon }}</mat-icon>\n <mat-icon class=\"arrows\" *ngIf=\"options.rightArrow.svgIcon\" [svgIcon]=\"options.rightArrow.svgIcon\"></mat-icon>\n </button>\n </div>\n</div>\n\n<input #fileInput type=\"file\" hidden [accept]=\"accept\" (change)=\"onFilesChange($event)\" [multiple]=\"multipleUpload\">\n", styles: [":root{--nice-assets-carousel-asset-width: 90px;--nice-assets-carousel-asset-height: 60px;--nice-assets-carousel-asset-gap: .75rem}\n"] }]
|
|
200
218
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
201
219
|
type: Optional
|
|
202
220
|
}, {
|
|
@@ -209,16 +227,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
|
|
|
209
227
|
type: Input
|
|
210
228
|
}], edit: [{
|
|
211
229
|
type: Input
|
|
230
|
+
}], loading: [{
|
|
231
|
+
type: Input
|
|
212
232
|
}], accept: [{
|
|
213
233
|
type: Input
|
|
214
234
|
}], customActions: [{
|
|
215
235
|
type: Input
|
|
236
|
+
}], imagesProcessor: [{
|
|
237
|
+
type: Input
|
|
216
238
|
}], multipleUpload: [{
|
|
217
239
|
type: Input
|
|
240
|
+
}], visiblePreviewAsset: [{
|
|
241
|
+
type: Input
|
|
218
242
|
}], showAddAssetContainer: [{
|
|
219
243
|
type: Input
|
|
244
|
+
}], activeContent: [{
|
|
245
|
+
type: ContentChild,
|
|
246
|
+
args: [NiceAssetsCarouselActiveContentDirective, { read: TemplateRef }]
|
|
220
247
|
}], activeChange: [{
|
|
221
248
|
type: Output
|
|
249
|
+
}], removedAsset: [{
|
|
250
|
+
type: Output
|
|
222
251
|
}], activeVideoElement: [{
|
|
223
252
|
type: ViewChild,
|
|
224
253
|
args: ["activeVideo"]
|
|
@@ -228,4 +257,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
|
|
|
228
257
|
}], assets: [{
|
|
229
258
|
type: Input
|
|
230
259
|
}] } });
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets-carousel.component.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/assets-carousel/assets-carousel.component.ts","../../../../../../projects/nice-ui-kit-v2/src/lib/components/assets-carousel/assets-carousel.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    Optional,\n    Output, QueryList,\n    ViewChild, ViewChildren,\n    ViewEncapsulation\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CanColor, ThemePalette } from \"@angular/material/core\";\nimport { niceAnimations } from \"../../animations\";\nimport { FileUtils } from \"../../utils\";\nimport { NICE_ASSETS_CAROUSEL_OPTIONS } from \"./assets-carousel.constant\";\n\nexport interface NiceAssets {\n    type: \"image\" | \"video\";\n    id?: number | string;\n    url?: string;\n    base64?: string;\n    file?: File;\n}\n\nexport type NiceAssetsCarouselActionIcon = { matIcon: string; svgIcon?: string; } | { matIcon?: string; svgIcon: string; };\n\nexport interface NiceAssetsCarouselActions {\n    icon: NiceAssetsCarouselActionIcon;\n    name: string;\n    action: (active: number) => void;\n}\n\nexport interface NiceAssetsCarouselOptions {\n    actionButtons?: {\n        moreOptions?: NiceAssetsCarouselActionIcon;\n        addPhoto?: NiceAssetsCarouselActionIcon;\n        remove?: NiceAssetsCarouselActionIcon;\n    };\n    addPhoto?: NiceAssetsCarouselActionIcon;\n    leftArrow?: NiceAssetsCarouselActionIcon;\n    rightArrow?: NiceAssetsCarouselActionIcon;\n    upload?: NiceAssetsCarouselActionIcon;\n}\n\n@Component({\n    selector: \"nice-assets-carousel\",\n    templateUrl: \"assets-carousel.template.html\",\n    styleUrls: [\"assets-carousel.theme.scss\"],\n    encapsulation: ViewEncapsulation.None,\n    animations: niceAnimations,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NiceAssetsCarouselComponent),\n            multi: true\n        }\n    ]\n})\nexport class NiceAssetsCarouselComponent implements ControlValueAccessor, CanColor {\n    public _activeTranslationPosition = 0;\n    public _active = 0;\n    public _assets: NiceAssets[] = [];\n    public _activeAsset: NiceAssets;\n    public _lastAsset = true;\n    public _shouldTransform = false;\n    public _activeVideoElement: ElementRef<HTMLVideoElement>;\n    public _assetsElement: QueryList<ElementRef<HTMLDivElement>>;\n    public defaultColor: ThemePalette = \"primary\";\n\n    @ViewChild(\"fileInput\")\n    public inputElement: ElementRef<HTMLInputElement>;\n\n    @Input()\n    public color: ThemePalette = this.defaultColor;\n\n    @Input()\n    public edit = false;\n\n    @Input()\n    public accept: string[] = [\"image/*\"];\n\n    @Input()\n    public customActions: NiceAssetsCarouselActions[] = [];\n\n    @Input()\n    public multipleUpload = false;\n\n    @Input()\n    public showAddAssetContainer = true;\n\n    @Output()\n    public activeChange = new EventEmitter<number>();\n\n    public listStyle: { transform: string } = { transform: \"translateX(0px)\" };\n\n    public showOverlay: boolean;\n\n    private propagate: (assets: NiceAssets[]) => void;\n\n    @ViewChild(\"activeVideo\")\n    public set activeVideoElement(activeVideoElement: ElementRef<HTMLVideoElement>) {\n        this._activeVideoElement = activeVideoElement;\n        if (!this._activeVideoElement || !this._assetsElement) {\n            return;\n        }\n\n        this.startSyncVideo();\n    }\n\n    @ViewChildren(\"assets\")\n    public set assetsElement(assetsElement: QueryList<ElementRef<HTMLDivElement>>) {\n        this._assetsElement = assetsElement;\n        if (!this._activeVideoElement || !this._assetsElement) {\n            return;\n        }\n\n        this.startSyncVideo();\n    }\n\n    @Input()\n    public set assets(assets: NiceAssets[]) {\n        this.writeValue(assets ?? []);\n    }\n\n    private set activeTranslationPosition(position: number) {\n        this._activeTranslationPosition = position;\n        this.listStyle.transform = `translateX(${position}px)`;\n    }\n\n    private set activeAsset(position: number) {\n        if (position < 0) {\n            position = 0;\n        }\n\n        this._active = position;\n        this._activeAsset = this._assets[this._active];\n        this._lastAsset = this._active === this._assets.length - 1 || !this._assets.length;\n        this._shouldTransform = (this.edit && this._active >= 3) || this._active >= 4;\n        this.activeChange.emit(this._active);\n    }\n\n    constructor(@Optional() @Inject(NICE_ASSETS_CAROUSEL_OPTIONS) public readonly options: NiceAssetsCarouselOptions) {\n        if (!this.options) {\n            this.options = {\n                actionButtons: {\n                    addPhoto: {\n                        matIcon: \"photo_camera\"\n                    },\n                    moreOptions: {\n                        matIcon: \"more_vert\"\n                    },\n                    remove: {\n                        matIcon: \"delete\"\n                    }\n                },\n                addPhoto: {\n                    matIcon: \"photo_camera\"\n                },\n                leftArrow: {\n                    matIcon: \"chevron_left\"\n                },\n                rightArrow: {\n                    matIcon: \"chevron_right\"\n                },\n                upload: {\n                    matIcon: \"file_upload\"\n                }\n            };\n        }\n    }\n\n    public writeValue(assets: NiceAssets[]): void {\n        this._assets = assets ?? [];\n        if (this._assets?.length) {\n            this._activeAsset = this._assets[this._active];\n        } else {\n            this._lastAsset = true;\n        }\n    }\n\n    public registerOnChange(fn: (assets: NiceAssets[]) => void): void {\n        this.propagate = fn;\n    }\n\n    public registerOnTouched(fn: (assets: NiceAssets[]) => void): void {}\n\n    public clickLeft(): void {\n        if (this._active) {\n            this.activeAsset = this._active - 1;\n        }\n\n        if (this._activeTranslationPosition < 0) {\n            this.activeTranslationPosition = this._activeTranslationPosition + 102;\n        }\n    }\n\n    public clickRight(): void {\n        if (this._lastAsset) {\n            return;\n        }\n\n        this.activeAsset = this._active + 1;\n        if (this._shouldTransform) {\n            this.activeTranslationPosition = this._activeTranslationPosition - 102;\n        }\n    }\n\n    public clickAsset(index: number): void {\n        let visibleAssets = this.edit ? 2 : 3;\n        if (index < visibleAssets) {\n            visibleAssets = index;\n        }\n\n        if (index >= 0) {\n            this.activeTranslationPosition = (index - visibleAssets) * -102;\n        }\n\n        this.activeAsset = index;\n    }\n\n    public async onFilesChange(event: Event): Promise<void> {\n        const files = (event.target as HTMLInputElement)?.files;\n        await this.onFilesDrop(files);\n\n        this.inputElement.nativeElement.files = null;\n    }\n\n    public async onFilesDrop(files: FileList): Promise<void> {\n        if (!files?.length) {\n            return;\n        }\n\n        let newAssetsAdded = false;\n        for (let i = 0; i < files.length; i++) {\n            const file = files.item(i);\n            if (!this.accept.some((accept) => {\n                if (accept.endsWith(\"*\")) {\n                    return file.type.startsWith(accept.replace(\"*\", \"\"));\n                }\n\n                return accept === file.type;\n            })) {\n                continue;\n            }\n\n            newAssetsAdded = true;\n            this._assets.push({\n                file,\n                type: file.type.split(\"/\").shift() as \"image\" | \"video\",\n                base64: await FileUtils.getDataUrl(file)\n            });\n        }\n\n        if (newAssetsAdded) {\n            this.clickAsset(this._assets.length - 1);\n            this.propagate?.(this._assets);\n        }\n    }\n\n    public clickRemove(): void {\n        this._assets.splice(this._active, 1);\n\n        if (this._lastAsset) {\n            this.clickAsset(this._assets.length - 1);\n        } else {\n            this.clickAsset(this._active);\n        }\n\n        this.propagate?.(this._assets);\n    }\n\n    public clickCustom(action: NiceAssetsCarouselActions): void {\n        action.action(this._active);\n    }\n\n    public async startSyncVideo(): Promise<void> {\n        (this._assetsElement.get(this._active).nativeElement.firstElementChild as HTMLVideoElement).pause();\n        (this._assetsElement.get(this._active).nativeElement.firstElementChild as HTMLVideoElement).currentTime = 0;\n\n        this._activeVideoElement.nativeElement.currentTime = 0;\n        await this._activeVideoElement.nativeElement.play();\n        await (this._assetsElement.get(this._active).nativeElement.firstElementChild as HTMLVideoElement).play();\n    }\n}\n","<div class=\"carousel-container\" niceDropzone (filesDropped)=\"onFilesDrop($event)\">\n    <div class=\"active-image\"\n         matRipple\n         [class.empty-state]=\"!_activeAsset\"\n         (click)=\"edit && fileInput.click(); $event.stopPropagation()\"\n    >\n        <img\n            *ngIf=\"_activeAsset?.type === 'image'\"\n            (mouseover)=\"showOverlay=true\"\n            [src]=\"_activeAsset.url ?? _activeAsset.base64\"\n            draggable=\"false\"\n            class=\"relative\"\n            alt=\"active-image\"\n        >\n        <video #activeVideo *ngIf=\"_activeAsset?.type === 'video'\" draggable=\"false\" loop [src]=\"_activeAsset.url ?? _activeAsset.base64\"></video>\n\n        <div class=\"empty-state-content\" *ngIf=\"!_activeAsset\">\n            <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n            <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n\n            <div class=\"text\">\n                {{ \"nice_ui_kit.assets_carousel.upload_here\" | translate }}\n            </div>\n        </div>\n\n        <div *ngIf=\"_activeAsset && showOverlay && edit\" class=\"active-image-overlay\">\n            <div\n                (mouseout)=\"showOverlay=false\"\n                class=\"flex flex-col justify-center items-center w-full h-full\"\n            >\n                <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n                <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n            </div>\n        </div>\n\n        <div *ngIf=\"edit\" class=\"active-buttons\">\n            <button mat-icon-button (click)=\"fileInput.click()\">\n                <mat-icon *ngIf=\"options.actionButtons.addPhoto.matIcon\">{{ options.actionButtons.addPhoto.matIcon }}</mat-icon>\n                <mat-icon *ngIf=\"options.actionButtons.addPhoto.svgIcon\" [svgIcon]=\"options.actionButtons.addPhoto.svgIcon\"></mat-icon>\n            </button>\n            <button mat-icon-button [matMenuTriggerFor]=\"assetActions\" (click)=\"$event.stopPropagation()\" [disabled]=\"!_activeAsset\">\n                <mat-icon *ngIf=\"options.actionButtons.moreOptions.matIcon\">{{ options.actionButtons.moreOptions.matIcon }}</mat-icon>\n                <mat-icon *ngIf=\"options.actionButtons.moreOptions.svgIcon\" [svgIcon]=\"options.actionButtons.moreOptions.svgIcon\"></mat-icon>\n            </button>\n\n            <mat-menu class=\"nice-asset-options-menu\" [xPosition]=\"'before'\" #assetActions=\"matMenu\">\n                <button\n                    mat-menu-item\n                    *ngFor=\"let action of customActions\"\n                    (click)=\"clickCustom(action); $event.stopPropagation()\"\n                >\n                    <mat-icon *ngIf=\"action.icon.matIcon\">{{ action.icon.matIcon }}</mat-icon>\n                    <mat-icon [svgIcon]=\"action.icon.svgIcon\" *ngIf=\"action.icon.svgIcon\"></mat-icon>\n                    <span>{{ action.name | translate }}</span>\n                </button>\n                <button\n                    mat-menu-item (click)=\"clickRemove(); $event.stopPropagation()\"\n                >\n                    <mat-icon *ngIf=\"options.actionButtons.remove.matIcon\">{{ options.actionButtons.remove.matIcon }}</mat-icon>\n                    <mat-icon *ngIf=\"options.actionButtons.remove.svgIcon\" [svgIcon]=\"options.actionButtons.remove.svgIcon\"></mat-icon>\n                    <span>{{ \"nice_ui_kit.assets_carousel.delete\" | translate }}</span>\n                </button>\n            </mat-menu>\n        </div>\n    </div>\n\n    <div class=\"carousel\">\n        <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button left-arrow\" mat-icon-button [disabled]=\"!_active\" (click)=\"clickLeft()\">\n            <mat-icon *ngIf=\"options.leftArrow.matIcon\">{{ options.leftArrow.matIcon }}</mat-icon>\n            <mat-icon class=\"arrows\" *ngIf=\"options.leftArrow.svgIcon\" [svgIcon]=\"options.leftArrow.svgIcon\"></mat-icon>\n        </button>\n        <div class=\"asset-list-container\">\n            <div *ngIf=\"showAddAssetContainer && edit\" class=\"add-asset-container\">\n                <div class=\"add-asset\" matRipple (click)=\"fileInput.click()\">\n                    <mat-icon *ngIf=\"options.addPhoto.matIcon\">{{ options.addPhoto.matIcon }}</mat-icon>\n                    <mat-icon *ngIf=\"options.addPhoto.svgIcon\" [svgIcon]=\"options.addPhoto.svgIcon\"></mat-icon>\n                </div>\n            </div>\n\n            <div class=\"asset-list\" [ngStyle]=\"listStyle\">\n                <div #assets class=\"asset\" *ngFor=\"let asset of _assets; let i = index\" (click)=\"clickAsset(i)\" [ngClass]=\"color\" [class.active]=\"_active === i\">\n                    <img *ngIf=\"asset.type === 'image'\" draggable=\"false\" [src]=\"asset.url ?? asset.base64\" alt=\"add-image\">\n                    <video *ngIf=\"asset.type === 'video'\" draggable=\"false\" loop [src]=\"asset.url ?? asset.base64\"></video>\n                </div>\n            </div>\n        </div>\n        <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button right-arrow\" mat-icon-button [disabled]=\"_lastAsset\" (click)=\"clickRight()\">\n            <mat-icon *ngIf=\"options.rightArrow.matIcon\">{{ options.rightArrow.matIcon }}</mat-icon>\n            <mat-icon class=\"arrows\" *ngIf=\"options.rightArrow.svgIcon\" [svgIcon]=\"options.rightArrow.svgIcon\"></mat-icon>\n        </button>\n    </div>\n</div>\n\n<input #fileInput type=\"file\" hidden [accept]=\"accept\" (change)=\"onFilesChange($event)\" [multiple]=\"multipleUpload\">\n"]}
|
|
260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets-carousel.component.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/assets-carousel/assets-carousel.component.ts","../../../../../../projects/nice-ui-kit-v2/src/lib/components/assets-carousel/assets-carousel.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    QueryList,\n    TemplateRef,\n    ViewChild,\n    ViewChildren,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CanColor, ThemePalette } from \"@angular/material/core\";\nimport { niceAnimations } from \"../../animations\";\nimport { FileUtils } from \"../../utils\";\nimport { NICE_ASSETS_CAROUSEL_OPTIONS } from \"./assets-carousel.constant\";\nimport { NiceAssetsCarouselActiveContentDirective } from \"./directives/assets-carousel-active-content.directive\";\n\nexport interface NiceAssets {\n    type: \"image\" | \"video\";\n    id?: number | string;\n    url?: string;\n    base64?: string;\n    file?: File;\n}\n\nexport type NiceAssetsCarouselActionIcon = { matIcon: string; svgIcon?: string; } | { matIcon?: string; svgIcon: string; };\n\nexport interface NiceAssetsCarouselActions {\n    icon: NiceAssetsCarouselActionIcon;\n    name: string;\n    action: (active: number) => void;\n}\n\nexport interface NiceAssetsCarouselOptions {\n    actionButtons?: {\n        moreOptions?: NiceAssetsCarouselActionIcon;\n        addPhoto?: NiceAssetsCarouselActionIcon;\n        remove?: NiceAssetsCarouselActionIcon;\n    };\n    addPhoto?: NiceAssetsCarouselActionIcon;\n    leftArrow?: NiceAssetsCarouselActionIcon;\n    rightArrow?: NiceAssetsCarouselActionIcon;\n    upload?: NiceAssetsCarouselActionIcon;\n}\n\n@Component({\n    selector: \"nice-assets-carousel\",\n    templateUrl: \"assets-carousel.template.html\",\n    styleUrls: [\"assets-carousel.theme.scss\"],\n    encapsulation: ViewEncapsulation.None,\n    animations: niceAnimations,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NiceAssetsCarouselComponent),\n            multi: true\n        }\n    ]\n})\nexport class NiceAssetsCarouselComponent implements ControlValueAccessor, CanColor {\n    public _activeTranslationPosition = 0;\n    public _active = 0;\n    public _assets: NiceAssets[] = [];\n    public _activeAsset: NiceAssets;\n    public _lastAsset = true;\n    public _shouldTransform = false;\n    public _activeVideoElement: ElementRef<HTMLVideoElement>;\n    public _assetsElement: QueryList<ElementRef<HTMLDivElement>>;\n    public defaultColor: ThemePalette = \"primary\";\n\n    @ViewChild(\"fileInput\")\n    public inputElement: ElementRef<HTMLInputElement>;\n\n    @Input()\n    public color: ThemePalette = this.defaultColor;\n\n    @Input()\n    public edit = false;\n\n    @Input()\n    public loading = false;\n\n    @Input()\n    public accept: string[] = [\"image/*\"];\n\n    @Input()\n    public customActions: NiceAssetsCarouselActions[] = [];\n\n    @Input()\n    public imagesProcessor: (fileList: FileList) => Promise<FileList>;\n\n    @Input()\n    public multipleUpload = false;\n\n    @Input()\n    public visiblePreviewAsset = 4;\n\n    @Input()\n    public showAddAssetContainer = true;\n\n    @ContentChild(NiceAssetsCarouselActiveContentDirective, { read: TemplateRef })\n    public activeContent: TemplateRef<any>;\n\n    @Output()\n    public activeChange = new EventEmitter<number>();\n\n    @Output()\n    public removedAsset = new EventEmitter<NiceAssets>();\n\n    public listStyle: { transform: string } = { transform: \"translateX(0px)\" };\n\n    public showOverlay: boolean;\n\n    private propagate: (assets: NiceAssets[]) => void;\n\n    @ViewChild(\"activeVideo\")\n    public set activeVideoElement(activeVideoElement: ElementRef<HTMLVideoElement>) {\n        this._activeVideoElement = activeVideoElement;\n\n        if (!this._activeVideoElement || !this._assetsElement) {\n            return;\n        }\n\n        this.startSyncVideo();\n    }\n\n    @ViewChildren(\"assets\")\n    public set assetsElement(assetsElement: QueryList<ElementRef<HTMLDivElement>>) {\n        this._assetsElement = assetsElement;\n\n        if (!this._activeVideoElement || !this._assetsElement) {\n            return;\n        }\n\n        this.startSyncVideo();\n    }\n\n    @Input()\n    public set assets(assets: NiceAssets[]) {\n        this.writeValue(assets ?? []);\n    }\n\n    private set activeTranslationPosition(position: number) {\n        this._activeTranslationPosition = position;\n        this.listStyle.transform = `translateX(calc((var(--nice-assets-carousel-asset-width) + var(--nice-assets-carousel-asset-gap)) * ${position}))`;\n    }\n\n    private set activeAsset(position: number) {\n        if (position < 0) {\n            position = 0;\n        }\n\n        this._active = position;\n        this._activeAsset = this._assets[this._active];\n        this._lastAsset = this._active === this._assets.length - 1 || !this._assets.length;\n        this._shouldTransform\n            = ((this.edit && this.showAddAssetContainer) && this._active >= (this.visiblePreviewAsset - 1))\n            || this._active >= this.visiblePreviewAsset;\n        this.activeChange.emit(this._active);\n    }\n\n    constructor(@Optional() @Inject(NICE_ASSETS_CAROUSEL_OPTIONS) public readonly options: NiceAssetsCarouselOptions) {\n        if (!this.options) {\n            this.options = {\n                actionButtons: {\n                    addPhoto: {\n                        matIcon: \"photo_camera\"\n                    },\n                    moreOptions: {\n                        matIcon: \"more_vert\"\n                    },\n                    remove: {\n                        matIcon: \"delete\"\n                    }\n                },\n                addPhoto: {\n                    matIcon: \"photo_camera\"\n                },\n                leftArrow: {\n                    matIcon: \"chevron_left\"\n                },\n                rightArrow: {\n                    matIcon: \"chevron_right\"\n                },\n                upload: {\n                    matIcon: \"file_upload\"\n                }\n            };\n        }\n    }\n\n    public writeValue(assets: NiceAssets[]): void {\n        this._assets = assets ?? [];\n\n        if (this._assets.length === 0) {\n            this._activeAsset = null;\n            this._lastAsset = true;\n        } else if (this._assets.length > 0) {\n            this._activeAsset = this._assets[this._active];\n        }\n    }\n\n    public registerOnChange(fn: (assets: NiceAssets[]) => void): void {\n        this.propagate = fn;\n    }\n\n    public registerOnTouched(fn: (assets: NiceAssets[]) => void): void {}\n\n    public clickLeft(): void {\n        if (this._active) {\n            this.activeAsset = this._active - 1;\n        }\n\n        if (this._activeTranslationPosition < 0) {\n            this.activeTranslationPosition = this._activeTranslationPosition + 1;\n        }\n    }\n\n    public clickRight(): void {\n        if (this._lastAsset) {\n            return;\n        }\n\n        this.activeAsset = this._active + 1;\n        if (this._shouldTransform) {\n            this.activeTranslationPosition = this._activeTranslationPosition - 1;\n        }\n    }\n\n    public clickAsset(index: number): void {\n        let visibleAssets = (this.edit && this.showAddAssetContainer) ? (this.visiblePreviewAsset - 2) : (this.visiblePreviewAsset - 1);\n        if (index < visibleAssets) {\n            visibleAssets = index;\n        }\n\n        if (index >= 0) {\n            this.activeTranslationPosition = (index - visibleAssets) * -1;\n        }\n\n        this.activeAsset = index;\n    }\n\n    public async onFilesChange(event: Event): Promise<void> {\n        let files = (event.target as HTMLInputElement)?.files;\n\n        if (this.imagesProcessor) {\n            files = await this.getProcessedFiles(files);\n        }\n\n        await this.onFilesDrop(files);\n\n        this.inputElement.nativeElement.value = \"\";\n    }\n\n    public async onFilesDrop(files: FileList): Promise<void> {\n        if (!files?.length) {\n            return;\n        }\n\n        let newAssetsAdded = false;\n\n        for (let i = 0; i < files.length; i++) {\n            const file = files.item(i);\n            if (!this.accept.some((accept) => {\n                if (accept.endsWith(\"*\")) {\n                    return file.type.startsWith(accept.replace(\"*\", \"\"));\n                }\n\n                return accept === file.type;\n            })) {\n                continue;\n            }\n\n            newAssetsAdded = true;\n\n            this._assets.push({\n                file,\n                type: file.type.split(\"/\").shift() as \"image\" | \"video\",\n                base64: await FileUtils.getDataUrl(file)\n            });\n        }\n\n        if (newAssetsAdded) {\n            this.clickAsset(this._assets.length - 1);\n            this.propagate?.(this._assets);\n        }\n    }\n\n    public clickRemove(): void {\n        this.removedAsset.emit(this._assets[this._active]);\n        this._assets.splice(this._active, 1);\n\n        if (this._lastAsset) {\n            this.clickAsset(this._assets.length - 1);\n        } else {\n            this.clickAsset(this._active);\n        }\n\n        this.propagate?.(this._assets);\n    }\n\n    public clickCustom(action: NiceAssetsCarouselActions): void {\n        action.action(this._active);\n    }\n\n    public async startSyncVideo(): Promise<void> {\n        (this._assetsElement.get(this._active).nativeElement.firstElementChild as HTMLVideoElement).pause();\n        (this._assetsElement.get(this._active).nativeElement.firstElementChild as HTMLVideoElement).currentTime = 0;\n\n        this._activeVideoElement.nativeElement.currentTime = 0;\n\n        await this._activeVideoElement.nativeElement.play();\n        await (this._assetsElement.get(this._active).nativeElement.firstElementChild as HTMLVideoElement).play();\n    }\n\n    private async getProcessedFiles(files: FileList): Promise<FileList> {\n        try {\n            return await this.imagesProcessor(files);\n        } catch (e) {}\n    }\n}\n","<div class=\"carousel-container\" niceDropzone (filesDropped)=\"onFilesDrop($event)\">\n    <div\n        class=\"active-image\"\n        matRipple\n        [class.empty-state]=\"!_activeAsset\"\n        (click)=\"edit && fileInput.click();\n        $event.stopPropagation()\"\n    >\n        <div *ngIf=\"loading\" class=\"flex flex-row justify-center items-center h-full\">\n            <mat-spinner [diameter]=\"32\"></mat-spinner>\n        </div>\n        <ng-container *ngIf=\"!loading\">\n            <ng-container\n                *ngIf=\"_activeAsset && activeContent\"\n                [ngTemplateOutlet]=\"activeContent\"\n                [ngTemplateOutletContext]=\"{ $implicit: _activeAsset}\"\n            ></ng-container>\n            <img\n                *ngIf=\"_activeAsset?.type === 'image'\"\n                (mouseover)=\"showOverlay=true\"\n                [src]=\"_activeAsset.url ?? _activeAsset.base64\"\n                draggable=\"false\"\n                class=\"relative\"\n                alt=\"active-image\"\n            >\n            <video #activeVideo *ngIf=\"_activeAsset?.type === 'video'\" draggable=\"false\" loop [src]=\"_activeAsset.url ?? _activeAsset.base64\"></video>\n\n            <div class=\"empty-state-content\" *ngIf=\"!_activeAsset\">\n                <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n                <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n                <div class=\"text\">\n                    {{ \"nice_ui_kit.assets_carousel.upload_here\" | translate }}\n                </div>\n            </div>\n\n            <div *ngIf=\"_activeAsset && showOverlay && edit\" class=\"active-image-overlay\">\n                <div\n                    (mouseout)=\"showOverlay=false\"\n                    class=\"flex flex-col justify-center items-center w-full h-full\"\n                >\n                    <mat-icon *ngIf=\"options.upload.matIcon\">{{ options.upload.matIcon }}</mat-icon>\n                    <mat-icon *ngIf=\"options.upload.svgIcon\" [svgIcon]=\"options.upload.svgIcon\"></mat-icon>\n                </div>\n            </div>\n\n            <div *ngIf=\"edit\" class=\"active-buttons\">\n                <button mat-icon-button (click)=\"fileInput.click(); $event.stopPropagation()\">\n                    <mat-icon *ngIf=\"options.actionButtons.addPhoto.matIcon\">{{ options.actionButtons.addPhoto.matIcon }}</mat-icon>\n                    <mat-icon *ngIf=\"options.actionButtons.addPhoto.svgIcon\" [svgIcon]=\"options.actionButtons.addPhoto.svgIcon\"></mat-icon>\n                </button>\n                <button mat-icon-button [matMenuTriggerFor]=\"assetActions\" (click)=\"$event.stopPropagation()\" [disabled]=\"!_activeAsset\">\n                    <mat-icon *ngIf=\"options.actionButtons.moreOptions.matIcon\">{{ options.actionButtons.moreOptions.matIcon }}</mat-icon>\n                    <mat-icon *ngIf=\"options.actionButtons.moreOptions.svgIcon\" [svgIcon]=\"options.actionButtons.moreOptions.svgIcon\"></mat-icon>\n                </button>\n                <mat-menu class=\"nice-asset-options-menu\" [xPosition]=\"'before'\" #assetActions=\"matMenu\">\n                    <button\n                        mat-menu-item\n                        *ngFor=\"let action of customActions\"\n                        (click)=\"clickCustom(action)\"\n                    >\n                        <mat-icon *ngIf=\"action.icon.matIcon\">{{ action.icon.matIcon }}</mat-icon>\n                        <mat-icon [svgIcon]=\"action.icon.svgIcon\" *ngIf=\"action.icon.svgIcon\"></mat-icon>\n                        <span>{{ action.name | translate }}</span>\n                    </button>\n                    <button mat-menu-item (click)=\"clickRemove()\">\n                        <mat-icon *ngIf=\"options.actionButtons.remove.matIcon\">{{ options.actionButtons.remove.matIcon }}</mat-icon>\n                        <mat-icon *ngIf=\"options.actionButtons.remove.svgIcon\" [svgIcon]=\"options.actionButtons.remove.svgIcon\"></mat-icon>\n                        <span>{{ \"nice_ui_kit.assets_carousel.delete\" | translate }}</span>\n                    </button>\n                </mat-menu>\n            </div>\n        </ng-container>\n    </div>\n\n    <div class=\"carousel\">\n        <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button left-arrow\" mat-icon-button [disabled]=\"!_active\" (click)=\"clickLeft()\">\n            <mat-icon *ngIf=\"options.leftArrow.matIcon\">{{ options.leftArrow.matIcon }}</mat-icon>\n            <mat-icon class=\"arrows\" *ngIf=\"options.leftArrow.svgIcon\" [svgIcon]=\"options.leftArrow.svgIcon\"></mat-icon>\n        </button>\n        <div class=\"asset-list-container\">\n            <div *ngIf=\"showAddAssetContainer && edit\" class=\"add-asset-container\">\n                <div class=\"add-asset\" matRipple (click)=\"fileInput.click()\">\n                    <mat-icon *ngIf=\"options.addPhoto.matIcon\">{{ options.addPhoto.matIcon }}</mat-icon>\n                    <mat-icon *ngIf=\"options.addPhoto.svgIcon\" [svgIcon]=\"options.addPhoto.svgIcon\"></mat-icon>\n                </div>\n            </div>\n            <div class=\"asset-list\" [ngStyle]=\"listStyle\">\n                <div\n                    #assets\n                    class=\"asset\"\n                    *ngFor=\"let asset of _assets; let i = index\"\n                    (click)=\"clickAsset(i)\"\n                    [ngClass]=\"color\"\n                    [class.active]=\"_active === i\"\n                >\n                    <ng-container>\n                        <img\n                            *ngIf=\"asset.type === 'image'\"\n                            draggable=\"false\"\n                            [src]=\"asset.url ?? asset.base64\"\n                            alt=\"add-image\"\n                        />\n                        <video\n                            *ngIf=\"asset.type === 'video'\"\n                            draggable=\"false\"\n                            loop\n                            [src]=\"asset.url ?? asset.base64\"\n                        ></video>\n                    </ng-container>\n                </div>\n            </div>\n        </div>\n        <button *ngIf=\"showAddAssetContainer || _activeAsset\" class=\"action-button right-arrow\" mat-icon-button [disabled]=\"_lastAsset\" (click)=\"clickRight()\">\n            <mat-icon *ngIf=\"options.rightArrow.matIcon\">{{ options.rightArrow.matIcon }}</mat-icon>\n            <mat-icon class=\"arrows\" *ngIf=\"options.rightArrow.svgIcon\" [svgIcon]=\"options.rightArrow.svgIcon\"></mat-icon>\n        </button>\n    </div>\n</div>\n\n<input #fileInput type=\"file\" hidden [accept]=\"accept\" (change)=\"onFilesChange($event)\" [multiple]=\"multipleUpload\">\n"]}
|
|
@@ -4,10 +4,12 @@ import { MatButtonModule } from "@angular/material/button";
|
|
|
4
4
|
import { MatRippleModule } from "@angular/material/core";
|
|
5
5
|
import { MatIconModule } from "@angular/material/icon";
|
|
6
6
|
import { MatMenuModule } from "@angular/material/menu";
|
|
7
|
+
import { MatProgressSpinnerModule } from "@angular/material/progress-spinner";
|
|
7
8
|
import { TranslateModule } from "@ngx-translate/core";
|
|
8
9
|
import { NiceDropzoneModule } from "../../directives/dropzone";
|
|
9
10
|
import { NiceAssetsCarouselComponent } from "./assets-carousel.component";
|
|
10
11
|
import { NICE_ASSETS_CAROUSEL_OPTIONS } from "./assets-carousel.constant";
|
|
12
|
+
import { NiceAssetsCarouselActiveContentDirective } from "./directives/assets-carousel-active-content.directive";
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
export class NiceAssetsCarouselModule {
|
|
13
15
|
static forRoot(options) {
|
|
@@ -48,22 +50,24 @@ export class NiceAssetsCarouselModule {
|
|
|
48
50
|
};
|
|
49
51
|
}
|
|
50
52
|
}
|
|
51
|
-
NiceAssetsCarouselModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
52
|
-
NiceAssetsCarouselModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
53
|
+
NiceAssetsCarouselModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
54
|
+
NiceAssetsCarouselModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselModule, declarations: [NiceAssetsCarouselComponent, NiceAssetsCarouselActiveContentDirective], imports: [CommonModule,
|
|
53
55
|
MatIconModule,
|
|
54
56
|
MatButtonModule,
|
|
55
57
|
MatMenuModule,
|
|
56
58
|
MatRippleModule,
|
|
57
59
|
NiceDropzoneModule,
|
|
58
|
-
TranslateModule
|
|
59
|
-
|
|
60
|
+
TranslateModule,
|
|
61
|
+
MatProgressSpinnerModule], exports: [NiceAssetsCarouselComponent, NiceAssetsCarouselActiveContentDirective] });
|
|
62
|
+
NiceAssetsCarouselModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselModule, imports: [CommonModule,
|
|
60
63
|
MatIconModule,
|
|
61
64
|
MatButtonModule,
|
|
62
65
|
MatMenuModule,
|
|
63
66
|
MatRippleModule,
|
|
64
67
|
NiceDropzoneModule,
|
|
65
|
-
TranslateModule
|
|
66
|
-
|
|
68
|
+
TranslateModule,
|
|
69
|
+
MatProgressSpinnerModule] });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselModule, decorators: [{
|
|
67
71
|
type: NgModule,
|
|
68
72
|
args: [{
|
|
69
73
|
imports: [
|
|
@@ -73,11 +77,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
|
|
|
73
77
|
MatMenuModule,
|
|
74
78
|
MatRippleModule,
|
|
75
79
|
NiceDropzoneModule,
|
|
76
|
-
TranslateModule
|
|
80
|
+
TranslateModule,
|
|
81
|
+
MatProgressSpinnerModule
|
|
77
82
|
],
|
|
78
|
-
declarations: [NiceAssetsCarouselComponent],
|
|
83
|
+
declarations: [NiceAssetsCarouselComponent, NiceAssetsCarouselActiveContentDirective],
|
|
79
84
|
providers: [],
|
|
80
|
-
exports: [NiceAssetsCarouselComponent]
|
|
85
|
+
exports: [NiceAssetsCarouselComponent, NiceAssetsCarouselActiveContentDirective]
|
|
81
86
|
}]
|
|
82
87
|
}] });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLWNhcm91c2VsLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9hc3NldHMtY2Fyb3VzZWwvYXNzZXRzLWNhcm91c2VsLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUF1QixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUUvRCxPQUFPLEVBQUUsMkJBQTJCLEVBQTZCLE1BQU0sNkJBQTZCLENBQUM7QUFDckcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDMUUsT0FBTyxFQUFFLHdDQUF3QyxFQUFFLE1BQU0sdURBQXVELENBQUM7O0FBaUJqSCxNQUFNLE9BQU8sd0JBQXdCO0lBQzFCLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBbUM7UUFDckQsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNWLE9BQU8sR0FBRztnQkFDTixhQUFhLEVBQUUsRUFBRTthQUNwQixDQUFDO1NBQ0w7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxXQUFXLEVBQUU7WUFDcEMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxXQUFXLEdBQUcsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLENBQUM7U0FDaEU7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUU7WUFDakMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxRQUFRLEdBQUcsRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFLENBQUM7U0FDaEU7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUU7WUFDL0IsT0FBTyxDQUFDLGFBQWEsQ0FBQyxNQUFNLEdBQUcsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLENBQUM7U0FDeEQ7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRTtZQUNuQixPQUFPLENBQUMsUUFBUSxHQUFHLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxDQUFDO1NBQ2xEO1FBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUU7WUFDcEIsT0FBTyxDQUFDLFNBQVMsR0FBRyxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsQ0FBQztTQUNuRDtRQUNELElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFO1lBQ3JCLE9BQU8sQ0FBQyxVQUFVLEdBQUcsRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLENBQUM7U0FDckQ7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtZQUNqQixPQUFPLENBQUMsTUFBTSxHQUFHLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDO1NBQy9DO1FBRUQsT0FBTztZQUNILFFBQVEsRUFBRSx3QkFBd0I7WUFDbEMsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSw0QkFBNEI7b0JBQ3JDLFFBQVEsRUFBRSxPQUFPO2lCQUNwQjthQUNKO1NBQ0osQ0FBQztJQUNOLENBQUM7O3FIQXRDUSx3QkFBd0I7c0hBQXhCLHdCQUF3QixpQkFKbEIsMkJBQTJCLEVBQUUsd0NBQXdDLGFBVGhGLFlBQVk7UUFDWixhQUFhO1FBQ2IsZUFBZTtRQUNmLGFBQWE7UUFDYixlQUFlO1FBQ2Ysa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZix3QkFBd0IsYUFJbEIsMkJBQTJCLEVBQUUsd0NBQXdDO3NIQUV0RSx3QkFBd0IsWUFiN0IsWUFBWTtRQUNaLGFBQWE7UUFDYixlQUFlO1FBQ2YsYUFBYTtRQUNiLGVBQWU7UUFDZixrQkFBa0I7UUFDbEIsZUFBZTtRQUNmLHdCQUF3QjsyRkFNbkIsd0JBQXdCO2tCQWZwQyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLHdCQUF3QjtxQkFDM0I7b0JBQ0QsWUFBWSxFQUFFLENBQUMsMkJBQTJCLEVBQUUsd0NBQXdDLENBQUM7b0JBQ3JGLFNBQVMsRUFBRSxFQUFFO29CQUNiLE9BQU8sRUFBRSxDQUFDLDJCQUEyQixFQUFFLHdDQUF3QyxDQUFDO2lCQUNuRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9idXR0b25cIjtcbmltcG9ydCB7IE1hdFJpcHBsZU1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9jb3JlXCI7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2ljb25cIjtcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudVwiO1xuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXJcIjtcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gXCJAbmd4LXRyYW5zbGF0ZS9jb3JlXCI7XG5pbXBvcnQgeyBOaWNlRHJvcHpvbmVNb2R1bGUgfSBmcm9tIFwiLi4vLi4vZGlyZWN0aXZlcy9kcm9wem9uZVwiO1xuXG5pbXBvcnQgeyBOaWNlQXNzZXRzQ2Fyb3VzZWxDb21wb25lbnQsIE5pY2VBc3NldHNDYXJvdXNlbE9wdGlvbnMgfSBmcm9tIFwiLi9hc3NldHMtY2Fyb3VzZWwuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBOSUNFX0FTU0VUU19DQVJPVVNFTF9PUFRJT05TIH0gZnJvbSBcIi4vYXNzZXRzLWNhcm91c2VsLmNvbnN0YW50XCI7XG5pbXBvcnQgeyBOaWNlQXNzZXRzQ2Fyb3VzZWxBY3RpdmVDb250ZW50RGlyZWN0aXZlIH0gZnJvbSBcIi4vZGlyZWN0aXZlcy9hc3NldHMtY2Fyb3VzZWwtYWN0aXZlLWNvbnRlbnQuZGlyZWN0aXZlXCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIE1hdEljb25Nb2R1bGUsXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICAgICAgTWF0TWVudU1vZHVsZSxcbiAgICAgICAgTWF0UmlwcGxlTW9kdWxlLFxuICAgICAgICBOaWNlRHJvcHpvbmVNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtOaWNlQXNzZXRzQ2Fyb3VzZWxDb21wb25lbnQsIE5pY2VBc3NldHNDYXJvdXNlbEFjdGl2ZUNvbnRlbnREaXJlY3RpdmVdLFxuICAgIHByb3ZpZGVyczogW10sXG4gICAgZXhwb3J0czogW05pY2VBc3NldHNDYXJvdXNlbENvbXBvbmVudCwgTmljZUFzc2V0c0Nhcm91c2VsQWN0aXZlQ29udGVudERpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgTmljZUFzc2V0c0Nhcm91c2VsTW9kdWxlIHtcbiAgICBwdWJsaWMgc3RhdGljIGZvclJvb3Qob3B0aW9ucz86IE5pY2VBc3NldHNDYXJvdXNlbE9wdGlvbnMpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPE5pY2VBc3NldHNDYXJvdXNlbE1vZHVsZT4ge1xuICAgICAgICBpZiAoIW9wdGlvbnMpIHtcbiAgICAgICAgICAgIG9wdGlvbnMgPSB7XG4gICAgICAgICAgICAgICAgYWN0aW9uQnV0dG9uczoge31cbiAgICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFvcHRpb25zLmFjdGlvbkJ1dHRvbnMubW9yZU9wdGlvbnMpIHtcbiAgICAgICAgICAgIG9wdGlvbnMuYWN0aW9uQnV0dG9ucy5tb3JlT3B0aW9ucyA9IHsgbWF0SWNvbjogXCJtb3JlX3ZlcnRcIiB9O1xuICAgICAgICB9XG4gICAgICAgIGlmICghb3B0aW9ucy5hY3Rpb25CdXR0b25zLmFkZFBob3RvKSB7XG4gICAgICAgICAgICBvcHRpb25zLmFjdGlvbkJ1dHRvbnMuYWRkUGhvdG8gPSB7IG1hdEljb246IFwicGhvdG9fY2FtZXJhXCIgfTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIW9wdGlvbnMuYWN0aW9uQnV0dG9ucy5yZW1vdmUpIHtcbiAgICAgICAgICAgIG9wdGlvbnMuYWN0aW9uQnV0dG9ucy5yZW1vdmUgPSB7IG1hdEljb246IFwiZGVsZXRlXCIgfTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIW9wdGlvbnMuYWRkUGhvdG8pIHtcbiAgICAgICAgICAgIG9wdGlvbnMuYWRkUGhvdG8gPSB7IG1hdEljb246IFwicGhvdG9fY2FtZXJhXCIgfTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIW9wdGlvbnMubGVmdEFycm93KSB7XG4gICAgICAgICAgICBvcHRpb25zLmxlZnRBcnJvdyA9IHsgbWF0SWNvbjogXCJjaGV2cm9uX2xlZnRcIiB9O1xuICAgICAgICB9XG4gICAgICAgIGlmICghb3B0aW9ucy5yaWdodEFycm93KSB7XG4gICAgICAgICAgICBvcHRpb25zLnJpZ2h0QXJyb3cgPSB7IG1hdEljb246IFwiY2hldnJvbl9yaWdodFwiIH07XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFvcHRpb25zLnVwbG9hZCkge1xuICAgICAgICAgICAgb3B0aW9ucy51cGxvYWQgPSB7IG1hdEljb246IFwiZmlsZV91cGxvYWRcIiB9O1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5nTW9kdWxlOiBOaWNlQXNzZXRzQ2Fyb3VzZWxNb2R1bGUsXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIHByb3ZpZGU6IE5JQ0VfQVNTRVRTX0NBUk9VU0VMX09QVElPTlMsXG4gICAgICAgICAgICAgICAgICAgIHVzZVZhbHVlOiBvcHRpb25zXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgXVxuICAgICAgICB9O1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Directive, TemplateRef } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NiceAssetsCarouselActiveContentDirective {
|
|
4
|
+
constructor(template) {
|
|
5
|
+
this.template = template;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
NiceAssetsCarouselActiveContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselActiveContentDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
+
NiceAssetsCarouselActiveContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: NiceAssetsCarouselActiveContentDirective, selector: "[niceAssetsCarouselActiveContent]", ngImport: i0 });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NiceAssetsCarouselActiveContentDirective, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{ selector: "[niceAssetsCarouselActiveContent]" }]
|
|
13
|
+
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLWNhcm91c2VsLWFjdGl2ZS1jb250ZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9hc3NldHMtY2Fyb3VzZWwvZGlyZWN0aXZlcy9hc3NldHMtY2Fyb3VzZWwtYWN0aXZlLWNvbnRlbnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUd2RCxNQUFNLE9BQU8sd0NBQXdDO0lBQ2pELFlBQW1CLFFBQTBCO1FBQTFCLGFBQVEsR0FBUixRQUFRLENBQWtCO0lBQzdDLENBQUM7O3FJQUZRLHdDQUF3Qzt5SEFBeEMsd0NBQXdDOzJGQUF4Qyx3Q0FBd0M7a0JBRHBELFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsbUNBQW1DLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiBcIltuaWNlQXNzZXRzQ2Fyb3VzZWxBY3RpdmVDb250ZW50XVwiIH0pXG5leHBvcnQgY2xhc3MgTmljZUFzc2V0c0Nhcm91c2VsQWN0aXZlQ29udGVudERpcmVjdGl2ZSB7XG4gICAgY29uc3RydWN0b3IocHVibGljIHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgfVxufVxuIl19
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from "./assets-carousel.component";
|
|
2
2
|
export * from "./assets-carousel.module";
|
|
3
|
-
|
|
3
|
+
export * from "./directives/assets-carousel-active-content.directive";
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9hc3NldHMtY2Fyb3VzZWwvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx1REFBdUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2Fzc2V0cy1jYXJvdXNlbC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2Fzc2V0cy1jYXJvdXNlbC5tb2R1bGVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RpcmVjdGl2ZXMvYXNzZXRzLWNhcm91c2VsLWFjdGl2ZS1jb250ZW50LmRpcmVjdGl2ZVwiO1xuIl19
|