All Downloads are FREE. Search and download functionalities are using the official Maven repository.

web.lib.components.extensions-picker.extension-row.tsx Maven / Gradle / Ivy

There is a newer version: 37
Show newest version
import React, { useEffect, useRef, useState } from 'react';
import classNames from 'classnames';
import { ExtensionEntry, TagEntry } from './extensions-picker';
import { ExtensionTags } from './extension-tags';
import { ExtensionMoreDropdown } from './extension-more-dropdown';
import { FaRegCheckSquare, FaRegSquare, FaTrashAlt } from 'react-icons/fa';
import './extension-row.scss';
import { ExtensionsOrigin } from './extensions-origin';

export interface ExtensionRowProps extends ExtensionEntry {
  selected?: boolean;
  keyboardActived?: boolean;
  layout?: 'picker' | 'cart';
  buildTool?: string;
  tagsDef: TagEntry[];
  transitive?:  boolean;

  onClick?(id: string): void;
}

export function ExtensionRow(props: ExtensionRowProps) {
  const [ hover, setHover ] = useState(false);
  const ref = useRef(null);

  function scrollIntoView() {
    if (ref.current) {
      ref.current.scrollIntoView({ behavior: 'smooth', block: 'center', inline: 'nearest' });
    }
  }

  const onClick = () => {
    if (props.transitive) {
      return;
    }
    props.onClick(props.id);
    setHover(false);
  };

  const activationEvents = {
    onClick,
    onMouseEnter: () => setHover(true),
    onMouseLeave: () => setHover(false),
  };

  useEffect(() => {
    if (props.keyboardActived) {
      scrollIntoView();
    }
  }, [ props.keyboardActived ])

  const description = props.description || '...';
  const transitive = props.transitive;
  const selected = props.selected || props.default;
  const ga = props.id.split(':');
  const id = ga[1] + (props.platform ? '' : `:${props.version}`);
  return (
    
{props.layout === 'picker' && (
{!selected && !(hover) && } {(hover || selected) && }
)}
{props.name} [{id}] {props.tags && props.tags.map((s, i) => )}
{props.layout === 'cart' && !props.transitive && (
{hover && props.selected && }
)} {props.layout === 'picker' && (
{description}
)}
); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy