mirror of
https://github.com/coracle-social/flotilla.git
synced 2025-12-10 10:57:04 +00:00
130 lines
5.1 KiB
Svelte
130 lines
5.1 KiB
Svelte
<style>
|
|
div {
|
|
mask-repeat: none;
|
|
mask-size: 100% 100%;
|
|
}
|
|
</style>
|
|
|
|
<script lang="ts">
|
|
import cx from 'classnames'
|
|
import {switcher} from "@welshman/lib"
|
|
import AddSquare from "@assets/icons/Add Square.svg?dataurl"
|
|
import Code2 from "@assets/icons/Code 2.svg?dataurl"
|
|
import Earth from "@assets/icons/Earth.svg?dataurl"
|
|
import Pen from "@assets/icons/Pen.svg?dataurl"
|
|
import HeadphonesRound from "@assets/icons/Headphones Round.svg?dataurl"
|
|
import AddCircle from "@assets/icons/Add Circle.svg?dataurl"
|
|
import AltArrowDown from "@assets/icons/Alt Arrow Down.svg?dataurl"
|
|
import AltArrowRight from "@assets/icons/Alt Arrow Right.svg?dataurl"
|
|
import AltArrowLeft from "@assets/icons/Alt Arrow Left.svg?dataurl"
|
|
import ArrowRight from "@assets/icons/Arrow Right.svg?dataurl"
|
|
import Bag from "@assets/icons/Bag.svg?dataurl"
|
|
import Bolt from "@assets/icons/Bolt.svg?dataurl"
|
|
import CalendarMinimalistic from "@assets/icons/Calendar Minimalistic.svg?dataurl"
|
|
import ChatRound from "@assets/icons/Chat Round.svg?dataurl"
|
|
import CheckCircle from "@assets/icons/Check Circle.svg?dataurl"
|
|
import ClipboardText from "@assets/icons/Clipboard Text.svg?dataurl"
|
|
import CloseCircle from "@assets/icons/Close Circle.svg?dataurl"
|
|
import Copy from "@assets/icons/Copy.svg?dataurl"
|
|
import Compass from "@assets/icons/Compass.svg?dataurl"
|
|
import CompassBig from "@assets/icons/Compass Big.svg?dataurl"
|
|
import Danger from "@assets/icons/Danger.svg?dataurl"
|
|
import Exit from "@assets/icons/Exit.svg?dataurl"
|
|
import FireMinimalistic from "@assets/icons/Fire Minimalistic.svg?dataurl"
|
|
import GallerySend from "@assets/icons/Gallery Send.svg?dataurl"
|
|
import Ghost from "@assets/icons/Ghost.svg?dataurl"
|
|
import Hashtag from "@assets/icons/Hashtag.svg?dataurl"
|
|
import HandPills from "@assets/icons/Hand Pills.svg?dataurl"
|
|
import HomeSmile from "@assets/icons/Home Smile.svg?dataurl"
|
|
import InfoCircle from "@assets/icons/Info Circle.svg?dataurl"
|
|
import InfoSquare from "@assets/icons/Info Square.svg?dataurl"
|
|
import Key from "@assets/icons/Key.svg?dataurl"
|
|
import LinkRound from "@assets/icons/Link Round.svg?dataurl"
|
|
import Login from "@assets/icons/Login.svg?dataurl"
|
|
import Login2 from "@assets/icons/Login 2.svg?dataurl"
|
|
import Magnifer from "@assets/icons/Magnifer.svg?dataurl"
|
|
import MenuDots from "@assets/icons/Menu Dots.svg?dataurl"
|
|
import NotesMinimalistic from "@assets/icons/Notes Minimalistic.svg?dataurl"
|
|
import Pallete2 from "@assets/icons/Pallete 2.svg?dataurl"
|
|
import Paperclip from "@assets/icons/Paperclip.svg?dataurl"
|
|
import Plain from "@assets/icons/Plain.svg?dataurl"
|
|
import RemoteControllerMinimalistic from "@assets/icons/Remote Controller Minimalistic.svg?dataurl"
|
|
import Reply from "@assets/icons/Reply.svg?dataurl"
|
|
import Settings from "@assets/icons/Settings.svg?dataurl"
|
|
import ShopMinimalistic from "@assets/icons/Shop Minimalistic.svg?dataurl"
|
|
import SmileCircle from "@assets/icons/Smile Circle.svg?dataurl"
|
|
import SquareShareLine from "@assets/icons/Square Share Line.svg?dataurl"
|
|
import UFO3 from "@assets/icons/UFO 3.svg?dataurl"
|
|
import UserHeart from "@assets/icons/User Heart.svg?dataurl"
|
|
import UserRounded from "@assets/icons/User Rounded.svg?dataurl"
|
|
import Widget from "@assets/icons/Widget.svg?dataurl"
|
|
import WiFiRouterRound from "@assets/icons/Wi-Fi Router Round.svg?dataurl"
|
|
|
|
export let icon
|
|
export let size = 5
|
|
|
|
const px = size * 4
|
|
|
|
const data = switcher(icon, {
|
|
"add-square": AddSquare,
|
|
"code-2": Code2,
|
|
"earth": Earth,
|
|
"pen": Pen,
|
|
"headphones-round": HeadphonesRound,
|
|
"add-circle": AddCircle,
|
|
"alt-arrow-down": AltArrowDown,
|
|
"alt-arrow-right": AltArrowRight,
|
|
"alt-arrow-left": AltArrowLeft,
|
|
"arrow-right": ArrowRight,
|
|
bag: Bag,
|
|
bolt: Bolt,
|
|
"calendar-minimalistic": CalendarMinimalistic,
|
|
"chat-round": ChatRound,
|
|
"check-circle": CheckCircle,
|
|
"clipboard-text": ClipboardText,
|
|
"close-circle": CloseCircle,
|
|
copy: Copy,
|
|
compass: Compass,
|
|
"compass-big": CompassBig,
|
|
danger: Danger,
|
|
exit: Exit,
|
|
"fire-minimalistic": FireMinimalistic,
|
|
"gallery-send": GallerySend,
|
|
ghost: Ghost,
|
|
hashtag: Hashtag,
|
|
"hand-pills": HandPills,
|
|
"home-smile": HomeSmile,
|
|
"info-circle": InfoCircle,
|
|
"info-square": InfoSquare,
|
|
key: Key,
|
|
"link-round": LinkRound,
|
|
login: Login,
|
|
"login-2": Login2,
|
|
magnifer: Magnifer,
|
|
"menu-dots": MenuDots,
|
|
"notes-minimalistic": NotesMinimalistic,
|
|
"pallete-2": Pallete2,
|
|
"paperclip": Paperclip,
|
|
plain: Plain,
|
|
reply: Reply,
|
|
"remote-controller-minimalistic": RemoteControllerMinimalistic,
|
|
"shop-minimalistic": ShopMinimalistic,
|
|
"smile-circle": SmileCircle,
|
|
settings: Settings,
|
|
"ufo-3": UFO3,
|
|
"square-share-line": SquareShareLine,
|
|
"user-heart": UserHeart,
|
|
"user-rounded": UserRounded,
|
|
widget: Widget,
|
|
"wifi-router-round": WiFiRouterRound,
|
|
})
|
|
|
|
if (!data) {
|
|
throw new Error(`Invalid icon: ${icon}`)
|
|
}
|
|
</script>
|
|
|
|
<div
|
|
class={cx("inline-block", $$props.class)}
|
|
style="mask-image: url({data}); width: {px}px; height: {px}px; min-width: {px}px; min-height: {px}px; background-color: currentcolor;" />
|