slick-components 4.4.13 → 4.4.16
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/css/slick-components.css +598 -365
- package/css/slick-components.min.css +1 -1
- package/esm2020/public-api.mjs +43 -0
- package/esm2020/slick-accordion/slick-accordion-item-header.component.mjs +14 -0
- package/esm2020/slick-accordion/slick-accordion-item.component.mjs +86 -0
- package/esm2020/slick-accordion/slick-accordion.component.mjs +75 -0
- package/esm2020/slick-accordion/slick-accordion.module.mjs +23 -0
- package/esm2020/slick-auto-complete/slick-auto-complete-list-item-template.directive.mjs +22 -0
- package/esm2020/slick-auto-complete/slick-auto-complete.component.mjs +375 -0
- package/esm2020/slick-auto-complete/slick-auto-complete.module.mjs +24 -0
- package/esm2020/slick-button-spinner/slick-button-spinner.component.mjs +175 -0
- package/esm2020/slick-button-spinner/slick-button-spinner.module.mjs +19 -0
- package/esm2020/slick-calendar/slick-calendar.component.mjs +246 -0
- package/esm2020/slick-calendar/slick-calendar.module.mjs +19 -0
- package/esm2020/slick-card/slick-card-header.component.mjs +14 -0
- package/esm2020/slick-card/slick-card.component.mjs +42 -0
- package/esm2020/slick-card/slick-card.module.mjs +20 -0
- package/esm2020/slick-components.mjs +5 -0
- package/esm2020/slick-confirm-dialog/slick-confirm-dialog.component.mjs +65 -0
- package/esm2020/slick-confirm-dialog/slick-confirm-dialog.module.mjs +20 -0
- package/esm2020/slick-container/slick-container-body.component.mjs +24 -0
- package/esm2020/slick-container/slick-container-footer.component.mjs +20 -0
- package/esm2020/slick-container/slick-container-header.component.mjs +20 -0
- package/esm2020/slick-container/slick-container.component.mjs +21 -0
- package/esm2020/slick-container/slick-container.module.mjs +25 -0
- package/esm2020/slick-context-menu/slick-context-menu-item.component.mjs +14 -0
- package/esm2020/slick-context-menu/slick-context-menu.component.mjs +48 -0
- package/esm2020/slick-context-menu/slick-context-menu.module.mjs +20 -0
- package/{esm2015/slick-currency-mask/slick-currency-mask-options.model.js → esm2020/slick-currency-mask/slick-currency-mask-options.model.mjs} +0 -0
- package/esm2020/slick-currency-mask/slick-currency-mask.directive.mjs +233 -0
- package/esm2020/slick-currency-mask/slick-currency-mask.module.mjs +19 -0
- package/esm2020/slick-date-picker/slick-date-picker.component.mjs +278 -0
- package/esm2020/slick-date-picker/slick-date-picker.module.mjs +21 -0
- package/esm2020/slick-dialog/slick-dialog-footer.component.mjs +24 -0
- package/esm2020/slick-dialog/slick-dialog.component.mjs +294 -0
- package/esm2020/slick-dialog/slick-dialog.module.mjs +23 -0
- package/esm2020/slick-dialog/slick-dialog.service.mjs +68 -0
- package/esm2020/slick-drag-drop/slick-drag-drop.directive.mjs +13 -0
- package/esm2020/slick-drag-drop/slick-drag-drop.module.mjs +21 -0
- package/esm2020/slick-drag-drop/slick-draggable.directive.mjs +13 -0
- package/{esm2015/slick-drop-down/slick-drop-down-button.model.js → esm2020/slick-drop-down/slick-drop-down-button.model.mjs} +0 -0
- package/esm2020/slick-drop-down/slick-drop-down.component.mjs +479 -0
- package/esm2020/slick-drop-down/slick-drop-down.module.mjs +24 -0
- package/esm2020/slick-drop-down/slick-drop-down.service.mjs +55 -0
- package/esm2020/slick-drop-list/slick-drop-list-grab.directive.mjs +18 -0
- package/esm2020/slick-drop-list/slick-drop-list-item.directive.mjs +18 -0
- package/esm2020/slick-drop-list/slick-drop-list.directive.mjs +215 -0
- package/esm2020/slick-drop-list/slick-drop-list.module.mjs +23 -0
- package/esm2020/slick-email-viewer/slick-email-viewer-dialog.component.mjs +81 -0
- package/esm2020/slick-email-viewer/slick-email-viewer.component.mjs +42 -0
- package/esm2020/slick-email-viewer/slick-email-viewer.module.mjs +26 -0
- package/{esm2015/slick-emailer/slick-emailer-address.model.js → esm2020/slick-emailer/slick-emailer-address.model.mjs} +0 -0
- package/esm2020/slick-emailer/slick-emailer-dialog.component.mjs +153 -0
- package/esm2020/slick-emailer/slick-emailer.component.mjs +235 -0
- package/{esm2015/slick-emailer/slick-emailer.model.js → esm2020/slick-emailer/slick-emailer.model.mjs} +0 -0
- package/esm2020/slick-emailer/slick-emailer.module.mjs +29 -0
- package/esm2020/slick-file-drop/slick-file-drop.component.mjs +156 -0
- package/esm2020/slick-file-drop/slick-file-drop.module.mjs +20 -0
- package/esm2020/slick-file-list/slick-file-list-item.component.mjs +173 -0
- package/esm2020/slick-file-list/slick-file-list.component.mjs +130 -0
- package/esm2020/slick-file-list/slick-file-list.module.mjs +23 -0
- package/{esm2015/slick-file-model/slick-file.model.js → esm2020/slick-file-model/slick-file.model.mjs} +0 -0
- package/esm2020/slick-google-address-search/slick-google-address-search.directive.mjs +75 -0
- package/esm2020/slick-google-address-search/slick-google-address-search.module.mjs +19 -0
- package/esm2020/slick-google-map/slick-google-map-dialog.component.mjs +50 -0
- package/esm2020/slick-google-map/slick-google-map.component.mjs +48 -0
- package/esm2020/slick-google-map/slick-google-map.module.mjs +22 -0
- package/esm2020/slick-grid/slick-grid-column-template.directive.mjs +19 -0
- package/{esm2015/slick-grid/slick-grid-column.model.js → esm2020/slick-grid/slick-grid-column.model.mjs} +0 -0
- package/{esm2015/slick-grid/slick-grid-favorite.model.js → esm2020/slick-grid/slick-grid-favorite.model.mjs} +0 -0
- package/{esm2015/slick-grid/slick-grid-request.model.js → esm2020/slick-grid/slick-grid-request.model.mjs} +0 -0
- package/{esm2015/slick-grid/slick-grid-response.model.js → esm2020/slick-grid/slick-grid-response.model.mjs} +0 -0
- package/esm2020/slick-grid/slick-grid-sanitize.pipe.mjs +20 -0
- package/esm2020/slick-grid/slick-grid.component.mjs +793 -0
- package/esm2020/slick-grid/slick-grid.module.mjs +43 -0
- package/{esm2015/slick-grid/slick-grid.options.js → esm2020/slick-grid/slick-grid.options.mjs} +0 -0
- package/esm2020/slick-grid/slick-grid.service.mjs +66 -0
- package/esm2020/slick-multi-select/slick-multi-select.component.mjs +362 -0
- package/esm2020/slick-multi-select/slick-multi-select.module.mjs +20 -0
- package/esm2020/slick-multi-select/slick-multi-select.service.mjs +77 -0
- package/esm2020/slick-ordered-list/slick-ordered-list.component.mjs +200 -0
- package/esm2020/slick-ordered-list/slick-ordered-list.module.mjs +20 -0
- package/esm2020/slick-paging/slick-paging.component.mjs +185 -0
- package/esm2020/slick-paging/slick-paging.module.mjs +19 -0
- package/esm2020/slick-photo-gallery/slick-photo-gallery.component.mjs +98 -0
- package/{esm2015/slick-photo-gallery/slick-photo-gallery.model.js → esm2020/slick-photo-gallery/slick-photo-gallery.model.mjs} +0 -0
- package/esm2020/slick-photo-gallery/slick-photo-gallery.module.mjs +21 -0
- package/esm2020/slick-pick-list/slick-pick-list.component.mjs +84 -0
- package/esm2020/slick-pick-list/slick-pick-list.module.mjs +20 -0
- package/esm2020/slick-popover/slick-popover.component.mjs +204 -0
- package/esm2020/slick-popover/slick-popover.module.mjs +19 -0
- package/esm2020/slick-profile-picture/slick-profile-picture.component.mjs +267 -0
- package/esm2020/slick-profile-picture/slick-profile-picture.module.mjs +20 -0
- package/esm2020/slick-progress-bar/slick-progress-bar.module.mjs +18 -0
- package/esm2020/slick-progress-bar/slick-progress-bar.service.mjs +53 -0
- package/esm2020/slick-screen-blocker/slick-screen-blocker.module.mjs +18 -0
- package/esm2020/slick-screen-blocker/slick-screen-blocker.service.mjs +83 -0
- package/{esm2015/slick-slider/slick-slider-tick.model.js → esm2020/slick-slider/slick-slider-tick.model.mjs} +0 -0
- package/esm2020/slick-slider/slick-slider.component.mjs +90 -0
- package/esm2020/slick-slider/slick-slider.module.mjs +20 -0
- package/esm2020/slick-split-screen/slick-screen-split-left-content.component.mjs +15 -0
- package/esm2020/slick-split-screen/slick-screen-split-right-content.component.mjs +15 -0
- package/esm2020/slick-split-screen/slick-split-screen.component.mjs +159 -0
- package/esm2020/slick-split-screen/slick-split-screen.module.mjs +21 -0
- package/esm2020/slick-tabs/slick-tab-header.component.mjs +28 -0
- package/esm2020/slick-tabs/slick-tab.component.mjs +63 -0
- package/{esm2015/slick-tabs/slick-tab.model.js → esm2020/slick-tabs/slick-tab.model.mjs} +0 -0
- package/esm2020/slick-tabs/slick-tabs.component.mjs +107 -0
- package/esm2020/slick-tabs/slick-tabs.module.mjs +23 -0
- package/esm2020/slick-toast/slick-toast.module.mjs +18 -0
- package/esm2020/slick-toast/slick-toast.service.mjs +88 -0
- package/{esm2015/slick-tree-view/slick-tree-node.model.js → esm2020/slick-tree-view/slick-tree-node.model.mjs} +0 -0
- package/esm2020/slick-tree-view/slick-tree-view.component.mjs +293 -0
- package/esm2020/slick-tree-view/slick-tree-view.module.mjs +22 -0
- package/esm2020/slick-type-ahead/slick-type-ahead.directive.mjs +164 -0
- package/esm2020/slick-type-ahead/slick-type-ahead.module.mjs +18 -0
- package/esm2020/slick-validation-indicator/slick-validation-indicator.directive.mjs +63 -0
- package/esm2020/slick-validation-indicator/slick-validation-indicator.module.mjs +19 -0
- package/esm2020/utils/slick-function-lock.service.mjs +55 -0
- package/esm2020/utils/slick-init.service.mjs +49 -0
- package/esm2020/utils/slick-log.service.mjs +23 -0
- package/esm2020/utils/slick-sleep.service.mjs +14 -0
- package/esm2020/utils/slick-utils.service.mjs +247 -0
- package/fesm2015/{slick-components.js → slick-components.mjs} +2779 -2070
- package/fesm2015/slick-components.mjs.map +1 -0
- package/fesm2020/slick-components.mjs +8467 -0
- package/fesm2020/slick-components.mjs.map +1 -0
- package/package.json +20 -8
- package/public-api.d.ts +8 -8
- package/slick-accordion/slick-accordion-item-header.component.d.ts +3 -0
- package/slick-accordion/slick-accordion-item.component.d.ts +3 -0
- package/slick-accordion/slick-accordion.component.d.ts +3 -0
- package/slick-accordion/slick-accordion.module.d.ts +8 -0
- package/slick-auto-complete/slick-auto-complete-list-item-template.directive.d.ts +3 -0
- package/slick-auto-complete/slick-auto-complete.component.d.ts +3 -0
- package/slick-auto-complete/slick-auto-complete.module.d.ts +8 -0
- package/slick-button-spinner/slick-button-spinner.component.d.ts +3 -0
- package/slick-button-spinner/slick-button-spinner.module.d.ts +6 -0
- package/slick-calendar/slick-calendar.component.d.ts +3 -0
- package/slick-calendar/slick-calendar.module.d.ts +6 -0
- package/slick-card/slick-card-header.component.d.ts +3 -0
- package/slick-card/slick-card.component.d.ts +3 -0
- package/slick-card/slick-card.module.d.ts +10 -0
- package/slick-components.d.ts +1 -22
- package/slick-confirm-dialog/slick-confirm-dialog.component.d.ts +3 -0
- package/slick-confirm-dialog/slick-confirm-dialog.module.d.ts +7 -0
- package/slick-container/slick-container-body.component.d.ts +3 -0
- package/slick-container/slick-container-footer.component.d.ts +3 -0
- package/slick-container/slick-container-header.component.d.ts +3 -0
- package/slick-container/slick-container.component.d.ts +3 -0
- package/slick-container/slick-container.module.d.ts +9 -0
- package/slick-context-menu/slick-context-menu-item.component.d.ts +3 -0
- package/slick-context-menu/slick-context-menu.component.d.ts +3 -0
- package/slick-context-menu/slick-context-menu.module.d.ts +7 -0
- package/slick-currency-mask/slick-currency-mask.directive.d.ts +3 -0
- package/slick-currency-mask/slick-currency-mask.module.d.ts +5 -0
- package/slick-date-picker/slick-date-picker.component.d.ts +3 -0
- package/slick-date-picker/slick-date-picker.module.d.ts +8 -0
- package/slick-dialog/slick-dialog-footer.component.d.ts +3 -0
- package/slick-dialog/slick-dialog.component.d.ts +3 -0
- package/slick-dialog/slick-dialog.module.d.ts +10 -1
- package/slick-dialog/slick-dialog.service.d.ts +3 -0
- package/slick-drag-drop/slick-drag-drop.directive.d.ts +3 -0
- package/slick-drag-drop/slick-drag-drop.module.d.ts +11 -0
- package/slick-drag-drop/slick-draggable.directive.d.ts +3 -0
- package/slick-drop-down/slick-drop-down.component.d.ts +3 -0
- package/slick-drop-down/slick-drop-down.module.d.ts +9 -0
- package/slick-drop-down/slick-drop-down.service.d.ts +3 -0
- package/slick-drop-list/slick-drop-list-grab.directive.d.ts +3 -0
- package/slick-drop-list/slick-drop-list-item.directive.d.ts +3 -0
- package/slick-drop-list/slick-drop-list.directive.d.ts +13 -7
- package/slick-drop-list/slick-drop-list.module.d.ts +14 -0
- package/slick-email-viewer/slick-email-viewer-dialog.component.d.ts +3 -0
- package/slick-email-viewer/slick-email-viewer.component.d.ts +3 -0
- package/slick-email-viewer/slick-email-viewer.module.d.ts +10 -0
- package/slick-emailer/slick-emailer-dialog.component.d.ts +3 -0
- package/slick-emailer/slick-emailer.component.d.ts +3 -0
- package/slick-emailer/slick-emailer.module.d.ts +13 -0
- package/slick-file-drop/slick-file-drop.component.d.ts +3 -0
- package/slick-file-drop/slick-file-drop.module.d.ts +7 -0
- package/slick-file-list/slick-file-list-item.component.d.ts +3 -0
- package/slick-file-list/slick-file-list.component.d.ts +3 -0
- package/slick-file-list/slick-file-list.module.d.ts +10 -0
- package/slick-google-address-search/slick-google-address-search.directive.d.ts +3 -0
- package/slick-google-address-search/slick-google-address-search.module.d.ts +6 -0
- package/slick-google-map/slick-google-map-dialog.component.d.ts +3 -0
- package/slick-google-map/slick-google-map.component.d.ts +3 -0
- package/slick-google-map/slick-google-map.module.d.ts +8 -0
- package/slick-grid/slick-grid-column-template.directive.d.ts +3 -0
- package/slick-grid/slick-grid-sanitize.pipe.d.ts +3 -0
- package/slick-grid/slick-grid.component.d.ts +3 -0
- package/slick-grid/slick-grid.module.d.ts +16 -0
- package/slick-grid/slick-grid.service.d.ts +3 -0
- package/slick-multi-select/slick-multi-select.component.d.ts +3 -0
- package/slick-multi-select/slick-multi-select.module.d.ts +7 -0
- package/slick-multi-select/slick-multi-select.service.d.ts +3 -0
- package/slick-ordered-list/slick-ordered-list.component.d.ts +3 -0
- package/slick-ordered-list/slick-ordered-list.module.d.ts +7 -0
- package/slick-paging/slick-paging.component.d.ts +3 -0
- package/slick-paging/slick-paging.module.d.ts +6 -0
- package/slick-photo-gallery/slick-photo-gallery.component.d.ts +3 -0
- package/slick-photo-gallery/slick-photo-gallery.module.d.ts +6 -0
- package/slick-pick-list/slick-pick-list.component.d.ts +3 -0
- package/slick-pick-list/slick-pick-list.module.d.ts +7 -0
- package/slick-popover/slick-popover.component.d.ts +3 -0
- package/slick-popover/slick-popover.module.d.ts +6 -0
- package/slick-profile-picture/slick-profile-picture.component.d.ts +3 -0
- package/slick-profile-picture/slick-profile-picture.module.d.ts +7 -0
- package/slick-progress-bar/slick-progress-bar.module.d.ts +5 -0
- package/slick-progress-bar/slick-progress-bar.service.d.ts +3 -0
- package/slick-screen-blocker/slick-screen-blocker.module.d.ts +5 -0
- package/slick-screen-blocker/slick-screen-blocker.service.d.ts +3 -0
- package/slick-slider/slick-slider.component.d.ts +3 -0
- package/slick-slider/slick-slider.module.d.ts +6 -0
- package/slick-split-screen/slick-screen-split-left-content.component.d.ts +3 -0
- package/slick-split-screen/slick-screen-split-right-content.component.d.ts +3 -0
- package/slick-split-screen/slick-split-screen.component.d.ts +3 -0
- package/slick-split-screen/slick-split-screen.module.d.ts +8 -0
- package/slick-tabs/slick-tab-header.component.d.ts +3 -0
- package/slick-tabs/slick-tab.component.d.ts +3 -0
- package/slick-tabs/slick-tabs.component.d.ts +3 -0
- package/slick-tabs/slick-tabs.module.d.ts +10 -0
- package/slick-toast/slick-toast.module.d.ts +5 -0
- package/slick-toast/slick-toast.service.d.ts +3 -0
- package/slick-tree-view/slick-tree-view.component.d.ts +3 -0
- package/slick-tree-view/slick-tree-view.module.d.ts +8 -0
- package/slick-type-ahead/slick-type-ahead.directive.d.ts +3 -0
- package/slick-type-ahead/slick-type-ahead.module.d.ts +5 -0
- package/slick-validation-indicator/slick-validation-indicator.directive.d.ts +3 -0
- package/slick-validation-indicator/slick-validation-indicator.module.d.ts +6 -0
- package/utils/slick-function-lock.service.d.ts +3 -0
- package/utils/slick-init.service.d.ts +3 -0
- package/utils/slick-log.service.d.ts +3 -0
- package/utils/slick-sleep.service.d.ts +3 -0
- package/utils/slick-utils.service.d.ts +5 -0
- package/bundles/slick-components.umd.js +0 -9777
- package/bundles/slick-components.umd.js.map +0 -1
- package/esm2015/public-api.js +0 -43
- package/esm2015/slick-accordion/slick-accordion-item-header.component.js +0 -10
- package/esm2015/slick-accordion/slick-accordion-item.component.js +0 -80
- package/esm2015/slick-accordion/slick-accordion.component.js +0 -77
- package/esm2015/slick-accordion/slick-accordion.module.js +0 -18
- package/esm2015/slick-auto-complete/slick-auto-complete-list-item-template.directive.js +0 -21
- package/esm2015/slick-auto-complete/slick-auto-complete.component.js +0 -352
- package/esm2015/slick-auto-complete/slick-auto-complete.module.js +0 -19
- package/esm2015/slick-button-spinner/slick-button-spinner.component.js +0 -186
- package/esm2015/slick-button-spinner/slick-button-spinner.module.js +0 -14
- package/esm2015/slick-calendar/slick-calendar.component.js +0 -233
- package/esm2015/slick-calendar/slick-calendar.module.js +0 -14
- package/esm2015/slick-card/slick-card-header.component.js +0 -10
- package/esm2015/slick-card/slick-card.component.js +0 -37
- package/esm2015/slick-card/slick-card.module.js +0 -14
- package/esm2015/slick-components.js +0 -27
- package/esm2015/slick-confirm-dialog/slick-confirm-dialog.component.js +0 -62
- package/esm2015/slick-confirm-dialog/slick-confirm-dialog.module.js +0 -15
- package/esm2015/slick-container/slick-container-body.component.js +0 -18
- package/esm2015/slick-container/slick-container-footer.component.js +0 -16
- package/esm2015/slick-container/slick-container-header.component.js +0 -16
- package/esm2015/slick-container/slick-container.component.js +0 -19
- package/esm2015/slick-container/slick-container.module.js +0 -20
- package/esm2015/slick-context-menu/slick-context-menu-item.component.js +0 -10
- package/esm2015/slick-context-menu/slick-context-menu.component.js +0 -43
- package/esm2015/slick-context-menu/slick-context-menu.module.js +0 -15
- package/esm2015/slick-currency-mask/slick-currency-mask.directive.js +0 -234
- package/esm2015/slick-currency-mask/slick-currency-mask.module.js +0 -14
- package/esm2015/slick-date-picker/slick-date-picker.component.js +0 -267
- package/esm2015/slick-date-picker/slick-date-picker.module.js +0 -16
- package/esm2015/slick-dialog/slick-dialog-footer.component.js +0 -18
- package/esm2015/slick-dialog/slick-dialog.component.js +0 -282
- package/esm2015/slick-dialog/slick-dialog.module.js +0 -18
- package/esm2015/slick-dialog/slick-dialog.service.js +0 -67
- package/esm2015/slick-drag-drop/slick-drag-drop.directive.js +0 -9
- package/esm2015/slick-drag-drop/slick-drag-drop.module.js +0 -14
- package/esm2015/slick-drag-drop/slick-draggable.directive.js +0 -9
- package/esm2015/slick-drop-down/slick-drop-down.component.js +0 -465
- package/esm2015/slick-drop-down/slick-drop-down.module.js +0 -19
- package/esm2015/slick-drop-down/slick-drop-down.service.js +0 -59
- package/esm2015/slick-drop-list/slick-drop-list-grab.directive.js +0 -18
- package/esm2015/slick-drop-list/slick-drop-list-item.directive.js +0 -18
- package/esm2015/slick-drop-list/slick-drop-list.directive.js +0 -162
- package/esm2015/slick-drop-list/slick-drop-list.module.js +0 -15
- package/esm2015/slick-email-viewer/slick-email-viewer-dialog.component.js +0 -61
- package/esm2015/slick-email-viewer/slick-email-viewer.component.js +0 -39
- package/esm2015/slick-email-viewer/slick-email-viewer.module.js +0 -21
- package/esm2015/slick-emailer/slick-emailer-dialog.component.js +0 -122
- package/esm2015/slick-emailer/slick-emailer.component.js +0 -226
- package/esm2015/slick-emailer/slick-emailer.module.js +0 -24
- package/esm2015/slick-file-drop/slick-file-drop.component.js +0 -144
- package/esm2015/slick-file-drop/slick-file-drop.module.js +0 -15
- package/esm2015/slick-file-list/slick-file-list-item.component.js +0 -156
- package/esm2015/slick-file-list/slick-file-list.component.js +0 -114
- package/esm2015/slick-file-list/slick-file-list.module.js +0 -18
- package/esm2015/slick-google-address-search/slick-google-address-search.directive.js +0 -75
- package/esm2015/slick-google-address-search/slick-google-address-search.module.js +0 -14
- package/esm2015/slick-google-map/slick-google-map-dialog.component.js +0 -45
- package/esm2015/slick-google-map/slick-google-map.component.js +0 -45
- package/esm2015/slick-google-map/slick-google-map.module.js +0 -17
- package/esm2015/slick-grid/slick-grid-column-template.directive.js +0 -19
- package/esm2015/slick-grid/slick-grid-sanitize.pipe.js +0 -20
- package/esm2015/slick-grid/slick-grid.component.js +0 -792
- package/esm2015/slick-grid/slick-grid.module.js +0 -38
- package/esm2015/slick-grid/slick-grid.service.js +0 -72
- package/esm2015/slick-multi-select/slick-multi-select.component.js +0 -356
- package/esm2015/slick-multi-select/slick-multi-select.module.js +0 -15
- package/esm2015/slick-multi-select/slick-multi-select.service.js +0 -74
- package/esm2015/slick-ordered-list/slick-ordered-list.component.js +0 -198
- package/esm2015/slick-ordered-list/slick-ordered-list.module.js +0 -15
- package/esm2015/slick-paging/slick-paging.component.js +0 -180
- package/esm2015/slick-paging/slick-paging.module.js +0 -14
- package/esm2015/slick-photo-gallery/slick-photo-gallery.component.js +0 -101
- package/esm2015/slick-photo-gallery/slick-photo-gallery.module.js +0 -16
- package/esm2015/slick-pick-list/slick-pick-list.component.js +0 -78
- package/esm2015/slick-pick-list/slick-pick-list.module.js +0 -15
- package/esm2015/slick-popover/slick-popover.component.js +0 -199
- package/esm2015/slick-popover/slick-popover.module.js +0 -14
- package/esm2015/slick-profile-picture/slick-profile-picture.component.js +0 -242
- package/esm2015/slick-profile-picture/slick-profile-picture.module.js +0 -15
- package/esm2015/slick-progress-bar/slick-progress-bar.module.js +0 -13
- package/esm2015/slick-progress-bar/slick-progress-bar.service.js +0 -50
- package/esm2015/slick-screen-blocker/slick-screen-blocker.module.js +0 -13
- package/esm2015/slick-screen-blocker/slick-screen-blocker.service.js +0 -80
- package/esm2015/slick-slider/slick-slider.component.js +0 -88
- package/esm2015/slick-slider/slick-slider.module.js +0 -15
- package/esm2015/slick-split-screen/slick-screen-split-left-content.component.js +0 -13
- package/esm2015/slick-split-screen/slick-screen-split-right-content.component.js +0 -13
- package/esm2015/slick-split-screen/slick-split-screen.component.js +0 -148
- package/esm2015/slick-split-screen/slick-split-screen.module.js +0 -16
- package/esm2015/slick-tabs/slick-tab-header.component.js +0 -25
- package/esm2015/slick-tabs/slick-tab.component.js +0 -67
- package/esm2015/slick-tabs/slick-tabs.component.js +0 -104
- package/esm2015/slick-tabs/slick-tabs.module.js +0 -17
- package/esm2015/slick-toast/slick-toast.module.js +0 -13
- package/esm2015/slick-toast/slick-toast.service.js +0 -91
- package/esm2015/slick-tree-view/slick-tree-view.component.js +0 -287
- package/esm2015/slick-tree-view/slick-tree-view.module.js +0 -17
- package/esm2015/slick-type-ahead/slick-type-ahead.directive.js +0 -155
- package/esm2015/slick-type-ahead/slick-type-ahead.module.js +0 -13
- package/esm2015/slick-validation-indicator/slick-validation-indicator.directive.js +0 -61
- package/esm2015/slick-validation-indicator/slick-validation-indicator.module.js +0 -14
- package/esm2015/utils/slick-function-lock.service.js +0 -54
- package/esm2015/utils/slick-init.service.js +0 -48
- package/esm2015/utils/slick-log.service.js +0 -27
- package/esm2015/utils/slick-sleep.service.js +0 -14
- package/esm2015/utils/slick-utils.service.js +0 -229
- package/fesm2015/slick-components.js.map +0 -1
- package/slick-components.metadata.json +0 -1
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { HttpClientModule } from "@angular/common/http";
|
|
4
|
+
import { SlickGridColumnModel, SlickGridColumnFilterTypes, SlickGridColumnSortDirection } from "./slick-grid-column.model";
|
|
5
|
+
import { SlickGridFavoriteModel } from "./slick-grid-favorite.model";
|
|
6
|
+
import { SlickGridRequestModel } from "./slick-grid-request.model";
|
|
7
|
+
import { SlickGridResponseModel } from "./slick-grid-response.model";
|
|
8
|
+
import { SlickGridComponent } from "./slick-grid.component";
|
|
9
|
+
import { SlickGridColumnTemplateDirective } from "./slick-grid-column-template.directive";
|
|
10
|
+
import { SlickGridOptions } from "./slick-grid.options";
|
|
11
|
+
import { SlickGridService } from "./slick-grid.service";
|
|
12
|
+
import { SlickConfirmDialogModule } from "../slick-confirm-dialog/slick-confirm-dialog.module";
|
|
13
|
+
import { SlickDialogModule } from "../slick-dialog/slick-dialog.module";
|
|
14
|
+
import { SlickDropDownModule } from "../slick-drop-down/slick-drop-down.module";
|
|
15
|
+
import { SlickDropListModule } from "../slick-drop-list/slick-drop-list.module";
|
|
16
|
+
import { SlickPagingModule } from "../slick-paging/slick-paging.module";
|
|
17
|
+
import { SlickPickListModule } from "../slick-pick-list/slick-pick-list.module";
|
|
18
|
+
import { SlickPopoverModule } from "../slick-popover/slick-popover.module";
|
|
19
|
+
import { SlickGridSanitizeHtmlPipe } from "./slick-grid-sanitize.pipe";
|
|
20
|
+
import { SlickFunctionLockService } from "../utils/slick-function-lock.service";
|
|
21
|
+
import * as i0 from "@angular/core";
|
|
22
|
+
export class SlickGridModule {
|
|
23
|
+
}
|
|
24
|
+
/** @nocollapse */ SlickGridModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
25
|
+
/** @nocollapse */ SlickGridModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridModule, declarations: [SlickGridComponent, SlickGridColumnTemplateDirective, SlickGridSanitizeHtmlPipe], imports: [CommonModule, SlickConfirmDialogModule, SlickPickListModule, SlickPopoverModule, SlickDialogModule, SlickDropDownModule, SlickDropListModule, SlickPagingModule, HttpClientModule], exports: [SlickGridComponent, SlickGridColumnTemplateDirective, SlickPickListModule, SlickDialogModule, SlickDropDownModule] });
|
|
26
|
+
/** @nocollapse */ SlickGridModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridModule, providers: [SlickGridService, SlickFunctionLockService, SlickGridSanitizeHtmlPipe], imports: [[CommonModule, SlickConfirmDialogModule, SlickPickListModule, SlickPopoverModule, SlickDialogModule, SlickDropDownModule, SlickDropListModule, SlickPagingModule, HttpClientModule], SlickPickListModule, SlickDialogModule, SlickDropDownModule] });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridModule, decorators: [{
|
|
28
|
+
type: NgModule,
|
|
29
|
+
args: [{
|
|
30
|
+
imports: [CommonModule, SlickConfirmDialogModule, SlickPickListModule, SlickPopoverModule, SlickDialogModule, SlickDropDownModule, SlickDropListModule, SlickPagingModule, HttpClientModule],
|
|
31
|
+
declarations: [SlickGridComponent, SlickGridColumnTemplateDirective, SlickGridSanitizeHtmlPipe],
|
|
32
|
+
exports: [SlickGridComponent, SlickGridColumnTemplateDirective, SlickPickListModule, SlickDialogModule, SlickDropDownModule],
|
|
33
|
+
providers: [SlickGridService, SlickFunctionLockService, SlickGridSanitizeHtmlPipe]
|
|
34
|
+
}]
|
|
35
|
+
}] });
|
|
36
|
+
export { SlickGridColumnModel, SlickGridColumnFilterTypes, SlickGridColumnSortDirection };
|
|
37
|
+
export { SlickGridFavoriteModel };
|
|
38
|
+
export { SlickGridRequestModel };
|
|
39
|
+
export { SlickGridResponseModel };
|
|
40
|
+
export { SlickGridComponent };
|
|
41
|
+
export { SlickGridColumnTemplateDirective };
|
|
42
|
+
export { SlickGridOptions };
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpY2stZ3JpZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9zbGljay1ncmlkL3NsaWNrLWdyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSwwQkFBMEIsRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzNILE9BQU8sRUFBMkIsc0JBQXNCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM5RixPQUFPLEVBQTBCLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDM0YsT0FBTyxFQUEyQixzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzlGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzFGLE9BQU8sRUFBcUIsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMzRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxxREFBcUQsQ0FBQztBQUMvRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNoRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNoRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNoRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMzRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUN2RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7QUFRaEYsTUFBTSxPQUFPLGVBQWU7OytIQUFmLGVBQWU7Z0lBQWYsZUFBZSxpQkFKWixrQkFBa0IsRUFBRyxnQ0FBZ0MsRUFBRSx5QkFBeUIsYUFEckYsWUFBWSxFQUFFLHdCQUF3QixFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixhQUVqTCxrQkFBa0IsRUFBRSxnQ0FBZ0MsRUFBRSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxtQkFBbUI7Z0lBRy9HLGVBQWUsYUFGaEIsQ0FBQyxnQkFBZ0IsRUFBRSx3QkFBd0IsRUFBRSx5QkFBeUIsQ0FBQyxZQUh6RSxDQUFDLFlBQVksRUFBRSx3QkFBd0IsRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsRUFBRSxtQkFBbUIsRUFBRSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxnQkFBZ0IsQ0FBQyxFQUU1SCxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxtQkFBbUI7MkZBRy9HLGVBQWU7a0JBTjNCLFFBQVE7bUJBQUM7b0JBQ1QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLHdCQUF3QixFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixDQUFDO29CQUM1TCxZQUFZLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRyxnQ0FBZ0MsRUFBRSx5QkFBeUIsQ0FBQztvQkFDaEcsT0FBTyxFQUFFLENBQUMsa0JBQWtCLEVBQUUsZ0NBQWdDLEVBQUUsbUJBQW1CLEVBQUUsaUJBQWlCLEVBQUUsbUJBQW1CLENBQUM7b0JBQzVILFNBQVMsRUFBRSxDQUFDLGdCQUFnQixFQUFFLHdCQUF3QixFQUFFLHlCQUF5QixDQUFDO2lCQUNsRjs7QUFHRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsMEJBQTBCLEVBQUUsNEJBQTRCLEVBQUUsQ0FBQTtBQUN6RixPQUFPLEVBQTJCLHNCQUFzQixFQUFFLENBQUE7QUFDMUQsT0FBTyxFQUEwQixxQkFBcUIsRUFBRSxDQUFBO0FBQ3hELE9BQU8sRUFBMkIsc0JBQXNCLEVBQUUsQ0FBQTtBQUMxRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQTtBQUM3QixPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsQ0FBQTtBQUMzQyxPQUFPLEVBQXFCLGdCQUFnQixFQUFFLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb24vaHR0cFwiO1xyXG5pbXBvcnQgeyBTbGlja0dyaWRDb2x1bW5Nb2RlbCwgU2xpY2tHcmlkQ29sdW1uRmlsdGVyVHlwZXMsIFNsaWNrR3JpZENvbHVtblNvcnREaXJlY3Rpb24gfSBmcm9tIFwiLi9zbGljay1ncmlkLWNvbHVtbi5tb2RlbFwiO1xyXG5pbXBvcnQgeyBJU2xpY2tHcmlkRmF2b3JpdGVNb2RlbCwgU2xpY2tHcmlkRmF2b3JpdGVNb2RlbCB9IGZyb20gXCIuL3NsaWNrLWdyaWQtZmF2b3JpdGUubW9kZWxcIjtcclxuaW1wb3J0IHsgSVNsaWNrR3JpZFJlcXVlc3RNb2RlbCwgU2xpY2tHcmlkUmVxdWVzdE1vZGVsIH0gZnJvbSBcIi4vc2xpY2stZ3JpZC1yZXF1ZXN0Lm1vZGVsXCI7XHJcbmltcG9ydCB7IElTbGlja0dyaWRSZXNwb25zZU1vZGVsLCBTbGlja0dyaWRSZXNwb25zZU1vZGVsIH0gZnJvbSBcIi4vc2xpY2stZ3JpZC1yZXNwb25zZS5tb2RlbFwiO1xyXG5pbXBvcnQgeyBTbGlja0dyaWRDb21wb25lbnQgfSBmcm9tIFwiLi9zbGljay1ncmlkLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBTbGlja0dyaWRDb2x1bW5UZW1wbGF0ZURpcmVjdGl2ZSB9IGZyb20gXCIuL3NsaWNrLWdyaWQtY29sdW1uLXRlbXBsYXRlLmRpcmVjdGl2ZVwiO1xyXG5pbXBvcnQgeyBJU2xpY2tHcmlkT3B0aW9ucywgU2xpY2tHcmlkT3B0aW9ucyB9IGZyb20gXCIuL3NsaWNrLWdyaWQub3B0aW9uc1wiO1xyXG5pbXBvcnQgeyBTbGlja0dyaWRTZXJ2aWNlIH0gZnJvbSBcIi4vc2xpY2stZ3JpZC5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IFNsaWNrQ29uZmlybURpYWxvZ01vZHVsZSB9IGZyb20gXCIuLi9zbGljay1jb25maXJtLWRpYWxvZy9zbGljay1jb25maXJtLWRpYWxvZy5tb2R1bGVcIjtcclxuaW1wb3J0IHsgU2xpY2tEaWFsb2dNb2R1bGUgfSBmcm9tIFwiLi4vc2xpY2stZGlhbG9nL3NsaWNrLWRpYWxvZy5tb2R1bGVcIjtcclxuaW1wb3J0IHsgU2xpY2tEcm9wRG93bk1vZHVsZSB9IGZyb20gXCIuLi9zbGljay1kcm9wLWRvd24vc2xpY2stZHJvcC1kb3duLm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBTbGlja0Ryb3BMaXN0TW9kdWxlIH0gZnJvbSBcIi4uL3NsaWNrLWRyb3AtbGlzdC9zbGljay1kcm9wLWxpc3QubW9kdWxlXCI7XHJcbmltcG9ydCB7IFNsaWNrUGFnaW5nTW9kdWxlIH0gZnJvbSBcIi4uL3NsaWNrLXBhZ2luZy9zbGljay1wYWdpbmcubW9kdWxlXCI7XHJcbmltcG9ydCB7IFNsaWNrUGlja0xpc3RNb2R1bGUgfSBmcm9tIFwiLi4vc2xpY2stcGljay1saXN0L3NsaWNrLXBpY2stbGlzdC5tb2R1bGVcIjtcclxuaW1wb3J0IHsgU2xpY2tQb3BvdmVyTW9kdWxlIH0gZnJvbSBcIi4uL3NsaWNrLXBvcG92ZXIvc2xpY2stcG9wb3Zlci5tb2R1bGVcIjtcclxuaW1wb3J0IHsgU2xpY2tHcmlkU2FuaXRpemVIdG1sUGlwZSB9IGZyb20gXCIuL3NsaWNrLWdyaWQtc2FuaXRpemUucGlwZVwiO1xyXG5pbXBvcnQgeyBTbGlja0Z1bmN0aW9uTG9ja1NlcnZpY2UgfSBmcm9tIFwiLi4vdXRpbHMvc2xpY2stZnVuY3Rpb24tbG9jay5zZXJ2aWNlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG5cdGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFNsaWNrQ29uZmlybURpYWxvZ01vZHVsZSwgU2xpY2tQaWNrTGlzdE1vZHVsZSwgU2xpY2tQb3BvdmVyTW9kdWxlLCBTbGlja0RpYWxvZ01vZHVsZSwgU2xpY2tEcm9wRG93bk1vZHVsZSwgU2xpY2tEcm9wTGlzdE1vZHVsZSwgU2xpY2tQYWdpbmdNb2R1bGUsIEh0dHBDbGllbnRNb2R1bGVdLFxyXG5cdGRlY2xhcmF0aW9uczogW1NsaWNrR3JpZENvbXBvbmVudCwgIFNsaWNrR3JpZENvbHVtblRlbXBsYXRlRGlyZWN0aXZlLCBTbGlja0dyaWRTYW5pdGl6ZUh0bWxQaXBlXSxcclxuXHRleHBvcnRzOiBbU2xpY2tHcmlkQ29tcG9uZW50LCBTbGlja0dyaWRDb2x1bW5UZW1wbGF0ZURpcmVjdGl2ZSwgU2xpY2tQaWNrTGlzdE1vZHVsZSwgU2xpY2tEaWFsb2dNb2R1bGUsIFNsaWNrRHJvcERvd25Nb2R1bGVdLFxyXG5cdHByb3ZpZGVyczogW1NsaWNrR3JpZFNlcnZpY2UsIFNsaWNrRnVuY3Rpb25Mb2NrU2VydmljZSwgU2xpY2tHcmlkU2FuaXRpemVIdG1sUGlwZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNsaWNrR3JpZE1vZHVsZSB7XHJcbn1cclxuZXhwb3J0IHsgU2xpY2tHcmlkQ29sdW1uTW9kZWwsIFNsaWNrR3JpZENvbHVtbkZpbHRlclR5cGVzLCBTbGlja0dyaWRDb2x1bW5Tb3J0RGlyZWN0aW9uIH1cclxuZXhwb3J0IHsgSVNsaWNrR3JpZEZhdm9yaXRlTW9kZWwsIFNsaWNrR3JpZEZhdm9yaXRlTW9kZWwgfVxyXG5leHBvcnQgeyBJU2xpY2tHcmlkUmVxdWVzdE1vZGVsLCBTbGlja0dyaWRSZXF1ZXN0TW9kZWwgfVxyXG5leHBvcnQgeyBJU2xpY2tHcmlkUmVzcG9uc2VNb2RlbCwgU2xpY2tHcmlkUmVzcG9uc2VNb2RlbCB9XHJcbmV4cG9ydCB7IFNsaWNrR3JpZENvbXBvbmVudCB9XHJcbmV4cG9ydCB7IFNsaWNrR3JpZENvbHVtblRlbXBsYXRlRGlyZWN0aXZlIH1cclxuZXhwb3J0IHsgSVNsaWNrR3JpZE9wdGlvbnMsIFNsaWNrR3JpZE9wdGlvbnMgfVxyXG5cclxuIl19
|
package/{esm2015/slick-grid/slick-grid.options.js → esm2020/slick-grid/slick-grid.options.mjs}
RENAMED
|
File without changes
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { SlickGridResponseModel } from "./slick-grid-response.model";
|
|
3
|
+
import { SlickUtilsService } from "../utils/slick-utils.service";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common/http";
|
|
6
|
+
export class SlickGridService {
|
|
7
|
+
constructor(http) {
|
|
8
|
+
this.http = http;
|
|
9
|
+
}
|
|
10
|
+
async getDataFromServer(requestModel) {
|
|
11
|
+
try {
|
|
12
|
+
let params = {};
|
|
13
|
+
if (requestModel.additionalParams)
|
|
14
|
+
params.additionalParams = requestModel.additionalParams;
|
|
15
|
+
// If the user has a custom search string, add it to the params here
|
|
16
|
+
if (requestModel.searchString)
|
|
17
|
+
params.searchString = requestModel.searchString;
|
|
18
|
+
if (requestModel.recordsPerPage)
|
|
19
|
+
params.recordsPerPage = requestModel.recordsPerPage;
|
|
20
|
+
params.page = (requestModel.page === null || requestModel.page === undefined) ? 1 : requestModel.page;
|
|
21
|
+
if (requestModel.sortColumn) {
|
|
22
|
+
params.sortColumn = requestModel.sortColumn;
|
|
23
|
+
params.sortDirection = requestModel.sortDirection;
|
|
24
|
+
}
|
|
25
|
+
delete params.columnSearchValues;
|
|
26
|
+
if (requestModel.columnSearchValues)
|
|
27
|
+
params.columnSearchValues = requestModel.columnSearchValues;
|
|
28
|
+
let data = await this.http.post(requestModel.url, params, { headers: requestModel.httpHeaders }).toPromise();
|
|
29
|
+
data = SlickUtilsService.dateSanitize(data);
|
|
30
|
+
return Promise.resolve(data);
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
console.error(error);
|
|
34
|
+
return Promise.reject(error);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
async getDataFromDataObj(requestModel, data) {
|
|
38
|
+
try {
|
|
39
|
+
let responseModel = new SlickGridResponseModel();
|
|
40
|
+
if (!data || data.length === 0) {
|
|
41
|
+
responseModel.totalRecords = 0;
|
|
42
|
+
responseModel.data = [];
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
responseModel.totalRecords = data.length;
|
|
46
|
+
let page = (requestModel.page === null || requestModel.page === undefined) ? 1 : requestModel.page;
|
|
47
|
+
let startIndex = (page - 1) * requestModel.recordsPerPage;
|
|
48
|
+
let endIndex = startIndex + requestModel.recordsPerPage;
|
|
49
|
+
if (endIndex > data.length)
|
|
50
|
+
endIndex = data.length;
|
|
51
|
+
responseModel.data = data.slice(startIndex, endIndex);
|
|
52
|
+
}
|
|
53
|
+
return Promise.resolve(responseModel);
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
console.error(error);
|
|
57
|
+
return Promise.reject(error);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
/** @nocollapse */ SlickGridService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
62
|
+
/** @nocollapse */ SlickGridService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridService });
|
|
63
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickGridService, decorators: [{
|
|
64
|
+
type: Injectable
|
|
65
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpY2stZ3JpZC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvc2xpY2stZ3JpZC9zbGljay1ncmlkLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUVyRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7O0FBR2pFLE1BQU0sT0FBTyxnQkFBZ0I7SUFDNUIsWUFBb0IsSUFBZ0I7UUFBaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtJQUFJLENBQUM7SUFFekMsS0FBSyxDQUFDLGlCQUFpQixDQUFFLFlBQW1DO1FBQzNELElBQUk7WUFDSCxJQUFJLE1BQU0sR0FBUSxFQUFFLENBQUM7WUFDckIsSUFBSSxZQUFZLENBQUMsZ0JBQWdCO2dCQUNoQyxNQUFNLENBQUMsZ0JBQWdCLEdBQUcsWUFBWSxDQUFDLGdCQUFnQixDQUFDO1lBRXpELG9FQUFvRTtZQUNwRSxJQUFJLFlBQVksQ0FBQyxZQUFZO2dCQUM1QixNQUFNLENBQUMsWUFBWSxHQUFHLFlBQVksQ0FBQyxZQUFZLENBQUM7WUFFakQsSUFBSSxZQUFZLENBQUMsY0FBYztnQkFDOUIsTUFBTSxDQUFDLGNBQWMsR0FBRyxZQUFZLENBQUMsY0FBYyxDQUFDO1lBRXJELE1BQU0sQ0FBQyxJQUFJLEdBQUcsQ0FBQyxZQUFZLENBQUMsSUFBSSxLQUFLLElBQUksSUFBSSxZQUFZLENBQUMsSUFBSSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUEsQ0FBQyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUM7WUFFckcsSUFBSSxZQUFZLENBQUMsVUFBVSxFQUFFO2dCQUM1QixNQUFNLENBQUMsVUFBVSxHQUFHLFlBQVksQ0FBQyxVQUFVLENBQUM7Z0JBQzVDLE1BQU0sQ0FBQyxhQUFhLEdBQUcsWUFBWSxDQUFDLGFBQWEsQ0FBQzthQUNsRDtZQUVELE9BQU8sTUFBTSxDQUFDLGtCQUFrQixDQUFDO1lBQ2pDLElBQUksWUFBWSxDQUFDLGtCQUFrQjtnQkFDbEMsTUFBTSxDQUFDLGtCQUFrQixHQUFHLFlBQVksQ0FBQyxrQkFBa0IsQ0FBQztZQUU3RCxJQUFJLElBQUksR0FBb0QsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxFQUFFLE9BQU8sRUFBRSxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxTQUFTLEVBQUcsQ0FBQztZQUMvSixJQUFJLEdBQUcsaUJBQWlCLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVDLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUM3QjtRQUNELE9BQU8sS0FBSyxFQUFFO1lBQ2IsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyQixPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDN0I7SUFFRixDQUFDO0lBRUQsS0FBSyxDQUFDLGtCQUFrQixDQUFDLFlBQW1DLEVBQUUsSUFBVztRQUN4RSxJQUFJO1lBQ0gsSUFBSSxhQUFhLEdBQTJCLElBQUksc0JBQXNCLEVBQUUsQ0FBQztZQUV6RSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO2dCQUMvQixhQUFhLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQztnQkFDL0IsYUFBYSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUM7YUFDeEI7aUJBQ0k7Z0JBQ0osYUFBYSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO2dCQUN6QyxJQUFJLElBQUksR0FBRyxDQUFDLFlBQVksQ0FBQyxJQUFJLEtBQUssSUFBSSxJQUFJLFlBQVksQ0FBQyxJQUFJLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQztnQkFFbkcsSUFBSSxVQUFVLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEdBQUcsWUFBWSxDQUFDLGNBQWMsQ0FBQztnQkFDMUQsSUFBSSxRQUFRLEdBQUcsVUFBVSxHQUFHLFlBQVksQ0FBQyxjQUFjLENBQUM7Z0JBQ3hELElBQUksUUFBUSxHQUFHLElBQUksQ0FBQyxNQUFNO29CQUN6QixRQUFRLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztnQkFDeEIsYUFBYSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxRQUFRLENBQUMsQ0FBQzthQUN0RDtZQUVELE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztTQUN0QztRQUNELE9BQU8sS0FBSyxFQUFFO1lBQ2IsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyQixPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDN0I7SUFFRixDQUFDOztnSUFoRVcsZ0JBQWdCO29JQUFoQixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBTbGlja0dyaWRSZXF1ZXN0TW9kZWwgfSBmcm9tIFwiLi9zbGljay1ncmlkLXJlcXVlc3QubW9kZWxcIjtcclxuaW1wb3J0IHsgU2xpY2tHcmlkUmVzcG9uc2VNb2RlbCB9IGZyb20gXCIuL3NsaWNrLWdyaWQtcmVzcG9uc2UubW9kZWxcIjtcclxuaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cEhlYWRlcnMgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcclxuaW1wb3J0IHsgU2xpY2tVdGlsc1NlcnZpY2UgfSBmcm9tIFwiLi4vdXRpbHMvc2xpY2stdXRpbHMuc2VydmljZVwiO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU2xpY2tHcmlkU2VydmljZSB7XHJcblx0Y29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50KSB7IH1cclxuXHJcblx0YXN5bmMgZ2V0RGF0YUZyb21TZXJ2ZXIgKHJlcXVlc3RNb2RlbDogU2xpY2tHcmlkUmVxdWVzdE1vZGVsKTogUHJvbWlzZTxTbGlja0dyaWRSZXNwb25zZU1vZGVsPiB7XHJcblx0XHR0cnkge1xyXG5cdFx0XHRsZXQgcGFyYW1zID0gPGFueT57fTtcclxuXHRcdFx0aWYgKHJlcXVlc3RNb2RlbC5hZGRpdGlvbmFsUGFyYW1zKVxyXG5cdFx0XHRcdHBhcmFtcy5hZGRpdGlvbmFsUGFyYW1zID0gcmVxdWVzdE1vZGVsLmFkZGl0aW9uYWxQYXJhbXM7XHJcblxyXG5cdFx0XHQvLyBJZiB0aGUgdXNlciBoYXMgYSBjdXN0b20gc2VhcmNoIHN0cmluZywgYWRkIGl0IHRvIHRoZSBwYXJhbXMgaGVyZVxyXG5cdFx0XHRpZiAocmVxdWVzdE1vZGVsLnNlYXJjaFN0cmluZylcclxuXHRcdFx0XHRwYXJhbXMuc2VhcmNoU3RyaW5nID0gcmVxdWVzdE1vZGVsLnNlYXJjaFN0cmluZztcclxuXHJcblx0XHRcdGlmIChyZXF1ZXN0TW9kZWwucmVjb3Jkc1BlclBhZ2UpXHJcblx0XHRcdFx0cGFyYW1zLnJlY29yZHNQZXJQYWdlID0gcmVxdWVzdE1vZGVsLnJlY29yZHNQZXJQYWdlO1xyXG5cclxuXHRcdFx0cGFyYW1zLnBhZ2UgPSAocmVxdWVzdE1vZGVsLnBhZ2UgPT09IG51bGwgfHwgcmVxdWVzdE1vZGVsLnBhZ2UgPT09IHVuZGVmaW5lZCkgPyAxOiByZXF1ZXN0TW9kZWwucGFnZTtcclxuXHJcblx0XHRcdGlmIChyZXF1ZXN0TW9kZWwuc29ydENvbHVtbikge1xyXG5cdFx0XHRcdHBhcmFtcy5zb3J0Q29sdW1uID0gcmVxdWVzdE1vZGVsLnNvcnRDb2x1bW47XHJcblx0XHRcdFx0cGFyYW1zLnNvcnREaXJlY3Rpb24gPSByZXF1ZXN0TW9kZWwuc29ydERpcmVjdGlvbjtcclxuXHRcdFx0fVxyXG5cclxuXHRcdFx0ZGVsZXRlIHBhcmFtcy5jb2x1bW5TZWFyY2hWYWx1ZXM7XHJcblx0XHRcdGlmIChyZXF1ZXN0TW9kZWwuY29sdW1uU2VhcmNoVmFsdWVzKVxyXG5cdFx0XHRcdHBhcmFtcy5jb2x1bW5TZWFyY2hWYWx1ZXMgPSByZXF1ZXN0TW9kZWwuY29sdW1uU2VhcmNoVmFsdWVzO1xyXG5cclxuXHRcdFx0bGV0IGRhdGE6IFNsaWNrR3JpZFJlc3BvbnNlTW9kZWwgPSAoPFNsaWNrR3JpZFJlc3BvbnNlTW9kZWw+YXdhaXQgdGhpcy5odHRwLnBvc3QocmVxdWVzdE1vZGVsLnVybCwgcGFyYW1zLCB7IGhlYWRlcnM6IHJlcXVlc3RNb2RlbC5odHRwSGVhZGVycyB9KS50b1Byb21pc2UoKSk7XHJcblx0XHRcdGRhdGEgPSBTbGlja1V0aWxzU2VydmljZS5kYXRlU2FuaXRpemUoZGF0YSk7XHJcblx0XHRcdHJldHVybiBQcm9taXNlLnJlc29sdmUoZGF0YSk7XHJcblx0XHR9XHJcblx0XHRjYXRjaCAoZXJyb3IpIHtcclxuXHRcdFx0Y29uc29sZS5lcnJvcihlcnJvcik7XHJcblx0XHRcdHJldHVybiBQcm9taXNlLnJlamVjdChlcnJvcik7XHJcblx0XHR9XHJcblxyXG5cdH1cclxuXHJcblx0YXN5bmMgZ2V0RGF0YUZyb21EYXRhT2JqKHJlcXVlc3RNb2RlbDogU2xpY2tHcmlkUmVxdWVzdE1vZGVsLCBkYXRhOiBhbnlbXSk6IFByb21pc2U8U2xpY2tHcmlkUmVzcG9uc2VNb2RlbD4ge1xyXG5cdFx0dHJ5IHtcclxuXHRcdFx0bGV0IHJlc3BvbnNlTW9kZWw6IFNsaWNrR3JpZFJlc3BvbnNlTW9kZWwgPSBuZXcgU2xpY2tHcmlkUmVzcG9uc2VNb2RlbCgpO1xyXG5cdFx0XHRcclxuXHRcdFx0aWYgKCFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwKSB7XHJcblx0XHRcdFx0cmVzcG9uc2VNb2RlbC50b3RhbFJlY29yZHMgPSAwO1xyXG5cdFx0XHRcdHJlc3BvbnNlTW9kZWwuZGF0YSA9IFtdO1xyXG5cdFx0XHR9XHJcblx0XHRcdGVsc2Uge1xyXG5cdFx0XHRcdHJlc3BvbnNlTW9kZWwudG90YWxSZWNvcmRzID0gZGF0YS5sZW5ndGg7XHJcblx0XHRcdFx0bGV0IHBhZ2UgPSAocmVxdWVzdE1vZGVsLnBhZ2UgPT09IG51bGwgfHwgcmVxdWVzdE1vZGVsLnBhZ2UgPT09IHVuZGVmaW5lZCkgPyAxIDogcmVxdWVzdE1vZGVsLnBhZ2U7XHJcblxyXG5cdFx0XHRcdGxldCBzdGFydEluZGV4ID0gKHBhZ2UgLSAxKSAqIHJlcXVlc3RNb2RlbC5yZWNvcmRzUGVyUGFnZTtcclxuXHRcdFx0XHRsZXQgZW5kSW5kZXggPSBzdGFydEluZGV4ICsgcmVxdWVzdE1vZGVsLnJlY29yZHNQZXJQYWdlO1xyXG5cdFx0XHRcdGlmIChlbmRJbmRleCA+IGRhdGEubGVuZ3RoKVxyXG5cdFx0XHRcdFx0ZW5kSW5kZXggPSBkYXRhLmxlbmd0aDtcclxuXHRcdFx0XHRyZXNwb25zZU1vZGVsLmRhdGEgPSBkYXRhLnNsaWNlKHN0YXJ0SW5kZXgsIGVuZEluZGV4KTtcclxuXHRcdFx0fVxyXG5cclxuXHRcdFx0cmV0dXJuIFByb21pc2UucmVzb2x2ZShyZXNwb25zZU1vZGVsKTtcclxuXHRcdH1cclxuXHRcdGNhdGNoIChlcnJvcikge1xyXG5cdFx0XHRjb25zb2xlLmVycm9yKGVycm9yKTtcclxuXHRcdFx0cmV0dXJuIFByb21pc2UucmVqZWN0KGVycm9yKTtcclxuXHRcdH1cclxuXHJcblx0fVxyXG59Il19
|
|
@@ -0,0 +1,362 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, ViewChild, forwardRef } from "@angular/core";
|
|
2
|
+
import { SlickMultiSelectService } from "./slick-multi-select.service";
|
|
3
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
|
+
import { SlickSleepService } from "../utils/slick-sleep.service";
|
|
5
|
+
import { SlickUtilsService } from "../utils/slick-utils.service";
|
|
6
|
+
import { SlickInitService } from "../utils/slick-init.service";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./slick-multi-select.service";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
export class SlickMultiSelectComponent {
|
|
11
|
+
constructor(ngZone, slickMultiSelectService, el) {
|
|
12
|
+
this.ngZone = ngZone;
|
|
13
|
+
this.slickMultiSelectService = slickMultiSelectService;
|
|
14
|
+
this.el = el;
|
|
15
|
+
this.placeholder = '';
|
|
16
|
+
this.idFieldName = "id";
|
|
17
|
+
this.textFieldName = "text";
|
|
18
|
+
this.disabled = false;
|
|
19
|
+
this.allowEmpty = 'true';
|
|
20
|
+
this.width = '100%';
|
|
21
|
+
this.listWidth = '100%';
|
|
22
|
+
this.height = '300px';
|
|
23
|
+
this.showLoadingMessage = false;
|
|
24
|
+
this.onExpand = new EventEmitter();
|
|
25
|
+
this.onCollapse = new EventEmitter();
|
|
26
|
+
this.onSelect = new EventEmitter();
|
|
27
|
+
// This is necessary so that the scroll and resize events can add and remove the event properly,
|
|
28
|
+
// as well as getting the correct ES6 function
|
|
29
|
+
this.fnDocumentClick = (e) => this.documentClick(e);
|
|
30
|
+
this.keyboardActive = false;
|
|
31
|
+
this.expanded = false;
|
|
32
|
+
this.filterText = '';
|
|
33
|
+
this.isAndroid = ((SlickInitService.getPlatform() || '').toLowerCase() === 'android');
|
|
34
|
+
this.skipClickExpand = false;
|
|
35
|
+
this.propagateChange = (_) => { };
|
|
36
|
+
this.uuid = SlickUtilsService.newGuid();
|
|
37
|
+
}
|
|
38
|
+
async ngAfterViewInit() {
|
|
39
|
+
// Remove this from the inline version and put it on the body so that it doesn't hide behind the bottom
|
|
40
|
+
// of a div when it expands beyond the bottom.
|
|
41
|
+
this.multiSelectList.nativeElement.remove(this.multiSelectList);
|
|
42
|
+
document.body.appendChild(this.multiSelectList.nativeElement);
|
|
43
|
+
}
|
|
44
|
+
// this is the initial value set to the component
|
|
45
|
+
writeValue(obj) {
|
|
46
|
+
if (obj)
|
|
47
|
+
this.selectedIds = obj;
|
|
48
|
+
else
|
|
49
|
+
this.selectedIds = null;
|
|
50
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
51
|
+
this.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
52
|
+
}
|
|
53
|
+
// registers 'fn' that will be fired when changes are made
|
|
54
|
+
// this is how we emit the changes back to the form
|
|
55
|
+
registerOnChange(fn) {
|
|
56
|
+
this.propagateChange = fn;
|
|
57
|
+
}
|
|
58
|
+
// not used, used for touch input
|
|
59
|
+
registerOnTouched() { }
|
|
60
|
+
ngOnChanges(changes) {
|
|
61
|
+
if (changes.isMobile) {
|
|
62
|
+
this.isMobile = (this.isMobile.toString().toLowerCase() === 'true') ? true : false;
|
|
63
|
+
}
|
|
64
|
+
if (changes.items) {
|
|
65
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
66
|
+
this.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
67
|
+
if (this.selectedTextInputRef && document.activeElement == this.selectedTextInputRef.nativeElement)
|
|
68
|
+
this.expand();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
ngOnDestroy() {
|
|
72
|
+
this.collapse();
|
|
73
|
+
document.removeEventListener("click", this.fnDocumentClick, true);
|
|
74
|
+
// it's okay if this fails. It was already removed
|
|
75
|
+
try {
|
|
76
|
+
document.body.removeChild(this.multiSelectList.nativeElement);
|
|
77
|
+
}
|
|
78
|
+
catch { }
|
|
79
|
+
}
|
|
80
|
+
async onKeyboardIconClicked() {
|
|
81
|
+
if (this.keyboardActive === true) {
|
|
82
|
+
this.collapse();
|
|
83
|
+
this.keyboardActive = false;
|
|
84
|
+
this.selectedText = '';
|
|
85
|
+
this.selectedTextInputRef.nativeElement.value = '';
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
this.keyboardActive = true;
|
|
89
|
+
await SlickSleepService.sleep();
|
|
90
|
+
this.selectedTextInputRef.nativeElement.focus();
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async expand() {
|
|
94
|
+
if (this.disabled)
|
|
95
|
+
return;
|
|
96
|
+
this.reposition();
|
|
97
|
+
await SlickSleepService.sleep();
|
|
98
|
+
this.multiSelectList.nativeElement.style.display = "inline-block";
|
|
99
|
+
let selectedItems = this.multiSelectList.nativeElement.getElementsByClassName("selected");
|
|
100
|
+
if (selectedItems && selectedItems.length > 0)
|
|
101
|
+
selectedItems[0].scrollIntoView({ block: 'nearest' });
|
|
102
|
+
this.expanded = true;
|
|
103
|
+
// This is necessary, otherwise `this` in the reposition function will be window
|
|
104
|
+
// and not the component.
|
|
105
|
+
// Since angular has no way to use the third parameter, I'm doing this in raw js
|
|
106
|
+
document.addEventListener("click", this.fnDocumentClick, true);
|
|
107
|
+
if (this.onExpand)
|
|
108
|
+
this.onExpand.emit();
|
|
109
|
+
}
|
|
110
|
+
collapse() {
|
|
111
|
+
this.expanded = false;
|
|
112
|
+
this.multiSelectList.nativeElement.style.display = "none";
|
|
113
|
+
// Since angular has no way to use the third parameter, I'm doing this in raw js
|
|
114
|
+
document.removeEventListener("click", this.fnDocumentClick, true);
|
|
115
|
+
if (this.onCollapse)
|
|
116
|
+
this.onCollapse.emit();
|
|
117
|
+
}
|
|
118
|
+
async reposition() {
|
|
119
|
+
await SlickSleepService.sleep();
|
|
120
|
+
let rect = this.containerDiv.nativeElement.getBoundingClientRect();
|
|
121
|
+
let containerLeft = rect.left;
|
|
122
|
+
let containerTop = rect.top;
|
|
123
|
+
let containerHeight = this.containerDiv.nativeElement.offsetHeight;
|
|
124
|
+
let containerWidth = rect.width;
|
|
125
|
+
this.width = containerWidth;
|
|
126
|
+
if (this.listWidth === '100%')
|
|
127
|
+
this.listGroupWidth = this.width;
|
|
128
|
+
else if (this.listWidth === 'auto')
|
|
129
|
+
this.listGroupWidth = "auto";
|
|
130
|
+
else
|
|
131
|
+
this.listGroupWidth = this.listWidth;
|
|
132
|
+
this.top = (containerTop + containerHeight);
|
|
133
|
+
this.left = containerLeft;
|
|
134
|
+
}
|
|
135
|
+
documentClick(e) {
|
|
136
|
+
if (!this.expanded || !e.target)
|
|
137
|
+
return;
|
|
138
|
+
// If they clicked on the keyboard icon, don't do anything
|
|
139
|
+
if (SlickUtilsService.checkParentClassExists(e.target, "slick-multi-select_mobile-container") &&
|
|
140
|
+
SlickUtilsService.checkParentIdExists(e.target, "slick-multi-select_" + this.uuid))
|
|
141
|
+
return;
|
|
142
|
+
const clickedInside = SlickUtilsService.checkParentClassExists(e.target, "slick-multi-select_list-item");
|
|
143
|
+
if (!clickedInside) {
|
|
144
|
+
this.keyboardActive = false;
|
|
145
|
+
this.selectedText = '';
|
|
146
|
+
this.selectedTextInputRef.nativeElement.value = '';
|
|
147
|
+
this.collapse();
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
selectItem(id) {
|
|
151
|
+
let item = this.slickMultiSelectService.getSelectedItem(this.visibleItems, id);
|
|
152
|
+
if (item) {
|
|
153
|
+
if (this.onSelect)
|
|
154
|
+
this.onSelect.emit(item);
|
|
155
|
+
if (!this.selectedIds)
|
|
156
|
+
this.selectedIds = [];
|
|
157
|
+
this.selectedIds.push(id);
|
|
158
|
+
this.propagateChange(this.selectedIds);
|
|
159
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
160
|
+
this.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
161
|
+
this.reposition();
|
|
162
|
+
this.selectedText = '';
|
|
163
|
+
this.selectedTextInputRef.nativeElement.value = '';
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
setFocus(showMobileKeyboard = false) {
|
|
167
|
+
this.selectedTextInputRef.nativeElement.focus();
|
|
168
|
+
if (showMobileKeyboard === true)
|
|
169
|
+
this.keyboardActive = true;
|
|
170
|
+
}
|
|
171
|
+
async onFocus() {
|
|
172
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
173
|
+
this.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
174
|
+
this.filterText = '';
|
|
175
|
+
this.selectedTextInputRef.nativeElement.focus();
|
|
176
|
+
// This is kind of hacky, but if onFocus is called by clicking the multiSelect, the onMultiSelectClick event is called as well
|
|
177
|
+
// That function will expand or collapse, depending on the state. Since this expands, it thinks it needs to collapse.
|
|
178
|
+
// So fake it out and tell it NOT to collapse. BUT, if we came in from tabbing into the field, then it would mess up
|
|
179
|
+
// the click event. So only wait for 1/2 second.
|
|
180
|
+
this.skipClickExpand = true;
|
|
181
|
+
this.expand();
|
|
182
|
+
await SlickSleepService.sleep(500);
|
|
183
|
+
this.skipClickExpand = false;
|
|
184
|
+
}
|
|
185
|
+
async onKeyUp(e) {
|
|
186
|
+
e.stopPropagation();
|
|
187
|
+
e.preventDefault();
|
|
188
|
+
// If this is android, it won't pass us any key data so just read the entire input element
|
|
189
|
+
if (this.isAndroid === true) {
|
|
190
|
+
await SlickSleepService.sleep();
|
|
191
|
+
this.filterText = this.selectedTextInputRef.nativeElement.value;
|
|
192
|
+
this.filterSearch();
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
// Tab/enter
|
|
196
|
+
if (e.which === 9 || e.which === 13) {
|
|
197
|
+
if (this.filterText && this.selectedIndex !== null && this.selectedIndex !== undefined) {
|
|
198
|
+
this.selectItem(this.visibleItems[this.selectedIndex].id);
|
|
199
|
+
this.filterText = '';
|
|
200
|
+
this.selectedIndex = null;
|
|
201
|
+
return false;
|
|
202
|
+
}
|
|
203
|
+
this.collapse();
|
|
204
|
+
this.filterText = '';
|
|
205
|
+
this.selectedText = '';
|
|
206
|
+
this.selectedTextInputRef.nativeElement.value = '';
|
|
207
|
+
this.selectedIndex = null;
|
|
208
|
+
return true;
|
|
209
|
+
}
|
|
210
|
+
// Esc
|
|
211
|
+
if (e.which === 27) {
|
|
212
|
+
this.filterText = '';
|
|
213
|
+
this.selectedText = '';
|
|
214
|
+
this.selectedTextInputRef.nativeElement.value = '';
|
|
215
|
+
this.collapse();
|
|
216
|
+
return false;
|
|
217
|
+
}
|
|
218
|
+
// Backspace
|
|
219
|
+
if (e.which === 8 && this.filterText) {
|
|
220
|
+
this.filterText = this.filterText.substring(0, this.filterText.length - 1);
|
|
221
|
+
if (this.filterText.length === 0) {
|
|
222
|
+
this.selectedText = '';
|
|
223
|
+
this.selectedTextInputRef.nativeElement.value = '';
|
|
224
|
+
this.selectedIndex = null;
|
|
225
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
226
|
+
this.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
227
|
+
}
|
|
228
|
+
else
|
|
229
|
+
this.filterSearch();
|
|
230
|
+
return false;
|
|
231
|
+
}
|
|
232
|
+
// Arrowup
|
|
233
|
+
if (e.which === 38) {
|
|
234
|
+
if (this.selectedIndex === null || this.selectedIndex === undefined)
|
|
235
|
+
this.selectedIndex = 0;
|
|
236
|
+
if (this.selectedIndex > 0)
|
|
237
|
+
this.selectedIndex--;
|
|
238
|
+
return false;
|
|
239
|
+
}
|
|
240
|
+
// Arrowdown
|
|
241
|
+
if (e.which === 40) {
|
|
242
|
+
if (this.selectedIndex === null || this.selectedIndex === undefined)
|
|
243
|
+
this.selectedIndex = -1;
|
|
244
|
+
if (!this.expanded || !this.visibleItems)
|
|
245
|
+
this.expand();
|
|
246
|
+
if (this.selectedIndex < this.visibleItems.length - 1)
|
|
247
|
+
this.selectedIndex++;
|
|
248
|
+
return false;
|
|
249
|
+
}
|
|
250
|
+
// If F1 is pressed, key length will be 2
|
|
251
|
+
if (e.key.length > 1 || e.ctrlKey || e.altKey)
|
|
252
|
+
return false;
|
|
253
|
+
if (e.which >= 32 && e.which <= 126) {
|
|
254
|
+
this.filterText += e.key;
|
|
255
|
+
this.filterSearch();
|
|
256
|
+
}
|
|
257
|
+
return true;
|
|
258
|
+
}
|
|
259
|
+
async filterSearch() {
|
|
260
|
+
if (!this.expanded)
|
|
261
|
+
this.expand();
|
|
262
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
263
|
+
this.visibleItems = this.visibleItems.filter(x => x.text.toLowerCase().indexOf(this.filterText.toLowerCase()) === 0);
|
|
264
|
+
if (this.visibleItems.length > 0) {
|
|
265
|
+
this.selectedIndex = 0;
|
|
266
|
+
this.selectedText = this.visibleItems[0].text;
|
|
267
|
+
if (this.isAndroid === false) {
|
|
268
|
+
await SlickSleepService.sleep();
|
|
269
|
+
this.selectedTextInputRef.nativeElement.value = this.selectedText;
|
|
270
|
+
this.selectedTextInputRef.nativeElement.setSelectionRange(this.filterText.length, this.selectedText.length);
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
else {
|
|
274
|
+
this.selectedIndex = null;
|
|
275
|
+
if (this.isAndroid === false) {
|
|
276
|
+
this.selectedText = this.filterText;
|
|
277
|
+
this.selectedTextInputRef.nativeElement.value = this.selectedText;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
this.reposition();
|
|
281
|
+
}
|
|
282
|
+
onMultiSelectClicked() {
|
|
283
|
+
if (this.skipClickExpand === true) {
|
|
284
|
+
this.skipClickExpand = false;
|
|
285
|
+
return;
|
|
286
|
+
}
|
|
287
|
+
this.selectedTextInputRef.nativeElement.focus();
|
|
288
|
+
if (this.expanded === false)
|
|
289
|
+
this.expand();
|
|
290
|
+
else
|
|
291
|
+
this.collapse();
|
|
292
|
+
}
|
|
293
|
+
onItemClick(item) {
|
|
294
|
+
this.selectItem(item.id);
|
|
295
|
+
if (this.keyboardActive === true)
|
|
296
|
+
this.selectedTextInputRef.nativeElement.focus();
|
|
297
|
+
}
|
|
298
|
+
onRemoveItem(item) {
|
|
299
|
+
this.selectedIds = this.selectedIds.filter(id => id !== item.id);
|
|
300
|
+
this.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
301
|
+
this.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);
|
|
302
|
+
this.propagateChange(this.selectedIds);
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
/** @nocollapse */ SlickMultiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickMultiSelectComponent, deps: [{ token: i0.NgZone }, { token: i1.SlickMultiSelectService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
306
|
+
/** @nocollapse */ SlickMultiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.3", type: SlickMultiSelectComponent, selector: "slick-multi-select", inputs: { placeholder: "placeholder", items: "items", idFieldName: "idFieldName", textFieldName: "textFieldName", disabled: "disabled", allowEmpty: "allowEmpty", width: "width", listWidth: "listWidth", height: "height", showLoadingMessage: "showLoadingMessage", showDebug: "showDebug", tabindex: "tabindex", isMobile: "isMobile" }, outputs: { onExpand: "onExpand", onCollapse: "onCollapse", onSelect: "onSelect" }, providers: [SlickMultiSelectService,
|
|
307
|
+
{
|
|
308
|
+
provide: NG_VALUE_ACCESSOR,
|
|
309
|
+
useExisting: forwardRef((() => SlickMultiSelectComponent)),
|
|
310
|
+
multi: true,
|
|
311
|
+
}], viewQueries: [{ propertyName: "containerDiv", first: true, predicate: ["containerDiv"], descendants: true }, { propertyName: "multiSelectList", first: true, predicate: ["multiSelectList"], descendants: true }, { propertyName: "selectedTextInputRef", first: true, predicate: ["selectedTextInputRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #containerDiv id=\"slick-multi-select_{{uuid}}\" attr.data-uuid=\"{{uuid}}\" class=\"slick-multi-select\" [class.mobile]=\"isMobile === true\" [class.open]=\"expanded\">\r\n\t<div class=\"slick-multi-select_input-container\">\r\n\t\t<div *ngIf=\"disabled === false\" style=\"cursor: pointer !important; flex-grow: 1;\" [ngClass]=\"{ 'slick-multi-select_mobile': isMobile === true }\" (click)=\"onMultiSelectClicked()\">\r\n\t\t\t<div *ngFor=\"let selectedItem of selectedItems\" class=\"slick-multi-select_selected-item card\"><div class=\"slick-multi-select_remove\" (click)=\"onRemoveItem(selectedItem)\"><i class=\"fas fa-times-circle bg-white text-danger\"></i></div>{{selectedItem.text}}</div>\r\n\t\t\t<input #selectedTextInputRef *ngIf=\"!isMobile\" [attr.tabindex]=\"tabindex\" [ngClass]=\"{'slick-multi-select_show-selected-text': (keyboardActive || (selectedText && selectedText.length > 0)) }\" (keyup)=\"onKeyUp($event)\" (focus)=\"onFocus()\" ng-disabled='disabled' readonly [placeholder]='placeholder' />\r\n\t\t\t<input #selectedTextInputRef *ngIf=\"isMobile === true\" [ngClass]=\"{'slick-multi-select_show-selected-text': (keyboardActive || (selectedText && selectedText.length > 0)) }\" (keyup)=\"onKeyUp($event)\" (focus)=\"onFocus()\" />\r\n\t\t</div>\r\n\t\t<div *ngIf=\"disabled === false && isMobile === true\" class=\"slick-multi-select_mobile-container\">\r\n\t\t\t<i class=\"far fa-keyboard\" style=\"cursor: pointer\" (click)=\"onKeyboardIconClicked()\"></i>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<div *ngIf=\"disabled === true\" class='input-group'>\r\n\t\t<div *ngFor=\"let selectedItem of selectedItems\" class=\"slick-multi-select_selected-item card\">{{selectedItem.text}}</div>\r\n\t</div>\r\n\r\n\t<ul #multiSelectList id=\"slick-multi-select-list_{{uuid}}\" class='slick-multi-select-list-group dropdown-menu' [style.width]=\"listGroupWidth\" [style.visibility]=\"(expanded === true) ? 'visible' : 'hidden'\" [style.opacity]=\"(expanded === true) ? '1' : '0'\" [style.max-height]=\"height\" [style.width.px]=\"listGroupWidth\" [style.left.px]=\"left\" [style.top.px]=\"top\">\r\n\t\t<li *ngFor=\"let item of visibleItems; let index = index;\" (mouseover)=\"selectedIndex = index\" (click)=\"onItemClick(item)\" [class.card-header]=\"selectedIndex === index\" class=\"dropdown-item slick-multi-select_list-item\">{{item.text}}</li>\r\n\t</ul>\r\n</div>", directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
312
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickMultiSelectComponent, decorators: [{
|
|
313
|
+
type: Component,
|
|
314
|
+
args: [{ selector: 'slick-multi-select', providers: [SlickMultiSelectService,
|
|
315
|
+
{
|
|
316
|
+
provide: NG_VALUE_ACCESSOR,
|
|
317
|
+
useExisting: forwardRef((() => SlickMultiSelectComponent)),
|
|
318
|
+
multi: true,
|
|
319
|
+
}], template: "<div #containerDiv id=\"slick-multi-select_{{uuid}}\" attr.data-uuid=\"{{uuid}}\" class=\"slick-multi-select\" [class.mobile]=\"isMobile === true\" [class.open]=\"expanded\">\r\n\t<div class=\"slick-multi-select_input-container\">\r\n\t\t<div *ngIf=\"disabled === false\" style=\"cursor: pointer !important; flex-grow: 1;\" [ngClass]=\"{ 'slick-multi-select_mobile': isMobile === true }\" (click)=\"onMultiSelectClicked()\">\r\n\t\t\t<div *ngFor=\"let selectedItem of selectedItems\" class=\"slick-multi-select_selected-item card\"><div class=\"slick-multi-select_remove\" (click)=\"onRemoveItem(selectedItem)\"><i class=\"fas fa-times-circle bg-white text-danger\"></i></div>{{selectedItem.text}}</div>\r\n\t\t\t<input #selectedTextInputRef *ngIf=\"!isMobile\" [attr.tabindex]=\"tabindex\" [ngClass]=\"{'slick-multi-select_show-selected-text': (keyboardActive || (selectedText && selectedText.length > 0)) }\" (keyup)=\"onKeyUp($event)\" (focus)=\"onFocus()\" ng-disabled='disabled' readonly [placeholder]='placeholder' />\r\n\t\t\t<input #selectedTextInputRef *ngIf=\"isMobile === true\" [ngClass]=\"{'slick-multi-select_show-selected-text': (keyboardActive || (selectedText && selectedText.length > 0)) }\" (keyup)=\"onKeyUp($event)\" (focus)=\"onFocus()\" />\r\n\t\t</div>\r\n\t\t<div *ngIf=\"disabled === false && isMobile === true\" class=\"slick-multi-select_mobile-container\">\r\n\t\t\t<i class=\"far fa-keyboard\" style=\"cursor: pointer\" (click)=\"onKeyboardIconClicked()\"></i>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<div *ngIf=\"disabled === true\" class='input-group'>\r\n\t\t<div *ngFor=\"let selectedItem of selectedItems\" class=\"slick-multi-select_selected-item card\">{{selectedItem.text}}</div>\r\n\t</div>\r\n\r\n\t<ul #multiSelectList id=\"slick-multi-select-list_{{uuid}}\" class='slick-multi-select-list-group dropdown-menu' [style.width]=\"listGroupWidth\" [style.visibility]=\"(expanded === true) ? 'visible' : 'hidden'\" [style.opacity]=\"(expanded === true) ? '1' : '0'\" [style.max-height]=\"height\" [style.width.px]=\"listGroupWidth\" [style.left.px]=\"left\" [style.top.px]=\"top\">\r\n\t\t<li *ngFor=\"let item of visibleItems; let index = index;\" (mouseover)=\"selectedIndex = index\" (click)=\"onItemClick(item)\" [class.card-header]=\"selectedIndex === index\" class=\"dropdown-item slick-multi-select_list-item\">{{item.text}}</li>\r\n\t</ul>\r\n</div>" }]
|
|
320
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.SlickMultiSelectService }, { type: i0.ElementRef }]; }, propDecorators: { placeholder: [{
|
|
321
|
+
type: Input
|
|
322
|
+
}], items: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], idFieldName: [{
|
|
325
|
+
type: Input
|
|
326
|
+
}], textFieldName: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], disabled: [{
|
|
329
|
+
type: Input
|
|
330
|
+
}], allowEmpty: [{
|
|
331
|
+
type: Input
|
|
332
|
+
}], width: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}], listWidth: [{
|
|
335
|
+
type: Input
|
|
336
|
+
}], height: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], showLoadingMessage: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], showDebug: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], tabindex: [{
|
|
343
|
+
type: Input
|
|
344
|
+
}], isMobile: [{
|
|
345
|
+
type: Input
|
|
346
|
+
}], onExpand: [{
|
|
347
|
+
type: Output
|
|
348
|
+
}], onCollapse: [{
|
|
349
|
+
type: Output
|
|
350
|
+
}], onSelect: [{
|
|
351
|
+
type: Output
|
|
352
|
+
}], containerDiv: [{
|
|
353
|
+
type: ViewChild,
|
|
354
|
+
args: ["containerDiv"]
|
|
355
|
+
}], multiSelectList: [{
|
|
356
|
+
type: ViewChild,
|
|
357
|
+
args: ["multiSelectList"]
|
|
358
|
+
}], selectedTextInputRef: [{
|
|
359
|
+
type: ViewChild,
|
|
360
|
+
args: ["selectedTextInputRef"]
|
|
361
|
+
}] } });
|
|
362
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-multi-select.component.js","sourceRoot":"","sources":["../../../../projects/components/src/slick-multi-select/slick-multi-select.component.ts","../../../../projects/components/src/slick-multi-select/slick-multi-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, NgZone, Input, Output, EventEmitter, ElementRef, AfterViewInit, OnDestroy, OnChanges, SimpleChanges, ViewChild, forwardRef } from \"@angular/core\";\r\nimport { SlickMultiSelectService } from \"./slick-multi-select.service\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { SlickSleepService } from \"../utils/slick-sleep.service\";\r\nimport { SlickUtilsService } from \"../utils/slick-utils.service\";\r\nimport { SlickInitService } from \"../utils/slick-init.service\";\r\n\r\n@Component({\r\n\tselector: 'slick-multi-select',\r\n\ttemplateUrl: 'slick-multi-select.component.html',\r\n\tproviders: [SlickMultiSelectService,\r\n\t\t{\r\n\t\t\tprovide: NG_VALUE_ACCESSOR,\r\n\t\t\tuseExisting: forwardRef(() => SlickMultiSelectComponent),\r\n\t\t\tmulti: true,\r\n\t\t}]\r\n})\r\nexport class SlickMultiSelectComponent implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor {\r\n\t@Input() placeholder: string = '';\r\n\t@Input() items: any[];\r\n\t@Input() idFieldName: string = \"id\";\r\n\t@Input() textFieldName: string = \"text\";\r\n\t@Input() disabled: boolean = false;\r\n\t@Input() allowEmpty: string = 'true';\r\n\t@Input() width: string = '100%';\r\n\t@Input() listWidth: string = '100%';\r\n\t@Input() height: string = '300px';\r\n\t@Input() showLoadingMessage: boolean = false;\r\n\t@Input() showDebug: boolean;\r\n\t@Input() tabindex: number;\r\n\t@Input() isMobile: boolean;\r\n\r\n\t@Output() onExpand: EventEmitter<void> = new EventEmitter<void>();\r\n\t@Output() onCollapse: EventEmitter<void> = new EventEmitter<void>();\r\n\t@Output() onSelect: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n\t@ViewChild(\"containerDiv\") containerDiv: ElementRef;\r\n\t@ViewChild(\"multiSelectList\") multiSelectList: ElementRef;\r\n\t@ViewChild(\"selectedTextInputRef\") selectedTextInputRef: ElementRef;\r\n\r\n\t// This is necessary so that the scroll and resize events can add and remove the event properly,\r\n\t// as well as getting the correct ES6 function\r\n\tprivate fnDocumentClick = (e) => this.documentClick(e);\r\n\r\n\tuuid: string;\r\n\tselectedIds: string[];\r\n\tselectedText: string;\r\n\tkeyboardActive: boolean = false;\r\n\texpanded: boolean = false;\r\n\tfilterText: string = '';\r\n\tselectedIndex: number;\r\n\tselectedItems: any[];\r\n\tvisibleItems: any[];\r\n\tleft: string;\r\n\ttop: string;\r\n\tlistGroupWidth: string;\r\n\tisAndroid: boolean = ((SlickInitService.getPlatform() || '').toLowerCase() === 'android');\r\n\r\n\tprivate skipClickExpand: boolean = false;\r\n\r\n\tconstructor(private ngZone: NgZone,\r\n\t\tprivate slickMultiSelectService: SlickMultiSelectService,\r\n\t\tprivate el: ElementRef) {\r\n\t\tthis.uuid = SlickUtilsService.newGuid();\r\n\t}\r\n\r\n\tasync ngAfterViewInit() {\r\n\t\t// Remove this from the inline version and put it on the body so that it doesn't hide behind the bottom\r\n\t\t// of a div when it expands beyond the bottom.\r\n\t\tthis.multiSelectList.nativeElement.remove(this.multiSelectList);\r\n\t\tdocument.body.appendChild(this.multiSelectList.nativeElement);\r\n\t}\r\n\r\n\tpropagateChange = (_: any) => { };\r\n\r\n\t// this is the initial value set to the component\r\n\tpublic writeValue(obj: any) {\r\n\t\tif (obj) \r\n\t\t\tthis.selectedIds = obj;\r\n\t\telse\r\n\t\t\tthis.selectedIds = null;\r\n\r\n\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\tthis.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t}\r\n\r\n\t// registers 'fn' that will be fired when changes are made\r\n\t// this is how we emit the changes back to the form\r\n\tpublic registerOnChange(fn: any) {\r\n\t\tthis.propagateChange = fn;\r\n\t}\r\n\r\n\t// not used, used for touch input\r\n\tpublic registerOnTouched() { }\r\n\r\n\tngOnChanges(changes: SimpleChanges) {\r\n\t\tif (changes.isMobile) {\r\n\t\t\tthis.isMobile = (this.isMobile.toString().toLowerCase() === 'true') ? true : false;\r\n\t\t}\r\n\t\tif (changes.items) {\r\n\t\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\t\tthis.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\t\tif (this.selectedTextInputRef && document.activeElement == this.selectedTextInputRef.nativeElement) \r\n\t\t\t\tthis.expand();\t\t\t\r\n\t\t}\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.collapse();\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\t\r\n\r\n\t\t// it's okay if this fails.  It was already removed\r\n\t\ttry {\r\n\t\t\tdocument.body.removeChild(this.multiSelectList.nativeElement);\r\n\t\t}\r\n\t\tcatch { }\r\n\r\n\t}\r\n\r\n\tasync onKeyboardIconClicked() {\r\n\t\tif (this.keyboardActive === true) {\r\n\t\t\tthis.collapse();\r\n\t\t\tthis.keyboardActive = false;\r\n\t\t\tthis.selectedText = '';\r\n\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = '';\r\n\t\t}\r\n\t\telse {\r\n\t\t\tthis.keyboardActive = true;\r\n\t\t\tawait SlickSleepService.sleep();\r\n\t\t\t(<HTMLElement>this.selectedTextInputRef.nativeElement).focus();\r\n\t\t}\r\n\t}\r\n\r\n\tasync expand() {\r\n\t\tif (this.disabled)\r\n\t\t\treturn;\r\n\r\n\t\tthis.reposition();\r\n\r\n\t\tawait SlickSleepService.sleep();\r\n\t\tthis.multiSelectList.nativeElement.style.display = \"inline-block\";\r\n\r\n\t\tlet selectedItems = this.multiSelectList.nativeElement.getElementsByClassName(\"selected\");\r\n\t\tif (selectedItems && selectedItems.length > 0) \r\n\t\t\t(<HTMLElement>selectedItems[0]).scrollIntoView({ block: 'nearest' });\t\t\r\n\r\n\t\tthis.expanded = true;\r\n\r\n\t\t// This is necessary, otherwise `this` in the reposition function will be window\r\n\t\t// and not the component.\r\n\t\t// Since angular has no way to use the third parameter, I'm doing this in raw js\r\n\t\tdocument.addEventListener(\"click\", this.fnDocumentClick, true);\t\t\t\r\n\r\n\t\tif (this.onExpand)\r\n\t\t\tthis.onExpand.emit();\r\n\t}\r\n\r\n\tcollapse() {\r\n        this.expanded = false;\r\n        this.multiSelectList.nativeElement.style.display = \"none\";\r\n\t\t// Since angular has no way to use the third parameter, I'm doing this in raw js\r\n\t\tdocument.removeEventListener(\"click\", this.fnDocumentClick, true);\t\r\n\r\n\t\tif (this.onCollapse) \r\n\t\t\tthis.onCollapse.emit();\r\n\t}\r\n\r\n\tasync reposition() {\r\n\t\tawait SlickSleepService.sleep();\r\n\t\tlet rect = this.containerDiv.nativeElement.getBoundingClientRect();\r\n\t\tlet containerLeft = rect.left;\r\n\t\tlet containerTop = rect.top;\r\n\t\tlet containerHeight = this.containerDiv.nativeElement.offsetHeight;\r\n\t\tlet containerWidth = rect.width;\r\n\r\n\t\tthis.width = containerWidth;\r\n\t\tif (this.listWidth === '100%')\r\n\t\t\tthis.listGroupWidth = this.width;\r\n\t\telse if (this.listWidth === 'auto')\r\n\t\t\tthis.listGroupWidth = \"auto\";\r\n\t\telse\r\n\t\t\tthis.listGroupWidth = this.listWidth;\r\n\t\tthis.top = (containerTop + containerHeight);\r\n\t\tthis.left = containerLeft;\r\n\t}\r\n\r\n\tprivate documentClick(e: MouseEvent) {\r\n\t\tif (!this.expanded || !e.target)\r\n\t\t\treturn;\r\n\t\t\r\n\t\t// If they clicked on the keyboard icon, don't do anything\r\n\t\tif (SlickUtilsService.checkParentClassExists(<HTMLElement>e.target, \"slick-multi-select_mobile-container\") && \r\n\t\t\tSlickUtilsService.checkParentIdExists(<HTMLElement>e.target, \"slick-multi-select_\" + this.uuid))\r\n\t\t\treturn;\r\n\t\t\r\n\t\tconst clickedInside = SlickUtilsService.checkParentClassExists(<HTMLElement>e.target, \"slick-multi-select_list-item\");\r\n\t\tif (!clickedInside) {\r\n\t\t\tthis.keyboardActive = false;\r\n\t\t\tthis.selectedText = '';\r\n\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = '';\r\n\t\t\tthis.collapse();\r\n\t\t}\r\n\t}\r\n\r\n\tprivate selectItem(id: string) {\r\n\t\tlet item = this.slickMultiSelectService.getSelectedItem(this.visibleItems, id);\r\n\t\t\r\n\t\tif (item) {\r\n\r\n\t\t\tif (this.onSelect)\r\n\t\t\t\tthis.onSelect.emit(item);\r\n\r\n\t\t\tif (!this.selectedIds)\r\n\t\t\t\tthis.selectedIds = [];\r\n\r\n\t\t\tthis.selectedIds.push(id);\r\n\t\t\tthis.propagateChange(this.selectedIds);\r\n\r\n\t\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\t\tthis.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\r\n\t\t\tthis.reposition();\r\n\t\t\tthis.selectedText = '';\r\n\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = '';\r\n\t\t}\r\n\t}\t\r\n\r\n\tsetFocus(showMobileKeyboard: boolean = false) {\r\n\t\t(<HTMLElement>this.selectedTextInputRef.nativeElement).focus();\r\n\t\tif (showMobileKeyboard === true)\r\n\t\t\tthis.keyboardActive = true;\r\n\t}\r\n\r\n\tasync onFocus() {\r\n\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\tthis.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\r\n\t\tthis.filterText = '';\r\n\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).focus();\r\n\r\n\t\t// This is kind of hacky, but if onFocus is called by clicking the multiSelect, the onMultiSelectClick event is called as well\r\n\t\t// That function will expand or collapse, depending on the state.  Since this expands, it thinks it needs to collapse.\r\n\t\t// So fake it out and tell it NOT to collapse.  BUT, if we came in from tabbing into the field, then it would mess up\r\n\t\t// the click event.  So only wait for 1/2 second.\r\n\t\tthis.skipClickExpand = true;\r\n\t\tthis.expand();\r\n\t\tawait SlickSleepService.sleep(500);\r\n\t\tthis.skipClickExpand = false;\r\n\t}\r\n\r\n\tasync onKeyUp(e: KeyboardEvent) {\r\n\t\te.stopPropagation();\r\n\t\te.preventDefault();\r\n\r\n\t\t// If this is android, it won't pass us any key data so just read the entire input element\r\n\t\tif (this.isAndroid === true) {\r\n\t\t\tawait SlickSleepService.sleep();\r\n\r\n\t\t\tthis.filterText = (<HTMLInputElement>this.selectedTextInputRef.nativeElement).value;\r\n\t\t\tthis.filterSearch();\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Tab/enter\r\n\t\tif (e.which === 9 || e.which === 13) {\r\n\r\n\t\t\tif (this.filterText && this.selectedIndex !== null && this.selectedIndex !== undefined) {\r\n\t\t\t\tthis.selectItem(this.visibleItems[this.selectedIndex].id);\r\n\t\t\t\tthis.filterText = '';\r\n\t\t\t\tthis.selectedIndex = null;\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\r\n\t\t\tthis.collapse();\r\n\r\n\t\t\tthis.filterText = '';\r\n\t\t\tthis.selectedText = '';\r\n\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = '';\r\n\t\t\tthis.selectedIndex = null;\r\n\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\t// Esc\r\n\t\tif (e.which === 27) {\r\n\t\t\tthis.filterText = '';\r\n\t\t\tthis.selectedText = '';\r\n\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = '';\r\n\t\t\tthis.collapse();\r\n\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// Backspace\r\n\t\tif (e.which === 8 && this.filterText) {\r\n\t\t\tthis.filterText = this.filterText.substring(0, this.filterText.length - 1);\r\n\t\t\tif (this.filterText.length === 0) {\r\n\t\t\t\tthis.selectedText = '';\r\n\t\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = '';\r\n\t\t\t\tthis.selectedIndex = null;\r\n\t\t\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\t\t\tthis.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\t\t\t}\r\n\t\t\telse\r\n\t\t\t\tthis.filterSearch();\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// Arrowup\r\n\t\tif (e.which === 38) {\r\n\t\t\tif (this.selectedIndex === null || this.selectedIndex === undefined)\r\n\t\t\t\tthis.selectedIndex = 0;\r\n\r\n\t\t\tif (this.selectedIndex > 0)\r\n\t\t\t\tthis.selectedIndex--;\r\n\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// Arrowdown\r\n\t\tif (e.which === 40) {\r\n\t\t\tif (this.selectedIndex === null || this.selectedIndex === undefined)\r\n\t\t\t\tthis.selectedIndex = -1;\r\n\r\n\t\t\tif (!this.expanded || !this.visibleItems) \r\n\t\t\t\tthis.expand();\r\n\r\n\t\t\tif (this.selectedIndex < this.visibleItems.length - 1)\r\n\t\t\t\tthis.selectedIndex++;\r\n\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// If F1 is pressed, key length will be 2\r\n\t\tif (e.key.length > 1 || e.ctrlKey || e.altKey)\r\n\t\t\treturn false;\r\n\r\n\t\tif (e.which >= 32 && e.which <= 126) {\r\n\t\t\tthis.filterText += e.key;\r\n\r\n\t\t\tthis.filterSearch();\r\n\t\t}\r\n\r\n\t\treturn true;\r\n\t}\r\n\r\n\tprivate async filterSearch() {\r\n\t\tif (!this.expanded) \r\n\t\t\tthis.expand();\t\r\n\r\n\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\tthis.visibleItems = this.visibleItems.filter(x => x.text.toLowerCase().indexOf(this.filterText.toLowerCase()) === 0);\r\n\t\tif (this.visibleItems.length > 0) {\r\n\t\t\tthis.selectedIndex = 0;\r\n\t\t\tthis.selectedText = this.visibleItems[0].text;\r\n\t\t\tif (this.isAndroid === false) {\r\n\t\t\t\tawait SlickSleepService.sleep();\r\n\t\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = this.selectedText;\r\n\t\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).setSelectionRange(this.filterText.length, this.selectedText.length);\r\n\t\t\t}\r\n\t\t}\r\n\t\telse {\r\n\t\t\tthis.selectedIndex = null;\r\n\t\t\tif (this.isAndroid === false) {\r\n\t\t\t\tthis.selectedText = this.filterText;\r\n\t\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).value = this.selectedText;\r\n\t\t\t}\r\n\r\n\t\t}\r\n\r\n\t\tthis.reposition();\r\n\t}\r\n\r\n\tonMultiSelectClicked() {\r\n\t\tif (this.skipClickExpand === true) {\r\n\t\t\tthis.skipClickExpand = false;\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).focus();\r\n\r\n\t\tif (this.expanded === false) \r\n\t\t\tthis.expand();\r\n\t\telse \r\n\t\t\tthis.collapse();\r\n\t}\r\n\r\n\tonItemClick(item: any) {\r\n\t\tthis.selectItem(item.id);\r\n\r\n\t\tif (this.keyboardActive === true)\r\n\t\t\t(<HTMLInputElement>this.selectedTextInputRef.nativeElement).focus();\r\n\t}\r\n\r\n\tonRemoveItem(item: any) {\r\n\t\tthis.selectedIds = this.selectedIds.filter(id => id !== item.id);\r\n\t\tthis.visibleItems = this.slickMultiSelectService.getVisibleItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\t\tthis.selectedItems = this.slickMultiSelectService.getSelectedItems(this.items, this.selectedIds, this.idFieldName, this.textFieldName);\r\n\r\n\t\tthis.propagateChange(this.selectedIds);\r\n\t}\r\n}","<div #containerDiv id=\"slick-multi-select_{{uuid}}\" attr.data-uuid=\"{{uuid}}\" class=\"slick-multi-select\" [class.mobile]=\"isMobile === true\" [class.open]=\"expanded\">\r\n\t<div class=\"slick-multi-select_input-container\">\r\n\t\t<div *ngIf=\"disabled === false\" style=\"cursor: pointer !important; flex-grow: 1;\" [ngClass]=\"{ 'slick-multi-select_mobile': isMobile === true }\" (click)=\"onMultiSelectClicked()\">\r\n\t\t\t<div *ngFor=\"let selectedItem of selectedItems\" class=\"slick-multi-select_selected-item card\"><div class=\"slick-multi-select_remove\" (click)=\"onRemoveItem(selectedItem)\"><i class=\"fas fa-times-circle bg-white text-danger\"></i></div>{{selectedItem.text}}</div>\r\n\t\t\t<input #selectedTextInputRef *ngIf=\"!isMobile\" [attr.tabindex]=\"tabindex\" [ngClass]=\"{'slick-multi-select_show-selected-text': (keyboardActive || (selectedText && selectedText.length > 0)) }\" (keyup)=\"onKeyUp($event)\" (focus)=\"onFocus()\" ng-disabled='disabled' readonly [placeholder]='placeholder' />\r\n\t\t\t<input #selectedTextInputRef *ngIf=\"isMobile === true\" [ngClass]=\"{'slick-multi-select_show-selected-text': (keyboardActive || (selectedText && selectedText.length > 0)) }\" (keyup)=\"onKeyUp($event)\" (focus)=\"onFocus()\" />\r\n\t\t</div>\r\n\t\t<div *ngIf=\"disabled === false && isMobile === true\" class=\"slick-multi-select_mobile-container\">\r\n\t\t\t<i class=\"far fa-keyboard\" style=\"cursor: pointer\" (click)=\"onKeyboardIconClicked()\"></i>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<div *ngIf=\"disabled === true\" class='input-group'>\r\n\t\t<div *ngFor=\"let selectedItem of selectedItems\" class=\"slick-multi-select_selected-item card\">{{selectedItem.text}}</div>\r\n\t</div>\r\n\r\n\t<ul #multiSelectList id=\"slick-multi-select-list_{{uuid}}\" class='slick-multi-select-list-group dropdown-menu' [style.width]=\"listGroupWidth\" [style.visibility]=\"(expanded === true) ? 'visible' : 'hidden'\" [style.opacity]=\"(expanded === true) ? '1' : '0'\" [style.max-height]=\"height\" [style.width.px]=\"listGroupWidth\" [style.left.px]=\"left\" [style.top.px]=\"top\">\r\n\t\t<li *ngFor=\"let item of visibleItems; let index = index;\" (mouseover)=\"selectedIndex = index\" (click)=\"onItemClick(item)\" [class.card-header]=\"selectedIndex === index\" class=\"dropdown-item slick-multi-select_list-item\">{{item.text}}</li>\r\n\t</ul>\r\n</div>"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { FormsModule } from "@angular/forms";
|
|
3
|
+
import { CommonModule } from "@angular/common";
|
|
4
|
+
import { SlickMultiSelectComponent } from "./slick-multi-select.component";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class SlickMultiSelectModule {
|
|
7
|
+
}
|
|
8
|
+
/** @nocollapse */ SlickMultiSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickMultiSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
+
/** @nocollapse */ SlickMultiSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickMultiSelectModule, declarations: [SlickMultiSelectComponent], imports: [CommonModule, FormsModule], exports: [SlickMultiSelectComponent] });
|
|
10
|
+
/** @nocollapse */ SlickMultiSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickMultiSelectModule, imports: [[CommonModule, FormsModule]] });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SlickMultiSelectModule, decorators: [{
|
|
12
|
+
type: NgModule,
|
|
13
|
+
args: [{
|
|
14
|
+
imports: [CommonModule, FormsModule],
|
|
15
|
+
declarations: [SlickMultiSelectComponent],
|
|
16
|
+
exports: [SlickMultiSelectComponent]
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
export { SlickMultiSelectComponent };
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpY2stbXVsdGktc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL3NsaWNrLW11bHRpLXNlbGVjdC9zbGljay1tdWx0aS1zZWxlY3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFRM0UsTUFBTSxPQUFPLHNCQUFzQjs7c0lBQXRCLHNCQUFzQjt1SUFBdEIsc0JBQXNCLGlCQUhuQix5QkFBeUIsYUFEOUIsWUFBWSxFQUFFLFdBQVcsYUFFekIseUJBQXlCO3VJQUV2QixzQkFBc0IsWUFKekIsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDOzJGQUl4QixzQkFBc0I7a0JBTGxDLFFBQVE7bUJBQUM7b0JBQ1QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztvQkFDcEMsWUFBWSxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ3pDLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUNwQzs7QUFHRCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBTbGlja011bHRpU2VsZWN0Q29tcG9uZW50IH0gZnJvbSBcIi4vc2xpY2stbXVsdGktc2VsZWN0LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBTbGlja011bHRpU2VsZWN0U2VydmljZSB9IGZyb20gXCIuL3NsaWNrLW11bHRpLXNlbGVjdC5zZXJ2aWNlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG5cdGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEZvcm1zTW9kdWxlXSxcclxuXHRkZWNsYXJhdGlvbnM6IFtTbGlja011bHRpU2VsZWN0Q29tcG9uZW50XSxcclxuXHRleHBvcnRzOiBbU2xpY2tNdWx0aVNlbGVjdENvbXBvbmVudF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNsaWNrTXVsdGlTZWxlY3RNb2R1bGUgeyB9XHJcblxyXG5leHBvcnQgeyBTbGlja011bHRpU2VsZWN0Q29tcG9uZW50IH0iXX0=
|