phanpy/src/components/icon.jsx

87 lines
2.3 KiB
React
Raw Normal View History

import 'iconify-icon';
2022-12-10 12:14:48 +03:00
const SIZES = {
s: 12,
m: 16,
l: 20,
xl: 24,
xxl: 32,
};
const ICONS = {
x: 'mingcute:close-line',
heart: 'mingcute:heart-line',
bookmark: 'mingcute:bookmark-line',
'check-circle': 'mingcute:check-circle-line',
transfer: 'mingcute:transfer-4-line',
rocket: 'mingcute:rocket-line',
'arrow-left': 'mingcute:arrow-left-line',
'arrow-right': 'mingcute:arrow-right-line',
'arrow-up': 'mingcute:arrow-up-line',
2022-12-29 06:47:10 +03:00
'arrow-down': 'mingcute:arrow-down-line',
2022-12-10 12:14:48 +03:00
earth: 'mingcute:earth-line',
lock: 'mingcute:lock-line',
unlock: 'mingcute:unlock-line',
'eye-close': 'mingcute:eye-close-line',
'eye-open': 'mingcute:eye-2-line',
message: 'mingcute:mail-line',
comment: 'mingcute:chat-3-line',
home: 'mingcute:home-5-line',
notification: 'mingcute:notification-line',
follow: 'mingcute:user-follow-line',
'follow-add': 'mingcute:user-add-line',
poll: 'mingcute:chart-bar-line',
pencil: 'mingcute:pencil-line',
quill: 'mingcute:quill-pen-line',
at: 'mingcute:at-line',
attachment: 'mingcute:attachment-line',
upload: 'mingcute:upload-3-line',
gear: 'mingcute:settings-3-line',
more: 'mingcute:more-1-line',
external: 'mingcute:external-link-line',
popout: 'mingcute:external-link-line',
popin: ['mingcute:external-link-line', '180deg'],
2022-12-14 16:48:17 +03:00
plus: 'mingcute:add-circle-line',
2022-12-18 15:53:32 +03:00
'chevron-left': 'mingcute:left-line',
reply: ['mingcute:share-forward-line', '180deg', 'horizontal'],
thread: 'mingcute:route-line',
group: 'mingcute:group-line',
bot: 'mingcute:android-2-line',
2022-12-10 12:14:48 +03:00
};
2022-12-16 08:27:04 +03:00
function Icon({ icon, size = 'm', alt, title, class: className = '' }) {
2022-12-14 16:48:17 +03:00
if (!icon) return null;
2022-12-10 12:14:48 +03:00
const iconSize = SIZES[size];
let iconName = ICONS[icon];
let rotate, flip;
if (Array.isArray(iconName)) {
[iconName, rotate, flip] = iconName;
}
2022-12-10 12:14:48 +03:00
return (
<div
class={`icon ${className}`}
title={title || alt}
style={{
width: `${iconSize}px`,
height: `${iconSize}px`,
display: 'inline-block',
overflow: 'hidden',
lineHeight: 0,
}}
>
<iconify-icon
width={iconSize}
height={iconSize}
icon={iconName}
rotate={rotate}
flip={flip}
>
2022-12-10 12:14:48 +03:00
{alt}
</iconify-icon>
</div>
);
2022-12-16 08:27:04 +03:00
}
export default Icon;