@ngstarter-ui/components 1.0.21
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/README.md +0 -0
- package/fesm2022/ngstarter-ui-components-action-required.mjs +42 -0
- package/fesm2022/ngstarter-ui-components-action-required.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-alert.mjs +132 -0
- package/fesm2022/ngstarter-ui-components-alert.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-announcement.mjs +86 -0
- package/fesm2022/ngstarter-ui-components-announcement.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-autocomplete.mjs +360 -0
- package/fesm2022/ngstarter-ui-components-autocomplete.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-avatar.mjs +235 -0
- package/fesm2022/ngstarter-ui-components-avatar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-badge.mjs +97 -0
- package/fesm2022/ngstarter-ui-components-badge.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-block-loader.mjs +48 -0
- package/fesm2022/ngstarter-ui-components-block-loader.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-bottom-sheet.mjs +327 -0
- package/fesm2022/ngstarter-ui-components-bottom-sheet.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-breadcrumbs.mjs +209 -0
- package/fesm2022/ngstarter-ui-components-breadcrumbs.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-button-toggle.mjs +175 -0
- package/fesm2022/ngstarter-ui-components-button-toggle.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-button.mjs +70 -0
- package/fesm2022/ngstarter-ui-components-button.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-card-overlay.mjs +49 -0
- package/fesm2022/ngstarter-ui-components-card-overlay.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-card.mjs +199 -0
- package/fesm2022/ngstarter-ui-components-card.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-carousel.mjs +614 -0
- package/fesm2022/ngstarter-ui-components-carousel.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-checkbox.mjs +300 -0
- package/fesm2022/ngstarter-ui-components-checkbox.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-chips.mjs +589 -0
- package/fesm2022/ngstarter-ui-components-chips.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-code-highlighter.mjs +347 -0
- package/fesm2022/ngstarter-ui-components-code-highlighter.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-color-picker.mjs +713 -0
- package/fesm2022/ngstarter-ui-components-color-picker.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-color-scheme.mjs +106 -0
- package/fesm2022/ngstarter-ui-components-color-scheme.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-color-switcher.mjs +72 -0
- package/fesm2022/ngstarter-ui-components-color-switcher.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-command-bar.mjs +57 -0
- package/fesm2022/ngstarter-ui-components-command-bar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-comment-editor.mjs +1024 -0
- package/fesm2022/ngstarter-ui-components-comment-editor.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-comparison-slider.mjs +177 -0
- package/fesm2022/ngstarter-ui-components-comparison-slider.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-confirm.mjs +85 -0
- package/fesm2022/ngstarter-ui-components-confirm.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-code-block.component-Bk6QTli8.mjs +173 -0
- package/fesm2022/ngstarter-ui-components-content-editor-code-block.component-Bk6QTli8.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-content-editor-content-editable.directive-Bvfa2dqh.mjs +124 -0
- package/fesm2022/ngstarter-ui-components-content-editor-content-editor-content-editable.directive-Bvfa2dqh.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-cursor-controller-4Ak8VqGX.mjs +99 -0
- package/fesm2022/ngstarter-ui-components-content-editor-cursor-controller-4Ak8VqGX.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs +33 -0
- package/fesm2022/ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-embed-block-BbkC_t86.mjs +354 -0
- package/fesm2022/ngstarter-ui-components-content-editor-embed-block-BbkC_t86.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-heading-block.component-D9_CxTY1.mjs +114 -0
- package/fesm2022/ngstarter-ui-components-content-editor-heading-block.component-D9_CxTY1.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-image-block.component-B4zJyUg1.mjs +146 -0
- package/fesm2022/ngstarter-ui-components-content-editor-image-block.component-B4zJyUg1.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-list-block.component-Cv6wx5Xe.mjs +215 -0
- package/fesm2022/ngstarter-ui-components-content-editor-list-block.component-Cv6wx5Xe.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-ngstarter-ui-components-content-editor-1Zi2nAX5.mjs +2548 -0
- package/fesm2022/ngstarter-ui-components-content-editor-ngstarter-ui-components-content-editor-1Zi2nAX5.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-paragraph-block.component-C9bQvDYU.mjs +110 -0
- package/fesm2022/ngstarter-ui-components-content-editor-paragraph-block.component-C9bQvDYU.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-quote-block.component-BbHds2r2.mjs +141 -0
- package/fesm2022/ngstarter-ui-components-content-editor-quote-block.component-BbHds2r2.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-table-block.component-DlDh7Fnn.mjs +1604 -0
- package/fesm2022/ngstarter-ui-components-content-editor-table-block.component-DlDh7Fnn.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor-video-block.component-m4DTihP2.mjs +175 -0
- package/fesm2022/ngstarter-ui-components-content-editor-video-block.component-m4DTihP2.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-editor.mjs +2 -0
- package/fesm2022/ngstarter-ui-components-content-editor.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-content-fade.mjs +35 -0
- package/fesm2022/ngstarter-ui-components-content-fade.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-cookie-popup.mjs +107 -0
- package/fesm2022/ngstarter-ui-components-cookie-popup.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-core.mjs +1330 -0
- package/fesm2022/ngstarter-ui-components-core.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-country-select.mjs +489 -0
- package/fesm2022/ngstarter-ui-components-country-select.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-crop.mjs +183 -0
- package/fesm2022/ngstarter-ui-components-crop.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-currency-select.mjs +397 -0
- package/fesm2022/ngstarter-ui-components-currency-select.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-data-view.mjs +1494 -0
- package/fesm2022/ngstarter-ui-components-data-view.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-date-format-select.mjs +154 -0
- package/fesm2022/ngstarter-ui-components-date-format-select.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-datepicker.mjs +1159 -0
- package/fesm2022/ngstarter-ui-components-datepicker.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-dialog.mjs +357 -0
- package/fesm2022/ngstarter-ui-components-dialog.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-divider.mjs +42 -0
- package/fesm2022/ngstarter-ui-components-divider.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-drawer.mjs +132 -0
- package/fesm2022/ngstarter-ui-components-drawer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-emoji-picker.mjs +245 -0
- package/fesm2022/ngstarter-ui-components-emoji-picker.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-empty-state.mjs +75 -0
- package/fesm2022/ngstarter-ui-components-empty-state.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-expand.mjs +56 -0
- package/fesm2022/ngstarter-ui-components-expand.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-expansion.mjs +193 -0
- package/fesm2022/ngstarter-ui-components-expansion.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-filter-builder.mjs +333 -0
- package/fesm2022/ngstarter-ui-components-filter-builder.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-field.mjs +230 -0
- package/fesm2022/ngstarter-ui-components-form-field.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-autocomplete-many-field-BKQVlZHV.mjs +124 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-autocomplete-many-field-BKQVlZHV.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-checkbox-field-CoyKdvhV.mjs +22 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-checkbox-field-CoyKdvhV.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-datepicker-field-Bzc0TPO9.mjs +44 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-datepicker-field-Bzc0TPO9.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-divider-content-CwGzDCZv.mjs +17 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-divider-content-CwGzDCZv.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-image-content-ICTwkZPa.mjs +17 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-image-content-ICTwkZPa.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-input-field-RYxi-Mpw.mjs +35 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-input-field-RYxi-Mpw.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-radio-group-field-Cv3AGpoq.mjs +38 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-radio-group-field-Cv3AGpoq.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-select-field-eLcwI-BY.mjs +39 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-select-field-eLcwI-BY.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-text-content-BjzH_M3-.mjs +24 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-text-content-BjzH_M3-.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-textarea-field-4zH7FTQ1.mjs +37 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-textarea-field-4zH7FTQ1.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-timezone-field-BpH65Hd-.mjs +35 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-timezone-field-BpH65Hd-.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-toggle-field-iyqUrWxt.mjs +22 -0
- package/fesm2022/ngstarter-ui-components-form-renderer-toggle-field-iyqUrWxt.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-form-renderer.mjs +317 -0
- package/fesm2022/ngstarter-ui-components-form-renderer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-gauge.mjs +44 -0
- package/fesm2022/ngstarter-ui-components-gauge.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-grid.mjs +78 -0
- package/fesm2022/ngstarter-ui-components-grid.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-guided-tour.mjs +736 -0
- package/fesm2022/ngstarter-ui-components-guided-tour.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-headless-stepper.mjs +192 -0
- package/fesm2022/ngstarter-ui-components-headless-stepper.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-icon.mjs +61 -0
- package/fesm2022/ngstarter-ui-components-icon.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-image-designer.mjs +4016 -0
- package/fesm2022/ngstarter-ui-components-image-designer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-image-placeholder.mjs +20 -0
- package/fesm2022/ngstarter-ui-components-image-placeholder.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-image-resizer.mjs +151 -0
- package/fesm2022/ngstarter-ui-components-image-resizer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-image-viewer.mjs +349 -0
- package/fesm2022/ngstarter-ui-components-image-viewer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-image-zoom-viewer.mjs +162 -0
- package/fesm2022/ngstarter-ui-components-image-zoom-viewer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-incidents.mjs +257 -0
- package/fesm2022/ngstarter-ui-components-incidents.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-inline-text-edit.mjs +179 -0
- package/fesm2022/ngstarter-ui-components-inline-text-edit.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-input-mask.mjs +180 -0
- package/fesm2022/ngstarter-ui-components-input-mask.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-input-validator.mjs +24 -0
- package/fesm2022/ngstarter-ui-components-input-validator.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-input.mjs +152 -0
- package/fesm2022/ngstarter-ui-components-input.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-kanban-board.mjs +156 -0
- package/fesm2022/ngstarter-ui-components-kanban-board.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-kbd.mjs +31 -0
- package/fesm2022/ngstarter-ui-components-kbd.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-layout.mjs +199 -0
- package/fesm2022/ngstarter-ui-components-layout.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-list.mjs +279 -0
- package/fesm2022/ngstarter-ui-components-list.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-logo.mjs +51 -0
- package/fesm2022/ngstarter-ui-components-logo.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-marquee.mjs +76 -0
- package/fesm2022/ngstarter-ui-components-marquee.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-menu.mjs +851 -0
- package/fesm2022/ngstarter-ui-components-menu.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-micro-chart.mjs +928 -0
- package/fesm2022/ngstarter-ui-components-micro-chart.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-navigation.mjs +439 -0
- package/fesm2022/ngstarter-ui-components-navigation.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-notifications.mjs +181 -0
- package/fesm2022/ngstarter-ui-components-notifications.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-number-input.mjs +293 -0
- package/fesm2022/ngstarter-ui-components-number-input.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-option.mjs +157 -0
- package/fesm2022/ngstarter-ui-components-option.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-overlay.mjs +112 -0
- package/fesm2022/ngstarter-ui-components-overlay.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-page-loading-bar.mjs +77 -0
- package/fesm2022/ngstarter-ui-components-page-loading-bar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-paginator.mjs +297 -0
- package/fesm2022/ngstarter-ui-components-paginator.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-panel.mjs +123 -0
- package/fesm2022/ngstarter-ui-components-panel.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-password-strength.mjs +335 -0
- package/fesm2022/ngstarter-ui-components-password-strength.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-phone-input.mjs +651 -0
- package/fesm2022/ngstarter-ui-components-phone-input.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-pin-input.mjs +193 -0
- package/fesm2022/ngstarter-ui-components-pin-input.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-popover.mjs +302 -0
- package/fesm2022/ngstarter-ui-components-popover.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-progress-bar.mjs +68 -0
- package/fesm2022/ngstarter-ui-components-progress-bar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-radio-card.mjs +102 -0
- package/fesm2022/ngstarter-ui-components-radio-card.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-radio.mjs +147 -0
- package/fesm2022/ngstarter-ui-components-radio.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-rail-nav.mjs +87 -0
- package/fesm2022/ngstarter-ui-components-rail-nav.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-resizable-container.mjs +74 -0
- package/fesm2022/ngstarter-ui-components-resizable-container.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-screen-loader.mjs +95 -0
- package/fesm2022/ngstarter-ui-components-screen-loader.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-scroll-spy.mjs +219 -0
- package/fesm2022/ngstarter-ui-components-scroll-spy.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-scrollbar-area.mjs +459 -0
- package/fesm2022/ngstarter-ui-components-scrollbar-area.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-segmented.mjs +218 -0
- package/fesm2022/ngstarter-ui-components-segmented.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-select.mjs +496 -0
- package/fesm2022/ngstarter-ui-components-select.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-side-panel.mjs +107 -0
- package/fesm2022/ngstarter-ui-components-side-panel.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-sidebar.mjs +435 -0
- package/fesm2022/ngstarter-ui-components-sidebar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-sidenav.mjs +354 -0
- package/fesm2022/ngstarter-ui-components-sidenav.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-signature-pad.mjs +452 -0
- package/fesm2022/ngstarter-ui-components-signature-pad.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-skeleton.mjs +22 -0
- package/fesm2022/ngstarter-ui-components-skeleton.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-slide-toggle.mjs +93 -0
- package/fesm2022/ngstarter-ui-components-slide-toggle.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-slider.mjs +481 -0
- package/fesm2022/ngstarter-ui-components-slider.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-snack-bar.mjs +354 -0
- package/fesm2022/ngstarter-ui-components-snack-bar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-sort.mjs +140 -0
- package/fesm2022/ngstarter-ui-components-sort.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-spinner.mjs +75 -0
- package/fesm2022/ngstarter-ui-components-spinner.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-splash-screen.mjs +93 -0
- package/fesm2022/ngstarter-ui-components-splash-screen.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-split.mjs +948 -0
- package/fesm2022/ngstarter-ui-components-split.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-stepper.mjs +103 -0
- package/fesm2022/ngstarter-ui-components-stepper.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-suggestions.mjs +72 -0
- package/fesm2022/ngstarter-ui-components-suggestions.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-tab-panel.mjs +265 -0
- package/fesm2022/ngstarter-ui-components-tab-panel.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-table.mjs +648 -0
- package/fesm2022/ngstarter-ui-components-table.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-tabs.mjs +591 -0
- package/fesm2022/ngstarter-ui-components-tabs.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-text-editor.mjs +1012 -0
- package/fesm2022/ngstarter-ui-components-text-editor.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-thumbnail-maker.mjs +212 -0
- package/fesm2022/ngstarter-ui-components-thumbnail-maker.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-tiles.mjs +634 -0
- package/fesm2022/ngstarter-ui-components-tiles.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-timeline.mjs +122 -0
- package/fesm2022/ngstarter-ui-components-timeline.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-timepicker.mjs +486 -0
- package/fesm2022/ngstarter-ui-components-timepicker.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-timezone-select.mjs +371 -0
- package/fesm2022/ngstarter-ui-components-timezone-select.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-toolbar.mjs +299 -0
- package/fesm2022/ngstarter-ui-components-toolbar.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-tooltip.mjs +506 -0
- package/fesm2022/ngstarter-ui-components-tooltip.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-tree.mjs +200 -0
- package/fesm2022/ngstarter-ui-components-tree.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-upload.mjs +330 -0
- package/fesm2022/ngstarter-ui-components-upload.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-video-player.mjs +516 -0
- package/fesm2022/ngstarter-ui-components-video-player.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-video-viewer.mjs +218 -0
- package/fesm2022/ngstarter-ui-components-video-viewer.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components-visual-builder.mjs +18 -0
- package/fesm2022/ngstarter-ui-components-visual-builder.mjs.map +1 -0
- package/fesm2022/ngstarter-ui-components.mjs +6 -0
- package/fesm2022/ngstarter-ui-components.mjs.map +1 -0
- package/package.json +535 -0
- package/styles/_common.scss +456 -0
- package/styles/_global.scss +91 -0
- package/styles/themes/default.scss +2 -0
- package/types/ngstarter-ui-components-action-required.d.ts +14 -0
- package/types/ngstarter-ui-components-alert.d.ts +50 -0
- package/types/ngstarter-ui-components-announcement.d.ts +59 -0
- package/types/ngstarter-ui-components-autocomplete.d.ts +83 -0
- package/types/ngstarter-ui-components-avatar.d.ts +69 -0
- package/types/ngstarter-ui-components-badge.d.ts +38 -0
- package/types/ngstarter-ui-components-block-loader.d.ts +21 -0
- package/types/ngstarter-ui-components-bottom-sheet.d.ts +149 -0
- package/types/ngstarter-ui-components-breadcrumbs.d.ts +104 -0
- package/types/ngstarter-ui-components-button-toggle.d.ts +54 -0
- package/types/ngstarter-ui-components-button.d.ts +27 -0
- package/types/ngstarter-ui-components-card-overlay.d.ts +20 -0
- package/types/ngstarter-ui-components-card.d.ts +85 -0
- package/types/ngstarter-ui-components-carousel.d.ts +76 -0
- package/types/ngstarter-ui-components-checkbox.d.ts +94 -0
- package/types/ngstarter-ui-components-chips.d.ts +189 -0
- package/types/ngstarter-ui-components-code-highlighter.d.ts +28 -0
- package/types/ngstarter-ui-components-color-picker.d.ts +92 -0
- package/types/ngstarter-ui-components-color-scheme.d.ts +44 -0
- package/types/ngstarter-ui-components-color-switcher.d.ts +26 -0
- package/types/ngstarter-ui-components-command-bar.d.ts +28 -0
- package/types/ngstarter-ui-components-comment-editor.d.ts +194 -0
- package/types/ngstarter-ui-components-comparison-slider.d.ts +42 -0
- package/types/ngstarter-ui-components-confirm.d.ts +34 -0
- package/types/ngstarter-ui-components-content-editor.d.ts +321 -0
- package/types/ngstarter-ui-components-content-fade.d.ts +17 -0
- package/types/ngstarter-ui-components-cookie-popup.d.ts +41 -0
- package/types/ngstarter-ui-components-core.d.ts +421 -0
- package/types/ngstarter-ui-components-country-select.d.ts +78 -0
- package/types/ngstarter-ui-components-crop.d.ts +59 -0
- package/types/ngstarter-ui-components-currency-select.d.ts +82 -0
- package/types/ngstarter-ui-components-data-view.d.ts +391 -0
- package/types/ngstarter-ui-components-date-format-select.d.ts +59 -0
- package/types/ngstarter-ui-components-datepicker.d.ts +384 -0
- package/types/ngstarter-ui-components-dialog.d.ts +115 -0
- package/types/ngstarter-ui-components-divider.d.ts +18 -0
- package/types/ngstarter-ui-components-drawer.d.ts +32 -0
- package/types/ngstarter-ui-components-emoji-picker.d.ts +49 -0
- package/types/ngstarter-ui-components-empty-state.d.ts +33 -0
- package/types/ngstarter-ui-components-expand.d.ts +26 -0
- package/types/ngstarter-ui-components-expansion.d.ts +68 -0
- package/types/ngstarter-ui-components-filter-builder.d.ts +106 -0
- package/types/ngstarter-ui-components-form-field.d.ts +107 -0
- package/types/ngstarter-ui-components-form-renderer.d.ts +121 -0
- package/types/ngstarter-ui-components-gauge.d.ts +21 -0
- package/types/ngstarter-ui-components-grid.d.ts +45 -0
- package/types/ngstarter-ui-components-guided-tour.d.ts +227 -0
- package/types/ngstarter-ui-components-headless-stepper.d.ts +65 -0
- package/types/ngstarter-ui-components-icon.d.ts +17 -0
- package/types/ngstarter-ui-components-image-designer.d.ts +357 -0
- package/types/ngstarter-ui-components-image-placeholder.d.ts +8 -0
- package/types/ngstarter-ui-components-image-resizer.d.ts +35 -0
- package/types/ngstarter-ui-components-image-viewer.d.ts +63 -0
- package/types/ngstarter-ui-components-image-zoom-viewer.d.ts +34 -0
- package/types/ngstarter-ui-components-incidents.d.ts +119 -0
- package/types/ngstarter-ui-components-inline-text-edit.d.ts +39 -0
- package/types/ngstarter-ui-components-input-mask.d.ts +36 -0
- package/types/ngstarter-ui-components-input-validator.d.ts +5 -0
- package/types/ngstarter-ui-components-input.d.ts +53 -0
- package/types/ngstarter-ui-components-kanban-board.d.ts +68 -0
- package/types/ngstarter-ui-components-kbd.d.ts +13 -0
- package/types/ngstarter-ui-components-layout.d.ts +83 -0
- package/types/ngstarter-ui-components-list.d.ts +98 -0
- package/types/ngstarter-ui-components-logo.d.ts +26 -0
- package/types/ngstarter-ui-components-marquee.d.ts +27 -0
- package/types/ngstarter-ui-components-menu.d.ts +199 -0
- package/types/ngstarter-ui-components-micro-chart.d.ts +195 -0
- package/types/ngstarter-ui-components-navigation.d.ts +136 -0
- package/types/ngstarter-ui-components-notifications.d.ts +84 -0
- package/types/ngstarter-ui-components-number-input.d.ts +99 -0
- package/types/ngstarter-ui-components-option.d.ts +61 -0
- package/types/ngstarter-ui-components-overlay.d.ts +12 -0
- package/types/ngstarter-ui-components-page-loading-bar.d.ts +20 -0
- package/types/ngstarter-ui-components-paginator.d.ts +145 -0
- package/types/ngstarter-ui-components-panel.d.ts +59 -0
- package/types/ngstarter-ui-components-password-strength.d.ts +109 -0
- package/types/ngstarter-ui-components-phone-input.d.ts +103 -0
- package/types/ngstarter-ui-components-pin-input.d.ts +48 -0
- package/types/ngstarter-ui-components-popover.d.ts +94 -0
- package/types/ngstarter-ui-components-progress-bar.d.ts +30 -0
- package/types/ngstarter-ui-components-radio-card.d.ts +37 -0
- package/types/ngstarter-ui-components-radio.d.ts +45 -0
- package/types/ngstarter-ui-components-rail-nav.d.ts +36 -0
- package/types/ngstarter-ui-components-resizable-container.d.ts +25 -0
- package/types/ngstarter-ui-components-screen-loader.d.ts +34 -0
- package/types/ngstarter-ui-components-scroll-spy.d.ts +63 -0
- package/types/ngstarter-ui-components-scrollbar-area.d.ts +67 -0
- package/types/ngstarter-ui-components-segmented.d.ts +65 -0
- package/types/ngstarter-ui-components-select.d.ts +126 -0
- package/types/ngstarter-ui-components-side-panel.d.ts +42 -0
- package/types/ngstarter-ui-components-sidebar.d.ts +143 -0
- package/types/ngstarter-ui-components-sidenav.d.ts +86 -0
- package/types/ngstarter-ui-components-signature-pad.d.ts +49 -0
- package/types/ngstarter-ui-components-skeleton.d.ts +9 -0
- package/types/ngstarter-ui-components-slide-toggle.d.ts +41 -0
- package/types/ngstarter-ui-components-slider.d.ts +85 -0
- package/types/ngstarter-ui-components-snack-bar.d.ts +142 -0
- package/types/ngstarter-ui-components-sort.d.ts +66 -0
- package/types/ngstarter-ui-components-spinner.d.ts +28 -0
- package/types/ngstarter-ui-components-splash-screen.d.ts +31 -0
- package/types/ngstarter-ui-components-split.d.ts +210 -0
- package/types/ngstarter-ui-components-stepper.d.ts +44 -0
- package/types/ngstarter-ui-components-suggestions.d.ts +32 -0
- package/types/ngstarter-ui-components-tab-panel.d.ts +96 -0
- package/types/ngstarter-ui-components-table.d.ts +277 -0
- package/types/ngstarter-ui-components-tabs.d.ts +145 -0
- package/types/ngstarter-ui-components-text-editor.d.ts +191 -0
- package/types/ngstarter-ui-components-thumbnail-maker.d.ts +35 -0
- package/types/ngstarter-ui-components-tiles.d.ts +109 -0
- package/types/ngstarter-ui-components-timeline.d.ts +57 -0
- package/types/ngstarter-ui-components-timepicker.d.ts +115 -0
- package/types/ngstarter-ui-components-timezone-select.d.ts +75 -0
- package/types/ngstarter-ui-components-toolbar.d.ts +74 -0
- package/types/ngstarter-ui-components-tooltip.d.ts +52 -0
- package/types/ngstarter-ui-components-tree.d.ts +60 -0
- package/types/ngstarter-ui-components-upload.d.ts +134 -0
- package/types/ngstarter-ui-components-video-player.d.ts +67 -0
- package/types/ngstarter-ui-components-video-viewer.d.ts +98 -0
- package/types/ngstarter-ui-components-visual-builder.d.ts +8 -0
- package/types/ngstarter-ui-components.d.ts +2 -0
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { inject, DestroyRef, viewChild, input, signal, forwardRef, ChangeDetectionStrategy, Component } from '@angular/core';
|
|
3
|
+
import { C as ContentBuilderStore, a as CONTENT_BUILDER, b as CONTENT_EDITOR_BLOCK } from './ngstarter-ui-components-content-editor-ngstarter-ui-components-content-editor-1Zi2nAX5.mjs';
|
|
4
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
|
+
import { EditorView, keymap } from '@codemirror/view';
|
|
6
|
+
import { basicSetup } from 'codemirror';
|
|
7
|
+
import { Compartment } from '@codemirror/state';
|
|
8
|
+
import { Menu, MenuItem, MenuTrigger } from '@ngstarter-ui/components/menu';
|
|
9
|
+
import { Button } from '@ngstarter-ui/components/button';
|
|
10
|
+
import { githubLight } from '@uiw/codemirror-theme-github';
|
|
11
|
+
import { indentWithTab } from '@codemirror/commands';
|
|
12
|
+
import { DOCUMENT } from '@angular/common';
|
|
13
|
+
|
|
14
|
+
class CodeBlockComponent {
|
|
15
|
+
_store = inject(ContentBuilderStore);
|
|
16
|
+
_contentBuilder = inject(CONTENT_BUILDER);
|
|
17
|
+
_destroyRef = inject(DestroyRef);
|
|
18
|
+
document = inject(DOCUMENT);
|
|
19
|
+
_contentRef = viewChild.required('contentRef');
|
|
20
|
+
id = input.required(...(ngDevMode ? [{ debugName: "id" }] : /* istanbul ignore next */ []));
|
|
21
|
+
content = input.required(...(ngDevMode ? [{ debugName: "content" }] : /* istanbul ignore next */ []));
|
|
22
|
+
settings = input.required(...(ngDevMode ? [{ debugName: "settings" }] : /* istanbul ignore next */ []));
|
|
23
|
+
index = input.required(...(ngDevMode ? [{ debugName: "index" }] : /* istanbul ignore next */ []));
|
|
24
|
+
placeholder = input('Write your code here', ...(ngDevMode ? [{ debugName: "placeholder" }] : /* istanbul ignore next */ []));
|
|
25
|
+
_languageList = signal([
|
|
26
|
+
{
|
|
27
|
+
language: 'none',
|
|
28
|
+
name: 'None',
|
|
29
|
+
library: () => new Promise(() => { })
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
language: 'angular',
|
|
33
|
+
name: 'Angular',
|
|
34
|
+
library: () => import('@codemirror/lang-angular').then(lang => lang.angular())
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
language: 'javascript',
|
|
38
|
+
name: 'JavaScript',
|
|
39
|
+
library: () => import('@codemirror/lang-javascript').then(lang => lang.javascript())
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
language: 'typescript',
|
|
43
|
+
name: 'TypeScript',
|
|
44
|
+
library: () => import('@codemirror/lang-javascript').then(lang => lang.javascript({ typescript: true }))
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
language: 'html',
|
|
48
|
+
name: 'HTML',
|
|
49
|
+
library: () => import('@codemirror/lang-html').then(lang => lang.html())
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
language: 'css',
|
|
53
|
+
name: 'CSS',
|
|
54
|
+
library: () => import('@codemirror/lang-css').then(lang => lang.css())
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
language: 'sass',
|
|
58
|
+
name: 'Sass',
|
|
59
|
+
library: () => import('@codemirror/lang-sass').then(lang => lang.sass())
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
language: 'json',
|
|
63
|
+
name: 'JSON',
|
|
64
|
+
library: () => import('@codemirror/lang-json').then(lang => lang.json())
|
|
65
|
+
}
|
|
66
|
+
], ...(ngDevMode ? [{ debugName: "_languageList" }] : /* istanbul ignore next */ []));
|
|
67
|
+
_code = signal('', ...(ngDevMode ? [{ debugName: "_code" }] : /* istanbul ignore next */ []));
|
|
68
|
+
_language = signal(this._languageList()[0], ...(ngDevMode ? [{ debugName: "_language" }] : /* istanbul ignore next */ []));
|
|
69
|
+
_isEmpty = signal(true, ...(ngDevMode ? [{ debugName: "_isEmpty" }] : /* istanbul ignore next */ []));
|
|
70
|
+
_editorView;
|
|
71
|
+
_editorLanguage = new Compartment();
|
|
72
|
+
initialized = signal(false, ...(ngDevMode ? [{ debugName: "initialized" }] : /* istanbul ignore next */ []));
|
|
73
|
+
async ngOnInit() {
|
|
74
|
+
const codeLanguage = this._languageList().find(codeLanguage => codeLanguage.language === this.settings().language);
|
|
75
|
+
if (codeLanguage) {
|
|
76
|
+
this._language.set(codeLanguage);
|
|
77
|
+
}
|
|
78
|
+
this._code.set(this.content() || '');
|
|
79
|
+
this._isEmpty.set(this._code().trim().length === 0);
|
|
80
|
+
this._contentBuilder
|
|
81
|
+
.focusChanged
|
|
82
|
+
.pipe(takeUntilDestroyed(this._destroyRef))
|
|
83
|
+
.subscribe(() => {
|
|
84
|
+
if (this._store.focusedBlockId() === this.id()) {
|
|
85
|
+
this.focus();
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
this._editorView = new EditorView({
|
|
89
|
+
doc: this._code(),
|
|
90
|
+
parent: this._contentRef().nativeElement,
|
|
91
|
+
extensions: [
|
|
92
|
+
basicSetup,
|
|
93
|
+
githubLight,
|
|
94
|
+
keymap.of([indentWithTab]),
|
|
95
|
+
this._editorLanguage.of([]),
|
|
96
|
+
EditorView.updateListener.of((v) => {
|
|
97
|
+
if (v.docChanged) {
|
|
98
|
+
this.update();
|
|
99
|
+
}
|
|
100
|
+
})
|
|
101
|
+
],
|
|
102
|
+
});
|
|
103
|
+
await this.selectLanguage(this._language());
|
|
104
|
+
this._editorView.contentDOM.style.width = '0';
|
|
105
|
+
this._editorView.focus();
|
|
106
|
+
this.initialized.set(true);
|
|
107
|
+
}
|
|
108
|
+
ngOnDestroy() {
|
|
109
|
+
this._editorView.destroy();
|
|
110
|
+
}
|
|
111
|
+
focus() {
|
|
112
|
+
this._editorView.focus();
|
|
113
|
+
}
|
|
114
|
+
getData() {
|
|
115
|
+
return {
|
|
116
|
+
content: this._editorView.state.doc.toString(),
|
|
117
|
+
settings: {
|
|
118
|
+
...this.settings(),
|
|
119
|
+
language: this._language().language
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
isEmpty() {
|
|
124
|
+
return this._editorView.state.doc.toString().trim().length === 0;
|
|
125
|
+
}
|
|
126
|
+
async selectLanguage(codeLanguage) {
|
|
127
|
+
this._language.set(codeLanguage);
|
|
128
|
+
if (codeLanguage.language === 'none') {
|
|
129
|
+
this._editorView.dispatch({
|
|
130
|
+
effects: this._editorLanguage.reconfigure([])
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
const language = await this._language().library();
|
|
135
|
+
this._editorView.dispatch({
|
|
136
|
+
effects: this._editorLanguage.reconfigure(language)
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
this.update();
|
|
140
|
+
}
|
|
141
|
+
update() {
|
|
142
|
+
this._store.updateBlock(this.id(), { ...this.getData(), isEmpty: this.isEmpty() });
|
|
143
|
+
this._contentBuilder.emitContentChangeEvent();
|
|
144
|
+
}
|
|
145
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.4", ngImport: i0, type: CodeBlockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
146
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.4", type: CodeBlockComponent, isStandalone: true, selector: "ngs-code-block", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: true, transformFunction: null }, content: { classPropertyName: "content", publicName: "content", isSignal: true, isRequired: true, transformFunction: null }, settings: { classPropertyName: "settings", publicName: "settings", isSignal: true, isRequired: true, transformFunction: null }, index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: true, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null } }, host: { classAttribute: "ngs-code-block" }, providers: [
|
|
147
|
+
{
|
|
148
|
+
provide: CONTENT_EDITOR_BLOCK,
|
|
149
|
+
useExisting: forwardRef(() => CodeBlockComponent),
|
|
150
|
+
multi: true
|
|
151
|
+
}
|
|
152
|
+
], viewQueries: [{ propertyName: "_contentRef", first: true, predicate: ["contentRef"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"bg-surface-container rounded-xl\">\n <div class=\"border-b border-b-default h-12 header\">\n <button ngsButton [ngsMenuTriggerFor]=\"languageListMenu\" class=\"-ms-2\">{{ _language().name }}</button>\n </div>\n <div class=\"content\">\n <div class=\"content-code\" #contentRef></div>\n </div>\n</div>\n\n<ngs-menu #languageListMenu=\"ngsMenu\">\n @for (languageItem of _languageList(); track $index) {\n <button ngs-menu-item (click)=\"selectLanguage(languageItem)\"\n class=\"[&.is-active]:!bg-secondary-fixed\"\n [class.is-active]=\"languageItem.language === _language().language\">{{ languageItem.name }}</button>\n }\n</ngs-menu>\n", styles: [":host{display:block;margin:calc(var(--spacing, .25rem) * 3) 0}:host .header{display:flex;align-items:center;padding:0 calc(var(--spacing, .25rem) * 4)}:host .language-trigger{font-size:var(--text-sm);cursor:pointer}:host .content{outline:none;font-size:var(--text-sm);padding:calc(var(--spacing, .25rem) * 2);min-width:0}:host .content .content-code{min-width:0}:host .content .content-code ::ng-deep .cm-editor{border-radius:.5rem}:host .content .content-code ::ng-deep .cm-scroller{border-radius:.5rem;overflow-x:auto}:host .content .content-code ::ng-deep .cm-content,:host .content .content-code ::ng-deep .cm-gutter{min-height:160px}:host-context(.block.is-active) .content:empty:before,:host-context(.block.is-focused) .content:empty:before{content:attr(data-empty-placeholder);color:var(--color-neutral-500)}\n/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */\n"], dependencies: [{ kind: "component", type: Menu, selector: "ngs-menu", inputs: ["role", "classList", "xPosition", "yPosition"], outputs: ["closed"], exportAs: ["ngsMenu"] }, { kind: "component", type: MenuItem, selector: "ngs-menu-item, [ngs-menu-item]", inputs: ["disabled", "role", "selected"], outputs: ["_triggered"], exportAs: ["ngsMenuItem"] }, { kind: "directive", type: MenuTrigger, selector: "[ngsMenuTriggerFor]", inputs: ["ngsMenuTriggerFor", "ngsMenuTriggerData", "ngsMenuDisabled", "xPosition", "yPosition", "ngsMenuTriggerRestoreFocus"], outputs: ["menuOpened", "menuClosed"], exportAs: ["ngsMenuTrigger"] }, { kind: "component", type: Button, selector: " button[ngsButton], button[ngsIconButton], a[ngsButton], a[ngsIconButton] ", inputs: ["ngsButton", "ngsIconButton", "loading", "disabled", "disabledInteractive", "disableRipple", "reverse", "fullWidth", "hideTextOnMobile"], exportAs: ["ngsButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
153
|
+
}
|
|
154
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.4", ngImport: i0, type: CodeBlockComponent, decorators: [{
|
|
155
|
+
type: Component,
|
|
156
|
+
args: [{ selector: 'ngs-code-block', imports: [
|
|
157
|
+
Menu,
|
|
158
|
+
MenuItem,
|
|
159
|
+
MenuTrigger,
|
|
160
|
+
Button
|
|
161
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
162
|
+
{
|
|
163
|
+
provide: CONTENT_EDITOR_BLOCK,
|
|
164
|
+
useExisting: forwardRef(() => CodeBlockComponent),
|
|
165
|
+
multi: true
|
|
166
|
+
}
|
|
167
|
+
], host: {
|
|
168
|
+
'class': 'ngs-code-block',
|
|
169
|
+
}, template: "<div class=\"bg-surface-container rounded-xl\">\n <div class=\"border-b border-b-default h-12 header\">\n <button ngsButton [ngsMenuTriggerFor]=\"languageListMenu\" class=\"-ms-2\">{{ _language().name }}</button>\n </div>\n <div class=\"content\">\n <div class=\"content-code\" #contentRef></div>\n </div>\n</div>\n\n<ngs-menu #languageListMenu=\"ngsMenu\">\n @for (languageItem of _languageList(); track $index) {\n <button ngs-menu-item (click)=\"selectLanguage(languageItem)\"\n class=\"[&.is-active]:!bg-secondary-fixed\"\n [class.is-active]=\"languageItem.language === _language().language\">{{ languageItem.name }}</button>\n }\n</ngs-menu>\n", styles: [":host{display:block;margin:calc(var(--spacing, .25rem) * 3) 0}:host .header{display:flex;align-items:center;padding:0 calc(var(--spacing, .25rem) * 4)}:host .language-trigger{font-size:var(--text-sm);cursor:pointer}:host .content{outline:none;font-size:var(--text-sm);padding:calc(var(--spacing, .25rem) * 2);min-width:0}:host .content .content-code{min-width:0}:host .content .content-code ::ng-deep .cm-editor{border-radius:.5rem}:host .content .content-code ::ng-deep .cm-scroller{border-radius:.5rem;overflow-x:auto}:host .content .content-code ::ng-deep .cm-content,:host .content .content-code ::ng-deep .cm-gutter{min-height:160px}:host-context(.block.is-active) .content:empty:before,:host-context(.block.is-focused) .content:empty:before{content:attr(data-empty-placeholder);color:var(--color-neutral-500)}\n/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */\n"] }]
|
|
170
|
+
}], propDecorators: { _contentRef: [{ type: i0.ViewChild, args: ['contentRef', { isSignal: true }] }], id: [{ type: i0.Input, args: [{ isSignal: true, alias: "id", required: true }] }], content: [{ type: i0.Input, args: [{ isSignal: true, alias: "content", required: true }] }], settings: [{ type: i0.Input, args: [{ isSignal: true, alias: "settings", required: true }] }], index: [{ type: i0.Input, args: [{ isSignal: true, alias: "index", required: true }] }], placeholder: [{ type: i0.Input, args: [{ isSignal: true, alias: "placeholder", required: false }] }] } });
|
|
171
|
+
|
|
172
|
+
export { CodeBlockComponent };
|
|
173
|
+
//# sourceMappingURL=ngstarter-ui-components-content-editor-code-block.component-Bk6QTli8.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ngstarter-ui-components-content-editor-code-block.component-Bk6QTli8.mjs","sources":["../../../projects/components/content-editor/src/_builder/code-block/code-block.component.ts","../../../projects/components/content-editor/src/_builder/code-block/code-block.component.html"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n DestroyRef,\n ElementRef, forwardRef,\n inject,\n input, OnDestroy,\n OnInit,\n signal,\n viewChild\n} from '@angular/core';\nimport {\n CONTENT_BUILDER,\n CONTENT_EDITOR_BLOCK,\n ContentEditorDataBlock\n} from '../../types';\nimport { ContentBuilderStore } from '../../content-builder.store';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { EditorView, keymap, ViewUpdate } from '@codemirror/view';\nimport { basicSetup } from 'codemirror';\nimport { Compartment } from '@codemirror/state';\nimport { Menu, MenuItem, MenuTrigger } from '@ngstarter-ui/components/menu';\nimport { Button } from '@ngstarter-ui/components/button';\nimport { githubLight } from '@uiw/codemirror-theme-github';\nimport { indentWithTab } from \"@codemirror/commands\"\nimport { ContentBuilderComponent } from '../../content-builder/content-builder.component';\nimport { DOCUMENT } from '@angular/common';\n\nexport interface ContentEditorCodeBlockSettings {\n language: string;\n}\n\nexport interface ContentEditorCodeLanguage {\n language: string;\n name: string;\n library: () => Promise<any>;\n}\n\n@Component({\n selector: 'ngs-code-block',\n imports: [\n Menu,\n MenuItem,\n MenuTrigger,\n Button\n ],\n changeDetection: ChangeDetectionStrategy.OnPush,\n templateUrl: './code-block.component.html',\n styleUrl: './code-block.component.scss',\n providers: [\n {\n provide: CONTENT_EDITOR_BLOCK,\n useExisting: forwardRef(() => CodeBlockComponent),\n multi: true\n }\n ],\n host: {\n 'class': 'ngs-code-block',\n }\n})\nexport class CodeBlockComponent implements OnInit, OnDestroy, ContentEditorDataBlock {\n private _store = inject(ContentBuilderStore);\n private _contentBuilder = inject<ContentBuilderComponent>(CONTENT_BUILDER);\n private _destroyRef = inject(DestroyRef);\n private document = inject(DOCUMENT);\n\n private _contentRef = viewChild.required<ElementRef<HTMLParagraphElement>>('contentRef');\n\n id = input.required<string>();\n content = input.required<string>();\n settings = input.required<ContentEditorCodeBlockSettings>();\n index = input.required<number>();\n placeholder = input('Write your code here');\n\n protected _languageList = signal<ContentEditorCodeLanguage[]>([\n {\n language: 'none',\n name: 'None',\n library: () => new Promise(() => {})\n },\n {\n language: 'angular',\n name: 'Angular',\n library: () => import('@codemirror/lang-angular').then(lang => lang.angular())\n },\n {\n language: 'javascript',\n name: 'JavaScript',\n library: () => import('@codemirror/lang-javascript').then(lang => lang.javascript())\n },\n {\n language: 'typescript',\n name: 'TypeScript',\n library: () => import('@codemirror/lang-javascript').then(lang => lang.javascript({ typescript: true }))\n },\n {\n language: 'html',\n name: 'HTML',\n library: () => import('@codemirror/lang-html').then(lang => lang.html())\n },\n {\n language: 'css',\n name: 'CSS',\n library: () => import('@codemirror/lang-css').then(lang => lang.css())\n },\n {\n language: 'sass',\n name: 'Sass',\n library: () => import('@codemirror/lang-sass').then(lang => lang.sass())\n },\n {\n language: 'json',\n name: 'JSON',\n library: () => import('@codemirror/lang-json').then(lang => lang.json())\n }\n ]);\n protected _code = signal<string>('');\n protected _language = signal<ContentEditorCodeLanguage>(this._languageList()[0]);\n protected _isEmpty = signal<boolean>(true);\n\n private _editorView!: EditorView;\n private _editorLanguage = new Compartment();\n readonly initialized = signal(false);\n\n async ngOnInit() {\n const codeLanguage = this._languageList().find(\n codeLanguage => codeLanguage.language === this.settings().language\n );\n\n if (codeLanguage) {\n this._language.set(codeLanguage);\n }\n\n this._code.set(this.content() || '');\n this._isEmpty.set(this._code().trim().length === 0);\n this._contentBuilder\n .focusChanged\n .pipe(takeUntilDestroyed(this._destroyRef))\n .subscribe(() => {\n if (this._store.focusedBlockId() === this.id()) {\n this.focus();\n }\n });\n this._editorView = new EditorView({\n doc: this._code(),\n parent: this._contentRef().nativeElement,\n extensions: [\n basicSetup,\n githubLight,\n keymap.of([indentWithTab]),\n this._editorLanguage.of([]),\n EditorView.updateListener.of((v: ViewUpdate) => {\n if (v.docChanged) {\n this.update();\n }\n })\n ],\n });\n await this.selectLanguage(this._language());\n this._editorView.contentDOM.style.width = '0';\n this._editorView.focus();\n this.initialized.set(true);\n }\n\n ngOnDestroy() {\n this._editorView.destroy();\n }\n\n focus() {\n this._editorView.focus();\n }\n\n getData(): any {\n return {\n content: this._editorView.state.doc.toString(),\n settings: {\n ...this.settings(),\n language: this._language().language\n }\n };\n }\n\n isEmpty(): boolean {\n return this._editorView.state.doc.toString().trim().length === 0;\n }\n\n protected async selectLanguage(codeLanguage: ContentEditorCodeLanguage) {\n this._language.set(codeLanguage);\n\n if (codeLanguage.language === 'none') {\n this._editorView.dispatch({\n effects: this._editorLanguage.reconfigure([])\n });\n } else {\n const language = await this._language().library();\n this._editorView.dispatch({\n effects: this._editorLanguage.reconfigure(language)\n });\n }\n\n this.update();\n }\n\n private update() {\n this._store.updateBlock(this.id(), {...this.getData(), isEmpty: this.isEmpty()});\n this._contentBuilder.emitContentChangeEvent();\n }\n}\n","<div class=\"bg-surface-container rounded-xl\">\n <div class=\"border-b border-b-default h-12 header\">\n <button ngsButton [ngsMenuTriggerFor]=\"languageListMenu\" class=\"-ms-2\">{{ _language().name }}</button>\n </div>\n <div class=\"content\">\n <div class=\"content-code\" #contentRef></div>\n </div>\n</div>\n\n<ngs-menu #languageListMenu=\"ngsMenu\">\n @for (languageItem of _languageList(); track $index) {\n <button ngs-menu-item (click)=\"selectLanguage(languageItem)\"\n class=\"[&.is-active]:!bg-secondary-fixed\"\n [class.is-active]=\"languageItem.language === _language().language\">{{ languageItem.name }}</button>\n }\n</ngs-menu>\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { inject, PLATFORM_ID, ElementRef, Renderer2, output, input, signal, Directive } from '@angular/core';
|
|
3
|
+
import { isPlatformServer } from '@angular/common';
|
|
4
|
+
|
|
5
|
+
class ContentEditorContentEditableDirective {
|
|
6
|
+
_platformId = inject(PLATFORM_ID);
|
|
7
|
+
_elementRef = inject(ElementRef);
|
|
8
|
+
_renderer = inject(Renderer2);
|
|
9
|
+
contentChanged = output();
|
|
10
|
+
pressedEnter = output();
|
|
11
|
+
initialized = output();
|
|
12
|
+
_observer;
|
|
13
|
+
content = input('', { ...(ngDevMode ? { debugName: "content" } : /* istanbul ignore next */ {}), alias: 'ngsContentEditorContentEditable' });
|
|
14
|
+
settings = input({}, ...(ngDevMode ? [{ debugName: "settings" }] : /* istanbul ignore next */ []));
|
|
15
|
+
props = input([], ...(ngDevMode ? [{ debugName: "props" }] : /* istanbul ignore next */ []));
|
|
16
|
+
_props = signal([], ...(ngDevMode ? [{ debugName: "_props" }] : /* istanbul ignore next */ []));
|
|
17
|
+
propsChanged = output();
|
|
18
|
+
_isAlreadyRendered = false;
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this._props.set(this.props() || []);
|
|
21
|
+
(this.props() || []).forEach(prop => {
|
|
22
|
+
this._renderer.setAttribute(this._elementRef.nativeElement, `data-props-${prop.name}`, prop.value);
|
|
23
|
+
});
|
|
24
|
+
this._renderer.setAttribute(this._elementRef.nativeElement, 'contenteditable', 'true');
|
|
25
|
+
if (this._isAlreadyRendered) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
if (this.content()) {
|
|
29
|
+
this._elementRef.nativeElement.innerHTML = this.content();
|
|
30
|
+
}
|
|
31
|
+
this._isAlreadyRendered = true;
|
|
32
|
+
this.initialized.emit();
|
|
33
|
+
let prevContent = this.getContent();
|
|
34
|
+
if (isPlatformServer(this._platformId)) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const config = { attributes: true, childList: true, subtree: true };
|
|
38
|
+
const callback = (mutationList, observer) => {
|
|
39
|
+
for (const mutation of mutationList) {
|
|
40
|
+
if (mutation.type === 'attributes') {
|
|
41
|
+
if (mutation.attributeName.startsWith('data-props-')) {
|
|
42
|
+
const prevPropsHash = JSON.stringify(this._props());
|
|
43
|
+
const propName = mutation.attributeName.replace('data-props-', '');
|
|
44
|
+
const propValue = mutation.target.getAttribute(mutation.attributeName);
|
|
45
|
+
const propIndex = this._props().findIndex(p => p.name === propName);
|
|
46
|
+
if (propIndex >= 0) {
|
|
47
|
+
this._props.update((props) => {
|
|
48
|
+
props[propIndex].value = propValue;
|
|
49
|
+
return props;
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this._props.update((props) => {
|
|
54
|
+
props.push({
|
|
55
|
+
name: propName,
|
|
56
|
+
value: propValue,
|
|
57
|
+
});
|
|
58
|
+
return props;
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
const updatedPropsHash = JSON.stringify(this._props());
|
|
62
|
+
if (prevPropsHash !== updatedPropsHash) {
|
|
63
|
+
this.propsChanged.emit(this._props());
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
const currentContent = this.getContent();
|
|
69
|
+
if (prevContent !== currentContent) {
|
|
70
|
+
prevContent = currentContent;
|
|
71
|
+
this._raiseUpdateEvent();
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
this._observer = new MutationObserver(callback);
|
|
77
|
+
this._observer.observe(this._elementRef.nativeElement, config);
|
|
78
|
+
}
|
|
79
|
+
ngOnDestroy() {
|
|
80
|
+
this._observer?.disconnect();
|
|
81
|
+
}
|
|
82
|
+
getContent() {
|
|
83
|
+
let content = this._elementRef.nativeElement.innerHTML;
|
|
84
|
+
content = content.replaceAll('<br>', '').replaceAll(/ /g, ' ').trim();
|
|
85
|
+
if (content.length === 0) {
|
|
86
|
+
this._elementRef.nativeElement.innerHTML = '';
|
|
87
|
+
}
|
|
88
|
+
return content;
|
|
89
|
+
}
|
|
90
|
+
_handleBlur(event) {
|
|
91
|
+
}
|
|
92
|
+
_handleInput(event) {
|
|
93
|
+
if (!this._isAlreadyRendered) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
this._raiseUpdateEvent();
|
|
97
|
+
}
|
|
98
|
+
_raiseUpdateEvent() {
|
|
99
|
+
this.contentChanged.emit(this.getContent());
|
|
100
|
+
}
|
|
101
|
+
_handleKeyPress(event) {
|
|
102
|
+
if (event.key === 'Enter') {
|
|
103
|
+
this.pressedEnter.emit(event);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.4", ngImport: i0, type: ContentEditorContentEditableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
107
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.2.4", type: ContentEditorContentEditableDirective, isStandalone: true, selector: "[ngsContentEditorContentEditable]", inputs: { content: { classPropertyName: "content", publicName: "ngsContentEditorContentEditable", isSignal: true, isRequired: false, transformFunction: null }, settings: { classPropertyName: "settings", publicName: "settings", isSignal: true, isRequired: false, transformFunction: null }, props: { classPropertyName: "props", publicName: "props", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { contentChanged: "contentChanged", pressedEnter: "pressedEnter", initialized: "initialized", propsChanged: "propsChanged" }, host: { listeners: { "blur": "_handleBlur($event)", "input": "_handleInput($event)", "keypress": "_handleKeyPress($event)" }, properties: { "class.ngs-content-editor-content-editable": "true" } }, exportAs: ["ngsContentEditorContentEditable"], ngImport: i0 });
|
|
108
|
+
}
|
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.4", ngImport: i0, type: ContentEditorContentEditableDirective, decorators: [{
|
|
110
|
+
type: Directive,
|
|
111
|
+
args: [{
|
|
112
|
+
selector: '[ngsContentEditorContentEditable]',
|
|
113
|
+
exportAs: 'ngsContentEditorContentEditable',
|
|
114
|
+
host: {
|
|
115
|
+
'[class.ngs-content-editor-content-editable]': 'true',
|
|
116
|
+
'(blur)': '_handleBlur($event)',
|
|
117
|
+
'(input)': '_handleInput($event)',
|
|
118
|
+
'(keypress)': '_handleKeyPress($event)',
|
|
119
|
+
}
|
|
120
|
+
}]
|
|
121
|
+
}], propDecorators: { contentChanged: [{ type: i0.Output, args: ["contentChanged"] }], pressedEnter: [{ type: i0.Output, args: ["pressedEnter"] }], initialized: [{ type: i0.Output, args: ["initialized"] }], content: [{ type: i0.Input, args: [{ isSignal: true, alias: "ngsContentEditorContentEditable", required: false }] }], settings: [{ type: i0.Input, args: [{ isSignal: true, alias: "settings", required: false }] }], props: [{ type: i0.Input, args: [{ isSignal: true, alias: "props", required: false }] }], propsChanged: [{ type: i0.Output, args: ["propsChanged"] }] } });
|
|
122
|
+
|
|
123
|
+
export { ContentEditorContentEditableDirective as C };
|
|
124
|
+
//# sourceMappingURL=ngstarter-ui-components-content-editor-content-editor-content-editable.directive-Bvfa2dqh.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ngstarter-ui-components-content-editor-content-editor-content-editable.directive-Bvfa2dqh.mjs","sources":["../../../projects/components/content-editor/src/content-editor-content-editable.directive.ts"],"sourcesContent":["import {\n Directive,\n ElementRef,\n inject,\n input,\n OnDestroy,\n OnInit,\n output,\n PLATFORM_ID,\n Renderer2,\n signal\n} from '@angular/core';\nimport { ContentEditorItemProperty } from './types';\nimport { isPlatformServer } from '@angular/common';\n\n@Directive({\n selector: '[ngsContentEditorContentEditable]',\n exportAs: 'ngsContentEditorContentEditable',\n host: {\n '[class.ngs-content-editor-content-editable]': 'true',\n '(blur)': '_handleBlur($event)',\n '(input)': '_handleInput($event)',\n '(keypress)': '_handleKeyPress($event)',\n }\n})\nexport class ContentEditorContentEditableDirective implements OnInit, OnDestroy {\n private _platformId = inject(PLATFORM_ID);\n private _elementRef = inject(ElementRef);\n private _renderer = inject(Renderer2);\n readonly contentChanged = output<string>();\n readonly pressedEnter = output<KeyboardEvent>();\n readonly initialized = output<void>();\n private _observer!: MutationObserver;\n\n content = input<string>('', {\n alias: 'ngsContentEditorContentEditable'\n });\n settings = input<any>({});\n props = input<ContentEditorItemProperty[]>([]);\n\n _props = signal<ContentEditorItemProperty[]>([]);\n\n readonly propsChanged = output<ContentEditorItemProperty[]>();\n\n private _isAlreadyRendered = false;\n\n ngOnInit() {\n this._props.set(this.props() || []);\n (this.props() || []).forEach(prop => {\n this._renderer.setAttribute(this._elementRef.nativeElement, `data-props-${prop.name}`, prop.value);\n });\n this._renderer.setAttribute(this._elementRef.nativeElement, 'contenteditable', 'true');\n\n if (this._isAlreadyRendered) {\n return;\n }\n\n if (this.content()) {\n this._elementRef.nativeElement.innerHTML = this.content();\n }\n\n this._isAlreadyRendered = true;\n this.initialized.emit();\n\n let prevContent = this.getContent();\n\n if (isPlatformServer(this._platformId)) {\n return;\n }\n\n const config = { attributes: true, childList: true, subtree: true };\n const callback = (mutationList: any, observer: any) => {\n for (const mutation of mutationList) {\n if (mutation.type === 'attributes') {\n if (mutation.attributeName.startsWith('data-props-')) {\n const prevPropsHash = JSON.stringify(this._props());\n const propName = mutation.attributeName.replace('data-props-', '');\n const propValue = mutation.target.getAttribute(mutation.attributeName);\n const propIndex = this._props().findIndex(p => p.name === propName);\n\n if (propIndex >= 0) {\n this._props.update((props: ContentEditorItemProperty[]) => {\n props[propIndex].value = propValue;\n return props;\n });\n } else {\n this._props.update((props: ContentEditorItemProperty[]) => {\n props.push({\n name: propName,\n value: propValue,\n })\n return props;\n });\n }\n\n const updatedPropsHash = JSON.stringify(this._props());\n\n if (prevPropsHash !== updatedPropsHash) {\n this.propsChanged.emit(this._props());\n }\n }\n } else {\n const currentContent = this.getContent();\n\n if (prevContent !== currentContent) {\n prevContent = currentContent;\n this._raiseUpdateEvent();\n }\n }\n }\n };\n this._observer = new MutationObserver(callback);\n this._observer.observe(this._elementRef.nativeElement, config);\n }\n\n ngOnDestroy() {\n this._observer?.disconnect();\n }\n\n getContent(): string {\n let content = this._elementRef.nativeElement.innerHTML as string;\n content = content.replaceAll('<br>', '').replaceAll(/ /g, ' ').trim();\n\n if (content.length === 0) {\n this._elementRef.nativeElement.innerHTML = '';\n }\n\n return content;\n }\n\n protected _handleBlur(event: Event) {\n }\n\n protected _handleInput(event: Event) {\n if (!this._isAlreadyRendered) {\n return;\n }\n\n this._raiseUpdateEvent();\n }\n\n protected _raiseUpdateEvent() {\n this.contentChanged.emit(this.getContent());\n }\n\n protected _handleKeyPress(event: KeyboardEvent) {\n if (event.key === 'Enter') {\n this.pressedEnter.emit(event);\n }\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
class CursorController {
|
|
2
|
+
targetElement;
|
|
3
|
+
/**
|
|
4
|
+
* Creates an instance of CursorController.
|
|
5
|
+
* @param {HTMLElement | string} elementOrSelector - The target HTML element or a CSS selector string to find it.
|
|
6
|
+
* @throws {Error} If the element cannot be found using the selector.
|
|
7
|
+
*/
|
|
8
|
+
constructor(elementOrSelector) {
|
|
9
|
+
const element = typeof elementOrSelector === 'string'
|
|
10
|
+
? document.querySelector(elementOrSelector)
|
|
11
|
+
: elementOrSelector;
|
|
12
|
+
if (!element) {
|
|
13
|
+
throw new Error(`CursorController: Element not found for selector "${elementOrSelector}"`);
|
|
14
|
+
}
|
|
15
|
+
// Basic check if the element type might support cursor positioning
|
|
16
|
+
if (!(element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement || element.isContentEditable)) {
|
|
17
|
+
console.warn(`CursorController: Target element (${element.tagName}) is not an input, textarea, or contenteditable. Cursor positioning may not work as expected.`);
|
|
18
|
+
}
|
|
19
|
+
this.targetElement = element;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Sets the cursor position to the beginning of the element's textContent.
|
|
23
|
+
* Ensures the element is focused before attempting to set the position.
|
|
24
|
+
*/
|
|
25
|
+
setToStart() {
|
|
26
|
+
this.targetElement.focus(); // Element must be focused to manipulate selection reliably
|
|
27
|
+
// Short delay can sometimes help ensure focus is registered before selection change
|
|
28
|
+
// Especially relevant in complex UI interactions or frameworks.
|
|
29
|
+
// Use requestAnimationFrame for a slightly better timing than setTimeout(0)
|
|
30
|
+
requestAnimationFrame(() => {
|
|
31
|
+
if (this.isInputOrTextAreaElement(this.targetElement)) {
|
|
32
|
+
// Handle <input> and <textarea> elements
|
|
33
|
+
this.targetElement.selectionStart = 0;
|
|
34
|
+
this.targetElement.selectionEnd = 0;
|
|
35
|
+
}
|
|
36
|
+
else if (this.targetElement.isContentEditable) {
|
|
37
|
+
// Handle contenteditable elements using Selection API
|
|
38
|
+
const selection = window.getSelection();
|
|
39
|
+
if (selection) {
|
|
40
|
+
const range = document.createRange();
|
|
41
|
+
range.selectNodeContents(this.targetElement); // Select all textContent within the element
|
|
42
|
+
range.collapse(true); // Collapse the range to its start point
|
|
43
|
+
selection.removeAllRanges(); // Clear any existing selections
|
|
44
|
+
selection.addRange(range); // Add the new collapsed range
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
console.warn(`CursorController: Cannot set cursor start on a non-editable element (${this.targetElement.tagName}).`);
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Sets the cursor position to the end of the element's textContent.
|
|
54
|
+
* Ensures the element is focused before attempting to set the position.
|
|
55
|
+
*/
|
|
56
|
+
setToEnd() {
|
|
57
|
+
this.targetElement.focus(); // Element must be focused
|
|
58
|
+
requestAnimationFrame(() => {
|
|
59
|
+
if (this.isInputOrTextAreaElement(this.targetElement)) {
|
|
60
|
+
// Handle <input> and <textarea> elements
|
|
61
|
+
const length = this.targetElement.value.length;
|
|
62
|
+
this.targetElement.selectionStart = length;
|
|
63
|
+
this.targetElement.selectionEnd = length;
|
|
64
|
+
}
|
|
65
|
+
else if (this.targetElement.isContentEditable) {
|
|
66
|
+
// Handle contenteditable elements using Selection API
|
|
67
|
+
const selection = window.getSelection();
|
|
68
|
+
if (selection) {
|
|
69
|
+
const range = document.createRange();
|
|
70
|
+
range.selectNodeContents(this.targetElement); // Select all textContent
|
|
71
|
+
range.collapse(false); // Collapse the range to its end point
|
|
72
|
+
selection.removeAllRanges(); // Clear existing selections
|
|
73
|
+
selection.addRange(range); // Add the new collapsed range
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
console.warn(`CursorController: Cannot set cursor end on a non-editable element (${this.targetElement.tagName}).`);
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Type guard to check if the element is an HTMLInputElement or HTMLTextAreaElement.
|
|
83
|
+
* @param element The element to check.
|
|
84
|
+
* @returns {boolean} True if the element is an input or textarea.
|
|
85
|
+
*/
|
|
86
|
+
isInputOrTextAreaElement(element) {
|
|
87
|
+
return element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Gets the underlying HTML element being controlled.
|
|
91
|
+
* @returns {HTMLElement} The target element.
|
|
92
|
+
*/
|
|
93
|
+
getElement() {
|
|
94
|
+
return this.targetElement;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
export { CursorController as C };
|
|
99
|
+
//# sourceMappingURL=ngstarter-ui-components-content-editor-cursor-controller-4Ak8VqGX.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ngstarter-ui-components-content-editor-cursor-controller-4Ak8VqGX.mjs","sources":["../../../projects/components/content-editor/src/utils/cursor-controller.ts"],"sourcesContent":["export class CursorController {\n private targetElement: HTMLElement;\n\n /**\n * Creates an instance of CursorController.\n * @param {HTMLElement | string} elementOrSelector - The target HTML element or a CSS selector string to find it.\n * @throws {Error} If the element cannot be found using the selector.\n */\n constructor(elementOrSelector: HTMLElement | string) {\n const element = typeof elementOrSelector === 'string'\n ? document.querySelector<HTMLElement>(elementOrSelector)\n : elementOrSelector;\n\n if (!element) {\n throw new Error(`CursorController: Element not found for selector \"${elementOrSelector}\"`);\n }\n\n // Basic check if the element type might support cursor positioning\n if (!(element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement || element.isContentEditable)) {\n console.warn(`CursorController: Target element (${element.tagName}) is not an input, textarea, or contenteditable. Cursor positioning may not work as expected.`);\n }\n\n this.targetElement = element;\n }\n\n /**\n * Sets the cursor position to the beginning of the element's textContent.\n * Ensures the element is focused before attempting to set the position.\n */\n public setToStart(): void {\n this.targetElement.focus(); // Element must be focused to manipulate selection reliably\n\n // Short delay can sometimes help ensure focus is registered before selection change\n // Especially relevant in complex UI interactions or frameworks.\n // Use requestAnimationFrame for a slightly better timing than setTimeout(0)\n requestAnimationFrame(() => {\n if (this.isInputOrTextAreaElement(this.targetElement)) {\n // Handle <input> and <textarea> elements\n this.targetElement.selectionStart = 0;\n this.targetElement.selectionEnd = 0;\n } else if (this.targetElement.isContentEditable) {\n // Handle contenteditable elements using Selection API\n const selection = window.getSelection();\n if (selection) {\n const range = document.createRange();\n range.selectNodeContents(this.targetElement); // Select all textContent within the element\n range.collapse(true); // Collapse the range to its start point\n selection.removeAllRanges(); // Clear any existing selections\n selection.addRange(range); // Add the new collapsed range\n }\n } else {\n console.warn(`CursorController: Cannot set cursor start on a non-editable element (${this.targetElement.tagName}).`);\n }\n });\n }\n\n /**\n * Sets the cursor position to the end of the element's textContent.\n * Ensures the element is focused before attempting to set the position.\n */\n public setToEnd(): void {\n this.targetElement.focus(); // Element must be focused\n\n requestAnimationFrame(() => {\n if (this.isInputOrTextAreaElement(this.targetElement)) {\n // Handle <input> and <textarea> elements\n const length = this.targetElement.value.length;\n this.targetElement.selectionStart = length;\n this.targetElement.selectionEnd = length;\n } else if (this.targetElement.isContentEditable) {\n // Handle contenteditable elements using Selection API\n const selection = window.getSelection();\n if (selection) {\n const range = document.createRange();\n range.selectNodeContents(this.targetElement); // Select all textContent\n range.collapse(false); // Collapse the range to its end point\n selection.removeAllRanges(); // Clear existing selections\n selection.addRange(range); // Add the new collapsed range\n }\n } else {\n console.warn(`CursorController: Cannot set cursor end on a non-editable element (${this.targetElement.tagName}).`);\n }\n });\n }\n\n /**\n * Type guard to check if the element is an HTMLInputElement or HTMLTextAreaElement.\n * @param element The element to check.\n * @returns {boolean} True if the element is an input or textarea.\n */\n private isInputOrTextAreaElement(element: HTMLElement): element is HTMLInputElement | HTMLTextAreaElement {\n return element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement;\n }\n\n /**\n * Gets the underlying HTML element being controlled.\n * @returns {HTMLElement} The target element.\n */\n public getElement(): HTMLElement {\n return this.targetElement;\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, signal, Component } from '@angular/core';
|
|
3
|
+
import { Divider } from '@ngstarter-ui/components/divider';
|
|
4
|
+
|
|
5
|
+
class DividerBlockComponent {
|
|
6
|
+
id = input.required(...(ngDevMode ? [{ debugName: "id" }] : /* istanbul ignore next */ []));
|
|
7
|
+
content = input.required(...(ngDevMode ? [{ debugName: "content" }] : /* istanbul ignore next */ []));
|
|
8
|
+
settings = input.required(...(ngDevMode ? [{ debugName: "settings" }] : /* istanbul ignore next */ []));
|
|
9
|
+
index = input.required(...(ngDevMode ? [{ debugName: "index" }] : /* istanbul ignore next */ []));
|
|
10
|
+
initialized = signal(true, ...(ngDevMode ? [{ debugName: "initialized" }] : /* istanbul ignore next */ []));
|
|
11
|
+
getData() {
|
|
12
|
+
return {
|
|
13
|
+
content: null,
|
|
14
|
+
settings: this.settings()
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
isEmpty() {
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
focus() {
|
|
21
|
+
}
|
|
22
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.4", ngImport: i0, type: DividerBlockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "21.2.4", type: DividerBlockComponent, isStandalone: true, selector: "ngs-divider-block", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: true, transformFunction: null }, content: { classPropertyName: "content", publicName: "content", isSignal: true, isRequired: true, transformFunction: null }, settings: { classPropertyName: "settings", publicName: "settings", isSignal: true, isRequired: true, transformFunction: null }, index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<ngs-divider/>\n", styles: [""], dependencies: [{ kind: "component", type: Divider, selector: "ngs-divider", inputs: ["vertical", "inset", "fixedHeight"], exportAs: ["ngsDivider"] }] });
|
|
24
|
+
}
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.4", ngImport: i0, type: DividerBlockComponent, decorators: [{
|
|
26
|
+
type: Component,
|
|
27
|
+
args: [{ selector: 'ngs-divider-block', imports: [
|
|
28
|
+
Divider
|
|
29
|
+
], template: "<ngs-divider/>\n" }]
|
|
30
|
+
}], propDecorators: { id: [{ type: i0.Input, args: [{ isSignal: true, alias: "id", required: true }] }], content: [{ type: i0.Input, args: [{ isSignal: true, alias: "content", required: true }] }], settings: [{ type: i0.Input, args: [{ isSignal: true, alias: "settings", required: true }] }], index: [{ type: i0.Input, args: [{ isSignal: true, alias: "index", required: true }] }] } });
|
|
31
|
+
|
|
32
|
+
export { DividerBlockComponent };
|
|
33
|
+
//# sourceMappingURL=ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs.map
|
package/fesm2022/ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs","sources":["../../../projects/components/content-editor/src/_builder/divider-block/divider-block.component.ts","../../../projects/components/content-editor/src/_builder/divider-block/divider-block.component.html"],"sourcesContent":["import { Component, input, signal } from '@angular/core';\nimport { Divider } from '@ngstarter-ui/components/divider';\nimport { ContentEditorDataBlock } from '../../types';\nimport { ContentEditorCodeBlockSettings } from '../code-block/code-block.component';\n\n@Component({\n selector: 'ngs-divider-block',\n imports: [\n Divider\n ],\n templateUrl: './divider-block.component.html',\n styleUrl: './divider-block.component.scss'\n})\nexport class DividerBlockComponent implements ContentEditorDataBlock {\n id = input.required<string>();\n content = input.required<string>();\n settings = input.required<ContentEditorCodeBlockSettings>();\n index = input.required<number>();\n\n readonly initialized = signal(true);\n\n getData(): any {\n return {\n content: null,\n settings: this.settings()\n };\n }\n\n isEmpty(): boolean {\n return true;\n }\n\n focus() {\n }\n}\n","<ngs-divider/>\n"],"names":[],"mappings":";;;;MAaa,qBAAqB,CAAA;AAChC,IAAA,EAAE,GAAG,KAAK,CAAC,QAAQ,wEAAU;AAC7B,IAAA,OAAO,GAAG,KAAK,CAAC,QAAQ,6EAAU;AAClC,IAAA,QAAQ,GAAG,KAAK,CAAC,QAAQ,8EAAkC;AAC3D,IAAA,KAAK,GAAG,KAAK,CAAC,QAAQ,2EAAU;AAEvB,IAAA,WAAW,GAAG,MAAM,CAAC,IAAI,kFAAC;IAEnC,OAAO,GAAA;QACL,OAAO;AACL,YAAA,OAAO,EAAE,IAAI;AACb,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB;IACH;IAEA,OAAO,GAAA;AACL,QAAA,OAAO,IAAI;IACb;IAEA,KAAK,GAAA;IACL;uGApBW,qBAAqB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;2FAArB,qBAAqB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,MAAA,EAAA,EAAA,EAAA,EAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,OAAA,EAAA,EAAA,iBAAA,EAAA,SAAA,EAAA,UAAA,EAAA,SAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,QAAA,EAAA,EAAA,iBAAA,EAAA,UAAA,EAAA,UAAA,EAAA,UAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,KAAA,EAAA,EAAA,iBAAA,EAAA,OAAA,EAAA,UAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,ECblC,kBACA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EDOI,OAAO,EAAA,QAAA,EAAA,aAAA,EAAA,MAAA,EAAA,CAAA,UAAA,EAAA,OAAA,EAAA,aAAA,CAAA,EAAA,QAAA,EAAA,CAAA,YAAA,CAAA,EAAA,CAAA,EAAA,CAAA;;2FAKE,qBAAqB,EAAA,UAAA,EAAA,CAAA;kBARjC,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,mBAAmB,EAAA,OAAA,EACpB;wBACP;AACD,qBAAA,EAAA,QAAA,EAAA,kBAAA,EAAA;;;;;"}
|