Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 4763 | Rev 4766 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
4243 stevensc 1
/* eslint-disable react/prop-types */
2
import React from 'react'
4247 stevensc 3
import './HeaderOptions.scss'
4432 stevensc 4
import './Dropdowns.scss'
4243 stevensc 5
 
4741 stevensc 6
const HeaderOptions = ({ Icon, title, url, childs = [], isMobile = false }) => {
4765 stevensc 7
    const path = window.location.pathname
4243 stevensc 8
    return (
4744 stevensc 9
        <li className={!isMobile && 'd-none d-md-block'}>
4765 stevensc 10
            <a
11
                href={url}
12
                className={`header__option ${isMobile && 'mobile'}`}
13
                onClick={(e) => childs.length && e.preventDefault()}
14
                target={path.includes('dashboard') ? '_blank' : '_self'}
15
                rel="noreferrer"
4763 stevensc 16
            >
4243 stevensc 17
                {Icon && <Icon className="header__option-icon" />}
4253 stevensc 18
                <span>{title}</span>
4243 stevensc 19
            </a>
4427 stevensc 20
            {!!childs.length &&
4741 stevensc 21
                <nav className={`nav__options-dropdown ${isMobile && 'mobile'}`}>
4427 stevensc 22
                    <ul>{childs.map((linkOption, index) =>
23
                        <li key={index}>
4449 stevensc 24
                            {linkOption.childs?.length
4427 stevensc 25
                                ? <a href='/' onClick={(e) => e.preventDefault()}>{linkOption.label}</a>
4765 stevensc 26
                                : <a href={linkOption.href} target={path.includes('dashboard') ? '_blank' : '_self'} rel="noreferrer" >{linkOption.label}</a>
4427 stevensc 27
                            }
4448 stevensc 28
                            {!!linkOption.childs?.length &&
4427 stevensc 29
                                <nav className='navLinkLevelThree'>
30
                                    <ul>
31
                                        {linkOption.childs?.map((optionsChild, index) =>
32
                                            <li key={index}>
4765 stevensc 33
                                                <a href={optionsChild.href} target={path.includes('dashboard') ? '_blank' : '_self'} rel="noreferrer" >{optionsChild.label}</a>
4427 stevensc 34
                                            </li>
35
                                        )}
36
                                    </ul>
37
                                </nav>
38
                            }
39
                        </li>
40
                    )}
41
                    </ul>
42
                </nav>
43
            }
4247 stevensc 44
        </li>
4243 stevensc 45
    )
46
}
47
 
48
export default HeaderOptions