@ngbase/adk 0.1.0 → 0.1.2

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 (244) hide show
  1. package/README.md +1 -1
  2. package/accordion/accordion-item.d.ts +4 -0
  3. package/accordion/public-api.d.ts +1 -1
  4. package/autocomplete/autocomplete.d.ts +2 -2
  5. package/avatar/avatar.d.ts +1 -1
  6. package/breadcrumb/breadcrumb.d.ts +2 -3
  7. package/breadcrumb/public-api.d.ts +1 -1
  8. package/carousel/carousel.d.ts +1 -1
  9. package/chip/chip.d.ts +2 -2
  10. package/datepicker/calendar.d.ts +3 -3
  11. package/datepicker/datepicker.d.ts +2 -2
  12. package/datepicker/time.d.ts +2 -2
  13. package/dialog/dialog.d.ts +1 -1
  14. package/fesm2022/ngbase-adk-accordion.mjs +4 -1
  15. package/fesm2022/ngbase-adk-accordion.mjs.map +1 -1
  16. package/fesm2022/ngbase-adk-autocomplete.mjs +7 -36
  17. package/fesm2022/ngbase-adk-autocomplete.mjs.map +1 -1
  18. package/fesm2022/ngbase-adk-avatar.mjs +2 -2
  19. package/fesm2022/ngbase-adk-avatar.mjs.map +1 -1
  20. package/fesm2022/ngbase-adk-breadcrumb.mjs +2 -2
  21. package/fesm2022/ngbase-adk-breadcrumb.mjs.map +1 -1
  22. package/fesm2022/ngbase-adk-carousel.mjs +2 -2
  23. package/fesm2022/ngbase-adk-carousel.mjs.map +1 -1
  24. package/fesm2022/ngbase-adk-chip.mjs +4 -2
  25. package/fesm2022/ngbase-adk-chip.mjs.map +1 -1
  26. package/fesm2022/ngbase-adk-datepicker.mjs +114 -328
  27. package/fesm2022/ngbase-adk-datepicker.mjs.map +1 -1
  28. package/fesm2022/ngbase-adk-dialog.mjs +18 -19
  29. package/fesm2022/ngbase-adk-dialog.mjs.map +1 -1
  30. package/fesm2022/ngbase-adk-form-field.mjs +2 -156
  31. package/fesm2022/ngbase-adk-form-field.mjs.map +1 -1
  32. package/fesm2022/ngbase-adk-menu.mjs +15 -30
  33. package/fesm2022/ngbase-adk-menu.mjs.map +1 -1
  34. package/fesm2022/ngbase-adk-otp.mjs +164 -0
  35. package/fesm2022/ngbase-adk-otp.mjs.map +1 -0
  36. package/fesm2022/ngbase-adk-pagination.mjs +8 -65
  37. package/fesm2022/ngbase-adk-pagination.mjs.map +1 -1
  38. package/fesm2022/ngbase-adk-popover.mjs +423 -548
  39. package/fesm2022/ngbase-adk-popover.mjs.map +1 -1
  40. package/fesm2022/ngbase-adk-portal.mjs +0 -1
  41. package/fesm2022/ngbase-adk-portal.mjs.map +1 -1
  42. package/fesm2022/ngbase-adk-radio.mjs +2 -16
  43. package/fesm2022/ngbase-adk-radio.mjs.map +1 -1
  44. package/fesm2022/ngbase-adk-resizable.mjs +10 -43
  45. package/fesm2022/ngbase-adk-resizable.mjs.map +1 -1
  46. package/fesm2022/ngbase-adk-select.mjs +67 -173
  47. package/fesm2022/ngbase-adk-select.mjs.map +1 -1
  48. package/fesm2022/ngbase-adk-sheet.mjs +95 -0
  49. package/fesm2022/ngbase-adk-sheet.mjs.map +1 -0
  50. package/fesm2022/ngbase-adk-sidenav.mjs +2 -2
  51. package/fesm2022/ngbase-adk-sidenav.mjs.map +1 -1
  52. package/fesm2022/ngbase-adk-slider.mjs +9 -23
  53. package/fesm2022/ngbase-adk-slider.mjs.map +1 -1
  54. package/fesm2022/ngbase-adk-sonner.mjs +13 -63
  55. package/fesm2022/ngbase-adk-sonner.mjs.map +1 -1
  56. package/fesm2022/ngbase-adk-stepper.mjs +16 -114
  57. package/fesm2022/ngbase-adk-stepper.mjs.map +1 -1
  58. package/fesm2022/ngbase-adk-switch.mjs +2 -2
  59. package/fesm2022/ngbase-adk-switch.mjs.map +1 -1
  60. package/fesm2022/ngbase-adk-table.mjs +10 -30
  61. package/fesm2022/ngbase-adk-table.mjs.map +1 -1
  62. package/fesm2022/ngbase-adk-tabs.mjs +14 -94
  63. package/fesm2022/ngbase-adk-tabs.mjs.map +1 -1
  64. package/fesm2022/ngbase-adk-tooltip.mjs +49 -39
  65. package/fesm2022/ngbase-adk-tooltip.mjs.map +1 -1
  66. package/fesm2022/ngbase-adk-tour.mjs +1 -1
  67. package/fesm2022/ngbase-adk-tour.mjs.map +1 -1
  68. package/fesm2022/ngbase-adk-tree.mjs +11 -43
  69. package/fesm2022/ngbase-adk-tree.mjs.map +1 -1
  70. package/form-field/public-api.d.ts +0 -1
  71. package/menu/menu-trigger.d.ts +2 -2
  72. package/menu/menu.d.ts +6 -6
  73. package/otp/index.d.ts +5 -0
  74. package/{form-field → otp}/otp.d.ts +1 -1
  75. package/otp/public-api.d.ts +1 -0
  76. package/package.json +22 -13
  77. package/pagination/pagination.d.ts +5 -1
  78. package/popover/popover-arrow.ng.d.ts +34 -0
  79. package/popover/popover.d.ts +12 -3
  80. package/popover/popover.service.d.ts +5 -4
  81. package/popover/public-api.d.ts +1 -0
  82. package/popover/utils.d.ts +32 -48
  83. package/portal/dialog-ref.d.ts +0 -1
  84. package/resizable/resizable-group.d.ts +2 -2
  85. package/resizable/resizable.d.ts +2 -2
  86. package/schematics/collection.json +15 -0
  87. package/schematics/components/files/accordion/accordion.ts.template +53 -0
  88. package/schematics/components/files/accordion/index.ts.template +5 -0
  89. package/schematics/components/files/alert/alert.ts.template +62 -0
  90. package/schematics/components/files/alert/index.ts.template +1 -0
  91. package/schematics/components/files/autocomplete/autocomplete.ts.template +44 -0
  92. package/schematics/components/files/autocomplete/index.ts.template +5 -0
  93. package/schematics/components/files/avatar/avatar.ts.template +31 -0
  94. package/schematics/components/files/avatar/index.ts.template +1 -0
  95. package/schematics/components/files/badge/badge.ts.template +11 -0
  96. package/schematics/components/files/badge/index.ts.template +1 -0
  97. package/schematics/components/files/breadcrumb/breadcrumb.ts.template +49 -0
  98. package/schematics/components/files/breadcrumb/index.ts.template +1 -0
  99. package/schematics/components/files/button/button.ts.template +29 -0
  100. package/schematics/components/files/button/index.ts.template +5 -0
  101. package/schematics/components/files/card/card.ts.template +11 -0
  102. package/schematics/components/files/card/index.ts.template +5 -0
  103. package/schematics/components/files/carousel/carousel.ts.template +44 -0
  104. package/schematics/components/files/carousel/index.ts.template +1 -0
  105. package/schematics/components/files/checkbox/checkbox.ts.template +46 -0
  106. package/schematics/components/files/checkbox/focus-style.directive.ts.template +12 -0
  107. package/schematics/components/files/checkbox/index.ts.template +6 -0
  108. package/schematics/components/files/chip/chip.ts.template +36 -0
  109. package/schematics/components/files/chip/index.ts.template +1 -0
  110. package/schematics/components/files/color-picker/color-picker.ts.template +104 -0
  111. package/schematics/components/files/color-picker/index.ts.template +5 -0
  112. package/schematics/components/files/command/command.ts.template +82 -0
  113. package/schematics/components/files/command/index.ts.template +1 -0
  114. package/schematics/components/files/datepicker/calendar.ts.template +117 -0
  115. package/schematics/components/files/datepicker/datepicker.ts.template +58 -0
  116. package/schematics/components/files/datepicker/index.ts.template +2 -0
  117. package/schematics/components/files/datepicker/time.ts.template +54 -0
  118. package/schematics/components/files/dialog/dialog.ts.template +89 -0
  119. package/schematics/components/files/dialog/index.ts.template +5 -0
  120. package/schematics/components/files/drawer/drawer.ts.template +104 -0
  121. package/schematics/components/files/drawer/index.ts.template +5 -0
  122. package/schematics/components/files/form-field/form-field.ts.template +111 -0
  123. package/schematics/components/files/form-field/index.ts.template +6 -0
  124. package/schematics/components/files/form-field/input-style.directive.ts.template +11 -0
  125. package/schematics/components/files/hover-card/hover-card.ts.template +13 -0
  126. package/schematics/components/files/hover-card/index.ts.template +5 -0
  127. package/schematics/components/files/icon/icon.ts.template +16 -0
  128. package/schematics/components/files/icon/index.ts.template +1 -0
  129. package/schematics/components/files/inline-edit/index.ts.template +1 -0
  130. package/schematics/components/files/inline-edit/inline-edit.ts.template +24 -0
  131. package/schematics/components/files/keys/index.ts.template +5 -0
  132. package/schematics/components/files/keys/key.ts.template +35 -0
  133. package/schematics/components/files/list/index.ts.template +5 -0
  134. package/schematics/components/files/list/list.ts.template +28 -0
  135. package/schematics/components/files/mask/index.ts.template +1 -0
  136. package/schematics/components/files/mask/mask.ts.template +8 -0
  137. package/schematics/components/files/menu/context-menu.ts.template +14 -0
  138. package/schematics/components/files/menu/index.ts.template +8 -0
  139. package/schematics/components/files/menu/mention.ts.template +14 -0
  140. package/schematics/components/files/menu/menu.ts.template +37 -0
  141. package/schematics/components/files/menu/navigation-menu.ts.template +8 -0
  142. package/schematics/components/files/otp/index.ts.template +5 -0
  143. package/schematics/components/files/otp/otp.ts.template +37 -0
  144. package/schematics/components/files/pagination/index.ts.template +1 -0
  145. package/schematics/components/files/pagination/pagination.ts.template +71 -0
  146. package/schematics/components/files/picasa/index.ts.template +1 -0
  147. package/schematics/components/files/picasa/picasa-base.component.ts.template +80 -0
  148. package/schematics/components/files/picasa/picasa.component.ts.template +57 -0
  149. package/schematics/components/files/picasa/picasa.directive.ts.template +41 -0
  150. package/schematics/components/files/picasa/picase.service.ts.template +24 -0
  151. package/schematics/components/files/popover/index.ts.template +1 -0
  152. package/schematics/components/files/popover/popover.ts.template +64 -0
  153. package/schematics/components/files/progress/index.ts.template +5 -0
  154. package/schematics/components/files/progress/progress.ts.template +14 -0
  155. package/schematics/components/files/radio/index.ts.template +5 -0
  156. package/schematics/components/files/radio/radio.ts.template +35 -0
  157. package/schematics/components/files/resizable/index.ts.template +5 -0
  158. package/schematics/components/files/resizable/resizable.ts.template +56 -0
  159. package/schematics/components/files/scroll-area/index.ts.template +1 -0
  160. package/schematics/components/files/scroll-area/scroll-area.ts.template +40 -0
  161. package/schematics/components/files/select/index.ts.template +8 -0
  162. package/schematics/components/files/select/list-selection.ts.template +15 -0
  163. package/schematics/components/files/select/option.ts.template +35 -0
  164. package/schematics/components/files/select/select-input.ts.template +21 -0
  165. package/schematics/components/files/select/select.ts.template +96 -0
  166. package/schematics/components/files/selectable/index.ts.template +1 -0
  167. package/schematics/components/files/selectable/selectable.ts.template +34 -0
  168. package/schematics/components/files/separator/index.ts.template +5 -0
  169. package/schematics/components/files/separator/separator.ts.template +19 -0
  170. package/schematics/components/files/sheet/index.ts.template +5 -0
  171. package/schematics/components/files/sheet/sheet.ts.template +69 -0
  172. package/schematics/components/files/sidenav/index.ts.template +1 -0
  173. package/schematics/components/files/sidenav/sidenav.ts.template +48 -0
  174. package/schematics/components/files/skeleton/index.ts.template +1 -0
  175. package/schematics/components/files/skeleton/skeleton.ts.template +15 -0
  176. package/schematics/components/files/slider/index.ts.template +5 -0
  177. package/schematics/components/files/slider/slider.ts.template +35 -0
  178. package/schematics/components/files/sonner/index.ts.template +5 -0
  179. package/schematics/components/files/sonner/sonner.ts.template +59 -0
  180. package/schematics/components/files/spinner/index.ts.template +1 -0
  181. package/schematics/components/files/spinner/spinner.ts.template +79 -0
  182. package/schematics/components/files/stepper/index.ts.template +1 -0
  183. package/schematics/components/files/stepper/stepper.ts.template +88 -0
  184. package/schematics/components/files/switch/index.ts.template +5 -0
  185. package/schematics/components/files/switch/switch.ts.template +29 -0
  186. package/schematics/components/files/table/body-cell.ts.template +19 -0
  187. package/schematics/components/files/table/body-row.ts.template +21 -0
  188. package/schematics/components/files/table/column.ts.template +8 -0
  189. package/schematics/components/files/table/head-cell.ts.template +19 -0
  190. package/schematics/components/files/table/head-row.ts.template +27 -0
  191. package/schematics/components/files/table/index.ts.template +26 -0
  192. package/schematics/components/files/table/table.ts.template +20 -0
  193. package/schematics/components/files/tabs/index.ts.template +5 -0
  194. package/schematics/components/files/tabs/tab.ts.template +92 -0
  195. package/schematics/components/files/theme/index.ts.template +2 -0
  196. package/schematics/components/files/theme/theme-button.component.ts.template +26 -0
  197. package/schematics/components/files/theme/theme.service.ts.template +33 -0
  198. package/schematics/components/files/toggle/index.ts.template +5 -0
  199. package/schematics/components/files/toggle/toggle.ts.template +13 -0
  200. package/schematics/components/files/toggle-group/index.ts.template +5 -0
  201. package/schematics/components/files/toggle-group/toggle-group.ts.template +25 -0
  202. package/schematics/components/files/tooltip/index.ts.template +5 -0
  203. package/schematics/components/files/tooltip/tooltip.ts.template +45 -0
  204. package/schematics/components/files/tour/index.ts.template +1 -0
  205. package/schematics/components/files/tour/tour.ts.template +19 -0
  206. package/schematics/components/files/tree/index.ts.template +1 -0
  207. package/schematics/components/files/tree/tree.ts.template +66 -0
  208. package/schematics/components/index.d.ts +3 -0
  209. package/schematics/components/index.js +17 -0
  210. package/schematics/components/index.js.map +1 -0
  211. package/schematics/components/index.ts +29 -0
  212. package/schematics/components/schema.d.ts +6 -0
  213. package/schematics/components/schema.js +3 -0
  214. package/schematics/components/schema.js.map +1 -0
  215. package/schematics/components/schema.json +145 -0
  216. package/schematics/components/schema.ts +6 -0
  217. package/select/option-group.d.ts +3 -3
  218. package/select/select.d.ts +2 -2
  219. package/sheet/index.d.ts +5 -0
  220. package/sheet/public-api.d.ts +2 -0
  221. package/sheet/sheet.d.ts +26 -0
  222. package/sheet/sheet.service.d.ts +13 -0
  223. package/sidenav/public-api.d.ts +1 -1
  224. package/sidenav/sidenav.d.ts +1 -1
  225. package/slider/public-api.d.ts +1 -1
  226. package/slider/slider.d.ts +5 -5
  227. package/sonner/sonner.d.ts +2 -1
  228. package/stepper/animation.d.ts +1 -1
  229. package/stepper/step.d.ts +1 -1
  230. package/stepper/stepper.d.ts +2 -2
  231. package/switch/switch.d.ts +1 -1
  232. package/table/body-row.d.ts +3 -3
  233. package/table/head-row.d.ts +3 -3
  234. package/table/table.d.ts +1 -1
  235. package/tabs/tab-group.d.ts +4 -4
  236. package/tabs/tab.d.ts +2 -2
  237. package/tooltip/public-api.d.ts +1 -1
  238. package/tooltip/tooltip.d.ts +5 -1
  239. package/tooltip/tooltip.directive.d.ts +1 -1
  240. package/tooltip/tooltip.service.d.ts +4 -2
  241. package/tour/tour.service.d.ts +3 -4
  242. package/tree/public-api.d.ts +2 -2
  243. package/tree/tree-node.d.ts +2 -2
  244. package/tree/tree.d.ts +2 -2
@@ -0,0 +1,33 @@
1
+ import { inject, Injectable, signal } from '@angular/core';
2
+ import { isClient } from '@ngbase/adk/utils';
3
+
4
+ @Injectable({ providedIn: 'root' })
5
+ export class ThemeService {
6
+ mode = signal<'light' | 'dark' | ''>('light');
7
+
8
+ constructor() {
9
+ if (isClient()) {
10
+ const theme = localStorage.getItem('theme');
11
+ this._update((theme as 'light' | 'dark') || 'light');
12
+
13
+ // registerShortcut('ctrl+h', () => this.open());
14
+ }
15
+ }
16
+
17
+ toggle() {
18
+ this._update(this.mode() === 'dark' ? 'light' : 'dark');
19
+ }
20
+
21
+ private _update(mode: 'light' | 'dark' = 'light') {
22
+ const body = document.body;
23
+ if (mode === 'dark') {
24
+ body.classList.add('dark');
25
+ } else {
26
+ body.classList.remove('dark');
27
+ }
28
+ localStorage.setItem('theme', mode);
29
+ this.mode.set(mode);
30
+ }
31
+ }
32
+
33
+ export const injectTheme = () => inject(ThemeService);
@@ -0,0 +1,5 @@
1
+ /*
2
+ * Public API Surface of toggle
3
+ */
4
+
5
+ export * from './toggle';
@@ -0,0 +1,13 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { NgbToggle } from '@ngbase/adk/toggle';
3
+
4
+ @Component({
5
+ selector: 'button[<%= name %>Toggle]',
6
+ changeDetection: ChangeDetectionStrategy.OnPush,
7
+ hostDirectives: [{ directive: NgbToggle, inputs: ['value'], outputs: ['valueChange'] }],
8
+ template: `<ng-content />`,
9
+ host: {
10
+ class: 'block w-9 h-9 rounded relative aria-[pressed=true]:bg-background',
11
+ },
12
+ })
13
+ export class Toggle {}
@@ -0,0 +1,5 @@
1
+ /*
2
+ * Public API Surface of toggle-group
3
+ */
4
+
5
+ export * from './toggle-group';
@@ -0,0 +1,25 @@
1
+ import { ChangeDetectionStrategy, Component, Directive } from '@angular/core';
2
+ import { NgbToggleGroup, NgbToggleItem } from '@ngbase/adk/toggle-group';
3
+
4
+ @Component({
5
+ selector: '<%= name %>-toggle-group',
6
+ changeDetection: ChangeDetectionStrategy.OnPush,
7
+ hostDirectives: [
8
+ { directive: NgbToggleGroup, inputs: ['value', 'multiple'], outputs: ['valueChange'] },
9
+ ],
10
+ template: ` <ng-content select="[<%= name %>ToggleItem]" /> `,
11
+ host: {
12
+ class: 'flex gap-1',
13
+ },
14
+ })
15
+ export class ToggleGroup<T> {}
16
+
17
+ @Directive({
18
+ selector: 'button[<%= name %>ToggleItem]',
19
+ hostDirectives: [{ directive: NgbToggleItem, inputs: ['disabled', 'value'] }],
20
+ host: {
21
+ class:
22
+ 'inline-block rounded h-9 px-3 hover:bg-opacity-80 active:bg-opacity-70 aria-[selected=true]:bg-background',
23
+ },
24
+ })
25
+ export class ToggleItem<T> {}
@@ -0,0 +1,5 @@
1
+ /*
2
+ * Public API Surface of tooltip
3
+ */
4
+
5
+ export { provideTooltipOptions, Tooltip } from './tooltip';
@@ -0,0 +1,45 @@
1
+ import { ChangeDetectionStrategy, Component, Directive } from '@angular/core';
2
+ import { injectTheme } from '<%= basepath %>/theme';
3
+ import { NgbPopoverArrow, providePopoverArrowTracker } from '@ngbase/adk/popover';
4
+ import {
5
+ NgbTooltip,
6
+ NgbTooltipTemplate,
7
+ provideNgbTooltipOptions,
8
+ tooltipAnimation,
9
+ TooltipOptions,
10
+ } from '@ngbase/adk/tooltip';
11
+
12
+ @Directive({
13
+ selector: '[<%= name %>Tooltip]',
14
+ hostDirectives: [
15
+ {
16
+ directive: NgbTooltip,
17
+ inputs: [
18
+ 'ngbTooltip: <%= name %>Tooltip',
19
+ 'ngbTooltipPosition: <%= name %>TooltipPosition',
20
+ 'delay',
21
+ ],
22
+ },
23
+ ],
24
+ })
25
+ export class Tooltip {}
26
+
27
+ @Component({
28
+ selector: '<%= name %>-tooltip',
29
+ changeDetection: ChangeDetectionStrategy.OnPush,
30
+ providers: [providePopoverArrowTracker()],
31
+ imports: [NgbPopoverArrow],
32
+ template: `<div ngbPopoverArrow>{{ content() }}</div>`,
33
+ host: {
34
+ class:
35
+ 'fixed inline-block rounded-lg bg-foreground px-3 py-1 border shadow-md z-p whitespace-pre-line max-w-[15rem] text-text',
36
+ '[class]': `theme.mode() === 'dark' ? 'light' : 'dark'`,
37
+ },
38
+ animations: [tooltipAnimation],
39
+ })
40
+ export class TooltipComponent extends NgbTooltipTemplate {
41
+ readonly theme = injectTheme();
42
+ }
43
+
44
+ export const provideTooltipOptions = (options: TooltipOptions) =>
45
+ provideNgbTooltipOptions({ ...options, component: TooltipComponent });
@@ -0,0 +1 @@
1
+ export * from './tour';
@@ -0,0 +1,19 @@
1
+ import { Directive, inject, InjectionToken } from '@angular/core';
2
+ import { NgbTour, NgbTourService, NgbTourStep } from '@ngbase/adk/tour';
3
+
4
+ export const TourService = new InjectionToken<NgbTourService>('TourService', {
5
+ providedIn: 'root',
6
+ factory: () => inject(NgbTourService),
7
+ });
8
+
9
+ @Directive({
10
+ selector: '[<%= name %>Tour]',
11
+ hostDirectives: [NgbTour],
12
+ })
13
+ export class Tour {}
14
+
15
+ @Directive({
16
+ selector: '[<%= name %>TourStep]',
17
+ hostDirectives: [{ directive: NgbTourStep, inputs: ['ngbTourStep: <%= name %>TourStep'] }],
18
+ })
19
+ export class TourStep {}
@@ -0,0 +1 @@
1
+ export * from './tree';
@@ -0,0 +1,66 @@
1
+ import { ChangeDetectionStrategy, Component, Directive, signal } from '@angular/core';
2
+ import {
3
+ NgbTree,
4
+ NgbTreeNode,
5
+ NgbTreeNodeContent,
6
+ NgbTreeNodeDef,
7
+ NgbTreeNodeToggle,
8
+ aliasTree,
9
+ aliasTreeNode,
10
+ } from '@ngbase/adk/tree';
11
+
12
+ @Component({
13
+ selector: '<%= name %>-tree',
14
+ exportAs: '<%= name %>Tree',
15
+ changeDetection: ChangeDetectionStrategy.OnPush,
16
+ providers: [aliasTree(Tree)],
17
+ template: `<ng-container #container />`,
18
+ host: {
19
+ class: 'block',
20
+ },
21
+ })
22
+ export class Tree<T> extends NgbTree<T> {}
23
+
24
+ @Component({
25
+ selector: '<%= name %>-tree-node',
26
+ exportAs: '<%= name %>TreeNode',
27
+ changeDetection: ChangeDetectionStrategy.OnPush,
28
+ template: `
29
+ <div class="flex items-start">
30
+ <ng-content />
31
+ </div>
32
+ <ng-content select="[<%= name %>TreeNodeContent]" />
33
+ <ng-container #container />
34
+ `,
35
+ providers: [provideTreeNode(TreeNode)],
36
+ host: {
37
+ class: 'block w-full cursor-pointer',
38
+ },
39
+ })
40
+ export class TreeNode<T> extends NgbTreeNode<T> {
41
+ override size = signal(16);
42
+ }
43
+
44
+ @Directive({
45
+ selector: '[<%= name %>TreeNodeToggle]',
46
+ hostDirectives: [NgbTreeNodeToggle],
47
+ host: {
48
+ class: `aria-[hidden="true"]:invisible`,
49
+ },
50
+ })
51
+ export class TreeNodeToggle {}
52
+
53
+ @Directive({
54
+ selector: '[<%= name %>TreeNodeDef]',
55
+ hostDirectives: [NgbTreeNodeDef],
56
+ })
57
+ export class TreeNodeDef<T> {}
58
+
59
+ @Directive({
60
+ selector: '[<%= name %>TreeNodeContent]',
61
+ hostDirectives: [NgbTreeNodeContent],
62
+ host: {
63
+ class: 'ml-8',
64
+ },
65
+ })
66
+ export class TreeNodeContent {}
@@ -0,0 +1,3 @@
1
+ import { Rule } from '@angular-devkit/schematics';
2
+ import { MyGeneratorSchema } from './schema';
3
+ export declare function myGenerator(options: MyGeneratorSchema): Rule;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.myGenerator = myGenerator;
4
+ const schematics_1 = require("@angular-devkit/schematics");
5
+ const core_1 = require("@angular-devkit/core");
6
+ function myGenerator(options) {
7
+ return () => {
8
+ const sourceTemplates = (0, schematics_1.url)(`./files/${options.component}`);
9
+ const targetPath = options.path || '';
10
+ const sourceParametrizedTemplates = (0, schematics_1.apply)(sourceTemplates, [
11
+ (0, schematics_1.applyTemplates)(Object.assign(Object.assign({}, core_1.strings), options)),
12
+ (0, schematics_1.move)((0, core_1.normalize)(`/${targetPath}/${options.component}`)),
13
+ ]);
14
+ return (0, schematics_1.chain)([(0, schematics_1.mergeWith)(sourceParametrizedTemplates)]);
15
+ };
16
+ }
17
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../projects/adk/schematics/components/index.ts"],"names":[],"mappings":";;AAYA,kCAgBC;AA5BD,2DAQoC;AACpC,+CAA0D;AAG1D,SAAgB,WAAW,CAAC,OAA0B;IACpD,OAAO,GAAG,EAAE;QACV,MAAM,eAAe,GAAG,IAAA,gBAAG,EAAC,WAAW,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;QAE5D,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC;QAEtC,MAAM,2BAA2B,GAAG,IAAA,kBAAK,EAAC,eAAe,EAAE;YACzD,IAAA,2BAAc,kCACT,cAAO,GACP,OAAO,EACV;YACF,IAAA,iBAAI,EAAC,IAAA,gBAAS,EAAC,IAAI,UAAU,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;SACvD,CAAC,CAAC;QAEH,OAAO,IAAA,kBAAK,EAAC,CAAC,IAAA,sBAAS,EAAC,2BAA2B,CAAC,CAAC,CAAC,CAAC;IACzD,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,29 @@
1
+ import {
2
+ Rule,
3
+ apply,
4
+ mergeWith,
5
+ move,
6
+ applyTemplates,
7
+ url,
8
+ chain,
9
+ } from '@angular-devkit/schematics';
10
+ import { strings, normalize } from '@angular-devkit/core';
11
+ import { MyGeneratorSchema } from './schema';
12
+
13
+ export function myGenerator(options: MyGeneratorSchema): Rule {
14
+ return () => {
15
+ const sourceTemplates = url(`./files/${options.component}`);
16
+
17
+ const targetPath = options.path || '';
18
+
19
+ const sourceParametrizedTemplates = apply(sourceTemplates, [
20
+ applyTemplates({
21
+ ...strings,
22
+ ...options,
23
+ }),
24
+ move(normalize(`/${targetPath}/${options.component}`)),
25
+ ]);
26
+
27
+ return chain([mergeWith(sourceParametrizedTemplates)]);
28
+ };
29
+ }
@@ -0,0 +1,6 @@
1
+ export interface MyGeneratorSchema {
2
+ name: string;
3
+ path?: string;
4
+ project?: string;
5
+ component: string;
6
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../projects/adk/schematics/components/schema.ts"],"names":[],"mappings":""}
@@ -0,0 +1,145 @@
1
+ {
2
+ "$schema": "http://json-schema.org/schema",
3
+ "$id": "SchematicsAccordion",
4
+ "title": "Accordion Schema",
5
+ "type": "object",
6
+ "properties": {
7
+ "name": {
8
+ "description": "The name of the component prefix.",
9
+ "x-prompt": "What is the name of the component prefix?",
10
+ "type": "string"
11
+ },
12
+ "path": {
13
+ "description": "Where should be created the file",
14
+ "type": "string",
15
+ "format": "path",
16
+ "x-prompt": "Where should be created the file?",
17
+ "default": "src/app"
18
+ },
19
+ "basepath": {
20
+ "description": "The base path of the UI library.",
21
+ "type": "string",
22
+ "format": "path",
23
+ "x-prompt": "What is the base path of the UI library?",
24
+ "default": "@"
25
+ },
26
+ "component": {
27
+ "description": "The file extension or preprocessor to use for style files.",
28
+ "type": "string",
29
+ "default": "accordion",
30
+ "enum": [
31
+ "accordion",
32
+ "alert",
33
+ "autocomplete",
34
+ "avatar",
35
+ "badge",
36
+ "breadcrumb",
37
+ "button",
38
+ "card",
39
+ "carousel",
40
+ "checkbox",
41
+ "chip",
42
+ "color-picker",
43
+ "command",
44
+ "datepicker",
45
+ "dialog",
46
+ "drawer",
47
+ "form-field",
48
+ "hover-card",
49
+ "icon",
50
+ "inline-edit",
51
+ "keys",
52
+ "list",
53
+ "mask",
54
+ "menu",
55
+ "otp",
56
+ "pagination",
57
+ "popover",
58
+ "progress",
59
+ "radio",
60
+ "resizable",
61
+ "scroll-area",
62
+ "select",
63
+ "selectable",
64
+ "separator",
65
+ "sheet",
66
+ "sidenav",
67
+ "skeleton",
68
+ "slider",
69
+ "sonner",
70
+ "spinner",
71
+ "stepper",
72
+ "switch",
73
+ "table",
74
+ "tabs",
75
+ "toggle",
76
+ "toggle-group",
77
+ "tooltip",
78
+ "tour",
79
+ "tree"
80
+ ],
81
+ "x-prompt": {
82
+ "message": "Which component would you like to create?",
83
+ "type": "list",
84
+ "items": [
85
+ { "value": "accordion", "label": "Accordion" },
86
+ { "value": "alert", "label": "Alert" },
87
+ { "value": "autocomplete", "label": "Autocomplete" },
88
+ { "value": "avatar", "label": "Avatar" },
89
+ { "value": "badge", "label": "Badge" },
90
+ { "value": "breadcrumb", "label": "Breadcrumb" },
91
+ { "value": "button", "label": "Button" },
92
+ { "value": "card", "label": "Card" },
93
+ { "value": "carousel", "label": "Carousel" },
94
+ { "value": "checkbox", "label": "Checkbox" },
95
+ { "value": "chip", "label": "Chip" },
96
+ { "value": "color-picker", "label": "Color Picker" },
97
+ { "value": "command", "label": "Command" },
98
+ { "value": "datepicker", "label": "Datepicker" },
99
+ { "value": "dialog", "label": "Dialog" },
100
+ { "value": "drawer", "label": "Drawer" },
101
+ { "value": "form-field", "label": "Form Field" },
102
+ { "value": "hover-card", "label": "Hover Card" },
103
+ { "value": "icon", "label": "Icon" },
104
+ { "value": "inline-edit", "label": "Inline Edit" },
105
+ { "value": "keys", "label": "Keys" },
106
+ { "value": "list", "label": "List" },
107
+ { "value": "mask", "label": "Mask" },
108
+ { "value": "menu", "label": "Menu" },
109
+ { "value": "otp", "label": "OTP" },
110
+ { "value": "pagination", "label": "Pagination" },
111
+ { "value": "popover", "label": "Popover" },
112
+ { "value": "progress", "label": "Progress" },
113
+ { "value": "radio", "label": "Radio" },
114
+ { "value": "resizable", "label": "Resizable" },
115
+ { "value": "scroll-area", "label": "Scroll Area" },
116
+ { "value": "select", "label": "Select" },
117
+ { "value": "selectable", "label": "Selectable" },
118
+ { "value": "separator", "label": "Separator" },
119
+ { "value": "sheet", "label": "Sheet" },
120
+ { "value": "sidenav", "label": "Sidenav" },
121
+ { "value": "skeleton", "label": "Skeleton" },
122
+ { "value": "slider", "label": "Slider" },
123
+ { "value": "sonner", "label": "Sonner" },
124
+ { "value": "spinner", "label": "Spinner" },
125
+ { "value": "stepper", "label": "Stepper" },
126
+ { "value": "switch", "label": "Switch" },
127
+ { "value": "table", "label": "Table" },
128
+ { "value": "tabs", "label": "Tabs" },
129
+ { "value": "toggle", "label": "Toggle" },
130
+ { "value": "toggle-group", "label": "Toggle Group" },
131
+ { "value": "tooltip", "label": "Tooltip" },
132
+ { "value": "tour", "label": "Tour" },
133
+ { "value": "tree", "label": "Tree" }
134
+ ]
135
+ },
136
+ "project": {
137
+ "type": "string",
138
+ "description": "The name of the project.",
139
+ "$default": {
140
+ "$source": "projectName"
141
+ }
142
+ }
143
+ }
144
+ }
145
+ }
@@ -0,0 +1,6 @@
1
+ export interface MyGeneratorSchema {
2
+ name: string;
3
+ path?: string;
4
+ project?: string;
5
+ component: string;
6
+ }
@@ -1,7 +1,7 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class NgbOptionGroup {
3
- label: import("@angular/core").InputSignal<string>;
4
- disabled: import("@angular/core").InputSignal<boolean>;
3
+ readonly label: import("@angular/core").InputSignal<string>;
4
+ readonly disabled: import("@angular/core").InputSignal<boolean>;
5
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbOptionGroup, never>;
6
- static ɵcmp: i0.ɵɵComponentDeclaration<NgbOptionGroup, "[ngbOptionGroup]", never, { "label": { "alias": "label"; "required": true; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
6
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbOptionGroup, "[ngbOptionGroup]", never, { "label": { "alias": "label"; "required": true; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
7
7
  }
@@ -35,9 +35,9 @@ export declare class NgbSelect<T> extends SelectBase<T> {
35
35
  };
36
36
  constructor();
37
37
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbSelect<any>, never>;
38
- static ɵcmp: i0.ɵɵComponentDeclaration<NgbSelect<any>, "[ngbSelect]", never, { "search": { "alias": "search"; "required": false; "isSignal": true; }; }, { "search": "searchChange"; }, ["optionTemplate"], [".select-prefix", "[ngbSelectTrigger]", "[ngbSelectInput]", "*"], true, never>;
38
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbSelect<any>, "[ngbSelect]", never, { "search": { "alias": "search"; "required": false; "isSignal": true; }; }, { "search": "searchChange"; }, ["optionTemplate"], never, true, never>;
39
39
  }
40
- export declare function provideSelect(select: typeof NgbSelect): (({
40
+ export declare function aliasSelect(select: typeof NgbSelect): (({
41
41
  provide: import("@angular/core").InjectionToken<readonly import("@angular/forms").ControlValueAccessor[]>;
42
42
  useExisting: import("@angular/core").Type<any>;
43
43
  multi: boolean;
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ /// <amd-module name="@ngbase/adk/sheet" />
5
+ export * from './public-api';
@@ -0,0 +1,2 @@
1
+ export * from './sheet.service';
2
+ export * from './sheet';
@@ -0,0 +1,26 @@
1
+ import { OnDestroy, ViewContainerRef } from '@angular/core';
2
+ import { BaseDialog } from '@ngbase/adk/portal';
3
+ import { SheetOptions } from './sheet.service';
4
+ import * as i0 from "@angular/core";
5
+ export declare class NgbSheetContainer extends BaseDialog implements OnDestroy {
6
+ myDialog: import("@angular/core").Signal<ViewContainerRef | undefined>;
7
+ readonly dir: import("@ngbase/adk/bidi").Directionality;
8
+ backdropColor: boolean;
9
+ options: SheetOptions;
10
+ classNames: string;
11
+ isHideHeader: boolean;
12
+ readonly position: import("@angular/core").Signal<{
13
+ params: {
14
+ outTransform: string;
15
+ };
16
+ }>;
17
+ constructor();
18
+ setOptions(options: SheetOptions): void;
19
+ ngOnDestroy(): void;
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgbSheetContainer, never>;
21
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbSheetContainer, "mee-sheet", never, {}, {}, never, never, true, never>;
22
+ }
23
+ export declare function aliasSheet(dialog: typeof NgbSheetContainer): {
24
+ provide: typeof NgbSheetContainer;
25
+ useExisting: typeof NgbSheetContainer;
26
+ };
@@ -0,0 +1,13 @@
1
+ import { DialogInput, DialogOptions } from '@ngbase/adk/portal';
2
+ import { NgbSheetContainer } from './sheet';
3
+ export declare class SheetOptions extends DialogOptions {
4
+ position?: 'left' | 'right';
5
+ }
6
+ export declare function ngbSheetPortal(component: typeof NgbSheetContainer): {
7
+ open: <T>(component: DialogInput, opt?: SheetOptions) => {
8
+ afterClosed: import("rxjs").Observable<any>;
9
+ close: (data?: any) => void;
10
+ };
11
+ closeAll: () => void;
12
+ };
13
+ export type NgbSheet = ReturnType<typeof ngbSheetPortal>;
@@ -1,3 +1,3 @@
1
- export { NgbSidenav, NgbSidenavOverlay, provideSidenav } from './sidenav';
1
+ export { NgbSidenav, NgbSidenavOverlay, aliasSidenav } from './sidenav';
2
2
  export { NgbSidenavHeader, NgbSidenavHeaderContent, NgbSidenavHeaderTrack, slideAnimation, } from './sidenav-header';
3
3
  export { type SidenavType } from './sidenav.service';
@@ -17,7 +17,7 @@ export declare class NgbSidenav {
17
17
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbSidenav, never>;
18
18
  static ɵdir: i0.ɵɵDirectiveDeclaration<NgbSidenav, "[ngbSidenav]", ["ngbSidenav"], { "show": { "alias": "show"; "required": false; "isSignal": true; }; "mode": { "alias": "mode"; "required": false; "isSignal": true; }; }, { "show": "showChange"; }, never, never, true, never>;
19
19
  }
20
- export declare const provideSidenav: (sidenav: Type<NgbSidenav>) => (typeof SidenavService | {
20
+ export declare const aliasSidenav: (sidenav: Type<NgbSidenav>) => (typeof SidenavService | {
21
21
  provide: typeof NgbSidenav;
22
22
  useExisting: Type<NgbSidenav>;
23
23
  })[];
@@ -1 +1 @@
1
- export { NgbSlider, SliderTrack, SliderRange, SliderThumb, provideSlider } from './slider';
1
+ export { NgbSlider, SliderTrack, SliderRange, SliderThumb, aliasSlider } from './slider';
@@ -1,4 +1,4 @@
1
- import { ElementRef, Type } from '@angular/core';
1
+ import { ElementRef } from '@angular/core';
2
2
  import { ControlValueAccessor } from '@angular/forms';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@ngbase/adk/drag";
@@ -61,13 +61,13 @@ export declare class NgbSlider implements ControlValueAccessor {
61
61
  private updateValue;
62
62
  private notifyChange;
63
63
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbSlider, never>;
64
- static ɵcmp: i0.ɵɵComponentDeclaration<NgbSlider, "[ngbSlider]", ["ngbSlider"], { "value": { "alias": "value"; "required": false; "isSignal": true; }; "step": { "alias": "step"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "range": { "alias": "range"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "orientation": { "alias": "orientation"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; }, never, never, true, never>;
64
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbSlider, "[ngbSlider]", ["ngbSlider"], { "value": { "alias": "value"; "required": false; "isSignal": true; }; "step": { "alias": "step"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "range": { "alias": "range"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "orientation": { "alias": "orientation"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; }, never, never, true, never>;
65
65
  }
66
- export declare const provideSlider: (slider: Type<NgbSlider>) => ({
66
+ export declare const aliasSlider: (slider: typeof NgbSlider) => ({
67
67
  provide: import("@angular/core").InjectionToken<readonly import("@angular/forms").ControlValueAccessor[]>;
68
- useExisting: Type<any>;
68
+ useExisting: import("@angular/core").Type<any>;
69
69
  multi: boolean;
70
70
  } | {
71
71
  provide: typeof NgbSlider;
72
- useExisting: Type<NgbSlider>;
72
+ useExisting: typeof NgbSlider;
73
73
  })[];
@@ -1,4 +1,5 @@
1
1
  import * as i0 from "@angular/core";
2
+ export declare const sonnerAnimation: import("@angular/animations").AnimationTriggerMetadata;
2
3
  export declare class SonnerBase {
3
4
  readonly ngbSonnerBase: import("@angular/core").InputSignal<number>;
4
5
  static ɵfac: i0.ɵɵFactoryDeclaration<SonnerBase, never>;
@@ -9,7 +10,7 @@ export declare class NgbSonner {
9
10
  addMessage(message: string, type: SonnerType, data?: SonnerData): void;
10
11
  clear(): void;
11
12
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbSonner, never>;
12
- static ɵcmp: i0.ɵɵComponentDeclaration<NgbSonner, "ngb-sonner", never, {}, {}, never, never, true, never>;
13
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbSonner, "ngb-sonner", never, {}, {}, never, never, true, never>;
13
14
  }
14
15
  export interface SonnerMessage {
15
16
  message: string;
@@ -1 +1 @@
1
- export declare const slideAnimation: import("@angular/animations").AnimationTriggerMetadata;
1
+ export declare const stepperAnimation: import("@angular/animations").AnimationTriggerMetadata;
package/stepper/step.d.ts CHANGED
@@ -12,7 +12,7 @@ export declare class NgbStep {
12
12
  readonly horizontalTemplate: import("@angular/core").Signal<false | TemplateRef<any> | null>;
13
13
  readonly verticalTemplate: import("@angular/core").Signal<false | TemplateRef<any> | null>;
14
14
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbStep, never>;
15
- static ɵcmp: i0.ɵɵComponentDeclaration<NgbStep, "[ngbStep]", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; }, {}, ["header"], ["*"], true, never>;
15
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbStep, "[ngbStep]", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; }, {}, ["header"], never, true, never>;
16
16
  }
17
17
  export declare class NgbStepHeader {
18
18
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbStepHeader, never>;
@@ -18,9 +18,9 @@ export declare class NgbStepper {
18
18
  nextStep(): void;
19
19
  prevStep(): void;
20
20
  static ɵfac: i0.ɵɵFactoryDeclaration<NgbStepper, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<NgbStepper, "[ngbStepper]", ["ngbStepper"], { "activeIndex": { "alias": "activeIndex"; "required": false; "isSignal": true; }; "direction": { "alias": "direction"; "required": false; "isSignal": true; }; }, { "activeIndex": "activeIndexChange"; }, ["steps"], ["*"], true, never>;
21
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgbStepper, "[ngbStepper]", ["ngbStepper"], { "activeIndex": { "alias": "activeIndex"; "required": false; "isSignal": true; }; "direction": { "alias": "direction"; "required": false; "isSignal": true; }; }, { "activeIndex": "activeIndexChange"; }, ["steps"], never, true, never>;
22
22
  }
23
- export declare const provideStepper: (stepper: typeof NgbStepper) => {
23
+ export declare const aliasStepper: (stepper: typeof NgbStepper) => {
24
24
  provide: typeof NgbStepper;
25
25
  useExisting: typeof NgbStepper;
26
26
  };