harnessforce 1.0.1

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 (42) hide show
  1. package/dist/commands/format.d.ts +23 -0
  2. package/dist/commands/format.d.ts.map +1 -0
  3. package/dist/commands/format.js +107 -0
  4. package/dist/commands/format.js.map +1 -0
  5. package/dist/commands/model.d.ts +15 -0
  6. package/dist/commands/model.d.ts.map +1 -0
  7. package/dist/commands/model.js +169 -0
  8. package/dist/commands/model.js.map +1 -0
  9. package/dist/commands/registry.d.ts +38 -0
  10. package/dist/commands/registry.d.ts.map +1 -0
  11. package/dist/commands/registry.js +1383 -0
  12. package/dist/commands/registry.js.map +1 -0
  13. package/dist/commands/skill.d.ts +10 -0
  14. package/dist/commands/skill.d.ts.map +1 -0
  15. package/dist/commands/skill.js +63 -0
  16. package/dist/commands/skill.js.map +1 -0
  17. package/dist/commands/tool.d.ts +9 -0
  18. package/dist/commands/tool.d.ts.map +1 -0
  19. package/dist/commands/tool.js +35 -0
  20. package/dist/commands/tool.js.map +1 -0
  21. package/dist/index.d.ts +3 -0
  22. package/dist/index.d.ts.map +1 -0
  23. package/dist/index.js +239 -0
  24. package/dist/index.js.map +1 -0
  25. package/dist/ui/agent-astro.png +0 -0
  26. package/dist/ui/app.d.ts +19 -0
  27. package/dist/ui/app.d.ts.map +1 -0
  28. package/dist/ui/app.js +384 -0
  29. package/dist/ui/app.js.map +1 -0
  30. package/dist/ui/greeting.d.ts +7 -0
  31. package/dist/ui/greeting.d.ts.map +1 -0
  32. package/dist/ui/greeting.js +109 -0
  33. package/dist/ui/greeting.js.map +1 -0
  34. package/dist/ui/markdown.d.ts +9 -0
  35. package/dist/ui/markdown.d.ts.map +1 -0
  36. package/dist/ui/markdown.js +98 -0
  37. package/dist/ui/markdown.js.map +1 -0
  38. package/dist/ui/status-bar.d.ts +10 -0
  39. package/dist/ui/status-bar.d.ts.map +1 -0
  40. package/dist/ui/status-bar.js +7 -0
  41. package/dist/ui/status-bar.js.map +1 -0
  42. package/package.json +45 -0
@@ -0,0 +1,98 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { Text } from "ink";
3
+ /**
4
+ * Render a markdown string as styled Ink <Text> elements.
5
+ * Handles: **bold**, `code`, ## headings, - list items, ```code blocks```
6
+ */
7
+ export function MarkdownText({ children }) {
8
+ const lines = children.split("\n");
9
+ const elements = [];
10
+ let inCodeBlock = false;
11
+ let codeBlockLines = [];
12
+ for (let i = 0; i < lines.length; i++) {
13
+ const line = lines[i];
14
+ // Code block toggle
15
+ if (line.trimStart().startsWith("```")) {
16
+ if (inCodeBlock) {
17
+ // End code block
18
+ elements.push(_jsx(Text, { color: "#A0A0A0", children: codeBlockLines.join("\n") }, `cb-${i}`));
19
+ codeBlockLines = [];
20
+ inCodeBlock = false;
21
+ }
22
+ else {
23
+ inCodeBlock = true;
24
+ }
25
+ continue;
26
+ }
27
+ if (inCodeBlock) {
28
+ codeBlockLines.push(line);
29
+ continue;
30
+ }
31
+ // Heading ##
32
+ if (line.match(/^#{1,3}\s/)) {
33
+ const text = line.replace(/^#{1,3}\s+/, "");
34
+ elements.push(_jsx(Text, { bold: true, color: "#00A1E0", children: text }, i));
35
+ continue;
36
+ }
37
+ // List item -
38
+ if (line.match(/^\s*-\s/)) {
39
+ const indent = line.match(/^(\s*)/)?.[1] ?? "";
40
+ const text = line.replace(/^\s*-\s+/, "");
41
+ elements.push(_jsxs(Text, { children: [indent, " • ", renderInline(text, i)] }, i));
42
+ continue;
43
+ }
44
+ // Empty line
45
+ if (!line.trim()) {
46
+ elements.push(_jsx(Text, { children: " " }, i));
47
+ continue;
48
+ }
49
+ // Regular text with inline formatting
50
+ elements.push(_jsx(Text, { children: renderInline(line, i) }, i));
51
+ }
52
+ // Close unclosed code block
53
+ if (inCodeBlock && codeBlockLines.length > 0) {
54
+ elements.push(_jsx(Text, { color: "#A0A0A0", children: codeBlockLines.join("\n") }, "cb-end"));
55
+ }
56
+ return _jsx(_Fragment, { children: elements.map((el, i) => _jsxs(Text, { children: [el, "\n"] }, i)) });
57
+ }
58
+ /**
59
+ * Render inline markdown: **bold**, `code`
60
+ */
61
+ function renderInline(text, lineKey) {
62
+ // Split on **bold** and `code` patterns
63
+ const parts = [];
64
+ let remaining = text;
65
+ let partIndex = 0;
66
+ while (remaining.length > 0) {
67
+ // Check for **bold**
68
+ const boldMatch = remaining.match(/\*\*(.+?)\*\*/);
69
+ // Check for `code`
70
+ const codeMatch = remaining.match(/`([^`]+)`/);
71
+ // Find which comes first
72
+ const boldIdx = boldMatch?.index ?? Infinity;
73
+ const codeIdx = codeMatch?.index ?? Infinity;
74
+ if (boldIdx === Infinity && codeIdx === Infinity) {
75
+ // No more patterns — push rest as plain text
76
+ parts.push(_jsx(Text, { children: remaining }, `${lineKey}-${partIndex++}`));
77
+ break;
78
+ }
79
+ if (boldIdx <= codeIdx && boldMatch) {
80
+ // Bold comes first
81
+ if (boldIdx > 0) {
82
+ parts.push(_jsx(Text, { children: remaining.slice(0, boldIdx) }, `${lineKey}-${partIndex++}`));
83
+ }
84
+ parts.push(_jsx(Text, { bold: true, children: boldMatch[1] }, `${lineKey}-${partIndex++}`));
85
+ remaining = remaining.slice(boldIdx + boldMatch[0].length);
86
+ }
87
+ else if (codeMatch) {
88
+ // Code comes first
89
+ if (codeIdx > 0) {
90
+ parts.push(_jsx(Text, { children: remaining.slice(0, codeIdx) }, `${lineKey}-${partIndex++}`));
91
+ }
92
+ parts.push(_jsx(Text, { color: "#F5A623", children: codeMatch[1] }, `${lineKey}-${partIndex++}`));
93
+ remaining = remaining.slice(codeIdx + codeMatch[0].length);
94
+ }
95
+ }
96
+ return _jsx(_Fragment, { children: parts });
97
+ }
98
+ //# sourceMappingURL=markdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown.js","sourceRoot":"","sources":["../../src/ui/markdown.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ interface StatusBarProps {
2
+ permissionMode: string;
3
+ model?: string;
4
+ org?: string;
5
+ tokenCount?: number;
6
+ gitBranch?: string;
7
+ }
8
+ export declare function StatusBar({ permissionMode, model, org, tokenCount, gitBranch }: StatusBarProps): import("react/jsx-runtime").JSX.Element;
9
+ export {};
10
+ //# sourceMappingURL=status-bar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status-bar.d.ts","sourceRoot":"","sources":["../../src/ui/status-bar.tsx"],"names":[],"mappings":"AAGA,UAAU,cAAc;IACtB,cAAc,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,SAAS,CAAC,EAAE,cAAc,EAAE,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE,SAAS,EAAE,EAAE,cAAc,2CAY9F"}
@@ -0,0 +1,7 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { Box, Text } from "ink";
3
+ export function StatusBar({ permissionMode, model, org, tokenCount, gitBranch }) {
4
+ const modeColor = permissionMode === "plan" ? "#F5A623" : permissionMode === "yolo" ? "#FF4444" : "#00A1E0";
5
+ return (_jsxs(Box, { borderStyle: "single", borderColor: "gray", paddingX: 1, children: [_jsxs(Text, { color: modeColor, bold: true, children: ["[", permissionMode.toUpperCase(), "]"] }), model && _jsxs(Text, { dimColor: true, children: [" ", model.split("/").pop()] }), org && _jsxs(Text, { dimColor: true, children: [" org:", org] }), tokenCount !== undefined && _jsxs(Text, { dimColor: true, children: [" ", tokenCount, "tok"] }), gitBranch && _jsxs(Text, { dimColor: true, children: [" ", gitBranch] }), _jsx(Text, { dimColor: true, children: " shift+tab to cycle" })] }));
6
+ }
7
+ //# sourceMappingURL=status-bar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status-bar.js","sourceRoot":"","sources":["../../src/ui/status-bar.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAUhC,MAAM,UAAU,SAAS,CAAC,EAAE,cAAc,EAAE,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE,SAAS,EAAkB;IAC7F,MAAM,SAAS,GAAG,cAAc,KAAK,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,cAAc,KAAK,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAC5G,OAAO,CACL,MAAC,GAAG,IAAC,WAAW,EAAC,QAAQ,EAAC,WAAW,EAAC,MAAM,EAAC,QAAQ,EAAE,CAAC,aACtD,MAAC,IAAI,IAAC,KAAK,EAAE,SAAS,EAAE,IAAI,wBAAG,cAAc,CAAC,WAAW,EAAE,SAAS,EACnE,KAAK,IAAI,MAAC,IAAI,IAAC,QAAQ,wBAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,IAAQ,EACxD,GAAG,IAAI,MAAC,IAAI,IAAC,QAAQ,4BAAO,GAAG,IAAQ,EACvC,UAAU,KAAK,SAAS,IAAI,MAAC,IAAI,IAAC,QAAQ,wBAAG,UAAU,WAAW,EAClE,SAAS,IAAI,MAAC,IAAI,IAAC,QAAQ,wBAAG,SAAS,IAAQ,EAChD,KAAC,IAAI,IAAC,QAAQ,0CAA2B,IACrC,CACP,CAAC;AACJ,CAAC"}
package/package.json ADDED
@@ -0,0 +1,45 @@
1
+ {
2
+ "name": "harnessforce",
3
+ "version": "1.0.1",
4
+ "description": "Harnessforce CLI — an open-source agent harness for Salesforce development",
5
+ "type": "module",
6
+ "bin": {
7
+ "harnessforce": "./dist/index.js"
8
+ },
9
+ "scripts": {
10
+ "build": "tsc && cp src/ui/agent-astro.png dist/ui/agent-astro.png",
11
+ "dev": "tsc --watch",
12
+ "start": "node dist/index.js"
13
+ },
14
+ "dependencies": {
15
+ "chalk": "^5.6.2",
16
+ "commander": "^14.0.3",
17
+ "figlet": "^1.11.0",
18
+ "gradient-string": "^3.0.0",
19
+ "ink": "^6.8.0",
20
+ "ink-text-input": "^6.0.0",
21
+ "react": "^19.2.4",
22
+ "harnessforce-core": "1.0.1"
23
+ },
24
+ "devDependencies": {
25
+ "@types/figlet": "^1.7.0",
26
+ "@types/gradient-string": "^1.1.6",
27
+ "@types/ink-text-input": "^2.0.5",
28
+ "@types/react": "^19.2.14",
29
+ "typescript": "^5.7.0"
30
+ },
31
+ "files": [
32
+ "dist",
33
+ "package.json",
34
+ "README.md"
35
+ ],
36
+ "publishConfig": {
37
+ "access": "public"
38
+ },
39
+ "repository": {
40
+ "type": "git",
41
+ "url": "https://github.com/skyrmionz/harnessforce.git",
42
+ "directory": "apps/cli"
43
+ },
44
+ "license": "MIT"
45
+ }