ValidatePlugin.tsx
commands/plugin/ValidatePlugin.tsx
98
Lines
12369
Bytes
1
Exports
9
Imports
10
Keywords
What this is
This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.
Beginner explanation
This file lives in the command layer. It likely turns a user action into concrete program behavior.
How it is used
Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.
Expert explanation
Architecturally, this file intersects with commands. It contains 98 lines, 9 detected imports, and 1 detected exports.
Important relationships
Detected exports
ValidatePlugin
Keywords
outputresultpathfiguresoncompletepluginlengthwarningsreacterrors
Detected imports
react/compiler-runtimefiguresreactreact../../ink.js../../utils/errors.js../../utils/log.js../../utils/plugins/validatePlugin.js../../utils/stringUtils.js
Source notes
This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.
Full source
import { c as _c } from "react/compiler-runtime";
import figures from 'figures';
import * as React from 'react';
import { useEffect } from 'react';
import { Box, Text } from '../../ink.js';
import { errorMessage } from '../../utils/errors.js';
import { logError } from '../../utils/log.js';
import { validateManifest } from '../../utils/plugins/validatePlugin.js';
import { plural } from '../../utils/stringUtils.js';
type Props = {
onComplete: (result?: string) => void;
path?: string;
};
export function ValidatePlugin(t0) {
const $ = _c(5);
const {
onComplete,
path
} = t0;
let t1;
let t2;
if ($[0] !== onComplete || $[1] !== path) {
t1 = () => {
const runValidation = async function runValidation() {
if (!path) {
onComplete("Usage: /plugin validate <path>\n\nValidate a plugin or marketplace manifest file or directory.\n\nExamples:\n /plugin validate .claude-plugin/plugin.json\n /plugin validate /path/to/plugin-directory\n /plugin validate .\n\nWhen given a directory, automatically validates .claude-plugin/marketplace.json\nor .claude-plugin/plugin.json (prefers marketplace if both exist).\n\nOr from the command line:\n claude plugin validate <path>");
return;
}
;
try {
const result = await validateManifest(path);
let output = "";
output = output + `Validating ${result.fileType} manifest: ${result.filePath}\n\n`;
output;
if (result.errors.length > 0) {
output = output + `${figures.cross} Found ${result.errors.length} ${plural(result.errors.length, "error")}:\n\n`;
output;
result.errors.forEach(error_0 => {
output = output + ` ${figures.pointer} ${error_0.path}: ${error_0.message}\n`;
output;
});
output = output + "\n";
output;
}
if (result.warnings.length > 0) {
output = output + `${figures.warning} Found ${result.warnings.length} ${plural(result.warnings.length, "warning")}:\n\n`;
output;
result.warnings.forEach(warning => {
output = output + ` ${figures.pointer} ${warning.path}: ${warning.message}\n`;
output;
});
output = output + "\n";
output;
}
if (result.success) {
if (result.warnings.length > 0) {
output = output + `${figures.tick} Validation passed with warnings\n`;
output;
} else {
output = output + `${figures.tick} Validation passed\n`;
output;
}
process.exitCode = 0;
} else {
output = output + `${figures.cross} Validation failed\n`;
output;
process.exitCode = 1;
}
onComplete(output);
} catch (t3) {
const error = t3;
process.exitCode = 2;
logError(error);
onComplete(`${figures.cross} Unexpected error during validation: ${errorMessage(error)}`);
}
};
runValidation();
};
t2 = [onComplete, path];
$[0] = onComplete;
$[1] = path;
$[2] = t1;
$[3] = t2;
} else {
t1 = $[2];
t2 = $[3];
}
useEffect(t1, t2);
let t3;
if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
t3 = <Box flexDirection="column"><Text>Running validation...</Text></Box>;
$[4] = t3;
} else {
t3 = $[4];
}
return t3;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["figures","React","useEffect","Box","Text","errorMessage","logError","validateManifest","plural","Props","onComplete","result","path","ValidatePlugin","t0","$","_c","t1","t2","runValidation","output","fileType","filePath","errors","length","cross","forEach","error_0","pointer","error","message","warnings","warning","success","tick","process","exitCode","t3","Symbol","for"],"sources":["ValidatePlugin.tsx"],"sourcesContent":["import figures from 'figures'\nimport * as React from 'react'\nimport { useEffect } from 'react'\nimport { Box, Text } from '../../ink.js'\nimport { errorMessage } from '../../utils/errors.js'\nimport { logError } from '../../utils/log.js'\nimport { validateManifest } from '../../utils/plugins/validatePlugin.js'\nimport { plural } from '../../utils/stringUtils.js'\n\ntype Props = {\n  onComplete: (result?: string) => void\n  path?: string\n}\n\nexport function ValidatePlugin({ onComplete, path }: Props): React.ReactNode {\n  useEffect(() => {\n    async function runValidation() {\n      // If no path provided, show usage\n      if (!path) {\n        onComplete(\n          'Usage: /plugin validate <path>\\n\\n' +\n            'Validate a plugin or marketplace manifest file or directory.\\n\\n' +\n            'Examples:\\n' +\n            '  /plugin validate .claude-plugin/plugin.json\\n' +\n            '  /plugin validate /path/to/plugin-directory\\n' +\n            '  /plugin validate .\\n\\n' +\n            'When given a directory, automatically validates .claude-plugin/marketplace.json\\n' +\n            'or .claude-plugin/plugin.json (prefers marketplace if both exist).\\n\\n' +\n            'Or from the command line:\\n' +\n            '  claude plugin validate <path>',\n        )\n        return\n      }\n\n      try {\n        const result = await validateManifest(path)\n\n        let output = ''\n\n        // Add header\n        output += `Validating ${result.fileType} manifest: ${result.filePath}\\n\\n`\n\n        // Show errors\n        if (result.errors.length > 0) {\n          output += `${figures.cross} Found ${result.errors.length} ${plural(result.errors.length, 'error')}:\\n\\n`\n\n          result.errors.forEach(error => {\n            output += `  ${figures.pointer} ${error.path}: ${error.message}\\n`\n          })\n\n          output += '\\n'\n        }\n\n        // Show warnings\n        if (result.warnings.length > 0) {\n          output += `${figures.warning} Found ${result.warnings.length} ${plural(result.warnings.length, 'warning')}:\\n\\n`\n\n          result.warnings.forEach(warning => {\n            output += `  ${figures.pointer} ${warning.path}: ${warning.message}\\n`\n          })\n\n          output += '\\n'\n        }\n\n        // Show success or failure\n        if (result.success) {\n          if (result.warnings.length > 0) {\n            output += `${figures.tick} Validation passed with warnings\\n`\n          } else {\n            output += `${figures.tick} Validation passed\\n`\n          }\n\n          // Exit with code 0 (success)\n          process.exitCode = 0\n        } else {\n          output += `${figures.cross} Validation failed\\n`\n\n          // Exit with code 1 (validation failure)\n          process.exitCode = 1\n        }\n\n        onComplete(output)\n      } catch (error) {\n        // Exit with code 2 (unexpected error)\n        process.exitCode = 2\n\n        logError(error)\n\n        onComplete(\n          `${figures.cross} Unexpected error during validation: ${errorMessage(error)}`,\n        )\n      }\n    }\n\n    void runValidation()\n  }, [onComplete, path])\n\n  return (\n    <Box flexDirection=\"column\">\n      <Text>Running validation...</Text>\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}