@fnd-platform/cli 1.0.0-alpha.24 → 1.0.0-alpha.25
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/bin/fnd.js +101 -4
- package/lib/bin/fnd.js.map +1 -1
- package/lib/commands/add.js +72 -75
- package/lib/commands/add.js.map +1 -1
- package/lib/commands/build.js +29 -34
- package/lib/commands/build.js.map +1 -1
- package/lib/commands/deploy.d.ts +13 -5
- package/lib/commands/deploy.d.ts.map +1 -1
- package/lib/commands/deploy.js +94 -75
- package/lib/commands/deploy.js.map +1 -1
- package/lib/commands/destroy.js +33 -38
- package/lib/commands/destroy.js.map +1 -1
- package/lib/commands/index.d.ts +1 -0
- package/lib/commands/index.d.ts.map +1 -1
- package/lib/commands/index.js +7 -15
- package/lib/commands/index.js.map +1 -1
- package/lib/commands/new.js +46 -50
- package/lib/commands/new.js.map +1 -1
- package/lib/commands/synth.d.ts +8 -1
- package/lib/commands/synth.d.ts.map +1 -1
- package/lib/commands/synth.js +82 -22
- package/lib/commands/synth.js.map +1 -1
- package/lib/commands/test.d.ts +73 -0
- package/lib/commands/test.d.ts.map +1 -0
- package/lib/commands/test.js +193 -0
- package/lib/commands/test.js.map +1 -0
- package/lib/index.d.ts +11 -2
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +29 -18
- package/lib/index.js.map +1 -1
- package/lib/lib/deploy-utils.d.ts.map +1 -1
- package/lib/lib/deploy-utils.js +73 -72
- package/lib/lib/deploy-utils.js.map +1 -1
- package/lib/lib/infra-generator.js +55 -63
- package/lib/lib/infra-generator.js.map +1 -1
- package/lib/lib/logger.js +23 -29
- package/lib/lib/logger.js.map +1 -1
- package/lib/lib/nx-stats.js +12 -18
- package/lib/lib/nx-stats.js.map +1 -1
- package/lib/lib/project.js +7 -11
- package/lib/lib/project.js.map +1 -1
- package/lib/lib/templates.js +2 -6
- package/lib/lib/templates.js.map +1 -1
- package/lib/lib/timer.js +2 -7
- package/lib/lib/timer.js.map +1 -1
- package/lib/lib/validation.d.ts +135 -0
- package/lib/lib/validation.d.ts.map +1 -0
- package/lib/lib/validation.js +233 -0
- package/lib/lib/validation.js.map +1 -0
- package/lib/tui/App.d.ts +11 -0
- package/lib/tui/App.d.ts.map +1 -0
- package/lib/tui/App.js +98 -0
- package/lib/tui/App.js.map +1 -0
- package/lib/tui/components/branding/AsciiBanner.d.ts +21 -0
- package/lib/tui/components/branding/AsciiBanner.d.ts.map +1 -0
- package/lib/tui/components/branding/AsciiBanner.js +15 -0
- package/lib/tui/components/branding/AsciiBanner.js.map +1 -0
- package/lib/tui/components/branding/index.d.ts +5 -0
- package/lib/tui/components/branding/index.d.ts.map +1 -0
- package/lib/tui/components/branding/index.js +5 -0
- package/lib/tui/components/branding/index.js.map +1 -0
- package/lib/tui/components/feedback/Notification.d.ts +51 -0
- package/lib/tui/components/feedback/Notification.d.ts.map +1 -0
- package/lib/tui/components/feedback/Notification.js +89 -0
- package/lib/tui/components/feedback/Notification.js.map +1 -0
- package/lib/tui/components/feedback/ProgressBar.d.ts +46 -0
- package/lib/tui/components/feedback/ProgressBar.d.ts.map +1 -0
- package/lib/tui/components/feedback/ProgressBar.js +30 -0
- package/lib/tui/components/feedback/ProgressBar.js.map +1 -0
- package/lib/tui/components/feedback/ProgressSteps.d.ts +35 -0
- package/lib/tui/components/feedback/ProgressSteps.d.ts.map +1 -0
- package/lib/tui/components/feedback/ProgressSteps.js +37 -0
- package/lib/tui/components/feedback/ProgressSteps.js.map +1 -0
- package/lib/tui/components/feedback/Spinner.d.ts +18 -0
- package/lib/tui/components/feedback/Spinner.d.ts.map +1 -0
- package/lib/tui/components/feedback/Spinner.js +28 -0
- package/lib/tui/components/feedback/Spinner.js.map +1 -0
- package/lib/tui/components/feedback/index.d.ts +8 -0
- package/lib/tui/components/feedback/index.d.ts.map +1 -0
- package/lib/tui/components/feedback/index.js +8 -0
- package/lib/tui/components/feedback/index.js.map +1 -0
- package/lib/tui/components/index.d.ts +8 -0
- package/lib/tui/components/index.d.ts.map +1 -0
- package/lib/tui/components/index.js +8 -0
- package/lib/tui/components/index.js.map +1 -0
- package/lib/tui/components/input/Checkbox.d.ts +26 -0
- package/lib/tui/components/input/Checkbox.d.ts.map +1 -0
- package/lib/tui/components/input/Checkbox.js +20 -0
- package/lib/tui/components/input/Checkbox.js.map +1 -0
- package/lib/tui/components/input/SelectInput.d.ts +41 -0
- package/lib/tui/components/input/SelectInput.d.ts.map +1 -0
- package/lib/tui/components/input/SelectInput.js +53 -0
- package/lib/tui/components/input/SelectInput.js.map +1 -0
- package/lib/tui/components/input/TextInput.d.ts +30 -0
- package/lib/tui/components/input/TextInput.d.ts.map +1 -0
- package/lib/tui/components/input/TextInput.js +48 -0
- package/lib/tui/components/input/TextInput.js.map +1 -0
- package/lib/tui/components/input/index.d.ts +7 -0
- package/lib/tui/components/input/index.d.ts.map +1 -0
- package/lib/tui/components/input/index.js +7 -0
- package/lib/tui/components/input/index.js.map +1 -0
- package/lib/tui/components/layout/Breadcrumbs.d.ts +11 -0
- package/lib/tui/components/layout/Breadcrumbs.d.ts.map +1 -0
- package/lib/tui/components/layout/Breadcrumbs.js +34 -0
- package/lib/tui/components/layout/Breadcrumbs.js.map +1 -0
- package/lib/tui/components/layout/Footer.d.ts +11 -0
- package/lib/tui/components/layout/Footer.d.ts.map +1 -0
- package/lib/tui/components/layout/Footer.js +20 -0
- package/lib/tui/components/layout/Footer.js.map +1 -0
- package/lib/tui/components/layout/Header.d.ts +21 -0
- package/lib/tui/components/layout/Header.d.ts.map +1 -0
- package/lib/tui/components/layout/Header.js +21 -0
- package/lib/tui/components/layout/Header.js.map +1 -0
- package/lib/tui/components/layout/Screen.d.ts +27 -0
- package/lib/tui/components/layout/Screen.d.ts.map +1 -0
- package/lib/tui/components/layout/Screen.js +11 -0
- package/lib/tui/components/layout/Screen.js.map +1 -0
- package/lib/tui/components/layout/index.d.ts +8 -0
- package/lib/tui/components/layout/index.d.ts.map +1 -0
- package/lib/tui/components/layout/index.js +8 -0
- package/lib/tui/components/layout/index.js.map +1 -0
- package/lib/tui/hooks/index.d.ts +20 -0
- package/lib/tui/hooks/index.d.ts.map +1 -0
- package/lib/tui/hooks/index.js +18 -0
- package/lib/tui/hooks/index.js.map +1 -0
- package/lib/tui/hooks/useAddPackage.d.ts +120 -0
- package/lib/tui/hooks/useAddPackage.d.ts.map +1 -0
- package/lib/tui/hooks/useAddPackage.js +347 -0
- package/lib/tui/hooks/useAddPackage.js.map +1 -0
- package/lib/tui/hooks/useCreateProject.d.ts +66 -0
- package/lib/tui/hooks/useCreateProject.d.ts.map +1 -0
- package/lib/tui/hooks/useCreateProject.js +156 -0
- package/lib/tui/hooks/useCreateProject.js.map +1 -0
- package/lib/tui/hooks/useDeploy.d.ts +93 -0
- package/lib/tui/hooks/useDeploy.d.ts.map +1 -0
- package/lib/tui/hooks/useDeploy.js +252 -0
- package/lib/tui/hooks/useDeploy.js.map +1 -0
- package/lib/tui/hooks/useKeyboard.d.ts +66 -0
- package/lib/tui/hooks/useKeyboard.d.ts.map +1 -0
- package/lib/tui/hooks/useKeyboard.js +101 -0
- package/lib/tui/hooks/useKeyboard.js.map +1 -0
- package/lib/tui/hooks/useNavigation.d.ts +33 -0
- package/lib/tui/hooks/useNavigation.d.ts.map +1 -0
- package/lib/tui/hooks/useNavigation.js +27 -0
- package/lib/tui/hooks/useNavigation.js.map +1 -0
- package/lib/tui/hooks/useProject.d.ts +36 -0
- package/lib/tui/hooks/useProject.d.ts.map +1 -0
- package/lib/tui/hooks/useProject.js +47 -0
- package/lib/tui/hooks/useProject.js.map +1 -0
- package/lib/tui/index.d.ts +15 -0
- package/lib/tui/index.d.ts.map +1 -0
- package/lib/tui/index.js +16 -0
- package/lib/tui/index.js.map +1 -0
- package/lib/tui/lib/add-package-tui.d.ts +127 -0
- package/lib/tui/lib/add-package-tui.d.ts.map +1 -0
- package/lib/tui/lib/add-package-tui.js +467 -0
- package/lib/tui/lib/add-package-tui.js.map +1 -0
- package/lib/tui/lib/create-project-tui.d.ts +84 -0
- package/lib/tui/lib/create-project-tui.d.ts.map +1 -0
- package/lib/tui/lib/create-project-tui.js +141 -0
- package/lib/tui/lib/create-project-tui.js.map +1 -0
- package/lib/tui/lib/deploy-tui.d.ts +131 -0
- package/lib/tui/lib/deploy-tui.d.ts.map +1 -0
- package/lib/tui/lib/deploy-tui.js +347 -0
- package/lib/tui/lib/deploy-tui.js.map +1 -0
- package/lib/tui/screens/AddPackageScreen.d.ts +12 -0
- package/lib/tui/screens/AddPackageScreen.d.ts.map +1 -0
- package/lib/tui/screens/AddPackageScreen.js +436 -0
- package/lib/tui/screens/AddPackageScreen.js.map +1 -0
- package/lib/tui/screens/CreateProjectScreen.d.ts +12 -0
- package/lib/tui/screens/CreateProjectScreen.d.ts.map +1 -0
- package/lib/tui/screens/CreateProjectScreen.js +252 -0
- package/lib/tui/screens/CreateProjectScreen.js.map +1 -0
- package/lib/tui/screens/DeployScreen.d.ts +11 -0
- package/lib/tui/screens/DeployScreen.d.ts.map +1 -0
- package/lib/tui/screens/DeployScreen.js +224 -0
- package/lib/tui/screens/DeployScreen.js.map +1 -0
- package/lib/tui/screens/ProjectDashboard.d.ts +11 -0
- package/lib/tui/screens/ProjectDashboard.d.ts.map +1 -0
- package/lib/tui/screens/ProjectDashboard.js +42 -0
- package/lib/tui/screens/ProjectDashboard.js.map +1 -0
- package/lib/tui/screens/WelcomeScreen.d.ts +11 -0
- package/lib/tui/screens/WelcomeScreen.d.ts.map +1 -0
- package/lib/tui/screens/WelcomeScreen.js +26 -0
- package/lib/tui/screens/WelcomeScreen.js.map +1 -0
- package/lib/tui/screens/index.d.ts +9 -0
- package/lib/tui/screens/index.d.ts.map +1 -0
- package/lib/tui/screens/index.js +9 -0
- package/lib/tui/screens/index.js.map +1 -0
- package/lib/tui/services/ConfigService.d.ts +133 -0
- package/lib/tui/services/ConfigService.d.ts.map +1 -0
- package/lib/tui/services/ConfigService.js +221 -0
- package/lib/tui/services/ConfigService.js.map +1 -0
- package/lib/tui/services/ProjectService.d.ts +55 -0
- package/lib/tui/services/ProjectService.d.ts.map +1 -0
- package/lib/tui/services/ProjectService.js +179 -0
- package/lib/tui/services/ProjectService.js.map +1 -0
- package/lib/tui/services/index.d.ts +6 -0
- package/lib/tui/services/index.d.ts.map +1 -0
- package/lib/tui/services/index.js +6 -0
- package/lib/tui/services/index.js.map +1 -0
- package/lib/tui/state/AppContext.d.ts +58 -0
- package/lib/tui/state/AppContext.d.ts.map +1 -0
- package/lib/tui/state/AppContext.js +75 -0
- package/lib/tui/state/AppContext.js.map +1 -0
- package/lib/tui/state/index.d.ts +7 -0
- package/lib/tui/state/index.d.ts.map +1 -0
- package/lib/tui/state/index.js +7 -0
- package/lib/tui/state/index.js.map +1 -0
- package/lib/tui/state/reducer.d.ts +13 -0
- package/lib/tui/state/reducer.d.ts.map +1 -0
- package/lib/tui/state/reducer.js +136 -0
- package/lib/tui/state/reducer.js.map +1 -0
- package/lib/tui/state/types.d.ts +132 -0
- package/lib/tui/state/types.d.ts.map +1 -0
- package/lib/tui/state/types.js +38 -0
- package/lib/tui/state/types.js.map +1 -0
- package/lib/tui/utils/ascii.d.ts +42 -0
- package/lib/tui/utils/ascii.d.ts.map +1 -0
- package/lib/tui/utils/ascii.js +63 -0
- package/lib/tui/utils/ascii.js.map +1 -0
- package/lib/tui/utils/colors.d.ts +65 -0
- package/lib/tui/utils/colors.d.ts.map +1 -0
- package/lib/tui/utils/colors.js +65 -0
- package/lib/tui/utils/colors.js.map +1 -0
- package/lib/tui/utils/index.d.ts +6 -0
- package/lib/tui/utils/index.d.ts.map +1 -0
- package/lib/tui/utils/index.js +6 -0
- package/lib/tui/utils/index.js.map +1 -0
- package/package.json +12 -3
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/input/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/tui/components/input/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,eAAe,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Breadcrumbs component for the FND TUI.
|
|
3
|
+
*
|
|
4
|
+
* Shows the navigation trail.
|
|
5
|
+
*/
|
|
6
|
+
import React from 'react';
|
|
7
|
+
/**
|
|
8
|
+
* Breadcrumbs component showing navigation trail.
|
|
9
|
+
*/
|
|
10
|
+
export declare function Breadcrumbs(): React.ReactElement;
|
|
11
|
+
//# sourceMappingURL=Breadcrumbs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumbs.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/Breadcrumbs.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAmB1B;;GAEG;AACH,wBAAgB,WAAW,IAAI,KAAK,CAAC,YAAY,CA8BhD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import { useNavigation } from '../../hooks/useNavigation.js';
|
|
4
|
+
import { colors } from '../../utils/colors.js';
|
|
5
|
+
/**
|
|
6
|
+
* Screen display names.
|
|
7
|
+
*/
|
|
8
|
+
const SCREEN_NAMES = {
|
|
9
|
+
welcome: 'Welcome',
|
|
10
|
+
'project-dashboard': 'Dashboard',
|
|
11
|
+
'create-project': 'New Project',
|
|
12
|
+
'add-package': 'Add Package',
|
|
13
|
+
deploy: 'Deploy',
|
|
14
|
+
settings: 'Settings',
|
|
15
|
+
help: 'Help',
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Breadcrumbs component showing navigation trail.
|
|
19
|
+
*/
|
|
20
|
+
export function Breadcrumbs() {
|
|
21
|
+
const { currentScreen, history } = useNavigation();
|
|
22
|
+
// Only show if we have history
|
|
23
|
+
if (history.length === 0) {
|
|
24
|
+
return _jsx(Box, {});
|
|
25
|
+
}
|
|
26
|
+
// Take last 3 items from history + current
|
|
27
|
+
const trail = [...history.slice(-2), currentScreen];
|
|
28
|
+
return (_jsx(Box, { children: trail.map((screen, index) => {
|
|
29
|
+
const isLast = index === trail.length - 1;
|
|
30
|
+
const name = SCREEN_NAMES[screen] || screen;
|
|
31
|
+
return (_jsxs(Box, { children: [_jsx(Text, { color: isLast ? colors.primary : colors.muted, children: name }), !isLast && (_jsx(Text, { color: colors.muted, children: " \u203A " }))] }, `${screen}-${index}`));
|
|
32
|
+
}) }));
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=Breadcrumbs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumbs.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/Breadcrumbs.tsx"],"names":[],"mappings":";AAOA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAG/C;;GAEG;AACH,MAAM,YAAY,GAA2B;IAC3C,OAAO,EAAE,SAAS;IAClB,mBAAmB,EAAE,WAAW;IAChC,gBAAgB,EAAE,aAAa;IAC/B,aAAa,EAAE,aAAa;IAC5B,MAAM,EAAE,QAAQ;IAChB,QAAQ,EAAE,UAAU;IACpB,IAAI,EAAE,MAAM;CACb,CAAC;AAEF;;GAEG;AACH,MAAM,UAAU,WAAW;IACzB,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,aAAa,EAAE,CAAC;IAEnD,+BAA+B;IAC/B,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,KAAC,GAAG,KAAG,CAAC;IACjB,CAAC;IAED,2CAA2C;IAC3C,MAAM,KAAK,GAAG,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC;IAEpD,OAAO,CACL,KAAC,GAAG,cACD,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YAC3B,MAAM,MAAM,GAAG,KAAK,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC1C,MAAM,IAAI,GAAG,YAAY,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC;YAE5C,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,YAChD,IAAI,GACA,EACN,CAAC,MAAM,IAAI,CACV,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,yBAAY,CACtC,KANO,GAAG,MAAM,IAAI,KAAK,EAAE,CAOxB,CACP,CAAC;QACJ,CAAC,CAAC,GACE,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Footer component for the FND TUI.
|
|
3
|
+
*
|
|
4
|
+
* Shows keyboard shortcuts and notifications.
|
|
5
|
+
*/
|
|
6
|
+
import React from 'react';
|
|
7
|
+
/**
|
|
8
|
+
* Footer component with keyboard shortcuts.
|
|
9
|
+
*/
|
|
10
|
+
export declare function Footer(): React.ReactElement;
|
|
11
|
+
//# sourceMappingURL=Footer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Footer.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/Footer.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B;;GAEG;AACH,wBAAgB,MAAM,IAAI,KAAK,CAAC,YAAY,CAsC3C"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import { useAppState } from '../../state/AppContext.js';
|
|
4
|
+
import { getShortcutsForScreen } from '../../hooks/useKeyboard.js';
|
|
5
|
+
import { colors, statusColors } from '../../utils/colors.js';
|
|
6
|
+
/**
|
|
7
|
+
* Footer component with keyboard shortcuts.
|
|
8
|
+
*/
|
|
9
|
+
export function Footer() {
|
|
10
|
+
const { state } = useAppState();
|
|
11
|
+
const { currentScreen } = state.navigation;
|
|
12
|
+
const { notification, notificationType } = state.ui;
|
|
13
|
+
const shortcuts = getShortcutsForScreen(currentScreen);
|
|
14
|
+
// Determine notification color
|
|
15
|
+
const notificationColor = notificationType
|
|
16
|
+
? statusColors[notificationType === 'info' ? 'idle' : notificationType === 'success' ? 'active' : notificationType === 'warning' ? 'pending' : 'failed']
|
|
17
|
+
: colors.muted;
|
|
18
|
+
return (_jsxs(Box, { flexDirection: "column", marginTop: 1, children: [notification && (_jsx(Box, { marginBottom: 1, children: _jsx(Text, { color: notificationColor, children: notification }) })), _jsx(Box, { children: _jsx(Text, { color: colors.muted, children: '─'.repeat(process.stdout.columns || 80) }) }), _jsx(Box, { gap: 2, flexWrap: "wrap", children: shortcuts.map((shortcut, index) => (_jsxs(Box, { children: [_jsx(Text, { color: colors.muted, children: "[" }), _jsx(Text, { color: colors.accent, children: shortcut.key }), _jsxs(Text, { color: colors.muted, children: ["] ", shortcut.description] })] }, index))) })] }));
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=Footer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Footer.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/Footer.tsx"],"names":[],"mappings":";AAOA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAE7D;;GAEG;AACH,MAAM,UAAU,MAAM;IACpB,MAAM,EAAE,KAAK,EAAE,GAAG,WAAW,EAAE,CAAC;IAChC,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC;IAC3C,MAAM,EAAE,YAAY,EAAE,gBAAgB,EAAE,GAAG,KAAK,CAAC,EAAE,CAAC;IAEpD,MAAM,SAAS,GAAG,qBAAqB,CAAC,aAAa,CAAC,CAAC;IAEvD,+BAA+B;IAC/B,MAAM,iBAAiB,GAAG,gBAAgB;QACxC,CAAC,CAAC,YAAY,CAAC,gBAAgB,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,gBAAgB,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,gBAAgB,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;QACxJ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;IAEjB,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,SAAS,EAAE,CAAC,aAErC,YAAY,IAAI,CACf,KAAC,GAAG,IAAC,YAAY,EAAE,CAAC,YAClB,KAAC,IAAI,IAAC,KAAK,EAAE,iBAAiB,YAAG,YAAY,GAAQ,GACjD,CACP,EAGD,KAAC,GAAG,cACF,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,YAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,GAAQ,GACxE,EAGN,KAAC,GAAG,IAAC,GAAG,EAAE,CAAC,EAAE,QAAQ,EAAC,MAAM,YACzB,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CAClC,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,kBAAU,EACnC,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,MAAM,YAAG,QAAQ,CAAC,GAAG,GAAQ,EACjD,MAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,mBAAK,QAAQ,CAAC,WAAW,IAAQ,KAHlD,KAAK,CAIT,CACP,CAAC,GACE,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Header component for the FND TUI.
|
|
3
|
+
*
|
|
4
|
+
* Shows the ASCII banner or breadcrumbs depending on context.
|
|
5
|
+
*/
|
|
6
|
+
import React from 'react';
|
|
7
|
+
/**
|
|
8
|
+
* Props for the Header component.
|
|
9
|
+
*/
|
|
10
|
+
interface HeaderProps {
|
|
11
|
+
/** Whether to show the full banner */
|
|
12
|
+
showBanner?: boolean;
|
|
13
|
+
/** Custom title to display */
|
|
14
|
+
title?: string;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Header component that shows banner or navigation breadcrumbs.
|
|
18
|
+
*/
|
|
19
|
+
export declare function Header({ showBanner, title }: HeaderProps): React.ReactElement;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=Header.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/Header.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B;;GAEG;AACH,UAAU,WAAW;IACnB,sCAAsC;IACtC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,8BAA8B;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,wBAAgB,MAAM,CAAC,EAAE,UAAkB,EAAE,KAAK,EAAE,EAAE,WAAW,GAAG,KAAK,CAAC,YAAY,CA4BrF"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import { useAppState } from '../../state/AppContext.js';
|
|
4
|
+
import { colors } from '../../utils/colors.js';
|
|
5
|
+
import { Breadcrumbs } from './Breadcrumbs.js';
|
|
6
|
+
import { AsciiBanner } from '../branding/AsciiBanner.js';
|
|
7
|
+
/**
|
|
8
|
+
* Header component that shows banner or navigation breadcrumbs.
|
|
9
|
+
*/
|
|
10
|
+
export function Header({ showBanner = false, title }) {
|
|
11
|
+
const { state } = useAppState();
|
|
12
|
+
const { currentScreen } = state.navigation;
|
|
13
|
+
const { showBanner: prefShowBanner } = state.preferences;
|
|
14
|
+
// Show banner on welcome screen if preferences allow
|
|
15
|
+
const shouldShowBanner = showBanner || (currentScreen === 'welcome' && prefShowBanner);
|
|
16
|
+
if (shouldShowBanner) {
|
|
17
|
+
return _jsx(AsciiBanner, {});
|
|
18
|
+
}
|
|
19
|
+
return (_jsxs(Box, { flexDirection: "column", marginBottom: 1, children: [_jsxs(Box, { children: [_jsx(Text, { bold: true, color: colors.primary, children: "FND" }), title && (_jsxs(_Fragment, { children: [_jsx(Text, { color: colors.muted, children: " / " }), _jsx(Text, { children: title })] }))] }), _jsx(Breadcrumbs, {})] }));
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=Header.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/Header.tsx"],"names":[],"mappings":";AAOA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAYzD;;GAEG;AACH,MAAM,UAAU,MAAM,CAAC,EAAE,UAAU,GAAG,KAAK,EAAE,KAAK,EAAe;IAC/D,MAAM,EAAE,KAAK,EAAE,GAAG,WAAW,EAAE,CAAC;IAChC,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC;IAC3C,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,GAAG,KAAK,CAAC,WAAW,CAAC;IAEzD,qDAAqD;IACrD,MAAM,gBAAgB,GAAG,UAAU,IAAI,CAAC,aAAa,KAAK,SAAS,IAAI,cAAc,CAAC,CAAC;IAEvF,IAAI,gBAAgB,EAAE,CAAC;QACrB,OAAO,KAAC,WAAW,KAAG,CAAC;IACzB,CAAC;IAED,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,YAAY,EAAE,CAAC,aACzC,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,MAAM,CAAC,OAAO,oBAEzB,EACN,KAAK,IAAI,CACR,8BACE,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,oBAAY,EACrC,KAAC,IAAI,cAAE,KAAK,GAAQ,IACnB,CACJ,IACG,EACN,KAAC,WAAW,KAAG,IACX,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Screen wrapper component for the FND TUI.
|
|
3
|
+
*
|
|
4
|
+
* Provides consistent layout for all screens.
|
|
5
|
+
*/
|
|
6
|
+
import React, { type ReactNode } from 'react';
|
|
7
|
+
/**
|
|
8
|
+
* Props for the Screen component.
|
|
9
|
+
*/
|
|
10
|
+
interface ScreenProps {
|
|
11
|
+
/** Screen content */
|
|
12
|
+
children: ReactNode;
|
|
13
|
+
/** Whether to show the ASCII banner */
|
|
14
|
+
showBanner?: boolean;
|
|
15
|
+
/** Screen title for header */
|
|
16
|
+
title?: string;
|
|
17
|
+
/** Whether to show footer */
|
|
18
|
+
showFooter?: boolean;
|
|
19
|
+
/** Whether to show header */
|
|
20
|
+
showHeader?: boolean;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Screen wrapper component providing consistent layout.
|
|
24
|
+
*/
|
|
25
|
+
export declare function Screen({ children, showBanner, title, showFooter, showHeader, }: ScreenProps): React.ReactElement;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=Screen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Screen.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/Screen.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAK9C;;GAEG;AACH,UAAU,WAAW;IACnB,qBAAqB;IACrB,QAAQ,EAAE,SAAS,CAAC;IACpB,uCAAuC;IACvC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,8BAA8B;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,6BAA6B;IAC7B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,6BAA6B;IAC7B,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED;;GAEG;AACH,wBAAgB,MAAM,CAAC,EACrB,QAAQ,EACR,UAAkB,EAClB,KAAK,EACL,UAAiB,EACjB,UAAiB,GAClB,EAAE,WAAW,GAAG,KAAK,CAAC,YAAY,CAUlC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box } from 'ink';
|
|
3
|
+
import { Header } from './Header.js';
|
|
4
|
+
import { Footer } from './Footer.js';
|
|
5
|
+
/**
|
|
6
|
+
* Screen wrapper component providing consistent layout.
|
|
7
|
+
*/
|
|
8
|
+
export function Screen({ children, showBanner = false, title, showFooter = true, showHeader = true, }) {
|
|
9
|
+
return (_jsxs(Box, { flexDirection: "column", padding: 1, children: [showHeader && _jsx(Header, { showBanner: showBanner, title: title }), _jsx(Box, { flexDirection: "column", flexGrow: 1, children: children }), showFooter && _jsx(Footer, {})] }));
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=Screen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Screen.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/Screen.tsx"],"names":[],"mappings":";AAOA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAkBrC;;GAEG;AACH,MAAM,UAAU,MAAM,CAAC,EACrB,QAAQ,EACR,UAAU,GAAG,KAAK,EAClB,KAAK,EACL,UAAU,GAAG,IAAI,EACjB,UAAU,GAAG,IAAI,GACL;IACZ,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,OAAO,EAAE,CAAC,aACnC,UAAU,IAAI,KAAC,MAAM,IAAC,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,GAAI,EAC/D,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,YACpC,QAAQ,GACL,EACL,UAAU,IAAI,KAAC,MAAM,KAAG,IACrB,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TUI hooks exports.
|
|
3
|
+
*
|
|
4
|
+
* Note: Each wizard hook (useCreateProject, useAddPackage, useDeploy) exports
|
|
5
|
+
* its own WizardStep type with different step values. To avoid naming conflicts,
|
|
6
|
+
* import WizardStep directly from the specific hook file if needed:
|
|
7
|
+
* - import { type WizardStep } from './useCreateProject.js'
|
|
8
|
+
* - import { type WizardStep } from './useAddPackage.js'
|
|
9
|
+
* - import { type WizardStep } from './useDeploy.js'
|
|
10
|
+
*/
|
|
11
|
+
export * from './useNavigation.js';
|
|
12
|
+
export * from './useKeyboard.js';
|
|
13
|
+
export * from './useProject.js';
|
|
14
|
+
export { useCreateProject } from './useCreateProject.js';
|
|
15
|
+
export type { CreateProjectState } from './useCreateProject.js';
|
|
16
|
+
export { useAddPackage } from './useAddPackage.js';
|
|
17
|
+
export type { ApiOptions, FrontendOptions, CmsOptions, ComponentLibraryOptions, AddPackageState, UseAddPackageResult, } from './useAddPackage.js';
|
|
18
|
+
export { useDeploy } from './useDeploy.js';
|
|
19
|
+
export type { DeployState } from './useDeploy.js';
|
|
20
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAGhC,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,YAAY,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAEhE,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,YAAY,EACV,UAAU,EACV,eAAe,EACf,UAAU,EACV,uBAAuB,EACvB,eAAe,EACf,mBAAmB,GACpB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,YAAY,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TUI hooks exports.
|
|
3
|
+
*
|
|
4
|
+
* Note: Each wizard hook (useCreateProject, useAddPackage, useDeploy) exports
|
|
5
|
+
* its own WizardStep type with different step values. To avoid naming conflicts,
|
|
6
|
+
* import WizardStep directly from the specific hook file if needed:
|
|
7
|
+
* - import { type WizardStep } from './useCreateProject.js'
|
|
8
|
+
* - import { type WizardStep } from './useAddPackage.js'
|
|
9
|
+
* - import { type WizardStep } from './useDeploy.js'
|
|
10
|
+
*/
|
|
11
|
+
export * from './useNavigation.js';
|
|
12
|
+
export * from './useKeyboard.js';
|
|
13
|
+
export * from './useProject.js';
|
|
14
|
+
// Export hooks and state types from wizard hooks, excluding WizardStep to avoid conflicts
|
|
15
|
+
export { useCreateProject } from './useCreateProject.js';
|
|
16
|
+
export { useAddPackage } from './useAddPackage.js';
|
|
17
|
+
export { useDeploy } from './useDeploy.js';
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tui/hooks/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAEhC,0FAA0F;AAC1F,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAGzD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAUnD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook for managing the add package wizard state.
|
|
3
|
+
*
|
|
4
|
+
* Manages form state locally (not in global state) since it's ephemeral
|
|
5
|
+
* and specific to the wizard flow.
|
|
6
|
+
*/
|
|
7
|
+
import { type PackageType, type AddPackageStep } from '../lib/add-package-tui.js';
|
|
8
|
+
/**
|
|
9
|
+
* Wizard step identifiers.
|
|
10
|
+
*/
|
|
11
|
+
export type WizardStep = 'type' | 'name' | 'api-selection' | 'options' | 'confirm' | 'adding' | 'done' | 'error';
|
|
12
|
+
/**
|
|
13
|
+
* API package options.
|
|
14
|
+
*/
|
|
15
|
+
export interface ApiOptions {
|
|
16
|
+
dynamodb: boolean;
|
|
17
|
+
cognito: boolean;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Frontend package options.
|
|
21
|
+
*/
|
|
22
|
+
export interface FrontendOptions {
|
|
23
|
+
auth: boolean;
|
|
24
|
+
port: number;
|
|
25
|
+
theme: string;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* CMS package options.
|
|
29
|
+
*/
|
|
30
|
+
export interface CmsOptions {
|
|
31
|
+
port: number;
|
|
32
|
+
mediaUpload: boolean;
|
|
33
|
+
richTextEditor: 'tiptap' | 'lexical';
|
|
34
|
+
theme: string;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Component library package options.
|
|
38
|
+
*/
|
|
39
|
+
export interface ComponentLibraryOptions {
|
|
40
|
+
port: number;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Wizard state.
|
|
44
|
+
*/
|
|
45
|
+
export interface AddPackageState {
|
|
46
|
+
/** Current wizard step */
|
|
47
|
+
step: WizardStep;
|
|
48
|
+
/** Selected package type */
|
|
49
|
+
packageType: PackageType | null;
|
|
50
|
+
/** Package name */
|
|
51
|
+
packageName: string;
|
|
52
|
+
/** Name validation error */
|
|
53
|
+
nameError: string | null;
|
|
54
|
+
/** Selected API package (for frontend/cms) */
|
|
55
|
+
selectedApi: string | null;
|
|
56
|
+
/** Available API packages in project */
|
|
57
|
+
availableApiPackages: string[];
|
|
58
|
+
/** API-specific options */
|
|
59
|
+
apiOptions: ApiOptions;
|
|
60
|
+
/** Frontend-specific options */
|
|
61
|
+
frontendOptions: FrontendOptions;
|
|
62
|
+
/** CMS-specific options */
|
|
63
|
+
cmsOptions: CmsOptions;
|
|
64
|
+
/** Component library-specific options */
|
|
65
|
+
componentLibraryOptions: ComponentLibraryOptions;
|
|
66
|
+
/** Current addition progress step */
|
|
67
|
+
addProgress: AddPackageStep;
|
|
68
|
+
/** Addition error message */
|
|
69
|
+
addError: string | null;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Hook result type.
|
|
73
|
+
*/
|
|
74
|
+
export interface UseAddPackageResult {
|
|
75
|
+
/** Current state */
|
|
76
|
+
state: AddPackageState;
|
|
77
|
+
/** Set package type */
|
|
78
|
+
setPackageType: (type: PackageType) => void;
|
|
79
|
+
/** Set package name */
|
|
80
|
+
setPackageName: (name: string) => void;
|
|
81
|
+
/** Set selected API */
|
|
82
|
+
setSelectedApi: (api: string) => void;
|
|
83
|
+
/** Toggle API option */
|
|
84
|
+
toggleApiOption: (key: keyof ApiOptions) => void;
|
|
85
|
+
/** Toggle frontend option */
|
|
86
|
+
toggleFrontendOption: (key: keyof FrontendOptions) => void;
|
|
87
|
+
/** Set frontend port */
|
|
88
|
+
setFrontendPort: (port: number) => void;
|
|
89
|
+
/** Set frontend theme */
|
|
90
|
+
setFrontendTheme: (theme: string) => void;
|
|
91
|
+
/** Toggle CMS option */
|
|
92
|
+
toggleCmsOption: (key: keyof CmsOptions) => void;
|
|
93
|
+
/** Set CMS port */
|
|
94
|
+
setCmsPort: (port: number) => void;
|
|
95
|
+
/** Set CMS rich text editor */
|
|
96
|
+
setCmsRichTextEditor: (editor: 'tiptap' | 'lexical') => void;
|
|
97
|
+
/** Set CMS theme */
|
|
98
|
+
setCmsTheme: (theme: string) => void;
|
|
99
|
+
/** Set component library port */
|
|
100
|
+
setComponentLibraryPort: (port: number) => void;
|
|
101
|
+
/** Move to next step */
|
|
102
|
+
nextStep: () => void;
|
|
103
|
+
/** Move to previous step */
|
|
104
|
+
prevStep: () => void;
|
|
105
|
+
/** Start package addition */
|
|
106
|
+
confirm: () => Promise<void>;
|
|
107
|
+
/** Reset wizard to initial state */
|
|
108
|
+
reset: () => void;
|
|
109
|
+
/** Cancel wizard and return */
|
|
110
|
+
cancel: () => void;
|
|
111
|
+
/** Retry after error */
|
|
112
|
+
retry: () => void;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Hook for managing the add package wizard.
|
|
116
|
+
*
|
|
117
|
+
* @returns Wizard state and actions
|
|
118
|
+
*/
|
|
119
|
+
export declare function useAddPackage(): UseAddPackageResult;
|
|
120
|
+
//# sourceMappingURL=useAddPackage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAddPackage.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useAddPackage.ts"],"names":[],"mappings":"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"}
|