hackmate-cli 1.0.28 → 1.1.0

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 (80) hide show
  1. package/dist/Dashboard.d.ts +2 -0
  2. package/dist/Dashboard.d.ts.map +1 -0
  3. package/dist/Dashboard.js +69 -0
  4. package/dist/Dashboard.js.map +1 -0
  5. package/dist/api.d.ts.map +1 -1
  6. package/dist/api.js +9 -1
  7. package/dist/api.js.map +1 -1
  8. package/dist/cli.js +5 -4
  9. package/dist/cli.js.map +1 -1
  10. package/dist/commands/Config.d.ts.map +1 -1
  11. package/dist/commands/Config.js +6 -5
  12. package/dist/commands/Config.js.map +1 -1
  13. package/dist/commands/DataExport.d.ts.map +1 -1
  14. package/dist/commands/DataExport.js +11 -15
  15. package/dist/commands/DataExport.js.map +1 -1
  16. package/dist/commands/Discover.d.ts.map +1 -1
  17. package/dist/commands/Discover.js +28 -74
  18. package/dist/commands/Discover.js.map +1 -1
  19. package/dist/commands/MatchList.d.ts.map +1 -1
  20. package/dist/commands/MatchList.js +49 -76
  21. package/dist/commands/MatchList.js.map +1 -1
  22. package/dist/commands/Presence.d.ts.map +1 -1
  23. package/dist/commands/Presence.js +10 -8
  24. package/dist/commands/Presence.js.map +1 -1
  25. package/dist/commands/Privacy.d.ts.map +1 -1
  26. package/dist/commands/Privacy.js +16 -31
  27. package/dist/commands/Privacy.js.map +1 -1
  28. package/dist/commands/Settings.d.ts.map +1 -1
  29. package/dist/commands/Settings.js +13 -31
  30. package/dist/commands/Settings.js.map +1 -1
  31. package/dist/commands/Stats.d.ts.map +1 -1
  32. package/dist/commands/Stats.js +12 -31
  33. package/dist/commands/Stats.js.map +1 -1
  34. package/dist/features/chat/components/ChatList.d.ts.map +1 -1
  35. package/dist/features/chat/components/ChatList.js +20 -38
  36. package/dist/features/chat/components/ChatList.js.map +1 -1
  37. package/dist/features/network/components/UnfriendByUsername.d.ts.map +1 -1
  38. package/dist/features/network/components/UnfriendByUsername.js +8 -8
  39. package/dist/features/network/components/UnfriendByUsername.js.map +1 -1
  40. package/dist/features/network/components/network.screen.d.ts.map +1 -1
  41. package/dist/features/network/components/network.screen.js +8 -7
  42. package/dist/features/network/components/network.screen.js.map +1 -1
  43. package/dist/features/profile/components/profile-edit-v3.screen.d.ts.map +1 -1
  44. package/dist/features/profile/components/profile-edit-v3.screen.js +14 -0
  45. package/dist/features/profile/components/profile-edit-v3.screen.js.map +1 -1
  46. package/dist/features/profile/components/profile-edit.screen.d.ts.map +1 -1
  47. package/dist/features/profile/components/profile-edit.screen.js +12 -12
  48. package/dist/features/profile/components/profile-edit.screen.js.map +1 -1
  49. package/dist/features/profile/components/profile-view.screen.d.ts.map +1 -1
  50. package/dist/features/profile/components/profile-view.screen.js +14 -17
  51. package/dist/features/profile/components/profile-view.screen.js.map +1 -1
  52. package/dist/shared/components/DataList.d.ts +10 -0
  53. package/dist/shared/components/DataList.d.ts.map +1 -0
  54. package/dist/shared/components/DataList.js +9 -0
  55. package/dist/shared/components/DataList.js.map +1 -0
  56. package/dist/shared/components/ErrorState.d.ts +7 -0
  57. package/dist/shared/components/ErrorState.d.ts.map +1 -0
  58. package/dist/shared/components/ErrorState.js +6 -0
  59. package/dist/shared/components/ErrorState.js.map +1 -0
  60. package/dist/shared/components/Loader.d.ts +7 -0
  61. package/dist/shared/components/Loader.d.ts.map +1 -0
  62. package/dist/shared/components/Loader.js +7 -0
  63. package/dist/shared/components/Loader.js.map +1 -0
  64. package/dist/shared/components/Screen.d.ts +10 -0
  65. package/dist/shared/components/Screen.d.ts.map +1 -0
  66. package/dist/shared/components/Screen.js +6 -0
  67. package/dist/shared/components/Screen.js.map +1 -0
  68. package/dist/shared/components/index.d.ts +5 -0
  69. package/dist/shared/components/index.d.ts.map +1 -0
  70. package/dist/shared/components/index.js +5 -0
  71. package/dist/shared/components/index.js.map +1 -0
  72. package/dist/shared/hooks/useAsyncRequest.d.ts +9 -0
  73. package/dist/shared/hooks/useAsyncRequest.d.ts.map +1 -0
  74. package/dist/shared/hooks/useAsyncRequest.js +52 -0
  75. package/dist/shared/hooks/useAsyncRequest.js.map +1 -0
  76. package/dist/shared/hooks/useListNavigation.d.ts +5 -0
  77. package/dist/shared/hooks/useListNavigation.d.ts.map +1 -0
  78. package/dist/shared/hooks/useListNavigation.js +15 -0
  79. package/dist/shared/hooks/useListNavigation.js.map +1 -0
  80. package/package.json +4 -4
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ interface ErrorStateProps {
3
+ error: string;
4
+ }
5
+ export declare const ErrorState: React.FC<ErrorStateProps>;
6
+ export {};
7
+ //# sourceMappingURL=ErrorState.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorState.d.ts","sourceRoot":"","sources":["../../../src/shared/components/ErrorState.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,eAAe;IACrB,KAAK,EAAE,MAAM,CAAC;CACjB;AAED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAOhD,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ export const ErrorState = ({ error }) => {
4
+ return (_jsxs(Box, { borderStyle: "double", borderColor: "red", padding: 1, children: [_jsx(Text, { color: "red", bold: true, children: "ERROR: " }), _jsx(Text, { children: error })] }));
5
+ };
6
+ //# sourceMappingURL=ErrorState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorState.js","sourceRoot":"","sources":["../../../src/shared/components/ErrorState.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAMhC,MAAM,CAAC,MAAM,UAAU,GAA8B,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;IAC/D,OAAO,CACH,MAAC,GAAG,IAAC,WAAW,EAAC,QAAQ,EAAC,WAAW,EAAC,KAAK,EAAC,OAAO,EAAE,CAAC,aAClD,KAAC,IAAI,IAAC,KAAK,EAAC,KAAK,EAAC,IAAI,8BAAe,EACrC,KAAC,IAAI,cAAE,KAAK,GAAQ,IAClB,CACT,CAAC;AACN,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ interface LoaderProps {
3
+ text?: string;
4
+ }
5
+ export declare const Loader: React.FC<LoaderProps>;
6
+ export {};
7
+ //# sourceMappingURL=Loader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Loader.d.ts","sourceRoot":"","sources":["../../../src/shared/components/Loader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,WAAW;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,eAAO,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,WAAW,CASxC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ import Spinner from 'ink-spinner';
4
+ export const Loader = ({ text = 'Loading...' }) => {
5
+ return (_jsxs(Box, { padding: 1, children: [_jsx(Text, { color: "green", children: _jsx(Spinner, { type: "dots" }) }), _jsxs(Text, { children: [" ", text] })] }));
6
+ };
7
+ //# sourceMappingURL=Loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Loader.js","sourceRoot":"","sources":["../../../src/shared/components/Loader.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,OAAO,MAAM,aAAa,CAAC;AAMlC,MAAM,CAAC,MAAM,MAAM,GAA0B,CAAC,EAAE,IAAI,GAAG,YAAY,EAAE,EAAE,EAAE;IACrE,OAAO,CACH,MAAC,GAAG,IAAC,OAAO,EAAE,CAAC,aACX,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,YACf,KAAC,OAAO,IAAC,IAAI,EAAC,MAAM,GAAG,GACpB,EACP,MAAC,IAAI,oBAAG,IAAI,IAAQ,IAClB,CACT,CAAC;AACN,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ interface ScreenProps {
3
+ title: string;
4
+ children: React.ReactNode;
5
+ borderColor?: string;
6
+ showFooter?: boolean;
7
+ }
8
+ export declare const Screen: React.FC<ScreenProps>;
9
+ export {};
10
+ //# sourceMappingURL=Screen.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Screen.d.ts","sourceRoot":"","sources":["../../../src/shared/components/Screen.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,WAAW;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,eAAO,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,WAAW,CA2BxC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ export const Screen = ({ title, children, borderColor = 'cyan', showFooter = true }) => {
4
+ return (_jsxs(Box, { flexDirection: "column", borderStyle: "round", borderColor: borderColor, padding: 1, children: [_jsx(Box, { marginBottom: 1, children: _jsx(Text, { bold: true, underline: true, color: borderColor, children: title }) }), _jsx(Box, { flexDirection: "column", flexGrow: 1, children: children }), showFooter && (_jsx(Box, { marginTop: 1, borderStyle: "single", borderColor: "gray", paddingX: 1, children: _jsxs(Text, { color: "gray", children: ["Press ", _jsx(Text, { bold: true, color: "white", children: "ESC" }), " to back/exit \u2022 ", _jsx(Text, { bold: true, color: "white", children: "\u2191\u2193" }), " to navigate \u2022 ", _jsx(Text, { bold: true, color: "white", children: "ENTER" }), " to select"] }) }))] }));
5
+ };
6
+ //# sourceMappingURL=Screen.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Screen.js","sourceRoot":"","sources":["../../../src/shared/components/Screen.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAShC,MAAM,CAAC,MAAM,MAAM,GAA0B,CAAC,EAC1C,KAAK,EACL,QAAQ,EACR,WAAW,GAAG,MAAM,EACpB,UAAU,GAAG,IAAI,EACpB,EAAE,EAAE;IACD,OAAO,CACH,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAC,OAAO,EAAC,WAAW,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,aAChF,KAAC,GAAG,IAAC,YAAY,EAAE,CAAC,YAChB,KAAC,IAAI,IAAC,IAAI,QAAC,SAAS,QAAC,KAAK,EAAE,WAAW,YAClC,KAAK,GACH,GACL,EAEN,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,YAClC,QAAQ,GACP,EAEL,UAAU,IAAI,CACX,KAAC,GAAG,IAAC,SAAS,EAAE,CAAC,EAAE,WAAW,EAAC,QAAQ,EAAC,WAAW,EAAC,MAAM,EAAC,QAAQ,EAAE,CAAC,YAClE,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,uBACR,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,OAAO,oBAAW,2BAAgB,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,OAAO,6BAAU,0BAAe,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,OAAO,sBAAa,kBAC5I,GACL,CACT,IACC,CACT,CAAC;AACN,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export * from './Screen.js';
2
+ export * from './Loader.js';
3
+ export * from './ErrorState.js';
4
+ export * from './DataList.js';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/shared/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC"}
@@ -0,0 +1,5 @@
1
+ export * from './Screen.js';
2
+ export * from './Loader.js';
3
+ export * from './ErrorState.js';
4
+ export * from './DataList.js';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/shared/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC"}
@@ -0,0 +1,9 @@
1
+ interface UseAsyncRequestResult<T> {
2
+ data: T | null;
3
+ loading: boolean;
4
+ error: string | null;
5
+ refetch: () => Promise<void>;
6
+ }
7
+ export declare const useAsyncRequest: <T>(url: string | null, method?: "get" | "post", body?: any) => UseAsyncRequestResult<T>;
8
+ export {};
9
+ //# sourceMappingURL=useAsyncRequest.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAsyncRequest.d.ts","sourceRoot":"","sources":["../../../src/shared/hooks/useAsyncRequest.ts"],"names":[],"mappings":"AAKA,UAAU,qBAAqB,CAAC,CAAC;IAC7B,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAChC;AAED,eAAO,MAAM,eAAe,GAAI,CAAC,EAC7B,KAAK,MAAM,GAAG,IAAI,EAClB,SAAQ,KAAK,GAAG,MAAc,EAC9B,OAAO,GAAG,KACX,qBAAqB,CAAC,CAAC,CAiDzB,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { useState, useEffect, useCallback } from 'react';
2
+ import api from '../../api.js';
3
+ import { useAuth } from '../../context/index.js';
4
+ import { useApp } from 'ink';
5
+ export const useAsyncRequest = (url, method = 'get', body) => {
6
+ const [data, setData] = useState(null);
7
+ const [loading, setLoading] = useState(true);
8
+ const [error, setError] = useState(null);
9
+ const { isAuthenticated, isLoading: authLoading } = useAuth();
10
+ const { exit } = useApp();
11
+ const fetchData = useCallback(async () => {
12
+ if (!url) {
13
+ setLoading(false);
14
+ return;
15
+ }
16
+ if (authLoading)
17
+ return;
18
+ if (!isAuthenticated) {
19
+ setError('Please login first using "hackmate auth login"');
20
+ setLoading(false);
21
+ // Optional: Auto-exit? Let's leave it to the UI component to decide via useEffect
22
+ return;
23
+ }
24
+ setLoading(true);
25
+ setError(null);
26
+ try {
27
+ let res;
28
+ if (method === 'get') {
29
+ res = await api.get(url);
30
+ }
31
+ else {
32
+ res = await api.post(url, body);
33
+ }
34
+ setData(res.data);
35
+ }
36
+ catch (err) {
37
+ let msg = err.response?.data?.message || err.message || 'Request failed';
38
+ if (msg.includes('No Authorization')) {
39
+ msg = 'Please login first using "hackmate auth login"';
40
+ }
41
+ setError(msg);
42
+ }
43
+ finally {
44
+ setLoading(false);
45
+ }
46
+ }, [url, method, body, isAuthenticated, authLoading]);
47
+ useEffect(() => {
48
+ fetchData();
49
+ }, [fetchData]);
50
+ return { data, loading, error, refetch: fetchData };
51
+ };
52
+ //# sourceMappingURL=useAsyncRequest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAsyncRequest.js","sourceRoot":"","sources":["../../../src/shared/hooks/useAsyncRequest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,GAAG,MAAM,cAAc,CAAC;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAS7B,MAAM,CAAC,MAAM,eAAe,GAAG,CAC3B,GAAkB,EAClB,SAAyB,KAAK,EAC9B,IAAU,EACc,EAAE;IAC1B,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAW,IAAI,CAAC,CAAC;IACjD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC7C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAC;IACxD,MAAM,EAAE,eAAe,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,OAAO,EAAE,CAAC;IAC9D,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,EAAE,CAAC;IAE1B,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAErC,IAAI,CAAC,GAAG,EAAE,CAAC;YACP,UAAU,CAAC,KAAK,CAAC,CAAC;YAClB,OAAO;QACX,CAAC;QAED,IAAI,WAAW;YAAE,OAAO;QAExB,IAAI,CAAC,eAAe,EAAE,CAAC;YACnB,QAAQ,CAAC,gDAAgD,CAAC,CAAC;YAC3D,UAAU,CAAC,KAAK,CAAC,CAAC;YAClB,kFAAkF;YAClF,OAAO;QACX,CAAC;QAED,UAAU,CAAC,IAAI,CAAC,CAAC;QACjB,QAAQ,CAAC,IAAI,CAAC,CAAC;QACf,IAAI,CAAC;YACD,IAAI,GAAG,CAAC;YACR,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;gBACnB,GAAG,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC,GAAI,CAAC,CAAC;YAC9B,CAAC;iBAAM,CAAC;gBACJ,GAAG,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC,GAAI,EAAE,IAAI,CAAC,CAAC;YACrC,CAAC;YACD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAChB,IAAI,GAAG,GAAG,GAAG,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,IAAI,GAAG,CAAC,OAAO,IAAI,gBAAgB,CAAC;YACzE,IAAI,GAAG,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,CAAC;gBACnC,GAAG,GAAG,gDAAgD,CAAC;YAC3D,CAAC;YACD,QAAQ,CAAC,GAAG,CAAC,CAAC;QAClB,CAAC;gBAAS,CAAC;YACP,UAAU,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;IACL,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,WAAW,CAAC,CAAC,CAAC;IAEtD,SAAS,CAAC,GAAG,EAAE;QACX,SAAS,EAAE,CAAC;IAChB,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;AACxD,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare const useListNavigation: (itemCount: number, initialIndex?: number) => {
2
+ selectedIndex: number;
3
+ setSelectedIndex: import("react").Dispatch<import("react").SetStateAction<number>>;
4
+ };
5
+ //# sourceMappingURL=useListNavigation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useListNavigation.d.ts","sourceRoot":"","sources":["../../../src/shared/hooks/useListNavigation.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,iBAAiB,GAAI,WAAW,MAAM,EAAE,qBAAgB;;;CAapE,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { useState } from 'react';
2
+ import { useInput } from 'ink';
3
+ export const useListNavigation = (itemCount, initialIndex = 0) => {
4
+ const [selectedIndex, setSelectedIndex] = useState(initialIndex);
5
+ useInput((input, key) => {
6
+ if (key.upArrow) {
7
+ setSelectedIndex((prev) => Math.max(0, prev - 1));
8
+ }
9
+ if (key.downArrow) {
10
+ setSelectedIndex((prev) => Math.min(itemCount - 1, prev + 1));
11
+ }
12
+ });
13
+ return { selectedIndex, setSelectedIndex };
14
+ };
15
+ //# sourceMappingURL=useListNavigation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useListNavigation.js","sourceRoot":"","sources":["../../../src/shared/hooks/useListNavigation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAE/B,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,SAAiB,EAAE,YAAY,GAAG,CAAC,EAAE,EAAE;IACrE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;IAEjE,QAAQ,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACpB,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;YACd,gBAAgB,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;QACtD,CAAC;QACD,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;YAChB,gBAAgB,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;QAClE,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,CAAC;AAC/C,CAAC,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hackmate-cli",
3
- "version": "1.0.28",
3
+ "version": "1.1.0",
4
4
  "description": "HackMate CLI - Terminal-based social network for developers and hackers",
5
5
  "type": "module",
6
6
  "bin": {
@@ -33,11 +33,11 @@
33
33
  "access": "public"
34
34
  },
35
35
  "dependencies": {
36
- "axios": "^1.13.2",
36
+ "axios": "^1.6.0",
37
37
  "chalk": "^5.0.0",
38
38
  "commander": "^12.0.0",
39
39
  "conf": "^15.0.2",
40
- "dotenv": "^17.2.3",
40
+ "dotenv": "^16.4.0",
41
41
  "ink": "^5.0.0",
42
42
  "ink-select-input": "^6.2.0",
43
43
  "ink-spinner": "^5.0.0",
@@ -55,4 +55,4 @@
55
55
  "engines": {
56
56
  "node": ">=20"
57
57
  }
58
- }
58
+ }