Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
import React from 'react'
import { List } from 'molecules/List'
import { SelectionState } from 'src/state/SelectionState'
import { SwatchWrapper, StyledSwatchesButton } from './styled'
import { SwatchListProps, SwatchItemProps } from './typings'

function defaultRenderSwatchItem(props: SwatchItemProps, index?: number) {
  const { label, ...remainingProps } = props
  const dataQa = props.isSelected ? 'qa-facet-selected' : 'qa-facet'
  const classes = props.isSelected && 'selected'
  return <StyledSwatchesButton className={classes} text={label} {...remainingProps} data-qa={dataQa} />
}

function defaultRenderSwatchList(props: SwatchListProps, state?: SelectionState) {
  const { list, renderItem } = props

  const view = list.map(item => renderItem(item, state, props))
  return view
}

function defaultRenderListWrapper(props: SwatchListProps) {
  const { children, className } = props
  return <SwatchWrapper className={className}>{children}</SwatchWrapper>
}

export {
  defaultRenderListWrapper,
  defaultRenderSwatchList,
  defaultRenderSwatchItem,
}