@ngbase/adk 0.1.3 → 0.1.5

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 (127) hide show
  1. package/package.json +13 -13
  2. package/schematics/collection.json +15 -0
  3. package/schematics/components/files/accordion/accordion.ts.template +53 -0
  4. package/schematics/components/files/accordion/index.ts.template +5 -0
  5. package/schematics/components/files/alert/alert.ts.template +62 -0
  6. package/schematics/components/files/alert/index.ts.template +1 -0
  7. package/schematics/components/files/autocomplete/autocomplete.ts.template +44 -0
  8. package/schematics/components/files/autocomplete/index.ts.template +5 -0
  9. package/schematics/components/files/avatar/avatar.ts.template +31 -0
  10. package/schematics/components/files/avatar/index.ts.template +1 -0
  11. package/schematics/components/files/badge/badge.ts.template +11 -0
  12. package/schematics/components/files/badge/index.ts.template +1 -0
  13. package/schematics/components/files/breadcrumb/breadcrumb.ts.template +53 -0
  14. package/schematics/components/files/breadcrumb/index.ts.template +1 -0
  15. package/schematics/components/files/button/button.ts.template +29 -0
  16. package/schematics/components/files/button/index.ts.template +5 -0
  17. package/schematics/components/files/card/card.ts.template +11 -0
  18. package/schematics/components/files/card/index.ts.template +5 -0
  19. package/schematics/components/files/carousel/carousel.ts.template +44 -0
  20. package/schematics/components/files/carousel/index.ts.template +1 -0
  21. package/schematics/components/files/checkbox/checkbox.ts.template +36 -0
  22. package/schematics/components/files/checkbox/focus-style.directive.ts.template +12 -0
  23. package/schematics/components/files/checkbox/index.ts.template +6 -0
  24. package/schematics/components/files/chip/chip.ts.template +38 -0
  25. package/schematics/components/files/chip/index.ts.template +1 -0
  26. package/schematics/components/files/color-picker/color-picker.ts.template +104 -0
  27. package/schematics/components/files/color-picker/index.ts.template +5 -0
  28. package/schematics/components/files/command/command.ts.template +82 -0
  29. package/schematics/components/files/command/index.ts.template +1 -0
  30. package/schematics/components/files/datepicker/calendar.ts.template +117 -0
  31. package/schematics/components/files/datepicker/datepicker.ts.template +59 -0
  32. package/schematics/components/files/datepicker/index.ts.template +2 -0
  33. package/schematics/components/files/datepicker/time.ts.template +54 -0
  34. package/schematics/components/files/dialog/dialog.ts.template +89 -0
  35. package/schematics/components/files/dialog/index.ts.template +5 -0
  36. package/schematics/components/files/drawer/drawer.ts.template +104 -0
  37. package/schematics/components/files/drawer/index.ts.template +5 -0
  38. package/schematics/components/files/form-field/form-field.ts.template +111 -0
  39. package/schematics/components/files/form-field/index.ts.template +6 -0
  40. package/schematics/components/files/form-field/input-style.directive.ts.template +11 -0
  41. package/schematics/components/files/hover-card/hover-card.ts.template +13 -0
  42. package/schematics/components/files/hover-card/index.ts.template +5 -0
  43. package/schematics/components/files/icon/icon.ts.template +16 -0
  44. package/schematics/components/files/icon/index.ts.template +1 -0
  45. package/schematics/components/files/inline-edit/index.ts.template +1 -0
  46. package/schematics/components/files/inline-edit/inline-edit.ts.template +24 -0
  47. package/schematics/components/files/keys/index.ts.template +5 -0
  48. package/schematics/components/files/keys/key.ts.template +35 -0
  49. package/schematics/components/files/list/index.ts.template +5 -0
  50. package/schematics/components/files/list/list.ts.template +28 -0
  51. package/schematics/components/files/mask/index.ts.template +1 -0
  52. package/schematics/components/files/mask/mask.ts.template +8 -0
  53. package/schematics/components/files/menu/context-menu.ts.template +14 -0
  54. package/schematics/components/files/menu/index.ts.template +8 -0
  55. package/schematics/components/files/menu/mention.ts.template +14 -0
  56. package/schematics/components/files/menu/menu.ts.template +37 -0
  57. package/schematics/components/files/menu/navigation-menu.ts.template +8 -0
  58. package/schematics/components/files/otp/index.ts.template +5 -0
  59. package/schematics/components/files/otp/otp.ts.template +37 -0
  60. package/schematics/components/files/pagination/index.ts.template +1 -0
  61. package/schematics/components/files/pagination/pagination.ts.template +75 -0
  62. package/schematics/components/files/picasa/index.ts.template +1 -0
  63. package/schematics/components/files/picasa/picasa-base.component.ts.template +80 -0
  64. package/schematics/components/files/picasa/picasa.component.ts.template +57 -0
  65. package/schematics/components/files/picasa/picasa.directive.ts.template +41 -0
  66. package/schematics/components/files/picasa/picase.service.ts.template +24 -0
  67. package/schematics/components/files/popover/index.ts.template +1 -0
  68. package/schematics/components/files/popover/popover.ts.template +64 -0
  69. package/schematics/components/files/progress/index.ts.template +5 -0
  70. package/schematics/components/files/progress/progress.ts.template +14 -0
  71. package/schematics/components/files/radio/index.ts.template +5 -0
  72. package/schematics/components/files/radio/radio.ts.template +37 -0
  73. package/schematics/components/files/resizable/index.ts.template +5 -0
  74. package/schematics/components/files/resizable/resizable.ts.template +59 -0
  75. package/schematics/components/files/scroll-area/index.ts.template +1 -0
  76. package/schematics/components/files/scroll-area/scroll-area.ts.template +40 -0
  77. package/schematics/components/files/select/index.ts.template +8 -0
  78. package/schematics/components/files/select/list-selection.ts.template +15 -0
  79. package/schematics/components/files/select/option.ts.template +35 -0
  80. package/schematics/components/files/select/select-input.ts.template +21 -0
  81. package/schematics/components/files/select/select.ts.template +96 -0
  82. package/schematics/components/files/selectable/index.ts.template +1 -0
  83. package/schematics/components/files/selectable/selectable.ts.template +34 -0
  84. package/schematics/components/files/separator/index.ts.template +5 -0
  85. package/schematics/components/files/separator/separator.ts.template +19 -0
  86. package/schematics/components/files/sheet/index.ts.template +5 -0
  87. package/schematics/components/files/sheet/sheet.ts.template +69 -0
  88. package/schematics/components/files/sidenav/index.ts.template +1 -0
  89. package/schematics/components/files/sidenav/sidenav.ts.template +48 -0
  90. package/schematics/components/files/skeleton/index.ts.template +1 -0
  91. package/schematics/components/files/skeleton/skeleton.ts.template +15 -0
  92. package/schematics/components/files/slider/index.ts.template +5 -0
  93. package/schematics/components/files/slider/slider.ts.template +35 -0
  94. package/schematics/components/files/sonner/index.ts.template +5 -0
  95. package/schematics/components/files/sonner/sonner.ts.template +59 -0
  96. package/schematics/components/files/spinner/index.ts.template +1 -0
  97. package/schematics/components/files/spinner/spinner.ts.template +79 -0
  98. package/schematics/components/files/stepper/index.ts.template +1 -0
  99. package/schematics/components/files/stepper/stepper.ts.template +88 -0
  100. package/schematics/components/files/switch/index.ts.template +5 -0
  101. package/schematics/components/files/switch/switch.ts.template +29 -0
  102. package/schematics/components/files/table/index.ts.template +27 -0
  103. package/schematics/components/files/table/table.ts.template +122 -0
  104. package/schematics/components/files/tabs/index.ts.template +5 -0
  105. package/schematics/components/files/tabs/tab.ts.template +92 -0
  106. package/schematics/components/files/theme/index.ts.template +2 -0
  107. package/schematics/components/files/theme/theme-button.component.ts.template +26 -0
  108. package/schematics/components/files/theme/theme.service.ts.template +33 -0
  109. package/schematics/components/files/toggle/index.ts.template +5 -0
  110. package/schematics/components/files/toggle/toggle.ts.template +13 -0
  111. package/schematics/components/files/toggle-group/index.ts.template +5 -0
  112. package/schematics/components/files/toggle-group/toggle-group.ts.template +25 -0
  113. package/schematics/components/files/tooltip/index.ts.template +5 -0
  114. package/schematics/components/files/tooltip/tooltip.ts.template +45 -0
  115. package/schematics/components/files/tour/index.ts.template +1 -0
  116. package/schematics/components/files/tour/tour.ts.template +19 -0
  117. package/schematics/components/files/tree/index.ts.template +1 -0
  118. package/schematics/components/files/tree/tree.ts.template +66 -0
  119. package/schematics/components/index.d.ts +3 -0
  120. package/schematics/components/index.js +23 -0
  121. package/schematics/components/index.js.map +1 -0
  122. package/schematics/components/index.ts +39 -0
  123. package/schematics/components/schema.d.ts +6 -0
  124. package/schematics/components/schema.js +3 -0
  125. package/schematics/components/schema.js.map +1 -0
  126. package/schematics/components/schema.json +142 -0
  127. package/schematics/components/schema.ts +6 -0
@@ -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-foreground',
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-foreground',
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-background 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,23 @@
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
+ if (!options.component || options.component.length === 0) {
9
+ return (0, schematics_1.noop)();
10
+ }
11
+ const rules = options.component.map(comp => {
12
+ const sourceTemplates = (0, schematics_1.url)(`./files/${comp}`);
13
+ const targetPath = options.path || '';
14
+ const sourceParametrizedTemplates = (0, schematics_1.apply)(sourceTemplates, [
15
+ (0, schematics_1.applyTemplates)(Object.assign(Object.assign(Object.assign({}, core_1.strings), options), { component: comp })),
16
+ (0, schematics_1.move)((0, core_1.normalize)(`/${targetPath}/${comp}`)),
17
+ ]);
18
+ return (0, schematics_1.mergeWith)(sourceParametrizedTemplates);
19
+ });
20
+ return (0, schematics_1.chain)(rules);
21
+ };
22
+ }
23
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../projects/adk/schematics/components/index.ts"],"names":[],"mappings":";;AAaA,kCAyBC;AAtCD,2DASoC;AACpC,+CAA0D;AAG1D,SAAgB,WAAW,CAAC,OAA0B;IACpD,OAAO,GAAG,EAAE;QACV,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzD,OAAO,IAAA,iBAAI,GAAE,CAAC;QAChB,CAAC;QAED,MAAM,KAAK,GAAW,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YACjD,MAAM,eAAe,GAAG,IAAA,gBAAG,EAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YAE/C,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC;YAEtC,MAAM,2BAA2B,GAAG,IAAA,kBAAK,EAAC,eAAe,EAAE;gBACzD,IAAA,2BAAc,gDACT,cAAO,GACP,OAAO,KACV,SAAS,EAAE,IAAI,IACf;gBACF,IAAA,iBAAI,EAAC,IAAA,gBAAS,EAAC,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC,CAAC;aAC1C,CAAC,CAAC;YAEH,OAAO,IAAA,sBAAS,EAAC,2BAA2B,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,OAAO,IAAA,kBAAK,EAAC,KAAK,CAAC,CAAC;IACtB,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,39 @@
1
+ import {
2
+ Rule,
3
+ apply,
4
+ mergeWith,
5
+ move,
6
+ applyTemplates,
7
+ url,
8
+ chain,
9
+ noop,
10
+ } from '@angular-devkit/schematics';
11
+ import { strings, normalize } from '@angular-devkit/core';
12
+ import { MyGeneratorSchema } from './schema';
13
+
14
+ export function myGenerator(options: MyGeneratorSchema): Rule {
15
+ return () => {
16
+ if (!options.component || options.component.length === 0) {
17
+ return noop();
18
+ }
19
+
20
+ const rules: Rule[] = options.component.map(comp => {
21
+ const sourceTemplates = url(`./files/${comp}`);
22
+
23
+ const targetPath = options.path || '';
24
+
25
+ const sourceParametrizedTemplates = apply(sourceTemplates, [
26
+ applyTemplates({
27
+ ...strings,
28
+ ...options,
29
+ component: comp,
30
+ }),
31
+ move(normalize(`/${targetPath}/${comp}`)),
32
+ ]);
33
+
34
+ return mergeWith(sourceParametrizedTemplates);
35
+ });
36
+
37
+ return chain(rules);
38
+ };
39
+ }
@@ -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,142 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/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": "array",
29
+ "items": {
30
+ "type": "string",
31
+ "enum": [
32
+ "accordion",
33
+ "alert",
34
+ "autocomplete",
35
+ "avatar",
36
+ "badge",
37
+ "breadcrumb",
38
+ "button",
39
+ "card",
40
+ "carousel",
41
+ "checkbox",
42
+ "chip",
43
+ "color-picker",
44
+ "command",
45
+ "datepicker",
46
+ "dialog",
47
+ "drawer",
48
+ "form-field",
49
+ "hover-card",
50
+ "icon",
51
+ "inline-edit",
52
+ "keys",
53
+ "list",
54
+ "mask",
55
+ "menu",
56
+ "otp",
57
+ "pagination",
58
+ "popover",
59
+ "progress",
60
+ "radio",
61
+ "resizable",
62
+ "scroll-area",
63
+ "select",
64
+ "selectable",
65
+ "separator",
66
+ "sheet",
67
+ "sidenav",
68
+ "skeleton",
69
+ "slider",
70
+ "sonner",
71
+ "spinner",
72
+ "stepper",
73
+ "switch",
74
+ "table",
75
+ "tabs",
76
+ "toggle",
77
+ "toggle-group",
78
+ "tooltip",
79
+ "tour",
80
+ "tree"
81
+ ]
82
+ },
83
+ "x-prompt": {
84
+ "message": "Which component would you like to create?",
85
+ "type": "list",
86
+ "multiselect": true,
87
+ "items": [
88
+ { "value": "accordion", "label": "Accordion" },
89
+ { "value": "alert", "label": "Alert" },
90
+ { "value": "autocomplete", "label": "Autocomplete" },
91
+ { "value": "avatar", "label": "Avatar" },
92
+ { "value": "badge", "label": "Badge" },
93
+ { "value": "breadcrumb", "label": "Breadcrumb" },
94
+ { "value": "button", "label": "Button" },
95
+ { "value": "card", "label": "Card" },
96
+ { "value": "carousel", "label": "Carousel" },
97
+ { "value": "checkbox", "label": "Checkbox" },
98
+ { "value": "chip", "label": "Chip" },
99
+ { "value": "color-picker", "label": "Color Picker" },
100
+ { "value": "command", "label": "Command" },
101
+ { "value": "datepicker", "label": "Datepicker" },
102
+ { "value": "dialog", "label": "Dialog" },
103
+ { "value": "drawer", "label": "Drawer" },
104
+ { "value": "form-field", "label": "Form Field" },
105
+ { "value": "hover-card", "label": "Hover Card" },
106
+ { "value": "icon", "label": "Icon" },
107
+ { "value": "inline-edit", "label": "Inline Edit" },
108
+ { "value": "keys", "label": "Keys" },
109
+ { "value": "list", "label": "List" },
110
+ { "value": "mask", "label": "Mask" },
111
+ { "value": "menu", "label": "Menu" },
112
+ { "value": "otp", "label": "OTP" },
113
+ { "value": "pagination", "label": "Pagination" },
114
+ { "value": "popover", "label": "Popover" },
115
+ { "value": "progress", "label": "Progress" },
116
+ { "value": "radio", "label": "Radio" },
117
+ { "value": "resizable", "label": "Resizable" },
118
+ { "value": "scroll-area", "label": "Scroll Area" },
119
+ { "value": "select", "label": "Select" },
120
+ { "value": "selectable", "label": "Selectable" },
121
+ { "value": "separator", "label": "Separator" },
122
+ { "value": "sheet", "label": "Sheet" },
123
+ { "value": "sidenav", "label": "Sidenav" },
124
+ { "value": "skeleton", "label": "Skeleton" },
125
+ { "value": "slider", "label": "Slider" },
126
+ { "value": "sonner", "label": "Sonner" },
127
+ { "value": "spinner", "label": "Spinner" },
128
+ { "value": "stepper", "label": "Stepper" },
129
+ { "value": "switch", "label": "Switch" },
130
+ { "value": "table", "label": "Table" },
131
+ { "value": "tabs", "label": "Tabs" },
132
+ { "value": "toggle", "label": "Toggle" },
133
+ { "value": "toggle-group", "label": "Toggle Group" },
134
+ { "value": "tooltip", "label": "Tooltip" },
135
+ { "value": "tour", "label": "Tour" },
136
+ { "value": "tree", "label": "Tree" }
137
+ ]
138
+ }
139
+ }
140
+ },
141
+ "required": ["name", "path", "basepath", "component"]
142
+ }
@@ -0,0 +1,6 @@
1
+ export interface MyGeneratorSchema {
2
+ name: string;
3
+ path?: string;
4
+ project?: string;
5
+ component: string[];
6
+ }