π File detail
components/CustomSelect/SelectMulti.tsx
π§© .tsxπ 213 linesπΎ 29,884 bytesπ text
β Back to All Filesπ― Use case
This file lives under βcomponents/β, which covers shared React UI pieces. On the API surface it exposes SelectMultiProps and SelectMulti β mainly types, interfaces, or factory objects. Dependencies touch React UI and figures. It composes internal code from ink, utils, select, select-input-option, and select-option (relative imports).
Generated from folder role, exports, dependency roots, and inline comments β not hand-reviewed for every path.
π§ Inline summary
import { c as _c } from "react/compiler-runtime"; import figures from 'figures'; import React from 'react'; import { Box, Text } from '../../ink.js'; import type { PastedContent } from '../../utils/config.js';
π€ Exports (heuristic)
SelectMultiPropsSelectMulti
π External import roots
Package roots from from "β¦" (relative paths omitted).
reactfigures
π₯οΈ Source preview
import { c as _c } from "react/compiler-runtime";
import figures from 'figures';
import React from 'react';
import { Box, Text } from '../../ink.js';
import type { PastedContent } from '../../utils/config.js';
import type { ImageDimensions } from '../../utils/imageResizer.js';
import type { OptionWithDescription } from './select.js';
import { SelectInputOption } from './select-input-option.js';
import { SelectOption } from './select-option.js';
import { useMultiSelectState } from './use-multi-select-state.js';
export type SelectMultiProps<T> = {
readonly isDisabled?: boolean;
readonly visibleOptionCount?: number;
readonly options: OptionWithDescription<T>[];
readonly defaultValue?: T[];
readonly onCancel: () => void;
readonly onChange?: (values: T[]) => void;
readonly onFocus?: (value: T) => void;
readonly focusValue?: T;
/**
* Text for the submit button. When provided, a submit button is shown and
* Enter toggles selection (submit only fires when the button is focused).
* When omitted, Enter submits directly and Space toggles selection.
*/
readonly submitButtonText?: string;
/**
* Callback when user submits. Receives the currently selected values.
*/
readonly onSubmit?: (values: T[]) => void;
/**
* When true, hides the numeric indexes next to each option.
*/
readonly hideIndexes?: boolean;
/**
* Callback when user presses down from the last item (submit button).
* If provided, navigation will not wrap to the first item.
*/
readonly onDownFromLastItem?: () => void;
/**
* Callback when user presses up from the first item.
* If provided, navigation will not wrap to the last item.
*/
readonly onUpFromFirstItem?: () => void;
/**
* Focus the last option initially instead of the first.
*/
readonly initialFocusLast?: boolean;
/**
* Callback to open external editor for editing input option values.
* When provided, ctrl+g will trigger this callback in input options
* with the current value and a setter function to update the internal state.
*/
readonly onOpenEditor?: (currentValue: string, setValue: (value: string) => void) => void;
readonly onImagePaste?: (base64Image: string, mediaType?: string, filename?: string, dimensions?: ImageDimensions, sourcePath?: string) => void;
readonly pastedContents?: Record<number, PastedContent>;
readonly onRemoveImage?: (id: number) => void;
};
export function SelectMulti(t0) {
const $ = _c(44);
const {
isDisabled: t1,
visibleOptionCount: t2,
options,
defaultValue: t3,
onCancel,
onChange,
onFocus,
focusValue,
submitButtonText,
onSubmit,
onDownFromLastItem,
onUpFromFirstItem,
initialFocusLast,
onOpenEditor,
hideIndexes: t4,
onImagePaste,
pastedContents,
onRemoveImage
} = t0;
const isDisabled = t1 === undefined ? false : t1;
const visibleOptionCount = t2 === undefined ? 5 : t2;
let t5;
if ($[0] !== t3) {
t5 = t3 === undefined ? [] : t3;
$[0] = t3;
$[1] = t5;
} else {
t5 = $[1];
}
const defaultValue = t5;
const hideIndexes = t4 === undefined ? false : t4;
let t6;
if ($[2] !== defaultValue || $[3] !== focusValue || $[4] !== hideIndexes || $[5] !== initialFocusLast || $[6] !== isDisabled || $[7] !== onCancel || $[8] !== onChange || $[9] !== onDownFromLastItem || $[10] !== onFocus || $[11] !== onSubmit || $[12] !== onUpFromFirstItem || $[13] !== options || $[14] !== submitButtonText || $[15] !== visibleOptionCount) {
t6 = {
isDisabled,
visibleOptionCount,
options,
defaultValue,
onChange,
onCancel,
onFocus,
focusValue,
submitButtonText,
onSubmit,
onDownFromLastItem,
onUpFromFirstItem,
initialFocusLast,
hideIndexes
};
$[2] = defaultValue;
$[3] = focusValue;
$[4] = hideIndexes;
$[5] = initialFocusLast;
$[6] = isDisabled;
$[7] = onCancel;
$[8] = onChange;
$[9] = onDownFromLastItem;
$[10] = onFocus;
$[11] = onSubmit;
$[12] = onUpFromFirstItem;
$[13] = options;
$[14] = submitButtonText;
$[15] = visibleOptionCount;
$[16] = t6;
} else {
t6 = $[16];
}
const state = useMultiSelectState(t6);
let T0;
let T1;
let t7;
let t8;
let t9;
if ($[17] !== hideIndexes || $[18] !== isDisabled || $[19] !== onCancel || $[20] !== onImagePaste || $[21] !== onOpenEditor || $[22] !== onRemoveImage || $[23] !== options.length || $[24] !== pastedContents || $[25] !== state) {
const maxIndexWidth = options.length.toString().length;
T1 = Box;
t9 = "column";
T0 = Box;
t7 = "column";
t8 = state.visibleOptions.map((option, index) => {
const isOptionFocused = !isDisabled && state.focusedValue === option.value && !state.isSubmitFocused;
const isSelected = state.selectedValues.includes(option.value);
const isFirstVisibleOption = option.index === state.visibleFromIndex;
const isLastVisibleOption = option.index === state.visibleToIndex - 1;
const areMoreOptionsBelow = state.visibleToIndex < options.length;
const areMoreOptionsAbove = state.visibleFromIndex > 0;
const i = state.visibleFromIndex + index + 1;
if (option.type === "input") {
const inputValue = state.inputValues.get(option.value) || "";
return <Box key={String(option.value)} gap={1}><SelectInputOption option={option} isFocused={isOptionFocused} isSelected={false} shouldShowDownArrow={areMoreOptionsBelow && isLastVisibleOption} shouldShowUpArrow={areMoreOptionsAbove && isFirstVisibleOption} maxIndexWidth={maxIndexWidth} index={i} inputValue={inputValue} onInputChange={value => {
state.updateInputValue(option.value, value);
}} onSubmit={_temp} onExit={() => {
onCancel();
}} layout="compact" onOpenEditor={onOpenEditor} onImagePaste={onImagePaste} pastedContents={pastedContents} onRemoveImage={onRemoveImage}><Text color={isSelected ? "success" : undefined}>[{isSelected ? figures.tick : " "}]{" "}</Text></SelectInputOption></Box>;
}
return <Box key={String(option.value)} gap={1}><SelectOption isFocused={isOptionFocused} isSelected={false} shouldShowDownArrow={areMoreOptionsBelow && isLastVisibleOption} shouldShowUpArrow={areMoreOptionsAbove && isFirstVisibleOption} description={option.description}>{!hideIndexes && <Text dimColor={true}>{`${i}.`.padEnd(maxIndexWidth)}</Text>}<Text color={isSelected ? "success" : undefined}>[{isSelected ? figures.tick : " "}]</Text><Text color={isOptionFocused ? "suggestion" : undefined}>{option.label}</Text></SelectOption></Box>;
});
$[17] = hideIndexes;
$[18] = isDisabled;
$[19] = onCancel;
$[20] = onImagePaste;
$[21] = onOpenEditor;
$[22] = onRemoveImage;
$[23] = options.length;
$[24] = pastedContents;
$[25] = state;
$[26] = T0;
$[27] = T1;
$[28] = t7;
$[29] = t8;
$[30] = t9;
} else {
T0 = $[26];
T1 = $[27];
t7 = $[28];
t8 = $[29];
t9 = $[30];
}
let t10;
if ($[31] !== T0 || $[32] !== t7 || $[33] !== t8) {
t10 = <T0 flexDirection={t7}>{t8}</T0>;
$[31] = T0;
$[32] = t7;
$[33] = t8;
$[34] = t10;
} else {
t10 = $[34];
}
let t11;
if ($[35] !== onSubmit || $[36] !== state.isSubmitFocused || $[37] !== submitButtonText) {
t11 = submitButtonText && onSubmit && <Box marginTop={0} gap={1}>{state.isSubmitFocused ? <Text color="suggestion">{figures.pointer}</Text> : <Text> </Text>}<Box marginLeft={3}><Text color={state.isSubmitFocused ? "suggestion" : undefined} bold={true}>{submitButtonText}</Text></Box></Box>;
$[35] = onSubmit;
$[36] = state.isSubmitFocused;
$[37] = submitButtonText;
$[38] = t11;
} else {
t11 = $[38];
}
let t12;
if ($[39] !== T1 || $[40] !== t10 || $[41] !== t11 || $[42] !== t9) {
t12 = <T1 flexDirection={t9}>{t10}{t11}</T1>;
$[39] = T1;
$[40] = t10;
$[41] = t11;
$[42] = t9;
$[43] = t12;
} else {
t12 = $[43];
}
return t12;
}
function _temp() {}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["figures","React","Box","Text","PastedContent","ImageDimensions","OptionWithDescription","SelectInputOption","SelectOption","useMultiSelectState","SelectMultiProps","isDisabled","visibleOptionCount","options","T","defaultValue","onCancel","onChange","values","onFocus","value","focusValue","submitButtonText","onSubmit","hideIndexes","onDownFromLastItem","onUpFromFirstItem","initialFocusLast","onOpenEditor","currentValue","setValue","onImagePaste","base64Image","mediaType","filename","dimensions","sourcePath","pastedContents","Record","onRemoveImage","id","SelectMulti","t0","$","_c","t1","t2","t3","t4","undefined","t5","t6","state","T0","T1","t7","t8","t9","length","maxIndexWidth","toString","visibleOptions","map","option","index","isOptionFocused","focusedValue","isSubmitFocused","isSelected","selectedValues","includes","isFirstVisibleOption","visibleFromIndex","isLastVisibleOption","visibleToIndex","areMoreOptionsBelow","areMoreOptionsAbove","i","type","inputValue","inputValues","get","String","updateInputValue","_temp","tick","description","padEnd","label","t10","t11","pointer","t12"],"sources":["SelectMulti.tsx"],"sourcesContent":["import figures from 'figures'\nimport React from 'react'\nimport { Box, Text } from '../../ink.js'\nimport type { PastedContent } from '../../utils/config.js'\nimport type { ImageDimensions } from '../../utils/imageResizer.js'\nimport type { OptionWithDescription } from './select.js'\nimport { SelectInputOption } from './select-input-option.js'\nimport { SelectOption } from './select-option.js'\nimport { useMultiSelectState } from './use-multi-select-state.js'\n\nexport type SelectMultiProps<T> = {\n  readonly isDisabled?: boolean\n  readonly visibleOptionCount?: number\n  readonly options: OptionWithDescription<T>[]\n  readonly defaultValue?: T[]\n  readonly onCancel: () => void\n  readonly onChange?: (values: T[]) => void\n  readonly onFocus?: (value: T) => void\n  readonly focusValue?: T\n  /**\n   * Text for the submit button. When provided, a submit button is shown and\n   * Enter toggles selection (submit only fires when the button is focused).\n   * When omitted, Enter submits directly and Space toggles selection.\n   */\n  readonly submitButtonText?: string\n  /**\n   * Callback when user submits. Receives the currently selected values.\n   */\n  readonly onSubmit?: (values: T[]) => void\n  /**\n   * When true, hides the numeric indexes next to each option.\n   */\n  readonly hideIndexes?: boolean\n  /**\n   * Callback when user presses down from the last item (submit button).\n   * If provided, navigation will not wrap to the first item.\n   */\n  readonly onDownFromLastItem?: () => void\n  /**\n   * Callback when user presses up from the first item.\n   * If provided, navigation will not wrap to the last item.\n   */\n  readonly onUpFromFirstItem?: () => void\n  /**\n   * Focus the last option initially instead of the first.\n   */\n  readonly initialFocusLast?: boolean\n  /**\n   * Callback to open external editor for editing input option values.\n   * When provided, ctrl+g will trigger this callback in input options\n   * with the current value and a setter function to update the internal state.\n   */\n  readonly onOpenEditor?: (\n    currentValue: string,\n    setValue: (value: string) => void,\n  ) => void\n  readonly onImagePaste?: (\n    base64Image: string,\n    mediaType?: string,\n    filename?: string,\n    dimensions?: ImageDimensions,\n    sourcePath?: string,\n  ) => void\n  readonly pastedContents?: Record<number, PastedContent>\n  readonly onRemoveImage?: (id: number) => void\n}\n\nexport function SelectMulti<T>({\n  isDisabled = false,\n  visibleOptionCount = 5,\n  options,\n  defaultValue = [],\n  onCancel,\n  onChange,\n  onFocus,\n  focusValue,\n  submitButtonText,\n  onSubmit,\n  onDownFromLastItem,\n  onUpFromFirstItem,\n  initialFocusLast,\n  onOpenEditor,\n  hideIndexes = false,\n  onImagePaste,\n  pastedContents,\n  onRemoveImage,\n}: SelectMultiProps<T>): React.ReactNode {\n  const state = useMultiSelectState<T>({\n    isDisabled,\n    visibleOptionCount,\n    options,\n    defaultValue,\n    onChange,\n    onCancel,\n    onFocus,\n    focusValue,\n    submitButtonText,\n    onSubmit,\n    onDownFromLastItem,\n    onUpFromFirstItem,\n    initialFocusLast,\n    hideIndexes,\n  })\n\n  const maxIndexWidth = options.length.toString().length\n\n  return (\n    <Box flexDirection=\"column\">\n      <Box flexDirection=\"column\">\n        {state.visibleOptions.map((option, index) => {\n          const isOptionFocused =\n            !isDisabled &&\n            state.focusedValue === option.value &&\n            !state.isSubmitFocused\n          const isSelected = state.selectedValues.includes(option.value)\n\n          const isFirstVisibleOption = option.index === state.visibleFromIndex\n          const isLastVisibleOption = option.index === state.visibleToIndex - 1\n          const areMoreOptionsBelow = state.visibleToIndex < options.length\n          const areMoreOptionsAbove = state.visibleFromIndex > 0\n\n          const i = state.visibleFromIndex + index + 1\n\n          if (option.type === 'input') {\n            const inputValue = state.inputValues.get(option.value) || ''\n\n            return (\n              <Box key={String(option.value)} gap={1}>\n                <SelectInputOption\n                  option={option}\n                  isFocused={isOptionFocused}\n                  isSelected={\n                    false /* We show selection state differently for multi-select */\n                  }\n                  shouldShowDownArrow={\n                    areMoreOptionsBelow && isLastVisibleOption\n                  }\n                  shouldShowUpArrow={\n                    areMoreOptionsAbove && isFirstVisibleOption\n                  }\n                  maxIndexWidth={maxIndexWidth}\n                  index={i}\n                  inputValue={inputValue}\n                  onInputChange={value => {\n                    state.updateInputValue(option.value, value)\n                  }}\n                  onSubmit={() => {}} /* We handle submit higher up */\n                  onExit={() => {\n                    onCancel()\n                  }}\n                  layout=\"compact\"\n                  onOpenEditor={onOpenEditor}\n                  onImagePaste={onImagePaste}\n                  pastedContents={pastedContents}\n                  onRemoveImage={onRemoveImage}\n                >\n                  <Text color={isSelected ? 'success' : undefined}>\n                    [{isSelected ? figures.tick : ' '}]{' '}\n                  </Text>\n                </SelectInputOption>\n              </Box>\n            )\n          }\n\n          return (\n            <Box key={String(option.value)} gap={1}>\n              <SelectOption\n                isFocused={isOptionFocused}\n                isSelected={\n                  false /* We show selection state differently for multi-select */\n                }\n                shouldShowDownArrow={areMoreOptionsBelow && isLastVisibleOption}\n                shouldShowUpArrow={areMoreOptionsAbove && isFirstVisibleOption}\n                description={option.description}\n              >\n                {!hideIndexes && (\n                  <Text dimColor>{`${i}.`.padEnd(maxIndexWidth)}</Text>\n                )}\n                <Text color={isSelected ? 'success' : undefined}>\n                  [{isSelected ? figures.tick : ' '}]\n                </Text>\n                <Text color={isOptionFocused ? 'suggestion' : undefined}>\n                  {option.label}\n                </Text>\n              </SelectOption>\n            </Box>\n          )\n        })}\n      </Box>\n      {submitButtonText && onSubmit && (\n        <Box marginTop={0} gap={1}>\n          {state.isSubmitFocused ? (\n            <Text color=\"suggestion\">{figures.pointer}</Text>\n          ) : (\n            <Text> </Text>\n          )}\n          <Box marginLeft={3}>\n            <Text\n              color={state.isSubmitFocused ? 'suggestion' : undefined}\n              bold={true}\n            >\n              {submitButtonText}\n            </Text>\n          </Box>\n        </Box>\n      )}\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}