fix: perfect copy componet

This commit is contained in:
chansee97 2024-06-26 21:00:08 +08:00
parent 8981f42571
commit eb82842fad
6 changed files with 19 additions and 6 deletions

View File

@ -148,6 +148,10 @@
"searchPlaceholder": "Search icon", "searchPlaceholder": "Search icon",
"clearIcon": "Clear icon", "clearIcon": "Clear icon",
"selectorTitle": "Icon selection" "selectorTitle": "Icon selection"
},
"copyText": {
"message": "Copied successfully",
"tooltip": "Copy"
} }
} }
} }

View File

@ -83,6 +83,10 @@
"inputPlaceholder": "选择目标图标", "inputPlaceholder": "选择目标图标",
"searchPlaceholder": "搜索图标", "searchPlaceholder": "搜索图标",
"clearIcon": "清除图标" "clearIcon": "清除图标"
},
"copyText":{
"tooltip":"复制",
"message":"复制成功"
} }
}, },
"login": { "login": {

View File

@ -57,7 +57,6 @@
"echarts": "^5.5.0", "echarts": "^5.5.0",
"md-editor-v3": "^4.15.2", "md-editor-v3": "^4.15.2",
"pinia": "^2.1.7", "pinia": "^2.1.7",
"pinia-plugin-persist": "^1.0.0",
"pinia-plugin-persistedstate": "^3.2.1", "pinia-plugin-persistedstate": "^3.2.1",
"quill": "^2.0.2", "quill": "^2.0.2",
"radash": "^12.1.0", "radash": "^12.1.0",

View File

@ -9,7 +9,7 @@ const props = defineProps<Props>()
<template> <template>
<n-tooltip :show-arrow="false" trigger="hover"> <n-tooltip :show-arrow="false" trigger="hover">
<template #trigger> <template #trigger>
<icon-park-outline-help /> <icon-park-outline-help class="op-50 cursor-help"/>
</template> </template>
{{ props.message }} {{ props.message }}
</n-tooltip> </n-tooltip>

View File

@ -10,8 +10,13 @@ const modelValue = defineModel<string>('value')
<n-ellipsis :style="{ 'max-width': props.maxLength || '12em' }"> <n-ellipsis :style="{ 'max-width': props.maxLength || '12em' }">
{{ modelValue }} {{ modelValue }}
</n-ellipsis> </n-ellipsis>
<span v-copy="modelValue" class="cursor-pointer"> <n-tooltip trigger="hover">
<icon-park-outline-copy /> <template #trigger>
</span> <span v-copy="modelValue" class="cursor-pointer">
<icon-park-outline-copy />
</span>
</template>
{{ $t('components.copyText.tooltip') }}
</n-tooltip>
</div> </div>
</template> </template>

View File

@ -1,4 +1,5 @@
import type { App, Directive } from 'vue' import type { App, Directive } from 'vue'
import { $t } from '@/utils'
interface CopyHTMLElement extends HTMLElement { interface CopyHTMLElement extends HTMLElement {
_copyText: string _copyText: string
@ -25,7 +26,7 @@ export function install(app: App) {
if (!clipboardEnable()) if (!clipboardEnable())
return return
copy(this._copyText) copy(this._copyText)
window.$message.success('复制成功') window.$message.success($t('components.copyText.message'))
} }
function updataClipboard(el: CopyHTMLElement, text: string) { function updataClipboard(el: CopyHTMLElement, text: string) {