Skip to content

Lmmmmmm-bb/semi-context-menu

Repository files navigation

Semi Context Menu

codeql release license npm

This is a simple context menu, based on the Semi Design Dropdown component.

  • No extra dependencies.
  • No extra props, all props base Semi Design Dropdown.
pnpm i semi-context-menu

Example

export default () => {
  const renderItem = (left: string, right: string) => (
    <div className="item">
      <div className="left">{left}</div>
      <div className="right">{right}</div>
    </div>
  );

  const menu = (
    <Dropdown.Menu>
      <Dropdown.Title>Context Menu</Dropdown.Title>
      <Dropdown.Divider />
      <Dropdown.Item icon={<IconCopy />} onClick={() => Toast.success('Copy')}>
        {renderItem('Copy', 'Ctrl + C')}
      </Dropdown.Item>
      <Dropdown.Item
        icon={<IconRefresh />}
        onClick={() => Toast.success('Refresh')}
      >
        {renderItem('Refresh', 'Ctrl + R')}
      </Dropdown.Item>
    </Dropdown.Menu>
  );

  return (
    <div className="App">
      <SemiContextMenu clickToHide render={menu}>
        <div>This is Context Menu Operable Area</div>
      </SemiContextMenu>
    </div>
  );
};