Filehigh importancesource

WorkflowMultiselectDialog.tsx

components/WorkflowMultiselectDialog.tsx

128
Lines
14276
Bytes
1
Exports
10
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 is one piece of the larger system. Its name, directory, imports, and exports show where it fits. Start by reading the exports and related files first.

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 tasks-background-jobs, ui-flow, workflow. It contains 128 lines, 10 detected imports, and 1 detected exports.

Important relationships

Detected exports

  • WorkflowMultiselectDialog

Keywords

workflowreactelsetextonsubmitexitstatekeyboardshortcuthintlabeldefaultselectionssetshowerror

Detected imports

  • react/compiler-runtime
  • react
  • ../commands/install-github-app/types.js
  • ../hooks/useExitOnCtrlCDWithKeybindings.js
  • ../ink.js
  • ./ConfigurableShortcutHint.js
  • ./CustomSelect/SelectMulti.js
  • ./design-system/Byline.js
  • ./design-system/Dialog.js
  • ./design-system/KeyboardShortcutHint.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 React, { useCallback, useState } from 'react';
import type { Workflow } from '../commands/install-github-app/types.js';
import type { ExitState } from '../hooks/useExitOnCtrlCDWithKeybindings.js';
import { Box, Link, Text } from '../ink.js';
import { ConfigurableShortcutHint } from './ConfigurableShortcutHint.js';
import { SelectMulti } from './CustomSelect/SelectMulti.js';
import { Byline } from './design-system/Byline.js';
import { Dialog } from './design-system/Dialog.js';
import { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js';
type WorkflowOption = {
  value: Workflow;
  label: string;
};
type Props = {
  onSubmit: (selectedWorkflows: Workflow[]) => void;
  defaultSelections: Workflow[];
};
const WORKFLOWS: WorkflowOption[] = [{
  value: 'claude' as const,
  label: '@Claude Code - Tag @claude in issues and PR comments'
}, {
  value: 'claude-review' as const,
  label: 'Claude Code Review - Automated code review on new PRs'
}];
function renderInputGuide(exitState: ExitState): React.ReactNode {
  if (exitState.pending) {
    return <Text>Press {exitState.keyName} again to exit</Text>;
  }
  return <Byline>
      <KeyboardShortcutHint shortcut="↑↓" action="navigate" />
      <KeyboardShortcutHint shortcut="Space" action="toggle" />
      <KeyboardShortcutHint shortcut="Enter" action="confirm" />
      <ConfigurableShortcutHint action="confirm:no" context="Confirmation" fallback="Esc" description="cancel" />
    </Byline>;
}
export function WorkflowMultiselectDialog(t0) {
  const $ = _c(14);
  const {
    onSubmit,
    defaultSelections
  } = t0;
  const [showError, setShowError] = useState(false);
  let t1;
  if ($[0] !== onSubmit) {
    t1 = selectedValues => {
      if (selectedValues.length === 0) {
        setShowError(true);
        return;
      }
      setShowError(false);
      onSubmit(selectedValues);
    };
    $[0] = onSubmit;
    $[1] = t1;
  } else {
    t1 = $[1];
  }
  const handleSubmit = t1;
  let t2;
  if ($[2] === Symbol.for("react.memo_cache_sentinel")) {
    t2 = () => {
      setShowError(false);
    };
    $[2] = t2;
  } else {
    t2 = $[2];
  }
  const handleChange = t2;
  let t3;
  if ($[3] === Symbol.for("react.memo_cache_sentinel")) {
    t3 = () => {
      setShowError(true);
    };
    $[3] = t3;
  } else {
    t3 = $[3];
  }
  const handleCancel = t3;
  let t4;
  if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
    t4 = <Box><Text dimColor={true}>More workflow examples (issue triage, CI fixes, etc.) at:{" "}<Link url="https://github.com/anthropics/claude-code-action/blob/main/examples/">https://github.com/anthropics/claude-code-action/blob/main/examples/</Link></Text></Box>;
    $[4] = t4;
  } else {
    t4 = $[4];
  }
  let t5;
  if ($[5] === Symbol.for("react.memo_cache_sentinel")) {
    t5 = WORKFLOWS.map(_temp);
    $[5] = t5;
  } else {
    t5 = $[5];
  }
  let t6;
  if ($[6] !== defaultSelections || $[7] !== handleSubmit) {
    t6 = <SelectMulti options={t5} defaultValue={defaultSelections} onSubmit={handleSubmit} onChange={handleChange} onCancel={handleCancel} hideIndexes={true} />;
    $[6] = defaultSelections;
    $[7] = handleSubmit;
    $[8] = t6;
  } else {
    t6 = $[8];
  }
  let t7;
  if ($[9] !== showError) {
    t7 = showError && <Box><Text color="error">You must select at least one workflow to continue</Text></Box>;
    $[9] = showError;
    $[10] = t7;
  } else {
    t7 = $[10];
  }
  let t8;
  if ($[11] !== t6 || $[12] !== t7) {
    t8 = <Dialog title="Select GitHub workflows to install" subtitle="We'll create a workflow file in your repository for each one you select." onCancel={handleCancel} inputGuide={renderInputGuide}>{t4}{t6}{t7}</Dialog>;
    $[11] = t6;
    $[12] = t7;
    $[13] = t8;
  } else {
    t8 = $[13];
  }
  return t8;
}
function _temp(workflow) {
  return {
    label: workflow.label,
    value: workflow.value
  };
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useCallback","useState","Workflow","ExitState","Box","Link","Text","ConfigurableShortcutHint","SelectMulti","Byline","Dialog","KeyboardShortcutHint","WorkflowOption","value","label","Props","onSubmit","selectedWorkflows","defaultSelections","WORKFLOWS","const","renderInputGuide","exitState","ReactNode","pending","keyName","WorkflowMultiselectDialog","t0","$","_c","showError","setShowError","t1","selectedValues","length","handleSubmit","t2","Symbol","for","handleChange","t3","handleCancel","t4","t5","map","_temp","t6","t7","t8","workflow"],"sources":["WorkflowMultiselectDialog.tsx"],"sourcesContent":["import React, { useCallback, useState } from 'react'\nimport type { Workflow } from '../commands/install-github-app/types.js'\nimport type { ExitState } from '../hooks/useExitOnCtrlCDWithKeybindings.js'\nimport { Box, Link, Text } from '../ink.js'\nimport { ConfigurableShortcutHint } from './ConfigurableShortcutHint.js'\nimport { SelectMulti } from './CustomSelect/SelectMulti.js'\nimport { Byline } from './design-system/Byline.js'\nimport { Dialog } from './design-system/Dialog.js'\nimport { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js'\n\ntype WorkflowOption = {\n  value: Workflow\n  label: string\n}\n\ntype Props = {\n  onSubmit: (selectedWorkflows: Workflow[]) => void\n  defaultSelections: Workflow[]\n}\n\nconst WORKFLOWS: WorkflowOption[] = [\n  {\n    value: 'claude' as const,\n    label: '@Claude Code - Tag @claude in issues and PR comments',\n  },\n  {\n    value: 'claude-review' as const,\n    label: 'Claude Code Review - Automated code review on new PRs',\n  },\n]\n\nfunction renderInputGuide(exitState: ExitState): React.ReactNode {\n  if (exitState.pending) {\n    return <Text>Press {exitState.keyName} again to exit</Text>\n  }\n  return (\n    <Byline>\n      <KeyboardShortcutHint shortcut=\"↑↓\" action=\"navigate\" />\n      <KeyboardShortcutHint shortcut=\"Space\" action=\"toggle\" />\n      <KeyboardShortcutHint shortcut=\"Enter\" action=\"confirm\" />\n      <ConfigurableShortcutHint\n        action=\"confirm:no\"\n        context=\"Confirmation\"\n        fallback=\"Esc\"\n        description=\"cancel\"\n      />\n    </Byline>\n  )\n}\n\nexport function WorkflowMultiselectDialog({\n  onSubmit,\n  defaultSelections,\n}: Props): React.ReactNode {\n  const [showError, setShowError] = useState(false)\n\n  const handleSubmit = useCallback(\n    (selectedValues: Workflow[]) => {\n      if (selectedValues.length === 0) {\n        setShowError(true)\n        return\n      }\n      setShowError(false)\n      onSubmit(selectedValues)\n    },\n    [onSubmit],\n  )\n\n  const handleChange = useCallback(() => {\n    setShowError(false)\n  }, [])\n\n  // Cancel just shows the error - user must select at least one workflow\n  const handleCancel = useCallback(() => {\n    setShowError(true)\n  }, [])\n\n  return (\n    <Dialog\n      title=\"Select GitHub workflows to install\"\n      subtitle=\"We'll create a workflow file in your repository for each one you select.\"\n      onCancel={handleCancel}\n      inputGuide={renderInputGuide}\n    >\n      <Box>\n        <Text dimColor>\n          More workflow examples (issue triage, CI fixes, etc.) at:{' '}\n          <Link url=\"https://github.com/anthropics/claude-code-action/blob/main/examples/\">\n            https://github.com/anthropics/claude-code-action/blob/main/examples/\n          </Link>\n        </Text>\n      </Box>\n\n      <SelectMulti\n        options={WORKFLOWS.map(workflow => ({\n          label: workflow.label,\n          value: workflow.value,\n        }))}\n        defaultValue={defaultSelections}\n        onSubmit={handleSubmit}\n        onChange={handleChange}\n        onCancel={handleCancel}\n        hideIndexes\n      />\n\n      {showError && (\n        <Box>\n          <Text color=\"error\">\n            You must select at least one workflow to continue\n          </Text>\n        </Box>\n      )}\n    </Dialog>\n  )\n}\n"],"mappings":"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","ignoreList":[]}