Filemedium importancesource

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-runtime
  • figures
  • react
  • react
  • ../../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.

Open parent directory

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":[]}