Skip to content
Snippets Groups Projects
Select Git revision
  • af49b812701ad7ac8740a4de5c9f64769a6157be
  • stable default protected
  • MA_Pape_2018
  • MA_2018_Lopatin
  • feature/mesh_viewer
  • feature/#468_access_isosurface_scalar
  • feature/#459_default_primitives
  • master protected
  • feature/#470_Create_a_color_lookup_table
  • feature/#473_resize_companion_window
  • feature/#462_do_not_use_arb_extensions
  • feature/#495_Provide_data_for_larger_isosurfaces
  • feature/#323_default_image
  • feature/#480_Create_a_smaller_test_mesh_for_combustion_demo
  • feature/#236_Get_Integration_tests_running_on_CI
  • feature/#447_Copy_standard_assets_to_build_folder
  • 447-copy-standard-assets-to-build-folder-and-remove-resource-path
  • feature/#445_mesh_render_settings_component
  • feature/#251_Make_sure_tests_cpp_is_compiled_once
  • feature/#455_Remove_navigation_and_improve_interaction_for_combustion_demo
  • feature/446_strange_txt_files
  • v18.06.0
  • v18.05.0
  • #251_bad
  • #251_good
  • v18.03.0
  • v18.02.0
  • v18.01.0
  • v17.12.0
  • v17.11.0
  • v17.10.0
  • v17.09.0
  • v17.07.0
33 results

generic_material_loader.hpp

Blame
  • PopoverListButton.tsx 1.18 KiB
    import IconButton from '@mui/material/IconButton';
    import { Fragment, PropsWithChildren, useState } from 'react';
    import List from '@mui/material/List';
    import Popover from '@mui/material/Popover';
    
    export interface PopoverListButtonProps extends PropsWithChildren {
      title: string;
      // renderIcon?: () => JSXEL;
      icon: any;
    }
    
    const PopoverListButton = (props: PopoverListButtonProps) => {
      const [buttonElement, setButtonElement] = useState<HTMLButtonElement | null>(null);
    
      const open = Boolean(buttonElement);
      const id = open ? `${props.title}-popover` : undefined;
    
      return (
        <Fragment>
          <IconButton
            color="inherit"
            onClick={event => setButtonElement(event.currentTarget)}
            title={props.title}
          >
            {
              <props.icon />
            }
          </IconButton>
          <Popover
            id={id}
            open={open}
            anchorEl={buttonElement}
            onClose={() => setButtonElement(null)}
            anchorOrigin={{
              vertical: "bottom",
              horizontal: "left",
            }}
          >
            <List>
              {
                props.children
              }
            </List>
          </Popover>
        </Fragment>
      );
    }
    
    export default PopoverListButton;