ink-tab
Version:
Tab component for Ink
282 lines (276 loc) • 37.9 kB
JavaScript
var _excluded = ["children", "flexDirection", "width", "isFocused", "showIndex", "colors"];
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
import React from 'react';
import readline from 'readline';
import { Box, Text, useStdin } from 'ink';
/**
* Represent props of a <Tab>
*/
/**
* A <Tab> component
*/ // eslint-disable-next-line react/prop-types
export var Tab = function Tab(_ref) {
var children = _ref.children;
return /*#__PURE__*/React.createElement(React.Fragment, null, children);
};
/**
* Declare how does the keyboard interacts with ink-tab here
*/
/**
* Props for the <Tabs> component
*/
var TabsWithStdin = /*#__PURE__*/function (_React$Component) {
_inherits(TabsWithStdin, _React$Component);
var _super = _createSuper(TabsWithStdin);
function TabsWithStdin(props) {
var _this;
_classCallCheck(this, TabsWithStdin);
_this = _super.call(this, props);
// eslint-disable-next-line react/sort-comp
_defineProperty(_assertThisInitialized(_this), "defaultKeyMap", void 0);
_this.handleTabChange = _this.handleTabChange.bind(_assertThisInitialized(_this));
_this.handleKeyPress = _this.handleKeyPress.bind(_assertThisInitialized(_this));
_this.moveToNextTab = _this.moveToNextTab.bind(_assertThisInitialized(_this));
_this.moveToPreviousTab = _this.moveToPreviousTab.bind(_assertThisInitialized(_this));
_this.state = {
activeTab: 0
};
_this.defaultKeyMap = {
useNumbers: true,
useTab: true,
previous: [_this.isColumn() ? 'up' : 'left'],
next: [_this.isColumn() ? 'down' : 'right']
};
return _this;
}
_createClass(TabsWithStdin, [{
key: "componentDidMount",
value: function componentDidMount() {
var _this$props = this.props,
stdin = _this$props.stdin,
setRawMode = _this$props.setRawMode,
isRawModeSupported = _this$props.isRawModeSupported,
children = _this$props.children,
defaultValue = _this$props.defaultValue;
if (isRawModeSupported) {
// use ink / node `setRawMode` to read key-by-key
setRawMode(true);
readline.emitKeypressEvents(stdin);
stdin.on('keypress', this.handleKeyPress);
}
// select defaultValue if it's valid otherwise select the first tab on component mount
var initialTabIndex = 0;
if (typeof defaultValue !== 'undefined') {
var foundIndex = children.findIndex(function (child) {
return child.props.name === defaultValue;
});
if (foundIndex > 0) {
initialTabIndex = foundIndex;
}
}
this.handleTabChange(initialTabIndex);
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
var _this$props2 = this.props,
stdin = _this$props2.stdin,
setRawMode = _this$props2.setRawMode,
isRawModeSupported = _this$props2.isRawModeSupported;
if (isRawModeSupported) {
setRawMode(false); // remove set raw mode, as it might interfere with CTRL-C
stdin.removeListener('keypress', this.handleKeyPress);
}
}
}, {
key: "handleTabChange",
value: function handleTabChange(tabId) {
var _this$props3 = this.props,
children = _this$props3.children,
onChange = _this$props3.onChange;
var tab = children[tabId];
// eslint-disable-next-line @typescript-eslint/strict-boolean-expressions -- handle possible runtime errors
if (!tab) {
return;
}
this.setState({
activeTab: tabId
});
onChange(tab.props.name, tab);
}
}, {
key: "handleKeyPress",
value: function handleKeyPress(ch, key) {
var _this$props4 = this.props,
keyMap = _this$props4.keyMap,
isFocused = _this$props4.isFocused;
if (key == null || isFocused === false) {
return;
}
var currentKeyMap = _objectSpread(_objectSpread({}, this.defaultKeyMap), keyMap);
var useNumbers = currentKeyMap.useNumbers,
useTab = currentKeyMap.useTab,
previous = currentKeyMap.previous,
next = currentKeyMap.next;
if (previous.some(function (keyName) {
return keyName === key.name;
})) {
this.moveToPreviousTab();
}
if (next.some(function (keyName) {
return keyName === key.name;
})) {
this.moveToNextTab();
}
switch (key.name) {
case 'tab':
{
if (!useTab || isFocused !== null) {
// if isFocused != null, then the focus is managed by ink and thus we can not use this key
return;
}
if (key.shift) {
this.moveToPreviousTab();
} else {
this.moveToNextTab();
}
break;
}
case '0':
case '1':
case '2':
case '3':
case '4':
case '5':
case '6':
case '7':
case '8':
case '9':
{
if (!useNumbers) {
return;
}
if (key.meta) {
var tabId = key.name === '0' ? 9 : parseInt(key.name, 10) - 1;
this.handleTabChange(tabId);
}
break;
}
default:
break;
}
}
}, {
key: "isColumn",
value: function isColumn() {
var flexDirection = this.props.flexDirection;
return flexDirection === 'column' || flexDirection === 'column-reverse';
}
}, {
key: "moveToNextTab",
value: function moveToNextTab() {
var children = this.props.children;
var activeTab = this.state.activeTab;
var nextTabId = activeTab + 1;
if (nextTabId >= children.length) {
nextTabId = 0;
}
this.handleTabChange(nextTabId);
}
}, {
key: "moveToPreviousTab",
value: function moveToPreviousTab() {
var children = this.props.children;
var activeTab = this.state.activeTab;
var nextTabId = activeTab - 1;
if (nextTabId < 0) {
nextTabId = children.length - 1;
}
this.handleTabChange(nextTabId);
}
}, {
key: "render",
value: function render() {
var _this$props5 = this.props,
children = _this$props5.children,
flexDirection = _this$props5.flexDirection,
width = _this$props5.width,
isFocused = _this$props5.isFocused,
showIndex = _this$props5.showIndex,
colorsProp = _this$props5.colors,
rest = _objectWithoutProperties(_this$props5, _excluded);
var activeTab = this.state.activeTab;
var separatorWidth = width !== null && width !== void 0 ? width : 6;
var separator = this.isColumn() ? new Array(separatorWidth).fill('─').join('') : ' | ';
return /*#__PURE__*/React.createElement(Box, _extends({
flexDirection: flexDirection,
width: width
}, rest), children.map(function (child, key) {
var name = child.props.name;
var colors = {};
if (isFocused !== false) {
var _colorsProp$activeTab, _colorsProp$activeTab2, _colorsProp$activeTab3, _colorsProp$activeTab4;
colors = {
backgroundColor: activeTab === key ? (_colorsProp$activeTab = colorsProp === null || colorsProp === void 0 ? void 0 : (_colorsProp$activeTab2 = colorsProp.activeTab) === null || _colorsProp$activeTab2 === void 0 ? void 0 : _colorsProp$activeTab2.color) !== null && _colorsProp$activeTab !== void 0 ? _colorsProp$activeTab : 'green' : undefined,
color: activeTab === key ? (_colorsProp$activeTab3 = colorsProp === null || colorsProp === void 0 ? void 0 : (_colorsProp$activeTab4 = colorsProp.activeTab) === null || _colorsProp$activeTab4 === void 0 ? void 0 : _colorsProp$activeTab4.backgroundColor) !== null && _colorsProp$activeTab3 !== void 0 ? _colorsProp$activeTab3 : 'black' : undefined
};
} else {
colors = {
backgroundColor: activeTab === key ? 'gray' : undefined,
color: activeTab === key ? 'black' : undefined
};
}
return /*#__PURE__*/React.createElement(Box, {
key: name,
flexDirection: flexDirection
}, key !== 0 && /*#__PURE__*/React.createElement(Text, {
color: "dim"
}, separator), /*#__PURE__*/React.createElement(Box, null, showIndex === true && /*#__PURE__*/React.createElement(Text, {
color: "grey"
}, key + 1, ". "), /*#__PURE__*/React.createElement(Text, colors, child)));
}));
}
}]);
return TabsWithStdin;
}(React.Component);
/**
* The <Tabs> component
*/
_defineProperty(TabsWithStdin, "defaultProps", {
flexDirection: 'row',
keyMap: null,
isFocused: null,
// isFocused is null mean that the focus not handle by ink
defaultValue: null,
showIndex: true
});
export var Tabs = function Tabs(props) {
var _useStdin = useStdin(),
isRawModeSupported = _useStdin.isRawModeSupported,
stdin = _useStdin.stdin,
setRawMode = _useStdin.setRawMode;
return /*#__PURE__*/React.createElement(TabsWithStdin, _extends({
isRawModeSupported: isRawModeSupported,
stdin: stdin,
setRawMode: setRawMode
}, props));
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","readline","Box","Text","useStdin","Tab","_ref","children","createElement","Fragment","TabsWithStdin","_React$Component","_inherits","_super","_createSuper","props","_this","_classCallCheck","call","_defineProperty","_assertThisInitialized","handleTabChange","bind","handleKeyPress","moveToNextTab","moveToPreviousTab","state","activeTab","defaultKeyMap","useNumbers","useTab","previous","isColumn","next","_createClass","key","value","componentDidMount","_this$props","stdin","setRawMode","isRawModeSupported","defaultValue","emitKeypressEvents","on","initialTabIndex","foundIndex","findIndex","child","name","componentWillUnmount","_this$props2","removeListener","tabId","_this$props3","onChange","tab","setState","ch","_this$props4","keyMap","isFocused","currentKeyMap","_objectSpread","some","keyName","shift","meta","parseInt","flexDirection","nextTabId","length","render","_this$props5","width","showIndex","colorsProp","colors","rest","_objectWithoutProperties","_excluded","separatorWidth","separator","Array","fill","join","_extends","map","_colorsProp$activeTab","_colorsProp$activeTab2","_colorsProp$activeTab3","_colorsProp$activeTab4","backgroundColor","color","undefined","Component","Tabs","_useStdin"],"sources":["../src/index.tsx"],"sourcesContent":["import React from 'react';\nimport readline from 'readline';\nimport { Box, type StdinProps, type BoxProps, Text, useStdin } from 'ink';\n\ntype ExtractFCProps<T> = T extends React.FunctionComponent<infer P> ? P : never;\n\n/**\n * Represent props of a <Tab>\n */\nexport interface TabProps {\n  name: string;\n  children: React.ReactNode;\n}\n\n/**\n * A <Tab> component\n */\n// eslint-disable-next-line react/prop-types\nexport const Tab: React.FunctionComponent<TabProps> = ({ children }) => (\n  <>{children}</>\n);\n\n/**\n * Declare how does the keyboard interacts with ink-tab here\n */\ninterface KeyMapProps {\n  useNumbers?: boolean;\n  useTab?: boolean;\n  previous?: string[];\n  next?: string[];\n}\n\ninterface RequiredKeyMapProps {\n  useNumbers: boolean;\n  useTab: boolean;\n  previous: string[];\n  next: string[];\n}\n\n/**\n * Props for the <Tabs> component\n */\nexport interface TabsProps {\n  /**\n   * A function called whenever a tab is changing.\n   * @param {string} name the name of the tab passed in the `name` prop\n   * @param {React.Component<TabProps>} activeTab the current active tab component\n   */\n  onChange: (name: string, activeTab: React.ReactElement<typeof Tab>) => void;\n  children: Array<React.ReactElement<typeof Tab>>;\n  flexDirection?: BoxProps['flexDirection'];\n  width?: BoxProps['width'];\n  keyMap?: KeyMapProps;\n  isFocused?: boolean;\n  defaultValue?: string;\n  showIndex?: boolean;\n  colors?: {\n    activeTab?: {\n      color?: ExtractFCProps<typeof Text>['color'];\n      backgroundColor?: ExtractFCProps<typeof Text>['backgroundColor'];\n    };\n  };\n}\ninterface TabsWithStdinProps extends TabsProps {\n  isRawModeSupported: boolean;\n  setRawMode: StdinProps['setRawMode'];\n  stdin: StdinProps['stdin'];\n}\n\ninterface TabsWithStdinState {\n  activeTab: number;\n}\n\nclass TabsWithStdin extends React.Component<\n  TabsWithStdinProps,\n  TabsWithStdinState\n> {\n  // eslint-disable-next-line react/sort-comp\n  private readonly defaultKeyMap: RequiredKeyMapProps;\n\n  public static defaultProps = {\n    flexDirection: 'row',\n    keyMap: null,\n    isFocused: null, // isFocused is null mean that the focus not handle by ink\n    defaultValue: null,\n    showIndex: true,\n  };\n\n  constructor(props: TabsWithStdinProps) {\n    super(props);\n\n    this.handleTabChange = this.handleTabChange.bind(this);\n    this.handleKeyPress = this.handleKeyPress.bind(this);\n    this.moveToNextTab = this.moveToNextTab.bind(this);\n    this.moveToPreviousTab = this.moveToPreviousTab.bind(this);\n\n    this.state = {\n      activeTab: 0,\n    };\n\n    this.defaultKeyMap = {\n      useNumbers: true,\n      useTab: true,\n      previous: [this.isColumn() ? 'up' : 'left'],\n      next: [this.isColumn() ? 'down' : 'right'],\n    };\n  }\n\n  componentDidMount(): void {\n    const { stdin, setRawMode, isRawModeSupported, children, defaultValue } =\n      this.props;\n\n    if (isRawModeSupported) {\n      // use ink / node `setRawMode` to read key-by-key\n      setRawMode(true);\n\n      readline.emitKeypressEvents(stdin);\n      stdin.on('keypress', this.handleKeyPress);\n    }\n\n    // select defaultValue if it's valid otherwise select the first tab on component mount\n    let initialTabIndex = 0;\n\n    if (typeof defaultValue !== 'undefined') {\n      const foundIndex = children.findIndex(\n        (child) => child.props.name === defaultValue\n      );\n\n      if (foundIndex > 0) {\n        initialTabIndex = foundIndex;\n      }\n    }\n\n    this.handleTabChange(initialTabIndex);\n  }\n\n  componentWillUnmount(): void {\n    const { stdin, setRawMode, isRawModeSupported } = this.props;\n\n    if (isRawModeSupported) {\n      setRawMode(false); // remove set raw mode, as it might interfere with CTRL-C\n      stdin.removeListener('keypress', this.handleKeyPress);\n    }\n  }\n\n  handleTabChange(tabId: number): void {\n    const { children, onChange } = this.props;\n\n    const tab = children[tabId];\n\n    // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions -- handle possible runtime errors\n    if (!tab) {\n      return;\n    }\n\n    this.setState({\n      activeTab: tabId,\n    });\n\n    onChange(tab.props.name, tab);\n  }\n\n  handleKeyPress(\n    ch: string,\n    key: null | { name: string; shift: boolean; meta: boolean }\n  ): void {\n    const { keyMap, isFocused } = this.props;\n\n    if (key == null || isFocused === false) {\n      return;\n    }\n\n    const currentKeyMap = { ...this.defaultKeyMap, ...keyMap };\n    const { useNumbers, useTab, previous, next } = currentKeyMap;\n\n    if (previous.some((keyName) => keyName === key.name)) {\n      this.moveToPreviousTab();\n    }\n\n    if (next.some((keyName) => keyName === key.name)) {\n      this.moveToNextTab();\n    }\n\n    switch (key.name) {\n      case 'tab': {\n        if (!useTab || isFocused !== null) {\n          // if isFocused != null, then the focus is managed by ink and thus we can not use this key\n          return;\n        }\n\n        if (key.shift) {\n          this.moveToPreviousTab();\n        } else {\n          this.moveToNextTab();\n        }\n\n        break;\n      }\n\n      case '0':\n      case '1':\n      case '2':\n      case '3':\n      case '4':\n      case '5':\n      case '6':\n      case '7':\n      case '8':\n      case '9': {\n        if (!useNumbers) {\n          return;\n        }\n        if (key.meta) {\n          const tabId = key.name === '0' ? 9 : parseInt(key.name, 10) - 1;\n\n          this.handleTabChange(tabId);\n        }\n\n        break;\n      }\n\n      default:\n        break;\n    }\n  }\n\n  isColumn(): boolean {\n    const { flexDirection } = this.props;\n\n    return flexDirection === 'column' || flexDirection === 'column-reverse';\n  }\n\n  moveToNextTab(): void {\n    const { children } = this.props;\n    const { activeTab } = this.state;\n\n    let nextTabId = activeTab + 1;\n    if (nextTabId >= children.length) {\n      nextTabId = 0;\n    }\n\n    this.handleTabChange(nextTabId);\n  }\n\n  moveToPreviousTab(): void {\n    const { children } = this.props;\n    const { activeTab } = this.state;\n\n    let nextTabId = activeTab - 1;\n    if (nextTabId < 0) {\n      nextTabId = children.length - 1;\n    }\n\n    this.handleTabChange(nextTabId);\n  }\n\n  render(): React.ReactNode {\n    const {\n      children,\n      flexDirection,\n      width,\n      isFocused,\n      showIndex,\n      colors: colorsProp,\n      ...rest\n    } = this.props;\n    const { activeTab } = this.state;\n\n    const separatorWidth = width ?? 6;\n\n    const separator = this.isColumn()\n      ? new Array(separatorWidth).fill('─').join('')\n      : ' | ';\n\n    return (\n      <Box flexDirection={flexDirection} width={width} {...rest}>\n        {children.map((child, key) => {\n          const { name } = child.props;\n          let colors = {};\n          if (isFocused !== false) {\n            colors = {\n              backgroundColor:\n                activeTab === key\n                  ? colorsProp?.activeTab?.color ?? 'green'\n                  : undefined,\n              color:\n                activeTab === key\n                  ? colorsProp?.activeTab?.backgroundColor ?? 'black'\n                  : undefined,\n            };\n          } else {\n            colors = {\n              backgroundColor: activeTab === key ? 'gray' : undefined,\n              color: activeTab === key ? 'black' : undefined,\n            };\n          }\n\n          return (\n            <Box key={name} flexDirection={flexDirection}>\n              {key !== 0 && <Text color=\"dim\">{separator}</Text>}\n              <Box>\n                {showIndex === true && <Text color=\"grey\">{key + 1}. </Text>}\n                <Text {...colors}>{child}</Text>\n              </Box>\n            </Box>\n          );\n        })}\n      </Box>\n    );\n  }\n}\n\n/**\n * The <Tabs> component\n */\nexport const Tabs: React.FunctionComponent<TabsProps> = (props) => {\n  const { isRawModeSupported, stdin, setRawMode } = useStdin();\n\n  return (\n    <TabsWithStdin\n      isRawModeSupported={isRawModeSupported}\n      stdin={stdin}\n      setRawMode={setRawMode}\n      {...props}\n    />\n  );\n};\n"],"mappings":"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"}