45 lines
1.7 KiB
Vue
45 lines
1.7 KiB
Vue
<script setup>
|
|
import { ref, computed } from "vue"
|
|
|
|
const props = defineProps({
|
|
title: String,
|
|
height: [Number, String],
|
|
width: [Number, String],
|
|
})
|
|
|
|
// variables
|
|
const heightNumber = ref(24)
|
|
const widthNumber = ref(24)
|
|
|
|
if (!Number.isNaN(props.height) && typeof props.height !== "undefined") {
|
|
heightNumber.value = Number.parseInt(props.height)
|
|
} else if (typeof props.height === "undefined" && (!Number.isNaN(props.width) && typeof props.width !== "undefined")) {
|
|
heightNumber.value = Number.parseInt(props.width)
|
|
}
|
|
|
|
if (!Number.isNaN(props.width) && typeof props.width !== "undefined") {
|
|
widthNumber.value = Number.parseInt(props.width)
|
|
} else if (typeof props.width === "undefined" && (!Number.isNaN(props.height) && typeof props.height !== "undefined")) {
|
|
widthNumber.value = Number.parseInt(props.height)
|
|
}
|
|
|
|
// computed
|
|
const titleString = computed(() => {
|
|
if (typeof props.title === "string" && props.title.trim().length > 0) {
|
|
return props.title.trim()
|
|
}
|
|
return ""
|
|
})
|
|
</script>
|
|
|
|
<template>
|
|
<svg xmlns="http://www.w3.org/2000/svg" :height="heightNumber" :width="widthNumber" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" preserveAspectRatio="xMidYMid meet">
|
|
<title v-if="titleString.length > 0" v-html="title"></title>
|
|
<path d="M17 11h1a3 3 0 0 1 0 6h-1"></path>
|
|
<path d="M9 12v6"></path>
|
|
<path d="M13 12v6"></path>
|
|
<path d="M14 7.5c-1 0-1.44.5-3 .5s-2-.5-3-.5-1.72.5-2.5.5a2.5 2.5 0 0 1 0-5c.78 0 1.57.5 2.5.5S9.44 2 11 2s2 1.5 3 1.5 1.72-.5 2.5-.5a2.5 2.5 0 0 1 0 5c-.78 0-1.5-.5-2.5-.5Z"></path>
|
|
<path d="M5 8v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V8"></path>
|
|
</svg>
|
|
</template>
|