2023-10-16 12:01:16 +03:00
|
|
|
import { memo } from 'preact/compat';
|
2023-12-23 13:05:30 +03:00
|
|
|
import { useEffect, useRef, useState } from 'preact/hooks';
|
2022-12-13 15:42:09 +03:00
|
|
|
|
2022-12-10 12:14:48 +03:00
|
|
|
const SIZES = {
|
|
|
|
s: 12,
|
|
|
|
m: 16,
|
|
|
|
l: 20,
|
|
|
|
xl: 24,
|
|
|
|
xxl: 32,
|
|
|
|
};
|
|
|
|
|
2023-08-13 12:15:49 +03:00
|
|
|
export const ICONS = {
|
2023-07-12 11:42:58 +03:00
|
|
|
x: () => import('@iconify-icons/mingcute/close-line'),
|
|
|
|
heart: () => import('@iconify-icons/mingcute/heart-line'),
|
|
|
|
bookmark: () => import('@iconify-icons/mingcute/bookmark-line'),
|
|
|
|
'check-circle': () => import('@iconify-icons/mingcute/check-circle-line'),
|
2023-08-11 13:00:36 +03:00
|
|
|
'x-circle': () => import('@iconify-icons/mingcute/close-circle-line'),
|
2023-07-12 11:42:58 +03:00
|
|
|
transfer: () => import('@iconify-icons/mingcute/transfer-4-line'),
|
|
|
|
rocket: () => import('@iconify-icons/mingcute/rocket-line'),
|
|
|
|
'arrow-left': () => import('@iconify-icons/mingcute/arrow-left-line'),
|
|
|
|
'arrow-right': () => import('@iconify-icons/mingcute/arrow-right-line'),
|
|
|
|
'arrow-up': () => import('@iconify-icons/mingcute/arrow-up-line'),
|
|
|
|
'arrow-down': () => import('@iconify-icons/mingcute/arrow-down-line'),
|
|
|
|
earth: () => import('@iconify-icons/mingcute/earth-line'),
|
|
|
|
lock: () => import('@iconify-icons/mingcute/lock-line'),
|
|
|
|
unlock: () => import('@iconify-icons/mingcute/unlock-line'),
|
|
|
|
'eye-close': () => import('@iconify-icons/mingcute/eye-close-line'),
|
|
|
|
'eye-open': () => import('@iconify-icons/mingcute/eye-2-line'),
|
|
|
|
message: () => import('@iconify-icons/mingcute/mail-line'),
|
|
|
|
comment: () => import('@iconify-icons/mingcute/chat-3-line'),
|
2023-11-14 11:52:47 +03:00
|
|
|
comment2: () => import('@iconify-icons/mingcute/comment-2-line'),
|
2023-07-12 11:42:58 +03:00
|
|
|
home: () => import('@iconify-icons/mingcute/home-3-line'),
|
|
|
|
notification: () => import('@iconify-icons/mingcute/notification-line'),
|
|
|
|
follow: () => import('@iconify-icons/mingcute/user-follow-line'),
|
|
|
|
'follow-add': () => import('@iconify-icons/mingcute/user-add-line'),
|
|
|
|
poll: [() => import('@iconify-icons/mingcute/chart-bar-line'), '90deg'],
|
|
|
|
pencil: () => import('@iconify-icons/mingcute/pencil-line'),
|
|
|
|
quill: () => import('@iconify-icons/mingcute/quill-pen-line'),
|
|
|
|
at: () => import('@iconify-icons/mingcute/at-line'),
|
|
|
|
attachment: () => import('@iconify-icons/mingcute/attachment-line'),
|
|
|
|
upload: () => import('@iconify-icons/mingcute/upload-3-line'),
|
|
|
|
gear: () => import('@iconify-icons/mingcute/settings-3-line'),
|
|
|
|
more: () => import('@iconify-icons/mingcute/more-3-line'),
|
|
|
|
external: () => import('@iconify-icons/mingcute/external-link-line'),
|
|
|
|
popout: () => import('@iconify-icons/mingcute/external-link-line'),
|
|
|
|
popin: [() => import('@iconify-icons/mingcute/external-link-line'), '180deg'],
|
|
|
|
plus: () => import('@iconify-icons/mingcute/add-circle-line'),
|
|
|
|
'chevron-left': () => import('@iconify-icons/mingcute/left-line'),
|
|
|
|
'chevron-right': () => import('@iconify-icons/mingcute/right-line'),
|
2023-09-12 06:27:54 +03:00
|
|
|
'chevron-down': () => import('@iconify-icons/mingcute/down-line'),
|
2023-07-12 11:42:58 +03:00
|
|
|
reply: [
|
|
|
|
() => import('@iconify-icons/mingcute/share-forward-line'),
|
|
|
|
'180deg',
|
|
|
|
'horizontal',
|
|
|
|
],
|
|
|
|
thread: () => import('@iconify-icons/mingcute/route-line'),
|
|
|
|
group: () => import('@iconify-icons/mingcute/group-line'),
|
|
|
|
bot: () => import('@iconify-icons/mingcute/android-2-line'),
|
|
|
|
menu: () => import('@iconify-icons/mingcute/rows-4-line'),
|
|
|
|
list: () => import('@iconify-icons/mingcute/list-check-line'),
|
|
|
|
search: () => import('@iconify-icons/mingcute/search-2-line'),
|
|
|
|
hashtag: () => import('@iconify-icons/mingcute/hashtag-line'),
|
|
|
|
info: () => import('@iconify-icons/mingcute/information-line'),
|
|
|
|
shortcut: () => import('@iconify-icons/mingcute/lightning-line'),
|
|
|
|
user: () => import('@iconify-icons/mingcute/user-4-line'),
|
|
|
|
following: () => import('@iconify-icons/mingcute/walk-line'),
|
|
|
|
pin: () => import('@iconify-icons/mingcute/pin-line'),
|
|
|
|
bus: () => import('@iconify-icons/mingcute/bus-2-line'),
|
|
|
|
link: () => import('@iconify-icons/mingcute/link-2-line'),
|
|
|
|
history: () => import('@iconify-icons/mingcute/history-line'),
|
|
|
|
share: () => import('@iconify-icons/mingcute/share-2-line'),
|
|
|
|
sparkles: () => import('@iconify-icons/mingcute/sparkles-line'),
|
|
|
|
exit: () => import('@iconify-icons/mingcute/exit-line'),
|
|
|
|
translate: () => import('@iconify-icons/mingcute/translate-line'),
|
|
|
|
play: () => import('@iconify-icons/mingcute/play-fill'),
|
|
|
|
trash: () => import('@iconify-icons/mingcute/delete-2-line'),
|
|
|
|
mute: () => import('@iconify-icons/mingcute/volume-mute-line'),
|
|
|
|
unmute: () => import('@iconify-icons/mingcute/volume-line'),
|
|
|
|
block: () => import('@iconify-icons/mingcute/forbid-circle-line'),
|
|
|
|
unblock: [
|
|
|
|
() => import('@iconify-icons/mingcute/forbid-circle-line'),
|
|
|
|
'180deg',
|
|
|
|
],
|
|
|
|
flag: () => import('@iconify-icons/mingcute/flag-4-line'),
|
|
|
|
time: () => import('@iconify-icons/mingcute/time-line'),
|
|
|
|
refresh: () => import('@iconify-icons/mingcute/refresh-2-line'),
|
|
|
|
emoji2: () => import('@iconify-icons/mingcute/emoji-2-line'),
|
|
|
|
filter: () => import('@iconify-icons/mingcute/filter-2-line'),
|
|
|
|
chart: () => import('@iconify-icons/mingcute/chart-line-line'),
|
|
|
|
react: () => import('@iconify-icons/mingcute/react-line'),
|
|
|
|
layout4: () => import('@iconify-icons/mingcute/layout-4-line'),
|
|
|
|
layout5: () => import('@iconify-icons/mingcute/layout-5-line'),
|
|
|
|
announce: () => import('@iconify-icons/mingcute/announcement-line'),
|
2023-07-17 16:01:00 +03:00
|
|
|
alert: () => import('@iconify-icons/mingcute/alert-line'),
|
2023-08-10 18:52:29 +03:00
|
|
|
round: () => import('@iconify-icons/mingcute/round-fill'),
|
2023-08-15 15:14:09 +03:00
|
|
|
'arrow-up-circle': () =>
|
|
|
|
import('@iconify-icons/mingcute/arrow-up-circle-line'),
|
|
|
|
'arrow-down-circle': () =>
|
|
|
|
import('@iconify-icons/mingcute/arrow-down-circle-line'),
|
|
|
|
clipboard: () => import('@iconify-icons/mingcute/clipboard-line'),
|
2023-09-05 04:19:11 +03:00
|
|
|
'account-edit': () => import('@iconify-icons/mingcute/user-edit-line'),
|
|
|
|
'account-warning': () => import('@iconify-icons/mingcute/user-warning-line'),
|
2023-09-06 17:54:05 +03:00
|
|
|
keyboard: () => import('@iconify-icons/mingcute/keyboard-line'),
|
2023-10-02 16:13:56 +03:00
|
|
|
cloud: () => import('@iconify-icons/mingcute/cloud-line'),
|
2023-10-20 14:24:01 +03:00
|
|
|
month: () => import('@iconify-icons/mingcute/calendar-month-line'),
|
2023-10-29 16:41:03 +03:00
|
|
|
media: () => import('@iconify-icons/mingcute/photo-album-line'),
|
2023-12-21 13:17:14 +03:00
|
|
|
speak: () => import('@iconify-icons/mingcute/radar-line'),
|
2022-12-10 12:14:48 +03:00
|
|
|
};
|
|
|
|
|
2023-12-23 07:14:11 +03:00
|
|
|
const ICONDATA = {};
|
|
|
|
|
2023-03-09 16:51:50 +03:00
|
|
|
function Icon({
|
|
|
|
icon,
|
|
|
|
size = 'm',
|
|
|
|
alt,
|
|
|
|
title,
|
|
|
|
class: className = '',
|
|
|
|
style = {},
|
|
|
|
}) {
|
2022-12-14 16:48:17 +03:00
|
|
|
if (!icon) return null;
|
|
|
|
|
2022-12-10 12:14:48 +03:00
|
|
|
const iconSize = SIZES[size];
|
2023-07-12 11:42:58 +03:00
|
|
|
let iconBlock = ICONS[icon];
|
2022-12-22 05:35:39 +03:00
|
|
|
let rotate, flip;
|
2023-07-12 11:42:58 +03:00
|
|
|
if (Array.isArray(iconBlock)) {
|
|
|
|
[iconBlock, rotate, flip] = iconBlock;
|
2022-12-13 15:42:09 +03:00
|
|
|
}
|
2023-01-11 04:47:46 +03:00
|
|
|
|
2023-12-23 07:14:11 +03:00
|
|
|
const [iconData, setIconData] = useState(ICONDATA[icon]);
|
2023-12-23 13:05:30 +03:00
|
|
|
const currentIcon = useRef(icon);
|
2023-12-23 07:14:11 +03:00
|
|
|
useEffect(() => {
|
2023-12-23 13:05:30 +03:00
|
|
|
if (iconData && currentIcon.current === icon) return;
|
2023-12-23 07:14:11 +03:00
|
|
|
(async () => {
|
|
|
|
const iconB = await iconBlock();
|
|
|
|
setIconData(iconB.default);
|
|
|
|
ICONDATA[icon] = iconB.default;
|
|
|
|
})();
|
2023-12-23 13:05:30 +03:00
|
|
|
currentIcon.current = icon;
|
|
|
|
}, [icon]);
|
2023-01-11 04:47:46 +03:00
|
|
|
|
2022-12-10 12:14:48 +03:00
|
|
|
return (
|
2023-09-29 16:02:09 +03:00
|
|
|
<span
|
2022-12-10 12:14:48 +03:00
|
|
|
class={`icon ${className}`}
|
|
|
|
title={title || alt}
|
|
|
|
style={{
|
|
|
|
width: `${iconSize}px`,
|
|
|
|
height: `${iconSize}px`,
|
2023-03-09 16:51:50 +03:00
|
|
|
...style,
|
2022-12-10 12:14:48 +03:00
|
|
|
}}
|
|
|
|
>
|
2023-01-11 04:47:46 +03:00
|
|
|
{iconData && (
|
|
|
|
<svg
|
|
|
|
width={iconSize}
|
|
|
|
height={iconSize}
|
|
|
|
viewBox={`0 0 ${iconData.width} ${iconData.height}`}
|
|
|
|
dangerouslySetInnerHTML={{ __html: iconData.body }}
|
|
|
|
style={{
|
|
|
|
transform: `${rotate ? `rotate(${rotate})` : ''} ${
|
|
|
|
flip ? `scaleX(-1)` : ''
|
|
|
|
}`,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
)}
|
2023-09-29 16:02:09 +03:00
|
|
|
</span>
|
2022-12-10 12:14:48 +03:00
|
|
|
);
|
2022-12-16 08:27:04 +03:00
|
|
|
}
|
|
|
|
|
2023-10-16 12:01:16 +03:00
|
|
|
export default memo(Icon);
|