[Cloud Posture][VulnerabilityManagement] add vendor logos using EuiIcon with custom svgs (#157302)

## Summary

This PR add the logo for each for each CVSS 
- Add Red hat and nvd logos  using `EuiIcon` with custom svgs
- For GHSA vendor which stands for GitHub Security Advisories, we will
use one of the EUI third party logos for Github - `logoGithub`

For icon reference see, [click
here](https://eui.elastic.co/pr_3350/#/display/icons)

<img width="1720" alt="Screen Shot 2023-05-10 at 12 22 35 PM"
src="7b9c3c9c-89aa-4f6a-980d-00c2f88fc833">
This commit is contained in:
Lola 2023-05-12 22:08:56 -04:00 committed by GitHub
parent 473a803bb1
commit 493a8f4d46
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 47 additions and 3 deletions

View file

@ -0,0 +1,8 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="42" height="42" fill="none" viewBox="0 0 42 42">
<rect width="100%" height="100%" fill="black" />
<path fill="url(#nvd)" d="M3 16h36v11H3z"/>
<defs>
<pattern id="nvd" width="1" height="1" patternContentUnits="objectBoundingBox">
<use xlink:href="#b" transform="matrix(.00731 0 0 .02511 -.239 -.115)"/>
</pattern>
<image xlink:href="

After

Width:  |  Height:  |  Size: 1.3 KiB

View file

@ -0,0 +1,9 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="42" height="42" fill="none" viewBox="0 0 42 42">
<path fill="url(#redhat)" d="M38.714 8H3v26.19h35.714V8Z"/>
<defs>
<pattern id="redhat" width="1" height="1" patternContentUnits="objectBoundingBox">
<use xlink:href="#b" transform="scale(.0103 .01406)"/>
</pattern>
<image xlink:href="" id="b" width="97" height="71" data-name="redhat.png"/>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.7 KiB

View file

@ -5,7 +5,14 @@
* 2.0.
*/
import { EuiFlexGroup, EuiFlexItem, EuiHorizontalRule, EuiLink, EuiText } from '@elastic/eui';
import {
EuiFlexGroup,
EuiFlexItem,
EuiHorizontalRule,
EuiIcon,
EuiLink,
EuiText,
} from '@elastic/eui';
import { css } from '@emotion/react';
import { FormattedMessage } from '@kbn/i18n-react';
import moment from 'moment';
@ -16,6 +23,8 @@ import { CVSScoreBadge } from '../../../components/vulnerability_badges';
import { CVSScoreProps, VectorScoreBase, Vendor, Vulnerability } from '../types';
import { getVectorScoreList } from '../utils';
import { OVERVIEW_TAB_VULNERABILITY_FLYOUT } from '../test_subjects';
import nvdLogo from '../../../assets/icons/nvd_logo.svg';
import redhatLogo from '../../../assets/icons/redhat_logo.svg';
const cvssVendors: Record<string, Vendor> = {
nvd: 'NVD',
@ -23,6 +32,12 @@ const cvssVendors: Record<string, Vendor> = {
ghsa: 'GHSA',
};
const vendorIcons: Record<string, string> = {
nvd: nvdLogo,
redhat: redhatLogo,
ghsa: 'logoGithub',
};
interface VulnerabilityTabProps {
vulnerability: Vulnerability;
}
@ -51,12 +66,24 @@ const CVSScore = ({ vectorBaseScore, vendor }: CVSScoreProps) => {
<EuiFlexItem
grow={false}
css={css`
width: 94px;
width: 116px;
font-weight: 600;
display: flex;
flex-direction: row;
align-items: center;
`}
>
{vendorName}
<span
css={css`
margin-right: 30px;
`}
>
<EuiIcon type={vendorIcons[vendor]} size="xl" />
</span>
<span>{vendorName}</span>
</EuiFlexItem>
<EuiFlexGroup direction="column" gutterSize="s">
{vectorScores.length > 0 &&
vectorScores.map((vectorScore, i) => (