@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.
Files changed (415) hide show
  1. package/README.md +0 -0
  2. package/fesm2022/ngstarter-ui-components-action-required.mjs +42 -0
  3. package/fesm2022/ngstarter-ui-components-action-required.mjs.map +1 -0
  4. package/fesm2022/ngstarter-ui-components-alert.mjs +132 -0
  5. package/fesm2022/ngstarter-ui-components-alert.mjs.map +1 -0
  6. package/fesm2022/ngstarter-ui-components-announcement.mjs +86 -0
  7. package/fesm2022/ngstarter-ui-components-announcement.mjs.map +1 -0
  8. package/fesm2022/ngstarter-ui-components-autocomplete.mjs +360 -0
  9. package/fesm2022/ngstarter-ui-components-autocomplete.mjs.map +1 -0
  10. package/fesm2022/ngstarter-ui-components-avatar.mjs +235 -0
  11. package/fesm2022/ngstarter-ui-components-avatar.mjs.map +1 -0
  12. package/fesm2022/ngstarter-ui-components-badge.mjs +97 -0
  13. package/fesm2022/ngstarter-ui-components-badge.mjs.map +1 -0
  14. package/fesm2022/ngstarter-ui-components-block-loader.mjs +48 -0
  15. package/fesm2022/ngstarter-ui-components-block-loader.mjs.map +1 -0
  16. package/fesm2022/ngstarter-ui-components-bottom-sheet.mjs +327 -0
  17. package/fesm2022/ngstarter-ui-components-bottom-sheet.mjs.map +1 -0
  18. package/fesm2022/ngstarter-ui-components-breadcrumbs.mjs +209 -0
  19. package/fesm2022/ngstarter-ui-components-breadcrumbs.mjs.map +1 -0
  20. package/fesm2022/ngstarter-ui-components-button-toggle.mjs +175 -0
  21. package/fesm2022/ngstarter-ui-components-button-toggle.mjs.map +1 -0
  22. package/fesm2022/ngstarter-ui-components-button.mjs +70 -0
  23. package/fesm2022/ngstarter-ui-components-button.mjs.map +1 -0
  24. package/fesm2022/ngstarter-ui-components-card-overlay.mjs +49 -0
  25. package/fesm2022/ngstarter-ui-components-card-overlay.mjs.map +1 -0
  26. package/fesm2022/ngstarter-ui-components-card.mjs +199 -0
  27. package/fesm2022/ngstarter-ui-components-card.mjs.map +1 -0
  28. package/fesm2022/ngstarter-ui-components-carousel.mjs +614 -0
  29. package/fesm2022/ngstarter-ui-components-carousel.mjs.map +1 -0
  30. package/fesm2022/ngstarter-ui-components-checkbox.mjs +300 -0
  31. package/fesm2022/ngstarter-ui-components-checkbox.mjs.map +1 -0
  32. package/fesm2022/ngstarter-ui-components-chips.mjs +589 -0
  33. package/fesm2022/ngstarter-ui-components-chips.mjs.map +1 -0
  34. package/fesm2022/ngstarter-ui-components-code-highlighter.mjs +347 -0
  35. package/fesm2022/ngstarter-ui-components-code-highlighter.mjs.map +1 -0
  36. package/fesm2022/ngstarter-ui-components-color-picker.mjs +713 -0
  37. package/fesm2022/ngstarter-ui-components-color-picker.mjs.map +1 -0
  38. package/fesm2022/ngstarter-ui-components-color-scheme.mjs +106 -0
  39. package/fesm2022/ngstarter-ui-components-color-scheme.mjs.map +1 -0
  40. package/fesm2022/ngstarter-ui-components-color-switcher.mjs +72 -0
  41. package/fesm2022/ngstarter-ui-components-color-switcher.mjs.map +1 -0
  42. package/fesm2022/ngstarter-ui-components-command-bar.mjs +57 -0
  43. package/fesm2022/ngstarter-ui-components-command-bar.mjs.map +1 -0
  44. package/fesm2022/ngstarter-ui-components-comment-editor.mjs +1024 -0
  45. package/fesm2022/ngstarter-ui-components-comment-editor.mjs.map +1 -0
  46. package/fesm2022/ngstarter-ui-components-comparison-slider.mjs +177 -0
  47. package/fesm2022/ngstarter-ui-components-comparison-slider.mjs.map +1 -0
  48. package/fesm2022/ngstarter-ui-components-confirm.mjs +85 -0
  49. package/fesm2022/ngstarter-ui-components-confirm.mjs.map +1 -0
  50. package/fesm2022/ngstarter-ui-components-content-editor-code-block.component-Bk6QTli8.mjs +173 -0
  51. package/fesm2022/ngstarter-ui-components-content-editor-code-block.component-Bk6QTli8.mjs.map +1 -0
  52. package/fesm2022/ngstarter-ui-components-content-editor-content-editor-content-editable.directive-Bvfa2dqh.mjs +124 -0
  53. package/fesm2022/ngstarter-ui-components-content-editor-content-editor-content-editable.directive-Bvfa2dqh.mjs.map +1 -0
  54. package/fesm2022/ngstarter-ui-components-content-editor-cursor-controller-4Ak8VqGX.mjs +99 -0
  55. package/fesm2022/ngstarter-ui-components-content-editor-cursor-controller-4Ak8VqGX.mjs.map +1 -0
  56. package/fesm2022/ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs +33 -0
  57. package/fesm2022/ngstarter-ui-components-content-editor-divider-block.component-C_iRTCPH.mjs.map +1 -0
  58. package/fesm2022/ngstarter-ui-components-content-editor-embed-block-BbkC_t86.mjs +354 -0
  59. package/fesm2022/ngstarter-ui-components-content-editor-embed-block-BbkC_t86.mjs.map +1 -0
  60. package/fesm2022/ngstarter-ui-components-content-editor-heading-block.component-D9_CxTY1.mjs +114 -0
  61. package/fesm2022/ngstarter-ui-components-content-editor-heading-block.component-D9_CxTY1.mjs.map +1 -0
  62. package/fesm2022/ngstarter-ui-components-content-editor-image-block.component-B4zJyUg1.mjs +146 -0
  63. package/fesm2022/ngstarter-ui-components-content-editor-image-block.component-B4zJyUg1.mjs.map +1 -0
  64. package/fesm2022/ngstarter-ui-components-content-editor-list-block.component-Cv6wx5Xe.mjs +215 -0
  65. package/fesm2022/ngstarter-ui-components-content-editor-list-block.component-Cv6wx5Xe.mjs.map +1 -0
  66. package/fesm2022/ngstarter-ui-components-content-editor-ngstarter-ui-components-content-editor-1Zi2nAX5.mjs +2548 -0
  67. package/fesm2022/ngstarter-ui-components-content-editor-ngstarter-ui-components-content-editor-1Zi2nAX5.mjs.map +1 -0
  68. package/fesm2022/ngstarter-ui-components-content-editor-paragraph-block.component-C9bQvDYU.mjs +110 -0
  69. package/fesm2022/ngstarter-ui-components-content-editor-paragraph-block.component-C9bQvDYU.mjs.map +1 -0
  70. package/fesm2022/ngstarter-ui-components-content-editor-quote-block.component-BbHds2r2.mjs +141 -0
  71. package/fesm2022/ngstarter-ui-components-content-editor-quote-block.component-BbHds2r2.mjs.map +1 -0
  72. package/fesm2022/ngstarter-ui-components-content-editor-table-block.component-DlDh7Fnn.mjs +1604 -0
  73. package/fesm2022/ngstarter-ui-components-content-editor-table-block.component-DlDh7Fnn.mjs.map +1 -0
  74. package/fesm2022/ngstarter-ui-components-content-editor-video-block.component-m4DTihP2.mjs +175 -0
  75. package/fesm2022/ngstarter-ui-components-content-editor-video-block.component-m4DTihP2.mjs.map +1 -0
  76. package/fesm2022/ngstarter-ui-components-content-editor.mjs +2 -0
  77. package/fesm2022/ngstarter-ui-components-content-editor.mjs.map +1 -0
  78. package/fesm2022/ngstarter-ui-components-content-fade.mjs +35 -0
  79. package/fesm2022/ngstarter-ui-components-content-fade.mjs.map +1 -0
  80. package/fesm2022/ngstarter-ui-components-cookie-popup.mjs +107 -0
  81. package/fesm2022/ngstarter-ui-components-cookie-popup.mjs.map +1 -0
  82. package/fesm2022/ngstarter-ui-components-core.mjs +1330 -0
  83. package/fesm2022/ngstarter-ui-components-core.mjs.map +1 -0
  84. package/fesm2022/ngstarter-ui-components-country-select.mjs +489 -0
  85. package/fesm2022/ngstarter-ui-components-country-select.mjs.map +1 -0
  86. package/fesm2022/ngstarter-ui-components-crop.mjs +183 -0
  87. package/fesm2022/ngstarter-ui-components-crop.mjs.map +1 -0
  88. package/fesm2022/ngstarter-ui-components-currency-select.mjs +397 -0
  89. package/fesm2022/ngstarter-ui-components-currency-select.mjs.map +1 -0
  90. package/fesm2022/ngstarter-ui-components-data-view.mjs +1494 -0
  91. package/fesm2022/ngstarter-ui-components-data-view.mjs.map +1 -0
  92. package/fesm2022/ngstarter-ui-components-date-format-select.mjs +154 -0
  93. package/fesm2022/ngstarter-ui-components-date-format-select.mjs.map +1 -0
  94. package/fesm2022/ngstarter-ui-components-datepicker.mjs +1159 -0
  95. package/fesm2022/ngstarter-ui-components-datepicker.mjs.map +1 -0
  96. package/fesm2022/ngstarter-ui-components-dialog.mjs +357 -0
  97. package/fesm2022/ngstarter-ui-components-dialog.mjs.map +1 -0
  98. package/fesm2022/ngstarter-ui-components-divider.mjs +42 -0
  99. package/fesm2022/ngstarter-ui-components-divider.mjs.map +1 -0
  100. package/fesm2022/ngstarter-ui-components-drawer.mjs +132 -0
  101. package/fesm2022/ngstarter-ui-components-drawer.mjs.map +1 -0
  102. package/fesm2022/ngstarter-ui-components-emoji-picker.mjs +245 -0
  103. package/fesm2022/ngstarter-ui-components-emoji-picker.mjs.map +1 -0
  104. package/fesm2022/ngstarter-ui-components-empty-state.mjs +75 -0
  105. package/fesm2022/ngstarter-ui-components-empty-state.mjs.map +1 -0
  106. package/fesm2022/ngstarter-ui-components-expand.mjs +56 -0
  107. package/fesm2022/ngstarter-ui-components-expand.mjs.map +1 -0
  108. package/fesm2022/ngstarter-ui-components-expansion.mjs +193 -0
  109. package/fesm2022/ngstarter-ui-components-expansion.mjs.map +1 -0
  110. package/fesm2022/ngstarter-ui-components-filter-builder.mjs +333 -0
  111. package/fesm2022/ngstarter-ui-components-filter-builder.mjs.map +1 -0
  112. package/fesm2022/ngstarter-ui-components-form-field.mjs +230 -0
  113. package/fesm2022/ngstarter-ui-components-form-field.mjs.map +1 -0
  114. package/fesm2022/ngstarter-ui-components-form-renderer-autocomplete-many-field-BKQVlZHV.mjs +124 -0
  115. package/fesm2022/ngstarter-ui-components-form-renderer-autocomplete-many-field-BKQVlZHV.mjs.map +1 -0
  116. package/fesm2022/ngstarter-ui-components-form-renderer-checkbox-field-CoyKdvhV.mjs +22 -0
  117. package/fesm2022/ngstarter-ui-components-form-renderer-checkbox-field-CoyKdvhV.mjs.map +1 -0
  118. package/fesm2022/ngstarter-ui-components-form-renderer-datepicker-field-Bzc0TPO9.mjs +44 -0
  119. package/fesm2022/ngstarter-ui-components-form-renderer-datepicker-field-Bzc0TPO9.mjs.map +1 -0
  120. package/fesm2022/ngstarter-ui-components-form-renderer-divider-content-CwGzDCZv.mjs +17 -0
  121. package/fesm2022/ngstarter-ui-components-form-renderer-divider-content-CwGzDCZv.mjs.map +1 -0
  122. package/fesm2022/ngstarter-ui-components-form-renderer-image-content-ICTwkZPa.mjs +17 -0
  123. package/fesm2022/ngstarter-ui-components-form-renderer-image-content-ICTwkZPa.mjs.map +1 -0
  124. package/fesm2022/ngstarter-ui-components-form-renderer-input-field-RYxi-Mpw.mjs +35 -0
  125. package/fesm2022/ngstarter-ui-components-form-renderer-input-field-RYxi-Mpw.mjs.map +1 -0
  126. package/fesm2022/ngstarter-ui-components-form-renderer-radio-group-field-Cv3AGpoq.mjs +38 -0
  127. package/fesm2022/ngstarter-ui-components-form-renderer-radio-group-field-Cv3AGpoq.mjs.map +1 -0
  128. package/fesm2022/ngstarter-ui-components-form-renderer-select-field-eLcwI-BY.mjs +39 -0
  129. package/fesm2022/ngstarter-ui-components-form-renderer-select-field-eLcwI-BY.mjs.map +1 -0
  130. package/fesm2022/ngstarter-ui-components-form-renderer-text-content-BjzH_M3-.mjs +24 -0
  131. package/fesm2022/ngstarter-ui-components-form-renderer-text-content-BjzH_M3-.mjs.map +1 -0
  132. package/fesm2022/ngstarter-ui-components-form-renderer-textarea-field-4zH7FTQ1.mjs +37 -0
  133. package/fesm2022/ngstarter-ui-components-form-renderer-textarea-field-4zH7FTQ1.mjs.map +1 -0
  134. package/fesm2022/ngstarter-ui-components-form-renderer-timezone-field-BpH65Hd-.mjs +35 -0
  135. package/fesm2022/ngstarter-ui-components-form-renderer-timezone-field-BpH65Hd-.mjs.map +1 -0
  136. package/fesm2022/ngstarter-ui-components-form-renderer-toggle-field-iyqUrWxt.mjs +22 -0
  137. package/fesm2022/ngstarter-ui-components-form-renderer-toggle-field-iyqUrWxt.mjs.map +1 -0
  138. package/fesm2022/ngstarter-ui-components-form-renderer.mjs +317 -0
  139. package/fesm2022/ngstarter-ui-components-form-renderer.mjs.map +1 -0
  140. package/fesm2022/ngstarter-ui-components-gauge.mjs +44 -0
  141. package/fesm2022/ngstarter-ui-components-gauge.mjs.map +1 -0
  142. package/fesm2022/ngstarter-ui-components-grid.mjs +78 -0
  143. package/fesm2022/ngstarter-ui-components-grid.mjs.map +1 -0
  144. package/fesm2022/ngstarter-ui-components-guided-tour.mjs +736 -0
  145. package/fesm2022/ngstarter-ui-components-guided-tour.mjs.map +1 -0
  146. package/fesm2022/ngstarter-ui-components-headless-stepper.mjs +192 -0
  147. package/fesm2022/ngstarter-ui-components-headless-stepper.mjs.map +1 -0
  148. package/fesm2022/ngstarter-ui-components-icon.mjs +61 -0
  149. package/fesm2022/ngstarter-ui-components-icon.mjs.map +1 -0
  150. package/fesm2022/ngstarter-ui-components-image-designer.mjs +4016 -0
  151. package/fesm2022/ngstarter-ui-components-image-designer.mjs.map +1 -0
  152. package/fesm2022/ngstarter-ui-components-image-placeholder.mjs +20 -0
  153. package/fesm2022/ngstarter-ui-components-image-placeholder.mjs.map +1 -0
  154. package/fesm2022/ngstarter-ui-components-image-resizer.mjs +151 -0
  155. package/fesm2022/ngstarter-ui-components-image-resizer.mjs.map +1 -0
  156. package/fesm2022/ngstarter-ui-components-image-viewer.mjs +349 -0
  157. package/fesm2022/ngstarter-ui-components-image-viewer.mjs.map +1 -0
  158. package/fesm2022/ngstarter-ui-components-image-zoom-viewer.mjs +162 -0
  159. package/fesm2022/ngstarter-ui-components-image-zoom-viewer.mjs.map +1 -0
  160. package/fesm2022/ngstarter-ui-components-incidents.mjs +257 -0
  161. package/fesm2022/ngstarter-ui-components-incidents.mjs.map +1 -0
  162. package/fesm2022/ngstarter-ui-components-inline-text-edit.mjs +179 -0
  163. package/fesm2022/ngstarter-ui-components-inline-text-edit.mjs.map +1 -0
  164. package/fesm2022/ngstarter-ui-components-input-mask.mjs +180 -0
  165. package/fesm2022/ngstarter-ui-components-input-mask.mjs.map +1 -0
  166. package/fesm2022/ngstarter-ui-components-input-validator.mjs +24 -0
  167. package/fesm2022/ngstarter-ui-components-input-validator.mjs.map +1 -0
  168. package/fesm2022/ngstarter-ui-components-input.mjs +152 -0
  169. package/fesm2022/ngstarter-ui-components-input.mjs.map +1 -0
  170. package/fesm2022/ngstarter-ui-components-kanban-board.mjs +156 -0
  171. package/fesm2022/ngstarter-ui-components-kanban-board.mjs.map +1 -0
  172. package/fesm2022/ngstarter-ui-components-kbd.mjs +31 -0
  173. package/fesm2022/ngstarter-ui-components-kbd.mjs.map +1 -0
  174. package/fesm2022/ngstarter-ui-components-layout.mjs +199 -0
  175. package/fesm2022/ngstarter-ui-components-layout.mjs.map +1 -0
  176. package/fesm2022/ngstarter-ui-components-list.mjs +279 -0
  177. package/fesm2022/ngstarter-ui-components-list.mjs.map +1 -0
  178. package/fesm2022/ngstarter-ui-components-logo.mjs +51 -0
  179. package/fesm2022/ngstarter-ui-components-logo.mjs.map +1 -0
  180. package/fesm2022/ngstarter-ui-components-marquee.mjs +76 -0
  181. package/fesm2022/ngstarter-ui-components-marquee.mjs.map +1 -0
  182. package/fesm2022/ngstarter-ui-components-menu.mjs +851 -0
  183. package/fesm2022/ngstarter-ui-components-menu.mjs.map +1 -0
  184. package/fesm2022/ngstarter-ui-components-micro-chart.mjs +928 -0
  185. package/fesm2022/ngstarter-ui-components-micro-chart.mjs.map +1 -0
  186. package/fesm2022/ngstarter-ui-components-navigation.mjs +439 -0
  187. package/fesm2022/ngstarter-ui-components-navigation.mjs.map +1 -0
  188. package/fesm2022/ngstarter-ui-components-notifications.mjs +181 -0
  189. package/fesm2022/ngstarter-ui-components-notifications.mjs.map +1 -0
  190. package/fesm2022/ngstarter-ui-components-number-input.mjs +293 -0
  191. package/fesm2022/ngstarter-ui-components-number-input.mjs.map +1 -0
  192. package/fesm2022/ngstarter-ui-components-option.mjs +157 -0
  193. package/fesm2022/ngstarter-ui-components-option.mjs.map +1 -0
  194. package/fesm2022/ngstarter-ui-components-overlay.mjs +112 -0
  195. package/fesm2022/ngstarter-ui-components-overlay.mjs.map +1 -0
  196. package/fesm2022/ngstarter-ui-components-page-loading-bar.mjs +77 -0
  197. package/fesm2022/ngstarter-ui-components-page-loading-bar.mjs.map +1 -0
  198. package/fesm2022/ngstarter-ui-components-paginator.mjs +297 -0
  199. package/fesm2022/ngstarter-ui-components-paginator.mjs.map +1 -0
  200. package/fesm2022/ngstarter-ui-components-panel.mjs +123 -0
  201. package/fesm2022/ngstarter-ui-components-panel.mjs.map +1 -0
  202. package/fesm2022/ngstarter-ui-components-password-strength.mjs +335 -0
  203. package/fesm2022/ngstarter-ui-components-password-strength.mjs.map +1 -0
  204. package/fesm2022/ngstarter-ui-components-phone-input.mjs +651 -0
  205. package/fesm2022/ngstarter-ui-components-phone-input.mjs.map +1 -0
  206. package/fesm2022/ngstarter-ui-components-pin-input.mjs +193 -0
  207. package/fesm2022/ngstarter-ui-components-pin-input.mjs.map +1 -0
  208. package/fesm2022/ngstarter-ui-components-popover.mjs +302 -0
  209. package/fesm2022/ngstarter-ui-components-popover.mjs.map +1 -0
  210. package/fesm2022/ngstarter-ui-components-progress-bar.mjs +68 -0
  211. package/fesm2022/ngstarter-ui-components-progress-bar.mjs.map +1 -0
  212. package/fesm2022/ngstarter-ui-components-radio-card.mjs +102 -0
  213. package/fesm2022/ngstarter-ui-components-radio-card.mjs.map +1 -0
  214. package/fesm2022/ngstarter-ui-components-radio.mjs +147 -0
  215. package/fesm2022/ngstarter-ui-components-radio.mjs.map +1 -0
  216. package/fesm2022/ngstarter-ui-components-rail-nav.mjs +87 -0
  217. package/fesm2022/ngstarter-ui-components-rail-nav.mjs.map +1 -0
  218. package/fesm2022/ngstarter-ui-components-resizable-container.mjs +74 -0
  219. package/fesm2022/ngstarter-ui-components-resizable-container.mjs.map +1 -0
  220. package/fesm2022/ngstarter-ui-components-screen-loader.mjs +95 -0
  221. package/fesm2022/ngstarter-ui-components-screen-loader.mjs.map +1 -0
  222. package/fesm2022/ngstarter-ui-components-scroll-spy.mjs +219 -0
  223. package/fesm2022/ngstarter-ui-components-scroll-spy.mjs.map +1 -0
  224. package/fesm2022/ngstarter-ui-components-scrollbar-area.mjs +459 -0
  225. package/fesm2022/ngstarter-ui-components-scrollbar-area.mjs.map +1 -0
  226. package/fesm2022/ngstarter-ui-components-segmented.mjs +218 -0
  227. package/fesm2022/ngstarter-ui-components-segmented.mjs.map +1 -0
  228. package/fesm2022/ngstarter-ui-components-select.mjs +496 -0
  229. package/fesm2022/ngstarter-ui-components-select.mjs.map +1 -0
  230. package/fesm2022/ngstarter-ui-components-side-panel.mjs +107 -0
  231. package/fesm2022/ngstarter-ui-components-side-panel.mjs.map +1 -0
  232. package/fesm2022/ngstarter-ui-components-sidebar.mjs +435 -0
  233. package/fesm2022/ngstarter-ui-components-sidebar.mjs.map +1 -0
  234. package/fesm2022/ngstarter-ui-components-sidenav.mjs +354 -0
  235. package/fesm2022/ngstarter-ui-components-sidenav.mjs.map +1 -0
  236. package/fesm2022/ngstarter-ui-components-signature-pad.mjs +452 -0
  237. package/fesm2022/ngstarter-ui-components-signature-pad.mjs.map +1 -0
  238. package/fesm2022/ngstarter-ui-components-skeleton.mjs +22 -0
  239. package/fesm2022/ngstarter-ui-components-skeleton.mjs.map +1 -0
  240. package/fesm2022/ngstarter-ui-components-slide-toggle.mjs +93 -0
  241. package/fesm2022/ngstarter-ui-components-slide-toggle.mjs.map +1 -0
  242. package/fesm2022/ngstarter-ui-components-slider.mjs +481 -0
  243. package/fesm2022/ngstarter-ui-components-slider.mjs.map +1 -0
  244. package/fesm2022/ngstarter-ui-components-snack-bar.mjs +354 -0
  245. package/fesm2022/ngstarter-ui-components-snack-bar.mjs.map +1 -0
  246. package/fesm2022/ngstarter-ui-components-sort.mjs +140 -0
  247. package/fesm2022/ngstarter-ui-components-sort.mjs.map +1 -0
  248. package/fesm2022/ngstarter-ui-components-spinner.mjs +75 -0
  249. package/fesm2022/ngstarter-ui-components-spinner.mjs.map +1 -0
  250. package/fesm2022/ngstarter-ui-components-splash-screen.mjs +93 -0
  251. package/fesm2022/ngstarter-ui-components-splash-screen.mjs.map +1 -0
  252. package/fesm2022/ngstarter-ui-components-split.mjs +948 -0
  253. package/fesm2022/ngstarter-ui-components-split.mjs.map +1 -0
  254. package/fesm2022/ngstarter-ui-components-stepper.mjs +103 -0
  255. package/fesm2022/ngstarter-ui-components-stepper.mjs.map +1 -0
  256. package/fesm2022/ngstarter-ui-components-suggestions.mjs +72 -0
  257. package/fesm2022/ngstarter-ui-components-suggestions.mjs.map +1 -0
  258. package/fesm2022/ngstarter-ui-components-tab-panel.mjs +265 -0
  259. package/fesm2022/ngstarter-ui-components-tab-panel.mjs.map +1 -0
  260. package/fesm2022/ngstarter-ui-components-table.mjs +648 -0
  261. package/fesm2022/ngstarter-ui-components-table.mjs.map +1 -0
  262. package/fesm2022/ngstarter-ui-components-tabs.mjs +591 -0
  263. package/fesm2022/ngstarter-ui-components-tabs.mjs.map +1 -0
  264. package/fesm2022/ngstarter-ui-components-text-editor.mjs +1012 -0
  265. package/fesm2022/ngstarter-ui-components-text-editor.mjs.map +1 -0
  266. package/fesm2022/ngstarter-ui-components-thumbnail-maker.mjs +212 -0
  267. package/fesm2022/ngstarter-ui-components-thumbnail-maker.mjs.map +1 -0
  268. package/fesm2022/ngstarter-ui-components-tiles.mjs +634 -0
  269. package/fesm2022/ngstarter-ui-components-tiles.mjs.map +1 -0
  270. package/fesm2022/ngstarter-ui-components-timeline.mjs +122 -0
  271. package/fesm2022/ngstarter-ui-components-timeline.mjs.map +1 -0
  272. package/fesm2022/ngstarter-ui-components-timepicker.mjs +486 -0
  273. package/fesm2022/ngstarter-ui-components-timepicker.mjs.map +1 -0
  274. package/fesm2022/ngstarter-ui-components-timezone-select.mjs +371 -0
  275. package/fesm2022/ngstarter-ui-components-timezone-select.mjs.map +1 -0
  276. package/fesm2022/ngstarter-ui-components-toolbar.mjs +299 -0
  277. package/fesm2022/ngstarter-ui-components-toolbar.mjs.map +1 -0
  278. package/fesm2022/ngstarter-ui-components-tooltip.mjs +506 -0
  279. package/fesm2022/ngstarter-ui-components-tooltip.mjs.map +1 -0
  280. package/fesm2022/ngstarter-ui-components-tree.mjs +200 -0
  281. package/fesm2022/ngstarter-ui-components-tree.mjs.map +1 -0
  282. package/fesm2022/ngstarter-ui-components-upload.mjs +330 -0
  283. package/fesm2022/ngstarter-ui-components-upload.mjs.map +1 -0
  284. package/fesm2022/ngstarter-ui-components-video-player.mjs +516 -0
  285. package/fesm2022/ngstarter-ui-components-video-player.mjs.map +1 -0
  286. package/fesm2022/ngstarter-ui-components-video-viewer.mjs +218 -0
  287. package/fesm2022/ngstarter-ui-components-video-viewer.mjs.map +1 -0
  288. package/fesm2022/ngstarter-ui-components-visual-builder.mjs +18 -0
  289. package/fesm2022/ngstarter-ui-components-visual-builder.mjs.map +1 -0
  290. package/fesm2022/ngstarter-ui-components.mjs +6 -0
  291. package/fesm2022/ngstarter-ui-components.mjs.map +1 -0
  292. package/package.json +535 -0
  293. package/styles/_common.scss +456 -0
  294. package/styles/_global.scss +91 -0
  295. package/styles/themes/default.scss +2 -0
  296. package/types/ngstarter-ui-components-action-required.d.ts +14 -0
  297. package/types/ngstarter-ui-components-alert.d.ts +50 -0
  298. package/types/ngstarter-ui-components-announcement.d.ts +59 -0
  299. package/types/ngstarter-ui-components-autocomplete.d.ts +83 -0
  300. package/types/ngstarter-ui-components-avatar.d.ts +69 -0
  301. package/types/ngstarter-ui-components-badge.d.ts +38 -0
  302. package/types/ngstarter-ui-components-block-loader.d.ts +21 -0
  303. package/types/ngstarter-ui-components-bottom-sheet.d.ts +149 -0
  304. package/types/ngstarter-ui-components-breadcrumbs.d.ts +104 -0
  305. package/types/ngstarter-ui-components-button-toggle.d.ts +54 -0
  306. package/types/ngstarter-ui-components-button.d.ts +27 -0
  307. package/types/ngstarter-ui-components-card-overlay.d.ts +20 -0
  308. package/types/ngstarter-ui-components-card.d.ts +85 -0
  309. package/types/ngstarter-ui-components-carousel.d.ts +76 -0
  310. package/types/ngstarter-ui-components-checkbox.d.ts +94 -0
  311. package/types/ngstarter-ui-components-chips.d.ts +189 -0
  312. package/types/ngstarter-ui-components-code-highlighter.d.ts +28 -0
  313. package/types/ngstarter-ui-components-color-picker.d.ts +92 -0
  314. package/types/ngstarter-ui-components-color-scheme.d.ts +44 -0
  315. package/types/ngstarter-ui-components-color-switcher.d.ts +26 -0
  316. package/types/ngstarter-ui-components-command-bar.d.ts +28 -0
  317. package/types/ngstarter-ui-components-comment-editor.d.ts +194 -0
  318. package/types/ngstarter-ui-components-comparison-slider.d.ts +42 -0
  319. package/types/ngstarter-ui-components-confirm.d.ts +34 -0
  320. package/types/ngstarter-ui-components-content-editor.d.ts +321 -0
  321. package/types/ngstarter-ui-components-content-fade.d.ts +17 -0
  322. package/types/ngstarter-ui-components-cookie-popup.d.ts +41 -0
  323. package/types/ngstarter-ui-components-core.d.ts +421 -0
  324. package/types/ngstarter-ui-components-country-select.d.ts +78 -0
  325. package/types/ngstarter-ui-components-crop.d.ts +59 -0
  326. package/types/ngstarter-ui-components-currency-select.d.ts +82 -0
  327. package/types/ngstarter-ui-components-data-view.d.ts +391 -0
  328. package/types/ngstarter-ui-components-date-format-select.d.ts +59 -0
  329. package/types/ngstarter-ui-components-datepicker.d.ts +384 -0
  330. package/types/ngstarter-ui-components-dialog.d.ts +115 -0
  331. package/types/ngstarter-ui-components-divider.d.ts +18 -0
  332. package/types/ngstarter-ui-components-drawer.d.ts +32 -0
  333. package/types/ngstarter-ui-components-emoji-picker.d.ts +49 -0
  334. package/types/ngstarter-ui-components-empty-state.d.ts +33 -0
  335. package/types/ngstarter-ui-components-expand.d.ts +26 -0
  336. package/types/ngstarter-ui-components-expansion.d.ts +68 -0
  337. package/types/ngstarter-ui-components-filter-builder.d.ts +106 -0
  338. package/types/ngstarter-ui-components-form-field.d.ts +107 -0
  339. package/types/ngstarter-ui-components-form-renderer.d.ts +121 -0
  340. package/types/ngstarter-ui-components-gauge.d.ts +21 -0
  341. package/types/ngstarter-ui-components-grid.d.ts +45 -0
  342. package/types/ngstarter-ui-components-guided-tour.d.ts +227 -0
  343. package/types/ngstarter-ui-components-headless-stepper.d.ts +65 -0
  344. package/types/ngstarter-ui-components-icon.d.ts +17 -0
  345. package/types/ngstarter-ui-components-image-designer.d.ts +357 -0
  346. package/types/ngstarter-ui-components-image-placeholder.d.ts +8 -0
  347. package/types/ngstarter-ui-components-image-resizer.d.ts +35 -0
  348. package/types/ngstarter-ui-components-image-viewer.d.ts +63 -0
  349. package/types/ngstarter-ui-components-image-zoom-viewer.d.ts +34 -0
  350. package/types/ngstarter-ui-components-incidents.d.ts +119 -0
  351. package/types/ngstarter-ui-components-inline-text-edit.d.ts +39 -0
  352. package/types/ngstarter-ui-components-input-mask.d.ts +36 -0
  353. package/types/ngstarter-ui-components-input-validator.d.ts +5 -0
  354. package/types/ngstarter-ui-components-input.d.ts +53 -0
  355. package/types/ngstarter-ui-components-kanban-board.d.ts +68 -0
  356. package/types/ngstarter-ui-components-kbd.d.ts +13 -0
  357. package/types/ngstarter-ui-components-layout.d.ts +83 -0
  358. package/types/ngstarter-ui-components-list.d.ts +98 -0
  359. package/types/ngstarter-ui-components-logo.d.ts +26 -0
  360. package/types/ngstarter-ui-components-marquee.d.ts +27 -0
  361. package/types/ngstarter-ui-components-menu.d.ts +199 -0
  362. package/types/ngstarter-ui-components-micro-chart.d.ts +195 -0
  363. package/types/ngstarter-ui-components-navigation.d.ts +136 -0
  364. package/types/ngstarter-ui-components-notifications.d.ts +84 -0
  365. package/types/ngstarter-ui-components-number-input.d.ts +99 -0
  366. package/types/ngstarter-ui-components-option.d.ts +61 -0
  367. package/types/ngstarter-ui-components-overlay.d.ts +12 -0
  368. package/types/ngstarter-ui-components-page-loading-bar.d.ts +20 -0
  369. package/types/ngstarter-ui-components-paginator.d.ts +145 -0
  370. package/types/ngstarter-ui-components-panel.d.ts +59 -0
  371. package/types/ngstarter-ui-components-password-strength.d.ts +109 -0
  372. package/types/ngstarter-ui-components-phone-input.d.ts +103 -0
  373. package/types/ngstarter-ui-components-pin-input.d.ts +48 -0
  374. package/types/ngstarter-ui-components-popover.d.ts +94 -0
  375. package/types/ngstarter-ui-components-progress-bar.d.ts +30 -0
  376. package/types/ngstarter-ui-components-radio-card.d.ts +37 -0
  377. package/types/ngstarter-ui-components-radio.d.ts +45 -0
  378. package/types/ngstarter-ui-components-rail-nav.d.ts +36 -0
  379. package/types/ngstarter-ui-components-resizable-container.d.ts +25 -0
  380. package/types/ngstarter-ui-components-screen-loader.d.ts +34 -0
  381. package/types/ngstarter-ui-components-scroll-spy.d.ts +63 -0
  382. package/types/ngstarter-ui-components-scrollbar-area.d.ts +67 -0
  383. package/types/ngstarter-ui-components-segmented.d.ts +65 -0
  384. package/types/ngstarter-ui-components-select.d.ts +126 -0
  385. package/types/ngstarter-ui-components-side-panel.d.ts +42 -0
  386. package/types/ngstarter-ui-components-sidebar.d.ts +143 -0
  387. package/types/ngstarter-ui-components-sidenav.d.ts +86 -0
  388. package/types/ngstarter-ui-components-signature-pad.d.ts +49 -0
  389. package/types/ngstarter-ui-components-skeleton.d.ts +9 -0
  390. package/types/ngstarter-ui-components-slide-toggle.d.ts +41 -0
  391. package/types/ngstarter-ui-components-slider.d.ts +85 -0
  392. package/types/ngstarter-ui-components-snack-bar.d.ts +142 -0
  393. package/types/ngstarter-ui-components-sort.d.ts +66 -0
  394. package/types/ngstarter-ui-components-spinner.d.ts +28 -0
  395. package/types/ngstarter-ui-components-splash-screen.d.ts +31 -0
  396. package/types/ngstarter-ui-components-split.d.ts +210 -0
  397. package/types/ngstarter-ui-components-stepper.d.ts +44 -0
  398. package/types/ngstarter-ui-components-suggestions.d.ts +32 -0
  399. package/types/ngstarter-ui-components-tab-panel.d.ts +96 -0
  400. package/types/ngstarter-ui-components-table.d.ts +277 -0
  401. package/types/ngstarter-ui-components-tabs.d.ts +145 -0
  402. package/types/ngstarter-ui-components-text-editor.d.ts +191 -0
  403. package/types/ngstarter-ui-components-thumbnail-maker.d.ts +35 -0
  404. package/types/ngstarter-ui-components-tiles.d.ts +109 -0
  405. package/types/ngstarter-ui-components-timeline.d.ts +57 -0
  406. package/types/ngstarter-ui-components-timepicker.d.ts +115 -0
  407. package/types/ngstarter-ui-components-timezone-select.d.ts +75 -0
  408. package/types/ngstarter-ui-components-toolbar.d.ts +74 -0
  409. package/types/ngstarter-ui-components-tooltip.d.ts +52 -0
  410. package/types/ngstarter-ui-components-tree.d.ts +60 -0
  411. package/types/ngstarter-ui-components-upload.d.ts +134 -0
  412. package/types/ngstarter-ui-components-video-player.d.ts +67 -0
  413. package/types/ngstarter-ui-components-video-viewer.d.ts +98 -0
  414. package/types/ngstarter-ui-components-visual-builder.d.ts +8 -0
  415. 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(/&nbsp;/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(/&nbsp;/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
@@ -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;;;;;"}