All files / modules/30-delegates/components/CreateDelegate/DelegateSelectStep/Delegates4Ways Delegates4Ways.tsx

95% Statements 19/20
77.78% Branches 7/9
75% Functions 3/4
95% Lines 19/20

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80              3x 3x 3x 3x       3x 3x 3x 3x               3x   3x 7x   7x 19x   6x   6x   7x       7x           26x                                                             3x  
/*
 * Copyright 2021 Harness Inc. All rights reserved.
 * Use of this source code is governed by the PolyForm Shield 1.0.0 license
 * that can be found in the licenses directory at the root of this repository, also available at
 * https://polyformproject.org/wp-content/uploads/2020/06/PolyForm-Shield-1.0.0.txt.
 */
 
import React from 'react'
import { CardSelect, Container, Text, Layout, Icon } from '@wings-software/uicore'
import { Color } from '@harness/design-system'
import { DelegateTypes } from '@delegates/constants'
 
import type { CardData } from '../DelegateSelectStep'
 
import Docker from './Icons/docker.svg'
import Ecs from './Icons/ecs.svg'
import Linux from './Icons/linux.svg'
import css from './Delegates4Ways.module.scss'
 
interface Delegates4WaysProps {
  onSelect: (value: CardData) => void
  selectedCard: CardData | undefined
  selectCardData: CardData[]
}
 
const allowedDelegateTypes = [DelegateTypes.KUBERNETES_CLUSTER, DelegateTypes.DOCKER]
 
const Delegates4Ways: React.FC<Delegates4WaysProps> = props => {
  const { onSelect, selectedCard, selectCardData } = props
 
  const getIcon = (type: string) => {
    switch (type) {
      case DelegateTypes.LINUX:
        return Linux
      case DelegateTypes.ECS:
        return Ecs
      case DelegateTypes.DOCKER:
        return Docker
    }
  }
 
  return (
    <CardSelect
      data={selectCardData}
      cornerSelected={true}
      selected={selectedCard}
      renderItem={item => (
        <Container className={css.cardBody} data-type={item.type}>
          {item.type !== DelegateTypes.KUBERNETES_CLUSTER && <img src={getIcon(item.type)} />}
          {item.type === DelegateTypes.KUBERNETES_CLUSTER && (
            <Icon name="service-kubernetes" size={20} className={css.kubIcon} />
          )}
          <Layout.Vertical className={css.cardContent}>
            <Text font={{ weight: 'bold' }} color={Color.GREY_900} className={css.cardHeader}>
              {item.name}
            </Text>
            <Text
              style={{
                color: '#6B6D85'
              }}
              className={css.subTitle}
            >
              {item.text}
            </Text>
          </Layout.Vertical>
        </Container>
      )}
      onChange={value => {
        if (allowedDelegateTypes.includes(value.type)) {
          /* istanbul ignore next */
          onSelect(value)
        }
      }}
      className={`grid ${css.cardWrapper}`}
    ></CardSelect>
  )
}
 
export default Delegates4Ways