aboutsummaryrefslogtreecommitdiff
path: root/src/tools/ipv4-subnet-calculator/copyable-ip-like.vue
diff options
context:
space:
mode:
authorGravatar Corentin Thomasset <corentin.thomasset74@gmail.com> 2023-03-28 23:31:11 +0200
committerGravatar Corentin THOMASSET <corentin.thomasset74@gmail.com> 2023-03-28 23:49:54 +0200
commitc339ab3551a93bc1c2f5c59575f691fbf4fa2dbb (patch)
treef4012250ca3c7bafc0b1f9bbd3cb2a2995c89ab1 /src/tools/ipv4-subnet-calculator/copyable-ip-like.vue
parent47948dd343777fd2d517466a3a19b0f23545f86c (diff)
downloadit-tools-c339ab3551a93bc1c2f5c59575f691fbf4fa2dbb.tar.gz
it-tools-c339ab3551a93bc1c2f5c59575f691fbf4fa2dbb.tar.zst
it-tools-c339ab3551a93bc1c2f5c59575f691fbf4fa2dbb.zip
feat(new-tool): IPv4 subnet calculator
Diffstat (limited to 'src/tools/ipv4-subnet-calculator/copyable-ip-like.vue')
-rw-r--r--src/tools/ipv4-subnet-calculator/copyable-ip-like.vue35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/tools/ipv4-subnet-calculator/copyable-ip-like.vue b/src/tools/ipv4-subnet-calculator/copyable-ip-like.vue
new file mode 100644
index 0000000..5069b87
--- /dev/null
+++ b/src/tools/ipv4-subnet-calculator/copyable-ip-like.vue
@@ -0,0 +1,35 @@
+<template>
+ <n-tooltip trigger="hover">
+ <template #trigger>
+ <span class="ip" @click="handleClick">{{ ip }}</span>
+ </template>
+ {{ tooltipText }}
+ </n-tooltip>
+</template>
+
+<script setup lang="ts">
+import { useClipboard } from '@vueuse/core';
+import { ref, toRefs } from 'vue';
+
+const props = withDefaults(defineProps<{ ip?: string }>(), { ip: '' });
+const { ip } = toRefs(props);
+
+const initialText = 'Copy to clipboard';
+const tooltipText = ref(initialText);
+
+const { copy } = useClipboard({ source: ip });
+
+function handleClick() {
+ copy();
+ tooltipText.value = 'Copied!';
+
+ setTimeout(() => (tooltipText.value = initialText), 1000);
+}
+</script>
+
+<style scoped lang="less">
+.ip {
+ font-family: monospace;
+ cursor: pointer;
+}
+</style>