aboutsummaryrefslogtreecommitdiff
path: root/vnext/src/ui/Icon.js
blob: bc5ce08aeec2fc383fe2cb97825fe263473a0a30 (plain) (blame)
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
import { createElement, memo } from 'react'
import PropTypes from 'prop-types'

import evilIcons from 'evil-icons/assets/sprite.svg'

/**
 * @typedef {object} IconProps
 * @property {string} size
 * @property {string=} className
 * @property {string} name
 * @property {boolean=} noFill
 */

 /**
  * Icon inner component
  * @param {IconProps} props - icon props
  */
function IconElement(props) {
    var size = props.size ? ' icon--' + props.size : ''
    var className = props.className ? ' ' + props.className : ''
    var klass = 'icon' + (!props.noFill ? ' icon--' + props.name : '') + size + className

    var name = '#' + props.name + '-icon'
    var useTag = `<use xlink:href='${evilIcons}${name}' />`
    var Icon = createElement('svg', { className: 'icon__cnt', dangerouslySetInnerHTML: { __html: useTag } })
    return createElement(
        'div',
        { className: klass },
        wrapSpinner(Icon, klass)
    )
}

/**
 * @param {import('react').ReactElement} Html
 * @param {string} klass
 */
function wrapSpinner(Html, klass) {
    if (klass.indexOf('spinner') > -1) {
        return createElement(
            'div',
            { className: 'icon__spinner' },
            Html
        )
    } else {
        return Html
    }
}

export default memo(IconElement)

IconElement.propTypes = {
    size: PropTypes.string.isRequired,
    name: PropTypes.string.isRequired,
    className: PropTypes.string,
    noFill: PropTypes.bool
}