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

// @ts-ignore
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
};