From fe75cffbf3bae6777aa2794fd89fa5dc37f5df8d Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期二, 15 七月 2025 10:11:23 +0800
Subject: [PATCH] 项目初始化

---
 src/directive/common/copyText.ts |   79 +++++++++++++++++++++++++++++++++++++++
 1 files changed, 79 insertions(+), 0 deletions(-)

diff --git a/src/directive/common/copyText.ts b/src/directive/common/copyText.ts
new file mode 100644
index 0000000..c73b312
--- /dev/null
+++ b/src/directive/common/copyText.ts
@@ -0,0 +1,79 @@
+// #ifdef APP-VUE || H5
+/**
+* v-copyText 澶嶅埗鏂囨湰鍐呭
+* Copyright (c) 2022 ruoyi
+* v-copyText="瑕佸鍒剁殑鏂囨湰鍐呭"
+* v-copyText:callback="澶嶅埗鎴愬姛鍚庣殑鍥炶皟鍑芥暟"
+* 鐐瑰嚮琚爣娉ㄧ殑鍏冪礌鍗冲彲澶嶅埗鏂囨湰鍐呭
+*/
+
+import type { Directive, DirectiveBinding } from "vue";
+interface ElType extends HTMLElement {
+  $copyValue: string;
+  $copyCallback: Function;
+  $destroyCopy:Function;
+}
+const vCopyText:Directive = {
+  beforeMount(el:ElType , binding:DirectiveBinding) {
+    if (binding.arg === "callback") {
+      el.$copyCallback = binding.value;
+    } else {
+      el.$copyValue = binding.value;
+      const handler = () => {
+        copyTextToClipboard(el.$copyValue);
+        if (el.$copyCallback) {
+          el.$copyCallback(el.$copyValue);
+        }
+      };
+      el.addEventListener("click", handler);
+      el.$destroyCopy = () => el.removeEventListener("click", handler);
+    }
+  }
+}
+export default vCopyText;
+
+function copyTextToClipboard(input:string, { target = document.body } = {}) {
+  const element = document.createElement('textarea');
+  const previouslyFocusedElement = document.activeElement  as HTMLElement;
+
+  element.value = input;
+
+  // Prevent keyboard from showing on mobile
+  element.setAttribute('readonly', '');
+
+  element.style.contain = 'strict';
+  element.style.position = 'absolute';
+  element.style.left = '-9999px';
+  element.style.fontSize = '12pt'; // Prevent zooming on iOS
+
+  const selection = document.getSelection();
+  if(!selection)return
+  const originalRange = selection.rangeCount > 0 && selection.getRangeAt(0);
+
+  target.append(element);
+  element.select();
+
+  // Explicit selection workaround for iOS
+  element.selectionStart = 0;
+  element.selectionEnd = input.length;
+
+  let isSuccess = false;
+  try {
+    isSuccess = document.execCommand('copy');
+  } catch { }
+
+  element.remove();
+
+  if (originalRange) {
+    selection.removeAllRanges();
+    selection.addRange(originalRange);
+  }
+
+  // Get the focus back on the previously focused element, if any
+  if (previouslyFocusedElement) {
+    previouslyFocusedElement.focus();
+  }
+
+  return isSuccess;
+}
+// #endif
\ No newline at end of file

--
Gitblit v1.9.3