Viewing File: /home/markqprx/iniasli.pro/client/datatable/data-table-add-item-button.tsx

import {AddIcon} from '../icons/material/Add';
import {Button} from '../ui/buttons/button';
import React, {ReactNode} from 'react';
import {useIsMobileMediaQuery} from '../utils/hooks/is-mobile-media-query';
import {IconButton} from '../ui/buttons/icon-button';
import {To} from 'react-router-dom';
import {ButtonBaseProps} from '../ui/buttons/button-base';

export interface DataTableAddItemButtonProps {
  children: ReactNode;
  to?: To;
  elementType?: ButtonBaseProps['elementType'];
  onClick?: ButtonBaseProps['onClick'];
}
export const DataTableAddItemButton = React.forwardRef<
  HTMLButtonElement,
  DataTableAddItemButtonProps
>(({children, to, elementType, onClick}, ref) => {
  const isMobile = useIsMobileMediaQuery();

  if (isMobile) {
    return (
      <IconButton
        ref={ref}
        variant="flat"
        color="primary"
        className="flex-shrink-0"
        size="sm"
        to={to}
        elementType={elementType}
        onClick={onClick}
      >
        <AddIcon />
      </IconButton>
    );
  }

  return (
    <Button
      ref={ref}
      startIcon={<AddIcon />}
      variant="flat"
      color="primary"
      size="sm"
      to={to}
      elementType={elementType}
      onClick={onClick}
    >
      {children}
    </Button>
  );
});
Back to Directory File Manager