import {h} from '/js/web_modules/preact.js'; import htm from '/js/web_modules/htm.js'; import {SOCIAL_PLATFORMS} from '../utils/platforms.js'; import {classNames} from '../utils/helpers.js'; const html = htm.bind(h); function SocialIcon(props) { const {platform, icon, url} = props; const platformInfo = SOCIAL_PLATFORMS[platform.toLowerCase()]; const inList = !!platformInfo; const iconSupplied = !!icon const name = inList ? platformInfo.name : platform; const finalIcon = iconSupplied ? icon : (inList ? platformInfo.icon : '/img/socialhandles/default.svg') const style = `background-image: url(${finalIcon});` const itemClass = classNames({ "user-social-item": true, "flex": true, "justify-start": true, "items-center": true, "-mr-1": true, "use-default": !inList, }); const labelClass = classNames({ "platform-label": true, "visually-hidden": !!finalIcon, "text-indigo-800": true, "text-xs": true, "uppercase": true, "max-w-xs": true, "inline-block": true, }); return ( html` Find me on ${name} `); } export default function (props) { const {handles} = props; if (handles == null) { return null; } const list = handles.map((item, index) => html`
  • <${SocialIcon} platform=${item.platform} icon=${item.icon} url=${item.url}/>
  • `); return html` `; }