@yxhl/specter-pui-vtk 1.0.83 → 1.0.85
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/specter-pui-vtk.css +1 -1
- package/dist/specter-pui.es.js +2201 -2188
- package/dist/specter-pui.es.js.map +1 -1
- package/dist/specter-pui.umd.js +1 -1
- package/dist/specter-pui.umd.js.map +1 -1
- package/package.json +1 -1
- package/src/components/assembly/VtkSearch.vue +62 -23
- package/src/components/assembly/VtkUpload.vue +25 -15
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"specter-pui.umd.js","sources":["../src/commons/storage.js","../src/stores/message.js","../src/components/message/index.js","../src/commons/request.js","../src/components/assembly/VtkArea.vue","../src/components/assembly/VtkAreaTabs.vue","../src/components/assembly/VtkBreadcrumb.vue","../src/components/assembly/VtkCheckbox.vue","../src/components/assembly/VtkCount.vue","../src/components/assembly/VtkDatePicker.vue","../src/components/assembly/VtkDateSelector.vue","../src/components/assembly/VtkDateTimePicker.vue","../src/components/assembly/VtkDept.vue","../src/components/assembly/VtkEmpty.vue","../src/components/assembly/VtkFab.vue","../src/components/assembly/VtkFormItem.vue","../src/components/assembly/VtkImg.vue","../src/components/assembly/VtkPage.vue","../src/components/assembly/VtkPdf.vue","../src/composables/usePage.js","../src/components/assembly/VtkProj.vue","../src/components/assembly/VtkRadio.vue","../src/components/assembly/VtkSearch.vue","../src/components/assembly/VtkSelect.vue","../src/components/assembly/VtkStepper.vue","../src/components/assembly/VtkUpload.vue","../src/commons/location.js","../src/commons/filters/dictionary.js","../src/commons/filters/format.js","../src/commons/filters/mask.js","../node_modules/vuetify/lib/util/colors.js","../src/commons/themes.js","../src/commons/validation.js","../src/components/message/alert.vue","../src/components/message/confirm.vue","../src/components/message/loading.vue","../src/components/message/vtkMessage.vue","../src/components/message/prompt.vue","../src/components/message/toast.vue","../src/index.js"],"sourcesContent":["const Storage = {};\r\n/** 获取Storage对象 */\r\nconst storage = (type = 'local') => {\r\n return type == \"local\" ? window.localStorage : window.sessionStorage;\r\n}\r\n/**\r\n * 获取对应缓存值JSON对象\r\n * @param {string} key 键\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n * @return {object} 对应的值JSON对象\r\n */\r\nStorage.get = (key, type = 'local') => {\r\n var js = storage(type).getItem(key);\r\n return /^[\\\\{|\\\\[].+[\\\\}|\\\\]]$/.test(js) ? JSON.parse(js) : js;\r\n};\r\n/**\r\n * 设置存储缓存取对象JSON\r\n * @param {string} key 键\r\n * @param {string} value 值(JSON对象)\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n */\r\nStorage.set = (key, value, type = 'local') => {\r\n value = (value.constructor === Object) ? JSON.stringify(value) : value\r\n storage(type).setItem(key, value);\r\n};\r\n/**\r\n * 删除对应的缓存对象JSON\r\n * @param {string} key 键\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n */\r\nStorage.remove = (key, type = 'local') => {\r\n storage(type).removeItem(key);\r\n};\r\n/**\r\n * 清空所有的缓存对象JSON\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n */\r\nStorage.clear = (type = 'local') => {\r\n storage(type).clear();\r\n};\r\n\r\nexport default Storage;\r\n","// stores/message.js\r\nimport { defineStore } from 'pinia'\r\n\r\nexport const useMessageStore = defineStore('message', {\r\n state: () => ({\r\n alert: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 500\r\n }\r\n },\r\n confirm: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 400,\r\n cancelText: '取消',\r\n confirmText: '确定'\r\n }\r\n },\r\n loading: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 300,\r\n indeterminate: true,\r\n value: 0,\r\n progressColor: 'primary',\r\n size: 64,\r\n circleWidth: 6\r\n }\r\n },\r\n prompt: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 500,\r\n label: '',\r\n placeholder: '',\r\n inputType: 'text',\r\n cancelText: '取消',\r\n confirmText: '确定'\r\n }\r\n },\r\n toast: {\r\n isActive: false,\r\n options: {\r\n text: '',\r\n color: '',\r\n timeout: 3000,\r\n position: 'top'\r\n }\r\n }\r\n }),\r\n \r\n actions: {\r\n hide(type) {\r\n if (this[type]) {\r\n this[type].isActive = false\r\n }\r\n },\r\n \r\n show(type, options) {\r\n if (this[type]) {\r\n this[type] = {\r\n isActive: true,\r\n options: options\r\n }\r\n }\r\n }\r\n }\r\n})","// components/message/index.js\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst Message = {\r\n // 显示 alert\r\n alert(options) {\r\n const messageStore = useMessageStore()\r\n messageStore.show('alert', options)\r\n },\r\n \r\n // 显示 confirm\r\n confirm(options) {\r\n const messageStore = useMessageStore()\r\n messageStore.show('confirm', options)\r\n },\r\n \r\n // loading 对象,包含 show 和 hide 方法\r\n loading: {\r\n show(options = {}) {\r\n const messageStore = useMessageStore()\r\n const defaultOptions = {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 120,\r\n indeterminate: true,\r\n progressColor: 'primary',\r\n size: 64,\r\n circleWidth: 6\r\n }\r\n messageStore.show('loading', { ...defaultOptions, ...options })\r\n },\r\n hide() {\r\n const messageStore = useMessageStore()\r\n messageStore.hide('loading')\r\n }\r\n },\r\n \r\n // 显示 prompt\r\n prompt(options) {\r\n const messageStore = useMessageStore()\r\n messageStore.show('prompt', options)\r\n },\r\n \r\n // 显示 toast\r\n toast(text, options = {}) {\r\n \r\n const messageStore = useMessageStore()\r\n // 确保传入的是字符串时正确处理\r\n const toastOptions = typeof text === 'string' \r\n ? { text, ...options }\r\n : text\r\n messageStore.show('toast', toastOptions)\r\n },\r\n \r\n // 隐藏指定类型的消息\r\n hide(type) {\r\n const messageStore = useMessageStore()\r\n messageStore.hide(type)\r\n }\r\n}\r\n\r\nexport default Message","import axios from \"axios\";\r\nimport Storage from \"./storage.js\";\r\nimport Message from \"../components/message/index.js\";\r\n\r\n// create an axios instance\r\nconst service = axios.create({\r\n baseURL: window.VITE_APP_API_URL || import.meta.env.VITE_APP_API_URL || \"\",\r\n headers: {\r\n \"X-Requested-With\": \"XMLHttpRequest\",\r\n },\r\n withCredentials: false,\r\n timeout: 30000,\r\n});\r\n\r\n// request interceptor\r\nservice.interceptors.request.use(\r\n (config) => {\r\n // 获取配置的键名,如果没有配置则使用默认值\r\n const tokenKey = window.VTK_CONFIG?.storageKeys?.token || '_mis_acis_token';\r\n if (Storage.get(tokenKey)) {\r\n config.headers[\"X-Token\"] = \"1b0679be72ad976ad5d491ad57a5eec0\";\r\n config.headers[\"Authorization\"] = \"Bearer \" + Storage.get(tokenKey);\r\n }\r\n return config;\r\n },\r\n (error) => {\r\n Message.toast(error.message || \"请求错误\");\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\n// response interceptor\r\nservice.interceptors.response.use(\r\n (response) => {\r\n let res = response.data;\r\n let header = response.headers[\"content-disposition\"];\r\n\r\n if (header != undefined && header.split(\";\")[0] == \"attachment\") {\r\n res = response;\r\n }\r\n if (response.status !== 200) {\r\n Message.toast(res.message || \"请求失败\", { color: \"error\" });\r\n return Promise.reject(new Error(res.message || \"请求失败\"));\r\n } else {\r\n // 检查登录过期\r\n if (\r\n res.meta &&\r\n !res.meta.success &&\r\n res.meta.message === \"specter_authorize_exception\"\r\n ) {\r\n Storage.clear(); //清除所有缓存\r\n const handleRedirect = () => {\r\n const url = window.location.href;\r\n const index = url.indexOf(\"#\");\r\n let newUrl;\r\n\r\n if (index > -1) {\r\n newUrl = url.substring(0, index) + \"#/\";\r\n } else {\r\n newUrl = url + \"#/\";\r\n }\r\n\r\n window.location.href = newUrl;\r\n };\r\n\r\n Message.confirm({\r\n title: \"提示\",\r\n text: \"对不起,您的登录信息过期!\",\r\n onConfirm: handleRedirect,\r\n onCancel: handleRedirect,\r\n });\r\n }\r\n return Promise.resolve(res);\r\n }\r\n },\r\n (error) => {\r\n console.log(\"err\" + error);\r\n Message.toast(error.message || \"网络错误\", { color: \"error\" });\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\nconst Request = {};\r\n\r\nRequest.http = (\r\n url,\r\n data = {},\r\n method = \"GET\",\r\n headers = { \"content-type\": \"application/x-www-form-urlencoded\" },\r\n responseType = null\r\n) => {\r\n if (headers[\"content-type\"] === \"application/x-www-form-urlencoded\") {\r\n return service({\r\n url: url,\r\n params: data,\r\n method: method,\r\n headers: headers,\r\n responseType: responseType,\r\n });\r\n } else {\r\n return service({\r\n url: url,\r\n data: data,\r\n method: method,\r\n headers: headers,\r\n responseType: responseType,\r\n });\r\n }\r\n};\r\n\r\nRequest.getForm = (url, data = {}) => {\r\n return Request.http(url, data);\r\n};\r\n\r\nRequest.postForm = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\");\r\n};\r\n\r\nRequest.getJson = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\", {\r\n \"content-type\": \"application/json\",\r\n });\r\n};\r\n\r\nRequest.postJson = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\", {\r\n \"content-type\": \"application/json\",\r\n });\r\n};\r\n\r\nRequest.imp = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\", {\r\n \"Content-Type\": \"multipart/form-data\",\r\n });\r\n};\r\n\r\nRequest.exp = (url, data = {}) => {\r\n return Request.http(\r\n url,\r\n data,\r\n \"POST\",\r\n { \"content-Type\": \"application/json\" },\r\n \"blob\"\r\n );\r\n};\r\n\r\nexport default Request;\r\n","<template>\r\n\t<div class=\"d-inline-block d-flex\">\r\n\t\t<VSelect\r\n\t\t\tv-model=\"entity.area2\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area2, 1)\"\r\n\t\t\t@click:clear=\"clear(1)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 2 ? entity.name2 : '---省级---'\"\r\n\t\t\t:items=\"areaData.area2\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box mr-3\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 2\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 4\"\r\n\t\t\tv-model=\"entity.area4\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area4, 2)\"\r\n\t\t\t@click:clear=\"clear(2)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 4 ? entity.name4 : '---市级---'\"\r\n\t\t\t:items=\"areaData.area4\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box\"\r\n\t\t\t:class=\"maxArea > 4 && 'mr-3'\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 4\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 6\"\r\n\t\t\tv-model=\"entity.area6\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area6, 3)\"\r\n\t\t\t@click:clear=\"clear(3)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 6 ? entity.name6 : '---区/县---'\"\r\n\t\t\t:items=\"areaData.area6\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box\"\r\n\t\t\t:class=\"maxArea > 6 && 'mr-3'\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 6\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 9\"\r\n\t\t\tv-model=\"entity.area9\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area9, 4)\"\r\n\t\t\t@click:clear=\"clear(4)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 9 ? entity.name9 : '---街/镇---'\"\r\n\t\t\t:items=\"areaData.area9\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box\"\r\n\t\t\t:class=\"maxArea > 9 && 'mr-3'\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 9\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 12\"\r\n\t\t\tv-model=\"entity.area12\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area12, 5)\"\r\n\t\t\t@click:clear=\"clear(5)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 12 ? entity.name12 : '---村/社---'\"\r\n\t\t\t:items=\"areaData.area12\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block\"\r\n\t\t\tstyle=\"width: 188px\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 12\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t</div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, reactive, onMounted, getCurrentInstance } from 'vue';\r\n\r\nimport Request from \"../../commons/request\"\r\n\r\nconst { proxy } = getCurrentInstance();\r\n\r\n// 定义组件名称和选项\r\ndefineOptions({\r\n\tname: \"VtkArea\",\r\n\tinheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n\tmaxArea: {\r\n\t\ttype: Number,\r\n\t\tdefault: 12,\r\n\t},\r\n\tminArea: {\r\n\t\ttype: Number,\r\n\t\tdefault: null,\r\n\t},\r\n\tareaStyle: {\r\n\t\ttype: String,\r\n\t\tdefault: \"\",\r\n\t},\r\n});\r\n\r\n// 定义emits\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 响应式数据\r\nconst entity = reactive({\r\n\tarea2: null,\r\n\tarea4: null,\r\n\tarea6: null,\r\n\tarea9: null,\r\n\tarea12: null,\r\n\tname2: '',\r\n\tname4: '',\r\n\tname6: '',\r\n\tname9: '',\r\n\tname12: ''\r\n});\r\n\r\nconst user = ref({ areacode: \"\" });\r\nconst areaData = reactive({\r\n\tarea2: [],\r\n\tarea4: [],\r\n\tarea6: [],\r\n\tarea9: [],\r\n\tarea12: []\r\n});\r\n\r\n// 安全获取 vtk 对象\r\nconst getVtk = () => {\r\n if (typeof window !== 'undefined' && window.$vtk) {\r\n return window.$vtk;\r\n }\r\n return null;\r\n};\r\n\r\n// 组件挂载时执行\r\nonMounted(() => {\r\n\t// 获取配置的键名,如果没有配置则使用默认值\r\n\tconst userKey = window.VTK_CONFIG?.storageKeys?.user || '_mis_acis_users';\r\n\tuser.value = typeof(proxy.$vtk.storage.get(userKey)) != 'object' ? JSON.parse(proxy.$vtk.storage.get(userKey)) : proxy.$vtk.storage.get(userKey) || '';\r\n\tif (user.value) {\r\n\t\tarea();\r\n\t}\r\n});\r\n\r\n// 所属地区\r\nconst area = () => {\r\n try {\r\n proxy.$vtk.message.loading.show();\r\n Request.postForm(`/dict/area/show/${user.value.areacode}`).then((res) => {\r\n proxy.$vtk.message.loading.hide();\r\n if (res.meta.success) {\r\n entity[`area${res.data.areaLeve}`] = res.data.areaCode;\r\n entity.name2 = res.data.province;\r\n entity.name4 = res.data.city;\r\n entity.name6 = res.data.district;\r\n entity.name9 = res.data?.town;\r\n entity.name12 = res.data?.village;\r\n nextArea(user.value.areacode);\r\n } else {\r\n proxy.$vtk.message.toast(res.meta.message);\r\n }\r\n }).catch(error => {\r\n proxy.$vtk.message.loading.hide();\r\n proxy.$vtk.message.toast('加载区域数据失败');\r\n });\r\n } catch (error) {\r\n console.error('初始化区域数据失败:', error);\r\n if (proxy.$vtk.message?.loading?.hide) {\r\n proxy.$vtk.message.loading.hide();\r\n }\r\n }\r\n};\r\n\r\n// 下一级地区列表\r\nconst nextArea = (areaCode, index) => {\r\n\tinputFn(areaCode);\r\n \r\n\tif (areaCode?.length < 12) {\r\n\t\tRequest.postForm(`/dict/area/next/${areaCode}`).then((res) => {\r\n\t\t\tproxy.$vtk.message.loading.hide();\r\n\t\t\tif (res.meta.success) {\r\n\t\t\t\tif (index) {\r\n\t\t\t\t\tObject.keys(areaData)\r\n\t\t\t\t\t\t.slice(index, 5)\r\n\t\t\t\t\t\t.forEach((e) => {\r\n\t\t\t\t\t\t\tareaData[e] = [];\r\n\t\t\t\t\t\t\tentity[e] = null;\r\n\t\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tareaData[`area${res.data[0].areaLeve}`] = res.data;\r\n\t\t\t} else {\r\n\t\t\t\tproxy.$vtk.message.toast(res.meta.message);\r\n\t\t\t}\r\n\t\t}).catch(error => {\r\n console.error('加载下级区域数据失败:', error);\r\n proxy.$vtk.message.toast('加载下级区域数据失败');\r\n });\r\n\t}\r\n};\r\n\r\n// 清除\r\nconst clear = (index) => {\r\n\tlet arr = Object.keys(areaData);\r\n\tinputFn(entity[arr[index - 2]]);\r\n\tarr.slice(index, 5).forEach((e) => {\r\n\t\tareaData[e] = [];\r\n\t\tentity[e] = null;\r\n\t});\r\n};\r\n\r\n// 输入事件\r\nconst inputFn = (e) => {\r\n\te && emit(\"update:modelValue\", e);\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.sel_box {\r\n\twidth: 164px;\r\n}\r\n</style>","<template>\r\n\t<v-menu v-model=\"menu\" :close-on-content-click=\"false\" max-width=\"520\" min-width=\"520\">\r\n\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t<v-btn\r\n\t\t\t\tv-bind=\"props\"\r\n\t\t\t\tvariant=\"outlined\"\r\n\t\t\t\tcolor=\"primary\"\r\n\t\t\t\tclass=\"area-select-btn\"\r\n\t\t\t\t:style=\"$attrs.styles\"\r\n\t\t\t>\r\n\t\t\t\t<span class=\"btn-text\">{{ itemText || '选择地区' }}</span>\r\n\t\t\t\t<v-icon v-if=\"itemText\" size=\"small\" @click.stop=\"textClear\" class=\"ml-2\">mdi-close-circle</v-icon>\r\n\t\t\t</v-btn>\r\n\t\t</template>\r\n\t\t<v-card elevation=\"0\" style=\"width: 350px;\">\r\n\t\t\t<p class=\"pt-3 px-3\">\r\n\t\t\t\t<v-icon color=\"primary\" class=\"mr-1\" size=\"20\">mdi-map-marker-radius</v-icon>\r\n\t\t\t\t<span v-for=\"link in entity\" :key=\"link.areaCode\" class=\"link text-body-2 text-primary\">{{ link.areaName }}</span>\r\n\t\t\t</p>\r\n\t\t\t<v-sheet class=\"rounded-lg mx-3 mt-2\" color=\"#b1b1b117\">\r\n\t\t\t\t<v-tabs v-model=\"tab\" @update:model-value=\"tabArea\" class=\"pt-2 px-1\">\r\n\t\t\t\t\t<v-tab\r\n\t\t\t\t\t\tv-for=\"(item, index) in tabItems\"\r\n\t\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\t\tclass=\"mx-1\"\r\n\t\t\t\t\t\t:style=\"tab == index && 'color:white;opacity:1'\"\r\n\t\t\t\t\t\t:disabled=\"areaStorage.length <= index + 1\"\r\n\t\t\t\t\t\tv-show=\"minArea ? minArea >= item.leve : true\"\r\n\t\t\t\t\t>{{ item.text }}</v-tab>\r\n\t\t\t\t</v-tabs>\r\n\t\t\t\t<v-sheet\r\n\t\t\t\t\tv-show=\"index == tab\"\r\n\t\t\t\t\tv-for=\"(item, index) in tabItems\"\r\n\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\tclass=\"px-3 py-1\"\r\n\t\t\t\t\tmin-height=\"100\"\r\n\t\t\t\t\tcolor=\"rgba(0,0,0,0)\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<v-chip-group v-model=\"current\" selected-class=\"chipActive\" column>\r\n\t\t\t\t\t\t<v-chip\r\n\t\t\t\t\t\t\tv-for=\"area in areaItems\"\r\n\t\t\t\t\t\t\t:key=\"area.id\"\r\n\t\t\t\t\t\t\t@click=\"areaChange(area, index)\"\r\n\t\t\t\t\t\t\tclass=\"rounded\"\r\n\t\t\t\t\t\t\t:class=\"area.areaCode == user.areacode && 'active'\"\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{{ area.areaName }}\r\n\t\t\t\t\t\t</v-chip>\r\n\t\t\t\t\t</v-chip-group>\r\n\t\t\t\t</v-sheet>\r\n\t\t\t</v-sheet>\r\n\r\n\t\t\t<v-card-actions class=\"pr-0 py-3\">\r\n\t\t\t\t<v-spacer />\r\n\t\t\t\t<v-btn @click=\"close\" elevation=\"0\" size=\"small\"><v-icon class=\"pt-1 pr-1\">mdi-progress-close</v-icon> 取消</v-btn>\r\n\t\t\t\t<v-btn @click=\"save\" class=\"text-white mr-3\" color=\"primary\" elevation=\"0\" size=\"small\"><v-icon class=\"pt-1 pr-1\">mdi-progress-check</v-icon> 确定</v-btn>\r\n\t\t\t</v-card-actions>\r\n\t\t</v-card>\r\n\t</v-menu>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, watch, onMounted, getCurrentInstance, nextTick } from 'vue';\r\n\r\nconst props = defineProps({\r\n\tmodelValue: {\r\n\t\ttype: [String, Object],\r\n\t\tdefault: null,\r\n\t},\r\n\tminArea: {\r\n\t\ttype: Number,\r\n\t\tdefault: null,\r\n\t},\r\n\tareaNode: {\r\n\t\ttype: Number,\r\n\t\tdefault: null,\r\n\t},\r\n\tareaCode: {\r\n\t\ttype: String,\r\n\t\tdefault: null,\r\n\t},\r\n\treturnObj: {\r\n\t\ttype: Boolean,\r\n\t\tdefault: false,\r\n\t},\r\n});\r\n\r\nconst emit = defineEmits(['update:modelValue', 'change']);\r\n\r\nconst { proxy } = getCurrentInstance();\r\n\r\nconst menu = ref(false);\r\nconst user = ref({});\r\nconst tab = ref(0);\r\nconst tabItems = ref([]);\r\nconst areaStorage = ref([]); //存储个级别地区数据\r\nconst areaItems = ref([]); //当前选择地区的所有列\r\nconst entity = ref([]); //存储选中的数据\r\nconst current = ref(null); //回显值选中\r\nconst itemValue = ref(\"\"); //传值:最终选择值\r\nconst itemText = ref(\"\"); //最终选择值\r\n\r\n// 值回显\r\nconst view = (code) => {\r\n\tproxy.$vtk.request.getForm(`/dict/area/show/${code}`).then((res) => {\r\n\t\tlet province = res.data.province ? `${res.data.province}` : \"\";\r\n\t\tlet city = res.data.city ? `/${res.data.city}` : \"\";\r\n\t\tlet district = res.data.district ? `/${res.data.district}` : \"\";\r\n\t\tlet town = res.data.town ? `/${res.data.town}` : \"\";\r\n\t\tlet village = res.data.village ? `/${res.data.village}` : \"\";\r\n\t\titemText.value = `${province}${city}${district}${town}${village}`;\r\n\t\tif (props.areaNode && props.areaNode > 0) {\r\n\t\t\titemText.value = itemText.value.split(\"/\").slice(-props.areaNode).join(\"/\");\r\n\t\t}\r\n\t});\r\n};\r\n\r\n// 切换Tab地区级别\r\nconst tabArea = (index) => {\r\n\tareaItems.value = [...areaStorage.value[index]];\r\n\tif (index < entity.value.length) {\r\n\t\tcurrent.value = areaItems.value.findIndex((e) => e.areaCode == entity.value[index].areaCode);\r\n\t} else {\r\n\t\tcurrent.value = null;\r\n\t}\r\n};\r\n\r\n//选择地区\r\nconst areaChange = (item, index) => {\r\n\tentity.value = entity.value.slice(0, index);\r\n\tentity.value.push(item);\r\n\tareaStorage.value = areaStorage.value.slice(0, index + 1);\r\n\tif (tabItems.value.length > tab.value + 1 && (props.minArea ? props.minArea > item.areaCode.length : true)) {\r\n\t\tgetTree(item.areaCode);\r\n\t\ttab.value++;\r\n\t}\r\n};\r\n\r\n// 加载下级地区\r\nconst getTree = (code) => {\r\n\tproxy.$vtk.request.getForm(`/dict/area/next/${code}`).then((res) => {\r\n\t\tareaItems.value = res.data;\r\n\t\tareaStorage.value.push(res.data);\r\n\t\tcurrent.value = null;\r\n\t\tnextTick(); //Vue 3中替代$forceUpdate\r\n\t});\r\n};\r\n\r\n// 加载第一个地区,用户所在地区\r\nconst getAreaName = (code) => {\r\n\tentity.value = [];\r\n\ttabItems.value = [\r\n\t\t{ text: \"省级\", leve: \"2\" },\r\n\t\t{ text: \"市级\", leve: \"4\" },\r\n\t\t{ text: \"区县\", leve: \"6\" },\r\n\t\t{ text: \"街镇\", leve: \"9\" },\r\n\t\t{ text: \"村社\", leve: \"12\" },\r\n\t].filter((e) => e.leve >= (props.areaCode || user.value?.areacode || user.value?.areaCode || '').length);\r\n\tareaStorage.value = [];\r\n\r\n\tproxy.$vtk.request.getForm(`/dict/area/show/${code}`).then((res) => {\r\n\t\tareaItems.value = [{ areaName: res.data.areaName, areaCode: res.data.areaCode }];\r\n\t\tareaStorage.value.push(areaItems.value);\r\n\t\tentity.value.push(areaItems.value[0]);\r\n\t});\r\n};\r\n\r\n//确认保存\r\nconst save = () => {\r\n\tlet text = [];\r\n\tlet val = [];\r\n\tentity.value.forEach((e) => {\r\n\t\ttext.push(e.areaName);\r\n\t\tval.push(e.areaCode);\r\n\t\titemValue.value = e.areaCode;\r\n\t});\r\n\tif (props.areaNode && props.areaNode > 0) {\r\n\t\ttext = text.slice(-props.areaNode);\r\n\t}\r\n\titemText.value = text.join().replace(/,/g, \"/\");\r\n\tconst lastItem = entity.value[entity.value.length - 1];\r\n\temit(\"update:modelValue\", props.returnObj ? { areaCode: lastItem?.areaCode, areaName: lastItem?.areaName } : itemValue.value);\r\n\temit(\"change\");\r\n\tclose();\r\n};\r\n\r\n// 清空\r\nconst textClear = () => {\r\n\ttab.value = 0;\r\n\tconst initCode = props.areaCode || user.value?.areacode || user.value?.areaCode;\r\n\tgetAreaName(initCode);\r\n\titemValue.value = initCode;\r\n\temit(\"update:modelValue\", itemValue.value);\r\n\temit(\"change\");\r\n};\r\n\r\n// 关闭弹窗\r\nconst close = () => {\r\n\tmenu.value = false;\r\n};\r\n\r\n// Watch modelValue\r\nwatch(() => props.modelValue, (newVal, oldVal) => {\r\n\tif (newVal && newVal != oldVal) {\r\n\t\tconst code = typeof newVal === 'object' ? newVal.areaCode : newVal;\r\n\t\tif (code) view(code);\r\n\t}\r\n});\r\n\r\n// 组件挂载时执行\r\nonMounted(() => {\r\n\t// 获取配置的键名,如果没有配置则使用默认值\r\n\tconst userKey = window.VTK_CONFIG?.storageKeys?.user || '_mis_acis_users';\r\n\tuser.value = proxy.$vtk.storage.get(userKey) && JSON.parse(proxy.$vtk.storage.get(userKey));\r\n\tconst initCode = props.areaCode || user.value?.areacode || user.value?.areaCode;\r\n\tif (initCode) {\r\n\t\tgetAreaName(initCode);\r\n\t}\r\n\tif (props.modelValue) {\r\n\t\tconst code = typeof props.modelValue === 'object' ? props.modelValue.areaCode : props.modelValue;\r\n\t\tif (code) view(code);\r\n\t}\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n// 圆形按钮样式\r\n.area-select-btn {\r\n\tborder-radius: 20px !important;\r\n\tpadding: 6px 20px !important;\r\n\tmin-width: 120px;\r\n\theight: 36px !important;\r\n\ttext-transform: none;\r\n\tletter-spacing: normal;\r\n\r\n\t.btn-text {\r\n\t\tfont-size: 14px;\r\n\t\tcolor: inherit;\r\n\t}\r\n\r\n\t&:hover {\r\n\t\tbackground-color: rgba(var(--v-theme-primary), 0.08);\r\n\t}\r\n}\r\n:deep(.v-tab__slider) {\r\n\theight: 0px !important;\r\n}\r\n\r\n.link::after {\r\n\tcontent: \" / \";\r\n\tfont-size: 14px;\r\n\tcolor: #999;\r\n}\r\n.link:last-of-type::after {\r\n\tcontent: \"\";\r\n}\r\n:deep(.v-chip:not(.v-chip--selected)) {\r\n\tbackground: #e0e0e000;\r\n}\r\n// Vuetify 3 tabs container styling\r\n:deep(.v-tabs) {\r\n\theight: 40px;\r\n}\r\n// Tab button styling\r\n:deep(.v-tab) {\r\n\tmin-width: 90px;\r\n\theight: 32px !important;\r\n\tborder-radius: 6px !important;\r\n\tcolor: rgba(0, 0, 0, .6);\r\n\ttransition: all 0.3s ease;\r\n\tz-index: 1;\r\n}\r\n// Active/selected tab styling\r\n:deep(.v-tab--selected) {\r\n\tbackground-color: rgb(var(--v-theme-primary));\r\n\tcolor: white !important;\r\n\topacity: 1;\r\n}\r\n// Hover effect\r\n:deep(.v-tab:hover) {\r\n\tbackground-color: rgba(var(--v-theme-primary), 0.9);\r\n\tcolor: white;\r\n}\r\n.tabActive {\r\n\tcolor: #fff;\r\n}\r\n.chipActive {\r\n\tcolor: #0095ff !important;\r\n\tbackground-color: #008eff05 !important;\r\n}\r\n.active {\r\n\tcolor: #0095ff !important;\r\n\tbackground-color: #008eff20 !important;\r\n}\r\n:deep(.v-slide-group__next),\r\n:deep(.v-slide-group__prev) {\r\n\tdisplay: none;\r\n}\r\n</style>\r\n","<template>\r\n <div class=\"vtk-breadcrumb-wrapper d-flex align-center justify-space-between\">\r\n <!-- 左侧面包屑 -->\r\n <v-breadcrumbs :items=\"breadcrumbItems\" class=\"pa-0\">\r\n <template v-slot:divider>\r\n <v-icon>mdi-chevron-right</v-icon>\r\n </template>\r\n <template v-slot:item=\"{ item }\">\r\n <v-breadcrumbs-item\r\n :title=\"item.title\"\r\n :to=\"item.to\"\r\n :disabled=\"item.disabled\"\r\n :class=\"{ 'text-primary': !item.disabled }\"\r\n >\r\n {{ item.title }}\r\n </v-breadcrumbs-item>\r\n </template>\r\n </v-breadcrumbs>\r\n\r\n <!-- 右侧返回按钮 -->\r\n <v-btn\r\n v-if=\"showBack\"\r\n variant=\"text\"\r\n color=\"primary\"\r\n prepend-icon=\"mdi-arrow-left\"\r\n @click=\"handleBack\"\r\n style=\"height: 36px;\"\r\n >\r\n {{ backText }}\r\n </v-btn>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed, inject, getCurrentInstance } from 'vue'\r\n\r\nconst props = defineProps({\r\n // 面包屑项目数组\r\n items: {\r\n type: Array,\r\n default: () => []\r\n },\r\n // 是否显示返回按钮\r\n showBack: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 返回按钮文字\r\n backText: {\r\n type: String,\r\n default: '返回'\r\n },\r\n // 自定义返回路径,不传则返回上一级\r\n backTo: {\r\n type: [String, Object],\r\n default: null\r\n }\r\n})\r\n\r\nconst emit = defineEmits(['back'])\r\n\r\n// 使用inject安全地获取router和route\r\nconst router = inject('router', null)\r\nconst route = inject('route', null)\r\n\r\n// 处理面包屑数据\r\nconst breadcrumbItems = computed(() => {\r\n if (props.items && props.items.length > 0) {\r\n return props.items.map((item, index) => ({\r\n title: item.title || item.text || item.name,\r\n to: item.to || item.path || item.href,\r\n disabled: item.disabled !== undefined ? item.disabled : index === props.items.length - 1\r\n }))\r\n }\r\n\r\n // 如果route不可用,返回空数组\r\n if (!route) {\r\n return []\r\n }\r\n\r\n // 如果没有传入items,尝试从路由meta中获取\r\n const matched = route.matched?.filter(r => r.meta && r.meta.breadcrumb) || []\r\n if (matched.length > 0) {\r\n return matched.map((r, index) => ({\r\n title: r.meta.breadcrumb,\r\n to: r.path,\r\n disabled: index === matched.length - 1\r\n }))\r\n }\r\n\r\n // 默认返回当前路由路径生成的面包屑\r\n const pathArray = route.path?.split('/').filter(p => p) || []\r\n return pathArray.map((path, index) => {\r\n const routePath = '/' + pathArray.slice(0, index + 1).join('/')\r\n return {\r\n title: path.charAt(0).toUpperCase() + path.slice(1),\r\n to: routePath,\r\n disabled: index === pathArray.length - 1\r\n }\r\n })\r\n})\r\n\r\n// 处理返回按钮点击\r\nconst handleBack = () => {\r\n // 触发back事件\r\n emit('back')\r\n\r\n // 如果router不可用,仅触发事件\r\n if (!router) {\r\n return\r\n }\r\n\r\n // 如果传入了backTo参数,跳转到指定路径\r\n if (props.backTo) {\r\n if (typeof props.backTo === 'string') {\r\n router.push(props.backTo)\r\n } else {\r\n router.push(props.backTo)\r\n }\r\n } else {\r\n // 默认返回上一级\r\n router.back()\r\n }\r\n}\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-breadcrumb-wrapper {\r\n width: 100%;\r\n padding: 12px 0;\r\n\r\n :deep(.v-breadcrumbs) {\r\n flex-grow: 1;\r\n height: 36px;\r\n }\r\n\r\n :deep(.v-breadcrumbs-item) {\r\n font-size: 14px;\r\n }\r\n\r\n :deep(.v-breadcrumbs-divider) {\r\n padding: 0 8px;\r\n }\r\n\r\n :deep(.v-breadcrumbs-item--disabled) {\r\n opacity: 0.6;\r\n }\r\n}\r\n</style>\r\n","<template>\r\n <VInput \r\n v-bind=\"inputAttrs\" \r\n :model-value=\"inputValue\"\r\n >\r\n <div class=\"checkGroup\" :class=\"inline ? 'd-flex flex-wrap align-top' : 'd-inline-block'\">\r\n <VCheckbox\r\n v-for=\"item in items\"\r\n hide-details\r\n :key=\"item.id || item.code\"\r\n :label=\"item.codeValue\"\r\n :value=\"item.code\"\r\n v-model=\"localValue\"\r\n v-bind=\"checkboxAttrs\"\r\n :class=\"inline ? 'mr-4' : ''\"\r\n />\r\n </div>\r\n </VInput>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, useAttrs, computed, watch } from 'vue';\r\nimport Request from '../../commons/request';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkCheckbox\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n /**\r\n * 字典来源:\r\n * - 若为静态数据,格式如:\"0:否/1:是\"\r\n * - 若为字典键,格式如:\"DISABLE_TYPE\"\r\n */\r\n list: {\r\n type: String,\r\n required: true,\r\n },\r\n /**\r\n * 是否横向排列\r\n */\r\n inline: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n /**\r\n * 绑定值\r\n */\r\n modelValue: {\r\n type: [Array, String],\r\n default: () => []\r\n }\r\n});\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 本地选中值\r\nconst localValue = ref([]);\r\n\r\n// 防止递归更新的标志位\r\nconst isUpdatingLocal = ref(false);\r\nconst isUpdatingModel = ref(false);\r\n\r\n// 同步外部 modelValue 到本地值\r\nwatch(() => props.modelValue, (newVal) => {\r\n if (isUpdatingModel.value) {\r\n isUpdatingModel.value = false;\r\n return;\r\n }\r\n \r\n isUpdatingLocal.value = true;\r\n if (Array.isArray(newVal)) {\r\n localValue.value = [...newVal];\r\n } else if (typeof newVal === 'string') {\r\n localValue.value = newVal ? [newVal] : [];\r\n } else {\r\n localValue.value = [];\r\n }\r\n}, { immediate: true });\r\n\r\n// 同步本地值到外部 modelValue\r\nwatch(localValue, (newVal) => {\r\n if (isUpdatingLocal.value) {\r\n isUpdatingLocal.value = false;\r\n return;\r\n }\r\n \r\n isUpdatingModel.value = true;\r\n emit('update:modelValue', newVal);\r\n}, { deep: true });\r\n\r\n// 获取透传属性\r\nconst attrs = useAttrs();\r\n\r\n// 分离传递给 input 和传递给 checkbox 的属性\r\nconst inputAttrs = computed(() => {\r\n const { list, inline, modelValue, ...rest } = attrs;\r\n return rest;\r\n});\r\n\r\nconst checkboxAttrs = computed(() => {\r\n // 移除表单验证相关属性,避免重复应用\r\n const { \r\n list, \r\n inline, \r\n modelValue,\r\n error, \r\n 'error-messages': errorMessages, \r\n rules, \r\n hint, \r\n 'persistent-hint': persistentHint,\r\n ...rest \r\n } = attrs;\r\n return rest;\r\n});\r\n\r\n// 为 v-input 提供一个值\r\nconst inputValue = computed(() => {\r\n return localValue.value && localValue.value.length > 0 ? localValue.value : null;\r\n});\r\n\r\n// 响应式数据\r\nconst items = ref([]);\r\n\r\n// 处理静态数据(如 \"0:否/1:是\")\r\nconst statc = () => {\r\n props.list.split('/').forEach(it => {\r\n const [code, codeValue] = it.split(':');\r\n items.value.push({ code, codeValue });\r\n });\r\n};\r\n\r\n// 请求远程字典数据\r\nconst miscs = async () => {\r\n try {\r\n const res = await Request.getForm(`dict/misc/list/${props.list}`);\r\n items.value = res.data || [];\r\n } catch (error) {\r\n console.error('[VtkCheckbox] Failed to load dictionary:', error);\r\n items.value = [];\r\n }\r\n};\r\n\r\n// 组件挂载时初始化数据\r\nonMounted(() => {\r\n if (props.list.includes(':')) {\r\n statc();\r\n } else {\r\n miscs();\r\n }\r\n});\r\n</script>\r\n\r\n<style scoped>\r\n:deep(.v-checkbox .v-selection-control) {\r\n margin: 0;\r\n padding: 0;\r\n min-height: 32px;\r\n}\r\n\r\n:deep(.v-input__details) {\r\n padding-inline: 16px;\r\n}\r\n</style>","<!-- \r\n\r\n// 基础用法\r\n <VtkCount :start=\"0\" :end=\"12345\" :duration=\"3000\" suffix=\"次\" />\r\n \r\n//带前缀和分隔符\r\n <VtkCount \r\n :start=\"0\" \r\n :end=\"999999\" \r\n :duration=\"2000\" \r\n prefix=\"¥\" \r\n suffix=\"元\" \r\n :separator=\"true\" \r\n />\r\n \r\n//手动控制\r\n <VtkCount \r\n ref=\"countRef\" \r\n :start=\"0\" \r\n :end=\"100\" \r\n :autoplay=\"false\" \r\n @complete=\"onComplete\"\r\n />\r\n <VBtn @click=\"startCount\">开始计数</VBtn>\r\n -->\r\n\r\n<template>\r\n <div class=\"vtk-count\" :class=\"containerClass\">\r\n <div class=\"count-display\" :style=\"{ color: color }\">\r\n <!-- 前缀 -->\r\n <span v-if=\"prefix\" class=\"prefix\">{{ prefix }}</span>\r\n \r\n <!-- 数字容器 -->\r\n <div class=\"digits-container\">\r\n <div \r\n v-for=\"(digitChar, index) in maxDigitString\" \r\n :key=\"`digit-${index}-${digitKey}`\"\r\n class=\"digit-wrapper\"\r\n :class=\"{ 'digit-separator': isNaN(digitChar) }\"\r\n >\r\n <div \r\n v-if=\"!isNaN(digitChar)\" \r\n class=\"digit-scroll\"\r\n >\r\n <div \r\n v-for=\"n in 10\" \r\n :key=\"n\" \r\n class=\"digit-item\"\r\n :style=\"getDigitStyle(getCurrentDigit(index), n-1)\"\r\n >\r\n {{ n-1 }}\r\n </div>\r\n </div>\r\n <div v-else class=\"separator\">{{ digitChar }}</div>\r\n </div>\r\n </div>\r\n \r\n <!-- 后缀 -->\r\n <span v-if=\"suffix\" class=\"suffix\">{{ suffix }}</span>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, onMounted, watch, nextTick } from 'vue'\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkCount\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // 初始值\r\n start: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 目标值\r\n end: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 动画持续时间(毫秒)\r\n duration: {\r\n type: Number,\r\n default: 2000\r\n },\r\n // 是否自动开始动画\r\n autoplay: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 数字前缀\r\n prefix: {\r\n type: String,\r\n default: ''\r\n },\r\n // 数字后缀\r\n suffix: {\r\n type: String,\r\n default: ''\r\n },\r\n // 容器自定义类名\r\n containerClass: {\r\n type: String,\r\n default: ''\r\n },\r\n // 是否使用分隔符(千分位)\r\n separator: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 小数位数\r\n decimals: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 文字颜色\r\n color: {\r\n type: String,\r\n default: '#1976d2'\r\n }\r\n})\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['complete'])\r\n\r\n// 当前显示的数值\r\nconst currentNumber = ref(props.start)\r\n\r\n// 当前每个位置的数字值\r\nconst currentDigits = ref([])\r\n\r\n// 用于强制重新渲染的key\r\nconst digitKey = ref(0)\r\n\r\n// 是否正在动画中\r\nconst isAnimating = ref(false)\r\n\r\n// 格式化数字(处理小数和分隔符)\r\nconst formatNumber = (num) => {\r\n let result = num.toFixed(props.decimals)\r\n if (props.separator && props.decimals === 0) {\r\n result = result.replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',')\r\n }\r\n return result\r\n}\r\n\r\n// 获取目标数字字符串\r\nconst targetNumberString = computed(() => {\r\n return formatNumber(props.end)\r\n})\r\n\r\n// 获取起始数字字符串\r\nconst startNumberString = computed(() => {\r\n return formatNumber(props.start)\r\n})\r\n\r\n// 获取最大位数的字符串(用于保持DOM结构稳定)\r\nconst maxDigitString = computed(() => {\r\n const target = targetNumberString.value\r\n const start = startNumberString.value\r\n return target.length >= start.length ? target : start\r\n})\r\n\r\n// 获取当前指定位置的数字\r\nconst getCurrentDigit = (index) => {\r\n if (index < currentDigits.value.length) {\r\n return currentDigits.value[index]\r\n }\r\n return '0'\r\n}\r\n\r\n// 初始化数字数组\r\nconst initDigitsArray = () => {\r\n const targetStr = targetNumberString.value\r\n const startStr = startNumberString.value\r\n \r\n // 初始化currentDigits数组,确保长度与maxDigitString一致\r\n currentDigits.value = maxDigitString.value.split('').map((char, index) => {\r\n if (isNaN(char)) {\r\n return char // 分隔符保持原样\r\n }\r\n \r\n // 从起始字符串对应位置获取数字\r\n if (index < startStr.length) {\r\n const startChar = startStr[index]\r\n return isNaN(startChar) ? '0' : startChar\r\n }\r\n return '0'\r\n })\r\n}\r\n\r\n// 获取数字样式\r\nconst getDigitStyle = (currentValue, digitValue) => {\r\n // 如果是分隔符,直接返回\r\n if (isNaN(currentValue) || isNaN(digitValue)) {\r\n return {\r\n transform: 'translateY(0)'\r\n }\r\n }\r\n \r\n const current = parseInt(currentValue) || 0\r\n const target = digitValue\r\n const offset = target - current\r\n \r\n // 处理循环滚动(9->0 或 0->9)\r\n let translateY\r\n if (offset > 5) {\r\n // 向下滚动(如 9->0)\r\n translateY = -(10 - offset) * 100\r\n } else if (offset < -5) {\r\n // 向上滚动(如 0->9)\r\n translateY = (10 + offset) * 100\r\n } else {\r\n translateY = -offset * 100\r\n }\r\n \r\n return {\r\n transform: `translateY(${translateY}%)`,\r\n transition: isAnimating.value ? 'transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94)' : 'none',\r\n color: props.color\r\n }\r\n}\r\n\r\n// 开始数字动画\r\nconst startAnimation = () => {\r\n if (isAnimating.value) return\r\n \r\n isAnimating.value = true\r\n const startTime = performance.now()\r\n const startValue = props.start\r\n const endValue = props.end\r\n const diff = endValue - startValue\r\n \r\n // 初始化数字数组\r\n initDigitsArray()\r\n \r\n const animate = (currentTime) => {\r\n const elapsed = currentTime - startTime\r\n const progress = Math.min(elapsed / props.duration, 1)\r\n \r\n // 使用缓动函数使动画更自然\r\n const easeOutQuart = 1 - Math.pow(1 - progress, 4)\r\n currentNumber.value = startValue + diff * easeOutQuart\r\n \r\n // 更新每个数字位的当前值\r\n updateDigitArray(currentNumber.value)\r\n \r\n if (progress < 1) {\r\n requestAnimationFrame(animate)\r\n } else {\r\n currentNumber.value = endValue\r\n // 确保最终值准确\r\n updateDigitArray(endValue)\r\n isAnimating.value = false\r\n emit('complete')\r\n }\r\n }\r\n \r\n requestAnimationFrame(animate)\r\n}\r\n\r\n// 更新数字数组\r\nconst updateDigitArray = (value) => {\r\n const valueStr = formatNumber(value)\r\n const maxStr = maxDigitString.value\r\n \r\n // 保持数组长度不变,只更新值\r\n for (let i = 0; i < maxStr.length; i++) {\r\n if (i < valueStr.length) {\r\n currentDigits.value[i] = valueStr[i]\r\n } else {\r\n // 超出部分保持为'0'或分隔符\r\n currentDigits.value[i] = isNaN(maxStr[i]) ? maxStr[i] : '0'\r\n }\r\n }\r\n}\r\n\r\n// 监听 end 值变化,重新开始动画\r\nwatch(() => props.end, (newVal, oldVal) => {\r\n if (newVal !== oldVal) {\r\n // 当位数可能发生变化时,更新key强制重新渲染\r\n const newStr = formatNumber(newVal)\r\n const oldStr = formatNumber(oldVal)\r\n if (newStr.length !== oldStr.length) {\r\n digitKey.value += 1\r\n nextTick(() => {\r\n startAnimation()\r\n })\r\n } else {\r\n startAnimation()\r\n }\r\n }\r\n})\r\n\r\n// 组件挂载时开始动画\r\nonMounted(() => {\r\n if (props.autoplay) {\r\n // 检查初始值和目标值位数是否不同,如果不同则更新key\r\n const startStr = startNumberString.value\r\n const endStr = targetNumberString.value\r\n if (startStr.length !== endStr.length) {\r\n digitKey.value += 1\r\n }\r\n \r\n nextTick(() => {\r\n startAnimation()\r\n })\r\n }\r\n})\r\n\r\n// 提供外部调用方法\r\ndefineExpose({\r\n startAnimation\r\n})\r\n</script>\r\n\r\n<style scoped>\r\n.vtk-count {\r\n display: inline-block;\r\n}\r\n\r\n.count-display {\r\n display: flex;\r\n align-items: center;\r\n font-family: 'Roboto Mono', monospace;\r\n font-size: 24px;\r\n font-weight: bold;\r\n}\r\n\r\n.digits-container {\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n.digit-wrapper {\r\n position: relative;\r\n width: 1em;\r\n height: 1em;\r\n overflow: hidden;\r\n text-align: center;\r\n margin: 0 1px;\r\n}\r\n\r\n.digit-wrapper.digit-separator {\r\n width: auto;\r\n animation: none;\r\n}\r\n\r\n.digit-scroll {\r\n position: relative;\r\n height: 100%;\r\n}\r\n\r\n.digit-item {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.separator {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 100%;\r\n font-weight: normal;\r\n}\r\n\r\n.prefix, .suffix {\r\n font-size: 0.8em;\r\n align-self: flex-end;\r\n margin-bottom: 0.1em;\r\n}\r\n\r\n.prefix {\r\n margin-right: 4px;\r\n}\r\n\r\n.suffix {\r\n margin-left: 4px;\r\n}\r\n\r\n/* 响应式设计 */\r\n@media (max-width: 768px) {\r\n .count-display {\r\n font-size: 20px;\r\n }\r\n}\r\n\r\n@media (max-width: 480px) {\r\n .count-display {\r\n font-size: 18px;\r\n }\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-date-range-picker\">\r\n <VMenu\r\n v-model=\"menu\"\r\n :close-on-content-click=\"false\"\r\n transition=\"scale-transition\"\r\n offset-y\r\n min-width=\"auto\"\r\n eager\r\n >\r\n <template #activator=\"{ props: activatorProps }\">\r\n <VTextField\r\n v-bind=\"{ ...activatorProps, ...textFieldProps }\"\r\n v-model=\"displayValue\"\r\n :placeholder=\"placeholder\"\r\n :disabled=\"disabled\"\r\n readonly\r\n clearable\r\n density=\"compact\"\r\n variant=\"outlined\"\r\n @click:clear=\"clearValue\"\r\n >\r\n <template #prepend-inner>\r\n <VIcon size=\"small\">mdi-calendar</VIcon>\r\n </template>\r\n </VTextField>\r\n </template>\r\n \r\n <VCard style=\"width: 650px;\">\r\n <VCardText class=\"pa-0\">\r\n <div class=\"date-picker-container\">\r\n <VDatePicker\r\n v-model=\"startDateRange\"\r\n hide-header\r\n :min=\"minDate\"\r\n :max=\"maxDate\"\r\n :show-current=\"showCurrent\"\r\n @update:model-value=\"onStartDateChange\"\r\n class=\"date-picker-item\"\r\n />\r\n <VDatePicker\r\n v-model=\"endDateRange\"\r\n hide-header\r\n :min=\"minDate\"\r\n :max=\"maxDate\"\r\n :show-current=\"showCurrent\"\r\n @update:model-value=\"onEndDateChange\"\r\n class=\"date-picker-item\"\r\n />\r\n </div>\r\n </VCardText>\r\n \r\n <VDivider></VDivider>\r\n \r\n <VCardActions>\r\n <VSpacer></VSpacer>\r\n <VBtn text @click=\"cancel\">取消</VBtn>\r\n <VBtn color=\"primary\" variant=\"tonal\" @click=\"confirm\">确定</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VMenu>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch, useAttrs } from 'vue';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkDatePicker\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n // v-model绑定值\r\n modelValue: {\r\n type: [Array, String],\r\n default: () => []\r\n },\r\n // 占位符\r\n placeholder: {\r\n type: String,\r\n default: '请选择日期范围'\r\n },\r\n // 禁用状态\r\n disabled: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 最小日期\r\n min: {\r\n type: String,\r\n default: undefined\r\n },\r\n // 最大日期\r\n max: {\r\n type: String,\r\n default: undefined\r\n },\r\n // 是否显示当前日期\r\n showCurrent: {\r\n type: [Boolean, String],\r\n default: true\r\n },\r\n // 显示格式\r\n format: {\r\n type: String,\r\n default: 'YYYY-MM-DD'\r\n },\r\n // 分隔符\r\n separator: {\r\n type: String,\r\n default: ' 至 '\r\n }\r\n});\r\n\r\n// 定义emit事件\r\nconst emit = defineEmits(['update:modelValue', 'change']);\r\n\r\n// 获取透传属性\r\nconst attrs = useAttrs();\r\n\r\n// 菜单显示控制\r\nconst menu = ref(false);\r\n\r\n// 日期范围值\r\nconst dateRange = ref([]);\r\n\r\n// 为了横向排列,需要分别管理开始和结束日期选择器的值\r\nconst startDateRange = ref(null);\r\nconst endDateRange = ref(null);\r\n\r\n\r\n// 显示值\r\nconst displayValue = computed(() => {\r\n if (!dateRange.value || dateRange.value.length === 0) {\r\n return '';\r\n }\r\n \r\n if (dateRange.value.length === 1) {\r\n return formatDate(dateRange.value[0]);\r\n }\r\n \r\n return `${formatDate(dateRange.value[0])}${props.separator}${formatDate(dateRange.value[1])}`;\r\n});\r\n\r\n// 文本框属性\r\nconst textFieldProps = computed(() => {\r\n // 排除我们自己使用的属性\r\n const { \r\n modelValue, \r\n placeholder, \r\n disabled, \r\n min, \r\n max, \r\n showCurrent, \r\n format,\r\n separator,\r\n ...rest \r\n } = attrs;\r\n \r\n return rest;\r\n});\r\n\r\n// 格式化日期\r\nconst formatDate = (date) => {\r\n if (!date) return '';\r\n \r\n // 如果是字符串直接返回\r\n if (typeof date === 'string') {\r\n return date;\r\n }\r\n \r\n // 如果是 Date 对象\r\n if (date instanceof Date) {\r\n const year = date.getFullYear();\r\n const month = String(date.getMonth() + 1).padStart(2, '0');\r\n const day = String(date.getDate()).padStart(2, '0');\r\n return `${year}-${month}-${day}`;\r\n }\r\n \r\n return date;\r\n};\r\n\r\n// 最小日期\r\nconst minDate = computed(() => props.min);\r\n\r\n// 最大日期\r\nconst maxDate = computed(() => props.max);\r\n\r\n// 监听外部modelValue变化\r\nwatch(\r\n () => props.modelValue,\r\n (newValue) => {\r\n if (Array.isArray(newValue) && newValue.length > 0) {\r\n dateRange.value = [...newValue];\r\n // 同步到单独的日期选择器\r\n if (newValue[0]) startDateRange.value = newValue[0];\r\n if (newValue[1]) endDateRange.value = newValue[1];\r\n } else if (typeof newValue === 'string' && newValue) {\r\n // 处理字符串形式的日期范围,如 \"2023-01-01 至 2023-01-31\"\r\n const dates = newValue.split(props.separator);\r\n if (dates.length === 2) {\r\n dateRange.value = [dates[0].trim(), dates[1].trim()];\r\n startDateRange.value = dates[0].trim();\r\n endDateRange.value = dates[1].trim();\r\n } else {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n }\r\n } else {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n }\r\n },\r\n { immediate: true }\r\n);\r\n\r\n\r\n// 开始日期变化处理\r\nconst onStartDateChange = (value) => {\r\n // 更新日期范围的第一个值\r\n if (value) {\r\n dateRange.value = [value, dateRange.value[1] || null];\r\n } else {\r\n // 如果开始日期被清除,清除整个范围或只清除开始日期\r\n if (dateRange.value.length > 0) {\r\n dateRange.value = [null, dateRange.value[1] || null];\r\n }\r\n }\r\n};\r\n\r\n// 结束日期变化处理\r\nconst onEndDateChange = (value) => {\r\n // 更新日期范围的第二个值\r\n if (value) {\r\n dateRange.value = [dateRange.value[0] || null, value];\r\n } else {\r\n // 如果结束日期被清除,只清除结束日期\r\n if (dateRange.value.length > 1) {\r\n dateRange.value = [dateRange.value[0] || null, null];\r\n }\r\n }\r\n};\r\n\r\n// 清除值\r\nconst clearValue = () => {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n emit('update:modelValue', []);\r\n emit('change', []);\r\n menu.value = false;\r\n};\r\n\r\n// 取消\r\nconst cancel = () => {\r\n // 恢复到原始值\r\n if (Array.isArray(props.modelValue)) {\r\n dateRange.value = [...props.modelValue];\r\n if (props.modelValue[0]) startDateRange.value = props.modelValue[0];\r\n if (props.modelValue[1]) endDateRange.value = props.modelValue[1];\r\n } else {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n }\r\n menu.value = false;\r\n};\r\n\r\n// 确认\r\nconst confirm = () => {\r\n // 确保日期按顺序排列\r\n let sortedRange = [...dateRange.value].filter(date => date !== null);\r\n if (sortedRange.length === 2) {\r\n const date1 = new Date(sortedRange[0]);\r\n const date2 = new Date(sortedRange[1]);\r\n if (date1 > date2) {\r\n sortedRange = [sortedRange[1], sortedRange[0]];\r\n }\r\n } else if (sortedRange.length === 1) {\r\n // 如果只有一个日期,复制为范围\r\n sortedRange = [sortedRange[0], sortedRange[0]];\r\n }\r\n \r\n emit('update:modelValue', sortedRange);\r\n emit('change', sortedRange);\r\n menu.value = false;\r\n};\r\n</script>\r\n\r\n<style scoped>\r\n.vtk-date-range-picker {\r\n width: 100%;\r\n}\r\n\r\n.date-picker-container {\r\n display: flex;\r\n flex-direction: row;\r\n gap: 0;\r\n}\r\n\r\n.date-picker-item {\r\n flex: 1;\r\n max-width: 50%;\r\n}\r\n\r\n.date-picker-item:first-child {\r\n border-right: 1px solid rgba(0, 0, 0, 0.12);\r\n}\r\n\r\n:deep(.v-picker) {\r\n border-radius: 0;\r\n}\r\n\r\n:deep(.v-date-picker-month__day--adjacent) {\r\n opacity: 0.5;\r\n}\r\n\r\n:deep(.v-date-picker-title) {\r\n display: none;\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-date-selector\">\r\n <VMenu\r\n v-if=\"!inline\"\r\n v-model=\"showPicker\"\r\n :attach=\"menuAttach\"\r\n :location=\"menuLocation\"\r\n :origin=\"menuOrigin\"\r\n offset=\"4\"\r\n :close-on-content-click=\"false\"\r\n >\r\n <template #activator=\"{ props: menuProps }\">\r\n <div class=\"date-input\">\r\n <VTextField :model-value=\"displayValue\" :placeholder=\"placeholder\" :disabled=\"disabled\" density=\"compact\"\r\n variant=\"outlined\" hide-details readonly v-bind=\"menuProps\" :clearable=\"!!displayValue && !disabled\"\r\n clear-icon=\"mdi-close-circle\" persistent-clear class=\"date-input-field\" @click:clear.stop=\"clearValue\">\r\n <template #append-inner>\r\n <span class=\"date-icon\" aria-hidden=\"true\">\r\n <svg viewBox=\"0 0 24 24\" fill=\"none\" class=\"date-icon-svg\">\r\n <path\r\n d=\"M7 2.75a.75.75 0 0 1 .75.75V5h8.5V3.5a.75.75 0 0 1 1.5 0V5h.75A2.5 2.5 0 0 1 21 7.5v10A2.5 2.5 0 0 1 18.5 20h-13A2.5 2.5 0 0 1 3 17.5v-10A2.5 2.5 0 0 1 5.5 5h.75V3.5A.75.75 0 0 1 7 2.75ZM4.5 10v7.5c0 .552.448 1 1 1h13c.552 0 1-.448 1-1V10h-15Zm1-3.5c-.552 0-1 .448-1 1v1h15v-1c0-.552-.448-1-1-1h-.75v1a.75.75 0 0 1-1.5 0v-1h-8.5v1a.75.75 0 0 1-1.5 0v-1H5.5Zm2.25 5.75a.75.75 0 0 1 .75.75v.25a.75.75 0 0 1-1.5 0V13a.75.75 0 0 1 .75-.75Zm4.25 0a.75.75 0 0 1 .75.75v.25a.75.75 0 0 1-1.5 0V13a.75.75 0 0 1 .75-.75Zm4.25 0a.75.75 0 0 1 .75.75v.25a.75.75 0 0 1-1.5 0V13a.75.75 0 0 1 .75-.75Zm-8.5 3.75a.75.75 0 0 1 .75.75V17a.75.75 0 0 1-1.5 0v-.25a.75.75 0 0 1 .75-.75Zm4.25 0a.75.75 0 0 1 .75.75V17a.75.75 0 0 1-1.5 0v-.25a.75.75 0 0 1 .75-.75Z\"\r\n fill=\"currentColor\" />\r\n </svg>\r\n </span>\r\n </template>\r\n </VTextField>\r\n </div>\r\n </template>\r\n <div class=\"date-picker-dropdown\" @click.stop @mousedown.stop>\r\n <!-- 头部控制区(非日期/月份范围选择模式时显示) -->\r\n <div v-if=\"!(mode === 'range' && (displayMode === 'day' || displayMode === 'month'))\" class=\"picker-header\">\r\n <button class=\"nav-btn\" @click=\"prevPeriod\">‹</button>\r\n <div class=\"header-title\">\r\n <span @click=\"changeViewMode('year')\" class=\"clickable\">{{ currentYear }}年</span>\r\n <span v-if=\"displayMode !== 'year' && viewMode !== 'month'\" @click=\"changeViewMode('month')\"\r\n class=\"clickable\">{{\r\n currentMonth + 1\r\n }}月</span>\r\n </div>\r\n <button class=\"nav-btn\" @click=\"nextPeriod\">›</button>\r\n </div>\r\n\r\n <!-- 年份选择视图 -->\r\n <div v-if=\"viewMode === 'year'\" class=\"picker-body\">\r\n <div class=\"year-grid\">\r\n <div v-for=\"year in yearList\" :key=\"year\"\r\n :class=\"['year-item', { 'selected': isYearSelected(year), 'in-range': isYearInRange(year), 'disabled': isFutureYear(year) }]\"\r\n @click=\"selectYear(year)\">\r\n {{ year }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 月份选择视图 -->\r\n <div v-else-if=\"viewMode === 'month'\" class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个年份的月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYear\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYearLeft\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYearRight\">‹</button>\r\n <span class=\"month-title\">{{ rightYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYear\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelectedRight(index), 'in-range': isMonthInRangeRight(index), 'disabled': isFutureMonth(index, rightYear) }]\"\r\n @click=\"selectMonthRight(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个年份的月份 -->\r\n <div v-else>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 周选择视图 -->\r\n <div v-else-if=\"viewMode === 'week'\" class=\"picker-body\">\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"week-grid\">\r\n <div v-for=\"week in weekList\" :key=\"week.weekNumber\"\r\n :class=\"['week-row', { 'selected': isWeekSelected(week), 'in-range': isWeekInRange(week) }]\"\r\n @click=\"selectWeek(week)\">\r\n <div class=\"week-number\">W{{ week.weekNumber }}</div>\r\n <div v-for=\"day in week.days\" :key=\"day.date\"\r\n :class=\"['day-cell', { 'other-month': day.otherMonth, 'today': day.isToday }]\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 日期选择视图(默认) -->\r\n <div v-else class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonth\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年{{ currentMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonthLeft\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonthRight\">‹</button>\r\n <span class=\"month-title\">{{ nextMonthYear }}年{{ nextMonthMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonth\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in nextMonthDayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个月份 -->\r\n <div v-else>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 底部操作区 -->\r\n <div v-if=\"mode === 'range' && (displayMode === 'day' || displayMode === 'month')\" class=\"range-display\">\r\n <span class=\"range-text\">\r\n <template v-if=\"tempValue && Array.isArray(tempValue) && tempValue.length > 0\">\r\n {{ tempValue[0] || (displayMode === 'month' ? '开始月份' : '开始日期') }}\r\n <span class=\"range-separator\"> - </span>\r\n {{ tempValue[1] || (displayMode === 'month' ? '结束月份' : '结束日期') }}\r\n </template>\r\n <template v-else>\r\n <span class=\"placeholder-text\">{{ displayMode === 'month' ? '请选择月份范围' : '请选择日期范围' }}</span>\r\n </template>\r\n </span>\r\n </div>\r\n <div class=\"picker-footer\">\r\n <button class=\"btn btn-text\" @click=\"handleCancel\">取消</button>\r\n <button class=\"btn btn-primary\" @click=\"handleConfirm\">确定</button>\r\n </div>\r\n </div>\r\n </VMenu>\r\n <div v-if=\"inline\" class=\"date-picker-dropdown inline-mode\" @click.stop @mousedown.stop>\r\n <!-- 头部控制区(非日期/月份范围选择模式时显示) -->\r\n <div v-if=\"!(mode === 'range' && (displayMode === 'day' || displayMode === 'month'))\" class=\"picker-header\">\r\n <button class=\"nav-btn\" @click=\"prevPeriod\">‹</button>\r\n <div class=\"header-title\">\r\n <span @click=\"changeViewMode('year')\" class=\"clickable\">{{ currentYear }}年</span>\r\n <span v-if=\"displayMode !== 'year' && viewMode !== 'month'\" @click=\"changeViewMode('month')\"\r\n class=\"clickable\">{{\r\n currentMonth + 1\r\n }}月</span>\r\n </div>\r\n <button class=\"nav-btn\" @click=\"nextPeriod\">›</button>\r\n </div>\r\n\r\n <!-- 年份选择视图 -->\r\n <div v-if=\"viewMode === 'year'\" class=\"picker-body\">\r\n <div class=\"year-grid\">\r\n <div v-for=\"year in yearList\" :key=\"year\"\r\n :class=\"['year-item', { 'selected': isYearSelected(year), 'in-range': isYearInRange(year), 'disabled': isFutureYear(year) }]\"\r\n @click=\"selectYear(year)\">\r\n {{ year }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 月份选择视图 -->\r\n <div v-else-if=\"viewMode === 'month'\" class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个年份的月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYear\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYearLeft\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYearRight\">‹</button>\r\n <span class=\"month-title\">{{ rightYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYear\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelectedRight(index), 'in-range': isMonthInRangeRight(index), 'disabled': isFutureMonth(index, rightYear) }]\"\r\n @click=\"selectMonthRight(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个年份的月份 -->\r\n <div v-else>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 周选择视图 -->\r\n <div v-else-if=\"viewMode === 'week'\" class=\"picker-body\">\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"week-grid\">\r\n <div v-for=\"week in weekList\" :key=\"week.weekNumber\"\r\n :class=\"['week-row', { 'selected': isWeekSelected(week), 'in-range': isWeekInRange(week) }]\"\r\n @click=\"selectWeek(week)\">\r\n <div class=\"week-number\">W{{ week.weekNumber }}</div>\r\n <div v-for=\"day in week.days\" :key=\"day.date\"\r\n :class=\"['day-cell', { 'other-month': day.otherMonth, 'today': day.isToday }]\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 日期选择视图(默认) -->\r\n <div v-else class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonth\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年{{ currentMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonthLeft\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonthRight\">‹</button>\r\n <span class=\"month-title\">{{ nextMonthYear }}年{{ nextMonthMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonth\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in nextMonthDayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个月份 -->\r\n <div v-else>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 底部操作区 -->\r\n <div v-if=\"mode === 'range' && (displayMode === 'day' || displayMode === 'month')\" class=\"range-display\">\r\n <span class=\"range-text\">\r\n <template v-if=\"tempValue && Array.isArray(tempValue) && tempValue.length > 0\">\r\n {{ tempValue[0] || (displayMode === 'month' ? '开始月份' : '开始日期') }}\r\n <span class=\"range-separator\"> - </span>\r\n {{ tempValue[1] || (displayMode === 'month' ? '结束月份' : '结束日期') }}\r\n </template>\r\n <template v-else>\r\n <span class=\"placeholder-text\">{{ displayMode === 'month' ? '请选择月份范围' : '请选择日期范围' }}</span>\r\n </template>\r\n </span>\r\n </div>\r\n <div class=\"picker-footer\">\r\n <button class=\"btn btn-text\" @click=\"handleCancel\">取消</button>\r\n <button class=\"btn btn-primary\" @click=\"handleConfirm\">确定</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch } from 'vue';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: 'VtkDateSelector',\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // v-model 绑定值\r\n modelValue: {\r\n type: [String, Array],\r\n default: null\r\n },\r\n // 显示模式: 'day' | 'week' | 'month' | 'year'\r\n displayMode: {\r\n type: String,\r\n default: 'day',\r\n validator: (value) => ['day', 'week', 'month', 'year'].includes(value)\r\n },\r\n // 选择模式: 'single' | 'range'\r\n mode: {\r\n type: String,\r\n default: 'single',\r\n validator: (value) => ['single', 'range'].includes(value)\r\n },\r\n // 占位符\r\n placeholder: {\r\n type: String,\r\n default: '请选择日期'\r\n },\r\n // 禁用状态\r\n disabled: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 日期格式\r\n format: {\r\n type: String,\r\n default: 'YYYY-MM-DD'\r\n },\r\n // 范围分隔符\r\n separator: {\r\n type: String,\r\n default: ' 至 '\r\n },\r\n // 内联模式(直接显示选择器,不需要点击输入框)\r\n inline: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 单面板模式(范围选择时只显示一个面板)\r\n singlePanel: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 禁用未来日期(大于当前日期的都置灰不可选)\r\n disableFuture: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 自定义取消方法\r\n onCancel: {\r\n type: Function,\r\n default: null\r\n },\r\n // 自定义确认方法\r\n onConfirm: {\r\n type: Function,\r\n default: null\r\n },\r\n // 禁用 Teleport 时,弹层保留在当前 DOM 树内\r\n noTeleport: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 下拉框对齐方式: 'left' | 'right'\r\n placement: {\r\n type: String,\r\n default: 'left',\r\n validator: (value) => ['left', 'right'].includes(value)\r\n }\r\n});\r\n\r\n// 定义 emit\r\nconst emit = defineEmits(['update:modelValue', 'change', 'cancel', 'confirm']);\r\n\r\n// 响应式数据\r\nconst showPicker = ref(false);\r\nconst viewMode = ref(props.displayMode);\r\nconst currentYear = ref(new Date().getFullYear());\r\nconst currentMonth = ref(new Date().getMonth());\r\nconst rightYear = ref(new Date().getFullYear());\r\nconst rightMonth = ref(new Date().getMonth() + 1);\r\nconst selectedValue = ref(null);\r\nconst tempValue = ref(null);\r\n\r\n// 当前日期(用于判断未来日期)\r\nconst today = new Date();\r\nconst todayYear = today.getFullYear();\r\nconst todayMonth = today.getMonth();\r\nconst todayDate = today.getDate();\r\n\r\n// 年份面板固定展示 12 个年份,并尽量让锚点年份落在中间偏前位置\r\nconst YEAR_PANEL_SIZE = 12;\r\nconst YEAR_PANEL_CENTER_OFFSET = 4;\r\n\r\n// 周和月份名称\r\nconst weekDays = ['日', '一', '二', '三', '四', '五', '六'];\r\nconst monthList = ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'];\r\n\r\n// 显示值\r\nconst menuAttach = computed(() => (props.noTeleport ? true : false));\r\n\r\nconst menuLocation = computed(() => props.placement === 'right' ? 'bottom end' : 'bottom start');\r\n\r\nconst menuOrigin = computed(() => props.placement === 'right' ? 'top end' : 'top start');\r\n\r\nconst displayValue = computed(() => {\r\n if (!selectedValue.value) return '';\r\n\r\n if (props.mode === 'range' && Array.isArray(selectedValue.value)) {\r\n if (selectedValue.value.length === 2) {\r\n return `${formatDisplay(selectedValue.value[0])}${props.separator}${formatDisplay(selectedValue.value[1])}`;\r\n }\r\n return '';\r\n }\r\n\r\n return formatDisplay(selectedValue.value);\r\n});\r\n\r\n// 格式化显示\r\nconst formatDisplay = (value) => {\r\n if (!value) return '';\r\n\r\n if (props.displayMode === 'year') {\r\n return `${value}年`;\r\n } else if (props.displayMode === 'month') {\r\n const [year, month] = value.split('-');\r\n return `${year}年${month}月`;\r\n } else if (props.displayMode === 'week') {\r\n const [year, week] = value.split('-W');\r\n return `${year}年第${week}周`;\r\n }\r\n\r\n return value;\r\n};\r\n\r\n// 年份列表(显示12年)\r\nconst yearList = computed(() => {\r\n // 年份面板打开时,以当前锚点年份为中心生成 12 个年份选项\r\n const startYear = currentYear.value - YEAR_PANEL_CENTER_OFFSET;\r\n return Array.from({ length: YEAR_PANEL_SIZE }, (_, i) => startYear + i);\r\n});\r\n\r\n// 周列表\r\nconst weekList = computed(() => {\r\n const weeks = [];\r\n const firstDay = new Date(currentYear.value, currentMonth.value, 1);\r\n const lastDay = new Date(currentYear.value, currentMonth.value + 1, 0);\r\n\r\n let currentDate = new Date(firstDay);\r\n currentDate.setDate(currentDate.getDate() - currentDate.getDay());\r\n\r\n let weekNumber = getWeekNumber(currentDate);\r\n\r\n while (currentDate <= lastDay || currentDate.getDay() !== 0) {\r\n const week = {\r\n weekNumber: weekNumber,\r\n startDate: new Date(currentDate),\r\n days: []\r\n };\r\n\r\n for (let i = 0; i < 7; i++) {\r\n const day = {\r\n date: formatDate(currentDate),\r\n day: currentDate.getDate(),\r\n month: currentDate.getMonth(),\r\n year: currentDate.getFullYear(),\r\n otherMonth: currentDate.getMonth() !== currentMonth.value,\r\n isToday: isToday(currentDate)\r\n };\r\n week.days.push(day);\r\n currentDate.setDate(currentDate.getDate() + 1);\r\n }\r\n\r\n weeks.push(week);\r\n weekNumber++;\r\n\r\n if (currentDate > lastDay && currentDate.getDay() === 0) break;\r\n }\r\n\r\n return weeks;\r\n});\r\n\r\n// 日期列表\r\nconst dayList = computed(() => {\r\n const days = [];\r\n const firstDay = new Date(currentYear.value, currentMonth.value, 1);\r\n const lastDay = new Date(currentYear.value, currentMonth.value + 1, 0);\r\n\r\n const startDate = new Date(firstDay);\r\n startDate.setDate(startDate.getDate() - startDate.getDay());\r\n\r\n const endDate = new Date(lastDay);\r\n endDate.setDate(endDate.getDate() + (6 - endDate.getDay()));\r\n\r\n let currentDate = new Date(startDate);\r\n\r\n while (currentDate <= endDate) {\r\n days.push({\r\n date: formatDate(currentDate),\r\n day: currentDate.getDate(),\r\n month: currentDate.getMonth(),\r\n year: currentDate.getFullYear(),\r\n otherMonth: currentDate.getMonth() !== currentMonth.value,\r\n isToday: isToday(currentDate)\r\n });\r\n currentDate.setDate(currentDate.getDate() + 1);\r\n }\r\n\r\n return days;\r\n});\r\n\r\n// 右侧日历的年份和月份(独立状态)\r\nconst nextMonthYear = computed(() => rightYear.value);\r\nconst nextMonthMonth = computed(() => rightMonth.value);\r\n\r\n// 下个月的日期列表\r\nconst nextMonthDayList = computed(() => {\r\n const days = [];\r\n const firstDay = new Date(nextMonthYear.value, nextMonthMonth.value, 1);\r\n const lastDay = new Date(nextMonthYear.value, nextMonthMonth.value + 1, 0);\r\n\r\n const startDate = new Date(firstDay);\r\n startDate.setDate(startDate.getDate() - startDate.getDay());\r\n\r\n const endDate = new Date(lastDay);\r\n endDate.setDate(endDate.getDate() + (6 - endDate.getDay()));\r\n\r\n let currentDate = new Date(startDate);\r\n\r\n while (currentDate <= endDate) {\r\n days.push({\r\n date: formatDate(currentDate),\r\n day: currentDate.getDate(),\r\n month: currentDate.getMonth(),\r\n year: currentDate.getFullYear(),\r\n otherMonth: currentDate.getMonth() !== nextMonthMonth.value,\r\n isToday: isToday(currentDate)\r\n });\r\n currentDate.setDate(currentDate.getDate() + 1);\r\n }\r\n\r\n return days;\r\n});\r\n\r\n// 工具函数\r\nconst formatDate = (date) => {\r\n const year = date.getFullYear();\r\n const month = String(date.getMonth() + 1).padStart(2, '0');\r\n const day = String(date.getDate()).padStart(2, '0');\r\n return `${year}-${month}-${day}`;\r\n};\r\n\r\nconst isToday = (date) => {\r\n const today = new Date();\r\n return date.getDate() === today.getDate() &&\r\n date.getMonth() === today.getMonth() &&\r\n date.getFullYear() === today.getFullYear();\r\n};\r\n\r\nconst getWeekNumber = (date) => {\r\n const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n const dayNum = d.getUTCDay() || 7;\r\n d.setUTCDate(d.getUTCDate() + 4 - dayNum);\r\n const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1));\r\n return Math.ceil((((d - yearStart) / 86400000) + 1) / 7);\r\n};\r\n\r\n// 选择判断\r\nconst isYearSelected = (year) => {\r\n if (!tempValue.value) return false;\r\n if (props.mode === 'single') {\r\n return tempValue.value === year.toString();\r\n }\r\n if (Array.isArray(tempValue.value) && tempValue.value.length > 0) {\r\n return tempValue.value.some(v => v && v.startsWith(year.toString()));\r\n }\r\n return false;\r\n};\r\n\r\nconst isYearInRange = (year) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const [start, end] = tempValue.value.map(v => parseInt(v));\r\n return year > start && year < end;\r\n};\r\n\r\nconst isMonthSelected = (month) => {\r\n if (!tempValue.value) return false;\r\n const monthStr = `${currentYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n return tempValue.value === monthStr;\r\n }\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(monthStr);\r\n }\r\n return false;\r\n};\r\n\r\nconst isMonthInRange = (month) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const monthStr = `${currentYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n return monthStr > tempValue.value[0] && monthStr < tempValue.value[1];\r\n};\r\n\r\nconst isWeekSelected = (week) => {\r\n if (!tempValue.value) return false;\r\n const weekStr = `${currentYear.value}-W${String(week.weekNumber).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n return tempValue.value === weekStr;\r\n }\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(weekStr);\r\n }\r\n return false;\r\n};\r\n\r\nconst isWeekInRange = (week) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const weekStr = `${currentYear.value}-W${String(week.weekNumber).padStart(2, '0')}`;\r\n return weekStr > tempValue.value[0] && weekStr < tempValue.value[1];\r\n};\r\n\r\nconst isDaySelected = (day) => {\r\n if (!tempValue.value) return false;\r\n if (props.mode === 'single') {\r\n return tempValue.value === day.date;\r\n }\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(day.date);\r\n }\r\n return false;\r\n};\r\n\r\nconst isDayInRange = (day) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n return day.date > tempValue.value[0] && day.date < tempValue.value[1];\r\n};\r\n\r\nconst isDayRangeStart = (day) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length === 0) {\r\n return false;\r\n }\r\n return day.date === tempValue.value[0];\r\n};\r\n\r\nconst isDayRangeEnd = (day) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length < 2) {\r\n return false;\r\n }\r\n return day.date === tempValue.value[1];\r\n};\r\n\r\n// 判断是否是未来日期/月份/年份\r\nconst isFutureYear = (year) => {\r\n if (!props.disableFuture) return false;\r\n return year > todayYear;\r\n};\r\n\r\nconst isFutureMonth = (month, year) => {\r\n if (!props.disableFuture) return false;\r\n if (year > todayYear) return true;\r\n if (year === todayYear && month > todayMonth) return true;\r\n return false;\r\n};\r\n\r\nconst isFutureDay = (day) => {\r\n if (!props.disableFuture) return false;\r\n const [year, month, date] = day.date.split('-').map(Number);\r\n if (year > todayYear) return true;\r\n if (year === todayYear && month - 1 > todayMonth) return true;\r\n if (year === todayYear && month - 1 === todayMonth && date > todayDate) return true;\r\n return false;\r\n};\r\n\r\n// 选择操作\r\nconst selectYear = (year) => {\r\n // 如果是未来年份且禁用未来日期,则不允许选择\r\n if (isFutureYear(year)) return;\r\n\r\n const yearStr = year.toString();\r\n\r\n // 如果 displayMode 是 'year',则选择年份作为值\r\n if (props.displayMode === 'year') {\r\n if (props.mode === 'single') {\r\n tempValue.value = yearStr;\r\n if (props.inline) {\r\n // 内联模式直接确认\r\n confirm();\r\n }\r\n } else {\r\n // 范围选择\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [yearStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= yearStr ? [first, yearStr] : [yearStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [yearStr];\r\n }\r\n }\r\n } else {\r\n // 如果 displayMode 不是 'year',则只是切换年份,然后返回到原来的视图\r\n currentYear.value = year;\r\n // 切换回原来的显示模式\r\n viewMode.value = props.displayMode;\r\n }\r\n};\r\n\r\nconst selectMonth = (month) => {\r\n // 如果是未来月份且禁用未来日期,则不允许选择\r\n if (isFutureMonth(month, currentYear.value)) return;\r\n\r\n if (props.displayMode !== 'month') {\r\n currentMonth.value = month;\r\n viewMode.value = props.displayMode;\r\n return;\r\n }\r\n\r\n const monthStr = `${currentYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n tempValue.value = monthStr;\r\n if (props.displayMode === 'month' || props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [monthStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= monthStr ? [first, monthStr] : [monthStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [monthStr];\r\n }\r\n }\r\n};\r\n\r\nconst selectMonthRight = (month) => {\r\n // 如果是未来月份且禁用未来日期,则不允许选择\r\n if (isFutureMonth(month, rightYear.value)) return;\r\n\r\n const monthStr = `${rightYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [monthStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= monthStr ? [first, monthStr] : [monthStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [monthStr];\r\n }\r\n};\r\n\r\nconst isMonthSelectedRight = (month) => {\r\n if (!tempValue.value) return false;\r\n const monthStr = `${rightYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(monthStr);\r\n }\r\n return false;\r\n};\r\n\r\nconst isMonthInRangeRight = (month) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const monthStr = `${rightYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n return monthStr > tempValue.value[0] && monthStr < tempValue.value[1];\r\n};\r\n\r\nconst selectWeek = (week) => {\r\n const weekStr = `${currentYear.value}-W${String(week.weekNumber).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n tempValue.value = weekStr;\r\n confirm();\r\n } else {\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [weekStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= weekStr ? [first, weekStr] : [weekStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [weekStr];\r\n }\r\n }\r\n};\r\n\r\nconst selectDay = (day) => {\r\n // 如果是未来日期且禁用未来日期,则不允许选择\r\n if (isFutureDay(day)) return;\r\n\r\n if (props.mode === 'single') {\r\n tempValue.value = day.date;\r\n // 内联模式下单选直接确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [day.date];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= day.date ? [first, day.date] : [day.date, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [day.date];\r\n }\r\n }\r\n};\r\n\r\n// 导航操作\r\nconst prevPeriod = () => {\r\n if (viewMode.value === 'year') {\r\n currentYear.value -= 12;\r\n } else if (viewMode.value === 'month') {\r\n currentYear.value -= 1;\r\n } else {\r\n if (currentMonth.value === 0) {\r\n currentMonth.value = 11;\r\n currentYear.value -= 1;\r\n } else {\r\n currentMonth.value -= 1;\r\n }\r\n }\r\n};\r\n\r\nconst nextPeriod = () => {\r\n if (viewMode.value === 'year') {\r\n currentYear.value += 12;\r\n } else if (viewMode.value === 'month') {\r\n currentYear.value += 1;\r\n } else {\r\n if (currentMonth.value === 11) {\r\n currentMonth.value = 0;\r\n currentYear.value += 1;\r\n } else {\r\n currentMonth.value += 1;\r\n }\r\n }\r\n};\r\n\r\n// 月份导航(用于双日历)\r\nconst prevMonth = () => {\r\n // 只控制左侧日历\r\n if (currentMonth.value === 0) {\r\n currentMonth.value = 11;\r\n currentYear.value -= 1;\r\n } else {\r\n currentMonth.value -= 1;\r\n }\r\n};\r\n\r\nconst nextMonthLeft = () => {\r\n // 增加左侧日历月份\r\n if (currentMonth.value === 11) {\r\n currentMonth.value = 0;\r\n currentYear.value += 1;\r\n } else {\r\n currentMonth.value += 1;\r\n }\r\n};\r\n\r\nconst prevMonthRight = () => {\r\n // 减少右侧日历月份\r\n if (rightMonth.value === 0) {\r\n rightMonth.value = 11;\r\n rightYear.value -= 1;\r\n } else {\r\n rightMonth.value -= 1;\r\n }\r\n};\r\n\r\nconst nextMonth = () => {\r\n // 只控制右侧日历\r\n if (rightMonth.value === 11) {\r\n rightMonth.value = 0;\r\n rightYear.value += 1;\r\n } else {\r\n rightMonth.value += 1;\r\n }\r\n};\r\n\r\n// 年份导航(用于双月份面板)\r\nconst prevYear = () => {\r\n // 只控制左侧年份\r\n currentYear.value -= 1;\r\n};\r\n\r\nconst nextYearLeft = () => {\r\n // 增加左侧年份\r\n currentYear.value += 1;\r\n};\r\n\r\nconst prevYearRight = () => {\r\n // 减少右侧年份\r\n rightYear.value -= 1;\r\n};\r\n\r\nconst nextYear = () => {\r\n // 只控制右侧年份\r\n rightYear.value += 1;\r\n};\r\n\r\nconst changeViewMode = (mode) => {\r\n if (props.displayMode === 'year' && mode !== 'year') return;\r\n if (props.displayMode === 'month' && !['year', 'month'].includes(mode)) return;\r\n viewMode.value = mode;\r\n};\r\n\r\n// 面板操作\r\nconst initializePicker = () => {\r\n if (props.displayMode === 'year' && props.mode === 'single') {\r\n currentYear.value = todayYear;\r\n }\r\n\r\n tempValue.value = selectedValue.value ?\r\n (Array.isArray(selectedValue.value) ? [...selectedValue.value] : selectedValue.value) :\r\n (props.mode === 'range' ? [] : null);\r\n viewMode.value = props.displayMode;\r\n\r\n if (props.displayMode === 'month') {\r\n rightYear.value = currentYear.value + 1;\r\n } else {\r\n if (currentMonth.value === 11) {\r\n rightYear.value = currentYear.value + 1;\r\n rightMonth.value = 0;\r\n } else {\r\n rightYear.value = currentYear.value;\r\n rightMonth.value = currentMonth.value + 1;\r\n }\r\n }\r\n};\r\n\r\nwatch(showPicker, (isOpen) => {\r\n if (isOpen) {\r\n initializePicker();\r\n }\r\n});\r\nif (props.inline) {\r\n // 内联模式下直接初始化\r\n tempValue.value = selectedValue.value ?\r\n (Array.isArray(selectedValue.value) ? [...selectedValue.value] : selectedValue.value) :\r\n (props.mode === 'range' ? [] : null);\r\n viewMode.value = props.displayMode;\r\n\r\n // 初始化右侧日历/年份\r\n if (props.displayMode === 'month') {\r\n rightYear.value = currentYear.value + 1;\r\n } else {\r\n if (currentMonth.value === 11) {\r\n rightYear.value = currentYear.value + 1;\r\n rightMonth.value = 0;\r\n } else {\r\n rightYear.value = currentYear.value;\r\n rightMonth.value = currentMonth.value + 1;\r\n }\r\n }\r\n}\r\n\r\nconst closePicker = () => {\r\n showPicker.value = false;\r\n};\r\n\r\nconst clearValue = () => {\r\n selectedValue.value = props.mode === 'range' ? [] : null;\r\n emit('update:modelValue', selectedValue.value);\r\n emit('change', selectedValue.value);\r\n};\r\n\r\nconst confirm = () => {\r\n selectedValue.value = tempValue.value;\r\n emit('update:modelValue', selectedValue.value);\r\n emit('change', selectedValue.value);\r\n closePicker();\r\n};\r\n\r\n// 自定义取消和确认处理\r\nconst handleCancel = () => {\r\n if (props.onCancel) {\r\n props.onCancel();\r\n } else {\r\n emit('cancel');\r\n closePicker();\r\n }\r\n};\r\n\r\nconst handleConfirm = () => {\r\n if (props.onConfirm) {\r\n props.onConfirm(tempValue.value);\r\n } else {\r\n emit('confirm', tempValue.value);\r\n confirm();\r\n }\r\n};\r\n\r\n// 监听外部值变化\r\nwatch(() => props.modelValue, (newValue) => {\r\n selectedValue.value = newValue;\r\n}, { immediate: true });\r\n</script>\r\n\r\n<style scoped>\r\n.vtk-date-selector {\r\n position: relative;\r\n width: 100%;\r\n}\r\n\r\n.date-input {\r\n width: 100%;\r\n}\r\n\r\n.date-input-field {\r\n cursor: pointer;\r\n}\r\n\r\n:deep(.date-input-field .v-field),\r\n:deep(.date-input-field input) {\r\n cursor: pointer;\r\n}\r\n\r\n.date-icon {\r\n margin-left: 8px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.date-icon-svg {\r\n width: 16px;\r\n height: 16px;\r\n display: block;\r\n}\r\n\r\n.clear-icon {\r\n margin-left: 4px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-size: 18px;\r\n line-height: 1;\r\n cursor: pointer;\r\n padding: 2px;\r\n}\r\n\r\n.clear-icon:hover {\r\n color: rgb(var(--v-theme-on-surface), 0.87);\r\n}\r\n\r\n.date-picker-dropdown {\r\n background: rgb(var(--v-theme-surface));\r\n border-radius: 8px;\r\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\r\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n}\r\n\r\n.date-picker-dropdown.inline-mode {\r\n box-shadow: none;\r\n width: fit-content;\r\n border: none;\r\n}\r\n\r\n.picker-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 12px 16px;\r\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n}\r\n\r\n.header-title {\r\n font-size: 16px;\r\n font-weight: 500;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.clickable {\r\n cursor: pointer;\r\n padding: 4px 8px;\r\n border-radius: 4px;\r\n transition: background 0.2s;\r\n}\r\n\r\n.clickable:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.nav-btn {\r\n border: none;\r\n background: none;\r\n font-size: 20px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n cursor: pointer;\r\n padding: 4px 12px;\r\n border-radius: 4px;\r\n transition: background 0.2s;\r\n}\r\n\r\n.nav-btn:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.picker-body {\r\n padding: 8px;\r\n min-height: 200px;\r\n}\r\n\r\n.dual-calendar {\r\n display: flex;\r\n gap: 8px;\r\n}\r\n\r\n.calendar-divider {\r\n width: 1px;\r\n background: rgb(var(--v-theme-on-surface), 0.12);\r\n margin: 0 6px;\r\n}\r\n\r\n.calendar-panel {\r\n flex: 0 0 210px;\r\n width: 210px;\r\n min-width: 210px;\r\n max-width: 210px;\r\n}\r\n\r\n/* 单面板模式:放大以匹配底部范围显示的宽度 */\r\n.calendar-panel:only-child {\r\n flex: 0 0 340px;\r\n width: 340px;\r\n min-width: 340px;\r\n max-width: 340px;\r\n}\r\n\r\n.calendar-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 4px 0;\r\n margin-bottom: 4px;\r\n}\r\n\r\n.month-title {\r\n font-size: 12px;\r\n font-weight: 500;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.nav-btn-small {\r\n border: none;\r\n background: none;\r\n font-size: 14px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n cursor: pointer;\r\n padding: 2px 4px;\r\n border-radius: 4px;\r\n transition: background 0.2s;\r\n}\r\n\r\n.nav-btn-small:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.nav-btn-small.invisible {\r\n visibility: hidden;\r\n pointer-events: none;\r\n}\r\n\r\n.year-grid,\r\n.month-grid {\r\n display: grid;\r\n grid-template-columns: repeat(3, 1fr);\r\n gap: 6px;\r\n}\r\n\r\n.year-item,\r\n.month-item {\r\n padding: 6px;\r\n text-align: center;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n transition: all 0.2s;\r\n border: 1px solid transparent;\r\n color: rgb(var(--v-theme-on-surface));\r\n font-size: 12px;\r\n}\r\n\r\n.year-item:hover,\r\n.month-item:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.year-item.selected,\r\n.month-item.selected {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.year-item.in-range,\r\n.month-item.in-range {\r\n background: rgb(var(--v-theme-primary), 0.12);\r\n}\r\n\r\n/* 禁用状态样式 */\r\n.year-item.disabled,\r\n.month-item.disabled,\r\n.day-item.disabled {\r\n color: rgb(var(--v-theme-on-surface), 0.26) !important;\r\n background: rgb(var(--v-theme-on-surface), 0.04) !important;\r\n cursor: not-allowed !important;\r\n pointer-events: none;\r\n opacity: 0.5;\r\n}\r\n\r\n.year-item.disabled:hover,\r\n.month-item.disabled:hover,\r\n.day-item.disabled:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.04) !important;\r\n}\r\n\r\n.week-header {\r\n display: grid;\r\n grid-template-columns: repeat(7, 1fr);\r\n gap: 2px;\r\n margin-bottom: 6px;\r\n}\r\n\r\n.week-day {\r\n text-align: center;\r\n padding: 6px 0;\r\n font-size: 12px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-weight: 500;\r\n}\r\n\r\n.week-grid {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 4px;\r\n}\r\n\r\n.week-row {\r\n display: grid;\r\n grid-template-columns: 40px repeat(7, 1fr);\r\n gap: 4px;\r\n padding: 4px;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n transition: background 0.2s;\r\n}\r\n\r\n.week-row:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.week-row.selected {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.week-row.in-range {\r\n background: rgb(var(--v-theme-primary), 0.12);\r\n}\r\n\r\n.week-number {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n font-size: 12px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-weight: 500;\r\n}\r\n\r\n.day-grid {\r\n display: grid;\r\n grid-template-columns: repeat(7, 1fr);\r\n gap: 2px;\r\n}\r\n\r\n.day-item,\r\n.day-cell {\r\n aspect-ratio: 1;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n transition: all 0.2s;\r\n font-size: 13px;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.day-item:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.day-item.other-month,\r\n.day-cell.other-month {\r\n color: rgb(var(--v-theme-on-surface), 0.38);\r\n}\r\n\r\n.day-item.today,\r\n.day-cell.today {\r\n color: rgb(var(--v-theme-primary));\r\n font-weight: 600;\r\n}\r\n\r\n.day-item.selected {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.day-item.in-range {\r\n background: rgb(var(--v-theme-primary), 0.12);\r\n}\r\n\r\n.day-item.range-start,\r\n.day-item.range-end {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.range-display {\r\n padding: 12px 16px;\r\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n text-align: center;\r\n}\r\n\r\n.range-text {\r\n font-size: 14px;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.range-separator {\r\n margin: 0 8px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n}\r\n\r\n.placeholder-text {\r\n color: rgb(var(--v-theme-on-surface), 0.38);\r\n}\r\n\r\n.picker-footer {\r\n display: flex;\r\n justify-content: flex-end;\r\n gap: 8px;\r\n padding: 12px 16px;\r\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n}\r\n\r\n.btn {\r\n padding: 8px 16px;\r\n border-radius: 4px;\r\n font-size: 14px;\r\n cursor: pointer;\r\n transition: all 0.2s;\r\n border: none;\r\n outline: none;\r\n}\r\n\r\n.btn-text {\r\n background: none;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n}\r\n\r\n.btn-text:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.btn-primary {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.btn-primary:hover {\r\n opacity: 0.9;\r\n}\r\n</style>\r\n","<template>\n <div class=\"vtk-date-time-picker\">\n <VMenu\n v-if=\"!inline\"\n v-model=\"showPicker\"\n :attach=\"menuAttach\"\n :location=\"menuLocation\"\n :origin=\"menuOrigin\"\n :width=\"menuWidth\"\n :min-width=\"menuWidth\"\n offset=\"4\"\n :close-on-content-click=\"false\"\n >\n <template #activator=\"{ props: menuProps }\">\n <div class=\"date-time-input\">\n <VTextField\n :model-value=\"displayValue\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n density=\"compact\"\n variant=\"outlined\"\n hide-details\n readonly\n v-bind=\"menuProps\"\n :clearable=\"clearable && !!displayValue && !disabled\"\n clear-icon=\"mdi-close-circle\"\n persistent-clear\n class=\"date-time-input-field\"\n @click:clear.stop=\"clearValue\"\n >\n <template #append-inner>\n <VIcon size=\"16\" class=\"date-time-icon\">mdi-clock-outline</VIcon>\n </template>\n </VTextField>\n </div>\n </template>\n\n <div class=\"date-time-picker-dropdown\" :class=\"{ 'range-mode': isRange }\" @click.stop @mousedown.stop>\n <template v-if=\"isRange\">\n <div class=\"range-input-row\">\n <input class=\"range-date-input\" :value=\"formatDatePart(tempRange[0])\" readonly placeholder=\"开始日期\" />\n <button\n class=\"range-time-input\"\n type=\"button\"\n :class=\"{ active: activeTimeSide === 'start' }\"\n @click=\"openRangeTime('start')\"\n >\n {{ formatTimePart(tempRange[0]) || defaultStartTime }}\n </button>\n <span class=\"range-arrow\">›</span>\n <input class=\"range-date-input\" :value=\"formatDatePart(tempRange[1])\" readonly placeholder=\"结束日期\" />\n <button\n class=\"range-time-input\"\n type=\"button\"\n :class=\"{ active: activeTimeSide === 'end' }\"\n @click=\"openRangeTime('end')\"\n >\n {{ formatTimePart(tempRange[1]) || defaultEndTime }}\n </button>\n\n <div v-if=\"activeTimeSide\" :class=\"['range-time-popover', activeTimeSide]\">\n <div class=\"time-columns compact\">\n <div class=\"time-column\">\n <button\n v-for=\"hour in hourOptions\"\n :key=\"hour\"\n type=\"button\"\n :class=\"['time-item', { selected: hour === activeRangeHour }]\"\n @click=\"selectRangeTime('hour', hour)\"\n >\n {{ padTime(hour) }}\n </button>\n </div>\n <div class=\"time-column\">\n <button\n v-for=\"minute in minuteOptions\"\n :key=\"minute\"\n type=\"button\"\n :class=\"['time-item', { selected: minute === activeRangeMinute }]\"\n @click=\"selectRangeTime('minute', minute)\"\n >\n {{ padTime(minute) }}\n </button>\n </div>\n <div v-if=\"showSeconds\" class=\"time-column\">\n <button\n v-for=\"second in secondOptions\"\n :key=\"second\"\n type=\"button\"\n :class=\"['time-item', { selected: second === activeRangeSecond }]\"\n @click=\"selectRangeTime('second', second)\"\n >\n {{ padTime(second) }}\n </button>\n </div>\n </div>\n <div class=\"time-popover-footer\">\n <button class=\"btn btn-text small\" type=\"button\" @click=\"activeTimeSide = null\">取消</button>\n <button class=\"btn btn-primary small\" type=\"button\" @click=\"activeTimeSide = null\">确定</button>\n </div>\n </div>\n </div>\n\n <div class=\"range-calendar-shell\">\n <div class=\"calendar-panel\">\n <div class=\"calendar-header\">\n <button class=\"nav-btn-small\" type=\"button\" @click=\"prevLeftMonth\">‹</button>\n <span class=\"month-title\">{{ leftYear }} 年 {{ leftMonth + 1 }} 月</span>\n <button class=\"nav-btn-small invisible\" type=\"button\">›</button>\n </div>\n <div class=\"week-header\">\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\n </div>\n <div class=\"day-grid\">\n <button\n v-for=\"day in leftDayList\"\n :key=\"day.date\"\n type=\"button\"\n :class=\"rangeDayClass(day)\"\n @click=\"selectRangeDay(day)\"\n >\n {{ day.day }}\n </button>\n </div>\n </div>\n\n <div class=\"calendar-divider\"></div>\n\n <div class=\"calendar-panel\">\n <div class=\"calendar-header\">\n <button class=\"nav-btn-small invisible\" type=\"button\">‹</button>\n <span class=\"month-title\">{{ rightYear }} 年 {{ rightMonth + 1 }} 月</span>\n <button class=\"nav-btn-small\" type=\"button\" @click=\"nextRightMonth\">›</button>\n </div>\n <div class=\"week-header\">\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\n </div>\n <div class=\"day-grid\">\n <button\n v-for=\"day in rightDayList\"\n :key=\"day.date\"\n type=\"button\"\n :class=\"rangeDayClass(day)\"\n @click=\"selectRangeDay(day)\"\n >\n {{ day.day }}\n </button>\n </div>\n </div>\n </div>\n </template>\n\n <template v-else>\n <div class=\"single-input-row\">\n <input class=\"single-date-input\" :value=\"formatDatePart(tempDate)\" readonly placeholder=\"请选择日期\" />\n <button\n class=\"single-time-input\"\n type=\"button\"\n :class=\"{ active: activeSingleTime }\"\n @click=\"activeSingleTime = true\"\n >\n {{ singleTimeValue }}\n </button>\n\n <div v-if=\"activeSingleTime\" class=\"single-time-popover\">\n <div class=\"time-columns compact\">\n <div class=\"time-column\">\n <button\n v-for=\"hour in hourOptions\"\n :key=\"hour\"\n type=\"button\"\n :class=\"['time-item', { selected: hour === selectedHour, disabled: isTimePartDisabled(hour, selectedMinute, selectedSecond) }]\"\n @click=\"selectHour(hour)\"\n >\n {{ padTime(hour) }}\n </button>\n </div>\n <div class=\"time-column\">\n <button\n v-for=\"minute in minuteOptions\"\n :key=\"minute\"\n type=\"button\"\n :class=\"['time-item', { selected: minute === selectedMinute, disabled: isTimePartDisabled(selectedHour, minute, selectedSecond) }]\"\n @click=\"selectMinute(minute)\"\n >\n {{ padTime(minute) }}\n </button>\n </div>\n <div v-if=\"showSeconds\" class=\"time-column\">\n <button\n v-for=\"second in secondOptions\"\n :key=\"second\"\n type=\"button\"\n :class=\"['time-item', { selected: second === selectedSecond, disabled: isTimePartDisabled(selectedHour, selectedMinute, second) }]\"\n @click=\"selectSecond(second)\"\n >\n {{ padTime(second) }}\n </button>\n </div>\n </div>\n <div class=\"time-popover-footer\">\n <button class=\"btn btn-text small\" type=\"button\" @click=\"activeSingleTime = false\">取消</button>\n <button class=\"btn btn-primary small\" type=\"button\" @click=\"activeSingleTime = false\">确定</button>\n </div>\n </div>\n </div>\n\n <div class=\"single-calendar-panel\">\n <div class=\"picker-header single-header\">\n <button class=\"nav-btn\" type=\"button\" @click=\"prevPeriod\">‹</button>\n <div class=\"header-title\">\n <span class=\"clickable\" @click=\"changeViewMode('year')\">{{ currentYear }} 年</span>\n <span v-if=\"viewMode !== 'year'\" class=\"clickable\" @click=\"changeViewMode('month')\">\n {{ currentMonth + 1 }} 月\n </span>\n </div>\n <button class=\"nav-btn\" type=\"button\" @click=\"nextPeriod\">›</button>\n </div>\n\n <div v-if=\"viewMode === 'year'\" class=\"picker-body\">\n <div class=\"year-grid\">\n <button\n v-for=\"year in yearList\"\n :key=\"year\"\n type=\"button\"\n :class=\"['year-item', { selected: year === currentYear, disabled: isYearDisabled(year) }]\"\n @click=\"selectYear(year)\"\n >\n {{ year }}\n </button>\n </div>\n </div>\n\n <div v-else-if=\"viewMode === 'month'\" class=\"picker-body\">\n <div class=\"month-grid\">\n <button\n v-for=\"(month, index) in monthList\"\n :key=\"month\"\n type=\"button\"\n :class=\"['month-item', { selected: index === currentMonth, disabled: isMonthDisabled(index) }]\"\n @click=\"selectMonth(index)\"\n >\n {{ month }}\n </button>\n </div>\n </div>\n\n <div v-else class=\"picker-body\">\n <div class=\"week-header\">\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\n </div>\n <div class=\"day-grid\">\n <button\n v-for=\"day in dayList\"\n :key=\"day.date\"\n type=\"button\"\n :class=\"['day-item', {\n 'other-month': day.otherMonth,\n selected: isDaySelected(day),\n today: day.isToday,\n disabled: isDayDisabled(day)\n }]\"\n @click=\"selectDay(day)\"\n >\n {{ day.day }}\n </button>\n </div>\n </div>\n </div>\n </template>\n\n <div class=\"picker-footer\">\n <button v-if=\"!isRange\" class=\"btn btn-text\" type=\"button\" @click=\"handleNow\">此刻</button>\n <button v-if=\"isRange\" class=\"btn btn-text\" type=\"button\" @click=\"clearTempRange\">清空</button>\n <span class=\"footer-spacer\"></span>\n <button class=\"btn btn-text\" type=\"button\" @click=\"handleCancel\">取消</button>\n <button class=\"btn btn-primary\" type=\"button\" :disabled=\"!canConfirm\" @click=\"handleConfirm\">确定</button>\n </div>\n </div>\n </VMenu>\n\n <div v-if=\"inline\" class=\"date-time-picker-dropdown inline-mode\" :class=\"{ 'range-mode': isRange }\" @click.stop @mousedown.stop>\n <div class=\"inline-message\">内联模式请使用默认单选面板。</div>\n </div>\n </div>\n</template>\n\n<script setup>\nimport { computed, ref, watch } from 'vue';\n\ndefineOptions({\n name: 'VtkDateTimePicker',\n});\n\nconst props = defineProps({\n modelValue: {\n type: [String, Date, Number, Array],\n default: null\n },\n mode: {\n type: String,\n default: 'single',\n validator: (value) => ['single', 'range'].includes(value)\n },\n placeholder: {\n type: String,\n default: '请选择日期时间'\n },\n disabled: {\n type: Boolean,\n default: false\n },\n clearable: {\n type: Boolean,\n default: true\n },\n format: {\n type: String,\n default: 'YYYY-MM-DD HH:mm:ss'\n },\n valueFormat: {\n type: String,\n default: 'YYYY-MM-DD HH:mm:ss'\n },\n separator: {\n type: String,\n default: ' 至 '\n },\n min: {\n type: [String, Date, Number],\n default: null\n },\n max: {\n type: [String, Date, Number],\n default: null\n },\n disableFuture: {\n type: Boolean,\n default: false\n },\n minuteStep: {\n type: Number,\n default: 1\n },\n secondStep: {\n type: Number,\n default: 1\n },\n showSeconds: {\n type: Boolean,\n default: true\n },\n inline: {\n type: Boolean,\n default: false\n },\n placement: {\n type: String,\n default: 'left',\n validator: (value) => ['left', 'right'].includes(value)\n },\n noTeleport: {\n type: Boolean,\n default: false\n },\n onCancel: {\n type: Function,\n default: null\n },\n onConfirm: {\n type: Function,\n default: null\n }\n});\n\nconst emit = defineEmits(['update:modelValue', 'change', 'cancel', 'confirm']);\n\nconst showPicker = ref(false);\nconst selectedDateTime = ref(null);\nconst selectedRange = ref([]);\nconst tempDate = ref(null);\nconst tempRange = ref([null, null]);\nconst currentYear = ref(new Date().getFullYear());\nconst currentMonth = ref(new Date().getMonth());\nconst leftYear = ref(new Date().getFullYear());\nconst leftMonth = ref(new Date().getMonth());\nconst rightYear = ref(new Date().getMonth() === 11 ? new Date().getFullYear() + 1 : new Date().getFullYear());\nconst rightMonth = ref(new Date().getMonth() === 11 ? 0 : new Date().getMonth() + 1);\nconst viewMode = ref('day');\nconst selectedHour = ref(0);\nconst selectedMinute = ref(0);\nconst selectedSecond = ref(0);\nconst activeRangeSide = ref('start');\nconst activeTimeSide = ref(null);\nconst activeSingleTime = ref(false);\n\nconst weekDays = ['日', '一', '二', '三', '四', '五', '六'];\nconst monthList = ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'];\nconst defaultStartTime = '00:00:00';\nconst defaultEndTime = '23:59:59';\n\nconst isRange = computed(() => props.mode === 'range');\nconst menuAttach = computed(() => (props.noTeleport ? true : false));\nconst menuLocation = computed(() => props.placement === 'right' ? 'bottom end' : 'bottom start');\nconst menuOrigin = computed(() => props.placement === 'right' ? 'top end' : 'top start');\nconst menuWidth = computed(() => isRange.value ? 646 : 360);\nconst minDateTime = computed(() => parseValue(props.min));\nconst maxDateTime = computed(() => parseValue(props.max));\nconst hourOptions = computed(() => Array.from({ length: 24 }, (_, index) => index));\nconst minuteOptions = computed(() => buildStepOptions(props.minuteStep));\nconst secondOptions = computed(() => buildStepOptions(props.secondStep));\n\nconst yearList = computed(() => {\n const startYear = Math.floor(currentYear.value / 12) * 12;\n return Array.from({ length: 12 }, (_, index) => startYear + index);\n});\n\nconst dayList = computed(() => getDayList(currentYear.value, currentMonth.value));\nconst leftDayList = computed(() => getDayList(leftYear.value, leftMonth.value));\nconst rightDayList = computed(() => getDayList(rightYear.value, rightMonth.value));\n\nconst displayValue = computed(() => {\n if (isRange.value) {\n if (!selectedRange.value.length) return '';\n const [start, end] = selectedRange.value;\n return [start, end].filter(Boolean).map(date => formatByPattern(date, props.format)).join(props.separator);\n }\n return selectedDateTime.value ? formatByPattern(selectedDateTime.value, props.format) : '';\n});\n\nconst previewValue = computed(() => tempDate.value ? formatByPattern(buildTempDateTime(), props.format) : '');\nconst singleTimeValue = computed(() => {\n const pattern = props.showSeconds ? 'HH:mm:ss' : 'HH:mm';\n const date = buildTempDateTime() || new Date(2000, 0, 1, selectedHour.value, selectedMinute.value, selectedSecond.value);\n return formatByPattern(date, pattern);\n});\n\nconst canConfirm = computed(() => {\n if (isRange.value) {\n const [start, end] = tempRange.value;\n return !!start && !!end && start <= end && !isDateTimeDisabled(start) && !isDateTimeDisabled(end);\n }\n if (!tempDate.value) return false;\n return !isDateTimeDisabled(buildTempDateTime());\n});\n\nconst activeRangeDate = computed(() => {\n return activeTimeSide.value === 'end' ? tempRange.value[1] : tempRange.value[0];\n});\n\nconst activeRangeHour = computed(() => activeRangeDate.value ? activeRangeDate.value.getHours() : 0);\nconst activeRangeMinute = computed(() => activeRangeDate.value ? activeRangeDate.value.getMinutes() : 0);\nconst activeRangeSecond = computed(() => activeRangeDate.value ? activeRangeDate.value.getSeconds() : 0);\n\nconst buildStepOptions = (step) => {\n const normalizedStep = Number.isFinite(step) && step > 0 ? Math.max(1, Math.floor(step)) : 1;\n const options = [];\n for (let value = 0; value < 60; value += normalizedStep) {\n options.push(value);\n }\n return options;\n};\n\nconst getDayList = (year, month) => {\n const firstDay = new Date(year, month, 1);\n const startDay = firstDay.getDay();\n const daysInMonth = new Date(year, month + 1, 0).getDate();\n const daysInPrevMonth = new Date(year, month, 0).getDate();\n const today = new Date();\n const days = [];\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push(createDay(new Date(year, month - 1, daysInPrevMonth - index), true, today));\n }\n for (let day = 1; day <= daysInMonth; day += 1) {\n days.push(createDay(new Date(year, month, day), false, today));\n }\n for (let day = 1; days.length < 42; day += 1) {\n days.push(createDay(new Date(year, month + 1, day), true, today));\n }\n\n return days;\n};\n\nconst createDay = (date, otherMonth, today) => ({\n date: formatByPattern(date, 'YYYY-MM-DD'),\n day: date.getDate(),\n year: date.getFullYear(),\n month: date.getMonth(),\n otherMonth,\n isToday: isSameDate(date, today)\n});\n\nconst padTime = (value) => String(value).padStart(2, '0');\n\nconst formatByPattern = (date, pattern) => {\n if (!(date instanceof Date) || Number.isNaN(date.getTime())) return '';\n const replacements = {\n YYYY: date.getFullYear(),\n MM: padTime(date.getMonth() + 1),\n DD: padTime(date.getDate()),\n HH: padTime(date.getHours()),\n mm: padTime(date.getMinutes()),\n ss: padTime(date.getSeconds())\n };\n return Object.keys(replacements).reduce((result, token) => {\n return result.replace(new RegExp(token, 'g'), replacements[token]);\n }, pattern);\n};\n\nconst formatDatePart = (date) => date ? formatByPattern(date, 'YYYY-MM-DD') : '';\nconst formatTimePart = (date) => date ? formatByPattern(date, props.showSeconds ? 'HH:mm:ss' : 'HH:mm') : '';\n\nconst parseValue = (value) => {\n if (!value && value !== 0) return null;\n if (value instanceof Date) return Number.isNaN(value.getTime()) ? null : new Date(value.getTime());\n if (typeof value === 'number') {\n const date = new Date(value);\n return Number.isNaN(date.getTime()) ? null : date;\n }\n if (typeof value !== 'string') return null;\n\n const normalized = value.trim().replace(/\\//g, '-');\n const match = normalized.match(/^(\\d{4})-(\\d{1,2})-(\\d{1,2})(?:[ T](\\d{1,2}):(\\d{1,2})(?::(\\d{1,2}))?)?/);\n if (!match) {\n const fallback = new Date(value);\n return Number.isNaN(fallback.getTime()) ? null : fallback;\n }\n\n const [, year, month, day, hour = '0', minute = '0', second = '0'] = match;\n const date = new Date(Number(year), Number(month) - 1, Number(day), Number(hour), Number(minute), Number(second));\n return Number.isNaN(date.getTime()) ? null : date;\n};\n\nconst parseRangeValue = (value) => {\n if (Array.isArray(value)) return value.map(parseValue).filter(Boolean).slice(0, 2);\n if (typeof value === 'string' && value.includes(props.separator)) {\n return value.split(props.separator).map(item => parseValue(item.trim())).filter(Boolean).slice(0, 2);\n }\n return [];\n};\n\nconst toModelValue = (date) => {\n if (!date) return null;\n if (props.valueFormat === 'timestamp') return date.getTime();\n if (props.valueFormat === 'Date') return new Date(date.getTime());\n return formatByPattern(date, props.valueFormat);\n};\n\nconst toModelRange = (range) => range.map(date => toModelValue(date));\n\nconst isSameDate = (left, right) => {\n return left.getFullYear() === right.getFullYear()\n && left.getMonth() === right.getMonth()\n && left.getDate() === right.getDate();\n};\n\nconst buildTempDateTime = (hour = selectedHour.value, minute = selectedMinute.value, second = selectedSecond.value) => {\n if (!tempDate.value) return null;\n return new Date(tempDate.value.getFullYear(), tempDate.value.getMonth(), tempDate.value.getDate(), hour, minute, props.showSeconds ? second : 0);\n};\n\nconst isDateTimeDisabled = (date) => {\n if (!date) return true;\n if (minDateTime.value && date < minDateTime.value) return true;\n if (maxDateTime.value && date > maxDateTime.value) return true;\n if (props.disableFuture && date > new Date()) return true;\n return false;\n};\n\nconst isYearDisabled = (year) => {\n const start = new Date(year, 0, 1, 0, 0, 0);\n const end = new Date(year, 11, 31, 23, 59, 59);\n if (minDateTime.value && end < minDateTime.value) return true;\n if (maxDateTime.value && start > maxDateTime.value) return true;\n if (props.disableFuture && start > new Date()) return true;\n return false;\n};\n\nconst isMonthDisabled = (month) => {\n const start = new Date(currentYear.value, month, 1, 0, 0, 0);\n const end = new Date(currentYear.value, month + 1, 0, 23, 59, 59);\n if (minDateTime.value && end < minDateTime.value) return true;\n if (maxDateTime.value && start > maxDateTime.value) return true;\n if (props.disableFuture && start > new Date()) return true;\n return false;\n};\n\nconst isDayDisabled = (day) => {\n const start = new Date(day.year, day.month, day.day, 0, 0, 0);\n const end = new Date(day.year, day.month, day.day, 23, 59, 59);\n if (minDateTime.value && end < minDateTime.value) return true;\n if (maxDateTime.value && start > maxDateTime.value) return true;\n if (props.disableFuture && start > new Date()) return true;\n return false;\n};\n\nconst isTimePartDisabled = (hour, minute, second) => {\n if (!tempDate.value) return false;\n return isDateTimeDisabled(buildTempDateTime(hour, minute, second));\n};\n\nconst isDaySelected = (day) => {\n if (!tempDate.value) return false;\n return tempDate.value.getFullYear() === day.year\n && tempDate.value.getMonth() === day.month\n && tempDate.value.getDate() === day.day;\n};\n\nconst isRangeDaySelected = (day, side) => {\n const date = tempRange.value[side === 'start' ? 0 : 1];\n return !!date && date.getFullYear() === day.year && date.getMonth() === day.month && date.getDate() === day.day;\n};\n\nconst isRangeDayInRange = (day) => {\n const [start, end] = tempRange.value;\n if (!start || !end) return false;\n const date = new Date(day.year, day.month, day.day, 12, 0, 0);\n return date > start && date < end;\n};\n\nconst rangeDayClass = (day) => ['day-item', {\n 'other-month': day.otherMonth,\n today: day.isToday,\n disabled: isDayDisabled(day),\n selected: isRangeDaySelected(day, 'start') || isRangeDaySelected(day, 'end'),\n 'range-start': isRangeDaySelected(day, 'start'),\n 'range-end': isRangeDaySelected(day, 'end'),\n 'in-range': isRangeDayInRange(day)\n}];\n\nconst setSinglePanelFromDate = (date) => {\n if (!date) return;\n currentYear.value = date.getFullYear();\n currentMonth.value = date.getMonth();\n tempDate.value = new Date(date.getFullYear(), date.getMonth(), date.getDate());\n selectedHour.value = date.getHours();\n selectedMinute.value = date.getMinutes();\n selectedSecond.value = date.getSeconds();\n};\n\nconst setRangePanelsFromDate = (date) => {\n const base = date || new Date();\n leftYear.value = base.getFullYear();\n leftMonth.value = base.getMonth();\n const right = new Date(base.getFullYear(), base.getMonth() + 1, 1);\n rightYear.value = right.getFullYear();\n rightMonth.value = right.getMonth();\n};\n\nconst initializePicker = () => {\n if (isRange.value) {\n tempRange.value = selectedRange.value.length ? selectedRange.value.map(date => new Date(date.getTime())) : [null, null];\n setRangePanelsFromDate(tempRange.value[0] || new Date());\n activeRangeSide.value = tempRange.value[0] && !tempRange.value[1] ? 'end' : 'start';\n activeTimeSide.value = null;\n return;\n }\n setSinglePanelFromDate(selectedDateTime.value || new Date());\n viewMode.value = 'day';\n activeSingleTime.value = false;\n};\n\nconst prevPeriod = () => {\n if (viewMode.value === 'year') currentYear.value -= 12;\n else if (viewMode.value === 'month') currentYear.value -= 1;\n else if (currentMonth.value === 0) {\n currentMonth.value = 11;\n currentYear.value -= 1;\n } else currentMonth.value -= 1;\n};\n\nconst nextPeriod = () => {\n if (viewMode.value === 'year') currentYear.value += 12;\n else if (viewMode.value === 'month') currentYear.value += 1;\n else if (currentMonth.value === 11) {\n currentMonth.value = 0;\n currentYear.value += 1;\n } else currentMonth.value += 1;\n};\n\nconst prevLeftMonth = () => {\n const left = new Date(leftYear.value, leftMonth.value - 1, 1);\n leftYear.value = left.getFullYear();\n leftMonth.value = left.getMonth();\n const right = new Date(leftYear.value, leftMonth.value + 1, 1);\n rightYear.value = right.getFullYear();\n rightMonth.value = right.getMonth();\n};\n\nconst nextRightMonth = () => {\n const right = new Date(rightYear.value, rightMonth.value + 1, 1);\n rightYear.value = right.getFullYear();\n rightMonth.value = right.getMonth();\n const left = new Date(rightYear.value, rightMonth.value - 1, 1);\n leftYear.value = left.getFullYear();\n leftMonth.value = left.getMonth();\n};\n\nconst changeViewMode = (mode) => {\n viewMode.value = mode;\n};\n\nconst selectYear = (year) => {\n if (isYearDisabled(year)) return;\n currentYear.value = year;\n viewMode.value = 'month';\n};\n\nconst selectMonth = (month) => {\n if (isMonthDisabled(month)) return;\n currentMonth.value = month;\n viewMode.value = 'day';\n};\n\nconst selectDay = (day) => {\n if (isDayDisabled(day)) return;\n tempDate.value = new Date(day.year, day.month, day.day);\n};\n\nconst selectRangeDay = (day) => {\n if (isDayDisabled(day)) return;\n const selected = new Date(day.year, day.month, day.day);\n if (activeRangeSide.value === 'start' || !tempRange.value[0] || (tempRange.value[0] && tempRange.value[1])) {\n const currentStart = tempRange.value[0];\n selected.setHours(currentStart?.getHours() ?? 0, currentStart?.getMinutes() ?? 0, props.showSeconds ? currentStart?.getSeconds() ?? 0 : 0, 0);\n tempRange.value = [selected, null];\n activeRangeSide.value = 'end';\n } else {\n const currentEnd = tempRange.value[1];\n selected.setHours(currentEnd?.getHours() ?? 23, currentEnd?.getMinutes() ?? 59, props.showSeconds ? currentEnd?.getSeconds() ?? 59 : 0, 0);\n const start = tempRange.value[0];\n tempRange.value = start <= selected ? [start, selected] : [selected, start];\n activeRangeSide.value = 'start';\n }\n};\n\nconst selectHour = (hour) => {\n if (isTimePartDisabled(hour, selectedMinute.value, selectedSecond.value)) return;\n selectedHour.value = hour;\n};\n\nconst selectMinute = (minute) => {\n if (isTimePartDisabled(selectedHour.value, minute, selectedSecond.value)) return;\n selectedMinute.value = minute;\n};\n\nconst selectSecond = (second) => {\n if (isTimePartDisabled(selectedHour.value, selectedMinute.value, second)) return;\n selectedSecond.value = second;\n};\n\nconst openRangeTime = (side) => {\n activeTimeSide.value = side;\n activeRangeSide.value = side;\n const index = side === 'start' ? 0 : 1;\n if (!tempRange.value[index]) {\n const base = new Date();\n base.setHours(side === 'start' ? 0 : 23, side === 'start' ? 0 : 59, props.showSeconds ? side === 'start' ? 0 : 59 : 0, 0);\n tempRange.value[index] = base;\n }\n};\n\nconst selectRangeTime = (part, value) => {\n const index = activeTimeSide.value === 'end' ? 1 : 0;\n const fallback = new Date();\n const date = tempRange.value[index] ? new Date(tempRange.value[index].getTime()) : fallback;\n if (part === 'hour') date.setHours(value);\n if (part === 'minute') date.setMinutes(value);\n if (part === 'second') date.setSeconds(value);\n if (!props.showSeconds) date.setSeconds(0);\n date.setMilliseconds(0);\n tempRange.value[index] = date;\n};\n\nconst closePicker = () => {\n showPicker.value = false;\n activeSingleTime.value = false;\n};\n\nconst clearTempRange = () => {\n tempRange.value = [null, null];\n activeRangeSide.value = 'start';\n activeTimeSide.value = null;\n};\n\nconst clearValue = () => {\n if (isRange.value) {\n selectedRange.value = [];\n tempRange.value = [null, null];\n emit('update:modelValue', []);\n emit('change', []);\n } else {\n selectedDateTime.value = null;\n tempDate.value = null;\n emit('update:modelValue', null);\n emit('change', null);\n }\n};\n\nconst confirm = () => {\n if (!canConfirm.value) return;\n if (isRange.value) {\n selectedRange.value = tempRange.value.map(date => new Date(date.getTime()));\n const modelValue = toModelRange(selectedRange.value);\n emit('update:modelValue', modelValue);\n emit('change', modelValue);\n closePicker();\n return;\n }\n const nextValue = buildTempDateTime();\n selectedDateTime.value = nextValue;\n const modelValue = toModelValue(nextValue);\n emit('update:modelValue', modelValue);\n emit('change', modelValue);\n closePicker();\n};\n\nconst handleCancel = () => {\n if (props.onCancel) {\n props.onCancel();\n } else {\n emit('cancel');\n closePicker();\n }\n};\n\nconst handleConfirm = () => {\n const value = isRange.value ? toModelRange(tempRange.value) : toModelValue(buildTempDateTime());\n if (props.onConfirm) {\n props.onConfirm(value);\n } else {\n emit('confirm', value);\n confirm();\n }\n};\n\nconst handleNow = () => {\n const now = new Date();\n if (isDateTimeDisabled(now)) return;\n setSinglePanelFromDate(now);\n};\n\nwatch(showPicker, (isOpen) => {\n if (isOpen) initializePicker();\n});\n\nwatch(() => props.modelValue, (newValue) => {\n if (isRange.value) {\n selectedRange.value = parseRangeValue(newValue);\n } else {\n selectedDateTime.value = parseValue(newValue);\n }\n}, { immediate: true });\n</script>\n\n<style scoped>\n.vtk-date-time-picker {\n position: relative;\n width: 100%;\n}\n\n.date-time-input {\n width: 100%;\n}\n\n.date-time-input-field {\n cursor: pointer;\n}\n\n:deep(.date-time-input-field .v-field),\n:deep(.date-time-input-field input) {\n cursor: pointer;\n}\n\n.date-time-icon {\n margin-left: 8px;\n color: rgb(var(--v-theme-on-surface), 0.6);\n}\n\n.date-time-picker-dropdown {\n background: rgb(var(--v-theme-surface));\n border-radius: 4px;\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n overflow: visible;\n}\n\n.date-time-picker-dropdown.range-mode {\n width: 646px;\n min-width: 646px;\n max-width: 646px;\n}\n\n.date-time-picker-dropdown:not(.range-mode) {\n width: 360px;\n min-width: 360px;\n max-width: none;\n}\n\n.date-time-picker-dropdown.inline-mode {\n box-shadow: none;\n width: fit-content;\n border: none;\n}\n\n.picker-shell,\n.range-calendar-shell {\n display: flex;\n align-items: stretch;\n flex-wrap: nowrap;\n}\n\n.date-panel {\n width: 288px;\n border-right: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.calendar-panel {\n flex: 0 0 322px;\n width: 322px;\n min-width: 322px;\n max-width: 322px;\n padding: 12px 16px 16px;\n box-sizing: border-box;\n}\n\n.calendar-divider {\n flex: 0 0 1px;\n width: 1px;\n background: rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.picker-header,\n.calendar-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n\n.picker-header {\n padding: 12px 16px;\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.picker-header.single-header {\n border-bottom: none;\n padding: 14px 16px 8px;\n}\n\n.calendar-header {\n height: 36px;\n margin-bottom: 8px;\n}\n\n.header-title,\n.month-title {\n font-size: 16px;\n font-weight: 500;\n color: rgb(var(--v-theme-on-surface));\n}\n\n.clickable {\n cursor: pointer;\n padding: 4px 8px;\n border-radius: 4px;\n transition: background 0.2s;\n}\n\n.clickable:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.nav-btn,\n.nav-btn-small {\n border: none;\n background: none;\n color: rgb(var(--v-theme-on-surface), 0.6);\n cursor: pointer;\n border-radius: 4px;\n transition: background 0.2s;\n}\n\n.nav-btn {\n font-size: 20px;\n padding: 4px 12px;\n}\n\n.nav-btn-small {\n font-size: 18px;\n padding: 4px 8px;\n}\n\n.nav-btn:hover,\n.nav-btn-small:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.nav-btn-small.invisible {\n visibility: hidden;\n}\n\n.picker-body {\n padding: 10px 16px 16px;\n min-height: 250px;\n}\n\n.year-grid,\n.month-grid {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 8px;\n}\n\n.year-item,\n.month-item {\n height: 42px;\n border: 1px solid transparent;\n background: transparent;\n text-align: center;\n border-radius: 4px;\n cursor: pointer;\n transition: all 0.2s;\n color: rgb(var(--v-theme-on-surface));\n font-size: 13px;\n}\n\n.year-item:hover,\n.month-item:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.year-item.selected,\n.month-item.selected {\n background: rgb(var(--v-theme-primary));\n color: rgb(var(--v-theme-on-primary));\n}\n\n.week-header {\n display: grid;\n grid-template-columns: repeat(7, 1fr);\n gap: 2px;\n margin-bottom: 6px;\n}\n\n.week-day {\n text-align: center;\n padding: 6px 0;\n font-size: 12px;\n color: rgb(var(--v-theme-on-surface), 0.6);\n font-weight: 500;\n}\n\n.day-grid {\n display: grid;\n grid-template-columns: repeat(7, 1fr);\n gap: 2px;\n}\n\n.day-item {\n aspect-ratio: 1;\n border: 1px solid transparent;\n background: transparent;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 4px;\n cursor: pointer;\n transition: all 0.2s;\n font-size: 13px;\n color: rgb(var(--v-theme-on-surface));\n}\n\n.day-item:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.day-item.other-month {\n color: rgb(var(--v-theme-on-surface), 0.38);\n}\n\n.day-item.today {\n color: rgb(var(--v-theme-primary));\n font-weight: 600;\n}\n\n.day-item.selected,\n.day-item.range-start,\n.day-item.range-end {\n background: rgb(var(--v-theme-primary));\n color: rgb(var(--v-theme-on-primary));\n}\n\n.day-item.in-range {\n background: rgb(var(--v-theme-primary), 0.1);\n}\n\n.year-item.disabled,\n.month-item.disabled,\n.day-item.disabled,\n.time-item.disabled {\n color: rgb(var(--v-theme-on-surface), 0.26) !important;\n background: rgb(var(--v-theme-on-surface), 0.04) !important;\n cursor: not-allowed !important;\n pointer-events: none;\n opacity: 0.5;\n}\n\n.time-panel {\n width: 156px;\n}\n\n.time-header {\n height: 49px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 14px;\n font-weight: 500;\n color: rgb(var(--v-theme-on-surface));\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.time-columns {\n display: flex;\n height: 250px;\n}\n\n.time-columns.compact {\n height: 192px;\n}\n\n.time-column {\n flex: 1;\n overflow-y: auto;\n padding: 6px 0;\n border-right: 1px solid rgb(var(--v-theme-on-surface), 0.08);\n scrollbar-width: none;\n -ms-overflow-style: none;\n}\n\n.time-column::-webkit-scrollbar {\n width: 0;\n height: 0;\n}\n\n.time-column:last-child {\n border-right: none;\n}\n\n.time-item {\n width: 100%;\n height: 28px;\n border: none;\n background: transparent;\n color: rgb(var(--v-theme-on-surface));\n cursor: pointer;\n font-size: 13px;\n transition: all 0.2s;\n}\n\n.time-item:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.time-item.selected {\n color: rgb(var(--v-theme-primary));\n font-weight: 600;\n background: rgb(var(--v-theme-primary), 0.1);\n}\n\n.range-input-row {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n flex-wrap: nowrap;\n gap: 8px;\n padding: 8px 12px;\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n box-sizing: border-box;\n}\n\n.single-input-row {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 8px;\n padding: 9px 12px;\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n box-sizing: border-box;\n}\n\n.single-date-input,\n.single-time-input {\n flex: 0 0 auto;\n width: 150px;\n height: 32px;\n border: 1px solid rgb(var(--v-theme-on-surface), 0.16);\n border-radius: 4px;\n background: rgb(var(--v-theme-surface));\n color: rgb(var(--v-theme-on-surface));\n font-size: 13px;\n padding: 0 12px;\n outline: none;\n}\n\n.single-time-input {\n text-align: left;\n cursor: pointer;\n}\n\n.single-time-input.active,\n.single-time-input:focus,\n.single-date-input:focus {\n border-color: rgb(var(--v-theme-primary));\n}\n\n.single-calendar-panel {\n width: 360px;\n}\n\n.range-date-input,\n.range-time-input {\n flex: 0 0 auto;\n height: 32px;\n border: 1px solid rgb(var(--v-theme-on-surface), 0.16);\n border-radius: 4px;\n background: rgb(var(--v-theme-surface));\n color: rgb(var(--v-theme-on-surface));\n font-size: 13px;\n padding: 0 12px;\n outline: none;\n}\n\n.range-date-input {\n width: 144px;\n}\n\n.range-time-input {\n width: 132px;\n text-align: left;\n cursor: pointer;\n}\n\n.range-time-input.active,\n.range-time-input:focus,\n.range-date-input:focus {\n border-color: rgb(var(--v-theme-primary));\n}\n\n.range-arrow {\n flex: 0 0 16px;\n width: 16px;\n text-align: center;\n color: rgb(var(--v-theme-on-surface), 0.6);\n font-size: 22px;\n}\n\n.range-time-popover {\n position: absolute;\n top: 45px;\n width: 180px;\n z-index: 2;\n background: rgb(var(--v-theme-surface));\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n border-radius: 4px;\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\n}\n\n.single-time-popover {\n position: absolute;\n top: 45px;\n left: 156px;\n width: 180px;\n z-index: 2;\n background: rgb(var(--v-theme-surface));\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n border-radius: 4px;\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\n}\n\n.range-time-popover.start {\n left: 162px;\n}\n\n.range-time-popover.end {\n left: 430px;\n}\n\n.time-popover-footer {\n display: flex;\n justify-content: flex-end;\n gap: 8px;\n padding: 8px 10px;\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.selected-display {\n padding: 10px 16px;\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n text-align: center;\n}\n\n.selected-text {\n font-size: 14px;\n color: rgb(var(--v-theme-on-surface));\n}\n\n.placeholder-text,\n.inline-message {\n font-size: 14px;\n color: rgb(var(--v-theme-on-surface), 0.38);\n}\n\n.inline-message {\n padding: 16px;\n}\n\n.picker-footer {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 8px 10px;\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.footer-spacer {\n flex: 1;\n}\n\n.btn {\n padding: 8px 16px;\n border-radius: 4px;\n font-size: 14px;\n cursor: pointer;\n transition: all 0.2s;\n border: none;\n outline: none;\n}\n\n.btn.small {\n padding: 4px 8px;\n font-size: 12px;\n}\n\n.btn:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n.btn-text {\n background: none;\n color: rgb(var(--v-theme-primary));\n}\n\n.btn-text:hover:not(:disabled) {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.btn-primary {\n background: rgb(var(--v-theme-primary));\n color: rgb(var(--v-theme-on-primary));\n}\n\n.btn-primary:hover:not(:disabled) {\n opacity: 0.9;\n}\n</style>\n","<script setup>\r\nimport { ref, computed, reactive, onMounted, getCurrentInstance, watch, nextTick } from \"vue\";\r\nconst { proxy } = getCurrentInstance();\r\n// 获取配置的键名,如果没有配置则使用默认值\r\nconst userKey = window.VTK_CONFIG?.storageKeys?.user || '_mis_acis_users';\r\nconst user = JSON.parse(proxy.$vtk.storage.get(userKey));\r\n\r\nconsole.log('window.VTK_CONFIG=', window.VTK_CONFIG)\r\nconsole.log('window.VTK_CONFIG?.storageKeys?.user', window.VTK_CONFIG?.storageKeys?.user)\r\nconsole.log('user', user)\r\nconst pause = (ms) => new Promise((resolve) => setTimeout(resolve, ms));\r\n\r\n// 定义 props - 控制是否支持多选\r\nconst props = defineProps({\r\n multiple: {\r\n type: Boolean,\r\n default: false // 默认单选\r\n }\r\n});\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['selected']);\r\n\r\n// 定义响应式数据\r\nconst dialog = ref(false);\r\n\r\n\r\n// 地区列表\r\nconst areaData = ref([]);\r\nconst areaSelectedData = ref([]);\r\nconst areaActivatedData = ref([]);\r\n\r\nwatch(areaActivatedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.areaCode) {\r\n getDeptList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\nwatch(areaSelectedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.areaCode) {\r\n getDeptList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\n// 获取地区列表\r\nconst getAreaList = () => {\r\n if (user && user.areacode) {\r\n proxy.$vtk.request.getForm(`/dict/area/show/${user.areacode}`).then((res) => {\r\n console.log('res=', res);\r\n if (res && res.data) {\r\n areaData.value = [{\r\n areaCode: res.data.areaCode,\r\n areaName: res.data.areaName,\r\n children: []\r\n }];\r\n }\r\n });\r\n }\r\n};\r\n\r\n// 获取下级地区列表\r\nconst getAreaNextList = async (item) => {\r\n await pause(300);\r\n const parentCode = item.areaCode;\r\n proxy.$vtk.request.getForm(`/dict/area/next/${parentCode}`).then((res) => {\r\n if (res && res.data) {\r\n res.data.forEach((it) => {\r\n it.areaLeve < 12 && (it.children = []);\r\n item.children.push(it);\r\n });\r\n }\r\n });\r\n};\r\n\r\n// 部门列表\r\nconst deptData = ref([]);\r\nconst deptSelectedData = ref([]);\r\nconst deptActivatedData = ref([]);\r\n\r\nwatch(deptSelectedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.id) {\r\n getPersonList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\nwatch(deptActivatedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.id) {\r\n getPersonList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\n// 点击叶子节点时调用的方法\r\nconst getDeptList = (node) => {\r\n const selectAreaCode = node[0].areaCode;\r\n const params = { codex: { area: selectAreaCode, type: \"0\" } };\r\n deptData.value = [];\r\n proxy.$vtk.request.postJson('/bizp/supported/dept/list', params).then((res) => {\r\n res.data.forEach((it) => {\r\n it.children = [];\r\n deptData.value.push(it);\r\n });\r\n });\r\n};\r\n\r\nconst getDepNextList = async (item) => {\r\n await pause(300);\r\n const selectAreaCode = item.areaCode;\r\n const selectPid = item.id;\r\n const params = { codex: { area: selectAreaCode, pid: selectPid } };\r\n proxy.$vtk.request.postJson('/bizp/supported/dept/list', params).then((res) => {\r\n if (res && res.data) {\r\n res.data.forEach((it) => {\r\n it.children = [];\r\n item.children.push(it);\r\n });\r\n }\r\n });\r\n};\r\n\r\n// 人员列表\r\nconst personData = ref([]);\r\nconst selectedPersonData = ref([]);\r\n// 全局已选人员列表(跨部门保存,用于去重和持久化选中状态)\r\nconst allSelectedPersons = ref([]);\r\n// 标记是否正在恢复选中状态(避免触发 watch 循环)\r\nconst isRestoringSelection = ref(false);\r\n\r\n// 已选中的人员列表(用于右侧显示)- 去重后的列表\r\nconst selectedPersonList = computed(() => {\r\n // 使用 Map 去重,key 为人员 id\r\n const uniqueMap = new Map();\r\n allSelectedPersons.value.forEach(person => {\r\n if (person && person.id) {\r\n uniqueMap.set(person.id, person);\r\n }\r\n });\r\n\r\n return Array.from(uniqueMap.values());\r\n});\r\n\r\n// 监听当前部门选中人员的变化\r\nwatch(selectedPersonData, (newVal, oldVal) => {\r\n // 如果正在恢复选中状态,不处理\r\n if (isRestoringSelection.value) {\r\n return;\r\n }\r\n\r\n // 单选模式:直接替换全局列表\r\n if (!props.multiple) {\r\n if (newVal && newVal.length > 0) {\r\n // 单选模式下只保留最新选中的一个\r\n allSelectedPersons.value = [newVal[0]];\r\n } else {\r\n // 取消选中时清空\r\n allSelectedPersons.value = [];\r\n }\r\n return;\r\n }\r\n\r\n // 多选模式:累加到全局列表\r\n // 处理新选中的人员\r\n if (newVal && newVal.length > 0) {\r\n newVal.forEach(person => {\r\n const exists = allSelectedPersons.value.some(p => p.id === person.id);\r\n if (!exists) {\r\n allSelectedPersons.value.push(person);\r\n }\r\n });\r\n }\r\n\r\n // 处理取消选中的人员\r\n if (oldVal && oldVal.length > 0) {\r\n oldVal.forEach(oldPerson => {\r\n const stillSelected = newVal?.some(p => p.id === oldPerson.id);\r\n if (!stillSelected) {\r\n // 从全局列表中移除\r\n const index = allSelectedPersons.value.findIndex(p => p.id === oldPerson.id);\r\n if (index > -1) {\r\n allSelectedPersons.value.splice(index, 1);\r\n }\r\n }\r\n });\r\n }\r\n}, { deep: true });\r\n\r\n// 监听部门切换,同步选中状态\r\nwatch(personData, async (newPersonData) => {\r\n if (!newPersonData || newPersonData.length === 0) {\r\n isRestoringSelection.value = true;\r\n selectedPersonData.value = [];\r\n await nextTick();\r\n isRestoringSelection.value = false;\r\n return;\r\n }\r\n\r\n // 等待 DOM 更新\r\n await nextTick();\r\n\r\n // 标记正在恢复选中状态\r\n isRestoringSelection.value = true;\r\n\r\n // 当人员列表更新时,恢复之前选中的状态\r\n const currentSelected = [];\r\n newPersonData.forEach(person => {\r\n const isSelected = allSelectedPersons.value.some(p => p.id === person.id);\r\n if (isSelected) {\r\n currentSelected.push(person);\r\n }\r\n });\r\n\r\n selectedPersonData.value = currentSelected;\r\n\r\n // 等待状态更新完成\r\n await nextTick();\r\n isRestoringSelection.value = false;\r\n}, { deep: true });\r\n\r\n// 移除已选中的人员\r\nconst removeSelectedPerson = (personId) => {\r\n // 从全局列表中移除\r\n const globalIndex = allSelectedPersons.value.findIndex(person => person.id === personId);\r\n if (globalIndex > -1) {\r\n allSelectedPersons.value.splice(globalIndex, 1);\r\n }\r\n\r\n // 从当前显示的选中列表中移除\r\n const currentIndex = selectedPersonData.value.findIndex(person => person.id === personId);\r\n if (currentIndex > -1) {\r\n selectedPersonData.value.splice(currentIndex, 1);\r\n }\r\n};\r\n\r\n\r\n// 点击叶子节点时调用的方法\r\n// \r\nconst getPersonList = (node) => {\r\n const selectAreaID = node[0].id;\r\n const params = { codex: { dept: selectAreaID } };\r\n\r\n proxy.$vtk.request.postJson('/bizp/supported/user/list', params).then((res) => {\r\n if (res && res.meta.success && res.data.length > 0) {\r\n personData.value = res.data\r\n } else {\r\n personData.value = null\r\n }\r\n });\r\n};\r\nconst add = () => {\r\n dialog.value = true;\r\n};\r\n\r\nconst close = () => {\r\n // 先设置标记,避免触发 watch\r\n isRestoringSelection.value = true;\r\n\r\n // 关闭对话框\r\n dialog.value = false;\r\n\r\n // 清空选中状态\r\n selectedPersonData.value = [];\r\n allSelectedPersons.value = [];\r\n areaSelectedData.value = [];\r\n areaActivatedData.value = [];\r\n deptSelectedData.value = [];\r\n deptActivatedData.value = [];\r\n personData.value = [];\r\n deptData.value = [];\r\n\r\n // 重置标记\r\n nextTick(() => {\r\n isRestoringSelection.value = false;\r\n });\r\n};\r\n\r\n// 确认选择\r\nconst confirm = () => {\r\n // 返回选中的人员列表给父组件\r\n const selectedPersons = selectedPersonList.value;\r\n // 通过 emit 将选中的人员传递给父组件\r\n emit('selected', selectedPersons);\r\n close();\r\n};\r\n\r\nonMounted(() => {\r\n // 获取地区列表\r\n getAreaList();\r\n});\r\n\r\n// 使组件方法可以被父组件调用\r\ndefineExpose({\r\n close,\r\n add,\r\n});\r\n</script>\r\n\r\n<template>\r\n <v-dialog v-model=\"dialog\" persistent width=\"1000\">\r\n <v-card>\r\n <v-card-title class=\"d-flex align-center\">\r\n <span class=\"text-h6\">人员选择</span>\r\n <v-spacer></v-spacer>\r\n <v-btn class=\"g-no-shadow\" icon @click=\"close\" size=\"small\">\r\n <v-icon>mdi-close</v-icon>\r\n </v-btn>\r\n </v-card-title>\r\n <v-divider />\r\n <v-card-text class=\"pb-0 mb-0 pl-0 pr-0\" style=\"height: 600px;\">\r\n <v-row style=\"margin-top:-16px; height: 100%;\">\r\n <v-col md=\"3\" class=\"pr-0 \" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">地区</span>\r\n </v-card-title>\r\n <v-sheet height=\"500\" style=\"overflow: auto\" class=\"mt-2 pl-2\">\r\n <v-treeview item-value=\"id\" item-title=\"areaName\" return-object :items=\"areaData\" density=\"compact\"\r\n color=\"primary\" item-props activatable v-model:selected=\"areaSelectedData\"\r\n v-model:activated=\"areaActivatedData\" :load-children=\"getAreaNextList\">\r\n <template v-slot:title=\"{ item }\">\r\n <span :title=\"item.areaName\">{{ item.areaName }}</span>\r\n </template>\r\n </v-treeview>\r\n </v-sheet>\r\n </v-col>\r\n <v-col md=\"3\" class=\"pr-0 pl-0\" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">部门</span>\r\n </v-card-title>\r\n <v-sheet height=\"500\" style=\"overflow: auto\" class=\"mt-2 pl-2\">\r\n <v-treeview v-if=\"deptData && deptData.length > 0\" item-value=\"id\" item-title=\"name\" return-object :items=\"deptData\" density=\"compact\"\r\n color=\"primary\" item-props activatable v-model:selected=\"deptSelectedData\"\r\n v-model:activated=\"deptActivatedData\" :load-children=\"getDepNextList\">\r\n <template v-slot:title=\"{ item }\">\r\n <span :title=\"item.name\">{{ item.name }}</span>\r\n </template>\r\n </v-treeview>\r\n <div v-else class=\"text-center pt-4 d-flex flex-column align-center justify-center\">\r\n <v-icon size=\"64\" color=\"grey-lighten-2\" class=\"mb-4\">\r\n mdi-office-building-outline\r\n </v-icon>\r\n <div class=\"text-grey\">暂无</div>\r\n </div>\r\n </v-sheet>\r\n </v-col>\r\n <v-col md=\"3\" class=\"pr-0 pl-0\" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">人员</span>\r\n </v-card-title>\r\n <v-sheet height=\"550\" style=\"overflow: auto;\" class=\"mt-2\">\r\n <v-treeview v-if=\"personData && personData.length > 0\"\r\n item-value=\"id\"\r\n item-title=\"username\"\r\n return-object\r\n :items=\"personData\"\r\n density=\"compact\"\r\n color=\"primary\"\r\n item-props\r\n selectable\r\n :select-strategy=\"multiple ? 'leaf' : 'single-leaf'\"\r\n v-model:selected=\"selectedPersonData\">\r\n <template v-slot:title=\"{ item }\">\r\n <div class=\"d-flex align-center\" :title=\"item.username\">\r\n <v-avatar size=\"24\" class=\"mr-2\">\r\n <v-img v-if=\"item.avatar\" :src=\"item.avatar\"></v-img>\r\n <v-icon v-else size=\"20\">mdi-account-circle</v-icon>\r\n </v-avatar>\r\n <span>{{ item.username }}</span>\r\n </div>\r\n </template>\r\n </v-treeview>\r\n <div v-else class=\"text-center pt-4 d-flex flex-column align-center justify-center\">\r\n <v-icon size=\"64\" color=\"grey-lighten-2\" class=\"mb-4\">\r\n mdi-account-group\r\n </v-icon>\r\n <div class=\"text-grey\">暂无</div>\r\n </div>\r\n </v-sheet>\r\n </v-col>\r\n <v-col md=\"3\" class=\"pr-0 pl-0\" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">已选中人员 ({{ selectedPersonList.length }})</span>\r\n </v-card-title>\r\n <v-sheet height=\"550\" style=\"overflow: auto\" class=\"mt-2 px-2\">\r\n <v-list v-if=\"selectedPersonList.length > 0\" density=\"compact\">\r\n <v-list-item\r\n v-for=\"person in selectedPersonList\"\r\n :key=\"person.id\"\r\n :title=\"person.username\"\r\n class=\"px-2 mb-1 mr-2\"\r\n rounded=\"lg\"\r\n color=\"primary\"\r\n variant=\"tonal\">\r\n <template v-slot:prepend>\r\n <v-avatar size=\"32\">\r\n <v-img v-if=\"person.avatar\" :src=\"person.avatar\"></v-img>\r\n <v-icon v-else>mdi-account-circle</v-icon>\r\n </v-avatar>\r\n </template>\r\n <template v-slot:append>\r\n <v-btn\r\n icon\r\n size=\"x-small\"\r\n variant=\"text\"\r\n @click=\"removeSelectedPerson(person.id)\">\r\n <v-icon size=\"16\">mdi-close</v-icon>\r\n </v-btn>\r\n </template>\r\n </v-list-item>\r\n </v-list>\r\n <div v-else class=\"text-center pt-4 d-flex flex-column align-center justify-center\">\r\n <v-icon size=\"64\" color=\"grey-lighten-2\" class=\"mb-4\">\r\n mdi-account\r\n </v-icon>\r\n <div class=\"text-grey\">暂无选中</div>\r\n </div>\r\n </v-sheet>\r\n </v-col>\r\n </v-row>\r\n </v-card-text>\r\n <v-divider />\r\n <v-card-actions>\r\n <v-spacer></v-spacer>\r\n <v-btn color=\"darken-1\" text @click=\"close\">取消</v-btn>\r\n <v-btn color=\"blue darken-1\" text @click=\"confirm\">确定</v-btn>\r\n </v-card-actions>\r\n </v-card>\r\n </v-dialog>\r\n</template>\r\n\r\n<style scoped>\r\n:deep() .v-sheet[style*=\"overflow: auto\"] {\r\n &::-webkit-scrollbar {\r\n width: 5px;\r\n }\r\n\r\n &::-webkit-scrollbar-thumb {\r\n background: #ccc;\r\n border-radius: 4px;\r\n }\r\n}\r\n</style>","<!-- 空页面 -->\r\n<template>\r\n <v-empty-state\r\n :headline=\"headline\"\r\n :title=\"title\"\r\n :text=\"text\"\r\n :image=\"image\"\r\n :icon=\"icon\"\r\n :rounded=\"rounded\"\r\n :elevation=\"elevation\"\r\n >\r\n <!-- 图像插槽 -->\r\n <template v-if=\"$slots.media\" #media>\r\n <slot name=\"media\"></slot>\r\n </template>\r\n\r\n <!-- 标题插槽 -->\r\n <template v-if=\"$slots.title\" #title>\r\n <slot name=\"title\"></slot>\r\n </template>\r\n\r\n <!-- 文本插槽 -->\r\n <template v-if=\"$slots.text\" #text>\r\n <slot name=\"text\"></slot>\r\n </template>\r\n\r\n <!-- 操作按钮插槽 -->\r\n <template v-if=\"$slots.actions\" #actions>\r\n <slot name=\"actions\"></slot>\r\n </template>\r\n\r\n <!-- 底部插槽 -->\r\n <template v-if=\"$slots.bottom\" #bottom>\r\n <slot name=\"bottom\"></slot>\r\n </template>\r\n </v-empty-state>\r\n</template>\r\n\r\n<script setup>\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkEmpty\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // 标题\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n // 副标题/文本\r\n text: {\r\n type: String,\r\n default: ''\r\n },\r\n // 头部文本(更大字体)\r\n headline: {\r\n type: String,\r\n default: ''\r\n },\r\n // 图标\r\n icon: {\r\n type: String,\r\n default: ''\r\n },\r\n // 图像\r\n image: {\r\n type: String,\r\n default: ''\r\n },\r\n // 圆角\r\n rounded: {\r\n type: [Boolean, String, Number],\r\n default: 'circle'\r\n },\r\n // 阴影\r\n elevation: {\r\n type: [Number, String],\r\n default: 0\r\n }\r\n});\r\n</script>\r\n\r\n<style scoped>\r\n/* 可以添加自定义样式 */\r\n:deep(.v-empty-state) {\r\n padding: 24px;\r\n}\r\n\r\n:deep(.v-empty-state__media) {\r\n margin-bottom: 16px;\r\n}\r\n\r\n:deep(.v-empty-state__headline) {\r\n margin-bottom: 8px;\r\n}\r\n\r\n:deep(.v-empty-state__title) {\r\n margin-bottom: 8px;\r\n}\r\n\r\n:deep(.v-empty-state__actions) {\r\n margin-top: 16px;\r\n}\r\n</style>","<!-- 悬浮按钮 -->\r\n<template>\r\n <transition name=\"slide-up\">\r\n <v-fab\r\n v-if=\"showFab\"\r\n :class=\"fabClass\"\r\n color=\"primary\"\r\n icon=\"mdi-arrow-up\"\r\n @click=\"scrollToTop\"\r\n ></v-fab>\r\n </transition>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, onBeforeUnmount } from 'vue'\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkFab\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 控制悬浮按钮显示状态\r\nconst showFab = ref(false)\r\n// 自定义类名用于样式调整\r\nconst fabClass = ref('scroll-to-top-fab')\r\n\r\n// 监听滚动事件\r\nconst handleScroll = () => {\r\n showFab.value = window.scrollY > 100\r\n}\r\n\r\n// 滚动到顶部\r\nconst scrollToTop = () => {\r\n window.scrollTo({\r\n top: 0,\r\n behavior: 'smooth'\r\n })\r\n}\r\n\r\n// 组件挂载时添加滚动监听\r\nonMounted(() => {\r\n window.addEventListener('scroll', handleScroll)\r\n})\r\n\r\n// 组件卸载前移除监听\r\nonBeforeUnmount(() => {\r\n window.removeEventListener('scroll', handleScroll)\r\n})\r\n</script>\r\n\r\n<style scoped>\r\n.scroll-to-top-fab {\r\n position: fixed;\r\n bottom: 24px;\r\n right: 24px;\r\n z-index: 1004;\r\n}\r\n\r\n/* 滑动动画 */\r\n.slide-up-enter-active {\r\n transition: all 0.2s ease-out;\r\n}\r\n\r\n.slide-up-leave-active {\r\n transition: all 0.2s ease-in;\r\n}\r\n\r\n.slide-up-enter-from {\r\n opacity: 0;\r\n transform: translateY(30px);\r\n}\r\n\r\n.slide-up-leave-to {\r\n opacity: 0;\r\n transform: translateY(30px);\r\n}\r\n</style>","<template>\r\n <div\r\n class=\"box\"\r\n :class=\"{\r\n 'form-item--vertical': top,\r\n 'form-item--horizontal': !top\r\n }\"\r\n style=\"position: relative\"\r\n >\r\n <!-- label 在上方 (top模式) -->\r\n <div\r\n v-if=\"label && top\"\r\n class=\"pb-2 text-left\"\r\n >\r\n <span v-if=\"must\" class=\"text-red mr-1\">*</span>\r\n <span>{{ label }}</span>\r\n </div>\r\n\r\n <!-- label 在左侧 (默认模式) -->\r\n <div\r\n v-if=\"label && !top\"\r\n :class=\"left ? '' : 'vtk-width-2'\"\r\n class=\"d-inline-block text-right\"\r\n :style=\"Tstyle\"\r\n style=\"min-width: 120px !important;vertical-align: top;padding-top: 11px;\"\r\n >\r\n <span v-if=\"must\" class=\"text-red\">*</span>\r\n <span>{{ label }}</span>\r\n </div>\r\n\r\n <!-- 输入框容器 (top模式) -->\r\n <div\r\n v-if=\"top\"\r\n :style=\"contentStyles\"\r\n >\r\n <slot></slot>\r\n </div>\r\n\r\n <!-- 输入框容器 (默认模式) -->\r\n <div\r\n v-if=\"!top\"\r\n class=\"d-inline-block vtk-width-7 \"\r\n style=\"min-width: 350px;\"\r\n >\r\n <slot></slot>\r\n </div>\r\n\r\n <!-- help提示 (仅left模式) -->\r\n <div\r\n v-if=\"left && help && !top\"\r\n class=\"box_help tips py-3 px-4\"\r\n style=\"width: calc(30% - 160px)\"\r\n >\r\n <p class=\"mb-2 font-weight-bold text-body-1\">{{ label }}</p>\r\n <span v-html=\"help\"></span>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\n\r\n// 定义组件名称和选项\r\ndefineOptions({\r\n name: \"VtkFormItem\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n label: {\r\n type: String,\r\n default: null\r\n },\r\n must: {\r\n type: Boolean,\r\n default: false\r\n },\r\n left: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 标签在上方的垂直布局\r\n top: {\r\n type: Boolean,\r\n default: false\r\n },\r\n Tstyle: {\r\n type: String,\r\n default: null\r\n },\r\n help: {\r\n type: String,\r\n default: null\r\n },\r\n // 控制top模式下内容的最大宽度\r\n maxWidth: {\r\n type: [String, Number],\r\n default: '100%'\r\n }\r\n});\r\n\r\n// 处理maxWidth属性\r\nconst processedMaxWidth = computed(() => {\r\n if (typeof props.maxWidth === 'number') {\r\n return props.maxWidth + 'px';\r\n }\r\n return props.maxWidth;\r\n});\r\n\r\n// 内容样式(仅在top模式下应用maxWidth)\r\nconst contentStyles = computed(() => {\r\n const styles = {};\r\n\r\n // 在top模式下应用maxWidth\r\n if (props.top && props.maxWidth) {\r\n styles.maxWidth = processedMaxWidth.value;\r\n }\r\n\r\n return styles;\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.box:hover > .box_help {\r\n display: inline-block !important;\r\n border-top-right-radius: 24px;\r\n border-bottom-left-radius: 24px;\r\n}\r\n\r\n.box_help {\r\n display: none;\r\n}\r\n\r\n.tips {\r\n position: absolute;\r\n right: 8px;\r\n top: 0;\r\n border: 1px rgba(175, 175, 175, 0.341) solid;\r\n}\r\n\r\n.form-item--vertical {\r\n display: block;\r\n margin-bottom: 1rem;\r\n}\r\n\r\n.form-item--horizontal {\r\n display: block;\r\n margin-bottom: 0.5rem;\r\n}\r\n</style>\r\n","<template>\r\n <div class=\"vtk-img-container\">\r\n <VCard \r\n :class=\"['vtk-img-card', { 'vtk-img-card--preview': preview }]\"\r\n @click=\"openPreview\"\r\n >\r\n <v-img \r\n v-bind=\"$attrs\" \r\n :src=\"srcWithToken\"\r\n class=\"vtk-img\"\r\n :aspect-ratio=\"aspectRatio\"\r\n cover\r\n >\r\n <template v-slot:placeholder>\r\n <div class=\"d-flex align-center justify-center fill-height\">\r\n <v-progress-circular indeterminate color=\"grey-lighten-1\"></v-progress-circular>\r\n </div>\r\n </template>\r\n </v-img>\r\n \r\n <!-- 图片标题和描述 -->\r\n <div class=\"vtk-img-info\" v-if=\"showTitle || showDescription\">\r\n <VCardTitle v-if=\"showTitle\" class=\"vtk-img-title text-subtitle-2 pa-2\">\r\n {{ title }}\r\n </VCardTitle>\r\n <v-card-subtitle v-if=\"showDescription\" class=\"vtk-img-description text-caption pa-2\">\r\n {{ description }}\r\n </v-card-subtitle>\r\n </div>\r\n </VCard>\r\n \r\n <!-- 使用 v-dialog 的图片预览 -->\r\n <VDialog \r\n v-model=\"showPreview\" \r\n max-width=\"90%\" \r\n fullscreen\r\n @click:outside=\"closePreview\"\r\n >\r\n <VCard class=\"image-viewer-card\">\r\n <v-toolbar dark color=\"primary\">\n <v-toolbar-title>{{ currentImageTitle }}</v-toolbar-title>\n <VSpacer></VSpacer>\n <v-toolbar-items>\n <VBtn icon dark @click=\"zoomImage(-0.3)\">\r\n <VIcon>mdi-magnify-minus-outline</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"zoomImage(0.3)\">\r\n <VIcon>mdi-magnify-plus-outline</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"rotateImage(-90)\">\r\n <VIcon>mdi-rotate-left</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"rotateImage(90)\">\r\n <VIcon>mdi-rotate-right</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"resetImageTransform\">\n <VIcon>mdi-refresh</VIcon>\n </VBtn>\n <VBtn icon dark @click=\"closePreview\">\n <VIcon>mdi-close</VIcon>\n </VBtn>\n </v-toolbar-items>\n </v-toolbar>\n \r\n <div class=\"image-viewer-content\">\r\n <VBtn \r\n v-if=\"hasPrev\" \r\n icon \r\n class=\"nav-button prev-button\" \r\n @click=\"prevImage\"\r\n >\r\n <VIcon>mdi-chevron-left</VIcon>\r\n </VBtn>\r\n \r\n <div class=\"image-container\" @wheel.prevent=\"handleImageWheel\">\r\n <v-img\r\n :src=\"currentImageUrl\"\r\n class=\"viewer-image\"\r\n :class=\"{ 'viewer-image--draggable': imageScale > 1 }\"\r\n :style=\"viewerImageStyle\"\r\n draggable=\"false\"\r\n @pointerdown=\"startImageDrag\"\r\n />\r\n </div>\r\n \r\n <VBtn \r\n v-if=\"hasNext\" \r\n icon \r\n class=\"nav-button next-button\" \r\n @click=\"nextImage\"\r\n >\r\n <VIcon>mdi-chevron-right</VIcon>\r\n </VBtn>\r\n </div>\r\n \r\n <div class=\"image-info\">\r\n <p class=\"text-center\">{{ currentImageDescription }}</p>\r\n <p class=\"text-center text--secondary\">{{ currentIndex + 1 }} / {{ imageList.length }}</p>\r\n </div>\r\n </VCard>\r\n </VDialog>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch } from 'vue';\r\n\r\ndefineOptions({\r\n name: 'VtkImg',\r\n inheritAttrs: true\r\n});\r\n\r\nconst props = defineProps({\r\n src: {\r\n type: String,\r\n default: null,\r\n },\r\n error: {\r\n type: String,\r\n default: new URL('../../assets/img/wxsq.png', import.meta.url).href,\r\n },\r\n preview: {\r\n type: Boolean,\r\n default: true\r\n },\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n description: {\r\n type: String,\r\n default: ''\r\n },\r\n // 图片列表,用于导航功能\r\n imageList: {\r\n type: Array,\r\n default: () => []\r\n },\r\n // 当前图片索引\r\n index: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 是否显示标题\r\n showTitle: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 是否显示描述\r\n showDescription: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 图片宽高比\r\n aspectRatio: {\r\n type: [String, Number],\r\n default: 16/9\r\n }\r\n});\r\n\r\n// 预览状态\r\nconst showPreview = ref(false);\r\n// 图片旋转角度\r\nconst imageRotation = ref(0);\r\n// 图片缩放和拖动位置\r\nconst imageScale = ref(1);\r\nconst imageTranslateX = ref(0);\r\nconst imageTranslateY = ref(0);\r\nconst imageDragState = ref(null);\r\n// 当前图片索引(预览模式下使用)\r\nconst currentIndex = ref(0);\r\n\r\n// 使用计算属性处理带token的URL\r\nconst srcWithToken = computed(() => {\r\n if (!props.src) return props.src;\r\n \r\n try {\r\n // 首先尝试使用 $vtk.storage\r\n if (window.$vtk && typeof window.$vtk.storage?.get === 'function') {\r\n const token = window.$vtk.storage.get('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n // 如果 $vtk 不存在,尝试从 localStorage 获取 token\r\n else {\r\n const token = localStorage.getItem('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n } catch (error) {\r\n // 发生错误时返回原始src\r\n console.warn('VtkImg: Failed to get token, using src without token', error);\r\n return props.src;\r\n }\r\n});\r\n\r\n// 当前预览图片的URL\r\nconst currentImageUrl = computed(() => {\r\n if (props.imageList.length > 0 && currentIndex.value < props.imageList.length) {\r\n const currentImage = props.imageList[currentIndex.value];\r\n if (currentImage && currentImage.url) {\r\n try {\r\n // 为图片列表中的图片也添加token\r\n if (window.$vtk && typeof window.$vtk.storage?.get === 'function') {\r\n const token = window.$vtk.storage.get('_mis_acis_token');\r\n return token ? `${currentImage.url}?stoken=${token}` : currentImage.url;\r\n } else {\r\n const token = localStorage.getItem('_mis_acis_token');\r\n return token ? `${currentImage.url}?stoken=${token}` : currentImage.url;\r\n }\r\n } catch (error) {\r\n return currentImage.url;\r\n }\r\n }\r\n }\r\n return srcWithToken.value;\r\n});\r\n\r\n// 当前图片标题\r\nconst currentImageTitle = computed(() => {\r\n if (props.imageList.length > 0 && currentIndex.value < props.imageList.length) {\r\n const currentImage = props.imageList[currentIndex.value];\r\n return currentImage?.title || '';\r\n }\r\n return props.title;\r\n});\r\n\r\n// 当前图片描述\r\nconst currentImageDescription = computed(() => {\r\n if (props.imageList.length > 0 && currentIndex.value < props.imageList.length) {\r\n const currentImage = props.imageList[currentIndex.value];\r\n return currentImage?.description || '';\r\n }\r\n return props.description;\r\n});\r\n\r\n// 是否有上一张图片\r\nconst hasPrev = computed(() => {\r\n return props.imageList.length > 1 && currentIndex.value > 0;\r\n});\r\n\r\n// 是否有下一张图片\r\nconst hasNext = computed(() => {\r\n return props.imageList.length > 1 && currentIndex.value < props.imageList.length - 1;\r\n});\r\n\r\nconst viewerImageStyle = computed(() => ({\r\n transform: `translate(${imageTranslateX.value}px, ${imageTranslateY.value}px) scale(${imageScale.value}) rotate(${imageRotation.value}deg)`,\r\n}));\r\n\r\nconst resetImageTransform = () => {\r\n imageRotation.value = 0;\r\n imageScale.value = 1;\r\n imageTranslateX.value = 0;\r\n imageTranslateY.value = 0;\r\n imageDragState.value = null;\r\n};\r\n\r\n// 监听预览状态变化\r\nwatch(showPreview, (newVal) => {\r\n if (newVal) {\r\n // 打开预览时重置旋转角度和当前索引\r\n resetImageTransform();\r\n currentIndex.value = props.index;\r\n }\r\n});\r\n\r\n// 打开预览\r\nconst openPreview = () => {\r\n if (props.preview) {\r\n showPreview.value = true;\r\n }\r\n};\r\n\r\n// 关闭预览\r\nconst closePreview = () => {\r\n showPreview.value = false;\r\n};\r\n\r\n// 上一张图片\r\nconst prevImage = () => {\r\n if (hasPrev.value) {\r\n currentIndex.value--;\r\n resetImageTransform();\r\n }\r\n};\r\n\r\n// 下一张图片\r\nconst nextImage = () => {\r\n if (hasNext.value) {\r\n currentIndex.value++;\r\n resetImageTransform();\r\n }\r\n};\r\n\r\n// 旋转图片\r\nconst rotateImage = (degrees) => {\r\n imageRotation.value += degrees;\r\n};\r\n\r\nconst zoomImage = (step) => {\r\n const nextScale = Number((imageScale.value + step).toFixed(2));\r\n imageScale.value = Math.min(3, Math.max(0.2, nextScale));\r\n if (imageScale.value <= 1) {\r\n imageTranslateX.value = 0;\r\n imageTranslateY.value = 0;\r\n }\r\n};\r\n\r\nconst handleImageWheel = (event) => {\r\n zoomImage(event.deltaY < 0 ? 0.2 : -0.2);\r\n};\r\n\r\nconst startImageDrag = (event) => {\r\n if (imageScale.value <= 1) return;\r\n event.preventDefault();\r\n const target = event.currentTarget;\r\n imageDragState.value = {\r\n pointerId: event.pointerId,\r\n startX: event.clientX,\r\n startY: event.clientY,\r\n translateX: imageTranslateX.value,\r\n translateY: imageTranslateY.value,\r\n };\r\n target.setPointerCapture?.(event.pointerId);\r\n target.addEventListener('pointermove', moveImageDrag);\r\n target.addEventListener('pointerup', endImageDrag, { once: true });\r\n target.addEventListener('pointercancel', endImageDrag, { once: true });\r\n};\r\n\r\nconst moveImageDrag = (event) => {\r\n const state = imageDragState.value;\r\n if (!state || state.pointerId !== event.pointerId) return;\r\n imageTranslateX.value = state.translateX + event.clientX - state.startX;\r\n imageTranslateY.value = state.translateY + event.clientY - state.startY;\r\n};\r\n\r\nconst endImageDrag = (event) => {\r\n event.currentTarget?.releasePointerCapture?.(event.pointerId);\r\n event.currentTarget?.removeEventListener('pointermove', moveImageDrag);\r\n imageDragState.value = null;\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-img-container {\r\n position: relative;\r\n display: inline-block;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.vtk-img-card {\r\n height: 100%;\r\n}\r\n\r\n.vtk-img-card--preview {\r\n cursor: pointer;\r\n transition: transform 0.2s ease-in-out;\r\n}\r\n\r\n.vtk-img-card--preview:hover {\r\n transform: translateY(-5px);\r\n}\r\n\r\n.vtk-img {\r\n width: 100%;\r\n}\r\n\r\n.vtk-img-info {\r\n padding: 0;\r\n}\r\n\r\n.vtk-img-title {\r\n word-break: break-word;\r\n}\r\n\r\n.vtk-img-description {\r\n word-break: break-word;\r\n}\r\n\r\n/* 图片查看器样式 */\r\n.image-viewer-card {\r\n background-color: rgba(0, 0, 0, 0.9);\r\n color: white;\r\n}\r\n\r\n.image-viewer-content {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: calc(100vh - 150px);\r\n position: relative;\r\n}\r\n\r\n.image-container {\r\n flex: 1;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n overflow: hidden;\r\n}\r\n\r\n.viewer-image {\r\n max-width: 90%;\r\n max-height: 80vh;\r\n transform-origin: center center;\r\n transition: transform 0.3s ease;\r\n user-select: none;\r\n touch-action: none;\r\n}\r\n\r\n.viewer-image--draggable {\r\n cursor: grab;\r\n}\r\n\r\n.viewer-image--draggable:active {\r\n cursor: grabbing;\r\n}\r\n\r\n.nav-button {\r\n position: absolute;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n z-index: 10;\r\n background-color: rgba(0, 0, 0, 0.5);\r\n color: white;\r\n width: 50px;\r\n height: 50px;\r\n}\r\n\r\n.prev-button {\r\n left: 20px;\r\n}\r\n\r\n.next-button {\r\n right: 20px;\r\n}\r\n\r\n.image-info {\r\n padding: 20px;\r\n background-color: rgba(0, 0, 0, 0.7);\r\n}\r\n\r\n.image-info p {\r\n margin: 5px 0;\r\n}\r\n\r\n:deep(.v-img__img) {\r\n background: v-bind('props.error') no-repeat center;\r\n background-size: cover;\r\n}\r\n\r\n:deep(.v-img__placeholder) {\r\n filter: blur(0px);\r\n}\r\n</style>\r\n","<template>\r\n <div class=\"m_pagination\">\r\n <VRow v-if=\"pageDatas.rowCount > 0\" class=\"pagination box\" align=\"center\">\r\n <span class=\"page-total d-none d-md-flex align-center\">共{{ pageDatas.rowCount }}条</span>\r\n <VSelect\r\n v-model=\"pagination.limit\"\r\n :items=\"pageSizeObjs\"\r\n variant=\"outlined\"\r\n density=\"compact\"\r\n :menu-props=\"{ offsetY: true }\"\r\n hide-details\r\n class=\"page-select ml-2 d-none d-md-flex\"\r\n @update:model-value=\"pageSizeChange()\"\r\n />\r\n <span class=\"my-2\">\r\n <v-pagination\r\n v-model=\"pageDatas.pageno\"\r\n :total-visible=\"5\"\r\n :length=\"pageDatas.pageCount\"\r\n size=\"small\"\r\n @update:model-value=\"pageChange()\"\r\n />\r\n </span>\r\n <span class=\"page-total ml-3 d-none d-md-flex align-center\">到</span>\r\n <VTextField\r\n v-model=\"pagination.pageno\"\r\n variant=\"outlined\"\r\n density=\"compact\"\r\n hide-details\r\n class=\"page-go ml-2 d-none d-md-flex\"\r\n @keyup.enter=\"toPage()\"\r\n />\r\n <span class=\"page-total ml-2 d-none d-md-flex align-center\">页</span>\r\n </VRow>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, reactive, computed, watch, onMounted } from 'vue';\r\n\r\nconst props = defineProps({\r\n pageData: {\r\n type: Object,\r\n default: () => ({})\r\n },\r\n pageSizes: {\r\n type: Array,\r\n default: () => [10, 20, 30]\r\n }\r\n});\r\n\r\nconst emit = defineEmits(['pageChange']);\r\n\r\nconst pagination = reactive({\r\n pageno: 1,\r\n limit: 10\r\n});\r\n\r\nconst pageSizeObjs = ref([]);\r\nconst pageDatas = ref({ ...props.pageData });\r\n\r\nconst paginationChange = computed(() => pageDatas.value.pageno);\r\n\r\nwatch(paginationChange, () => {\r\n pagination.pageno = pageDatas.value.pageno;\r\n});\r\n\r\nwatch(() => props.pageData, (newVal) => {\r\n pageDatas.value = { ...newVal };\r\n if (newVal.rowCount < 1 && newVal.rows > 0) {\r\n pageDatas.value.pageno = newVal.pageno - 1;\r\n pageChange();\r\n }\r\n}, { deep: true });\r\n\r\nonMounted(() => {\r\n pageSizeFormat();\r\n});\r\n\r\nconst toPage = () => {\r\n const re = /^[0-9]+$/;\r\n if (re.test(pagination.pageno) && pagination.pageno <= pageDatas.value.pageCount) {\r\n pageDatas.value.pageno = parseInt(pagination.pageno);\r\n pageChange();\r\n } else {\r\n pagination.pageno = pageDatas.value.pageno;\r\n }\r\n};\r\n\r\nconst pageSizeChange = () => {\r\n pageDatas.value.pageCount = 1;\r\n pageChange();\r\n};\r\n\r\nconst pageSizeFormat = () => {\r\n const temp = props.pageSizes;\r\n temp.forEach((value) => {\r\n const obj = {\r\n title: value + \"条/页\",\r\n value: value\r\n };\r\n pageSizeObjs.value.push(obj);\r\n });\r\n pagination.limit = temp[0];\r\n};\r\n\r\nconst pageChange = () => {\r\n const page = {\r\n pageno: pageDatas.value.pageno,\r\n limit: pagination.limit\r\n };\r\n emit('pageChange', page);\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.mt-1 {\r\n margin-top: 11px !important;\r\n}\r\n.my-5 {\r\n margin-top: 20px !important;\r\n margin-bottom: 20px !important;\r\n}\r\n.m_pagination {\r\n width: 100%;\r\n min-height: 52px;\r\n display: flex;\r\n align-items: center;\r\n .box {\r\n position: absolute;\r\n right: 32px;\r\n }\r\n}\r\n.page-total {\r\n display: flex;\r\n align-items: center;\r\n height: 36px;\r\n font-size: 13px;\r\n padding-top: 4px;\r\n}\r\n.page-select {\r\n padding-top: 4px;\r\n max-width: 115px;\r\n :deep(.v-input__control) {\r\n min-height: 36px !important;\r\n height: 36px !important;\r\n }\r\n :deep(.v-field) {\r\n height: 36px !important;\r\n font-size: 13px !important;\r\n }\r\n :deep(.v-field__input) {\r\n padding-top: 6px !important;\r\n padding-bottom: 6px !important;\r\n min-height: 36px !important;\r\n }\r\n}\r\n.page-go {\r\n max-width: 75px;\r\n :deep(.v-input__control) {\r\n min-height: 36px !important;\r\n height: 36px !important;\r\n }\r\n :deep(.v-field) {\r\n height: 36px !important;\r\n font-size: 13px !important;\r\n }\r\n :deep(.v-field__input) {\r\n padding-top: 6px !important;\r\n padding-bottom: 6px !important;\r\n min-height: 36px !important;\r\n }\r\n}\r\n\r\n// 分页按钮缩小\r\n.my-2 {\r\n :deep(.v-pagination__item),\r\n :deep(.v-pagination__prev),\r\n :deep(.v-pagination__next) {\r\n min-width: 32px !important;\r\n height: 36px !important;\r\n font-size: 13px !important;\r\n }\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-pdf-container\">\r\n <VCard \r\n :class=\"['vtk-pdf-card', { 'vtk-pdf-card--preview': preview }]\"\r\n @click=\"openPreview\"\r\n >\r\n <!-- PDF封面或默认图标 -->\r\n <div class=\"vtk-pdf-cover\" :style=\"{ aspectRatio: aspectRatio }\">\r\n <VIcon size=\"48\" color=\"red\">mdi-file-pdf-box</VIcon>\r\n <div class=\"vtk-pdf-label\">PDF</div>\r\n </div>\r\n \r\n <!-- PDF标题和描述 -->\r\n <div class=\"vtk-pdf-info\" v-if=\"showTitle || showDescription\">\r\n <VCardTitle v-if=\"showTitle\" class=\"vtk-pdf-title text-subtitle-2 pa-2\">\r\n {{ title }}\r\n </VCardTitle>\r\n <v-card-subtitle v-if=\"showDescription\" class=\"vtk-pdf-description text-caption pa-2\">\r\n {{ description }}\r\n </v-card-subtitle>\r\n </div>\r\n </VCard>\r\n \r\n <!-- 使用 v-dialog 的PDF预览 -->\r\n <VDialog \r\n v-model=\"showPreview\" \r\n max-width=\"90%\" \r\n fullscreen\r\n @click:outside=\"closePreview\"\r\n >\r\n <VCard class=\"pdf-viewer-card\">\r\n <v-toolbar dark color=\"red darken-1\">\r\n <VBtn icon dark @click=\"closePreview\">\r\n <VIcon>mdi-close</VIcon>\r\n </VBtn>\r\n <v-toolbar-title>{{ title }}</v-toolbar-title>\r\n <VSpacer></VSpacer>\r\n <v-toolbar-items>\r\n <VBtn icon dark @click=\"downloadPdf\">\r\n <VIcon>mdi-download</VIcon>\r\n </VBtn>\r\n </v-toolbar-items>\r\n </v-toolbar>\r\n \r\n <div class=\"pdf-viewer-content\">\r\n <div class=\"pdf-container\" ref=\"pdfContainer\">\r\n <!-- PDF内容将通过PDF.js渲染 -->\r\n <div id=\"pdf-viewer\"></div>\r\n </div>\r\n </div>\r\n \r\n <div class=\"pdf-viewer-footer\" v-if=\"pdfLoaded\">\r\n <VRow align=\"center\" justify=\"center\">\r\n <VCol cols=\"12\" sm=\"6\" class=\"d-flex justify-center\">\r\n <VBtn icon @click=\"prevPage\" :disabled=\"currentPage <= 1\">\r\n <VIcon>mdi-chevron-left</VIcon>\r\n </VBtn>\r\n <div class=\"mx-4\">\r\n <span>第 {{ currentPage }} 页 / 共 {{ pageCount }} 页</span>\r\n </div>\r\n <VBtn icon @click=\"nextPage\" :disabled=\"currentPage >= pageCount\">\r\n <VIcon>mdi-chevron-right</VIcon>\r\n </VBtn>\r\n </VCol>\r\n <VCol cols=\"12\" sm=\"6\" class=\"d-flex justify-center\">\r\n <VSlider\r\n v-model=\"currentPage\"\r\n :min=\"1\"\r\n :max=\"pageCount\"\r\n hide-details\r\n class=\"mx-4\"\r\n ></VSlider>\r\n </VCol>\r\n </VRow>\r\n </div>\r\n \r\n <div class=\"pdf-loading\" v-if=\"loading\">\r\n <v-progress-circular indeterminate color=\"red\"></v-progress-circular>\r\n <p class=\"mt-2\">正在加载PDF...</p>\r\n </div>\r\n </VCard>\r\n </VDialog>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, onMounted, onBeforeUnmount } from 'vue';\r\n// import * as pdfjsLib from 'pdfjs-dist';\r\n// 注意:在实际项目中,您需要安装 pdfjs-dist 库\r\n// npm install pdfjs-dist\r\n// import * as pdfjsLib from 'pdfjs-dist';\r\n\r\ndefineOptions({\r\n name: 'VtkPdf',\r\n inheritAttrs: true\r\n});\r\n\r\nconst props = defineProps({\r\n src: {\r\n type: String,\r\n default: null,\r\n },\r\n preview: {\r\n type: Boolean,\r\n default: true\r\n },\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n description: {\r\n type: String,\r\n default: ''\r\n },\r\n // 是否显示标题\r\n showTitle: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 是否显示描述\r\n showDescription: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 封面宽高比\r\n aspectRatio: {\r\n type: [String, Number],\r\n default: 16/9\r\n }\r\n});\r\n\r\n// 预览状态\r\nconst showPreview = ref(false);\r\n// PDF相关状态\r\nconst loading = ref(false);\r\nconst pdfLoaded = ref(false);\r\nconst currentPage = ref(1);\r\nconst pageCount = ref(0);\r\nconst pdfContainer = ref(null);\r\n\r\n// PDF对象(实际使用时需要引入pdfjsLib)\r\nlet pdfDoc = null;\r\n\r\n// 使用计算属性处理带token的URL\r\nconst srcWithToken = computed(() => {\r\n if (!props.src) return props.src;\r\n \r\n try {\r\n // 首先尝试使用 $vtk.storage\r\n if (window.$vtk && typeof window.$vtk.storage?.get === 'function') {\r\n const token = window.$vtk.storage.get('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n // 如果 $vtk 不存在,尝试从 localStorage 获取 token\r\n else {\r\n const token = localStorage.getItem('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n } catch (error) {\r\n // 发生错误时返回原始src\r\n console.warn('VtkPdf: Failed to get token, using src without token', error);\r\n return props.src;\r\n }\r\n});\r\n\r\n// 打开预览\r\nconst openPreview = () => {\r\n if (props.preview) {\r\n showPreview.value = true;\r\n // 延迟加载PDF以确保DOM已准备好\r\n setTimeout(() => {\r\n loadPdf();\r\n }, 300);\r\n }\r\n};\r\n\r\n// 关闭预览\r\nconst closePreview = () => {\r\n showPreview.value = false;\r\n // 清理PDF对象\r\n pdfDoc = null;\r\n pdfLoaded.value = false;\r\n currentPage.value = 1;\r\n pageCount.value = 0;\r\n};\r\n\r\n// 加载PDF(示例实现,实际使用需要PDF.js库)\r\nconst loadPdf = async () => {\r\n if (!srcWithToken.value) return;\r\n \r\n loading.value = true;\r\n \r\n try {\r\n // 模拟PDF加载(实际实现需要使用PDF.js)\r\n /*\r\n // 实际使用时的代码示例:\r\n pdfjsLib.GlobalWorkerOptions.workerSrc = '//cdnjs.cloudflare.com/ajax/libs/pdf.js/2.11.338/pdf.worker.min.js';\r\n \r\n const loadingTask = pdfjsLib.getDocument(srcWithToken.value);\r\n pdfDoc = await loadingTask.promise;\r\n pageCount.value = pdfDoc.numPages;\r\n pdfLoaded.value = true;\r\n \r\n // 渲染第一页\r\n renderPage(currentPage.value);\r\n */\r\n \r\n // 模拟加载过程\r\n await new Promise(resolve => setTimeout(resolve, 1000));\r\n pageCount.value = 10; // 模拟10页PDF\r\n pdfLoaded.value = true;\r\n } catch (error) {\r\n console.error('加载PDF失败:', error);\r\n } finally {\r\n loading.value = false;\r\n }\r\n};\r\n\r\n// 渲染PDF页面(示例实现)\r\nconst renderPage = async (pageNum) => {\r\n if (!pdfDoc || !pdfContainer.value) return;\r\n \r\n try {\r\n /*\r\n // 实际使用时的代码示例:\r\n const page = await pdfDoc.getPage(pageNum);\r\n const viewport = page.getViewport({ scale: 1.5 });\r\n \r\n // 准备canvas\r\n const canvas = document.createElement('canvas');\r\n const context = canvas.getContext('2d');\r\n canvas.height = viewport.height;\r\n canvas.width = viewport.width;\r\n \r\n // 清空容器\r\n pdfContainer.value.innerHTML = '';\r\n pdfContainer.value.appendChild(canvas);\r\n \r\n // 渲染页面\r\n const renderContext = {\r\n canvasContext: context,\r\n viewport: viewport\r\n };\r\n await page.render(renderContext).promise;\r\n */\r\n } catch (error) {\r\n console.error('渲染PDF页面失败:', error);\r\n }\r\n};\r\n\r\n// 上一页\r\nconst prevPage = () => {\r\n if (currentPage.value > 1) {\r\n currentPage.value--;\r\n renderPage(currentPage.value);\r\n }\r\n};\r\n\r\n// 下一页\r\nconst nextPage = () => {\r\n if (currentPage.value < pageCount.value) {\r\n currentPage.value++;\r\n renderPage(currentPage.value);\r\n }\r\n};\r\n\r\n// 下载PDF\r\nconst downloadPdf = async () => {\r\n if (!srcWithToken.value) return;\r\n \r\n try {\r\n // 获取PDF文件的二进制数据\r\n const response = await fetch(srcWithToken.value);\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n \r\n const blob = await response.blob();\r\n const fileName = props.title && props.title.trim() !== '' \r\n ? `${props.title}.pdf` \r\n : 'document.pdf';\r\n \r\n // 创建下载链接\r\n const url = window.URL.createObjectURL(blob);\r\n const link = document.createElement('a');\r\n link.href = url;\r\n link.download = fileName;\r\n document.body.appendChild(link);\r\n link.click();\r\n \r\n // 清理\r\n document.body.removeChild(link);\r\n window.URL.revokeObjectURL(url);\r\n } catch (error) {\r\n console.error('下载PDF失败:', error);\r\n // 备用方案:在新窗口打开\r\n window.open(srcWithToken.value, '_blank');\r\n }\r\n};\r\n\r\n// 监听页码变化\r\nconst handlePageChange = (newPage) => {\r\n if (newPage >= 1 && newPage <= pageCount.value) {\r\n renderPage(newPage);\r\n }\r\n};\r\n\r\n// 监听 currentPage 变化\r\n// 在实际实现中,您需要使用 watch 监听 currentPage 变化\r\n// watch(currentPage, handlePageChange);\r\n\r\n// 组件销毁前清理\r\nonBeforeUnmount(() => {\r\n pdfDoc = null;\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-pdf-container {\r\n position: relative;\r\n display: inline-block;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.vtk-pdf-card {\r\n height: 100%;\r\n}\r\n\r\n.vtk-pdf-card--preview {\r\n cursor: pointer;\r\n transition: transform 0.2s ease-in-out;\r\n}\r\n\r\n.vtk-pdf-card--preview:hover {\r\n transform: translateY(-5px);\r\n}\r\n\r\n.vtk-pdf-cover {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n background-color: #f5f5f5;\r\n border: 1px solid #ddd;\r\n width: 100%;\r\n}\r\n\r\n.vtk-pdf-label {\r\n margin-top: 8px;\r\n font-weight: 500;\r\n color: #666;\r\n}\r\n\r\n.vtk-pdf-info {\r\n padding: 0;\r\n}\r\n\r\n.vtk-pdf-title {\r\n word-break: break-word;\r\n}\r\n\r\n.vtk-pdf-description {\r\n word-break: break-word;\r\n}\r\n\r\n/* PDF查看器样式 */\r\n.pdf-viewer-card {\r\n background-color: #e0e0e0;\r\n color: #333;\r\n}\r\n\r\n.pdf-viewer-content {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: calc(100vh - 150px);\r\n position: relative;\r\n background-color: #555;\r\n overflow: auto;\r\n}\r\n\r\n.pdf-container {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n#pdf-viewer {\r\n max-width: 100%;\r\n max-height: 100%;\r\n box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);\r\n background-color: white;\r\n /* 实际PDF内容将在此处渲染 */\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n min-height: 500px;\r\n min-width: 400px;\r\n}\r\n\r\n.pdf-viewer-footer {\r\n padding: 16px;\r\n background-color: #f5f5f5;\r\n border-top: 1px solid #ddd;\r\n}\r\n\r\n.pdf-loading {\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n background-color: rgba(255, 255, 255, 0.9);\r\n padding: 20px;\r\n border-radius: 8px;\r\n z-index: 100;\r\n}\r\n</style>","// composables/useMixins.js\r\nimport { ref, reactive } from 'vue'\r\nimport Request from '../commons/request.js'\r\nimport Message from '../components/message/index.js'\r\nimport storage from '../commons/storage.js'\r\n\r\n/**\r\n * 通用 mixins composable\r\n * @param {Object} urlConfig - URL 配置对象\r\n * @returns {Object} 包含所有状态和方法的对象\r\n */\r\nexport function useMixins(urlConfig = {}) {\r\n // 响应式数据\r\n const queryParam = reactive({})\r\n const desserts = ref([])\r\n const loading = ref(false)\r\n const superQueryParams = ref('')\r\n const page = reactive({\r\n pageno: 1,\r\n limit: 10\r\n })\r\n const pageData = ref({})\r\n const sumup = ref({})\r\n const pageDataCopy = ref([])\r\n const overlay = ref(false)\r\n const user = ref({})\r\n\r\n // URL 配置\r\n const url = reactive(urlConfig)\r\n\r\n /**\r\n * 获取查询参数\r\n * @returns {Object} 查询参数对象\r\n */\r\n const getQueryParams = () => {\r\n user.value = storage.get('_mis_acis_users')\r\n if (!queryParam.areaCode) {\r\n queryParam.areaCode = user.value?.areacode\r\n }\r\n const codex = Object.assign({}, queryParam)\r\n const params = {\r\n pageno: page.pageno,\r\n limit: page.limit,\r\n codex: codex\r\n }\r\n return params\r\n }\r\n\r\n /**\r\n * 加载页面数据\r\n */\r\n const loadPage = () => {\r\n if (!url.list) {\r\n Message.toast('请先设置url.list属性', { color: 'warning' })\r\n return\r\n }\r\n const params = getQueryParams()\r\n loading.value = true\r\n\r\n // 兼容处理 vtk 对象\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.show()\r\n }\r\n\r\n Request.postJson(url.list, params)\r\n .then((res) => {\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n\r\n if (res.meta.success || res.data) {\r\n desserts.value = res.data?.rows || []\r\n pageData.value = res.data\r\n sumup.value = res.data.sumup ? res.data.sumup : {}\r\n pageDataCopy.value = res.data\r\n }\r\n loading.value = false\r\n })\r\n .catch((error) => {\r\n console.error('加载页面数据失败:', error)\r\n loading.value = false\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n })\r\n }\r\n\r\n /**\r\n * 搜索查询\r\n */\r\n const searchQuery = () => {\r\n page.pageno = 1\r\n page.limit ??= 10\r\n loadPage()\r\n }\r\n\r\n /**\r\n * 分页变化处理\r\n * @param {Object} pageInfo - 分页信息\r\n */\r\n const getListPage = (pageInfo) => {\r\n page.pageno = pageInfo.pageno\r\n page.limit = pageInfo.limit\r\n loadPage()\r\n }\r\n\r\n /**\r\n * 删除项\r\n * @param {string|number} id - 要删除的项ID\r\n * @param {string} text - 确认提示文本\r\n */\r\n const deleteItem = (id, text) => {\r\n if (!url.delete) {\r\n Message.toast('请设置url.delete属性!', { color: 'warning' })\r\n return\r\n }\r\n\r\n Message.confirm(\r\n { title: '确认删除', text: text ? text : '是否删除?' },\r\n (result) => {\r\n if (result) {\r\n Request.getForm(url.delete, { id: id })\r\n .then((res) => {\r\n if (res.meta.success) {\r\n Message.toast('删除成功', { color: 'success' })\r\n loadPage()\r\n } else {\r\n Message.toast('删除失败', { color: 'warning' })\r\n }\r\n })\r\n .catch((error) => {\r\n console.error('删除失败:', error)\r\n Message.toast('删除失败', { color: 'warning' })\r\n })\r\n }\r\n }\r\n )\r\n }\r\n\r\n /**\r\n * 复制项\r\n * @param {string|number} id - 要复制的项ID\r\n * @param {string} text - 确认提示文本\r\n */\r\n const copyItem = (id, text) => {\r\n if (!url.copy) {\r\n Message.toast('请设置url.copy!', { color: 'warning' })\r\n return\r\n }\r\n\r\n Message.confirm(\r\n { title: '拷贝', text: text ? text : '是否确认拷贝当前数据?' },\r\n (result) => {\r\n if (result) {\r\n Request.getForm(url.copy, { id: id })\r\n .then((res) => {\r\n if (res.meta.success) {\r\n Message.toast('拷贝成功', { color: 'success' })\r\n loadPage()\r\n } else {\r\n Message.toast('拷贝失败', { color: 'warning' })\r\n }\r\n })\r\n .catch((error) => {\r\n console.error('拷贝失败:', error)\r\n Message.toast('拷贝失败', { color: 'warning' })\r\n })\r\n }\r\n }\r\n )\r\n }\r\n\r\n /**\r\n * 编辑项\r\n * @param {Object} record - 要编辑的记录\r\n * @param {Object} modalFormRef - 模态框引用\r\n */\r\n const edit = (record, modalFormRef) => {\r\n if (modalFormRef?.value) {\r\n modalFormRef.value.edit(record)\r\n }\r\n }\r\n\r\n /**\r\n * 添加新项\r\n * @param {Object} modalFormRef - 模态框引用\r\n */\r\n const add = (modalFormRef) => {\r\n if (modalFormRef?.value) {\r\n modalFormRef.value.add()\r\n }\r\n }\r\n\r\n /**\r\n * 模态框确认回调\r\n */\r\n const modalFormOk = () => {\r\n loadPage()\r\n }\r\n\r\n /**\r\n * 导出数据\r\n */\r\n const expData = () => {\r\n overlay.value = true\r\n\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.show()\r\n }\r\n\r\n const params = getQueryParams()\r\n Request.exp(url.exp, params)\r\n .then((res) => {\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n\r\n if (res) {\r\n const disposition = res.headers['content-disposition']\r\n const filename = decodeURI(\r\n disposition.substring(\r\n disposition.indexOf('filename=') + 9,\r\n disposition.length\r\n )\r\n )\r\n const blob = new Blob([res.data], {\r\n type: 'application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n })\r\n\r\n if (window.navigator.msSaveOrOpenBlob) {\r\n navigator.msSaveBlob(blob)\r\n } else {\r\n const link = document.createElement('a')\r\n link.style.display = 'none'\r\n link.href = URL.createObjectURL(blob)\r\n link.download = filename\r\n document.body.appendChild(link)\r\n link.click()\r\n document.body.removeChild(link)\r\n }\r\n }\r\n overlay.value = false\r\n })\r\n .catch((error) => {\r\n console.error('导出数据失败:', error)\r\n overlay.value = false\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n })\r\n }\r\n\r\n /**\r\n * 重置查询参数\r\n */\r\n const resetQueryParams = () => {\r\n Object.keys(queryParam).forEach(key => {\r\n delete queryParam[key]\r\n })\r\n }\r\n\r\n /**\r\n * 重置分页\r\n */\r\n const resetPage = () => {\r\n page.pageno = 1\r\n page.limit = 10\r\n }\r\n\r\n /**\r\n * 更新 URL 配置\r\n * @param {Object} newUrlConfig - 新的 URL 配置\r\n */\r\n const updateUrlConfig = (newUrlConfig) => {\r\n Object.assign(url, newUrlConfig)\r\n }\r\n\r\n // 返回所有状态和方法\r\n return {\r\n // 响应式数据\r\n queryParam,\r\n desserts,\r\n loading,\r\n superQueryParams,\r\n page,\r\n pageData,\r\n sumup,\r\n pageDataCopy,\r\n overlay,\r\n user,\r\n url,\r\n\r\n // 方法\r\n getQueryParams,\r\n loadPage,\r\n searchQuery,\r\n getListPage,\r\n deleteItem,\r\n copyItem,\r\n edit,\r\n add,\r\n modalFormOk,\r\n expData,\r\n resetQueryParams,\r\n resetPage,\r\n updateUrlConfig\r\n }\r\n}\r\n\r\n// 默认导出保持向后兼容\r\nexport default useMixins","<template>\r\n\t<VContainer fluid class=\"vtk-height pa-0\">\r\n\t\t<VTabs v-model=\"examType\" bg-color=\"transparent\" height=\"38\" style=\"width: 100%\">\r\n\t\t\t<VTab @click=\"examAll()\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-clipboard-arrow-up</VIcon>全部</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"list\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-star-circle</VIcon>审核</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"tip\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-hand-heart</VIcon>实施</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"tip\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-comment-minus</VIcon>评价</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"tip\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-credit-card-check</VIcon>支付</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VSpacer />\r\n\t\t</VTabs>\r\n\t\t<VCard elevation=\"0\" style=\"min-height: calc(100% - 38px)\">\r\n\t\t\t<VCardTitle style=\"height: 88px\">\r\n\t\t\t\t<VMenu v-if=\"examType == '0' && (expShow || user.grole >= 2)\" offset-y :close-on-content-click=\"false\" location=\"bottom\">\r\n\t\t\t\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t\t\t\t<VBtn @click=\"exv\" v-bind=\"props\" class=\"bg-orange text-white mr-3\" elevation=\"0\">\r\n\t\t\t\t\t\t\t<VIcon>mdi-export-variant</VIcon> 导出\r\n\t\t\t\t\t\t</VBtn>\r\n\t\t\t\t\t</template>\r\n\t\t\t\t\t<VCard class=\"pa-3\" width=\"300\">\r\n\t\t\t\t\t\t<div>\r\n\t\t\t\t\t\t\t<p class=\"mb-2 font-weight-bold\">公共字段</p>\r\n\t\t\t\t\t\t\t<p class=\"text-caption\">\r\n\t\t\t\t\t\t\t\t服务事项\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t所属区县\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t所属镇街\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t所属社区\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t申请人证件号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t申请人姓名\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t残疾人证号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t性别\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t申请人手机号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t补助金额\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t开户银行\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t银行卡号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t收款人姓名\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t收款人证件号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t状态\r\n\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t<VDivider />\r\n\t\t\t\t\t\t\t<div v-if=\"queryParam.servState == '1' && projName\">\r\n\t\t\t\t\t\t\t\t<VCardTitle class=\"pa-0 text-body-1 mb-2 pt-3\">\r\n\t\t\t\t\t\t\t\t\t<VCheckbox @update:model-value=\"chkAll\" v-model=\"select\" class=\"mt-n1\" hide-details>\r\n\t\t\t\t\t\t\t\t\t\t<template v-slot:append>\r\n\t\t\t\t\t\t\t\t\t\t\t<VIcon class=\"active\" style=\"display: none\" size=\"18\">mdi-check-circle</VIcon>\r\n\t\t\t\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t\t\t</VCheckbox>\r\n\t\t\t\t\t\t\t\t\t<span class=\"font-weight-bold ml-n2\">拓展字段</span>\r\n\t\t\t\t\t\t\t\t\t<VSpacer />\r\n\t\t\t\t\t\t\t\t</VCardTitle>\r\n\t\t\t\t\t\t\t\t<p v-if=\"formArr?.length > 0\" class=\"mb-0 expBox\">\r\n\t\t\t\t\t\t\t\t\t<VCheckbox\r\n\t\t\t\t\t\t\t\t\t\tv-for=\"(item, index) in formArr\"\r\n\t\t\t\t\t\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\t\t\t\t\t\tv-model=\"expArr\"\r\n\t\t\t\t\t\t\t\t\t\t:label=\"item.label\"\r\n\t\t\t\t\t\t\t\t\t\t:value=\"{ name: item.name, valu: `${item.label}${item.valu && item.valu.includes('/') && item.valu.includes(':') ? `(${item.valu})` : ''}` }\"\r\n\t\t\t\t\t\t\t\t\t\tclass=\"mt-2\"\r\n\t\t\t\t\t\t\t\t\t\tmultiple\r\n\t\t\t\t\t\t\t\t\t\thide-details>\r\n\t\t\t\t\t\t\t\t\t\t<template v-slot:append>\r\n\t\t\t\t\t\t\t\t\t\t\t<VIcon class=\"active\" style=\"display: none\" size=\"18\">mdi-check-circle</VIcon>\r\n\t\t\t\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t\t\t</VCheckbox>\r\n\t\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t\t<p v-else class=\"text-red text-body-2 mb-2\">{{ projTip }}</p>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t<div v-else>\r\n\t\t\t\t\t\t\t\t<p class=\"mb-3 pt-3 font-weight-bold\">导出提示</p>\r\n\t\t\t\t\t\t\t\t<p :class=\"queryParam.servState == '1' ? 'text-green' : 'text-red'\" class=\"mb-3 text-body-2\">\r\n\t\t\t\t\t\t\t\t\t<VIcon size=\"20\" :color=\"queryParam.servState == '1' ? 'green' : 'red'\">{{ queryParam.servState == \"1\" ? \"mdi-progress-check\" : \"mdi-progress-close\" }}</VIcon>\r\n\t\t\t\t\t\t\t\t\t导出数据仅限已服务信息\r\n\t\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t\t<p class=\"mb-2 text-body-2\" :class=\"projName ? 'text-green' : 'text-red'\">\r\n\t\t\t\t\t\t\t\t\t<VIcon size=\"20\" :color=\"projName ? 'green' : 'red'\">{{ projName ? \"mdi-progress-check\" : \"mdi-progress-close\" }}</VIcon>\r\n\t\t\t\t\t\t\t\t\t至少选择一个服务事项导出\r\n\t\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<VBtn @click=\"exp\" :disabled=\"!(projName && queryParam.servState == '1')\" elevation=\"0\" color=\"primary\" class=\"vtk-width mt-3\" size=\"small\">确认导出</VBtn>\r\n\t\t\t\t\t</VCard>\r\n\t\t\t\t</VMenu>\r\n\t\t\t\t<VSpacer />\r\n\t\t\t\t<vtk-search v-model=\"queryParam\" @search=\"searchQuery\" placeholder=\"输入姓名/身份证查询\" :styles=\"'width:320px'\">\r\n\t\t\t\t\t<VTextField @click=\"searchProj\" v-model=\"projName\" :title=\"projName\" clearable readonly variant=\"outlined\" placeholder=\"服务事项\" density=\"compact\" hide-details class=\"my-3\"></VTextField>\r\n\t\t\t\t\t<vtk-area-tabs v-model=\"queryParam.areaCode\" :styles=\"'width:100%'\" />\r\n\t\t\t\t\t<div v-if=\"examType == 0\" style=\"width: 400px\">\r\n\t\t\t\t\t\t<vtk-select v-model=\"queryParam.servState\" @change=\"searchQuery\" placeholder=\"服务状态\" list=\"0:服务中/1:已服务\" class=\"mt-3 d-inline-block mr-3 mb-3\" style=\"width: calc(50% - 6px)\" hide-details density=\"compact\" variant=\"outlined\" clearable></vtk-select>\r\n\t\t\t\t\t\t<vtk-select v-model=\"queryParam.rateState\" @change=\"searchQuery\" placeholder=\"是否评价\" list=\"0:未评价/1:已评价\" class=\"mt-3 d-inline-block\" style=\"width: calc(50% - 6px)\" hide-details density=\"compact\" variant=\"outlined\" clearable></vtk-select>\r\n\t\t\t\t\t\t<VMenu v-model=\"menu\" :close-on-content-click=\"false\" transition=\"scale-transition\" location=\"bottom\" max-width=\"290px\" min-width=\"auto\">\r\n\t\t\t\t\t\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t\t\t\t\t\t<VTextField v-model=\"queryParam.servFtime0\" placeholder=\"开始时间\" persistent-hint append-icon=\"mdi-calendar\" class=\"d-inline-block\" style=\"width: calc(50% - 16px)\" hide-details variant=\"outlined\" density=\"compact\" v-bind=\"props\"></VTextField>\r\n\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t<VDatePicker v-model=\"queryParam.servFtime0\" title=\"\" @update:model-value=\"menu = false\" view-mode=\"month\" :max=\"queryParam.servFtime1\"></VDatePicker>\r\n\t\t\t\t\t\t</VMenu>\r\n\t\t\t\t\t\t<span class=\"mx-2\">至</span>\r\n\t\t\t\t\t\t<VMenu v-model=\"menu1\" :close-on-content-click=\"false\" transition=\"scale-transition\" location=\"bottom\" max-width=\"290px\" min-width=\"auto\">\r\n\t\t\t\t\t\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t\t\t\t\t\t<VTextField v-model=\"queryParam.servFtime1\" placeholder=\"结束时间\" persistent-hint append-icon=\"mdi-calendar\" class=\"d-inline-block\" style=\"width: calc(50% - 15px)\" hide-details variant=\"outlined\" density=\"compact\" v-bind=\"props\"></VTextField>\r\n\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t<VDatePicker v-model=\"queryParam.servFtime1\" title=\"\" @update:model-value=\"menu1 = false\" view-mode=\"month\" :min=\"queryParam.servFtime0\"></VDatePicker>\r\n\t\t\t\t\t\t</VMenu>\r\n\t\t\t\t\t\t<vtk-select v-if=\"queryParam.servState == '1'\" @change=\"searchQuery\" v-model=\"queryParam.state\" class=\"mt-3\" placeholder=\"状态\" list=\"1:已通过/0:未通过\" hide-details density=\"compact\" variant=\"outlined\" clearable></vtk-select>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</vtk-search>\r\n\t\t\t</VCardTitle>\r\n\t\t\t<VCardText>\r\n\t\t\t\t<VDataTable :headers=\"headers\" :items=\"desserts\" :loading=\"loading\" disable-pagination loading-text=\"数据加载中...\" class=\"elevation-0\" hide-default-footer>\r\n\t\t\t\t\t<template v-slot:[`item.objsName`]=\"{ item }\">\r\n\t\t\t\t\t\t<div class=\"py-3\" @click=\"toView(item)\">\r\n\t\t\t\t\t\t\t<p class=\"vtk-cursor-pointer text-body-1 font-weight-bold mb-2\">\r\n\t\t\t\t\t\t\t\t{{ item.objsName }}<span class=\"ml-3 text-grey\">{{ formatIdCard(item.objsCode) }} </span>\r\n\t\t\t\t\t\t\t\t<VChip class=\"ml-2\" :class=\"getServStateClass(item.servState)\" size=\"small\" label>{{ getServStateText(item.servState) }} </VChip>\r\n\t\t\t\t\t\t\t\t<VChip class=\"ml-2\" :class=\"getRateStateClass(item.rateState)\" size=\"small\" label>{{ getRateStateText(item.rateState) }} </VChip>\r\n\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t<span>\r\n\t\t\t\t\t\t\t\t<VChip class=\"bg-orange-lighten-5 text-orange\" size=\"small\" label> 事项编码:{{ item.projCode }} </VChip>\r\n\t\t\t\t\t\t\t\t<VChip class=\"text-primary ml-2\" size=\"small\" label> 办件编号:{{ item.inst }} </VChip>\r\n\t\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t\t<div class=\"mb-0 mt-2 text-grey\">\r\n\t\t\t\t\t\t\t\t<div class=\"d-inline-block\" style=\"min-width: 320px\">\r\n\t\t\t\t\t\t\t\t\t服务名称:<span class=\"text-blue\">{{ item.projName }}</span>\r\n\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t\t<span>补助金额:{{ item.servAmts }}元</span>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t<VRow class=\"py-2\" style=\"color: #979797c2\">\r\n\t\t\t\t\t\t\t\t<VCol style=\"max-width: 320px\">\r\n\t\t\t\t\t\t\t\t\t<span :title=\"item.name\" class=\"d-block\" style=\"color: #979797c2\">申请途径:{{ getServFromText(item.servFrom) }}</span>\r\n\t\t\t\t\t\t\t\t</VCol>\r\n\t\t\t\t\t\t\t\t<VCol>\r\n\t\t\t\t\t\t\t\t\t<span :title=\"item.name\" class=\"d-block\" style=\"color: #979797c2\">申请时间:{{ formatDate(item.servCtime) }}</span>\r\n\t\t\t\t\t\t\t\t</VCol>\r\n\t\t\t\t\t\t\t</VRow>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</template>\r\n\t\t\t\t\t<template v-slot:[`item.actions`]=\"{ item }\">\r\n\t\t\t\t\t\t<a v-if=\"item.state != 0 && user.areacode?.length == 6 && item.servState == '1'\" @click=\"del(item)\" class=\"text-error\" text>作废</a>\r\n\t\t\t\t\t\t<div v-if=\"item.state == 0\" class=\"state_btg text-right\"></div>\r\n\t\t\t\t\t</template>\r\n\t\t\t\t\t<template v-slot:no-data>\r\n\t\t\t\t\t\t<vtk-empty />\r\n\t\t\t\t\t</template>\r\n\t\t\t\t</VDataTable>\r\n\t\t\t\t<vtk-page :page-sizes=\"[10, 20]\" :page-data=\"pageData\" @pageChange=\"getListPage\" />\r\n\t\t\t</VCardText>\r\n\t\t</VCard>\r\n\t\t<!-- 服务事项 -->\r\n\t\t<vtk-proj ref=\"MprojRef\" @toPage=\"toPage\" />\r\n\t\t<!-- 删除服务 -->\r\n\t\t<VDialog v-model=\"dialog\" persistent max-width=\"500\">\r\n\t\t\t<VCard>\r\n\t\t\t\t<VCardTitle>作废</VCardTitle>\r\n\t\t\t\t<VCardText class=\"pb-0\">\r\n\t\t\t\t\t服务作废后将无法恢复,请谨慎操作!!!\r\n\t\t\t\t\t<VTextarea v-model=\"delNote\" variant=\"outlined\" label=\"请填写作废原因\" class=\"mt-3\" hide-details density=\"compact\"></VTextarea>\r\n\t\t\t\t</VCardText>\r\n\t\t\t\t<VCardActions>\r\n\t\t\t\t\t<VSpacer />\r\n\t\t\t\t\t<VBtn @click=\"dialog = false\" variant=\"text\">取消</VBtn>\r\n\t\t\t\t\t<VBtn @click=\"delSave(true)\" variant=\"text\">确定</VBtn>\r\n\t\t\t\t</VCardActions>\r\n\t\t\t</VCard>\r\n\t\t</VDialog>\r\n\t</VContainer>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, watch, onActivated } from 'vue';\r\nimport { useMixins } from '../../composables/useMixins'\r\nimport Request from '../../commons/request';\r\n\r\n// 定义组件选项\r\ndefineOptions({\r\n\tname: 'VtkProj',\r\n\tinheritAttrs: false,\r\n});\r\n\r\n// 表单列表 URL 配置\r\nconst urlConfig = {\r\n\tlist: '/kudas/xfwez/page',\r\n\texp: '/kudas/xfwez/exp',\r\n\tdelete: '/kudas/xfwez/delete'\r\n};\r\n\r\n// 使用 mixins composable\r\nconst {\r\n\tpageData,\r\n\tgetListPage,\r\n\tloadPage,\r\n\texpData,\r\n\tdesserts,\r\n\tloading,\r\n\tqueryParam: mixinQueryParam,\r\n\turl\r\n} = useMixins(urlConfig);\r\n\r\n// 合并 queryParam\r\nObject.assign(mixinQueryParam, {});\r\nconst queryParam = mixinQueryParam;\r\n\r\n// 响应式数据\r\nconst user = ref({});\r\nconst examType = ref(1);\r\n\r\nconst headers = ref([\r\n\t{ title: '事项', key: 'objsName', sortable: false },\r\n\t{ title: '状态', key: 'actions', sortable: false, align: 'end' },\r\n]);\r\n\r\n// 主题筛选\r\nconst permits = ref([]);\r\nconst projName = ref('');\r\nconst projTip = ref('');\r\nconst bizType = ref('');\r\nconst expShow = ref(false);\r\nconst menu = ref(false);\r\nconst menu1 = ref(false);\r\n\r\n// 导出\r\nconst expArr = ref([]);\r\nconst formArr = ref([]);\r\nconst select = ref(false);\r\nconst selectAll = ref([]);\r\n\r\n// 删除\r\nconst dialog = ref(false);\r\nconst delItem = ref({});\r\nconst delNote = ref('');\r\n\r\n// ref\r\nconst MprojRef = ref(null);\r\n\r\n// 监听器\r\nwatch(expArr, (newVal) => {\r\n\tif (newVal.length < selectAll.value.length) {\r\n\t\tselect.value = false;\r\n\t}\r\n}, { deep: true });\r\n\r\n// 生命周期\r\nonActivated(() => {\r\n\talert('onActivated');\r\n\tlist();\r\n\t// 监听接收消息,刷新页面\r\n\twindow.addEventListener('storage', (event) => {\r\n\t\tif (JSON.parse(event?.newValue)?.fwez) {\r\n\t\t\texamType.value == '0' ? examAll() : loadPage();\r\n\t\t}\r\n\t});\r\n});\r\n\r\n// 方法\r\n// 全选\r\nconst chkAll = (e) => {\r\n\texpArr.value = e ? selectAll.value : [];\r\n};\r\n\r\nconst list = () => {\r\n\tbizType.value = '';\r\n\texpShow.value = false;\r\n\tuser.value = getUserInfo();\r\n\tpermits.value = [];\r\n\tuser.value.permits?.forEach((e) => {\r\n\t\tif (e.permNkey.includes('biz_type')) {\r\n\t\t\tpermits.value.push(e);\r\n\t\t\tbizType.value = bizType.value + e.permNkey.slice(9) + ',';\r\n\t\t} else if (e.permNkey == 'btn_expo') {\r\n\t\t\texpShow.value = true;\r\n\t\t}\r\n\t});\r\n\tqueryParam.bizType = bizType.value;\r\n\texamWait();\r\n};\r\n\r\n// 获取用户信息\r\nconst getUserInfo = () => {\r\n\ttry {\r\n\t\t// 实际项目中从存储或状态管理获取\r\n\t\treturn window.$vtk?.storage?.get('_mis_acis_users') || {};\r\n\t} catch (error) {\r\n\t\tconsole.warn('获取用户信息失败:', error);\r\n\t\treturn {};\r\n\t}\r\n};\r\n\r\n// 待审\r\nconst examWait = () => {\r\n\texamType.value = 1;\r\n\tqueryParam.operateLeve = user.value.areacode?.length;\r\n\tqueryParam.servState = '0';\r\n\tloadPage();\r\n};\r\n\r\n// 全部审核\r\nconst examAll = () => {\r\n\texamType.value = 0;\r\n\tdelete queryParam.operateLeve;\r\n\tdelete queryParam.servState;\r\n\tloadPage();\r\n};\r\n\r\n// 审核\r\nconst toView = (item) => {\r\n\tconst url = item.servState == 1\r\n\t\t? `#/mino/suse/view/${item.inst}?ddtab=true`\r\n\t\t: `#/mino/suse/exam/${item.inst}?ddtab=true`;\r\n\twindow.open(url);\r\n};\r\n\r\n// 服务事项查询/筛选\r\nconst searchProj = () => {\r\n\tMprojRef.value?.add(queryParam.projCode);\r\n};\r\n\r\nconst toPage = (param) => {\r\n\tprojName.value = param.projName;\r\n\tqueryParam.projCode = param.projCode;\r\n\tdelete queryParam.bizType;\r\n\tsearchQuery();\r\n};\r\n\r\nconst searchQuery = () => {\r\n\t// 搜索查询逻辑\r\n\tloadPage();\r\n};\r\n\r\n// 导出相关\r\nconst exv = () => {\r\n\tif (projName.value && queryParam.servState == '1') {\r\n\t\texpArr.value = [];\r\n\t\tformArr.value = [];\r\n\t\t// 显示加载状态\r\n\t\tRequest.postJson('/kudas/xfwez/exv', { codex: queryParam }).then((res) => {\r\n\t\t\tif (res.meta.success) {\r\n\t\t\t\tJSON.parse(res.data.formJson).forEach((item) => {\r\n\t\t\t\t\tif (['text', 'radio', 'number', 'time', 'checkbox', 'textarea', 'select'].includes(item.type)) {\r\n\t\t\t\t\t\titem.value = {\r\n\t\t\t\t\t\t\tname: item.name,\r\n\t\t\t\t\t\t\tvalu: `${item.label}${item.valu && item.valu.includes('/') && item.valu.includes(':') ? `(${item.valu})` : ''}`\r\n\t\t\t\t\t\t};\r\n\t\t\t\t\t\tformArr.value.push(item);\r\n\t\t\t\t\t\tselectAll.value.push(item.value);\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t} else {\r\n\t\t\t\tprojTip.value = res.meta.message;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n};\r\n\r\nconst exp = () => {\r\n\tqueryParam.fields = expArr.value;\r\n\texpData();\r\n};\r\n\r\n// 服务作废\r\nconst del = (item) => {\r\n\tdialog.value = true;\r\n\tdelItem.value = item;\r\n\tdelNote.value = '';\r\n};\r\n\r\nconst delSave = () => {\r\n\tif (delNote.value) {\r\n\t\tRequest.postForm(url.delete, { id: delItem.value.id, note: delNote.value }).then((res) => {\r\n\t\t\tif (res.meta.success) {\r\n\t\t\t\t// 显示成功消息\r\n\t\t\t\tdialog.value = false;\r\n\t\t\t\tloadPage();\r\n\t\t\t} else {\r\n\t\t\t\t// 显示失败消息\r\n\t\t\t}\r\n\t\t});\r\n\t} else {\r\n\t\t// 显示错误消息\r\n\t}\r\n};\r\n\r\n// 提示\r\nconst tip = () => {\r\n\t// 显示应用开发中的消息\r\n};\r\n\r\n// 工具函数\r\nconst formatIdCard = (idcard) => {\r\n\tif (!idcard) return '';\r\n\treturn idcard.replace(/^(.{6})(?:\\d+)(.{4})$/, '$1********$2');\r\n};\r\n\r\nconst formatDate = (dateStr) => {\r\n\tif (!dateStr) return '';\r\n\tconst date = new Date(dateStr);\r\n\treturn `${date.getFullYear()}年${String(date.getMonth() + 1).padStart(2, '0')}月${String(date.getDate()).padStart(2, '0')}日 ${String(date.getHours()).padStart(2, '0')}:${String(date.getMinutes()).padStart(2, '0')}:${String(date.getSeconds()).padStart(2, '0')}`;\r\n};\r\n\r\nconst getServStateClass = (state) => {\r\n\treturn state == '0' ? 'bg-blue-lighten-5 text-blue' : 'bg-green-lighten-5 text-green';\r\n};\r\n\r\nconst getServStateText = (state) => {\r\n\treturn state == '0' ? '服务中' : '已服务';\r\n};\r\n\r\nconst getRateStateClass = (state) => {\r\n\treturn state == '0' ? 'bg-orange-lighten-5 text-orange' : 'bg-blue-lighten-5 text-blue';\r\n};\r\n\r\nconst getRateStateText = (state) => {\r\n\treturn state == '0' ? '未评价' : '已评价';\r\n};\r\n\r\nconst getServFromText = (from) => {\r\n\tconst fromMap = {\r\n\t\t'100': '特殊渠道',\r\n\t\t'101': '移动端代办',\r\n\t\t'102': '窗口端通办',\r\n\t\t'200': '特殊渠道',\r\n\t\t'210': '浙里办App',\r\n\t\t'211': '浙里办微信小程序',\r\n\t\t'212': '浙里办支付宝小程序',\r\n\t\t'230': '微信小程序',\r\n\t\t'240': '支付宝小程序',\r\n\t\t'250': '自助机',\r\n\t\t'300': '特殊渠道',\r\n\t\t'310': '服务外包代办'\r\n\t};\r\n\treturn fromMap[from] || from;\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.state_btg {\r\n\tpadding-right: 0;\r\n\theight: 100%;\r\n\tbackground: url(../../assets/img/objs_btg.png) no-repeat;\r\n\tbackground-size: 80px;\r\n\tbackground-position: 100% 100%;\r\n}\r\n\r\n:deep(.v-tab) {\r\n\tbackground: url(../../assets/img/tab-2.png) no-repeat;\r\n\tbackground-size: 100% 100%;\r\n\twidth: 150px;\r\n\tmargin-left: -11px;\r\n\tborder-top-left-radius: 20px;\r\n\tborder-top-right-radius: 20px;\r\n\tspan {\r\n\t\tz-index: 99;\r\n\t}\r\n}\r\n\r\n/* Dark theme */\r\n.v-theme--dark {\r\n\t:deep(.v-tab) {\r\n\t\tbackground: url(../../assets/img/tab-4.png) no-repeat;\r\n\t\tbackground-size: 100% 100%;\r\n\t}\r\n\r\n\t:deep(.v-tabs__slider) {\r\n\t\tbackground: url(../../assets/img/tab-3.png) no-repeat !important;\r\n\t\tbackground-size: 100% 100% !important;\r\n\t}\r\n}\r\n\r\n:deep(.v-tab::before),\r\n:deep(.v-tab:focus::before),\r\n:deep(.v-tab:hover::before) {\r\n\tbackground-color: transparent !important;\r\n\topacity: 0 !important;\r\n}\r\n\r\n:deep(.v-tabs__slider) {\r\n\theight: 38px !important;\r\n\tbackground: url(../../assets/img/tab-1.png) no-repeat;\r\n\tbackground-size: 100% 100%;\r\n}\r\n\r\n.expBox {\r\n\t:deep(td) {\r\n\t\tborder-bottom: thin solid rgba(123, 123, 123, 0.22);\r\n\t}\r\n\r\n\t:deep(.v-data-table__empty-wrapper td) {\r\n\t\tborder: none;\r\n\t}\r\n\r\n\t:deep(.v-checkbox.v-selection-control--dirty) {\r\n\t\tbackground-color: rgba(33, 149, 243, 0.06) !important;\r\n\r\n\t\t.v-label {\r\n\t\t\tcolor: rgb(33, 150, 243) !important;\r\n\t\t}\r\n\r\n\t\t.active {\r\n\t\t\tcolor: rgb(33, 150, 243);\r\n\t\t\tdisplay: inline-block !important;\r\n\t\t}\r\n\t}\r\n\r\n\t:deep(.v-selection-control__input) {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t:deep(.v-checkbox) {\r\n\t\tpadding: 4px 8px 4px 10px;\r\n\t\tborder-radius: 6px;\r\n\t\tbackground-color: rgba(117, 117, 117, 0.06);\r\n\r\n\t\t.v-label {\r\n\t\t\tmargin-top: 3px;\r\n\t\t\tfont-size: 12px;\r\n\t\t}\r\n\t}\r\n}\r\n</style>\r\n","<template>\r\n <VRadioGroup v-bind=\"attrs\" :modelValue=\"modelValue\" @update:modelValue=\"onUpdate\">\r\n <VRadio\r\n v-for=\"item in items\"\r\n :key=\"item.id || item.code\"\r\n :label=\"item.codeValue\"\r\n :value=\"item.code\"\r\n />\r\n </VRadioGroup>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, useAttrs } from 'vue';\r\nimport Request from '../../commons/request';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkRadio\",\r\n inheritAttrs: false,\r\n});\r\n// 定义 props\r\nconst props = defineProps({\r\n /**\r\n * 字典来源:\r\n * - 静态数据,如:\"0:否/1:是\"\r\n * - 字典键名,如:\"DISABLE_TYPE\"\r\n */\r\n list: {\r\n type: String,\r\n required: true,\r\n },\r\n modelValue: {\r\n type: [String, Number],\r\n default: null,\r\n },\r\n});\r\n\r\n// 定义 emit 事件\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 获取透传属性(替代 $attrs)\r\nconst attrs = useAttrs();\r\n\r\n// 响应式数据\r\nconst items = ref([]);\r\n\r\n// 处理静态数据\r\nconst statc = () => {\r\n props.list.split('/').forEach(it => {\r\n const [code, codeValue] = it.split(':');\r\n items.value.push({ code, codeValue });\r\n });\r\n};\r\n\r\n// 请求远程字典\r\nconst miscs = async () => {\r\n try {\r\n const res = await Request.getForm(`dict/misc/list/${props.list}`);\r\n items.value = res.data || [];\r\n } catch (error) {\r\n console.error('[VtkRadio] Failed to load dictionary:', error);\r\n items.value = [];\r\n }\r\n};\r\n\r\n// 更新 v-model 值\r\nconst onUpdate = (val) => {\r\n emit('update:modelValue', val);\r\n};\r\n\r\n// 初始化数据\r\nonMounted(() => {\r\n if (props.list.includes(':')) {\r\n statc();\r\n } else {\r\n miscs();\r\n }\r\n});\r\n</script>\r\n\r\n<style scoped>\r\n</style>","<template>\r\n <div class=\"search\">\r\n <VMenu\r\n v-model=\"menu\"\r\n @update:model-value=\"obtain\"\r\n location=\"bottom end\"\r\n origin=\"top end\"\r\n offset=\"12\"\r\n :close-on-content-click=\"false\"\r\n >\r\n <template v-slot:activator=\"{ props }\">\r\n <VTextField\r\n v-model=\"queryParam.condition\"\r\n :placeholder=\"$attrs.placeholder || '请输入查询内容'\"\r\n :style=\"$attrs.styles\"\r\n class=\"box\"\r\n density=\"compact\"\r\n variant=\"outlined\"\r\n hide-details\r\n @click:append=\"search\"\r\n @keyup.enter=\"search\"\r\n @click:clear=\"(queryParam.condition = ''), search()\"\r\n clearable\r\n >\r\n <template v-slot:append-inner>\r\n <VBadge\r\n dot\r\n :content=\"initialIndex\"\r\n :model-value=\"initialIndex > 0\"\r\n color=\"error\"\r\n class=\"advanced-badge\"\r\n >\r\n <span\r\n v-bind=\"props\"\r\n class=\"text-blue vtk-cursor-pointer d-inline-flex align-center text-body-2\"\r\n >\r\n 高级\r\n </span>\r\n </VBadge>\r\n </template>\r\n </VTextField>\r\n </template>\r\n\r\n <VCard class=\"search-panel\">\r\n <VCardTitle class=\"pr-3 d-flex justify-space-between align-center pb-5\">\r\n <span>高级搜索</span>\r\n <VBtn class=\"mx-0\" variant=\"text\" icon @click=\"close\" size=\"small\">\r\n <VIcon>mdi-close</VIcon>\r\n </VBtn>\r\n </VCardTitle>\r\n\r\n <VCardText class=\"search-panel__body\">\r\n <div class=\"search-panel__content\" :style=\"contentStyle\">\r\n <slot :query-param=\"queryParam\"></slot>\r\n </div>\r\n </VCardText>\r\n\r\n <VCardActions class=\"pt-0 px-4 pb-3\">\r\n <slot name=\"actions\"></slot>\r\n <VSpacer />\r\n <VBtn @click=\"search\" variant=\"flat\" color=\"primary\">\r\n <VIcon class=\"mr-1\">mdi-magnify</VIcon>搜索\r\n </VBtn>\r\n <VBtn @click=\"handleResetClick\" variant=\"flat\" color=\"error\">\r\n <VIcon class=\"mr-1\">mdi-sync</VIcon>重置\r\n </VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VMenu>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed, getCurrentInstance, onMounted, ref, watch } from 'vue';\r\n\r\ndefineOptions({\r\n name: \"VtkSearch\"\r\n});\r\n\r\nconst props = defineProps({\r\n value: {\r\n type: Object,\r\n default: () => ({})\r\n },\r\n contentMinHeight: {\r\n type: [Number, String],\r\n default: 0\r\n },\r\n contentMaxHeight: {\r\n type: [Number, String],\r\n default: 360\r\n }\r\n});\r\n\r\nconst emit = defineEmits(['update:value', 'search', 'reset']);\r\nconst instance = getCurrentInstance();\r\n\r\nconst user = ref({});\r\nconst menu = ref(false);\r\nconst queryParam = ref({ ...props.value });\r\nconst initialQueryParam = ref({ ...props.value });\r\n\r\nconst initialIndex = computed(() => {\r\n return Object.entries(queryParam.value).filter(([key, val]) => {\r\n if (key === 'condition') return false;\r\n const initVal = initialQueryParam.value[key];\r\n if (Array.isArray(val) && Array.isArray(initVal)) {\r\n return JSON.stringify(val) !== JSON.stringify(initVal);\r\n }\r\n return val !== initVal;\r\n }).length;\r\n});\r\n\r\nconst contentStyle = computed(() => {\r\n const minValue = props.contentMinHeight;\r\n const maxValue = props.contentMaxHeight;\r\n const minHeight = typeof minValue === 'number' ? `${minValue}px` : minValue;\r\n const maxHeight = typeof maxValue === 'number' ? `${maxValue}px` : maxValue;\r\n\r\n return {\r\n ...(minValue ? { minHeight } : {}),\r\n maxHeight,\r\n };\r\n});\r\n\r\nwatch(\r\n () => props.value,\r\n (newVal) => {\r\n queryParam.value = { ...newVal };\r\n }\r\n);\r\n\r\nonMounted(() => {\r\n user.value = JSON.parse(localStorage.getItem(\"_mis_acis_users\") || \"{}\");\r\n});\r\n\r\nconst obtain = () => {};\r\n\r\nconst close = () => {\r\n menu.value = false;\r\n obtain();\r\n};\r\n\r\nconst filterNull = (obj) => {\r\n return Object.fromEntries(Object.entries(obj).filter(([, v]) => v !== null && v !== undefined));\r\n};\r\n\r\nconst search = () => {\r\n close();\r\n emit('update:value', filterNull(queryParam.value));\r\n emit(\"search\");\r\n};\r\n\r\nconst reset = () => {\r\n queryParam.value = {\r\n ...initialQueryParam.value,\r\n condition: ''\r\n };\r\n emit('update:value', filterNull(queryParam.value));\r\n emit(\"search\");\r\n menu.value = false;\r\n};\r\n\r\nconst handleResetClick = () => {\r\n const hasParentResetHandler = Boolean(instance?.vnode.props?.onReset);\r\n\r\n if (hasParentResetHandler) {\r\n emit('reset', { ...queryParam.value });\r\n return;\r\n }\r\n\r\n reset();\r\n};\r\n\r\ndefineExpose({ search, reset });\r\n\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.search {\r\n position: relative;\r\n min-width: 380px;\r\n min-height: 40px;\r\n}\r\n\r\n.box {\r\n min-width: 380px;\r\n min-height: 40px;\r\n}\r\n\r\n.search-panel {\r\n width: 380px;\r\n margin-right: -16px;\r\n overflow: visible;\r\n}\r\n\r\n.search-panel__body {\r\n overflow: visible;\r\n}\r\n\r\n.search-panel__content {\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n scrollbar-gutter: stable;\r\n scrollbar-color: rgb(var(--v-theme-primary)) transparent;\r\n scrollbar-width: thin;\r\n}\r\n\r\n\r\n.search-panel__content::-webkit-scrollbar-track {\r\n background: transparent;\r\n}\r\n\r\n.search-panel__content::-webkit-scrollbar-thumb {\r\n background: rgb(var(--v-theme-primary));\r\n}\r\n\r\n:deep(.box .v-field__append-inner) {\r\n cursor: pointer;\r\n padding-left: 16px !important;\r\n padding-right: 4px !important;\r\n border-left: 1px #cccccc88 solid;\r\n min-width: 50px;\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n:deep(.advanced-badge .v-badge__badge) {\r\n transform: translate(10px, -2px);\r\n}\r\n</style>\r\n","<template>\r\n <VSelect \r\n v-bind=\"filteredAttrs\" \r\n :items=\"items\" \r\n item-title=\"codeValue\" \r\n item-value=\"code\" \r\n :multiple=\"multi\"\r\n :menu-props=\"{ offsetY: true }\" \r\n @update:model-value=\"$emit('update:modelValue', $event)\"\r\n />\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, useAttrs, computed } from 'vue'\r\nimport Request from \"../../commons/request\";\r\n\r\n// 定义组件名称和选项\r\ndefineOptions({\r\n name: \"VtkSelect\",\r\n inheritAttrs: false\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // 数据库字段名字(DISABLE_TYPE) 或 静态的字段(0:否/1:是)\r\n list: {\r\n type: String,\r\n default: null,\r\n },\r\n multi: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n});\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 获取所有传递的属性\r\nconst attrs = useAttrs();\r\n\r\n// 过滤属性,排除组件内部使用的属性\r\nconst filteredAttrs = computed(() => {\r\n const { list, multi, ...rest } = attrs;\r\n return rest;\r\n});\r\n\r\n// 响应式数据\r\nconst items = ref([]);\r\n\r\n// 方法定义\r\nconst miscs = () => {\r\n Request.getForm(`dict/misc/list/${props.list}`).then((res) => {\r\n items.value = res.data;\r\n });\r\n};\r\n\r\nconst statc = () => {\r\n if (!props.list) return;\r\n \r\n props.list.split(\"/\").forEach((it) => {\r\n const its = it.split(\":\");\r\n items.value.push({ code: its[0], codeValue: its[1] });\r\n });\r\n};\r\n\r\n// 生命周期钩子\r\nonMounted(() => {\r\n if (props.list) {\r\n if (props.list.includes(\":\")) {\r\n statc();\r\n } else {\r\n miscs();\r\n }\r\n }\r\n});\r\n\r\n// 使用方式\r\n// <vtk-select\r\n// v-model=\"value\"\r\n// list=\"YOUR_LIST\"\r\n// variant=\"outlined\" <!-- 样式变体 -->\r\n// density=\"compact\" <!-- 密度 'default' | 'comfortable' | 'compact' -->\r\n// clearable <!-- 可清除 -->\r\n// placeholder=\"请选择\" <!-- 占位符 -->\r\n// :rules=\"rules\" <!-- 验证规则 -->\r\n// disabled <!-- 禁用状态 -->\r\n// readonly <!-- 只读状态 -->\r\n// hide-details <!-- 隐藏详情信息 -->\r\n// />\r\n\r\n</script>\r\n\r\n<style scoped>\r\n::-webkit-scrollbar {\r\n width: 6px;\r\n}\r\n\r\n::-webkit-scrollbar-thumb {\r\n border-radius: 3px;\r\n height: 100px;\r\n background-color: #007acc;\r\n}\r\n</style>","<template>\r\n\t<VStepper class=\"elevation-0\" v-model=\"stepIndex\">\r\n\t\t<VStepperHeader class=\"elevation-0\" style=\"overflow: hidden;\">\r\n\t\t\t<VRow class=\"stepList\">\r\n\t\t\t\t<VCol class=\"pl-0 colItem\" v-for=\"(item, index) in step\" :key=\"index\" style=\"\">\r\n\t\t\t\t\t<div class=\"first-box1 last-box pl-10 py-5 stepItem\" :class=\"stepIndex > index? 'selected' : ''\"\r\n\t\t\t\t\t\t:complete=\"stepIndex > index\" :step=\"index + 1\">\r\n\t\t\t\t\t\t{{ item }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</VCol>\r\n\t\t\t</VRow>\r\n\t\t</VStepperHeader>\r\n\r\n\t\t<VStepperWindow>\r\n\t\t\t<VStepperWindowItem v-for=\"(item, index) in list\" :key=\"index\" :value=\"index + 1\">\r\n\t\t\t\t<slot :name=\"index + 1\"></slot>\r\n\t\t\t</VStepperWindowItem>\r\n\t\t\t<slot></slot>\r\n\t\t</VStepperWindow>\r\n\t</VStepper>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, watch, onMounted } from 'vue';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n\tname: \"VtkStepper\",\r\n\tinheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n\tlist: {\r\n\t\ttype: String,\r\n\t\tdefault: null,\r\n\t},\r\n\tel: {\r\n\t\ttype: Number,\r\n\t\tdefault: 1,\r\n\t},\r\n});\r\n\r\n// 响应式数据\r\nconst stepIndex = ref(props.el);\r\nconst step = ref([]);\r\n\r\n// 监听el属性变化\r\nwatch(() => props.el, (val) => {\r\n\tstepIndex.value = val;\r\n});\r\n\r\n// 处理内容\r\nconst content = () => {\r\n\tif (props.list) {\r\n\t\tstep.value = props.list.split(\",\");\r\n\t}\r\n};\r\n\r\n// 组件挂载时执行\r\nonMounted(() => {\r\n\tcontent();\r\n});\r\n\r\n// 监听list变化\r\nwatch(() => props.list, () => {\r\n\tcontent();\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n// 颜色变量定义\r\n$color-background: #c7ccd538;\r\n$color-selected: #165dff;\r\n$color-white: #fff;\r\n$color-light-bg: #f2f3f5;\r\n$color-dark-bg: #1e1e1e;\r\n\r\n.v-stepper__step {\r\n\tbackground: $color-background;\r\n\tposition: relative;\r\n}\r\n\r\n// 隐藏步骤数字\r\n:deep(.v-stepper__step__step) {\r\n\tdisplay: none !important;\r\n}\r\n\r\n.stepItem {\r\n\talign-items: center;\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tpadding: 24px;\r\n\tposition: relative;\r\n\tbackground: $color-background;\r\n\r\n\t// 暗色主题样式\r\n\t.v-theme--dark & {\r\n\t\tcolor: rgba(255, 255, 255, 0.5);\r\n\t}\r\n\r\n\t// 选中状态\r\n\t&.selected {\r\n\t\tbackground: $color-selected;\r\n\t\tcolor: $color-white !important;\r\n\r\n\t\t&.last-box::after {\r\n\t\t\tborder-color: transparent transparent transparent $color-selected;\r\n\t\t}\r\n\r\n\t\t:deep(.v-stepper__label) {\r\n\t\t\tcolor: $color-white !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n.colItem {\r\n\t&:first-child .first-box1::before {\r\n\t\tborder-color: transparent !important;\r\n\t}\r\n\r\n\t&:last-child .last-box::after {\r\n\t\tborder-color: transparent !important;\r\n\t}\r\n}\r\n\r\n.first-box1::before {\r\n\tposition: absolute;\r\n\tleft: 0;\r\n\tcontent: \"\";\r\n\twidth: 0;\r\n\theight: 0;\r\n\tz-index: 0;\r\n\tborder: 30px solid;\r\n\tborder-color: transparent transparent transparent $color-white;\r\n\r\n\t.v-theme--dark & {\r\n\t\tborder-color: transparent transparent transparent $color-dark-bg;\r\n\t}\r\n}\r\n\r\n.last-box::after {\r\n\tposition: absolute;\r\n\tright: -69px;\r\n\tcontent: \"\";\r\n\tz-index: 1;\r\n\twidth: 0;\r\n\theight: 0;\r\n\tborder: 35px solid;\r\n\tborder-color: transparent transparent transparent $color-light-bg;\r\n\r\n\t.v-theme--dark & {\r\n\t\tborder-color: transparent transparent transparent $color-background;\r\n\t}\r\n}\r\n\r\n.theme--dark.v-stepper {\r\n\tbackground: transparent;\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-upload\">\r\n <!-- 拖拽 / 点击上传区域 -->\r\n <div\r\n v-if=\"listType !== 'picture-card' && !detail\"\n :class=\"['vtk-upload__dragger', { 'is-dragover': isDragover, 'is-disabled': disabled }]\"\n title=\"点击上传\"\n @click=\"!disabled && triggerInput()\"\n @dragover.prevent=\"onDragover\"\r\n @dragleave.prevent=\"isDragover = false\"\r\n @drop.prevent=\"onDrop\"\r\n >\r\n <slot>\r\n <div class=\"vtk-upload__dragger-inner\">\r\n <VIcon size=\"40\" color=\"grey-lighten-1\">mdi-cloud-upload-outline</VIcon>\r\n <div class=\"text-body-2 mt-2 text-grey\">将文件拖到此处,或 <span class=\"text-primary\" style=\"cursor:pointer\">点击上传</span></div>\r\n <div v-if=\"tip\" class=\"text-caption text-grey-lighten-1 mt-1\">{{ tip }}</div>\r\n </div>\r\n </slot>\r\n </div>\r\n\r\n <!-- picture-card 模式 -->\r\n <div v-if=\"listType === 'picture-card'\" class=\"vtk-upload__picture-card-wrap\">\r\n <div\r\n v-for=\"file in fileList\"\r\n :key=\"file.uid\"\r\n class=\"vtk-upload__picture-card-item\"\r\n >\r\n <v-img :src=\"file.url || file.preview\" cover class=\"fill-height\" />\r\n <div class=\"vtk-upload__picture-card-mask\">\r\n <VBtn icon size=\"x-small\" variant=\"text\" color=\"white\" title=\"查看\" @click.stop=\"handlePreview(file)\">\n <VIcon>mdi-eye</VIcon>\n </VBtn>\n <VBtn v-if=\"!disabled && !detail\" icon size=\"x-small\" variant=\"text\" color=\"white\" title=\"删除\" @click.stop=\"handleRemove(file)\">\n <VIcon>mdi-delete</VIcon>\n </VBtn>\n </div>\r\n <!-- 上传进度 -->\r\n <div v-if=\"file.status === 'uploading'\" class=\"vtk-upload__picture-card-progress\">\r\n <v-progress-circular :model-value=\"file.percentage\" size=\"36\" color=\"white\" />\r\n </div>\r\n </div>\r\n\r\n <!-- 添加按钮 -->\r\n <div\r\n v-if=\"!disabled && !detail && (limit === 0 || fileList.length < limit)\"\n :class=\"['vtk-upload__picture-card-add', { 'is-dragover': isDragover }]\"\n title=\"添加文件\"\n @click=\"triggerInput()\"\n @dragover.prevent=\"onDragover\"\r\n @dragleave.prevent=\"isDragover = false\"\r\n @drop.prevent=\"onDrop\"\r\n >\r\n <VIcon size=\"28\" color=\"grey-lighten-1\">mdi-plus</VIcon>\r\n </div>\r\n </div>\r\n\r\n <!-- 隐藏的 input -->\r\n <input\r\n ref=\"inputRef\"\r\n type=\"file\"\r\n class=\"vtk-upload__input\"\r\n :accept=\"accept\"\r\n :multiple=\"multiple\"\r\n @change=\"onInputChange\"\r\n />\r\n\r\n <!-- 文件列表 (非 picture-card) -->\r\n <div v-if=\"showFileList && listType !== 'picture-card' && fileList.length > 0\" class=\"vtk-upload__list mt-2\">\r\n <div\r\n v-for=\"file in fileList\"\r\n :key=\"file.uid\"\r\n :class=\"['vtk-upload__list-item', `is-${file.status}`]\"\r\n style=\"cursor: pointer;\"\r\n >\r\n <VIcon size=\"18\" class=\"mr-1\" :color=\"file.status === 'error' ? 'error' : 'primary'\">\r\n {{ fileIcon(file) }}\r\n </VIcon>\r\n <span class=\"vtk-upload__list-item-name flex-grow-1 text-truncate\" @click=\"handlePreview(file)\" :title=\"file.name\">{{ file.name }}</span>\r\n <span v-if=\"file.status === 'uploading'\" class=\"text-caption text-grey ml-2\">{{ file.percentage }}%</span>\r\n <VBtn\r\n v-if=\"!disabled && !detail\"\n icon\r\n size=\"x-small\"\r\n variant=\"text\"\n color=\"grey\"\n class=\"ml-1\"\n title=\"删除\"\n @click=\"handleRemove(file)\"\n >\r\n <VIcon size=\"16\">mdi-close</VIcon>\r\n </VBtn>\r\n <!-- 进度条 -->\r\n <v-progress-linear\r\n v-if=\"file.status === 'uploading'\"\r\n :model-value=\"file.percentage\"\r\n color=\"primary\"\r\n class=\"vtk-upload__list-progress\"\r\n height=\"2\"\r\n />\r\n </div>\r\n </div>\r\n\r\n <!-- 预览 Dialog -->\r\n <VDialog v-model=\"previewVisible\" fullscreen scrollable @click:outside=\"closePreview\">\r\n <VCard class=\"vtk-upload__preview-card\">\r\n <v-toolbar color=\"primary\" density=\"comfortable\">\r\n <v-toolbar-title class=\"text-truncate\">{{ previewFile?.name }}</v-toolbar-title>\n <VSpacer />\n <VBtn icon variant=\"text\" title=\"新窗口打开\" @click=\"openCurrentPreview\">\n <VIcon>mdi-open-in-new</VIcon>\n </VBtn>\n <template v-if=\"isImage(previewFile)\">\n <VBtn icon variant=\"text\" title=\"缩小\" @click=\"zoomPreview(-0.3)\">\n <VIcon>mdi-magnify-minus-outline</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"放大\" @click=\"zoomPreview(0.3)\">\n <VIcon>mdi-magnify-plus-outline</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"向左旋转\" @click=\"rotatePreview(-90)\">\n <VIcon>mdi-rotate-left</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"向右旋转\" @click=\"rotatePreview(90)\">\n <VIcon>mdi-rotate-right</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"重置\" @click=\"resetPreviewTransform\">\n <VIcon>mdi-refresh</VIcon>\n </VBtn>\n </template>\n <VBtn icon variant=\"text\" title=\"关闭\" @click=\"closePreview\">\n <VIcon>mdi-close</VIcon>\n </VBtn>\n </v-toolbar>\r\n <div class=\"vtk-upload__preview-body\">\r\n <div v-if=\"isImage(previewFile)\" class=\"vtk-upload__preview-image-wrap\">\r\n <img\r\n class=\"vtk-upload__preview-image\"\r\n :src=\"previewFile?._previewSrc\"\r\n :alt=\"previewFile?.name\"\r\n :style=\"previewImageStyle\"\r\n draggable=\"false\"\r\n @pointerdown=\"startPreviewDrag\"\r\n />\r\n </div>\r\n <div v-else class=\"vtk-upload__preview-empty\">\r\n <VIcon size=\"64\">{{ isExcel(previewFile) ? 'mdi-microsoft-excel' : 'mdi-file-outline' }}</VIcon>\r\n <div class=\"mt-2\">{{ previewFile?.name }}</div>\r\n <div class=\"text-caption mt-1\">This file cannot be previewed online.</div>\r\n </div>\r\n </div>\r\n </VCard>\r\n </VDialog>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed, ref, watch } from 'vue';\r\nimport Request from '../../commons/request.js';\r\n\r\ndefineOptions({\r\n name: 'VtkUpload',\r\n inheritAttrs: false,\r\n});\r\n\r\nconst props = defineProps({\r\n /** v-model 文件列表 */\r\n modelValue: {\r\n type: Array,\r\n default: () => [],\r\n },\r\n /** 上传地址 */\r\n action: {\r\n type: String,\r\n default: '',\r\n },\r\n /** 接受的文件类型,同原生 accept */\r\n accept: {\r\n type: String,\r\n default: '',\r\n },\r\n /** 是否多选 */\r\n multiple: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n /** 最大上传数量,0 表示不限制 */\r\n limit: {\r\n type: Number,\r\n default: 0,\r\n },\r\n /** 单文件最大体积,单位 MB,0 表示不限制 */\r\n maxSize: {\r\n type: Number,\r\n default: 0,\r\n },\r\n /** 列表类型:text | picture | picture-card */\r\n listType: {\r\n type: String,\r\n default: 'text',\r\n validator: (v) => ['text', 'picture', 'picture-card'].includes(v),\r\n },\r\n /** 是否显示文件列表 */\r\n showFileList: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n /** 是否自动上传 */\r\n autoUpload: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n /** 是否禁用 */\r\n disabled: {\n type: Boolean,\n default: false,\n },\n /** 详情模式:隐藏上传和删除入口,仅展示已上传文件并保留查看 */\n detail: {\n type: Boolean,\n default: false,\n },\n /** 附加请求头 */\r\n headers: {\r\n type: Object,\r\n default: () => ({}),\r\n },\r\n /** 附加请求数据 */\r\n data: {\r\n type: Object,\r\n default: () => ({}),\r\n },\r\n /** 文件字段名 */\r\n name: {\r\n type: String,\r\n default: 'file',\r\n },\r\n /** 提示文字 */\r\n tip: {\r\n type: String,\r\n default: '',\r\n },\r\n /** 上传前钩子,返回 false 或 rejected Promise 则停止上传 */\r\n beforeUpload: {\r\n type: Function,\r\n default: null,\r\n },\r\n /** 移除前钩子 */\r\n beforeRemove: {\r\n type: Function,\r\n default: null,\r\n },\r\n});\r\n\r\nconst emit = defineEmits([\r\n 'update:modelValue',\r\n 'change',\r\n 'success',\r\n 'error',\r\n 'progress',\r\n 'remove',\r\n 'exceed',\r\n 'preview',\r\n]);\r\n\r\n/* -------------------- 内部状态 -------------------- */\r\nconst inputRef = ref(null);\r\nconst isDragover = ref(false);\r\nconst previewVisible = ref(false);\r\nconst previewFile = ref(null);\r\nconst previewScale = ref(1);\r\nconst previewRotation = ref(0);\r\nconst previewTranslateX = ref(0);\r\nconst previewTranslateY = ref(0);\r\nconst previewDragState = ref(null);\r\n\r\n// 内部维护文件列表\r\nconst fileList = ref([]);\n\r\nwatch(\r\n () => props.modelValue,\r\n (val) => {\r\n // 统一接收外部传入的 URL 列表或文件对象列表。\n fileList.value = normalizeFileList(val || []);\n },\r\n);\r\n\r\n/* -------------------- 工具函数 -------------------- */\r\nlet uidCounter = 0;\nconst genUid = () => `vtk-upload-${Date.now()}-${uidCounter++}`;\n\nconst getFileNameFromUrl = (url) => {\n const cleanUrl = String(url || '').split('?')[0].split('#')[0];\n const name = cleanUrl.substring(cleanUrl.lastIndexOf('/') + 1);\n try {\n return decodeURIComponent(name || cleanUrl || 'file');\n } catch (e) {\n return name || cleanUrl || 'file';\n }\n};\n\nconst normalizeFileList = (value) => {\n if (!Array.isArray(value)) return [];\n\n return value\n .filter((item) => item)\n .map((item) => {\n if (typeof item === 'string') {\n return {\n uid: genUid(),\n name: getFileNameFromUrl(item),\n size: 0,\n type: '',\n status: 'success',\n percentage: 100,\n raw: null,\n url: item,\n preview: '',\n response: null,\n };\n }\n\n return {\n uid: item.uid || genUid(),\n name: item.name || getFileNameFromUrl(item.url || item.preview),\n size: item.size || 0,\n type: item.type || '',\n status: item.status || 'success',\n percentage: item.percentage ?? 100,\n raw: item.raw || null,\n url: item.url || '',\n preview: item.preview || '',\n response: item.response || null,\n ...item,\n };\n });\n};\n\nfileList.value = normalizeFileList(props.modelValue || []);\n\nconst isImage = (file) => {\n if (!file) return false;\r\n return /image\\//.test(file.type) || /\\.(png|jpg|jpeg|gif|bmp|webp|svg)$/i.test(file.name || '');\r\n};\r\n\r\nconst fileIcon = (file) => {\r\n if (file.status === 'error') return 'mdi-file-alert-outline';\r\n if (isImage(file)) return 'mdi-file-image-outline';\r\n return 'mdi-file-outline';\r\n};\r\n\r\nconst previewImageStyle = computed(() => ({\r\n transform: `translate(${previewTranslateX.value}px, ${previewTranslateY.value}px) scale(${previewScale.value}) rotate(${previewRotation.value}deg)`,\r\n}));\r\n\r\n/* -------------------- 触发 input -------------------- */\r\nconst triggerInput = () => {\r\n inputRef.value && inputRef.value.click();\r\n};\r\n\r\n/* -------------------- 拖拽 -------------------- */\r\nconst onDragover = () => {\n if (!props.disabled && !props.detail) isDragover.value = true;\n};\n\nconst onDrop = (e) => {\n isDragover.value = false;\n if (props.disabled || props.detail) return;\n processFiles(Array.from(e.dataTransfer.files));\n};\n\r\n/* -------------------- input change -------------------- */\r\nconst onInputChange = (e) => {\n if (props.disabled || props.detail) return;\n processFiles(Array.from(e.target.files));\n // 清空,允许重复选同一文件\r\n e.target.value = '';\r\n};\r\n\r\n/* -------------------- 文件处理 -------------------- */\r\nconst processFiles = (rawFiles) => {\r\n if (!rawFiles.length) return;\r\n\r\n // 数量限制检查\r\n if (props.limit > 0 && fileList.value.length + rawFiles.length > props.limit) {\r\n emit('exceed', rawFiles, fileList.value);\r\n return;\r\n }\r\n\r\n rawFiles.forEach((raw) => {\r\n // 体积检查\r\n if (props.maxSize > 0 && raw.size / 1024 / 1024 > props.maxSize) {\r\n const errFile = buildFile(raw, 'error');\r\n emit('error', new Error(`文件 ${raw.name} 超过最大限制 ${props.maxSize}MB`), errFile, fileList.value);\r\n return;\r\n }\r\n\r\n const file = buildFile(raw, 'ready');\r\n\r\n // 生成预览\r\n if (isImage(raw)) {\r\n const reader = new FileReader();\r\n reader.onload = (e) => { file.preview = e.target.result; };\r\n reader.readAsDataURL(raw);\r\n }\r\n\r\n const beforeHook = props.beforeUpload ? props.beforeUpload(raw) : true;\r\n Promise.resolve(beforeHook).then((result) => {\r\n if (result === false) return;\r\n addFile(file);\r\n if (props.autoUpload && props.action) {\r\n uploadFile(file);\r\n }\r\n }).catch(() => {});\r\n });\r\n};\r\n\r\nconst buildFile = (raw, status) => ({\r\n uid: genUid(),\r\n name: raw.name,\r\n size: raw.size,\r\n type: raw.type,\r\n status,\r\n percentage: 0,\r\n raw,\r\n url: '',\r\n preview: '',\r\n response: null,\r\n});\r\n\r\nconst addFile = (file) => {\r\n fileList.value.push(file);\r\n syncModel();\r\n emit('change', file, fileList.value);\r\n};\r\n\r\nconst syncModel = () => {\r\n const urls = fileList.value\r\n .filter((f) => f.status === 'success' && f.url)\r\n .map((f) => String(f.url));\r\n emit('update:modelValue', urls);\r\n};\r\n\r\n/* -------------------- 上传逻辑 -------------------- */\r\nconst uploadFile = (file) => {\r\n file.status = 'uploading';\r\n const formData = new FormData();\r\n formData.append(props.name, file.raw);\r\n Object.entries(props.data).forEach(([k, v]) => formData.append(k, v));\r\n\r\n // 使用 axios 直接调,以获得 onUploadProgress\r\n const tokenKey = window.VTK_CONFIG?.storageKeys?.token || '_mis_acis_token';\r\n const token = window.$vtk?.storage?.get(tokenKey) || localStorage.getItem(tokenKey);\r\n\r\n const headers = {\r\n 'content-type': 'multipart/form-data',\r\n ...props.headers,\r\n };\r\n if (token) headers['Authorization'] = `Bearer ${token}`;\r\n\r\n Request.http(props.action, formData, 'POST', headers).then((res) => {\r\n file.status = 'success';\r\n file.response = res;\r\n // 兼容 { data: 'url' } 和 { data: { url: '...' } } 两种结构\r\n const url = typeof res?.data === 'string' ? res.data : (res?.data?.url || res?.url || '');\r\n if (url) file.url = url;\r\n console.log('[VtkUpload] res:', res, '| file.url:', file.url, '| fileList:', JSON.parse(JSON.stringify(fileList.value)));\r\n syncModel();\r\n emit('success', res, file, fileList.value);\r\n emit('change', file, fileList.value);\r\n }).catch((err) => {\r\n file.status = 'error';\r\n syncModel();\r\n emit('error', err, file, fileList.value);\r\n emit('change', file, fileList.value);\r\n });\r\n};\r\n\r\n/* -------------------- 移除文件 -------------------- */\r\nconst handleRemove = (file) => {\r\n const doRemove = () => {\r\n fileList.value = fileList.value.filter((f) => f.uid !== file.uid);\r\n syncModel();\r\n emit('remove', file, fileList.value);\r\n };\r\n\r\n if (props.beforeRemove) {\r\n Promise.resolve(props.beforeRemove(file, fileList.value)).then((result) => {\r\n if (result !== false) doRemove();\r\n }).catch(() => {});\r\n } else {\r\n doRemove();\r\n }\r\n};\r\n\r\n/* -------------------- 预览 -------------------- */\r\nconst isExcel = (file) => /\\.(xlsx|xls)$/i.test(file?.name || '');\r\n\r\nconst resetPreviewTransform = () => {\r\n previewScale.value = 1;\r\n previewRotation.value = 0;\r\n previewTranslateX.value = 0;\r\n previewTranslateY.value = 0;\r\n};\r\n\r\nconst closePreview = () => {\r\n previewVisible.value = false;\r\n};\r\n\r\nconst rotatePreview = (degrees) => {\r\n previewRotation.value += degrees;\r\n};\r\n\r\nconst zoomPreview = (step) => {\r\n const nextScale = Number((previewScale.value + step).toFixed(2));\r\n previewScale.value = Math.min(3, Math.max(0.2, nextScale));\r\n};\r\n\r\nconst startPreviewDrag = (event) => {\r\n if (previewScale.value <= 1) return;\r\n event.preventDefault();\r\n const target = event.currentTarget;\r\n previewDragState.value = {\r\n pointerId: event.pointerId,\r\n startX: event.clientX,\r\n startY: event.clientY,\r\n translateX: previewTranslateX.value,\r\n translateY: previewTranslateY.value,\r\n };\r\n target.setPointerCapture?.(event.pointerId);\r\n target.addEventListener('pointermove', movePreviewDrag);\r\n target.addEventListener('pointerup', endPreviewDrag, { once: true });\r\n target.addEventListener('pointercancel', endPreviewDrag, { once: true });\r\n};\r\n\r\nconst movePreviewDrag = (event) => {\r\n const state = previewDragState.value;\r\n if (!state || state.pointerId !== event.pointerId) return;\r\n previewTranslateX.value = state.translateX + event.clientX - state.startX;\r\n previewTranslateY.value = state.translateY + event.clientY - state.startY;\r\n};\r\n\r\nconst endPreviewDrag = (event) => {\r\n event.currentTarget?.releasePointerCapture?.(event.pointerId);\r\n event.currentTarget?.removeEventListener('pointermove', movePreviewDrag);\r\n previewDragState.value = null;\r\n};\r\n\r\nconst openFileInNewTab = (file, fileUrl) => {\n if (fileUrl) {\n window.open(fileUrl, '_blank');\n return;\n }\n\r\n if (file.raw instanceof File || file.raw instanceof Blob) {\r\n const blobUrl = URL.createObjectURL(file.raw);\r\n const win = window.open(blobUrl, '_blank');\r\n win?.addEventListener('unload', () => URL.revokeObjectURL(blobUrl));\n }\n};\n\nconst openCurrentPreview = () => {\n if (!previewFile.value) return;\n openFileInNewTab(previewFile.value, previewFile.value._previewSrc || previewFile.value.url || previewFile.value.preview);\n};\n\nconst handlePreview = (file) => {\n emit('preview', file);\r\n\r\n const fileUrl = file.url || file.preview;\r\n\r\n // Non-image files open in a new tab.\r\n if (!isImage(file) && !isExcel(file)) {\r\n openFileInNewTab(file, fileUrl);\r\n return;\r\n }\r\n\r\n // Excel:Office Online 查看器(需要文件有公网 URL)\r\n if (isExcel(file)) {\r\n if (fileUrl && /^https?:\\/\\//.test(fileUrl)) {\n window.open(`https://view.officeapps.live.com/op/view.aspx?src=${encodeURIComponent(fileUrl)}`, '_blank');\n } else {\n // Excel without a public URL falls back to the dialog hint.\n previewFile.value = { ...file, _previewSrc: fileUrl };\n resetPreviewTransform();\n previewVisible.value = true;\n }\r\n return;\r\n }\r\n\r\n // Images preview inside the dialog.\n previewFile.value = {\r\n ...file,\r\n _previewSrc: fileUrl,\r\n };\r\n resetPreviewTransform();\r\n previewVisible.value = true;\r\n};\r\n\r\nwatch(previewVisible, (visible) => {\r\n if (!visible) resetPreviewTransform();\r\n});\r\n\r\n/* -------------------- 对外暴露方法 -------------------- */\r\n/** 手动触发未上传文件的上传 */\r\nconst submit = () => {\r\n fileList.value\r\n .filter((f) => f.status === 'ready' && props.action)\r\n .forEach(uploadFile);\r\n};\r\n\r\n/** 清空文件列表 */\r\nconst clearFiles = () => {\r\n fileList.value = [];\r\n syncModel();\r\n};\r\n\r\n/** 手动移除某个文件 */\r\nconst remove = (file) => handleRemove(file);\r\n\r\ndefineExpose({ submit, clearFiles, remove });\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-upload {\r\n width: 100%;\r\n}\r\n\r\n/* ---- 拖拽区域 ---- */\r\n.vtk-upload__dragger {\r\n border: 1px dashed rgba(0, 0, 0, 0.2);\r\n border-radius: 6px;\r\n padding: 24px 16px;\r\n text-align: center;\r\n cursor: pointer;\r\n transition: border-color 0.2s, background 0.2s;\r\n background: transparent;\r\n\r\n &:hover:not(.is-disabled) {\r\n border-color: rgb(var(--v-theme-primary));\r\n }\r\n\r\n &.is-dragover {\r\n border-color: rgb(var(--v-theme-primary));\r\n background: rgba(var(--v-theme-primary), 0.05);\r\n }\r\n\r\n &.is-disabled {\r\n cursor: not-allowed;\r\n opacity: 0.6;\r\n }\r\n}\r\n\r\n/* ---- 文件列表 ---- */\r\n.vtk-upload__list {\r\n border-top: 1px solid rgba(0, 0, 0, 0.08);\r\n}\r\n\r\n.vtk-upload__list-item {\r\n position: relative;\r\n display: flex;\r\n align-items: center;\r\n padding: 4px 4px 4px 8px;\r\n border-radius: 4px;\r\n font-size: 13px;\r\n transition: background 0.15s;\r\n\r\n &:hover {\r\n background: rgba(0, 0, 0, 0.04);\r\n }\r\n\r\n &.is-error {\r\n color: rgb(var(--v-theme-error));\r\n }\r\n\r\n &.is-success .vtk-upload__list-item-name {\r\n cursor: pointer;\r\n &:hover { color: rgb(var(--v-theme-primary)); }\r\n }\r\n}\r\n\r\n.vtk-upload__list-item-name {\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n max-width: 500px;\r\n}\r\n\r\n.vtk-upload__list-progress {\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n}\r\n\r\n/* ---- picture-card ---- */\r\n.vtk-upload__picture-card-wrap {\r\n display: flex;\r\n flex-wrap: wrap;\r\n gap: 8px;\r\n}\r\n\r\n.vtk-upload__picture-card-item,\r\n.vtk-upload__picture-card-add {\r\n width: 100px;\r\n height: 100px;\r\n border-radius: 6px;\r\n overflow: hidden;\r\n}\r\n\r\n.vtk-upload__picture-card-item {\r\n position: relative;\r\n border: 1px solid rgba(0, 0, 0, 0.12);\r\n\r\n &:hover .vtk-upload__picture-card-mask {\r\n opacity: 1;\r\n }\r\n}\r\n\r\n.vtk-upload__picture-card-mask {\r\n position: absolute;\r\n inset: 0;\r\n background: rgba(0, 0, 0, 0.45);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n gap: 4px;\r\n opacity: 0;\r\n transition: opacity 0.2s;\r\n}\r\n\r\n.vtk-upload__picture-card-progress {\r\n position: absolute;\r\n inset: 0;\r\n background: rgba(0, 0, 0, 0.4);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.vtk-upload__picture-card-add {\r\n border: 1px dashed rgba(0, 0, 0, 0.2);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n cursor: pointer;\r\n transition: border-color 0.2s, background 0.2s;\r\n\r\n &:hover, &.is-dragover {\r\n border-color: rgb(var(--v-theme-primary));\r\n background: rgba(var(--v-theme-primary), 0.04);\r\n }\r\n}\r\n\r\n/* ---- 隐藏 input ---- */\r\n.vtk-upload__input {\r\n display: none;\r\n}\r\n\r\n/* ---- preview ---- */\r\n.vtk-upload__preview-card {\r\n height: 100vh;\r\n background: #111;\r\n}\r\n\r\n.vtk-upload__preview-body {\r\n height: calc(100vh - 64px);\r\n overflow: auto;\r\n background: #111;\r\n}\r\n\r\n.vtk-upload__preview-image-wrap {\r\n min-width: 100%;\r\n min-height: 100%;\r\n padding: 32px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.vtk-upload__preview-image {\r\n display: block;\r\n max-width: 90vw;\r\n max-height: calc(100vh - 128px);\r\n object-fit: contain;\r\n transform-origin: center center;\r\n transition: transform 0.2s ease;\r\n user-select: none;\r\n cursor: grab;\r\n touch-action: none;\r\n\r\n &:active {\r\n cursor: grabbing;\r\n }\r\n}\r\n\r\n.vtk-upload__preview-empty {\r\n min-height: 100%;\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 32px;\r\n color: rgba(255, 255, 255, 0.72);\r\n text-align: center;\r\n}\r\n</style>\r\n","import Request from \"./request.js\";\r\nimport Storage from \"./storage.js\";\r\nimport Message from \"../components/message/index.js\";\r\n\r\nfunction isAid(value) {\r\n const str = String(value || \"\");\r\n return !!str && !/^(https?:)?\\/\\//i.test(str) && !str.includes(\"/\") && !str.includes(\"?\");\r\n\r\n \r\n}\r\n\r\nfunction getLinkFromResponse(data) {\r\n if (!data) {\r\n return \"\";\r\n }\r\n\r\n if (typeof data === \"string\") {\r\n return data;\r\n }\r\n\r\n return data.puri || \"\";\r\n}\r\n\r\nfunction buildUrlWithParams(target, appendParams) {\r\n const queryString = target.includes(\"?\") ? target.split(\"?\")[1] : \"\";\r\n const queryParams = new URLSearchParams(queryString);\r\n const newParams = [];\r\n\r\n Object.entries(appendParams).forEach(([key, value]) => {\r\n if (!key || value === undefined || value === null || value === \"\") {\r\n return;\r\n }\r\n\r\n if (!queryParams.has(key)) {\r\n newParams.push(`${encodeURIComponent(key)}=${encodeURIComponent(value)}`);\r\n }\r\n });\r\n\r\n if (!newParams.length) {\r\n return target;\r\n }\r\n\r\n const joinSymbol = target.includes(\"?\") ? \"&\" : \"?\";\r\n return `${target}${joinSymbol}${newParams.join(\"&\")}`;\r\n}\r\n\r\nfunction appendParamsToUrl(targetUrl, appendParams) {\r\n const hashIndex = targetUrl.indexOf(\"#\");\r\n\r\n if (hashIndex === -1) {\r\n return buildUrlWithParams(targetUrl, appendParams);\r\n }\r\n\r\n const baseUrl = targetUrl.slice(0, hashIndex);\r\n const hashRoute = targetUrl.slice(hashIndex + 1);\r\n const newHashRoute = buildUrlWithParams(hashRoute, appendParams);\r\n return `${baseUrl}#${newHashRoute}`;\r\n}\r\n\r\nasync function resolveAidUrl(aid) {\r\n if (!aid) {\r\n return aid;\r\n }\r\n\r\n try {\r\n const res = await Request.postForm(\"/kudas/xfwez/apps\", { aid });\r\n const realUrl = res?.meta?.success ? getLinkFromResponse(res.data) : \"\";\r\n return realUrl || aid;\r\n } catch (error) {\r\n return aid;\r\n }\r\n}\r\n\r\nfunction buildAppendParams(sobject, sroute, stokenKey) {\r\n const appendParams = {};\r\n const storageKey = stokenKey || \"_mis_acis_token\";\r\n const stoken = Storage.get(storageKey);\r\n\r\n if (stoken !== undefined && stoken !== null && stoken !== \"\") {\r\n appendParams.stoken = stoken;\r\n }\r\n\r\n if (sroute) {\r\n appendParams.sroute = sroute;\r\n }\r\n\r\n if (sobject && typeof sobject === \"object\" && Object.keys(sobject).length) {\r\n appendParams.sobject = btoa(encodeURIComponent(JSON.stringify(sobject)));\r\n }\r\n\r\n return appendParams;\r\n}\r\n\r\n/**\r\n * 解析地址中的指定参数值。\r\n * @param {string} name 参数名。\r\n * @param {string} url 要解析的地址,不传时默认使用当前地址。\r\n * @return {string} 参数值;未找到时返回空字符串。\r\n */\r\nexport function GetQueryString(name, url = window.location.href) {\r\n const reg = new RegExp(`[?&]${name}=([^&^#^/]*)`, \"i\");\r\n const res = String(url || \"\").match(reg);\r\n return res ? decodeURIComponent(res[1]) : \"\";\r\n}\r\n\r\n/**\r\n * 追加应用访问参数。\r\n * @param {string} url 链接地址或应用 aid;不传时默认取当前地址。\r\n * @param {Object} sobject 参数对象;会按 `btoa(encodeURIComponent(JSON.stringify(sobject)))` 编码后追加为 `sobject` 参数。\r\n * @param {string} sroute 页面路由标识;传值后会在最终地址中追加 `sroute=xxx`。\r\n * @param {string} stokenKey 取 `stoken` 的存储键名,默认 `_mis_acis_token`。\r\n * @return {Promise<string>} 拼接后的链接地址。\r\n */\r\nexport async function appendAppParams(url, sobject = {}, sroute = \"\", stokenKey = \"_mis_acis_token\") {\r\n if (url === undefined || url === null || url === \"\" || url === 0 || url === \"0\") {\r\n Message.toast(\"应用标识错误\", { color: \"error\" });\r\n return \"\";\r\n }\r\n\r\n const source = url || window.location.href;\r\n\r\n if (!source) {\r\n return \"\";\r\n }\r\n\r\n const targetUrl = isAid(source) ? await resolveAidUrl(source) : source;\r\n return appendParamsToUrl(targetUrl, buildAppendParams(sobject, sroute, stokenKey));\r\n}\r\n","/**\r\n * 将数值转换成中文 '0:未启/1:已启'\r\n * \r\n * @param {*} val 数值\r\n * @param {*} map 值对\r\n * @return {string} 中文值\r\n */\r\nexport function dict(val, map) {\r\n let value = \"\";\r\n if (val && val.includes(\",\")) {\r\n value = val.split(\",\").map(item => pre(item, map)).join();\r\n } else {\r\n value = pre(val, map)\r\n }\r\n return value;\r\n}\r\n\r\nfunction pre(value, map) {\r\n if (value) {\r\n var val = Array.isArray(value) ? value : value.split(\",\");\r\n var maps = map?.split(\"/\");\r\n var results = []; // 创建一个空数组,用于存储匹配到的值\r\n // 遍历 val 数组\r\n for (var j = 0; j < val?.length; j++) {\r\n var currentVal = val[j]; // 获取当前要查找的键\r\n for (var i in maps) {\r\n var kv = maps[i].split(\":\");\r\n if (kv[0] == currentVal) {\r\n results.push(kv[1]); // 将匹配到的值添加到结果数组中\r\n break; // 找到匹配项后,跳出内层循环\r\n }\r\n }\r\n }\r\n return results.length > 0 ? results.join() : \"其他\";\r\n }\r\n\r\n}\r\n\r\n\r\n/**\r\n * 1,2字符残疾类别转换\r\n * \r\n * @param {*} val 数值\r\n * @return {string} 中文值\r\n */\r\nexport function analyType(val) {\r\n if (!val) {\r\n return ''\r\n }\r\n let newVal = ''\r\n let arr = ['视力', '听力', '言语', '肢体', '智力', '精神', '多重']\r\n for (let i = 1; i < 8; i++) {\r\n if (i === 1) {\r\n newVal = val.replace(i.toString(), arr[i - 1])\r\n } else {\r\n newVal = newVal.replace(i.toString(), arr[i - 1])\r\n }\r\n }\r\n return newVal;\r\n}\r\nexport function analyLevel(val) {\r\n if (!val) {\r\n return ''\r\n }\r\n let newVal = ''\r\n let arr = ['一级', '二级', '三级', '四级', '不限等级']\r\n for (let i = 1; i < 7; i++) {\r\n if (i === 1) {\r\n newVal = val.replace(i.toString(), arr[i - 1])\r\n } else {\r\n newVal = newVal.replace(i.toString(), arr[i - 1])\r\n }\r\n }\r\n return newVal;\r\n}","/**\r\n * \r\n * @param {*} value 需格式化的时间\r\n * @param {*} fmt 格式\r\n */\r\nexport function date(value, fmt) {\r\n if (!value || value == '无' || value == null) {\r\n fmt = '无';\r\n return fmt;\r\n }\r\n let getDate = new Date(value)\r\n let o = {\r\n 'M+': getDate.getMonth() + 1,\r\n 'd+': getDate.getDate(),\r\n 'H+': getDate.getHours(),\r\n 'h+': getDate.getHours(),\r\n 'm+': getDate.getMinutes(),\r\n 's+': getDate.getSeconds(),\r\n 'q+': Math.floor((getDate.getMonth() + 3) / 3),\r\n 'S': getDate.getMilliseconds()\r\n }\r\n if (/(y+)/.test(fmt)) {\r\n fmt = fmt.replace(RegExp.$1, (getDate.getFullYear() + '').substr(4 - RegExp.$1.length))\r\n }\r\n for (let k in o) {\r\n if (new RegExp('(' + k + ')').test(fmt)) {\r\n fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))\r\n }\r\n }\r\n return fmt\r\n\r\n}\r\n\r\n\r\n/**\r\n * 数字格式化 '0,000.00'\r\n * @param {*} val 数值\r\n * @param {*} fmt 格式\r\n * @return {string} 数字字符串\r\n */\r\nexport function num(val, fmt) {\r\n if (isNaN(val) || val === '' || val === null) {\r\n return val;\r\n }\r\n\r\n // 移除了对Strings和Datetime的依赖,这些在当前上下文中未定义\r\n var numValue = parseFloat(val);\r\n var neg = numValue < 0 ? \"-\" : \"\"; // 正负数\r\n var absValue = Math.abs(numValue);\r\n\r\n // 解析格式字符串,确定小数位数\r\n var fix = 0;\r\n if (fmt && fmt.includes('.')) {\r\n fix = fmt.length - fmt.lastIndexOf('.') - 1;\r\n }\r\n\r\n // 是否需要千分位分隔符\r\n var needSep = fmt && fmt.includes(',');\r\n\r\n // 处理小数部分\r\n var xs = fix > 0 ? absValue.toFixed(fix) : Math.round(absValue);\r\n var decimalPart = fix > 0 ? '.' + xs.toString().split('.')[1] : '';\r\n\r\n // 处理整数部分\r\n var integerPart = fix > 0 ? Math.floor(absValue).toString() : xs.toString();\r\n\r\n // 添加千分位分隔符\r\n if (needSep && integerPart.length > 3) {\r\n integerPart = integerPart.replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\");\r\n }\r\n\r\n return neg + integerPart + decimalPart;\r\n}\r\n\r\n\r\n/**\r\n * 年龄\r\n * @param {*} val 时间 yyyy-MM-dd\r\n * @return {string} 年龄\r\n */\r\nexport function age(val) {\r\n let birthdays = new Date(val.slice(0, 10).replace(/-/g, \"/\"));\r\n let d = new Date();\r\n let age = d.getFullYear() - birthdays.getFullYear() - ((d.getMonth() < birthdays.getMonth() || (d.getMonth() === birthdays.getMonth() && d.getDate() < birthdays.getDate())) ? 1 : 0);\r\n return age;\r\n}\r\n\r\n/**\r\n * 指定中文大于len,用...省略号表示,达到美观效果\r\n * @param {*} val 需格式的中文\r\n * @param {*} len 需格式的长度\r\n */\r\nexport function txt(val, len) {\r\n if (val?.length > len) {\r\n return val.slice(0, len) + \"...\";\r\n } else {\r\n return val;\r\n }\r\n\r\n}\r\n\r\n/**\r\n * 取数据绝对值\r\n * @param {*} val 手机号\r\n */\r\nexport function abs(val) {\r\n return isNaN(val) ? 0 : Math.abs(val)\r\n}\r\n\r\n\r\n\r\n\r\n\r\n","/**\r\n * 脱敏手机号码\r\n * @param {*} val 手机号\r\n * @return {string} 手机号码\r\n */\r\nexport function mobile(val) {\r\n return val.replace(/(\\d{3})\\d{4}(\\d{4})/, \"$1****$2\");\r\n}\r\n\r\n\r\n/**\r\n * 脱敏身份证号\r\n * @param {*} val 身份证号\r\n * @return {string} 身份证号\r\n */\r\nexport function idcard(val) {\r\n if (val) {\r\n return val.replace(/^(.{4})(?:\\d+)(.{4})$/, \"$1** **** ****$2\");\r\n }\r\n}\r\n\r\n\r\n\r\n\r\n\r\n","export const red = {\n base: '#f44336',\n lighten5: '#ffebee',\n lighten4: '#ffcdd2',\n lighten3: '#ef9a9a',\n lighten2: '#e57373',\n lighten1: '#ef5350',\n darken1: '#e53935',\n darken2: '#d32f2f',\n darken3: '#c62828',\n darken4: '#b71c1c',\n accent1: '#ff8a80',\n accent2: '#ff5252',\n accent3: '#ff1744',\n accent4: '#d50000'\n};\nexport const pink = {\n base: '#e91e63',\n lighten5: '#fce4ec',\n lighten4: '#f8bbd0',\n lighten3: '#f48fb1',\n lighten2: '#f06292',\n lighten1: '#ec407a',\n darken1: '#d81b60',\n darken2: '#c2185b',\n darken3: '#ad1457',\n darken4: '#880e4f',\n accent1: '#ff80ab',\n accent2: '#ff4081',\n accent3: '#f50057',\n accent4: '#c51162'\n};\nexport const purple = {\n base: '#9c27b0',\n lighten5: '#f3e5f5',\n lighten4: '#e1bee7',\n lighten3: '#ce93d8',\n lighten2: '#ba68c8',\n lighten1: '#ab47bc',\n darken1: '#8e24aa',\n darken2: '#7b1fa2',\n darken3: '#6a1b9a',\n darken4: '#4a148c',\n accent1: '#ea80fc',\n accent2: '#e040fb',\n accent3: '#d500f9',\n accent4: '#aa00ff'\n};\nexport const deepPurple = {\n base: '#673ab7',\n lighten5: '#ede7f6',\n lighten4: '#d1c4e9',\n lighten3: '#b39ddb',\n lighten2: '#9575cd',\n lighten1: '#7e57c2',\n darken1: '#5e35b1',\n darken2: '#512da8',\n darken3: '#4527a0',\n darken4: '#311b92',\n accent1: '#b388ff',\n accent2: '#7c4dff',\n accent3: '#651fff',\n accent4: '#6200ea'\n};\nexport const indigo = {\n base: '#3f51b5',\n lighten5: '#e8eaf6',\n lighten4: '#c5cae9',\n lighten3: '#9fa8da',\n lighten2: '#7986cb',\n lighten1: '#5c6bc0',\n darken1: '#3949ab',\n darken2: '#303f9f',\n darken3: '#283593',\n darken4: '#1a237e',\n accent1: '#8c9eff',\n accent2: '#536dfe',\n accent3: '#3d5afe',\n accent4: '#304ffe'\n};\nexport const blue = {\n base: '#2196f3',\n lighten5: '#e3f2fd',\n lighten4: '#bbdefb',\n lighten3: '#90caf9',\n lighten2: '#64b5f6',\n lighten1: '#42a5f5',\n darken1: '#1e88e5',\n darken2: '#1976d2',\n darken3: '#1565c0',\n darken4: '#0d47a1',\n accent1: '#82b1ff',\n accent2: '#448aff',\n accent3: '#2979ff',\n accent4: '#2962ff'\n};\nexport const lightBlue = {\n base: '#03a9f4',\n lighten5: '#e1f5fe',\n lighten4: '#b3e5fc',\n lighten3: '#81d4fa',\n lighten2: '#4fc3f7',\n lighten1: '#29b6f6',\n darken1: '#039be5',\n darken2: '#0288d1',\n darken3: '#0277bd',\n darken4: '#01579b',\n accent1: '#80d8ff',\n accent2: '#40c4ff',\n accent3: '#00b0ff',\n accent4: '#0091ea'\n};\nexport const cyan = {\n base: '#00bcd4',\n lighten5: '#e0f7fa',\n lighten4: '#b2ebf2',\n lighten3: '#80deea',\n lighten2: '#4dd0e1',\n lighten1: '#26c6da',\n darken1: '#00acc1',\n darken2: '#0097a7',\n darken3: '#00838f',\n darken4: '#006064',\n accent1: '#84ffff',\n accent2: '#18ffff',\n accent3: '#00e5ff',\n accent4: '#00b8d4'\n};\nexport const teal = {\n base: '#009688',\n lighten5: '#e0f2f1',\n lighten4: '#b2dfdb',\n lighten3: '#80cbc4',\n lighten2: '#4db6ac',\n lighten1: '#26a69a',\n darken1: '#00897b',\n darken2: '#00796b',\n darken3: '#00695c',\n darken4: '#004d40',\n accent1: '#a7ffeb',\n accent2: '#64ffda',\n accent3: '#1de9b6',\n accent4: '#00bfa5'\n};\nexport const green = {\n base: '#4caf50',\n lighten5: '#e8f5e9',\n lighten4: '#c8e6c9',\n lighten3: '#a5d6a7',\n lighten2: '#81c784',\n lighten1: '#66bb6a',\n darken1: '#43a047',\n darken2: '#388e3c',\n darken3: '#2e7d32',\n darken4: '#1b5e20',\n accent1: '#b9f6ca',\n accent2: '#69f0ae',\n accent3: '#00e676',\n accent4: '#00c853'\n};\nexport const lightGreen = {\n base: '#8bc34a',\n lighten5: '#f1f8e9',\n lighten4: '#dcedc8',\n lighten3: '#c5e1a5',\n lighten2: '#aed581',\n lighten1: '#9ccc65',\n darken1: '#7cb342',\n darken2: '#689f38',\n darken3: '#558b2f',\n darken4: '#33691e',\n accent1: '#ccff90',\n accent2: '#b2ff59',\n accent3: '#76ff03',\n accent4: '#64dd17'\n};\nexport const lime = {\n base: '#cddc39',\n lighten5: '#f9fbe7',\n lighten4: '#f0f4c3',\n lighten3: '#e6ee9c',\n lighten2: '#dce775',\n lighten1: '#d4e157',\n darken1: '#c0ca33',\n darken2: '#afb42b',\n darken3: '#9e9d24',\n darken4: '#827717',\n accent1: '#f4ff81',\n accent2: '#eeff41',\n accent3: '#c6ff00',\n accent4: '#aeea00'\n};\nexport const yellow = {\n base: '#ffeb3b',\n lighten5: '#fffde7',\n lighten4: '#fff9c4',\n lighten3: '#fff59d',\n lighten2: '#fff176',\n lighten1: '#ffee58',\n darken1: '#fdd835',\n darken2: '#fbc02d',\n darken3: '#f9a825',\n darken4: '#f57f17',\n accent1: '#ffff8d',\n accent2: '#ffff00',\n accent3: '#ffea00',\n accent4: '#ffd600'\n};\nexport const amber = {\n base: '#ffc107',\n lighten5: '#fff8e1',\n lighten4: '#ffecb3',\n lighten3: '#ffe082',\n lighten2: '#ffd54f',\n lighten1: '#ffca28',\n darken1: '#ffb300',\n darken2: '#ffa000',\n darken3: '#ff8f00',\n darken4: '#ff6f00',\n accent1: '#ffe57f',\n accent2: '#ffd740',\n accent3: '#ffc400',\n accent4: '#ffab00'\n};\nexport const orange = {\n base: '#ff9800',\n lighten5: '#fff3e0',\n lighten4: '#ffe0b2',\n lighten3: '#ffcc80',\n lighten2: '#ffb74d',\n lighten1: '#ffa726',\n darken1: '#fb8c00',\n darken2: '#f57c00',\n darken3: '#ef6c00',\n darken4: '#e65100',\n accent1: '#ffd180',\n accent2: '#ffab40',\n accent3: '#ff9100',\n accent4: '#ff6d00'\n};\nexport const deepOrange = {\n base: '#ff5722',\n lighten5: '#fbe9e7',\n lighten4: '#ffccbc',\n lighten3: '#ffab91',\n lighten2: '#ff8a65',\n lighten1: '#ff7043',\n darken1: '#f4511e',\n darken2: '#e64a19',\n darken3: '#d84315',\n darken4: '#bf360c',\n accent1: '#ff9e80',\n accent2: '#ff6e40',\n accent3: '#ff3d00',\n accent4: '#dd2c00'\n};\nexport const brown = {\n base: '#795548',\n lighten5: '#efebe9',\n lighten4: '#d7ccc8',\n lighten3: '#bcaaa4',\n lighten2: '#a1887f',\n lighten1: '#8d6e63',\n darken1: '#6d4c41',\n darken2: '#5d4037',\n darken3: '#4e342e',\n darken4: '#3e2723'\n};\nexport const blueGrey = {\n base: '#607d8b',\n lighten5: '#eceff1',\n lighten4: '#cfd8dc',\n lighten3: '#b0bec5',\n lighten2: '#90a4ae',\n lighten1: '#78909c',\n darken1: '#546e7a',\n darken2: '#455a64',\n darken3: '#37474f',\n darken4: '#263238'\n};\nexport const grey = {\n base: '#9e9e9e',\n lighten5: '#fafafa',\n lighten4: '#f5f5f5',\n lighten3: '#eeeeee',\n lighten2: '#e0e0e0',\n lighten1: '#bdbdbd',\n darken1: '#757575',\n darken2: '#616161',\n darken3: '#424242',\n darken4: '#212121'\n};\nexport const shades = {\n black: '#000000',\n white: '#ffffff',\n transparent: '#ffffff00'\n};\nexport default {\n red,\n pink,\n purple,\n deepPurple,\n indigo,\n blue,\n lightBlue,\n cyan,\n teal,\n green,\n lightGreen,\n lime,\n yellow,\n amber,\n orange,\n deepOrange,\n brown,\n blueGrey,\n grey,\n shades\n};\n//# sourceMappingURL=colors.js.map","import colors from 'vuetify/lib/util/colors';\r\n\r\nconst theme_colors = [\r\n {\r\n name: 'Blue-light',\r\n scheme: 'md-blue-500-scheme',\r\n dark: true,\r\n primary: colors.blue.base,\r\n secondary: colors.blue.lighten4, // #FFCDD2\r\n accent: colors.blue.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Yellow-light',\r\n scheme: 'md-amber-a700-scheme',\r\n dark: true,\r\n primary: colors.amber.darken1,\r\n secondary: colors.amber.lighten4, // #FFCDD2\r\n accent: colors.amber.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Red-light',\r\n scheme: 'md-red-a400-scheme',\r\n dark: true,\r\n primary: colors.red.accent3,\r\n secondary: colors.red.lighten4, // #FFCDD2\r\n accent: colors.red.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Pink-light',\r\n dark: false,\r\n scheme: 'md-pink-a100-scheme',\r\n primary: colors.pink.accent1,\r\n secondary: colors.pink.lighten4, // #FFCDD2\r\n accent: colors.pink.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Purple-light',\r\n dark: false,\r\n scheme: 'md-purple-a700-scheme',\r\n primary: colors.purple.accent4,\r\n secondary: colors.purple.lighten4, // #FFCDD2\r\n accent: colors.purple.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'DeepPurple-light',\r\n dark: false,\r\n scheme: 'md-deep-purple-a700-scheme',\r\n primary: colors.deepPurple.base,\r\n secondary: colors.deepPurple.lighten4, // #FFCDD2\r\n accent: colors.deepPurple.accent2, // #3F51B5\r\n }\r\n];\r\n\r\nconst navi_colors = [\r\n {\r\n name: 'black',\r\n class: 'black'\r\n },\r\n {\r\n name: 'red-pink',\r\n class: 'gradient-red-pink'\r\n },\r\n {\r\n name: 'blue-grey-blue',\r\n class: 'gradient-blue-grey-blue'\r\n },\r\n {\r\n name: 'green-teal',\r\n class: 'gradient-green-teal'\r\n },\r\n {\r\n name: 'purple-deep-purple',\r\n class: 'gradient-purple-deep-purple'\r\n },\r\n {\r\n name: 'purple-amber',\r\n class: 'gradient-purple-amber'\r\n },\r\n {\r\n name: 'indigo-purple',\r\n class: 'gradient-indigo-purple'\r\n },\r\n {\r\n name: 'deep-purple-blue',\r\n class: 'gradient-deep-purple-blue'\r\n },\r\n {\r\n name: 'deep-orange-orange',\r\n class: 'gradient-deep-orange-orange'\r\n },\r\n {\r\n name: 'light-blue-cyan',\r\n class: 'gradient-light-blue-cyan'\r\n },\r\n {\r\n name: 'timber',\r\n class: 'gradient-timber'\r\n },\r\n {\r\n name: 'strawberry',\r\n class: 'gradient-strawberry'\r\n },\r\n {\r\n name: 'orange',\r\n class: 'gradient-orange'\r\n },\r\n {\r\n name: 'pomegranate',\r\n class: 'gradient-pomegranate'\r\n },\r\n {\r\n name: 'green-tea',\r\n class: 'gradient-green-tea'\r\n },\r\n {\r\n name: 'blackberry',\r\n class: 'gradient-blackberry'\r\n },\r\n {\r\n name: 'plum',\r\n class: 'gradient-plum'\r\n },\r\n {\r\n name: 'passion-fruit',\r\n class: 'gradient-passion-fruit'\r\n },\r\n {\r\n name: 'sublime-vivid',\r\n class: 'gradient-sublime-vivid'\r\n },\r\n {\r\n name: 'summer',\r\n class: 'gradient-summer'\r\n },\r\n {\r\n name: 'crystal-clear',\r\n class: 'gradient-crystal-clear'\r\n },\r\n {\r\n name: 'dawn',\r\n class: 'gradient-dawn'\r\n },\r\n {\r\n name: 'grapefruit-sunset',\r\n class: 'gradient-grapefruit-sunset'\r\n },\r\n {\r\n name: 'man-of-steel',\r\n class: 'gradient-man-of-steel'\r\n }\r\n]\r\n\r\nexport default { theme_colors, navi_colors }\r\n","/** https://github.com/shadowOfCode/bee.js */\r\nconst Validation = {\r\n //手机号码\r\n isMobile: function (input) {\r\n return /^(?:\\+86)?(?:13\\d|14[57]|15[0-35-9]|17[35-8]|18\\d)\\d{8}$|^(?:\\+86)?170[057-9]\\d{7}$/.test(input);\r\n },\r\n //手机号码简单校验,只校验长度\r\n isMobileSize: function (input) {\r\n return /^(?:\\+86)?1\\d{10}$/.test(input);\r\n },\r\n isPhone: function (input) {\r\n return /^(?:\\(\\d{3,4}\\)|\\d{3,4}-)?\\d{7,8}(?:-\\d{1,4})?$/.test(input);\r\n },\r\n isCall: (input) => {\r\n return this.isPhone(input) || this.isMobile(input);\r\n },\r\n //邮箱格式校验\r\n isEmail: function (input) {\r\n return /^[-\\w+]+(?:\\.[-\\w]+)*@[-a-z0-9]+(?:\\.[a-z0-9]+)*(?:\\.[a-z]{2,})$/i.test(input);\r\n },\r\n //18位身份证简单校验\r\n isIdCardSimple: function (idCard) {\r\n return /^(?:1[1-5]|2[1-3]|3[1-7]|4[1-6]|5[0-4]|6[1-5])\\d{4}(?:1[89]|20)\\d{2}(?:0[1-9]|1[0-2])(?:0[1-9]|[12]\\d|3[01])\\d{3}(?:\\d|[xX])$/.test(idCard);\r\n },\r\n // 真实姓名校验\r\n isName: function (input) {\r\n return /^([\\u4e00-\\u9fa5]{1,20}|[a-zA-Z.\\s]{1,20})$/.test(input);\r\n },\r\n //\r\n //18位身份证严格校验\r\n isIdCard: function (idCard) {\r\n let checkCode = (input) => {\r\n var multiplier = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];\r\n var ids = input.split(\"\");\r\n var len = 17, sum = 0;\r\n for (var i = 0; i < len; i++) {\r\n sum += ids[i] * multiplier[i];\r\n }\r\n var remainder = sum % 11;\r\n var checkCodeArr = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];\r\n var result = checkCodeArr[remainder];\r\n return result === input[17];\r\n }\r\n //先校验格式\r\n if (this.isIdCardSimple(idCard)) {\r\n //校验日期时间是否合法\r\n var dateStr = idCard.substr(6, 8);\r\n var dateStrNew = dateStr.replace(/(\\d{4})(\\d{2})(\\d{2})/, \"$1/$2/$3\");\r\n var dateObj = new Date(dateStrNew);\r\n var month = dateObj.getMonth() + 1;\r\n if (parseInt(dateStr.substr(4, 2)) === month) {\r\n return checkCode(idCard);\r\n }\r\n }\r\n return false;\r\n },\r\n getFromIdCard: (idCard) => {\r\n var area = idCard.substr(0, 6);\r\n var birth = idCard.substr(6, 8).replace(/(\\d{4})(\\d{2})(\\d{2})/, '$1年$2月$3日');\r\n var age = new Date().getFullYear() - idCard.substr(6, 4) + 1;\r\n var sex = (idCard.substr(16, 1) % 2 === 0) ? '女' : '男';\r\n\r\n return {\r\n 'area': area,\r\n 'birth': birth,\r\n 'age': age,\r\n 'sex': sex\r\n };\r\n }\r\n};\r\n\r\nexport default Validation;","<template>\r\n <VDialog v-model=\"isActive\" persistent :width=\"options.width\">\r\n <VCard :color=\"options.color\">\r\n <VCardTitle>{{ options.title }}</VCardTitle>\r\n <VCardText v-if=\"options.text\">\r\n {{ options.text }}\r\n </VCardText>\r\n <VCardActions>\r\n <VSpacer />\r\n <VBtn text @click=\"close_modal\">确定</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VDialog>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js' // 根据实际路径调整\r\n\r\nconst messageStore = useMessageStore()\r\n\r\n\r\n// 使用 computed 获取响应式数据\r\nconst isActive = computed(() => messageStore.alert?.isActive || false)\r\nconst options = computed(() => messageStore.alert?.options || {})\r\n\r\n// 关闭模态框方法\r\nconst close_modal = () => {\r\n messageStore.hide('alert')\r\n}\r\n</script>","<template>\r\n <VDialog v-model=\"isActive\" persistent :max-width=\"options.width || 400\">\r\n <VCard :color=\"options.color\">\r\n <VCardTitle>{{ options.title }}</VCardTitle>\r\n <VCardText v-if=\"options.text\">\r\n {{ options.text }}\r\n </VCardText>\r\n <VCardActions>\r\n <VSpacer />\r\n <VBtn text @click=\"cancel\">{{ options.cancelText || '取消' }}</VBtn>\r\n <VBtn text @click=\"confirm\">{{ options.confirmText || '确定' }}</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VDialog>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst messageStore = useMessageStore()\r\n\r\n// 使用 computed 获取响应式数据\r\nconst isActive = computed(() => messageStore.confirm?.isActive || false)\r\nconst options = computed(() => messageStore.confirm?.options || {})\r\n\r\n// 确认操作\r\nconst confirm = () => {\r\n // 如果 options.onConfirm 存在则执行回调\r\n if (typeof options.value.onConfirm === 'function') {\r\n options.value.onConfirm()\r\n }\r\n messageStore.hide('confirm')\r\n}\r\n\r\n// 取消操作\r\nconst cancel = () => {\r\n // 如果 options.onCancel 存在则执行回调\r\n if (typeof options.value.onCancel === 'function') {\r\n options.value.onCancel()\r\n }\r\n messageStore.hide('confirm')\r\n}\r\n</script>","<template>\r\n <v-overlay v-model=\"isActive\" persistent class=\"align-center justify-center\" :style=\"{ zIndex: 9999 }\">\r\n <v-progress-circular indeterminate size=\"64\" width=\"6\" color=\"primary\"></v-progress-circular>\r\n </v-overlay>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst messageStore = useMessageStore()\r\n\r\nconst isActive = computed(() => messageStore.loading?.isActive || false)\r\n</script>\r\n","<template>\r\n <div class=\"text-center\">\r\n <vtk-alert />\r\n <vtk-confirm />\r\n <vtk-loading />\r\n <vtk-prompt />\r\n <vtk-toast />\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport vtkAlert from \"./alert.vue\";\r\nimport vtkConfirm from \"./confirm.vue\";\r\nimport vtkLoading from \"./loading.vue\";\r\nimport vtkPrompt from \"./prompt.vue\";\r\nimport vtkToast from \"./toast.vue\";\r\nexport default {\r\n name: \"vtkMessage\",\r\n components: {\r\n vtkAlert,\r\n vtkConfirm,\r\n vtkLoading,\r\n vtkPrompt,\r\n vtkToast,\r\n },\r\n};\r\n</script>","<template>\r\n <VDialog v-model=\"isActive\" persistent :width=\"options.width\">\r\n <VCard :color=\"options.color\">\r\n <VCardTitle>{{ options.title }}</VCardTitle>\r\n <VCardText>\r\n <VTextField\r\n v-model=\"inputValue\"\r\n :label=\"options.label\"\r\n :placeholder=\"options.placeholder\"\r\n :type=\"options.inputType || 'text'\"\r\n outlined\r\n dense\r\n />\r\n <div v-if=\"options.text\" class=\"mt-2\">\r\n {{ options.text }}\r\n </div>\r\n </VCardText>\r\n <VCardActions>\r\n <VSpacer />\r\n <VBtn text @click=\"cancel\">{{ options.cancelText || '取消' }}</VBtn>\r\n <VBtn text @click=\"confirm\">{{ options.confirmText || '确定' }}</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VDialog>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst messageStore = useMessageStore()\r\nconst inputValue = ref('')\r\n\r\n// 使用 computed 获取响应式数据\r\nconst isActive = computed(() => messageStore.prompt?.isActive || false)\r\nconst options = computed(() => messageStore.prompt?.options || {})\r\n\r\n// 确认操作\r\nconst confirm = () => {\r\n // 如果 options.onConfirm 存在则执行回调\r\n if (typeof options.value.onConfirm === 'function') {\r\n options.value.onConfirm(inputValue.value)\r\n }\r\n messageStore.hide('prompt')\r\n inputValue.value = '' // 清空输入值\r\n}\r\n\r\n// 取消操作\r\nconst cancel = () => {\r\n // 如果 options.onCancel 存在则执行回调\r\n if (typeof options.value.onCancel === 'function') {\r\n options.value.onCancel()\r\n }\r\n messageStore.hide('prompt')\r\n inputValue.value = '' // 清空输入值\r\n}\r\n</script>","<template>\r\n\t<VSnackbar v-model=\"isActive\" :timeout=\"options.timeout > 0 ? options.timeout : 3000\" :color=\"options.color\" centered @update:modelValue=\"onModelUpdate\">\r\n\t\t{{ options.text }}\r\n\t\t<template v-slot:actions>\r\n\t\t\t<VBtn text icon @click=\"close_modal()\">\r\n\t\t\t\t<VIcon>mdi-close</VIcon>\r\n\t\t\t</VBtn>\r\n\t\t</template>\r\n\t</VSnackbar>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from \"vue\";\r\nimport { useMessageStore } from \"../../stores/message.js\";\r\n\r\nconst messageStore = useMessageStore();\r\n\r\nconst isActive = computed({\r\n\tget: () => messageStore.toast?.isActive || false,\r\n\tset: (value) => {\r\n\t\tif (messageStore.toast) {\r\n\t\t\tmessageStore.toast.isActive = value;\r\n\t\t}\r\n\t},\r\n});\r\n\r\nconst options = computed(() => messageStore.toast?.options || {});\r\n\r\nconst close_modal = () => {\r\n\tmessageStore.hide(\"toast\");\r\n};\r\n\r\n// 监听模型值更新\r\nconst onModelUpdate = (value) => {\r\n\tif (!value) {\r\n\t\t// Snackbar 关闭时确保 store 状态同步\r\n\t\tmessageStore.hide(\"toast\");\r\n\t}\r\n};\r\n</script>\r\n<style lang=\"scss\" scoped>\r\n:deep(.v-snackbar__wrapper) {\r\n\ttop: 24px;\r\n}\r\n</style>\r\n","/**\r\n * Specter PUI - Vue 3 组件库\r\n */\r\n\r\nexport { default as VtkArea } from \"./components/assembly/VtkArea.vue\";\r\nexport { default as VtkAreaTabs } from \"./components/assembly/VtkAreaTabs.vue\";\r\nexport { default as VtkBreadcrumb } from \"./components/assembly/VtkBreadcrumb.vue\";\r\nexport { default as VtkCheckbox } from \"./components/assembly/VtkCheckbox.vue\";\r\nexport { default as VtkCount } from \"./components/assembly/VtkCount.vue\";\nexport { default as VtkDatePicker } from \"./components/assembly/VtkDatePicker.vue\";\nexport { default as VtkDateSelector } from \"./components/assembly/VtkDateSelector.vue\";\nexport { default as VtkDateTimePicker } from \"./components/assembly/VtkDateTimePicker.vue\";\nexport { default as VtkDept } from \"./components/assembly/VtkDept.vue\";\nexport { default as VtkEmpty } from \"./components/assembly/VtkEmpty.vue\";\r\nexport { default as VtkFab } from \"./components/assembly/VtkFab.vue\";\r\nexport { default as VtkFormItem } from \"./components/assembly/VtkFormItem.vue\";\r\nexport { default as VtkImg } from \"./components/assembly/VtkImg.vue\";\r\nexport { default as VtkPage } from \"./components/assembly/VtkPage.vue\";\r\nexport { default as VtkPdf } from \"./components/assembly/VtkPdf.vue\";\r\nexport { default as VtkProj } from \"./components/assembly/VtkProj.vue\";\r\nexport { default as VtkRadio } from \"./components/assembly/VtkRadio.vue\";\r\nexport { default as VtkSearch } from \"./components/assembly/VtkSearch.vue\";\r\nexport { default as VtkSelect } from \"./components/assembly/VtkSelect.vue\";\r\nexport { default as VtkStepper } from \"./components/assembly/VtkStepper.vue\";\r\nexport { default as VtkUpload } from \"./components/assembly/VtkUpload.vue\";\r\n\r\nexport * from \"./commons/location.js\";\r\nexport * from \"./commons/filters/dictionary.js\";\r\nexport * from \"./commons/filters/format.js\";\r\nexport * from \"./commons/filters/mask.js\";\r\nexport { default as request } from \"./commons/request.js\";\r\nexport { default as storage } from \"./commons/storage.js\";\r\nexport { default as themes } from \"./commons/themes.js\";\r\nexport * from \"./commons/validation.js\";\r\n\r\nexport { useMixins } from \"./composables/usePage.js\";\r\nexport { default as vtkMessage } from \"./components/message/index.js\";\r\n\r\nimport vtkMessage from \"./components/message/index.js\";\r\nimport storage from \"./commons/storage.js\";\r\nimport themes from \"./commons/themes.js\";\r\nimport request from \"./commons/request.js\";\r\nimport * as location from \"./commons/location.js\";\r\nimport Validation from \"./commons/validation.js\";\r\nimport * as dictionary from \"./commons/filters/dictionary.js\";\r\nimport * as mask from \"./commons/filters/mask.js\";\r\nimport * as format from \"./commons/filters/format.js\";\r\n\r\nimport VtkArea from \"./components/assembly/VtkArea.vue\";\r\nimport VtkAreaTabs from \"./components/assembly/VtkAreaTabs.vue\";\r\nimport VtkBreadcrumb from \"./components/assembly/VtkBreadcrumb.vue\";\r\nimport VtkCheckbox from \"./components/assembly/VtkCheckbox.vue\";\r\nimport VtkCount from \"./components/assembly/VtkCount.vue\";\nimport VtkDatePicker from \"./components/assembly/VtkDatePicker.vue\";\nimport VtkDateSelector from \"./components/assembly/VtkDateSelector.vue\";\nimport VtkDateTimePicker from \"./components/assembly/VtkDateTimePicker.vue\";\nimport VtkDept from \"./components/assembly/VtkDept.vue\";\nimport VtkEmpty from \"./components/assembly/VtkEmpty.vue\";\r\nimport VtkFab from \"./components/assembly/VtkFab.vue\";\r\nimport VtkFormItem from \"./components/assembly/VtkFormItem.vue\";\r\nimport VtkImg from \"./components/assembly/VtkImg.vue\";\r\nimport VtkPage from \"./components/assembly/VtkPage.vue\";\r\nimport VtkPdf from \"./components/assembly/VtkPdf.vue\";\r\nimport VtkProj from \"./components/assembly/VtkProj.vue\";\r\nimport VtkRadio from \"./components/assembly/VtkRadio.vue\";\r\nimport VtkSearch from \"./components/assembly/VtkSearch.vue\";\r\nimport VtkSelect from \"./components/assembly/VtkSelect.vue\";\r\nimport VtkStepper from \"./components/assembly/VtkStepper.vue\";\r\nimport VtkUpload from \"./components/assembly/VtkUpload.vue\";\r\nimport VtkMessageComponent from \"./components/message/vtkMessage.vue\";\r\n\r\nfunction install(app, options = {}) {\r\n const components = {\r\n VtkArea,\r\n VtkAreaTabs,\r\n VtkBreadcrumb,\r\n VtkCheckbox,\r\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDateTimePicker,\n VtkDept,\n VtkEmpty,\r\n VtkFab,\r\n VtkFormItem,\r\n VtkImg,\r\n VtkPage,\r\n VtkPdf,\r\n VtkProj,\r\n VtkRadio,\r\n VtkSearch,\r\n VtkSelect,\r\n VtkStepper,\r\n VtkUpload,\r\n VtkMessage: VtkMessageComponent\r\n };\r\n\r\n Object.keys(components).forEach(name => {\r\n app.component(name, components[name]);\r\n });\r\n\r\n app.config.globalProperties.$vtk = {\r\n message: vtkMessage,\r\n request,\r\n storage,\r\n themes,\r\n location,\r\n Validation,\r\n filters: {\r\n ...dictionary,\r\n ...mask,\r\n ...format\r\n },\r\n ...options\r\n };\r\n\r\n return app;\r\n}\r\n\r\nexport default {\r\n install,\r\n VtkArea,\r\n VtkAreaTabs,\r\n VtkBreadcrumb,\r\n VtkCheckbox,\r\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDateTimePicker,\n VtkDept,\n VtkEmpty,\r\n VtkFab,\r\n VtkFormItem,\r\n VtkImg,\r\n VtkPage,\r\n VtkPdf,\r\n VtkProj,\r\n VtkRadio,\r\n VtkSearch,\r\n VtkSelect,\r\n VtkStepper,\r\n VtkUpload,\r\n request,\r\n storage,\r\n themes,\r\n vtkMessage\r\n};\r\n"],"names":["Storage","storage","type","key","js","value","useMessageStore","defineStore","options","Message","messageStore","defaultOptions","text","toastOptions","service","axios","config","tokenKey","_b","_a","error","response","res","header","handleRedirect","url","index","newUrl","Request","data","method","headers","responseType","proxy","getCurrentInstance","emit","__emit","entity","reactive","user","ref","areaData","onMounted","userKey","area","nextArea","areaCode","inputFn","e","clear","arr","_openBlock","_createElementBlock","_hoisted_1","_createVNode","_component_VSelect","_cache","$event","__props","_createBlock","_c","_normalizeClass","_d","_e","_f","_g","_h","_i","_normalizeStyle","_j","props","menu","tab","tabItems","areaStorage","areaItems","current","itemValue","itemText","view","code","province","city","district","town","village","tabArea","areaChange","item","getTree","nextTick","getAreaName","save","val","lastItem","close","textClear","initCode","watch","newVal","oldVal","_component_v_menu","_withCtx","_component_v_btn","_mergeProps","$attrs","_createElementVNode","_toDisplayString","_component_v_icon","_component_v_card","_hoisted_2","_Fragment","_renderList","link","_component_v_sheet","_component_v_tabs","_component_v_tab","_createTextVNode","_vShow","_component_v_chip_group","_component_v_chip","_component_v_card_actions","_component_v_spacer","router","inject","route","breadcrumbItems","computed","matched","r","pathArray","p","path","routePath","handleBack","_component_v_breadcrumbs","_component_v_breadcrumbs_item","localValue","isUpdatingLocal","isUpdatingModel","attrs","useAttrs","inputAttrs","list","inline","modelValue","rest","checkboxAttrs","errorMessages","rules","hint","persistentHint","inputValue","items","statc","it","codeValue","miscs","_component_VInput","_component_VCheckbox","currentNumber","currentDigits","digitKey","isAnimating","formatNumber","num","result","targetNumberString","startNumberString","maxDigitString","target","start","getCurrentDigit","initDigitsArray","startStr","char","startChar","getDigitStyle","currentValue","digitValue","offset","translateY","startAnimation","startTime","startValue","endValue","diff","animate","currentTime","elapsed","progress","easeOutQuart","updateDigitArray","valueStr","maxStr","i","newStr","oldStr","endStr","__expose","digitChar","_hoisted_4","_hoisted_3","n","_hoisted_5","dateRange","startDateRange","endDateRange","displayValue","formatDate","textFieldProps","placeholder","disabled","min","max","showCurrent","format","separator","date","year","month","day","minDate","maxDate","newValue","dates","onStartDateChange","onEndDateChange","clearValue","cancel","confirm","sortedRange","date1","date2","_component_VMenu","activatorProps","_component_VTextField","_component_VIcon","_component_VCard","_component_VCardText","_component_VDatePicker","_component_VDivider","_component_VCardActions","_component_VSpacer","_component_VBtn","YEAR_PANEL_SIZE","YEAR_PANEL_CENTER_OFFSET","showPicker","viewMode","currentYear","currentMonth","rightYear","rightMonth","selectedValue","tempValue","today","todayYear","todayMonth","todayDate","weekDays","monthList","menuAttach","menuLocation","menuOrigin","formatDisplay","week","yearList","startYear","_","weekList","weeks","firstDay","lastDay","currentDate","weekNumber","getWeekNumber","isToday","dayList","days","startDate","endDate","nextMonthYear","nextMonthMonth","nextMonthDayList","d","dayNum","yearStart","isYearSelected","v","isYearInRange","end","isMonthSelected","monthStr","isMonthInRange","isWeekSelected","weekStr","isWeekInRange","isDaySelected","isDayInRange","isDayRangeStart","isDayRangeEnd","isFutureYear","isFutureMonth","isFutureDay","selectYear","yearStr","first","selectMonth","selectMonthRight","isMonthSelectedRight","isMonthInRangeRight","selectWeek","selectDay","prevPeriod","nextPeriod","prevMonth","nextMonthLeft","prevMonthRight","nextMonth","prevYear","nextYearLeft","prevYearRight","nextYear","changeViewMode","mode","initializePicker","isOpen","closePicker","handleCancel","handleConfirm","menuProps","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","_hoisted_16","_hoisted_17","_hoisted_18","_hoisted_19","_hoisted_20","_hoisted_21","_hoisted_22","_hoisted_23","_hoisted_24","_hoisted_25","_hoisted_27","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","_hoisted_36","_hoisted_37","_hoisted_38","_hoisted_39","_hoisted_40","_hoisted_41","_hoisted_42","_hoisted_43","_hoisted_44","_hoisted_45","_hoisted_46","_hoisted_47","_hoisted_48","_hoisted_49","_hoisted_50","_hoisted_51","_hoisted_52","_hoisted_53","_hoisted_54","_hoisted_55","_hoisted_56","_hoisted_57","_hoisted_58","_hoisted_59","_hoisted_60","_hoisted_61","_hoisted_62","_hoisted_63","_hoisted_64","_hoisted_65","_hoisted_66","_hoisted_67","_hoisted_68","_hoisted_69","_hoisted_70","_hoisted_71","_hoisted_73","_hoisted_74","_hoisted_75","_hoisted_76","_hoisted_77","_hoisted_78","_hoisted_79","_hoisted_80","_hoisted_81","_hoisted_82","_hoisted_83","_hoisted_84","_hoisted_85","_hoisted_86","_hoisted_87","_hoisted_88","_hoisted_89","_hoisted_90","_hoisted_91","_hoisted_92","_hoisted_93","_hoisted_94","defaultStartTime","defaultEndTime","selectedDateTime","selectedRange","tempDate","tempRange","leftYear","leftMonth","selectedHour","selectedMinute","selectedSecond","activeRangeSide","activeTimeSide","activeSingleTime","isRange","menuWidth","minDateTime","parseValue","maxDateTime","hourOptions","minuteOptions","buildStepOptions","secondOptions","getDayList","leftDayList","rightDayList","formatByPattern","buildTempDateTime","singleTimeValue","pattern","canConfirm","isDateTimeDisabled","activeRangeDate","activeRangeHour","activeRangeMinute","activeRangeSecond","step","normalizedStep","startDay","daysInMonth","daysInPrevMonth","createDay","otherMonth","isSameDate","padTime","replacements","token","formatDatePart","formatTimePart","match","fallback","hour","minute","second","parseRangeValue","toModelValue","toModelRange","range","left","right","isYearDisabled","isMonthDisabled","isDayDisabled","isTimePartDisabled","isRangeDaySelected","side","isRangeDayInRange","rangeDayClass","setSinglePanelFromDate","setRangePanelsFromDate","base","prevLeftMonth","nextRightMonth","selectRangeDay","selected","currentStart","currentEnd","selectHour","selectMinute","selectSecond","openRangeTime","selectRangeTime","part","clearTempRange","nextValue","handleNow","now","_hoisted_26","pause","ms","resolve","dialog","areaSelectedData","areaActivatedData","getDeptList","getAreaList","getAreaNextList","parentCode","deptData","deptSelectedData","deptActivatedData","getPersonList","node","params","getDepNextList","selectAreaCode","selectPid","personData","selectedPersonData","allSelectedPersons","isRestoringSelection","selectedPersonList","uniqueMap","person","oldPerson","newPersonData","currentSelected","removeSelectedPerson","personId","globalIndex","currentIndex","add","selectedPersons","_component_v_dialog","_component_v_card_title","_component_v_divider","_component_v_card_text","_component_v_row","_component_v_col","_component_v_treeview","_component_v_avatar","_component_v_img","_component_v_list","_component_v_list_item","_component_v_empty_state","$slots","_renderSlot","_ctx","showFab","fabClass","handleScroll","scrollToTop","onBeforeUnmount","_Transition","_component_v_fab","processedMaxWidth","contentStyles","styles","showPreview","imageRotation","imageScale","imageTranslateX","imageTranslateY","imageDragState","srcWithToken","currentImageUrl","currentImage","currentImageTitle","currentImageDescription","hasPrev","hasNext","viewerImageStyle","resetImageTransform","openPreview","closePreview","prevImage","nextImage","rotateImage","degrees","zoomImage","nextScale","handleImageWheel","event","startImageDrag","moveImageDrag","endImageDrag","state","_component_v_progress_circular","_component_VCardTitle","_component_v_card_subtitle","_component_VDialog","_component_v_toolbar","_component_v_toolbar_title","_component_v_toolbar_items","pagination","pageSizeObjs","pageDatas","paginationChange","pageChange","pageSizeFormat","toPage","pageSizeChange","temp","obj","page","_component_VRow","_component_v_pagination","loading","pdfLoaded","currentPage","pageCount","pdfContainer","pdfDoc","loadPdf","renderPage","pageNum","prevPage","nextPage","downloadPdf","blob","fileName","_component_VCol","_component_VSlider","useMixins","urlConfig","queryParam","desserts","superQueryParams","pageData","sumup","pageDataCopy","overlay","getQueryParams","codex","loadPage","pageInfo","id","record","modalFormRef","disposition","filename","newUrlConfig","getListPage","expData","mixinQueryParam","examType","permits","projName","projTip","bizType","expShow","menu1","expArr","formArr","select","selectAll","delItem","delNote","MprojRef","onActivated","examAll","chkAll","getUserInfo","examWait","toView","searchProj","param","searchQuery","exv","exp","del","delSave","tip","formatIdCard","idcard","dateStr","getServStateClass","getServStateText","getRateStateClass","getRateStateText","getServFromText","from","_component_VContainer","_component_VTabs","_component_VTab","_unref","_component_vtk_search","_component_vtk_area_tabs","_component_vtk_select","_component_VDataTable","_component_VChip","_component_vtk_empty","_component_vtk_page","_component_vtk_proj","_component_VTextarea","onUpdate","_component_VRadioGroup","_component_VRadio","instance","initialQueryParam","initialIndex","initVal","contentStyle","minValue","maxValue","minHeight","maxHeight","obtain","filterNull","search","reset","handleResetClick","_component_VBadge","filteredAttrs","multi","its","$emit","stepIndex","content","_component_VStepper","_component_VStepperHeader","_component_VStepperWindow","_component_VStepperWindowItem","inputRef","isDragover","previewVisible","previewFile","previewScale","previewRotation","previewTranslateX","previewTranslateY","previewDragState","fileList","normalizeFileList","uidCounter","genUid","getFileNameFromUrl","cleanUrl","name","isImage","file","fileIcon","previewImageStyle","triggerInput","onDragover","onDrop","processFiles","onInputChange","rawFiles","raw","errFile","buildFile","reader","beforeHook","addFile","uploadFile","status","syncModel","urls","f","formData","k","err","handleRemove","doRemove","isExcel","resetPreviewTransform","rotatePreview","zoomPreview","startPreviewDrag","movePreviewDrag","endPreviewDrag","openFileInNewTab","fileUrl","blobUrl","win","openCurrentPreview","handlePreview","visible","_withModifiers","_component_v_progress_linear","isAid","str","getLinkFromResponse","buildUrlWithParams","appendParams","queryString","queryParams","newParams","joinSymbol","appendParamsToUrl","targetUrl","hashIndex","baseUrl","hashRoute","newHashRoute","resolveAidUrl","aid","buildAppendParams","sobject","sroute","stokenKey","storageKey","stoken","GetQueryString","reg","appendAppParams","source","dict","map","pre","maps","results","j","currentVal","kv","analyType","analyLevel","fmt","getDate","o","numValue","neg","absValue","fix","needSep","xs","decimalPart","integerPart","age","birthdays","txt","len","abs","mobile","colors","themes","Validation","input","this","idCard","checkCode","multiplier","ids","sum","remainder","checkCodeArr","dateStrNew","dateObj","birth","sex","isActive","close_modal","_component_v_overlay","_sfc_main","vtkAlert","vtkConfirm","vtkLoading","onModelUpdate","_component_VSnackbar","_component_vtk_alert","_component_vtk_confirm","_component_vtk_loading","_component_vtk_prompt","_component_vtk_toast","install","app","components","VtkArea","VtkAreaTabs","VtkBreadcrumb","VtkCheckbox","VtkCount","VtkDatePicker","VtkDateSelector","VtkDateTimePicker","VtkDept","VtkEmpty","VtkFab","VtkFormItem","VtkImg","VtkPage","VtkPdf","VtkProj","VtkRadio","VtkSearch","VtkSelect","VtkStepper","VtkUpload","VtkMessageComponent","vtkMessage","request","location","dictionary","mask"],"mappings":"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","x_google_ignoreList":[30]}
|
|
1
|
+
{"version":3,"file":"specter-pui.umd.js","sources":["../src/commons/storage.js","../src/stores/message.js","../src/components/message/index.js","../src/commons/request.js","../src/components/assembly/VtkArea.vue","../src/components/assembly/VtkAreaTabs.vue","../src/components/assembly/VtkBreadcrumb.vue","../src/components/assembly/VtkCheckbox.vue","../src/components/assembly/VtkCount.vue","../src/components/assembly/VtkDatePicker.vue","../src/components/assembly/VtkDateSelector.vue","../src/components/assembly/VtkDateTimePicker.vue","../src/components/assembly/VtkDept.vue","../src/components/assembly/VtkEmpty.vue","../src/components/assembly/VtkFab.vue","../src/components/assembly/VtkFormItem.vue","../src/components/assembly/VtkImg.vue","../src/components/assembly/VtkPage.vue","../src/components/assembly/VtkPdf.vue","../src/composables/usePage.js","../src/components/assembly/VtkProj.vue","../src/components/assembly/VtkRadio.vue","../src/components/assembly/VtkSearch.vue","../src/components/assembly/VtkSelect.vue","../src/components/assembly/VtkStepper.vue","../src/components/assembly/VtkUpload.vue","../src/commons/location.js","../src/commons/filters/dictionary.js","../src/commons/filters/format.js","../src/commons/filters/mask.js","../node_modules/vuetify/lib/util/colors.js","../src/commons/themes.js","../src/commons/validation.js","../src/components/message/alert.vue","../src/components/message/confirm.vue","../src/components/message/loading.vue","../src/components/message/vtkMessage.vue","../src/components/message/prompt.vue","../src/components/message/toast.vue","../src/index.js"],"sourcesContent":["const Storage = {};\r\n/** 获取Storage对象 */\r\nconst storage = (type = 'local') => {\r\n return type == \"local\" ? window.localStorage : window.sessionStorage;\r\n}\r\n/**\r\n * 获取对应缓存值JSON对象\r\n * @param {string} key 键\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n * @return {object} 对应的值JSON对象\r\n */\r\nStorage.get = (key, type = 'local') => {\r\n var js = storage(type).getItem(key);\r\n return /^[\\\\{|\\\\[].+[\\\\}|\\\\]]$/.test(js) ? JSON.parse(js) : js;\r\n};\r\n/**\r\n * 设置存储缓存取对象JSON\r\n * @param {string} key 键\r\n * @param {string} value 值(JSON对象)\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n */\r\nStorage.set = (key, value, type = 'local') => {\r\n value = (value.constructor === Object) ? JSON.stringify(value) : value\r\n storage(type).setItem(key, value);\r\n};\r\n/**\r\n * 删除对应的缓存对象JSON\r\n * @param {string} key 键\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n */\r\nStorage.remove = (key, type = 'local') => {\r\n storage(type).removeItem(key);\r\n};\r\n/**\r\n * 清空所有的缓存对象JSON\r\n * @param {string} type 默认为localStorage, 'session'为sessionStorage\r\n */\r\nStorage.clear = (type = 'local') => {\r\n storage(type).clear();\r\n};\r\n\r\nexport default Storage;\r\n","// stores/message.js\r\nimport { defineStore } from 'pinia'\r\n\r\nexport const useMessageStore = defineStore('message', {\r\n state: () => ({\r\n alert: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 500\r\n }\r\n },\r\n confirm: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 400,\r\n cancelText: '取消',\r\n confirmText: '确定'\r\n }\r\n },\r\n loading: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 300,\r\n indeterminate: true,\r\n value: 0,\r\n progressColor: 'primary',\r\n size: 64,\r\n circleWidth: 6\r\n }\r\n },\r\n prompt: {\r\n isActive: false,\r\n options: {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 500,\r\n label: '',\r\n placeholder: '',\r\n inputType: 'text',\r\n cancelText: '取消',\r\n confirmText: '确定'\r\n }\r\n },\r\n toast: {\r\n isActive: false,\r\n options: {\r\n text: '',\r\n color: '',\r\n timeout: 3000,\r\n position: 'top'\r\n }\r\n }\r\n }),\r\n \r\n actions: {\r\n hide(type) {\r\n if (this[type]) {\r\n this[type].isActive = false\r\n }\r\n },\r\n \r\n show(type, options) {\r\n if (this[type]) {\r\n this[type] = {\r\n isActive: true,\r\n options: options\r\n }\r\n }\r\n }\r\n }\r\n})","// components/message/index.js\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst Message = {\r\n // 显示 alert\r\n alert(options) {\r\n const messageStore = useMessageStore()\r\n messageStore.show('alert', options)\r\n },\r\n \r\n // 显示 confirm\r\n confirm(options) {\r\n const messageStore = useMessageStore()\r\n messageStore.show('confirm', options)\r\n },\r\n \r\n // loading 对象,包含 show 和 hide 方法\r\n loading: {\r\n show(options = {}) {\r\n const messageStore = useMessageStore()\r\n const defaultOptions = {\r\n title: '',\r\n text: '',\r\n color: '',\r\n width: 120,\r\n indeterminate: true,\r\n progressColor: 'primary',\r\n size: 64,\r\n circleWidth: 6\r\n }\r\n messageStore.show('loading', { ...defaultOptions, ...options })\r\n },\r\n hide() {\r\n const messageStore = useMessageStore()\r\n messageStore.hide('loading')\r\n }\r\n },\r\n \r\n // 显示 prompt\r\n prompt(options) {\r\n const messageStore = useMessageStore()\r\n messageStore.show('prompt', options)\r\n },\r\n \r\n // 显示 toast\r\n toast(text, options = {}) {\r\n \r\n const messageStore = useMessageStore()\r\n // 确保传入的是字符串时正确处理\r\n const toastOptions = typeof text === 'string' \r\n ? { text, ...options }\r\n : text\r\n messageStore.show('toast', toastOptions)\r\n },\r\n \r\n // 隐藏指定类型的消息\r\n hide(type) {\r\n const messageStore = useMessageStore()\r\n messageStore.hide(type)\r\n }\r\n}\r\n\r\nexport default Message","import axios from \"axios\";\r\nimport Storage from \"./storage.js\";\r\nimport Message from \"../components/message/index.js\";\r\n\r\n// create an axios instance\r\nconst service = axios.create({\r\n baseURL: window.VITE_APP_API_URL || import.meta.env.VITE_APP_API_URL || \"\",\r\n headers: {\r\n \"X-Requested-With\": \"XMLHttpRequest\",\r\n },\r\n withCredentials: false,\r\n timeout: 30000,\r\n});\r\n\r\n// request interceptor\r\nservice.interceptors.request.use(\r\n (config) => {\r\n // 获取配置的键名,如果没有配置则使用默认值\r\n const tokenKey = window.VTK_CONFIG?.storageKeys?.token || '_mis_acis_token';\r\n if (Storage.get(tokenKey)) {\r\n config.headers[\"X-Token\"] = \"1b0679be72ad976ad5d491ad57a5eec0\";\r\n config.headers[\"Authorization\"] = \"Bearer \" + Storage.get(tokenKey);\r\n }\r\n return config;\r\n },\r\n (error) => {\r\n Message.toast(error.message || \"请求错误\");\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\n// response interceptor\r\nservice.interceptors.response.use(\r\n (response) => {\r\n let res = response.data;\r\n let header = response.headers[\"content-disposition\"];\r\n\r\n if (header != undefined && header.split(\";\")[0] == \"attachment\") {\r\n res = response;\r\n }\r\n if (response.status !== 200) {\r\n Message.toast(res.message || \"请求失败\", { color: \"error\" });\r\n return Promise.reject(new Error(res.message || \"请求失败\"));\r\n } else {\r\n // 检查登录过期\r\n if (\r\n res.meta &&\r\n !res.meta.success &&\r\n res.meta.message === \"specter_authorize_exception\"\r\n ) {\r\n Storage.clear(); //清除所有缓存\r\n const handleRedirect = () => {\r\n const url = window.location.href;\r\n const index = url.indexOf(\"#\");\r\n let newUrl;\r\n\r\n if (index > -1) {\r\n newUrl = url.substring(0, index) + \"#/\";\r\n } else {\r\n newUrl = url + \"#/\";\r\n }\r\n\r\n window.location.href = newUrl;\r\n };\r\n\r\n Message.confirm({\r\n title: \"提示\",\r\n text: \"对不起,您的登录信息过期!\",\r\n onConfirm: handleRedirect,\r\n onCancel: handleRedirect,\r\n });\r\n }\r\n return Promise.resolve(res);\r\n }\r\n },\r\n (error) => {\r\n console.log(\"err\" + error);\r\n Message.toast(error.message || \"网络错误\", { color: \"error\" });\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\nconst Request = {};\r\n\r\nRequest.http = (\r\n url,\r\n data = {},\r\n method = \"GET\",\r\n headers = { \"content-type\": \"application/x-www-form-urlencoded\" },\r\n responseType = null\r\n) => {\r\n if (headers[\"content-type\"] === \"application/x-www-form-urlencoded\") {\r\n return service({\r\n url: url,\r\n params: data,\r\n method: method,\r\n headers: headers,\r\n responseType: responseType,\r\n });\r\n } else {\r\n return service({\r\n url: url,\r\n data: data,\r\n method: method,\r\n headers: headers,\r\n responseType: responseType,\r\n });\r\n }\r\n};\r\n\r\nRequest.getForm = (url, data = {}) => {\r\n return Request.http(url, data);\r\n};\r\n\r\nRequest.postForm = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\");\r\n};\r\n\r\nRequest.getJson = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\", {\r\n \"content-type\": \"application/json\",\r\n });\r\n};\r\n\r\nRequest.postJson = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\", {\r\n \"content-type\": \"application/json\",\r\n });\r\n};\r\n\r\nRequest.imp = (url, data = {}) => {\r\n return Request.http(url, data, \"POST\", {\r\n \"Content-Type\": \"multipart/form-data\",\r\n });\r\n};\r\n\r\nRequest.exp = (url, data = {}) => {\r\n return Request.http(\r\n url,\r\n data,\r\n \"POST\",\r\n { \"content-Type\": \"application/json\" },\r\n \"blob\"\r\n );\r\n};\r\n\r\nexport default Request;\r\n","<template>\r\n\t<div class=\"d-inline-block d-flex\">\r\n\t\t<VSelect\r\n\t\t\tv-model=\"entity.area2\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area2, 1)\"\r\n\t\t\t@click:clear=\"clear(1)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 2 ? entity.name2 : '---省级---'\"\r\n\t\t\t:items=\"areaData.area2\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box mr-3\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 2\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 4\"\r\n\t\t\tv-model=\"entity.area4\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area4, 2)\"\r\n\t\t\t@click:clear=\"clear(2)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 4 ? entity.name4 : '---市级---'\"\r\n\t\t\t:items=\"areaData.area4\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box\"\r\n\t\t\t:class=\"maxArea > 4 && 'mr-3'\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 4\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 6\"\r\n\t\t\tv-model=\"entity.area6\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area6, 3)\"\r\n\t\t\t@click:clear=\"clear(3)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 6 ? entity.name6 : '---区/县---'\"\r\n\t\t\t:items=\"areaData.area6\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box\"\r\n\t\t\t:class=\"maxArea > 6 && 'mr-3'\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 6\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 9\"\r\n\t\t\tv-model=\"entity.area9\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area9, 4)\"\r\n\t\t\t@click:clear=\"clear(4)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 9 ? entity.name9 : '---街/镇---'\"\r\n\t\t\t:items=\"areaData.area9\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block sel_box\"\r\n\t\t\t:class=\"maxArea > 9 && 'mr-3'\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 9\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t\t<VSelect\r\n\t\t\tv-if=\"maxArea >= 12\"\r\n\t\t\tv-model=\"entity.area12\"\r\n\t\t\t@update:model-value=\"nextArea(entity.area12, 5)\"\r\n\t\t\t@click:clear=\"clear(5)\"\r\n\t\t\t:placeholder=\"user.areacode?.length >= 12 ? entity.name12 : '---村/社---'\"\r\n\t\t\t:items=\"areaData.area12\"\r\n\t\t\titem-title=\"areaName\"\r\n\t\t\titem-value=\"areaCode\"\r\n\t\t\tclass=\"d-inline-block\"\r\n\t\t\tstyle=\"width: 188px\"\r\n\t\t\thide-details\r\n\t\t\tdensity=\"compact\"\r\n\t\t\tvariant=\"outlined\"\r\n\t\t\tclearable\r\n\t\t\t:disabled=\"user.areacode?.length >= 12\"\r\n\t\t\t:menu-props=\"{ offsetY: true }\"\r\n\t\t\t:style=\"areaStyle\"></VSelect>\r\n\t</div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, reactive, onMounted, getCurrentInstance } from 'vue';\r\n\r\nimport Request from \"../../commons/request\"\r\n\r\nconst { proxy } = getCurrentInstance();\r\n\r\n// 定义组件名称和选项\r\ndefineOptions({\r\n\tname: \"VtkArea\",\r\n\tinheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n\tmaxArea: {\r\n\t\ttype: Number,\r\n\t\tdefault: 12,\r\n\t},\r\n\tminArea: {\r\n\t\ttype: Number,\r\n\t\tdefault: null,\r\n\t},\r\n\tareaStyle: {\r\n\t\ttype: String,\r\n\t\tdefault: \"\",\r\n\t},\r\n});\r\n\r\n// 定义emits\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 响应式数据\r\nconst entity = reactive({\r\n\tarea2: null,\r\n\tarea4: null,\r\n\tarea6: null,\r\n\tarea9: null,\r\n\tarea12: null,\r\n\tname2: '',\r\n\tname4: '',\r\n\tname6: '',\r\n\tname9: '',\r\n\tname12: ''\r\n});\r\n\r\nconst user = ref({ areacode: \"\" });\r\nconst areaData = reactive({\r\n\tarea2: [],\r\n\tarea4: [],\r\n\tarea6: [],\r\n\tarea9: [],\r\n\tarea12: []\r\n});\r\n\r\n// 安全获取 vtk 对象\r\nconst getVtk = () => {\r\n if (typeof window !== 'undefined' && window.$vtk) {\r\n return window.$vtk;\r\n }\r\n return null;\r\n};\r\n\r\n// 组件挂载时执行\r\nonMounted(() => {\r\n\t// 获取配置的键名,如果没有配置则使用默认值\r\n\tconst userKey = window.VTK_CONFIG?.storageKeys?.user || '_mis_acis_users';\r\n\tuser.value = typeof(proxy.$vtk.storage.get(userKey)) != 'object' ? JSON.parse(proxy.$vtk.storage.get(userKey)) : proxy.$vtk.storage.get(userKey) || '';\r\n\tif (user.value) {\r\n\t\tarea();\r\n\t}\r\n});\r\n\r\n// 所属地区\r\nconst area = () => {\r\n try {\r\n proxy.$vtk.message.loading.show();\r\n Request.postForm(`/dict/area/show/${user.value.areacode}`).then((res) => {\r\n proxy.$vtk.message.loading.hide();\r\n if (res.meta.success) {\r\n entity[`area${res.data.areaLeve}`] = res.data.areaCode;\r\n entity.name2 = res.data.province;\r\n entity.name4 = res.data.city;\r\n entity.name6 = res.data.district;\r\n entity.name9 = res.data?.town;\r\n entity.name12 = res.data?.village;\r\n nextArea(user.value.areacode);\r\n } else {\r\n proxy.$vtk.message.toast(res.meta.message);\r\n }\r\n }).catch(error => {\r\n proxy.$vtk.message.loading.hide();\r\n proxy.$vtk.message.toast('加载区域数据失败');\r\n });\r\n } catch (error) {\r\n console.error('初始化区域数据失败:', error);\r\n if (proxy.$vtk.message?.loading?.hide) {\r\n proxy.$vtk.message.loading.hide();\r\n }\r\n }\r\n};\r\n\r\n// 下一级地区列表\r\nconst nextArea = (areaCode, index) => {\r\n\tinputFn(areaCode);\r\n \r\n\tif (areaCode?.length < 12) {\r\n\t\tRequest.postForm(`/dict/area/next/${areaCode}`).then((res) => {\r\n\t\t\tproxy.$vtk.message.loading.hide();\r\n\t\t\tif (res.meta.success) {\r\n\t\t\t\tif (index) {\r\n\t\t\t\t\tObject.keys(areaData)\r\n\t\t\t\t\t\t.slice(index, 5)\r\n\t\t\t\t\t\t.forEach((e) => {\r\n\t\t\t\t\t\t\tareaData[e] = [];\r\n\t\t\t\t\t\t\tentity[e] = null;\r\n\t\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tareaData[`area${res.data[0].areaLeve}`] = res.data;\r\n\t\t\t} else {\r\n\t\t\t\tproxy.$vtk.message.toast(res.meta.message);\r\n\t\t\t}\r\n\t\t}).catch(error => {\r\n console.error('加载下级区域数据失败:', error);\r\n proxy.$vtk.message.toast('加载下级区域数据失败');\r\n });\r\n\t}\r\n};\r\n\r\n// 清除\r\nconst clear = (index) => {\r\n\tlet arr = Object.keys(areaData);\r\n\tinputFn(entity[arr[index - 2]]);\r\n\tarr.slice(index, 5).forEach((e) => {\r\n\t\tareaData[e] = [];\r\n\t\tentity[e] = null;\r\n\t});\r\n};\r\n\r\n// 输入事件\r\nconst inputFn = (e) => {\r\n\te && emit(\"update:modelValue\", e);\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.sel_box {\r\n\twidth: 164px;\r\n}\r\n</style>","<template>\r\n\t<v-menu v-model=\"menu\" :close-on-content-click=\"false\" max-width=\"520\" min-width=\"520\">\r\n\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t<v-btn\r\n\t\t\t\tv-bind=\"props\"\r\n\t\t\t\tvariant=\"outlined\"\r\n\t\t\t\tcolor=\"primary\"\r\n\t\t\t\tclass=\"area-select-btn\"\r\n\t\t\t\t:style=\"$attrs.styles\"\r\n\t\t\t>\r\n\t\t\t\t<span class=\"btn-text\">{{ itemText || '选择地区' }}</span>\r\n\t\t\t\t<v-icon v-if=\"itemText\" size=\"small\" @click.stop=\"textClear\" class=\"ml-2\">mdi-close-circle</v-icon>\r\n\t\t\t</v-btn>\r\n\t\t</template>\r\n\t\t<v-card elevation=\"0\" style=\"width: 350px;\">\r\n\t\t\t<p class=\"pt-3 px-3\">\r\n\t\t\t\t<v-icon color=\"primary\" class=\"mr-1\" size=\"20\">mdi-map-marker-radius</v-icon>\r\n\t\t\t\t<span v-for=\"link in entity\" :key=\"link.areaCode\" class=\"link text-body-2 text-primary\">{{ link.areaName }}</span>\r\n\t\t\t</p>\r\n\t\t\t<v-sheet class=\"rounded-lg mx-3 mt-2\" color=\"#b1b1b117\">\r\n\t\t\t\t<v-tabs v-model=\"tab\" @update:model-value=\"tabArea\" class=\"pt-2 px-1\">\r\n\t\t\t\t\t<v-tab\r\n\t\t\t\t\t\tv-for=\"(item, index) in tabItems\"\r\n\t\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\t\tclass=\"mx-1\"\r\n\t\t\t\t\t\t:style=\"tab == index && 'color:white;opacity:1'\"\r\n\t\t\t\t\t\t:disabled=\"areaStorage.length <= index + 1\"\r\n\t\t\t\t\t\tv-show=\"minArea ? minArea >= item.leve : true\"\r\n\t\t\t\t\t>{{ item.text }}</v-tab>\r\n\t\t\t\t</v-tabs>\r\n\t\t\t\t<v-sheet\r\n\t\t\t\t\tv-show=\"index == tab\"\r\n\t\t\t\t\tv-for=\"(item, index) in tabItems\"\r\n\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\tclass=\"px-3 py-1\"\r\n\t\t\t\t\tmin-height=\"100\"\r\n\t\t\t\t\tcolor=\"rgba(0,0,0,0)\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<v-chip-group v-model=\"current\" selected-class=\"chipActive\" column>\r\n\t\t\t\t\t\t<v-chip\r\n\t\t\t\t\t\t\tv-for=\"area in areaItems\"\r\n\t\t\t\t\t\t\t:key=\"area.id\"\r\n\t\t\t\t\t\t\t@click=\"areaChange(area, index)\"\r\n\t\t\t\t\t\t\tclass=\"rounded\"\r\n\t\t\t\t\t\t\t:class=\"area.areaCode == user.areacode && 'active'\"\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t{{ area.areaName }}\r\n\t\t\t\t\t\t</v-chip>\r\n\t\t\t\t\t</v-chip-group>\r\n\t\t\t\t</v-sheet>\r\n\t\t\t</v-sheet>\r\n\r\n\t\t\t<v-card-actions class=\"pr-0 py-3\">\r\n\t\t\t\t<v-spacer />\r\n\t\t\t\t<v-btn @click=\"close\" elevation=\"0\" size=\"small\"><v-icon class=\"pt-1 pr-1\">mdi-progress-close</v-icon> 取消</v-btn>\r\n\t\t\t\t<v-btn @click=\"save\" class=\"text-white mr-3\" color=\"primary\" elevation=\"0\" size=\"small\"><v-icon class=\"pt-1 pr-1\">mdi-progress-check</v-icon> 确定</v-btn>\r\n\t\t\t</v-card-actions>\r\n\t\t</v-card>\r\n\t</v-menu>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, watch, onMounted, getCurrentInstance, nextTick } from 'vue';\r\n\r\nconst props = defineProps({\r\n\tmodelValue: {\r\n\t\ttype: [String, Object],\r\n\t\tdefault: null,\r\n\t},\r\n\tminArea: {\r\n\t\ttype: Number,\r\n\t\tdefault: null,\r\n\t},\r\n\tareaNode: {\r\n\t\ttype: Number,\r\n\t\tdefault: null,\r\n\t},\r\n\tareaCode: {\r\n\t\ttype: String,\r\n\t\tdefault: null,\r\n\t},\r\n\treturnObj: {\r\n\t\ttype: Boolean,\r\n\t\tdefault: false,\r\n\t},\r\n});\r\n\r\nconst emit = defineEmits(['update:modelValue', 'change']);\r\n\r\nconst { proxy } = getCurrentInstance();\r\n\r\nconst menu = ref(false);\r\nconst user = ref({});\r\nconst tab = ref(0);\r\nconst tabItems = ref([]);\r\nconst areaStorage = ref([]); //存储个级别地区数据\r\nconst areaItems = ref([]); //当前选择地区的所有列\r\nconst entity = ref([]); //存储选中的数据\r\nconst current = ref(null); //回显值选中\r\nconst itemValue = ref(\"\"); //传值:最终选择值\r\nconst itemText = ref(\"\"); //最终选择值\r\n\r\n// 值回显\r\nconst view = (code) => {\r\n\tproxy.$vtk.request.getForm(`/dict/area/show/${code}`).then((res) => {\r\n\t\tlet province = res.data.province ? `${res.data.province}` : \"\";\r\n\t\tlet city = res.data.city ? `/${res.data.city}` : \"\";\r\n\t\tlet district = res.data.district ? `/${res.data.district}` : \"\";\r\n\t\tlet town = res.data.town ? `/${res.data.town}` : \"\";\r\n\t\tlet village = res.data.village ? `/${res.data.village}` : \"\";\r\n\t\titemText.value = `${province}${city}${district}${town}${village}`;\r\n\t\tif (props.areaNode && props.areaNode > 0) {\r\n\t\t\titemText.value = itemText.value.split(\"/\").slice(-props.areaNode).join(\"/\");\r\n\t\t}\r\n\t});\r\n};\r\n\r\n// 切换Tab地区级别\r\nconst tabArea = (index) => {\r\n\tareaItems.value = [...areaStorage.value[index]];\r\n\tif (index < entity.value.length) {\r\n\t\tcurrent.value = areaItems.value.findIndex((e) => e.areaCode == entity.value[index].areaCode);\r\n\t} else {\r\n\t\tcurrent.value = null;\r\n\t}\r\n};\r\n\r\n//选择地区\r\nconst areaChange = (item, index) => {\r\n\tentity.value = entity.value.slice(0, index);\r\n\tentity.value.push(item);\r\n\tareaStorage.value = areaStorage.value.slice(0, index + 1);\r\n\tif (tabItems.value.length > tab.value + 1 && (props.minArea ? props.minArea > item.areaCode.length : true)) {\r\n\t\tgetTree(item.areaCode);\r\n\t\ttab.value++;\r\n\t}\r\n};\r\n\r\n// 加载下级地区\r\nconst getTree = (code) => {\r\n\tproxy.$vtk.request.getForm(`/dict/area/next/${code}`).then((res) => {\r\n\t\tareaItems.value = res.data;\r\n\t\tareaStorage.value.push(res.data);\r\n\t\tcurrent.value = null;\r\n\t\tnextTick(); //Vue 3中替代$forceUpdate\r\n\t});\r\n};\r\n\r\n// 加载第一个地区,用户所在地区\r\nconst getAreaName = (code) => {\r\n\tentity.value = [];\r\n\ttabItems.value = [\r\n\t\t{ text: \"省级\", leve: \"2\" },\r\n\t\t{ text: \"市级\", leve: \"4\" },\r\n\t\t{ text: \"区县\", leve: \"6\" },\r\n\t\t{ text: \"街镇\", leve: \"9\" },\r\n\t\t{ text: \"村社\", leve: \"12\" },\r\n\t].filter((e) => e.leve >= (props.areaCode || user.value?.areacode || user.value?.areaCode || '').length);\r\n\tareaStorage.value = [];\r\n\r\n\tproxy.$vtk.request.getForm(`/dict/area/show/${code}`).then((res) => {\r\n\t\tareaItems.value = [{ areaName: res.data.areaName, areaCode: res.data.areaCode }];\r\n\t\tareaStorage.value.push(areaItems.value);\r\n\t\tentity.value.push(areaItems.value[0]);\r\n\t});\r\n};\r\n\r\n//确认保存\r\nconst save = () => {\r\n\tlet text = [];\r\n\tlet val = [];\r\n\tentity.value.forEach((e) => {\r\n\t\ttext.push(e.areaName);\r\n\t\tval.push(e.areaCode);\r\n\t\titemValue.value = e.areaCode;\r\n\t});\r\n\tif (props.areaNode && props.areaNode > 0) {\r\n\t\ttext = text.slice(-props.areaNode);\r\n\t}\r\n\titemText.value = text.join().replace(/,/g, \"/\");\r\n\tconst lastItem = entity.value[entity.value.length - 1];\r\n\temit(\"update:modelValue\", props.returnObj ? { areaCode: lastItem?.areaCode, areaName: lastItem?.areaName } : itemValue.value);\r\n\temit(\"change\");\r\n\tclose();\r\n};\r\n\r\n// 清空\r\nconst textClear = () => {\r\n\ttab.value = 0;\r\n\tconst initCode = props.areaCode || user.value?.areacode || user.value?.areaCode;\r\n\tgetAreaName(initCode);\r\n\titemValue.value = initCode;\r\n\temit(\"update:modelValue\", itemValue.value);\r\n\temit(\"change\");\r\n};\r\n\r\n// 关闭弹窗\r\nconst close = () => {\r\n\tmenu.value = false;\r\n};\r\n\r\n// Watch modelValue\r\nwatch(() => props.modelValue, (newVal, oldVal) => {\r\n\tif (newVal && newVal != oldVal) {\r\n\t\tconst code = typeof newVal === 'object' ? newVal.areaCode : newVal;\r\n\t\tif (code) view(code);\r\n\t}\r\n});\r\n\r\n// 组件挂载时执行\r\nonMounted(() => {\r\n\t// 获取配置的键名,如果没有配置则使用默认值\r\n\tconst userKey = window.VTK_CONFIG?.storageKeys?.user || '_mis_acis_users';\r\n\tuser.value = proxy.$vtk.storage.get(userKey) && JSON.parse(proxy.$vtk.storage.get(userKey));\r\n\tconst initCode = props.areaCode || user.value?.areacode || user.value?.areaCode;\r\n\tif (initCode) {\r\n\t\tgetAreaName(initCode);\r\n\t}\r\n\tif (props.modelValue) {\r\n\t\tconst code = typeof props.modelValue === 'object' ? props.modelValue.areaCode : props.modelValue;\r\n\t\tif (code) view(code);\r\n\t}\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n// 圆形按钮样式\r\n.area-select-btn {\r\n\tborder-radius: 20px !important;\r\n\tpadding: 6px 20px !important;\r\n\tmin-width: 120px;\r\n\theight: 36px !important;\r\n\ttext-transform: none;\r\n\tletter-spacing: normal;\r\n\r\n\t.btn-text {\r\n\t\tfont-size: 14px;\r\n\t\tcolor: inherit;\r\n\t}\r\n\r\n\t&:hover {\r\n\t\tbackground-color: rgba(var(--v-theme-primary), 0.08);\r\n\t}\r\n}\r\n:deep(.v-tab__slider) {\r\n\theight: 0px !important;\r\n}\r\n\r\n.link::after {\r\n\tcontent: \" / \";\r\n\tfont-size: 14px;\r\n\tcolor: #999;\r\n}\r\n.link:last-of-type::after {\r\n\tcontent: \"\";\r\n}\r\n:deep(.v-chip:not(.v-chip--selected)) {\r\n\tbackground: #e0e0e000;\r\n}\r\n// Vuetify 3 tabs container styling\r\n:deep(.v-tabs) {\r\n\theight: 40px;\r\n}\r\n// Tab button styling\r\n:deep(.v-tab) {\r\n\tmin-width: 90px;\r\n\theight: 32px !important;\r\n\tborder-radius: 6px !important;\r\n\tcolor: rgba(0, 0, 0, .6);\r\n\ttransition: all 0.3s ease;\r\n\tz-index: 1;\r\n}\r\n// Active/selected tab styling\r\n:deep(.v-tab--selected) {\r\n\tbackground-color: rgb(var(--v-theme-primary));\r\n\tcolor: white !important;\r\n\topacity: 1;\r\n}\r\n// Hover effect\r\n:deep(.v-tab:hover) {\r\n\tbackground-color: rgba(var(--v-theme-primary), 0.9);\r\n\tcolor: white;\r\n}\r\n.tabActive {\r\n\tcolor: #fff;\r\n}\r\n.chipActive {\r\n\tcolor: #0095ff !important;\r\n\tbackground-color: #008eff05 !important;\r\n}\r\n.active {\r\n\tcolor: #0095ff !important;\r\n\tbackground-color: #008eff20 !important;\r\n}\r\n:deep(.v-slide-group__next),\r\n:deep(.v-slide-group__prev) {\r\n\tdisplay: none;\r\n}\r\n</style>\r\n","<template>\r\n <div class=\"vtk-breadcrumb-wrapper d-flex align-center justify-space-between\">\r\n <!-- 左侧面包屑 -->\r\n <v-breadcrumbs :items=\"breadcrumbItems\" class=\"pa-0\">\r\n <template v-slot:divider>\r\n <v-icon>mdi-chevron-right</v-icon>\r\n </template>\r\n <template v-slot:item=\"{ item }\">\r\n <v-breadcrumbs-item\r\n :title=\"item.title\"\r\n :to=\"item.to\"\r\n :disabled=\"item.disabled\"\r\n :class=\"{ 'text-primary': !item.disabled }\"\r\n >\r\n {{ item.title }}\r\n </v-breadcrumbs-item>\r\n </template>\r\n </v-breadcrumbs>\r\n\r\n <!-- 右侧返回按钮 -->\r\n <v-btn\r\n v-if=\"showBack\"\r\n variant=\"text\"\r\n color=\"primary\"\r\n prepend-icon=\"mdi-arrow-left\"\r\n @click=\"handleBack\"\r\n style=\"height: 36px;\"\r\n >\r\n {{ backText }}\r\n </v-btn>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed, inject, getCurrentInstance } from 'vue'\r\n\r\nconst props = defineProps({\r\n // 面包屑项目数组\r\n items: {\r\n type: Array,\r\n default: () => []\r\n },\r\n // 是否显示返回按钮\r\n showBack: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 返回按钮文字\r\n backText: {\r\n type: String,\r\n default: '返回'\r\n },\r\n // 自定义返回路径,不传则返回上一级\r\n backTo: {\r\n type: [String, Object],\r\n default: null\r\n }\r\n})\r\n\r\nconst emit = defineEmits(['back'])\r\n\r\n// 使用inject安全地获取router和route\r\nconst router = inject('router', null)\r\nconst route = inject('route', null)\r\n\r\n// 处理面包屑数据\r\nconst breadcrumbItems = computed(() => {\r\n if (props.items && props.items.length > 0) {\r\n return props.items.map((item, index) => ({\r\n title: item.title || item.text || item.name,\r\n to: item.to || item.path || item.href,\r\n disabled: item.disabled !== undefined ? item.disabled : index === props.items.length - 1\r\n }))\r\n }\r\n\r\n // 如果route不可用,返回空数组\r\n if (!route) {\r\n return []\r\n }\r\n\r\n // 如果没有传入items,尝试从路由meta中获取\r\n const matched = route.matched?.filter(r => r.meta && r.meta.breadcrumb) || []\r\n if (matched.length > 0) {\r\n return matched.map((r, index) => ({\r\n title: r.meta.breadcrumb,\r\n to: r.path,\r\n disabled: index === matched.length - 1\r\n }))\r\n }\r\n\r\n // 默认返回当前路由路径生成的面包屑\r\n const pathArray = route.path?.split('/').filter(p => p) || []\r\n return pathArray.map((path, index) => {\r\n const routePath = '/' + pathArray.slice(0, index + 1).join('/')\r\n return {\r\n title: path.charAt(0).toUpperCase() + path.slice(1),\r\n to: routePath,\r\n disabled: index === pathArray.length - 1\r\n }\r\n })\r\n})\r\n\r\n// 处理返回按钮点击\r\nconst handleBack = () => {\r\n // 触发back事件\r\n emit('back')\r\n\r\n // 如果router不可用,仅触发事件\r\n if (!router) {\r\n return\r\n }\r\n\r\n // 如果传入了backTo参数,跳转到指定路径\r\n if (props.backTo) {\r\n if (typeof props.backTo === 'string') {\r\n router.push(props.backTo)\r\n } else {\r\n router.push(props.backTo)\r\n }\r\n } else {\r\n // 默认返回上一级\r\n router.back()\r\n }\r\n}\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-breadcrumb-wrapper {\r\n width: 100%;\r\n padding: 12px 0;\r\n\r\n :deep(.v-breadcrumbs) {\r\n flex-grow: 1;\r\n height: 36px;\r\n }\r\n\r\n :deep(.v-breadcrumbs-item) {\r\n font-size: 14px;\r\n }\r\n\r\n :deep(.v-breadcrumbs-divider) {\r\n padding: 0 8px;\r\n }\r\n\r\n :deep(.v-breadcrumbs-item--disabled) {\r\n opacity: 0.6;\r\n }\r\n}\r\n</style>\r\n","<template>\r\n <VInput \r\n v-bind=\"inputAttrs\" \r\n :model-value=\"inputValue\"\r\n >\r\n <div class=\"checkGroup\" :class=\"inline ? 'd-flex flex-wrap align-top' : 'd-inline-block'\">\r\n <VCheckbox\r\n v-for=\"item in items\"\r\n hide-details\r\n :key=\"item.id || item.code\"\r\n :label=\"item.codeValue\"\r\n :value=\"item.code\"\r\n v-model=\"localValue\"\r\n v-bind=\"checkboxAttrs\"\r\n :class=\"inline ? 'mr-4' : ''\"\r\n />\r\n </div>\r\n </VInput>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, useAttrs, computed, watch } from 'vue';\r\nimport Request from '../../commons/request';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkCheckbox\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n /**\r\n * 字典来源:\r\n * - 若为静态数据,格式如:\"0:否/1:是\"\r\n * - 若为字典键,格式如:\"DISABLE_TYPE\"\r\n */\r\n list: {\r\n type: String,\r\n required: true,\r\n },\r\n /**\r\n * 是否横向排列\r\n */\r\n inline: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n /**\r\n * 绑定值\r\n */\r\n modelValue: {\r\n type: [Array, String],\r\n default: () => []\r\n }\r\n});\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 本地选中值\r\nconst localValue = ref([]);\r\n\r\n// 防止递归更新的标志位\r\nconst isUpdatingLocal = ref(false);\r\nconst isUpdatingModel = ref(false);\r\n\r\n// 同步外部 modelValue 到本地值\r\nwatch(() => props.modelValue, (newVal) => {\r\n if (isUpdatingModel.value) {\r\n isUpdatingModel.value = false;\r\n return;\r\n }\r\n \r\n isUpdatingLocal.value = true;\r\n if (Array.isArray(newVal)) {\r\n localValue.value = [...newVal];\r\n } else if (typeof newVal === 'string') {\r\n localValue.value = newVal ? [newVal] : [];\r\n } else {\r\n localValue.value = [];\r\n }\r\n}, { immediate: true });\r\n\r\n// 同步本地值到外部 modelValue\r\nwatch(localValue, (newVal) => {\r\n if (isUpdatingLocal.value) {\r\n isUpdatingLocal.value = false;\r\n return;\r\n }\r\n \r\n isUpdatingModel.value = true;\r\n emit('update:modelValue', newVal);\r\n}, { deep: true });\r\n\r\n// 获取透传属性\r\nconst attrs = useAttrs();\r\n\r\n// 分离传递给 input 和传递给 checkbox 的属性\r\nconst inputAttrs = computed(() => {\r\n const { list, inline, modelValue, ...rest } = attrs;\r\n return rest;\r\n});\r\n\r\nconst checkboxAttrs = computed(() => {\r\n // 移除表单验证相关属性,避免重复应用\r\n const { \r\n list, \r\n inline, \r\n modelValue,\r\n error, \r\n 'error-messages': errorMessages, \r\n rules, \r\n hint, \r\n 'persistent-hint': persistentHint,\r\n ...rest \r\n } = attrs;\r\n return rest;\r\n});\r\n\r\n// 为 v-input 提供一个值\r\nconst inputValue = computed(() => {\r\n return localValue.value && localValue.value.length > 0 ? localValue.value : null;\r\n});\r\n\r\n// 响应式数据\r\nconst items = ref([]);\r\n\r\n// 处理静态数据(如 \"0:否/1:是\")\r\nconst statc = () => {\r\n props.list.split('/').forEach(it => {\r\n const [code, codeValue] = it.split(':');\r\n items.value.push({ code, codeValue });\r\n });\r\n};\r\n\r\n// 请求远程字典数据\r\nconst miscs = async () => {\r\n try {\r\n const res = await Request.getForm(`dict/misc/list/${props.list}`);\r\n items.value = res.data || [];\r\n } catch (error) {\r\n console.error('[VtkCheckbox] Failed to load dictionary:', error);\r\n items.value = [];\r\n }\r\n};\r\n\r\n// 组件挂载时初始化数据\r\nonMounted(() => {\r\n if (props.list.includes(':')) {\r\n statc();\r\n } else {\r\n miscs();\r\n }\r\n});\r\n</script>\r\n\r\n<style scoped>\r\n:deep(.v-checkbox .v-selection-control) {\r\n margin: 0;\r\n padding: 0;\r\n min-height: 32px;\r\n}\r\n\r\n:deep(.v-input__details) {\r\n padding-inline: 16px;\r\n}\r\n</style>","<!-- \r\n\r\n// 基础用法\r\n <VtkCount :start=\"0\" :end=\"12345\" :duration=\"3000\" suffix=\"次\" />\r\n \r\n//带前缀和分隔符\r\n <VtkCount \r\n :start=\"0\" \r\n :end=\"999999\" \r\n :duration=\"2000\" \r\n prefix=\"¥\" \r\n suffix=\"元\" \r\n :separator=\"true\" \r\n />\r\n \r\n//手动控制\r\n <VtkCount \r\n ref=\"countRef\" \r\n :start=\"0\" \r\n :end=\"100\" \r\n :autoplay=\"false\" \r\n @complete=\"onComplete\"\r\n />\r\n <VBtn @click=\"startCount\">开始计数</VBtn>\r\n -->\r\n\r\n<template>\r\n <div class=\"vtk-count\" :class=\"containerClass\">\r\n <div class=\"count-display\" :style=\"{ color: color }\">\r\n <!-- 前缀 -->\r\n <span v-if=\"prefix\" class=\"prefix\">{{ prefix }}</span>\r\n \r\n <!-- 数字容器 -->\r\n <div class=\"digits-container\">\r\n <div \r\n v-for=\"(digitChar, index) in maxDigitString\" \r\n :key=\"`digit-${index}-${digitKey}`\"\r\n class=\"digit-wrapper\"\r\n :class=\"{ 'digit-separator': isNaN(digitChar) }\"\r\n >\r\n <div \r\n v-if=\"!isNaN(digitChar)\" \r\n class=\"digit-scroll\"\r\n >\r\n <div \r\n v-for=\"n in 10\" \r\n :key=\"n\" \r\n class=\"digit-item\"\r\n :style=\"getDigitStyle(getCurrentDigit(index), n-1)\"\r\n >\r\n {{ n-1 }}\r\n </div>\r\n </div>\r\n <div v-else class=\"separator\">{{ digitChar }}</div>\r\n </div>\r\n </div>\r\n \r\n <!-- 后缀 -->\r\n <span v-if=\"suffix\" class=\"suffix\">{{ suffix }}</span>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, onMounted, watch, nextTick } from 'vue'\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkCount\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // 初始值\r\n start: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 目标值\r\n end: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 动画持续时间(毫秒)\r\n duration: {\r\n type: Number,\r\n default: 2000\r\n },\r\n // 是否自动开始动画\r\n autoplay: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 数字前缀\r\n prefix: {\r\n type: String,\r\n default: ''\r\n },\r\n // 数字后缀\r\n suffix: {\r\n type: String,\r\n default: ''\r\n },\r\n // 容器自定义类名\r\n containerClass: {\r\n type: String,\r\n default: ''\r\n },\r\n // 是否使用分隔符(千分位)\r\n separator: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 小数位数\r\n decimals: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 文字颜色\r\n color: {\r\n type: String,\r\n default: '#1976d2'\r\n }\r\n})\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['complete'])\r\n\r\n// 当前显示的数值\r\nconst currentNumber = ref(props.start)\r\n\r\n// 当前每个位置的数字值\r\nconst currentDigits = ref([])\r\n\r\n// 用于强制重新渲染的key\r\nconst digitKey = ref(0)\r\n\r\n// 是否正在动画中\r\nconst isAnimating = ref(false)\r\n\r\n// 格式化数字(处理小数和分隔符)\r\nconst formatNumber = (num) => {\r\n let result = num.toFixed(props.decimals)\r\n if (props.separator && props.decimals === 0) {\r\n result = result.replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',')\r\n }\r\n return result\r\n}\r\n\r\n// 获取目标数字字符串\r\nconst targetNumberString = computed(() => {\r\n return formatNumber(props.end)\r\n})\r\n\r\n// 获取起始数字字符串\r\nconst startNumberString = computed(() => {\r\n return formatNumber(props.start)\r\n})\r\n\r\n// 获取最大位数的字符串(用于保持DOM结构稳定)\r\nconst maxDigitString = computed(() => {\r\n const target = targetNumberString.value\r\n const start = startNumberString.value\r\n return target.length >= start.length ? target : start\r\n})\r\n\r\n// 获取当前指定位置的数字\r\nconst getCurrentDigit = (index) => {\r\n if (index < currentDigits.value.length) {\r\n return currentDigits.value[index]\r\n }\r\n return '0'\r\n}\r\n\r\n// 初始化数字数组\r\nconst initDigitsArray = () => {\r\n const targetStr = targetNumberString.value\r\n const startStr = startNumberString.value\r\n \r\n // 初始化currentDigits数组,确保长度与maxDigitString一致\r\n currentDigits.value = maxDigitString.value.split('').map((char, index) => {\r\n if (isNaN(char)) {\r\n return char // 分隔符保持原样\r\n }\r\n \r\n // 从起始字符串对应位置获取数字\r\n if (index < startStr.length) {\r\n const startChar = startStr[index]\r\n return isNaN(startChar) ? '0' : startChar\r\n }\r\n return '0'\r\n })\r\n}\r\n\r\n// 获取数字样式\r\nconst getDigitStyle = (currentValue, digitValue) => {\r\n // 如果是分隔符,直接返回\r\n if (isNaN(currentValue) || isNaN(digitValue)) {\r\n return {\r\n transform: 'translateY(0)'\r\n }\r\n }\r\n \r\n const current = parseInt(currentValue) || 0\r\n const target = digitValue\r\n const offset = target - current\r\n \r\n // 处理循环滚动(9->0 或 0->9)\r\n let translateY\r\n if (offset > 5) {\r\n // 向下滚动(如 9->0)\r\n translateY = -(10 - offset) * 100\r\n } else if (offset < -5) {\r\n // 向上滚动(如 0->9)\r\n translateY = (10 + offset) * 100\r\n } else {\r\n translateY = -offset * 100\r\n }\r\n \r\n return {\r\n transform: `translateY(${translateY}%)`,\r\n transition: isAnimating.value ? 'transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94)' : 'none',\r\n color: props.color\r\n }\r\n}\r\n\r\n// 开始数字动画\r\nconst startAnimation = () => {\r\n if (isAnimating.value) return\r\n \r\n isAnimating.value = true\r\n const startTime = performance.now()\r\n const startValue = props.start\r\n const endValue = props.end\r\n const diff = endValue - startValue\r\n \r\n // 初始化数字数组\r\n initDigitsArray()\r\n \r\n const animate = (currentTime) => {\r\n const elapsed = currentTime - startTime\r\n const progress = Math.min(elapsed / props.duration, 1)\r\n \r\n // 使用缓动函数使动画更自然\r\n const easeOutQuart = 1 - Math.pow(1 - progress, 4)\r\n currentNumber.value = startValue + diff * easeOutQuart\r\n \r\n // 更新每个数字位的当前值\r\n updateDigitArray(currentNumber.value)\r\n \r\n if (progress < 1) {\r\n requestAnimationFrame(animate)\r\n } else {\r\n currentNumber.value = endValue\r\n // 确保最终值准确\r\n updateDigitArray(endValue)\r\n isAnimating.value = false\r\n emit('complete')\r\n }\r\n }\r\n \r\n requestAnimationFrame(animate)\r\n}\r\n\r\n// 更新数字数组\r\nconst updateDigitArray = (value) => {\r\n const valueStr = formatNumber(value)\r\n const maxStr = maxDigitString.value\r\n \r\n // 保持数组长度不变,只更新值\r\n for (let i = 0; i < maxStr.length; i++) {\r\n if (i < valueStr.length) {\r\n currentDigits.value[i] = valueStr[i]\r\n } else {\r\n // 超出部分保持为'0'或分隔符\r\n currentDigits.value[i] = isNaN(maxStr[i]) ? maxStr[i] : '0'\r\n }\r\n }\r\n}\r\n\r\n// 监听 end 值变化,重新开始动画\r\nwatch(() => props.end, (newVal, oldVal) => {\r\n if (newVal !== oldVal) {\r\n // 当位数可能发生变化时,更新key强制重新渲染\r\n const newStr = formatNumber(newVal)\r\n const oldStr = formatNumber(oldVal)\r\n if (newStr.length !== oldStr.length) {\r\n digitKey.value += 1\r\n nextTick(() => {\r\n startAnimation()\r\n })\r\n } else {\r\n startAnimation()\r\n }\r\n }\r\n})\r\n\r\n// 组件挂载时开始动画\r\nonMounted(() => {\r\n if (props.autoplay) {\r\n // 检查初始值和目标值位数是否不同,如果不同则更新key\r\n const startStr = startNumberString.value\r\n const endStr = targetNumberString.value\r\n if (startStr.length !== endStr.length) {\r\n digitKey.value += 1\r\n }\r\n \r\n nextTick(() => {\r\n startAnimation()\r\n })\r\n }\r\n})\r\n\r\n// 提供外部调用方法\r\ndefineExpose({\r\n startAnimation\r\n})\r\n</script>\r\n\r\n<style scoped>\r\n.vtk-count {\r\n display: inline-block;\r\n}\r\n\r\n.count-display {\r\n display: flex;\r\n align-items: center;\r\n font-family: 'Roboto Mono', monospace;\r\n font-size: 24px;\r\n font-weight: bold;\r\n}\r\n\r\n.digits-container {\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n.digit-wrapper {\r\n position: relative;\r\n width: 1em;\r\n height: 1em;\r\n overflow: hidden;\r\n text-align: center;\r\n margin: 0 1px;\r\n}\r\n\r\n.digit-wrapper.digit-separator {\r\n width: auto;\r\n animation: none;\r\n}\r\n\r\n.digit-scroll {\r\n position: relative;\r\n height: 100%;\r\n}\r\n\r\n.digit-item {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.separator {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 100%;\r\n font-weight: normal;\r\n}\r\n\r\n.prefix, .suffix {\r\n font-size: 0.8em;\r\n align-self: flex-end;\r\n margin-bottom: 0.1em;\r\n}\r\n\r\n.prefix {\r\n margin-right: 4px;\r\n}\r\n\r\n.suffix {\r\n margin-left: 4px;\r\n}\r\n\r\n/* 响应式设计 */\r\n@media (max-width: 768px) {\r\n .count-display {\r\n font-size: 20px;\r\n }\r\n}\r\n\r\n@media (max-width: 480px) {\r\n .count-display {\r\n font-size: 18px;\r\n }\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-date-range-picker\">\r\n <VMenu\r\n v-model=\"menu\"\r\n :close-on-content-click=\"false\"\r\n transition=\"scale-transition\"\r\n offset-y\r\n min-width=\"auto\"\r\n eager\r\n >\r\n <template #activator=\"{ props: activatorProps }\">\r\n <VTextField\r\n v-bind=\"{ ...activatorProps, ...textFieldProps }\"\r\n v-model=\"displayValue\"\r\n :placeholder=\"placeholder\"\r\n :disabled=\"disabled\"\r\n readonly\r\n clearable\r\n density=\"compact\"\r\n variant=\"outlined\"\r\n @click:clear=\"clearValue\"\r\n >\r\n <template #prepend-inner>\r\n <VIcon size=\"small\">mdi-calendar</VIcon>\r\n </template>\r\n </VTextField>\r\n </template>\r\n \r\n <VCard style=\"width: 650px;\">\r\n <VCardText class=\"pa-0\">\r\n <div class=\"date-picker-container\">\r\n <VDatePicker\r\n v-model=\"startDateRange\"\r\n hide-header\r\n :min=\"minDate\"\r\n :max=\"maxDate\"\r\n :show-current=\"showCurrent\"\r\n @update:model-value=\"onStartDateChange\"\r\n class=\"date-picker-item\"\r\n />\r\n <VDatePicker\r\n v-model=\"endDateRange\"\r\n hide-header\r\n :min=\"minDate\"\r\n :max=\"maxDate\"\r\n :show-current=\"showCurrent\"\r\n @update:model-value=\"onEndDateChange\"\r\n class=\"date-picker-item\"\r\n />\r\n </div>\r\n </VCardText>\r\n \r\n <VDivider></VDivider>\r\n \r\n <VCardActions>\r\n <VSpacer></VSpacer>\r\n <VBtn text @click=\"cancel\">取消</VBtn>\r\n <VBtn color=\"primary\" variant=\"tonal\" @click=\"confirm\">确定</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VMenu>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch, useAttrs } from 'vue';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkDatePicker\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n // v-model绑定值\r\n modelValue: {\r\n type: [Array, String],\r\n default: () => []\r\n },\r\n // 占位符\r\n placeholder: {\r\n type: String,\r\n default: '请选择日期范围'\r\n },\r\n // 禁用状态\r\n disabled: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 最小日期\r\n min: {\r\n type: String,\r\n default: undefined\r\n },\r\n // 最大日期\r\n max: {\r\n type: String,\r\n default: undefined\r\n },\r\n // 是否显示当前日期\r\n showCurrent: {\r\n type: [Boolean, String],\r\n default: true\r\n },\r\n // 显示格式\r\n format: {\r\n type: String,\r\n default: 'YYYY-MM-DD'\r\n },\r\n // 分隔符\r\n separator: {\r\n type: String,\r\n default: ' 至 '\r\n }\r\n});\r\n\r\n// 定义emit事件\r\nconst emit = defineEmits(['update:modelValue', 'change']);\r\n\r\n// 获取透传属性\r\nconst attrs = useAttrs();\r\n\r\n// 菜单显示控制\r\nconst menu = ref(false);\r\n\r\n// 日期范围值\r\nconst dateRange = ref([]);\r\n\r\n// 为了横向排列,需要分别管理开始和结束日期选择器的值\r\nconst startDateRange = ref(null);\r\nconst endDateRange = ref(null);\r\n\r\n\r\n// 显示值\r\nconst displayValue = computed(() => {\r\n if (!dateRange.value || dateRange.value.length === 0) {\r\n return '';\r\n }\r\n \r\n if (dateRange.value.length === 1) {\r\n return formatDate(dateRange.value[0]);\r\n }\r\n \r\n return `${formatDate(dateRange.value[0])}${props.separator}${formatDate(dateRange.value[1])}`;\r\n});\r\n\r\n// 文本框属性\r\nconst textFieldProps = computed(() => {\r\n // 排除我们自己使用的属性\r\n const { \r\n modelValue, \r\n placeholder, \r\n disabled, \r\n min, \r\n max, \r\n showCurrent, \r\n format,\r\n separator,\r\n ...rest \r\n } = attrs;\r\n \r\n return rest;\r\n});\r\n\r\n// 格式化日期\r\nconst formatDate = (date) => {\r\n if (!date) return '';\r\n \r\n // 如果是字符串直接返回\r\n if (typeof date === 'string') {\r\n return date;\r\n }\r\n \r\n // 如果是 Date 对象\r\n if (date instanceof Date) {\r\n const year = date.getFullYear();\r\n const month = String(date.getMonth() + 1).padStart(2, '0');\r\n const day = String(date.getDate()).padStart(2, '0');\r\n return `${year}-${month}-${day}`;\r\n }\r\n \r\n return date;\r\n};\r\n\r\n// 最小日期\r\nconst minDate = computed(() => props.min);\r\n\r\n// 最大日期\r\nconst maxDate = computed(() => props.max);\r\n\r\n// 监听外部modelValue变化\r\nwatch(\r\n () => props.modelValue,\r\n (newValue) => {\r\n if (Array.isArray(newValue) && newValue.length > 0) {\r\n dateRange.value = [...newValue];\r\n // 同步到单独的日期选择器\r\n if (newValue[0]) startDateRange.value = newValue[0];\r\n if (newValue[1]) endDateRange.value = newValue[1];\r\n } else if (typeof newValue === 'string' && newValue) {\r\n // 处理字符串形式的日期范围,如 \"2023-01-01 至 2023-01-31\"\r\n const dates = newValue.split(props.separator);\r\n if (dates.length === 2) {\r\n dateRange.value = [dates[0].trim(), dates[1].trim()];\r\n startDateRange.value = dates[0].trim();\r\n endDateRange.value = dates[1].trim();\r\n } else {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n }\r\n } else {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n }\r\n },\r\n { immediate: true }\r\n);\r\n\r\n\r\n// 开始日期变化处理\r\nconst onStartDateChange = (value) => {\r\n // 更新日期范围的第一个值\r\n if (value) {\r\n dateRange.value = [value, dateRange.value[1] || null];\r\n } else {\r\n // 如果开始日期被清除,清除整个范围或只清除开始日期\r\n if (dateRange.value.length > 0) {\r\n dateRange.value = [null, dateRange.value[1] || null];\r\n }\r\n }\r\n};\r\n\r\n// 结束日期变化处理\r\nconst onEndDateChange = (value) => {\r\n // 更新日期范围的第二个值\r\n if (value) {\r\n dateRange.value = [dateRange.value[0] || null, value];\r\n } else {\r\n // 如果结束日期被清除,只清除结束日期\r\n if (dateRange.value.length > 1) {\r\n dateRange.value = [dateRange.value[0] || null, null];\r\n }\r\n }\r\n};\r\n\r\n// 清除值\r\nconst clearValue = () => {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n emit('update:modelValue', []);\r\n emit('change', []);\r\n menu.value = false;\r\n};\r\n\r\n// 取消\r\nconst cancel = () => {\r\n // 恢复到原始值\r\n if (Array.isArray(props.modelValue)) {\r\n dateRange.value = [...props.modelValue];\r\n if (props.modelValue[0]) startDateRange.value = props.modelValue[0];\r\n if (props.modelValue[1]) endDateRange.value = props.modelValue[1];\r\n } else {\r\n dateRange.value = [];\r\n startDateRange.value = null;\r\n endDateRange.value = null;\r\n }\r\n menu.value = false;\r\n};\r\n\r\n// 确认\r\nconst confirm = () => {\r\n // 确保日期按顺序排列\r\n let sortedRange = [...dateRange.value].filter(date => date !== null);\r\n if (sortedRange.length === 2) {\r\n const date1 = new Date(sortedRange[0]);\r\n const date2 = new Date(sortedRange[1]);\r\n if (date1 > date2) {\r\n sortedRange = [sortedRange[1], sortedRange[0]];\r\n }\r\n } else if (sortedRange.length === 1) {\r\n // 如果只有一个日期,复制为范围\r\n sortedRange = [sortedRange[0], sortedRange[0]];\r\n }\r\n \r\n emit('update:modelValue', sortedRange);\r\n emit('change', sortedRange);\r\n menu.value = false;\r\n};\r\n</script>\r\n\r\n<style scoped>\r\n.vtk-date-range-picker {\r\n width: 100%;\r\n}\r\n\r\n.date-picker-container {\r\n display: flex;\r\n flex-direction: row;\r\n gap: 0;\r\n}\r\n\r\n.date-picker-item {\r\n flex: 1;\r\n max-width: 50%;\r\n}\r\n\r\n.date-picker-item:first-child {\r\n border-right: 1px solid rgba(0, 0, 0, 0.12);\r\n}\r\n\r\n:deep(.v-picker) {\r\n border-radius: 0;\r\n}\r\n\r\n:deep(.v-date-picker-month__day--adjacent) {\r\n opacity: 0.5;\r\n}\r\n\r\n:deep(.v-date-picker-title) {\r\n display: none;\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-date-selector\">\r\n <VMenu\r\n v-if=\"!inline\"\r\n v-model=\"showPicker\"\r\n :attach=\"menuAttach\"\r\n :location=\"menuLocation\"\r\n :origin=\"menuOrigin\"\r\n offset=\"4\"\r\n :close-on-content-click=\"false\"\r\n >\r\n <template #activator=\"{ props: menuProps }\">\r\n <div class=\"date-input\">\r\n <VTextField :model-value=\"displayValue\" :placeholder=\"placeholder\" :disabled=\"disabled\" density=\"compact\"\r\n variant=\"outlined\" hide-details readonly v-bind=\"menuProps\" :clearable=\"!!displayValue && !disabled\"\r\n clear-icon=\"mdi-close-circle\" persistent-clear class=\"date-input-field\" @click:clear.stop=\"clearValue\">\r\n <template #append-inner>\r\n <span class=\"date-icon\" aria-hidden=\"true\">\r\n <svg viewBox=\"0 0 24 24\" fill=\"none\" class=\"date-icon-svg\">\r\n <path\r\n d=\"M7 2.75a.75.75 0 0 1 .75.75V5h8.5V3.5a.75.75 0 0 1 1.5 0V5h.75A2.5 2.5 0 0 1 21 7.5v10A2.5 2.5 0 0 1 18.5 20h-13A2.5 2.5 0 0 1 3 17.5v-10A2.5 2.5 0 0 1 5.5 5h.75V3.5A.75.75 0 0 1 7 2.75ZM4.5 10v7.5c0 .552.448 1 1 1h13c.552 0 1-.448 1-1V10h-15Zm1-3.5c-.552 0-1 .448-1 1v1h15v-1c0-.552-.448-1-1-1h-.75v1a.75.75 0 0 1-1.5 0v-1h-8.5v1a.75.75 0 0 1-1.5 0v-1H5.5Zm2.25 5.75a.75.75 0 0 1 .75.75v.25a.75.75 0 0 1-1.5 0V13a.75.75 0 0 1 .75-.75Zm4.25 0a.75.75 0 0 1 .75.75v.25a.75.75 0 0 1-1.5 0V13a.75.75 0 0 1 .75-.75Zm4.25 0a.75.75 0 0 1 .75.75v.25a.75.75 0 0 1-1.5 0V13a.75.75 0 0 1 .75-.75Zm-8.5 3.75a.75.75 0 0 1 .75.75V17a.75.75 0 0 1-1.5 0v-.25a.75.75 0 0 1 .75-.75Zm4.25 0a.75.75 0 0 1 .75.75V17a.75.75 0 0 1-1.5 0v-.25a.75.75 0 0 1 .75-.75Z\"\r\n fill=\"currentColor\" />\r\n </svg>\r\n </span>\r\n </template>\r\n </VTextField>\r\n </div>\r\n </template>\r\n <div class=\"date-picker-dropdown\" @click.stop @mousedown.stop>\r\n <!-- 头部控制区(非日期/月份范围选择模式时显示) -->\r\n <div v-if=\"!(mode === 'range' && (displayMode === 'day' || displayMode === 'month'))\" class=\"picker-header\">\r\n <button class=\"nav-btn\" @click=\"prevPeriod\">‹</button>\r\n <div class=\"header-title\">\r\n <span @click=\"changeViewMode('year')\" class=\"clickable\">{{ currentYear }}年</span>\r\n <span v-if=\"displayMode !== 'year' && viewMode !== 'month'\" @click=\"changeViewMode('month')\"\r\n class=\"clickable\">{{\r\n currentMonth + 1\r\n }}月</span>\r\n </div>\r\n <button class=\"nav-btn\" @click=\"nextPeriod\">›</button>\r\n </div>\r\n\r\n <!-- 年份选择视图 -->\r\n <div v-if=\"viewMode === 'year'\" class=\"picker-body\">\r\n <div class=\"year-grid\">\r\n <div v-for=\"year in yearList\" :key=\"year\"\r\n :class=\"['year-item', { 'selected': isYearSelected(year), 'in-range': isYearInRange(year), 'disabled': isFutureYear(year) }]\"\r\n @click=\"selectYear(year)\">\r\n {{ year }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 月份选择视图 -->\r\n <div v-else-if=\"viewMode === 'month'\" class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个年份的月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYear\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYearLeft\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYearRight\">‹</button>\r\n <span class=\"month-title\">{{ rightYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYear\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelectedRight(index), 'in-range': isMonthInRangeRight(index), 'disabled': isFutureMonth(index, rightYear) }]\"\r\n @click=\"selectMonthRight(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个年份的月份 -->\r\n <div v-else>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 周选择视图 -->\r\n <div v-else-if=\"viewMode === 'week'\" class=\"picker-body\">\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"week-grid\">\r\n <div v-for=\"week in weekList\" :key=\"week.weekNumber\"\r\n :class=\"['week-row', { 'selected': isWeekSelected(week), 'in-range': isWeekInRange(week) }]\"\r\n @click=\"selectWeek(week)\">\r\n <div class=\"week-number\">W{{ week.weekNumber }}</div>\r\n <div v-for=\"day in week.days\" :key=\"day.date\"\r\n :class=\"['day-cell', { 'other-month': day.otherMonth, 'today': day.isToday }]\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 日期选择视图(默认) -->\r\n <div v-else class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonth\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年{{ currentMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonthLeft\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonthRight\">‹</button>\r\n <span class=\"month-title\">{{ nextMonthYear }}年{{ nextMonthMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonth\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in nextMonthDayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个月份 -->\r\n <div v-else>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 底部操作区 -->\r\n <div v-if=\"mode === 'range' && (displayMode === 'day' || displayMode === 'month')\" class=\"range-display\">\r\n <span class=\"range-text\">\r\n <template v-if=\"tempValue && Array.isArray(tempValue) && tempValue.length > 0\">\r\n {{ tempValue[0] || (displayMode === 'month' ? '开始月份' : '开始日期') }}\r\n <span class=\"range-separator\"> - </span>\r\n {{ tempValue[1] || (displayMode === 'month' ? '结束月份' : '结束日期') }}\r\n </template>\r\n <template v-else>\r\n <span class=\"placeholder-text\">{{ displayMode === 'month' ? '请选择月份范围' : '请选择日期范围' }}</span>\r\n </template>\r\n </span>\r\n </div>\r\n <div class=\"picker-footer\">\r\n <button class=\"btn btn-text\" @click=\"handleCancel\">取消</button>\r\n <button class=\"btn btn-primary\" @click=\"handleConfirm\">确定</button>\r\n </div>\r\n </div>\r\n </VMenu>\r\n <div v-if=\"inline\" class=\"date-picker-dropdown inline-mode\" @click.stop @mousedown.stop>\r\n <!-- 头部控制区(非日期/月份范围选择模式时显示) -->\r\n <div v-if=\"!(mode === 'range' && (displayMode === 'day' || displayMode === 'month'))\" class=\"picker-header\">\r\n <button class=\"nav-btn\" @click=\"prevPeriod\">‹</button>\r\n <div class=\"header-title\">\r\n <span @click=\"changeViewMode('year')\" class=\"clickable\">{{ currentYear }}年</span>\r\n <span v-if=\"displayMode !== 'year' && viewMode !== 'month'\" @click=\"changeViewMode('month')\"\r\n class=\"clickable\">{{\r\n currentMonth + 1\r\n }}月</span>\r\n </div>\r\n <button class=\"nav-btn\" @click=\"nextPeriod\">›</button>\r\n </div>\r\n\r\n <!-- 年份选择视图 -->\r\n <div v-if=\"viewMode === 'year'\" class=\"picker-body\">\r\n <div class=\"year-grid\">\r\n <div v-for=\"year in yearList\" :key=\"year\"\r\n :class=\"['year-item', { 'selected': isYearSelected(year), 'in-range': isYearInRange(year), 'disabled': isFutureYear(year) }]\"\r\n @click=\"selectYear(year)\">\r\n {{ year }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 月份选择视图 -->\r\n <div v-else-if=\"viewMode === 'month'\" class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个年份的月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYear\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYearLeft\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧年份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevYearRight\">‹</button>\r\n <span class=\"month-title\">{{ rightYear }}年</span>\r\n <button class=\"nav-btn-small\" @click=\"nextYear\">›</button>\r\n </div>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelectedRight(index), 'in-range': isMonthInRangeRight(index), 'disabled': isFutureMonth(index, rightYear) }]\"\r\n @click=\"selectMonthRight(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个年份的月份 -->\r\n <div v-else>\r\n <div class=\"month-grid\">\r\n <div v-for=\"(month, index) in monthList\" :key=\"index\"\r\n :class=\"['month-item', { 'selected': isMonthSelected(index), 'in-range': isMonthInRange(index), 'disabled': isFutureMonth(index, currentYear) }]\"\r\n @click=\"selectMonth(index)\">\r\n {{ month }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 周选择视图 -->\r\n <div v-else-if=\"viewMode === 'week'\" class=\"picker-body\">\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"week-grid\">\r\n <div v-for=\"week in weekList\" :key=\"week.weekNumber\"\r\n :class=\"['week-row', { 'selected': isWeekSelected(week), 'in-range': isWeekInRange(week) }]\"\r\n @click=\"selectWeek(week)\">\r\n <div class=\"week-number\">W{{ week.weekNumber }}</div>\r\n <div v-for=\"day in week.days\" :key=\"day.date\"\r\n :class=\"['day-cell', { 'other-month': day.otherMonth, 'today': day.isToday }]\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 日期选择视图(默认) -->\r\n <div v-else class=\"picker-body\">\r\n <!-- 范围选择模式:显示两个月份 -->\r\n <div v-if=\"mode === 'range'\" class=\"dual-calendar\">\r\n <!-- 左侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonth\">‹</button>\r\n <span class=\"month-title\">{{ currentYear }}年{{ currentMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonthLeft\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <template v-if=\"!singlePanel\">\r\n <!-- 分割线 -->\r\n <div class=\"calendar-divider\"></div>\r\n\r\n <!-- 右侧月份 -->\r\n <div class=\"calendar-panel\">\r\n <div class=\"calendar-header\">\r\n <button class=\"nav-btn-small\" @click=\"prevMonthRight\">‹</button>\r\n <span class=\"month-title\">{{ nextMonthYear }}年{{ nextMonthMonth + 1 }}月</span>\r\n <button class=\"nav-btn-small\" @click=\"nextMonth\">›</button>\r\n </div>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in nextMonthDayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday,\r\n 'disabled': isFutureDay(day)\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </template>\r\n </div>\r\n\r\n <!-- 单选模式:显示一个月份 -->\r\n <div v-else>\r\n <div class=\"week-header\">\r\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\r\n </div>\r\n <div class=\"day-grid\">\r\n <div v-for=\"day in dayList\" :key=\"day.date\" :class=\"['day-item', {\r\n 'other-month': day.otherMonth,\r\n 'selected': isDaySelected(day),\r\n 'in-range': isDayInRange(day),\r\n 'range-start': isDayRangeStart(day),\r\n 'range-end': isDayRangeEnd(day),\r\n 'today': day.isToday\r\n }]\" @click=\"selectDay(day)\">\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- 底部操作区 -->\r\n <div v-if=\"mode === 'range' && (displayMode === 'day' || displayMode === 'month')\" class=\"range-display\">\r\n <span class=\"range-text\">\r\n <template v-if=\"tempValue && Array.isArray(tempValue) && tempValue.length > 0\">\r\n {{ tempValue[0] || (displayMode === 'month' ? '开始月份' : '开始日期') }}\r\n <span class=\"range-separator\"> - </span>\r\n {{ tempValue[1] || (displayMode === 'month' ? '结束月份' : '结束日期') }}\r\n </template>\r\n <template v-else>\r\n <span class=\"placeholder-text\">{{ displayMode === 'month' ? '请选择月份范围' : '请选择日期范围' }}</span>\r\n </template>\r\n </span>\r\n </div>\r\n <div class=\"picker-footer\">\r\n <button class=\"btn btn-text\" @click=\"handleCancel\">取消</button>\r\n <button class=\"btn btn-primary\" @click=\"handleConfirm\">确定</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch } from 'vue';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: 'VtkDateSelector',\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // v-model 绑定值\r\n modelValue: {\r\n type: [String, Array],\r\n default: null\r\n },\r\n // 显示模式: 'day' | 'week' | 'month' | 'year'\r\n displayMode: {\r\n type: String,\r\n default: 'day',\r\n validator: (value) => ['day', 'week', 'month', 'year'].includes(value)\r\n },\r\n // 选择模式: 'single' | 'range'\r\n mode: {\r\n type: String,\r\n default: 'single',\r\n validator: (value) => ['single', 'range'].includes(value)\r\n },\r\n // 占位符\r\n placeholder: {\r\n type: String,\r\n default: '请选择日期'\r\n },\r\n // 禁用状态\r\n disabled: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 日期格式\r\n format: {\r\n type: String,\r\n default: 'YYYY-MM-DD'\r\n },\r\n // 范围分隔符\r\n separator: {\r\n type: String,\r\n default: ' 至 '\r\n },\r\n // 内联模式(直接显示选择器,不需要点击输入框)\r\n inline: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 单面板模式(范围选择时只显示一个面板)\r\n singlePanel: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 禁用未来日期(大于当前日期的都置灰不可选)\r\n disableFuture: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 自定义取消方法\r\n onCancel: {\r\n type: Function,\r\n default: null\r\n },\r\n // 自定义确认方法\r\n onConfirm: {\r\n type: Function,\r\n default: null\r\n },\r\n // 禁用 Teleport 时,弹层保留在当前 DOM 树内\r\n noTeleport: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 下拉框对齐方式: 'left' | 'right'\r\n placement: {\r\n type: String,\r\n default: 'left',\r\n validator: (value) => ['left', 'right'].includes(value)\r\n }\r\n});\r\n\r\n// 定义 emit\r\nconst emit = defineEmits(['update:modelValue', 'change', 'cancel', 'confirm']);\r\n\r\n// 响应式数据\r\nconst showPicker = ref(false);\r\nconst viewMode = ref(props.displayMode);\r\nconst currentYear = ref(new Date().getFullYear());\r\nconst currentMonth = ref(new Date().getMonth());\r\nconst rightYear = ref(new Date().getFullYear());\r\nconst rightMonth = ref(new Date().getMonth() + 1);\r\nconst selectedValue = ref(null);\r\nconst tempValue = ref(null);\r\n\r\n// 当前日期(用于判断未来日期)\r\nconst today = new Date();\r\nconst todayYear = today.getFullYear();\r\nconst todayMonth = today.getMonth();\r\nconst todayDate = today.getDate();\r\n\r\n// 年份面板固定展示 12 个年份,并尽量让锚点年份落在中间偏前位置\r\nconst YEAR_PANEL_SIZE = 12;\r\nconst YEAR_PANEL_CENTER_OFFSET = 4;\r\n\r\n// 周和月份名称\r\nconst weekDays = ['日', '一', '二', '三', '四', '五', '六'];\r\nconst monthList = ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'];\r\n\r\n// 显示值\r\nconst menuAttach = computed(() => (props.noTeleport ? true : false));\r\n\r\nconst menuLocation = computed(() => props.placement === 'right' ? 'bottom end' : 'bottom start');\r\n\r\nconst menuOrigin = computed(() => props.placement === 'right' ? 'top end' : 'top start');\r\n\r\nconst displayValue = computed(() => {\r\n if (!selectedValue.value) return '';\r\n\r\n if (props.mode === 'range' && Array.isArray(selectedValue.value)) {\r\n if (selectedValue.value.length === 2) {\r\n return `${formatDisplay(selectedValue.value[0])}${props.separator}${formatDisplay(selectedValue.value[1])}`;\r\n }\r\n return '';\r\n }\r\n\r\n return formatDisplay(selectedValue.value);\r\n});\r\n\r\n// 格式化显示\r\nconst formatDisplay = (value) => {\r\n if (!value) return '';\r\n\r\n if (props.displayMode === 'year') {\r\n return `${value}年`;\r\n } else if (props.displayMode === 'month') {\r\n const [year, month] = value.split('-');\r\n return `${year}年${month}月`;\r\n } else if (props.displayMode === 'week') {\r\n const [year, week] = value.split('-W');\r\n return `${year}年第${week}周`;\r\n }\r\n\r\n return value;\r\n};\r\n\r\n// 年份列表(显示12年)\r\nconst yearList = computed(() => {\r\n // 年份面板打开时,以当前锚点年份为中心生成 12 个年份选项\r\n const startYear = currentYear.value - YEAR_PANEL_CENTER_OFFSET;\r\n return Array.from({ length: YEAR_PANEL_SIZE }, (_, i) => startYear + i);\r\n});\r\n\r\n// 周列表\r\nconst weekList = computed(() => {\r\n const weeks = [];\r\n const firstDay = new Date(currentYear.value, currentMonth.value, 1);\r\n const lastDay = new Date(currentYear.value, currentMonth.value + 1, 0);\r\n\r\n let currentDate = new Date(firstDay);\r\n currentDate.setDate(currentDate.getDate() - currentDate.getDay());\r\n\r\n let weekNumber = getWeekNumber(currentDate);\r\n\r\n while (currentDate <= lastDay || currentDate.getDay() !== 0) {\r\n const week = {\r\n weekNumber: weekNumber,\r\n startDate: new Date(currentDate),\r\n days: []\r\n };\r\n\r\n for (let i = 0; i < 7; i++) {\r\n const day = {\r\n date: formatDate(currentDate),\r\n day: currentDate.getDate(),\r\n month: currentDate.getMonth(),\r\n year: currentDate.getFullYear(),\r\n otherMonth: currentDate.getMonth() !== currentMonth.value,\r\n isToday: isToday(currentDate)\r\n };\r\n week.days.push(day);\r\n currentDate.setDate(currentDate.getDate() + 1);\r\n }\r\n\r\n weeks.push(week);\r\n weekNumber++;\r\n\r\n if (currentDate > lastDay && currentDate.getDay() === 0) break;\r\n }\r\n\r\n return weeks;\r\n});\r\n\r\n// 日期列表\r\nconst dayList = computed(() => {\r\n const days = [];\r\n const firstDay = new Date(currentYear.value, currentMonth.value, 1);\r\n const lastDay = new Date(currentYear.value, currentMonth.value + 1, 0);\r\n\r\n const startDate = new Date(firstDay);\r\n startDate.setDate(startDate.getDate() - startDate.getDay());\r\n\r\n const endDate = new Date(lastDay);\r\n endDate.setDate(endDate.getDate() + (6 - endDate.getDay()));\r\n\r\n let currentDate = new Date(startDate);\r\n\r\n while (currentDate <= endDate) {\r\n days.push({\r\n date: formatDate(currentDate),\r\n day: currentDate.getDate(),\r\n month: currentDate.getMonth(),\r\n year: currentDate.getFullYear(),\r\n otherMonth: currentDate.getMonth() !== currentMonth.value,\r\n isToday: isToday(currentDate)\r\n });\r\n currentDate.setDate(currentDate.getDate() + 1);\r\n }\r\n\r\n return days;\r\n});\r\n\r\n// 右侧日历的年份和月份(独立状态)\r\nconst nextMonthYear = computed(() => rightYear.value);\r\nconst nextMonthMonth = computed(() => rightMonth.value);\r\n\r\n// 下个月的日期列表\r\nconst nextMonthDayList = computed(() => {\r\n const days = [];\r\n const firstDay = new Date(nextMonthYear.value, nextMonthMonth.value, 1);\r\n const lastDay = new Date(nextMonthYear.value, nextMonthMonth.value + 1, 0);\r\n\r\n const startDate = new Date(firstDay);\r\n startDate.setDate(startDate.getDate() - startDate.getDay());\r\n\r\n const endDate = new Date(lastDay);\r\n endDate.setDate(endDate.getDate() + (6 - endDate.getDay()));\r\n\r\n let currentDate = new Date(startDate);\r\n\r\n while (currentDate <= endDate) {\r\n days.push({\r\n date: formatDate(currentDate),\r\n day: currentDate.getDate(),\r\n month: currentDate.getMonth(),\r\n year: currentDate.getFullYear(),\r\n otherMonth: currentDate.getMonth() !== nextMonthMonth.value,\r\n isToday: isToday(currentDate)\r\n });\r\n currentDate.setDate(currentDate.getDate() + 1);\r\n }\r\n\r\n return days;\r\n});\r\n\r\n// 工具函数\r\nconst formatDate = (date) => {\r\n const year = date.getFullYear();\r\n const month = String(date.getMonth() + 1).padStart(2, '0');\r\n const day = String(date.getDate()).padStart(2, '0');\r\n return `${year}-${month}-${day}`;\r\n};\r\n\r\nconst isToday = (date) => {\r\n const today = new Date();\r\n return date.getDate() === today.getDate() &&\r\n date.getMonth() === today.getMonth() &&\r\n date.getFullYear() === today.getFullYear();\r\n};\r\n\r\nconst getWeekNumber = (date) => {\r\n const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n const dayNum = d.getUTCDay() || 7;\r\n d.setUTCDate(d.getUTCDate() + 4 - dayNum);\r\n const yearStart = new Date(Date.UTC(d.getUTCFullYear(), 0, 1));\r\n return Math.ceil((((d - yearStart) / 86400000) + 1) / 7);\r\n};\r\n\r\n// 选择判断\r\nconst isYearSelected = (year) => {\r\n if (!tempValue.value) return false;\r\n if (props.mode === 'single') {\r\n return tempValue.value === year.toString();\r\n }\r\n if (Array.isArray(tempValue.value) && tempValue.value.length > 0) {\r\n return tempValue.value.some(v => v && v.startsWith(year.toString()));\r\n }\r\n return false;\r\n};\r\n\r\nconst isYearInRange = (year) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const [start, end] = tempValue.value.map(v => parseInt(v));\r\n return year > start && year < end;\r\n};\r\n\r\nconst isMonthSelected = (month) => {\r\n if (!tempValue.value) return false;\r\n const monthStr = `${currentYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n return tempValue.value === monthStr;\r\n }\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(monthStr);\r\n }\r\n return false;\r\n};\r\n\r\nconst isMonthInRange = (month) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const monthStr = `${currentYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n return monthStr > tempValue.value[0] && monthStr < tempValue.value[1];\r\n};\r\n\r\nconst isWeekSelected = (week) => {\r\n if (!tempValue.value) return false;\r\n const weekStr = `${currentYear.value}-W${String(week.weekNumber).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n return tempValue.value === weekStr;\r\n }\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(weekStr);\r\n }\r\n return false;\r\n};\r\n\r\nconst isWeekInRange = (week) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const weekStr = `${currentYear.value}-W${String(week.weekNumber).padStart(2, '0')}`;\r\n return weekStr > tempValue.value[0] && weekStr < tempValue.value[1];\r\n};\r\n\r\nconst isDaySelected = (day) => {\r\n if (!tempValue.value) return false;\r\n if (props.mode === 'single') {\r\n return tempValue.value === day.date;\r\n }\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(day.date);\r\n }\r\n return false;\r\n};\r\n\r\nconst isDayInRange = (day) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n return day.date > tempValue.value[0] && day.date < tempValue.value[1];\r\n};\r\n\r\nconst isDayRangeStart = (day) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length === 0) {\r\n return false;\r\n }\r\n return day.date === tempValue.value[0];\r\n};\r\n\r\nconst isDayRangeEnd = (day) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length < 2) {\r\n return false;\r\n }\r\n return day.date === tempValue.value[1];\r\n};\r\n\r\n// 判断是否是未来日期/月份/年份\r\nconst isFutureYear = (year) => {\r\n if (!props.disableFuture) return false;\r\n return year > todayYear;\r\n};\r\n\r\nconst isFutureMonth = (month, year) => {\r\n if (!props.disableFuture) return false;\r\n if (year > todayYear) return true;\r\n if (year === todayYear && month > todayMonth) return true;\r\n return false;\r\n};\r\n\r\nconst isFutureDay = (day) => {\r\n if (!props.disableFuture) return false;\r\n const [year, month, date] = day.date.split('-').map(Number);\r\n if (year > todayYear) return true;\r\n if (year === todayYear && month - 1 > todayMonth) return true;\r\n if (year === todayYear && month - 1 === todayMonth && date > todayDate) return true;\r\n return false;\r\n};\r\n\r\n// 选择操作\r\nconst selectYear = (year) => {\r\n // 如果是未来年份且禁用未来日期,则不允许选择\r\n if (isFutureYear(year)) return;\r\n\r\n const yearStr = year.toString();\r\n\r\n // 如果 displayMode 是 'year',则选择年份作为值\r\n if (props.displayMode === 'year') {\r\n if (props.mode === 'single') {\r\n tempValue.value = yearStr;\r\n if (props.inline) {\r\n // 内联模式直接确认\r\n confirm();\r\n }\r\n } else {\r\n // 范围选择\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [yearStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= yearStr ? [first, yearStr] : [yearStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [yearStr];\r\n }\r\n }\r\n } else {\r\n // 如果 displayMode 不是 'year',则只是切换年份,然后返回到原来的视图\r\n currentYear.value = year;\r\n // 切换回原来的显示模式\r\n viewMode.value = props.displayMode;\r\n }\r\n};\r\n\r\nconst selectMonth = (month) => {\r\n // 如果是未来月份且禁用未来日期,则不允许选择\r\n if (isFutureMonth(month, currentYear.value)) return;\r\n\r\n if (props.displayMode !== 'month') {\r\n currentMonth.value = month;\r\n viewMode.value = props.displayMode;\r\n return;\r\n }\r\n\r\n const monthStr = `${currentYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n tempValue.value = monthStr;\r\n if (props.displayMode === 'month' || props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [monthStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= monthStr ? [first, monthStr] : [monthStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [monthStr];\r\n }\r\n }\r\n};\r\n\r\nconst selectMonthRight = (month) => {\r\n // 如果是未来月份且禁用未来日期,则不允许选择\r\n if (isFutureMonth(month, rightYear.value)) return;\r\n\r\n const monthStr = `${rightYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [monthStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= monthStr ? [first, monthStr] : [monthStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [monthStr];\r\n }\r\n};\r\n\r\nconst isMonthSelectedRight = (month) => {\r\n if (!tempValue.value) return false;\r\n const monthStr = `${rightYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n if (Array.isArray(tempValue.value)) {\r\n return tempValue.value.includes(monthStr);\r\n }\r\n return false;\r\n};\r\n\r\nconst isMonthInRangeRight = (month) => {\r\n if (props.mode !== 'range' || !Array.isArray(tempValue.value) || tempValue.value.length !== 2) {\r\n return false;\r\n }\r\n const monthStr = `${rightYear.value}-${String(month + 1).padStart(2, '0')}`;\r\n return monthStr > tempValue.value[0] && monthStr < tempValue.value[1];\r\n};\r\n\r\nconst selectWeek = (week) => {\r\n const weekStr = `${currentYear.value}-W${String(week.weekNumber).padStart(2, '0')}`;\r\n if (props.mode === 'single') {\r\n tempValue.value = weekStr;\r\n confirm();\r\n } else {\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [weekStr];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= weekStr ? [first, weekStr] : [weekStr, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [weekStr];\r\n }\r\n }\r\n};\r\n\r\nconst selectDay = (day) => {\r\n // 如果是未来日期且禁用未来日期,则不允许选择\r\n if (isFutureDay(day)) return;\r\n\r\n if (props.mode === 'single') {\r\n tempValue.value = day.date;\r\n // 内联模式下单选直接确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n if (!tempValue.value || !Array.isArray(tempValue.value)) {\r\n tempValue.value = [day.date];\r\n } else if (tempValue.value.length === 1) {\r\n const [first] = tempValue.value;\r\n tempValue.value = first <= day.date ? [first, day.date] : [day.date, first];\r\n // 内联模式下范围选择完成后自动确认\r\n if (props.inline) {\r\n confirm();\r\n }\r\n } else {\r\n tempValue.value = [day.date];\r\n }\r\n }\r\n};\r\n\r\n// 导航操作\r\nconst prevPeriod = () => {\r\n if (viewMode.value === 'year') {\r\n currentYear.value -= 12;\r\n } else if (viewMode.value === 'month') {\r\n currentYear.value -= 1;\r\n } else {\r\n if (currentMonth.value === 0) {\r\n currentMonth.value = 11;\r\n currentYear.value -= 1;\r\n } else {\r\n currentMonth.value -= 1;\r\n }\r\n }\r\n};\r\n\r\nconst nextPeriod = () => {\r\n if (viewMode.value === 'year') {\r\n currentYear.value += 12;\r\n } else if (viewMode.value === 'month') {\r\n currentYear.value += 1;\r\n } else {\r\n if (currentMonth.value === 11) {\r\n currentMonth.value = 0;\r\n currentYear.value += 1;\r\n } else {\r\n currentMonth.value += 1;\r\n }\r\n }\r\n};\r\n\r\n// 月份导航(用于双日历)\r\nconst prevMonth = () => {\r\n // 只控制左侧日历\r\n if (currentMonth.value === 0) {\r\n currentMonth.value = 11;\r\n currentYear.value -= 1;\r\n } else {\r\n currentMonth.value -= 1;\r\n }\r\n};\r\n\r\nconst nextMonthLeft = () => {\r\n // 增加左侧日历月份\r\n if (currentMonth.value === 11) {\r\n currentMonth.value = 0;\r\n currentYear.value += 1;\r\n } else {\r\n currentMonth.value += 1;\r\n }\r\n};\r\n\r\nconst prevMonthRight = () => {\r\n // 减少右侧日历月份\r\n if (rightMonth.value === 0) {\r\n rightMonth.value = 11;\r\n rightYear.value -= 1;\r\n } else {\r\n rightMonth.value -= 1;\r\n }\r\n};\r\n\r\nconst nextMonth = () => {\r\n // 只控制右侧日历\r\n if (rightMonth.value === 11) {\r\n rightMonth.value = 0;\r\n rightYear.value += 1;\r\n } else {\r\n rightMonth.value += 1;\r\n }\r\n};\r\n\r\n// 年份导航(用于双月份面板)\r\nconst prevYear = () => {\r\n // 只控制左侧年份\r\n currentYear.value -= 1;\r\n};\r\n\r\nconst nextYearLeft = () => {\r\n // 增加左侧年份\r\n currentYear.value += 1;\r\n};\r\n\r\nconst prevYearRight = () => {\r\n // 减少右侧年份\r\n rightYear.value -= 1;\r\n};\r\n\r\nconst nextYear = () => {\r\n // 只控制右侧年份\r\n rightYear.value += 1;\r\n};\r\n\r\nconst changeViewMode = (mode) => {\r\n if (props.displayMode === 'year' && mode !== 'year') return;\r\n if (props.displayMode === 'month' && !['year', 'month'].includes(mode)) return;\r\n viewMode.value = mode;\r\n};\r\n\r\n// 面板操作\r\nconst initializePicker = () => {\r\n if (props.displayMode === 'year' && props.mode === 'single') {\r\n currentYear.value = todayYear;\r\n }\r\n\r\n tempValue.value = selectedValue.value ?\r\n (Array.isArray(selectedValue.value) ? [...selectedValue.value] : selectedValue.value) :\r\n (props.mode === 'range' ? [] : null);\r\n viewMode.value = props.displayMode;\r\n\r\n if (props.displayMode === 'month') {\r\n rightYear.value = currentYear.value + 1;\r\n } else {\r\n if (currentMonth.value === 11) {\r\n rightYear.value = currentYear.value + 1;\r\n rightMonth.value = 0;\r\n } else {\r\n rightYear.value = currentYear.value;\r\n rightMonth.value = currentMonth.value + 1;\r\n }\r\n }\r\n};\r\n\r\nwatch(showPicker, (isOpen) => {\r\n if (isOpen) {\r\n initializePicker();\r\n }\r\n});\r\nif (props.inline) {\r\n // 内联模式下直接初始化\r\n tempValue.value = selectedValue.value ?\r\n (Array.isArray(selectedValue.value) ? [...selectedValue.value] : selectedValue.value) :\r\n (props.mode === 'range' ? [] : null);\r\n viewMode.value = props.displayMode;\r\n\r\n // 初始化右侧日历/年份\r\n if (props.displayMode === 'month') {\r\n rightYear.value = currentYear.value + 1;\r\n } else {\r\n if (currentMonth.value === 11) {\r\n rightYear.value = currentYear.value + 1;\r\n rightMonth.value = 0;\r\n } else {\r\n rightYear.value = currentYear.value;\r\n rightMonth.value = currentMonth.value + 1;\r\n }\r\n }\r\n}\r\n\r\nconst closePicker = () => {\r\n showPicker.value = false;\r\n};\r\n\r\nconst clearValue = () => {\r\n selectedValue.value = props.mode === 'range' ? [] : null;\r\n emit('update:modelValue', selectedValue.value);\r\n emit('change', selectedValue.value);\r\n};\r\n\r\nconst confirm = () => {\r\n selectedValue.value = tempValue.value;\r\n emit('update:modelValue', selectedValue.value);\r\n emit('change', selectedValue.value);\r\n closePicker();\r\n};\r\n\r\n// 自定义取消和确认处理\r\nconst handleCancel = () => {\r\n if (props.onCancel) {\r\n props.onCancel();\r\n } else {\r\n emit('cancel');\r\n closePicker();\r\n }\r\n};\r\n\r\nconst handleConfirm = () => {\r\n if (props.onConfirm) {\r\n props.onConfirm(tempValue.value);\r\n } else {\r\n emit('confirm', tempValue.value);\r\n confirm();\r\n }\r\n};\r\n\r\n// 监听外部值变化\r\nwatch(() => props.modelValue, (newValue) => {\r\n selectedValue.value = newValue;\r\n}, { immediate: true });\r\n</script>\r\n\r\n<style scoped>\r\n.vtk-date-selector {\r\n position: relative;\r\n width: 100%;\r\n}\r\n\r\n.date-input {\r\n width: 100%;\r\n}\r\n\r\n.date-input-field {\r\n cursor: pointer;\r\n}\r\n\r\n:deep(.date-input-field .v-field),\r\n:deep(.date-input-field input) {\r\n cursor: pointer;\r\n}\r\n\r\n.date-icon {\r\n margin-left: 8px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.date-icon-svg {\r\n width: 16px;\r\n height: 16px;\r\n display: block;\r\n}\r\n\r\n.clear-icon {\r\n margin-left: 4px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-size: 18px;\r\n line-height: 1;\r\n cursor: pointer;\r\n padding: 2px;\r\n}\r\n\r\n.clear-icon:hover {\r\n color: rgb(var(--v-theme-on-surface), 0.87);\r\n}\r\n\r\n.date-picker-dropdown {\r\n background: rgb(var(--v-theme-surface));\r\n border-radius: 8px;\r\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\r\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n}\r\n\r\n.date-picker-dropdown.inline-mode {\r\n box-shadow: none;\r\n width: fit-content;\r\n border: none;\r\n}\r\n\r\n.picker-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 12px 16px;\r\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n}\r\n\r\n.header-title {\r\n font-size: 16px;\r\n font-weight: 500;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.clickable {\r\n cursor: pointer;\r\n padding: 4px 8px;\r\n border-radius: 4px;\r\n transition: background 0.2s;\r\n}\r\n\r\n.clickable:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.nav-btn {\r\n border: none;\r\n background: none;\r\n font-size: 20px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n cursor: pointer;\r\n padding: 4px 12px;\r\n border-radius: 4px;\r\n transition: background 0.2s;\r\n}\r\n\r\n.nav-btn:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.picker-body {\r\n padding: 8px;\r\n min-height: 200px;\r\n}\r\n\r\n.dual-calendar {\r\n display: flex;\r\n gap: 8px;\r\n}\r\n\r\n.calendar-divider {\r\n width: 1px;\r\n background: rgb(var(--v-theme-on-surface), 0.12);\r\n margin: 0 6px;\r\n}\r\n\r\n.calendar-panel {\r\n flex: 0 0 210px;\r\n width: 210px;\r\n min-width: 210px;\r\n max-width: 210px;\r\n}\r\n\r\n/* 单面板模式:放大以匹配底部范围显示的宽度 */\r\n.calendar-panel:only-child {\r\n flex: 0 0 340px;\r\n width: 340px;\r\n min-width: 340px;\r\n max-width: 340px;\r\n}\r\n\r\n.calendar-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 4px 0;\r\n margin-bottom: 4px;\r\n}\r\n\r\n.month-title {\r\n font-size: 12px;\r\n font-weight: 500;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.nav-btn-small {\r\n border: none;\r\n background: none;\r\n font-size: 14px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n cursor: pointer;\r\n padding: 2px 4px;\r\n border-radius: 4px;\r\n transition: background 0.2s;\r\n}\r\n\r\n.nav-btn-small:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.nav-btn-small.invisible {\r\n visibility: hidden;\r\n pointer-events: none;\r\n}\r\n\r\n.year-grid,\r\n.month-grid {\r\n display: grid;\r\n grid-template-columns: repeat(3, 1fr);\r\n gap: 6px;\r\n}\r\n\r\n.year-item,\r\n.month-item {\r\n padding: 6px;\r\n text-align: center;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n transition: all 0.2s;\r\n border: 1px solid transparent;\r\n color: rgb(var(--v-theme-on-surface));\r\n font-size: 12px;\r\n}\r\n\r\n.year-item:hover,\r\n.month-item:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.year-item.selected,\r\n.month-item.selected {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.year-item.in-range,\r\n.month-item.in-range {\r\n background: rgb(var(--v-theme-primary), 0.12);\r\n}\r\n\r\n/* 禁用状态样式 */\r\n.year-item.disabled,\r\n.month-item.disabled,\r\n.day-item.disabled {\r\n color: rgb(var(--v-theme-on-surface), 0.26) !important;\r\n background: rgb(var(--v-theme-on-surface), 0.04) !important;\r\n cursor: not-allowed !important;\r\n pointer-events: none;\r\n opacity: 0.5;\r\n}\r\n\r\n.year-item.disabled:hover,\r\n.month-item.disabled:hover,\r\n.day-item.disabled:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.04) !important;\r\n}\r\n\r\n.week-header {\r\n display: grid;\r\n grid-template-columns: repeat(7, 1fr);\r\n gap: 2px;\r\n margin-bottom: 6px;\r\n}\r\n\r\n.week-day {\r\n text-align: center;\r\n padding: 6px 0;\r\n font-size: 12px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-weight: 500;\r\n}\r\n\r\n.week-grid {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 4px;\r\n}\r\n\r\n.week-row {\r\n display: grid;\r\n grid-template-columns: 40px repeat(7, 1fr);\r\n gap: 4px;\r\n padding: 4px;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n transition: background 0.2s;\r\n}\r\n\r\n.week-row:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.week-row.selected {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.week-row.in-range {\r\n background: rgb(var(--v-theme-primary), 0.12);\r\n}\r\n\r\n.week-number {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n font-size: 12px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-weight: 500;\r\n}\r\n\r\n.day-grid {\r\n display: grid;\r\n grid-template-columns: repeat(7, 1fr);\r\n gap: 2px;\r\n}\r\n\r\n.day-item,\r\n.day-cell {\r\n aspect-ratio: 1;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n transition: all 0.2s;\r\n font-size: 13px;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.day-item:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.day-item.other-month,\r\n.day-cell.other-month {\r\n color: rgb(var(--v-theme-on-surface), 0.38);\r\n}\r\n\r\n.day-item.today,\r\n.day-cell.today {\r\n color: rgb(var(--v-theme-primary));\r\n font-weight: 600;\r\n}\r\n\r\n.day-item.selected {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.day-item.in-range {\r\n background: rgb(var(--v-theme-primary), 0.12);\r\n}\r\n\r\n.day-item.range-start,\r\n.day-item.range-end {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.range-display {\r\n padding: 12px 16px;\r\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n text-align: center;\r\n}\r\n\r\n.range-text {\r\n font-size: 14px;\r\n color: rgb(var(--v-theme-on-surface));\r\n}\r\n\r\n.range-separator {\r\n margin: 0 8px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n}\r\n\r\n.placeholder-text {\r\n color: rgb(var(--v-theme-on-surface), 0.38);\r\n}\r\n\r\n.picker-footer {\r\n display: flex;\r\n justify-content: flex-end;\r\n gap: 8px;\r\n padding: 12px 16px;\r\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\r\n}\r\n\r\n.btn {\r\n padding: 8px 16px;\r\n border-radius: 4px;\r\n font-size: 14px;\r\n cursor: pointer;\r\n transition: all 0.2s;\r\n border: none;\r\n outline: none;\r\n}\r\n\r\n.btn-text {\r\n background: none;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n}\r\n\r\n.btn-text:hover {\r\n background: rgb(var(--v-theme-on-surface), 0.08);\r\n}\r\n\r\n.btn-primary {\r\n background: rgb(var(--v-theme-primary));\r\n color: rgb(var(--v-theme-on-primary));\r\n}\r\n\r\n.btn-primary:hover {\r\n opacity: 0.9;\r\n}\r\n</style>\r\n","<template>\n <div class=\"vtk-date-time-picker\">\n <VMenu\n v-if=\"!inline\"\n v-model=\"showPicker\"\n :attach=\"menuAttach\"\n :location=\"menuLocation\"\n :origin=\"menuOrigin\"\n :width=\"menuWidth\"\n :min-width=\"menuWidth\"\n offset=\"4\"\n :close-on-content-click=\"false\"\n >\n <template #activator=\"{ props: menuProps }\">\n <div class=\"date-time-input\">\n <VTextField\n :model-value=\"displayValue\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n density=\"compact\"\n variant=\"outlined\"\n hide-details\n readonly\n v-bind=\"menuProps\"\n :clearable=\"clearable && !!displayValue && !disabled\"\n clear-icon=\"mdi-close-circle\"\n persistent-clear\n class=\"date-time-input-field\"\n @click:clear.stop=\"clearValue\"\n >\n <template #append-inner>\n <VIcon size=\"16\" class=\"date-time-icon\">mdi-clock-outline</VIcon>\n </template>\n </VTextField>\n </div>\n </template>\n\n <div class=\"date-time-picker-dropdown\" :class=\"{ 'range-mode': isRange }\" @click.stop @mousedown.stop>\n <template v-if=\"isRange\">\n <div class=\"range-input-row\">\n <input class=\"range-date-input\" :value=\"formatDatePart(tempRange[0])\" readonly placeholder=\"开始日期\" />\n <button\n class=\"range-time-input\"\n type=\"button\"\n :class=\"{ active: activeTimeSide === 'start' }\"\n @click=\"openRangeTime('start')\"\n >\n {{ formatTimePart(tempRange[0]) || defaultStartTime }}\n </button>\n <span class=\"range-arrow\">›</span>\n <input class=\"range-date-input\" :value=\"formatDatePart(tempRange[1])\" readonly placeholder=\"结束日期\" />\n <button\n class=\"range-time-input\"\n type=\"button\"\n :class=\"{ active: activeTimeSide === 'end' }\"\n @click=\"openRangeTime('end')\"\n >\n {{ formatTimePart(tempRange[1]) || defaultEndTime }}\n </button>\n\n <div v-if=\"activeTimeSide\" :class=\"['range-time-popover', activeTimeSide]\">\n <div class=\"time-columns compact\">\n <div class=\"time-column\">\n <button\n v-for=\"hour in hourOptions\"\n :key=\"hour\"\n type=\"button\"\n :class=\"['time-item', { selected: hour === activeRangeHour }]\"\n @click=\"selectRangeTime('hour', hour)\"\n >\n {{ padTime(hour) }}\n </button>\n </div>\n <div class=\"time-column\">\n <button\n v-for=\"minute in minuteOptions\"\n :key=\"minute\"\n type=\"button\"\n :class=\"['time-item', { selected: minute === activeRangeMinute }]\"\n @click=\"selectRangeTime('minute', minute)\"\n >\n {{ padTime(minute) }}\n </button>\n </div>\n <div v-if=\"showSeconds\" class=\"time-column\">\n <button\n v-for=\"second in secondOptions\"\n :key=\"second\"\n type=\"button\"\n :class=\"['time-item', { selected: second === activeRangeSecond }]\"\n @click=\"selectRangeTime('second', second)\"\n >\n {{ padTime(second) }}\n </button>\n </div>\n </div>\n <div class=\"time-popover-footer\">\n <button class=\"btn btn-text small\" type=\"button\" @click=\"activeTimeSide = null\">取消</button>\n <button class=\"btn btn-primary small\" type=\"button\" @click=\"activeTimeSide = null\">确定</button>\n </div>\n </div>\n </div>\n\n <div class=\"range-calendar-shell\">\n <div class=\"calendar-panel\">\n <div class=\"calendar-header\">\n <button class=\"nav-btn-small\" type=\"button\" @click=\"prevLeftMonth\">‹</button>\n <span class=\"month-title\">{{ leftYear }} 年 {{ leftMonth + 1 }} 月</span>\n <button class=\"nav-btn-small invisible\" type=\"button\">›</button>\n </div>\n <div class=\"week-header\">\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\n </div>\n <div class=\"day-grid\">\n <button\n v-for=\"day in leftDayList\"\n :key=\"day.date\"\n type=\"button\"\n :class=\"rangeDayClass(day)\"\n @click=\"selectRangeDay(day)\"\n >\n {{ day.day }}\n </button>\n </div>\n </div>\n\n <div class=\"calendar-divider\"></div>\n\n <div class=\"calendar-panel\">\n <div class=\"calendar-header\">\n <button class=\"nav-btn-small invisible\" type=\"button\">‹</button>\n <span class=\"month-title\">{{ rightYear }} 年 {{ rightMonth + 1 }} 月</span>\n <button class=\"nav-btn-small\" type=\"button\" @click=\"nextRightMonth\">›</button>\n </div>\n <div class=\"week-header\">\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\n </div>\n <div class=\"day-grid\">\n <button\n v-for=\"day in rightDayList\"\n :key=\"day.date\"\n type=\"button\"\n :class=\"rangeDayClass(day)\"\n @click=\"selectRangeDay(day)\"\n >\n {{ day.day }}\n </button>\n </div>\n </div>\n </div>\n </template>\n\n <template v-else>\n <div class=\"single-input-row\">\n <input class=\"single-date-input\" :value=\"formatDatePart(tempDate)\" readonly placeholder=\"请选择日期\" />\n <button\n class=\"single-time-input\"\n type=\"button\"\n :class=\"{ active: activeSingleTime }\"\n @click=\"activeSingleTime = true\"\n >\n {{ singleTimeValue }}\n </button>\n\n <div v-if=\"activeSingleTime\" class=\"single-time-popover\">\n <div class=\"time-columns compact\">\n <div class=\"time-column\">\n <button\n v-for=\"hour in hourOptions\"\n :key=\"hour\"\n type=\"button\"\n :class=\"['time-item', { selected: hour === selectedHour, disabled: isTimePartDisabled(hour, selectedMinute, selectedSecond) }]\"\n @click=\"selectHour(hour)\"\n >\n {{ padTime(hour) }}\n </button>\n </div>\n <div class=\"time-column\">\n <button\n v-for=\"minute in minuteOptions\"\n :key=\"minute\"\n type=\"button\"\n :class=\"['time-item', { selected: minute === selectedMinute, disabled: isTimePartDisabled(selectedHour, minute, selectedSecond) }]\"\n @click=\"selectMinute(minute)\"\n >\n {{ padTime(minute) }}\n </button>\n </div>\n <div v-if=\"showSeconds\" class=\"time-column\">\n <button\n v-for=\"second in secondOptions\"\n :key=\"second\"\n type=\"button\"\n :class=\"['time-item', { selected: second === selectedSecond, disabled: isTimePartDisabled(selectedHour, selectedMinute, second) }]\"\n @click=\"selectSecond(second)\"\n >\n {{ padTime(second) }}\n </button>\n </div>\n </div>\n <div class=\"time-popover-footer\">\n <button class=\"btn btn-text small\" type=\"button\" @click=\"activeSingleTime = false\">取消</button>\n <button class=\"btn btn-primary small\" type=\"button\" @click=\"activeSingleTime = false\">确定</button>\n </div>\n </div>\n </div>\n\n <div class=\"single-calendar-panel\">\n <div class=\"picker-header single-header\">\n <button class=\"nav-btn\" type=\"button\" @click=\"prevPeriod\">‹</button>\n <div class=\"header-title\">\n <span class=\"clickable\" @click=\"changeViewMode('year')\">{{ currentYear }} 年</span>\n <span v-if=\"viewMode !== 'year'\" class=\"clickable\" @click=\"changeViewMode('month')\">\n {{ currentMonth + 1 }} 月\n </span>\n </div>\n <button class=\"nav-btn\" type=\"button\" @click=\"nextPeriod\">›</button>\n </div>\n\n <div v-if=\"viewMode === 'year'\" class=\"picker-body\">\n <div class=\"year-grid\">\n <button\n v-for=\"year in yearList\"\n :key=\"year\"\n type=\"button\"\n :class=\"['year-item', { selected: year === currentYear, disabled: isYearDisabled(year) }]\"\n @click=\"selectYear(year)\"\n >\n {{ year }}\n </button>\n </div>\n </div>\n\n <div v-else-if=\"viewMode === 'month'\" class=\"picker-body\">\n <div class=\"month-grid\">\n <button\n v-for=\"(month, index) in monthList\"\n :key=\"month\"\n type=\"button\"\n :class=\"['month-item', { selected: index === currentMonth, disabled: isMonthDisabled(index) }]\"\n @click=\"selectMonth(index)\"\n >\n {{ month }}\n </button>\n </div>\n </div>\n\n <div v-else class=\"picker-body\">\n <div class=\"week-header\">\n <div v-for=\"day in weekDays\" :key=\"day\" class=\"week-day\">{{ day }}</div>\n </div>\n <div class=\"day-grid\">\n <button\n v-for=\"day in dayList\"\n :key=\"day.date\"\n type=\"button\"\n :class=\"['day-item', {\n 'other-month': day.otherMonth,\n selected: isDaySelected(day),\n today: day.isToday,\n disabled: isDayDisabled(day)\n }]\"\n @click=\"selectDay(day)\"\n >\n {{ day.day }}\n </button>\n </div>\n </div>\n </div>\n </template>\n\n <div class=\"picker-footer\">\n <button v-if=\"!isRange\" class=\"btn btn-text\" type=\"button\" @click=\"handleNow\">此刻</button>\n <button v-if=\"isRange\" class=\"btn btn-text\" type=\"button\" @click=\"clearTempRange\">清空</button>\n <span class=\"footer-spacer\"></span>\n <button class=\"btn btn-text\" type=\"button\" @click=\"handleCancel\">取消</button>\n <button class=\"btn btn-primary\" type=\"button\" :disabled=\"!canConfirm\" @click=\"handleConfirm\">确定</button>\n </div>\n </div>\n </VMenu>\n\n <div v-if=\"inline\" class=\"date-time-picker-dropdown inline-mode\" :class=\"{ 'range-mode': isRange }\" @click.stop @mousedown.stop>\n <div class=\"inline-message\">内联模式请使用默认单选面板。</div>\n </div>\n </div>\n</template>\n\n<script setup>\nimport { computed, ref, watch } from 'vue';\n\ndefineOptions({\n name: 'VtkDateTimePicker',\n});\n\nconst props = defineProps({\n modelValue: {\n type: [String, Date, Number, Array],\n default: null\n },\n mode: {\n type: String,\n default: 'single',\n validator: (value) => ['single', 'range'].includes(value)\n },\n placeholder: {\n type: String,\n default: '请选择日期时间'\n },\n disabled: {\n type: Boolean,\n default: false\n },\n clearable: {\n type: Boolean,\n default: true\n },\n format: {\n type: String,\n default: 'YYYY-MM-DD HH:mm:ss'\n },\n valueFormat: {\n type: String,\n default: 'YYYY-MM-DD HH:mm:ss'\n },\n separator: {\n type: String,\n default: ' 至 '\n },\n min: {\n type: [String, Date, Number],\n default: null\n },\n max: {\n type: [String, Date, Number],\n default: null\n },\n disableFuture: {\n type: Boolean,\n default: false\n },\n minuteStep: {\n type: Number,\n default: 1\n },\n secondStep: {\n type: Number,\n default: 1\n },\n showSeconds: {\n type: Boolean,\n default: true\n },\n inline: {\n type: Boolean,\n default: false\n },\n placement: {\n type: String,\n default: 'left',\n validator: (value) => ['left', 'right'].includes(value)\n },\n noTeleport: {\n type: Boolean,\n default: false\n },\n onCancel: {\n type: Function,\n default: null\n },\n onConfirm: {\n type: Function,\n default: null\n }\n});\n\nconst emit = defineEmits(['update:modelValue', 'change', 'cancel', 'confirm']);\n\nconst showPicker = ref(false);\nconst selectedDateTime = ref(null);\nconst selectedRange = ref([]);\nconst tempDate = ref(null);\nconst tempRange = ref([null, null]);\nconst currentYear = ref(new Date().getFullYear());\nconst currentMonth = ref(new Date().getMonth());\nconst leftYear = ref(new Date().getFullYear());\nconst leftMonth = ref(new Date().getMonth());\nconst rightYear = ref(new Date().getMonth() === 11 ? new Date().getFullYear() + 1 : new Date().getFullYear());\nconst rightMonth = ref(new Date().getMonth() === 11 ? 0 : new Date().getMonth() + 1);\nconst viewMode = ref('day');\nconst selectedHour = ref(0);\nconst selectedMinute = ref(0);\nconst selectedSecond = ref(0);\nconst activeRangeSide = ref('start');\nconst activeTimeSide = ref(null);\nconst activeSingleTime = ref(false);\n\nconst weekDays = ['日', '一', '二', '三', '四', '五', '六'];\nconst monthList = ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'];\nconst defaultStartTime = '00:00:00';\nconst defaultEndTime = '23:59:59';\n\nconst isRange = computed(() => props.mode === 'range');\nconst menuAttach = computed(() => (props.noTeleport ? true : false));\nconst menuLocation = computed(() => props.placement === 'right' ? 'bottom end' : 'bottom start');\nconst menuOrigin = computed(() => props.placement === 'right' ? 'top end' : 'top start');\nconst menuWidth = computed(() => isRange.value ? 646 : 360);\nconst minDateTime = computed(() => parseValue(props.min));\nconst maxDateTime = computed(() => parseValue(props.max));\nconst hourOptions = computed(() => Array.from({ length: 24 }, (_, index) => index));\nconst minuteOptions = computed(() => buildStepOptions(props.minuteStep));\nconst secondOptions = computed(() => buildStepOptions(props.secondStep));\n\nconst yearList = computed(() => {\n const startYear = Math.floor(currentYear.value / 12) * 12;\n return Array.from({ length: 12 }, (_, index) => startYear + index);\n});\n\nconst dayList = computed(() => getDayList(currentYear.value, currentMonth.value));\nconst leftDayList = computed(() => getDayList(leftYear.value, leftMonth.value));\nconst rightDayList = computed(() => getDayList(rightYear.value, rightMonth.value));\n\nconst displayValue = computed(() => {\n if (isRange.value) {\n if (!selectedRange.value.length) return '';\n const [start, end] = selectedRange.value;\n return [start, end].filter(Boolean).map(date => formatByPattern(date, props.format)).join(props.separator);\n }\n return selectedDateTime.value ? formatByPattern(selectedDateTime.value, props.format) : '';\n});\n\nconst previewValue = computed(() => tempDate.value ? formatByPattern(buildTempDateTime(), props.format) : '');\nconst singleTimeValue = computed(() => {\n const pattern = props.showSeconds ? 'HH:mm:ss' : 'HH:mm';\n const date = buildTempDateTime() || new Date(2000, 0, 1, selectedHour.value, selectedMinute.value, selectedSecond.value);\n return formatByPattern(date, pattern);\n});\n\nconst canConfirm = computed(() => {\n if (isRange.value) {\n const [start, end] = tempRange.value;\n return !!start && !!end && start <= end && !isDateTimeDisabled(start) && !isDateTimeDisabled(end);\n }\n if (!tempDate.value) return false;\n return !isDateTimeDisabled(buildTempDateTime());\n});\n\nconst activeRangeDate = computed(() => {\n return activeTimeSide.value === 'end' ? tempRange.value[1] : tempRange.value[0];\n});\n\nconst activeRangeHour = computed(() => activeRangeDate.value ? activeRangeDate.value.getHours() : 0);\nconst activeRangeMinute = computed(() => activeRangeDate.value ? activeRangeDate.value.getMinutes() : 0);\nconst activeRangeSecond = computed(() => activeRangeDate.value ? activeRangeDate.value.getSeconds() : 0);\n\nconst buildStepOptions = (step) => {\n const normalizedStep = Number.isFinite(step) && step > 0 ? Math.max(1, Math.floor(step)) : 1;\n const options = [];\n for (let value = 0; value < 60; value += normalizedStep) {\n options.push(value);\n }\n return options;\n};\n\nconst getDayList = (year, month) => {\n const firstDay = new Date(year, month, 1);\n const startDay = firstDay.getDay();\n const daysInMonth = new Date(year, month + 1, 0).getDate();\n const daysInPrevMonth = new Date(year, month, 0).getDate();\n const today = new Date();\n const days = [];\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push(createDay(new Date(year, month - 1, daysInPrevMonth - index), true, today));\n }\n for (let day = 1; day <= daysInMonth; day += 1) {\n days.push(createDay(new Date(year, month, day), false, today));\n }\n for (let day = 1; days.length < 42; day += 1) {\n days.push(createDay(new Date(year, month + 1, day), true, today));\n }\n\n return days;\n};\n\nconst createDay = (date, otherMonth, today) => ({\n date: formatByPattern(date, 'YYYY-MM-DD'),\n day: date.getDate(),\n year: date.getFullYear(),\n month: date.getMonth(),\n otherMonth,\n isToday: isSameDate(date, today)\n});\n\nconst padTime = (value) => String(value).padStart(2, '0');\n\nconst formatByPattern = (date, pattern) => {\n if (!(date instanceof Date) || Number.isNaN(date.getTime())) return '';\n const replacements = {\n YYYY: date.getFullYear(),\n MM: padTime(date.getMonth() + 1),\n DD: padTime(date.getDate()),\n HH: padTime(date.getHours()),\n mm: padTime(date.getMinutes()),\n ss: padTime(date.getSeconds())\n };\n return Object.keys(replacements).reduce((result, token) => {\n return result.replace(new RegExp(token, 'g'), replacements[token]);\n }, pattern);\n};\n\nconst formatDatePart = (date) => date ? formatByPattern(date, 'YYYY-MM-DD') : '';\nconst formatTimePart = (date) => date ? formatByPattern(date, props.showSeconds ? 'HH:mm:ss' : 'HH:mm') : '';\n\nconst parseValue = (value) => {\n if (!value && value !== 0) return null;\n if (value instanceof Date) return Number.isNaN(value.getTime()) ? null : new Date(value.getTime());\n if (typeof value === 'number') {\n const date = new Date(value);\n return Number.isNaN(date.getTime()) ? null : date;\n }\n if (typeof value !== 'string') return null;\n\n const normalized = value.trim().replace(/\\//g, '-');\n const match = normalized.match(/^(\\d{4})-(\\d{1,2})-(\\d{1,2})(?:[ T](\\d{1,2}):(\\d{1,2})(?::(\\d{1,2}))?)?/);\n if (!match) {\n const fallback = new Date(value);\n return Number.isNaN(fallback.getTime()) ? null : fallback;\n }\n\n const [, year, month, day, hour = '0', minute = '0', second = '0'] = match;\n const date = new Date(Number(year), Number(month) - 1, Number(day), Number(hour), Number(minute), Number(second));\n return Number.isNaN(date.getTime()) ? null : date;\n};\n\nconst parseRangeValue = (value) => {\n if (Array.isArray(value)) return value.map(parseValue).filter(Boolean).slice(0, 2);\n if (typeof value === 'string' && value.includes(props.separator)) {\n return value.split(props.separator).map(item => parseValue(item.trim())).filter(Boolean).slice(0, 2);\n }\n return [];\n};\n\nconst toModelValue = (date) => {\n if (!date) return null;\n if (props.valueFormat === 'timestamp') return date.getTime();\n if (props.valueFormat === 'Date') return new Date(date.getTime());\n return formatByPattern(date, props.valueFormat);\n};\n\nconst toModelRange = (range) => range.map(date => toModelValue(date));\n\nconst isSameDate = (left, right) => {\n return left.getFullYear() === right.getFullYear()\n && left.getMonth() === right.getMonth()\n && left.getDate() === right.getDate();\n};\n\nconst buildTempDateTime = (hour = selectedHour.value, minute = selectedMinute.value, second = selectedSecond.value) => {\n if (!tempDate.value) return null;\n return new Date(tempDate.value.getFullYear(), tempDate.value.getMonth(), tempDate.value.getDate(), hour, minute, props.showSeconds ? second : 0);\n};\n\nconst isDateTimeDisabled = (date) => {\n if (!date) return true;\n if (minDateTime.value && date < minDateTime.value) return true;\n if (maxDateTime.value && date > maxDateTime.value) return true;\n if (props.disableFuture && date > new Date()) return true;\n return false;\n};\n\nconst isYearDisabled = (year) => {\n const start = new Date(year, 0, 1, 0, 0, 0);\n const end = new Date(year, 11, 31, 23, 59, 59);\n if (minDateTime.value && end < minDateTime.value) return true;\n if (maxDateTime.value && start > maxDateTime.value) return true;\n if (props.disableFuture && start > new Date()) return true;\n return false;\n};\n\nconst isMonthDisabled = (month) => {\n const start = new Date(currentYear.value, month, 1, 0, 0, 0);\n const end = new Date(currentYear.value, month + 1, 0, 23, 59, 59);\n if (minDateTime.value && end < minDateTime.value) return true;\n if (maxDateTime.value && start > maxDateTime.value) return true;\n if (props.disableFuture && start > new Date()) return true;\n return false;\n};\n\nconst isDayDisabled = (day) => {\n const start = new Date(day.year, day.month, day.day, 0, 0, 0);\n const end = new Date(day.year, day.month, day.day, 23, 59, 59);\n if (minDateTime.value && end < minDateTime.value) return true;\n if (maxDateTime.value && start > maxDateTime.value) return true;\n if (props.disableFuture && start > new Date()) return true;\n return false;\n};\n\nconst isTimePartDisabled = (hour, minute, second) => {\n if (!tempDate.value) return false;\n return isDateTimeDisabled(buildTempDateTime(hour, minute, second));\n};\n\nconst isDaySelected = (day) => {\n if (!tempDate.value) return false;\n return tempDate.value.getFullYear() === day.year\n && tempDate.value.getMonth() === day.month\n && tempDate.value.getDate() === day.day;\n};\n\nconst isRangeDaySelected = (day, side) => {\n const date = tempRange.value[side === 'start' ? 0 : 1];\n return !!date && date.getFullYear() === day.year && date.getMonth() === day.month && date.getDate() === day.day;\n};\n\nconst isRangeDayInRange = (day) => {\n const [start, end] = tempRange.value;\n if (!start || !end) return false;\n const date = new Date(day.year, day.month, day.day, 12, 0, 0);\n return date > start && date < end;\n};\n\nconst rangeDayClass = (day) => ['day-item', {\n 'other-month': day.otherMonth,\n today: day.isToday,\n disabled: isDayDisabled(day),\n selected: isRangeDaySelected(day, 'start') || isRangeDaySelected(day, 'end'),\n 'range-start': isRangeDaySelected(day, 'start'),\n 'range-end': isRangeDaySelected(day, 'end'),\n 'in-range': isRangeDayInRange(day)\n}];\n\nconst setSinglePanelFromDate = (date) => {\n if (!date) return;\n currentYear.value = date.getFullYear();\n currentMonth.value = date.getMonth();\n tempDate.value = new Date(date.getFullYear(), date.getMonth(), date.getDate());\n selectedHour.value = date.getHours();\n selectedMinute.value = date.getMinutes();\n selectedSecond.value = date.getSeconds();\n};\n\nconst setRangePanelsFromDate = (date) => {\n const base = date || new Date();\n leftYear.value = base.getFullYear();\n leftMonth.value = base.getMonth();\n const right = new Date(base.getFullYear(), base.getMonth() + 1, 1);\n rightYear.value = right.getFullYear();\n rightMonth.value = right.getMonth();\n};\n\nconst initializePicker = () => {\n if (isRange.value) {\n tempRange.value = selectedRange.value.length ? selectedRange.value.map(date => new Date(date.getTime())) : [null, null];\n setRangePanelsFromDate(tempRange.value[0] || new Date());\n activeRangeSide.value = tempRange.value[0] && !tempRange.value[1] ? 'end' : 'start';\n activeTimeSide.value = null;\n return;\n }\n setSinglePanelFromDate(selectedDateTime.value || new Date());\n viewMode.value = 'day';\n activeSingleTime.value = false;\n};\n\nconst prevPeriod = () => {\n if (viewMode.value === 'year') currentYear.value -= 12;\n else if (viewMode.value === 'month') currentYear.value -= 1;\n else if (currentMonth.value === 0) {\n currentMonth.value = 11;\n currentYear.value -= 1;\n } else currentMonth.value -= 1;\n};\n\nconst nextPeriod = () => {\n if (viewMode.value === 'year') currentYear.value += 12;\n else if (viewMode.value === 'month') currentYear.value += 1;\n else if (currentMonth.value === 11) {\n currentMonth.value = 0;\n currentYear.value += 1;\n } else currentMonth.value += 1;\n};\n\nconst prevLeftMonth = () => {\n const left = new Date(leftYear.value, leftMonth.value - 1, 1);\n leftYear.value = left.getFullYear();\n leftMonth.value = left.getMonth();\n const right = new Date(leftYear.value, leftMonth.value + 1, 1);\n rightYear.value = right.getFullYear();\n rightMonth.value = right.getMonth();\n};\n\nconst nextRightMonth = () => {\n const right = new Date(rightYear.value, rightMonth.value + 1, 1);\n rightYear.value = right.getFullYear();\n rightMonth.value = right.getMonth();\n const left = new Date(rightYear.value, rightMonth.value - 1, 1);\n leftYear.value = left.getFullYear();\n leftMonth.value = left.getMonth();\n};\n\nconst changeViewMode = (mode) => {\n viewMode.value = mode;\n};\n\nconst selectYear = (year) => {\n if (isYearDisabled(year)) return;\n currentYear.value = year;\n viewMode.value = 'month';\n};\n\nconst selectMonth = (month) => {\n if (isMonthDisabled(month)) return;\n currentMonth.value = month;\n viewMode.value = 'day';\n};\n\nconst selectDay = (day) => {\n if (isDayDisabled(day)) return;\n tempDate.value = new Date(day.year, day.month, day.day);\n};\n\nconst selectRangeDay = (day) => {\n if (isDayDisabled(day)) return;\n const selected = new Date(day.year, day.month, day.day);\n if (activeRangeSide.value === 'start' || !tempRange.value[0] || (tempRange.value[0] && tempRange.value[1])) {\n const currentStart = tempRange.value[0];\n selected.setHours(currentStart?.getHours() ?? 0, currentStart?.getMinutes() ?? 0, props.showSeconds ? currentStart?.getSeconds() ?? 0 : 0, 0);\n tempRange.value = [selected, null];\n activeRangeSide.value = 'end';\n } else {\n const currentEnd = tempRange.value[1];\n selected.setHours(currentEnd?.getHours() ?? 23, currentEnd?.getMinutes() ?? 59, props.showSeconds ? currentEnd?.getSeconds() ?? 59 : 0, 0);\n const start = tempRange.value[0];\n tempRange.value = start <= selected ? [start, selected] : [selected, start];\n activeRangeSide.value = 'start';\n }\n};\n\nconst selectHour = (hour) => {\n if (isTimePartDisabled(hour, selectedMinute.value, selectedSecond.value)) return;\n selectedHour.value = hour;\n};\n\nconst selectMinute = (minute) => {\n if (isTimePartDisabled(selectedHour.value, minute, selectedSecond.value)) return;\n selectedMinute.value = minute;\n};\n\nconst selectSecond = (second) => {\n if (isTimePartDisabled(selectedHour.value, selectedMinute.value, second)) return;\n selectedSecond.value = second;\n};\n\nconst openRangeTime = (side) => {\n activeTimeSide.value = side;\n activeRangeSide.value = side;\n const index = side === 'start' ? 0 : 1;\n if (!tempRange.value[index]) {\n const base = new Date();\n base.setHours(side === 'start' ? 0 : 23, side === 'start' ? 0 : 59, props.showSeconds ? side === 'start' ? 0 : 59 : 0, 0);\n tempRange.value[index] = base;\n }\n};\n\nconst selectRangeTime = (part, value) => {\n const index = activeTimeSide.value === 'end' ? 1 : 0;\n const fallback = new Date();\n const date = tempRange.value[index] ? new Date(tempRange.value[index].getTime()) : fallback;\n if (part === 'hour') date.setHours(value);\n if (part === 'minute') date.setMinutes(value);\n if (part === 'second') date.setSeconds(value);\n if (!props.showSeconds) date.setSeconds(0);\n date.setMilliseconds(0);\n tempRange.value[index] = date;\n};\n\nconst closePicker = () => {\n showPicker.value = false;\n activeSingleTime.value = false;\n};\n\nconst clearTempRange = () => {\n tempRange.value = [null, null];\n activeRangeSide.value = 'start';\n activeTimeSide.value = null;\n};\n\nconst clearValue = () => {\n if (isRange.value) {\n selectedRange.value = [];\n tempRange.value = [null, null];\n emit('update:modelValue', []);\n emit('change', []);\n } else {\n selectedDateTime.value = null;\n tempDate.value = null;\n emit('update:modelValue', null);\n emit('change', null);\n }\n};\n\nconst confirm = () => {\n if (!canConfirm.value) return;\n if (isRange.value) {\n selectedRange.value = tempRange.value.map(date => new Date(date.getTime()));\n const modelValue = toModelRange(selectedRange.value);\n emit('update:modelValue', modelValue);\n emit('change', modelValue);\n closePicker();\n return;\n }\n const nextValue = buildTempDateTime();\n selectedDateTime.value = nextValue;\n const modelValue = toModelValue(nextValue);\n emit('update:modelValue', modelValue);\n emit('change', modelValue);\n closePicker();\n};\n\nconst handleCancel = () => {\n if (props.onCancel) {\n props.onCancel();\n } else {\n emit('cancel');\n closePicker();\n }\n};\n\nconst handleConfirm = () => {\n const value = isRange.value ? toModelRange(tempRange.value) : toModelValue(buildTempDateTime());\n if (props.onConfirm) {\n props.onConfirm(value);\n } else {\n emit('confirm', value);\n confirm();\n }\n};\n\nconst handleNow = () => {\n const now = new Date();\n if (isDateTimeDisabled(now)) return;\n setSinglePanelFromDate(now);\n};\n\nwatch(showPicker, (isOpen) => {\n if (isOpen) initializePicker();\n});\n\nwatch(() => props.modelValue, (newValue) => {\n if (isRange.value) {\n selectedRange.value = parseRangeValue(newValue);\n } else {\n selectedDateTime.value = parseValue(newValue);\n }\n}, { immediate: true });\n</script>\n\n<style scoped>\n.vtk-date-time-picker {\n position: relative;\n width: 100%;\n}\n\n.date-time-input {\n width: 100%;\n}\n\n.date-time-input-field {\n cursor: pointer;\n}\n\n:deep(.date-time-input-field .v-field),\n:deep(.date-time-input-field input) {\n cursor: pointer;\n}\n\n.date-time-icon {\n margin-left: 8px;\n color: rgb(var(--v-theme-on-surface), 0.6);\n}\n\n.date-time-picker-dropdown {\n background: rgb(var(--v-theme-surface));\n border-radius: 4px;\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n overflow: visible;\n}\n\n.date-time-picker-dropdown.range-mode {\n width: 646px;\n min-width: 646px;\n max-width: 646px;\n}\n\n.date-time-picker-dropdown:not(.range-mode) {\n width: 360px;\n min-width: 360px;\n max-width: none;\n}\n\n.date-time-picker-dropdown.inline-mode {\n box-shadow: none;\n width: fit-content;\n border: none;\n}\n\n.picker-shell,\n.range-calendar-shell {\n display: flex;\n align-items: stretch;\n flex-wrap: nowrap;\n}\n\n.date-panel {\n width: 288px;\n border-right: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.calendar-panel {\n flex: 0 0 322px;\n width: 322px;\n min-width: 322px;\n max-width: 322px;\n padding: 12px 16px 16px;\n box-sizing: border-box;\n}\n\n.calendar-divider {\n flex: 0 0 1px;\n width: 1px;\n background: rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.picker-header,\n.calendar-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n\n.picker-header {\n padding: 12px 16px;\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.picker-header.single-header {\n border-bottom: none;\n padding: 14px 16px 8px;\n}\n\n.calendar-header {\n height: 36px;\n margin-bottom: 8px;\n}\n\n.header-title,\n.month-title {\n font-size: 16px;\n font-weight: 500;\n color: rgb(var(--v-theme-on-surface));\n}\n\n.clickable {\n cursor: pointer;\n padding: 4px 8px;\n border-radius: 4px;\n transition: background 0.2s;\n}\n\n.clickable:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.nav-btn,\n.nav-btn-small {\n border: none;\n background: none;\n color: rgb(var(--v-theme-on-surface), 0.6);\n cursor: pointer;\n border-radius: 4px;\n transition: background 0.2s;\n}\n\n.nav-btn {\n font-size: 20px;\n padding: 4px 12px;\n}\n\n.nav-btn-small {\n font-size: 18px;\n padding: 4px 8px;\n}\n\n.nav-btn:hover,\n.nav-btn-small:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.nav-btn-small.invisible {\n visibility: hidden;\n}\n\n.picker-body {\n padding: 10px 16px 16px;\n min-height: 250px;\n}\n\n.year-grid,\n.month-grid {\n display: grid;\n grid-template-columns: repeat(3, 1fr);\n gap: 8px;\n}\n\n.year-item,\n.month-item {\n height: 42px;\n border: 1px solid transparent;\n background: transparent;\n text-align: center;\n border-radius: 4px;\n cursor: pointer;\n transition: all 0.2s;\n color: rgb(var(--v-theme-on-surface));\n font-size: 13px;\n}\n\n.year-item:hover,\n.month-item:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.year-item.selected,\n.month-item.selected {\n background: rgb(var(--v-theme-primary));\n color: rgb(var(--v-theme-on-primary));\n}\n\n.week-header {\n display: grid;\n grid-template-columns: repeat(7, 1fr);\n gap: 2px;\n margin-bottom: 6px;\n}\n\n.week-day {\n text-align: center;\n padding: 6px 0;\n font-size: 12px;\n color: rgb(var(--v-theme-on-surface), 0.6);\n font-weight: 500;\n}\n\n.day-grid {\n display: grid;\n grid-template-columns: repeat(7, 1fr);\n gap: 2px;\n}\n\n.day-item {\n aspect-ratio: 1;\n border: 1px solid transparent;\n background: transparent;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 4px;\n cursor: pointer;\n transition: all 0.2s;\n font-size: 13px;\n color: rgb(var(--v-theme-on-surface));\n}\n\n.day-item:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.day-item.other-month {\n color: rgb(var(--v-theme-on-surface), 0.38);\n}\n\n.day-item.today {\n color: rgb(var(--v-theme-primary));\n font-weight: 600;\n}\n\n.day-item.selected,\n.day-item.range-start,\n.day-item.range-end {\n background: rgb(var(--v-theme-primary));\n color: rgb(var(--v-theme-on-primary));\n}\n\n.day-item.in-range {\n background: rgb(var(--v-theme-primary), 0.1);\n}\n\n.year-item.disabled,\n.month-item.disabled,\n.day-item.disabled,\n.time-item.disabled {\n color: rgb(var(--v-theme-on-surface), 0.26) !important;\n background: rgb(var(--v-theme-on-surface), 0.04) !important;\n cursor: not-allowed !important;\n pointer-events: none;\n opacity: 0.5;\n}\n\n.time-panel {\n width: 156px;\n}\n\n.time-header {\n height: 49px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 14px;\n font-weight: 500;\n color: rgb(var(--v-theme-on-surface));\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.time-columns {\n display: flex;\n height: 250px;\n}\n\n.time-columns.compact {\n height: 192px;\n}\n\n.time-column {\n flex: 1;\n overflow-y: auto;\n padding: 6px 0;\n border-right: 1px solid rgb(var(--v-theme-on-surface), 0.08);\n scrollbar-width: none;\n -ms-overflow-style: none;\n}\n\n.time-column::-webkit-scrollbar {\n width: 0;\n height: 0;\n}\n\n.time-column:last-child {\n border-right: none;\n}\n\n.time-item {\n width: 100%;\n height: 28px;\n border: none;\n background: transparent;\n color: rgb(var(--v-theme-on-surface));\n cursor: pointer;\n font-size: 13px;\n transition: all 0.2s;\n}\n\n.time-item:hover {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.time-item.selected {\n color: rgb(var(--v-theme-primary));\n font-weight: 600;\n background: rgb(var(--v-theme-primary), 0.1);\n}\n\n.range-input-row {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n flex-wrap: nowrap;\n gap: 8px;\n padding: 8px 12px;\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n box-sizing: border-box;\n}\n\n.single-input-row {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 8px;\n padding: 9px 12px;\n border-bottom: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n box-sizing: border-box;\n}\n\n.single-date-input,\n.single-time-input {\n flex: 0 0 auto;\n width: 150px;\n height: 32px;\n border: 1px solid rgb(var(--v-theme-on-surface), 0.16);\n border-radius: 4px;\n background: rgb(var(--v-theme-surface));\n color: rgb(var(--v-theme-on-surface));\n font-size: 13px;\n padding: 0 12px;\n outline: none;\n}\n\n.single-time-input {\n text-align: left;\n cursor: pointer;\n}\n\n.single-time-input.active,\n.single-time-input:focus,\n.single-date-input:focus {\n border-color: rgb(var(--v-theme-primary));\n}\n\n.single-calendar-panel {\n width: 360px;\n}\n\n.range-date-input,\n.range-time-input {\n flex: 0 0 auto;\n height: 32px;\n border: 1px solid rgb(var(--v-theme-on-surface), 0.16);\n border-radius: 4px;\n background: rgb(var(--v-theme-surface));\n color: rgb(var(--v-theme-on-surface));\n font-size: 13px;\n padding: 0 12px;\n outline: none;\n}\n\n.range-date-input {\n width: 144px;\n}\n\n.range-time-input {\n width: 132px;\n text-align: left;\n cursor: pointer;\n}\n\n.range-time-input.active,\n.range-time-input:focus,\n.range-date-input:focus {\n border-color: rgb(var(--v-theme-primary));\n}\n\n.range-arrow {\n flex: 0 0 16px;\n width: 16px;\n text-align: center;\n color: rgb(var(--v-theme-on-surface), 0.6);\n font-size: 22px;\n}\n\n.range-time-popover {\n position: absolute;\n top: 45px;\n width: 180px;\n z-index: 2;\n background: rgb(var(--v-theme-surface));\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n border-radius: 4px;\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\n}\n\n.single-time-popover {\n position: absolute;\n top: 45px;\n left: 156px;\n width: 180px;\n z-index: 2;\n background: rgb(var(--v-theme-surface));\n border: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n border-radius: 4px;\n box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);\n}\n\n.range-time-popover.start {\n left: 162px;\n}\n\n.range-time-popover.end {\n left: 430px;\n}\n\n.time-popover-footer {\n display: flex;\n justify-content: flex-end;\n gap: 8px;\n padding: 8px 10px;\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.selected-display {\n padding: 10px 16px;\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n text-align: center;\n}\n\n.selected-text {\n font-size: 14px;\n color: rgb(var(--v-theme-on-surface));\n}\n\n.placeholder-text,\n.inline-message {\n font-size: 14px;\n color: rgb(var(--v-theme-on-surface), 0.38);\n}\n\n.inline-message {\n padding: 16px;\n}\n\n.picker-footer {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 8px 10px;\n border-top: 1px solid rgb(var(--v-theme-on-surface), 0.12);\n}\n\n.footer-spacer {\n flex: 1;\n}\n\n.btn {\n padding: 8px 16px;\n border-radius: 4px;\n font-size: 14px;\n cursor: pointer;\n transition: all 0.2s;\n border: none;\n outline: none;\n}\n\n.btn.small {\n padding: 4px 8px;\n font-size: 12px;\n}\n\n.btn:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n\n.btn-text {\n background: none;\n color: rgb(var(--v-theme-primary));\n}\n\n.btn-text:hover:not(:disabled) {\n background: rgb(var(--v-theme-on-surface), 0.08);\n}\n\n.btn-primary {\n background: rgb(var(--v-theme-primary));\n color: rgb(var(--v-theme-on-primary));\n}\n\n.btn-primary:hover:not(:disabled) {\n opacity: 0.9;\n}\n</style>\n","<script setup>\r\nimport { ref, computed, reactive, onMounted, getCurrentInstance, watch, nextTick } from \"vue\";\r\nconst { proxy } = getCurrentInstance();\r\n// 获取配置的键名,如果没有配置则使用默认值\r\nconst userKey = window.VTK_CONFIG?.storageKeys?.user || '_mis_acis_users';\r\nconst user = JSON.parse(proxy.$vtk.storage.get(userKey));\r\n\r\nconsole.log('window.VTK_CONFIG=', window.VTK_CONFIG)\r\nconsole.log('window.VTK_CONFIG?.storageKeys?.user', window.VTK_CONFIG?.storageKeys?.user)\r\nconsole.log('user', user)\r\nconst pause = (ms) => new Promise((resolve) => setTimeout(resolve, ms));\r\n\r\n// 定义 props - 控制是否支持多选\r\nconst props = defineProps({\r\n multiple: {\r\n type: Boolean,\r\n default: false // 默认单选\r\n }\r\n});\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['selected']);\r\n\r\n// 定义响应式数据\r\nconst dialog = ref(false);\r\n\r\n\r\n// 地区列表\r\nconst areaData = ref([]);\r\nconst areaSelectedData = ref([]);\r\nconst areaActivatedData = ref([]);\r\n\r\nwatch(areaActivatedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.areaCode) {\r\n getDeptList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\nwatch(areaSelectedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.areaCode) {\r\n getDeptList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\n// 获取地区列表\r\nconst getAreaList = () => {\r\n if (user && user.areacode) {\r\n proxy.$vtk.request.getForm(`/dict/area/show/${user.areacode}`).then((res) => {\r\n console.log('res=', res);\r\n if (res && res.data) {\r\n areaData.value = [{\r\n areaCode: res.data.areaCode,\r\n areaName: res.data.areaName,\r\n children: []\r\n }];\r\n }\r\n });\r\n }\r\n};\r\n\r\n// 获取下级地区列表\r\nconst getAreaNextList = async (item) => {\r\n await pause(300);\r\n const parentCode = item.areaCode;\r\n proxy.$vtk.request.getForm(`/dict/area/next/${parentCode}`).then((res) => {\r\n if (res && res.data) {\r\n res.data.forEach((it) => {\r\n it.areaLeve < 12 && (it.children = []);\r\n item.children.push(it);\r\n });\r\n }\r\n });\r\n};\r\n\r\n// 部门列表\r\nconst deptData = ref([]);\r\nconst deptSelectedData = ref([]);\r\nconst deptActivatedData = ref([]);\r\n\r\nwatch(deptSelectedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.id) {\r\n getPersonList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\nwatch(deptActivatedData, (newVal, oldVal) => {\r\n // 检查数组非空且有有效数据\r\n if (newVal && newVal.length > 0 && newVal[0]?.id) {\r\n getPersonList(newVal);\r\n }\r\n}, { deep: true });\r\n\r\n// 点击叶子节点时调用的方法\r\nconst getDeptList = (node) => {\r\n const selectAreaCode = node[0].areaCode;\r\n const params = { codex: { area: selectAreaCode, type: \"0\" } };\r\n deptData.value = [];\r\n proxy.$vtk.request.postJson('/bizp/supported/dept/list', params).then((res) => {\r\n res.data.forEach((it) => {\r\n it.children = [];\r\n deptData.value.push(it);\r\n });\r\n });\r\n};\r\n\r\nconst getDepNextList = async (item) => {\r\n await pause(300);\r\n const selectAreaCode = item.areaCode;\r\n const selectPid = item.id;\r\n const params = { codex: { area: selectAreaCode, pid: selectPid } };\r\n proxy.$vtk.request.postJson('/bizp/supported/dept/list', params).then((res) => {\r\n if (res && res.data) {\r\n res.data.forEach((it) => {\r\n it.children = [];\r\n item.children.push(it);\r\n });\r\n }\r\n });\r\n};\r\n\r\n// 人员列表\r\nconst personData = ref([]);\r\nconst selectedPersonData = ref([]);\r\n// 全局已选人员列表(跨部门保存,用于去重和持久化选中状态)\r\nconst allSelectedPersons = ref([]);\r\n// 标记是否正在恢复选中状态(避免触发 watch 循环)\r\nconst isRestoringSelection = ref(false);\r\n\r\n// 已选中的人员列表(用于右侧显示)- 去重后的列表\r\nconst selectedPersonList = computed(() => {\r\n // 使用 Map 去重,key 为人员 id\r\n const uniqueMap = new Map();\r\n allSelectedPersons.value.forEach(person => {\r\n if (person && person.id) {\r\n uniqueMap.set(person.id, person);\r\n }\r\n });\r\n\r\n return Array.from(uniqueMap.values());\r\n});\r\n\r\n// 监听当前部门选中人员的变化\r\nwatch(selectedPersonData, (newVal, oldVal) => {\r\n // 如果正在恢复选中状态,不处理\r\n if (isRestoringSelection.value) {\r\n return;\r\n }\r\n\r\n // 单选模式:直接替换全局列表\r\n if (!props.multiple) {\r\n if (newVal && newVal.length > 0) {\r\n // 单选模式下只保留最新选中的一个\r\n allSelectedPersons.value = [newVal[0]];\r\n } else {\r\n // 取消选中时清空\r\n allSelectedPersons.value = [];\r\n }\r\n return;\r\n }\r\n\r\n // 多选模式:累加到全局列表\r\n // 处理新选中的人员\r\n if (newVal && newVal.length > 0) {\r\n newVal.forEach(person => {\r\n const exists = allSelectedPersons.value.some(p => p.id === person.id);\r\n if (!exists) {\r\n allSelectedPersons.value.push(person);\r\n }\r\n });\r\n }\r\n\r\n // 处理取消选中的人员\r\n if (oldVal && oldVal.length > 0) {\r\n oldVal.forEach(oldPerson => {\r\n const stillSelected = newVal?.some(p => p.id === oldPerson.id);\r\n if (!stillSelected) {\r\n // 从全局列表中移除\r\n const index = allSelectedPersons.value.findIndex(p => p.id === oldPerson.id);\r\n if (index > -1) {\r\n allSelectedPersons.value.splice(index, 1);\r\n }\r\n }\r\n });\r\n }\r\n}, { deep: true });\r\n\r\n// 监听部门切换,同步选中状态\r\nwatch(personData, async (newPersonData) => {\r\n if (!newPersonData || newPersonData.length === 0) {\r\n isRestoringSelection.value = true;\r\n selectedPersonData.value = [];\r\n await nextTick();\r\n isRestoringSelection.value = false;\r\n return;\r\n }\r\n\r\n // 等待 DOM 更新\r\n await nextTick();\r\n\r\n // 标记正在恢复选中状态\r\n isRestoringSelection.value = true;\r\n\r\n // 当人员列表更新时,恢复之前选中的状态\r\n const currentSelected = [];\r\n newPersonData.forEach(person => {\r\n const isSelected = allSelectedPersons.value.some(p => p.id === person.id);\r\n if (isSelected) {\r\n currentSelected.push(person);\r\n }\r\n });\r\n\r\n selectedPersonData.value = currentSelected;\r\n\r\n // 等待状态更新完成\r\n await nextTick();\r\n isRestoringSelection.value = false;\r\n}, { deep: true });\r\n\r\n// 移除已选中的人员\r\nconst removeSelectedPerson = (personId) => {\r\n // 从全局列表中移除\r\n const globalIndex = allSelectedPersons.value.findIndex(person => person.id === personId);\r\n if (globalIndex > -1) {\r\n allSelectedPersons.value.splice(globalIndex, 1);\r\n }\r\n\r\n // 从当前显示的选中列表中移除\r\n const currentIndex = selectedPersonData.value.findIndex(person => person.id === personId);\r\n if (currentIndex > -1) {\r\n selectedPersonData.value.splice(currentIndex, 1);\r\n }\r\n};\r\n\r\n\r\n// 点击叶子节点时调用的方法\r\n// \r\nconst getPersonList = (node) => {\r\n const selectAreaID = node[0].id;\r\n const params = { codex: { dept: selectAreaID } };\r\n\r\n proxy.$vtk.request.postJson('/bizp/supported/user/list', params).then((res) => {\r\n if (res && res.meta.success && res.data.length > 0) {\r\n personData.value = res.data\r\n } else {\r\n personData.value = null\r\n }\r\n });\r\n};\r\nconst add = () => {\r\n dialog.value = true;\r\n};\r\n\r\nconst close = () => {\r\n // 先设置标记,避免触发 watch\r\n isRestoringSelection.value = true;\r\n\r\n // 关闭对话框\r\n dialog.value = false;\r\n\r\n // 清空选中状态\r\n selectedPersonData.value = [];\r\n allSelectedPersons.value = [];\r\n areaSelectedData.value = [];\r\n areaActivatedData.value = [];\r\n deptSelectedData.value = [];\r\n deptActivatedData.value = [];\r\n personData.value = [];\r\n deptData.value = [];\r\n\r\n // 重置标记\r\n nextTick(() => {\r\n isRestoringSelection.value = false;\r\n });\r\n};\r\n\r\n// 确认选择\r\nconst confirm = () => {\r\n // 返回选中的人员列表给父组件\r\n const selectedPersons = selectedPersonList.value;\r\n // 通过 emit 将选中的人员传递给父组件\r\n emit('selected', selectedPersons);\r\n close();\r\n};\r\n\r\nonMounted(() => {\r\n // 获取地区列表\r\n getAreaList();\r\n});\r\n\r\n// 使组件方法可以被父组件调用\r\ndefineExpose({\r\n close,\r\n add,\r\n});\r\n</script>\r\n\r\n<template>\r\n <v-dialog v-model=\"dialog\" persistent width=\"1000\">\r\n <v-card>\r\n <v-card-title class=\"d-flex align-center\">\r\n <span class=\"text-h6\">人员选择</span>\r\n <v-spacer></v-spacer>\r\n <v-btn class=\"g-no-shadow\" icon @click=\"close\" size=\"small\">\r\n <v-icon>mdi-close</v-icon>\r\n </v-btn>\r\n </v-card-title>\r\n <v-divider />\r\n <v-card-text class=\"pb-0 mb-0 pl-0 pr-0\" style=\"height: 600px;\">\r\n <v-row style=\"margin-top:-16px; height: 100%;\">\r\n <v-col md=\"3\" class=\"pr-0 \" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">地区</span>\r\n </v-card-title>\r\n <v-sheet height=\"500\" style=\"overflow: auto\" class=\"mt-2 pl-2\">\r\n <v-treeview item-value=\"id\" item-title=\"areaName\" return-object :items=\"areaData\" density=\"compact\"\r\n color=\"primary\" item-props activatable v-model:selected=\"areaSelectedData\"\r\n v-model:activated=\"areaActivatedData\" :load-children=\"getAreaNextList\">\r\n <template v-slot:title=\"{ item }\">\r\n <span :title=\"item.areaName\">{{ item.areaName }}</span>\r\n </template>\r\n </v-treeview>\r\n </v-sheet>\r\n </v-col>\r\n <v-col md=\"3\" class=\"pr-0 pl-0\" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">部门</span>\r\n </v-card-title>\r\n <v-sheet height=\"500\" style=\"overflow: auto\" class=\"mt-2 pl-2\">\r\n <v-treeview v-if=\"deptData && deptData.length > 0\" item-value=\"id\" item-title=\"name\" return-object :items=\"deptData\" density=\"compact\"\r\n color=\"primary\" item-props activatable v-model:selected=\"deptSelectedData\"\r\n v-model:activated=\"deptActivatedData\" :load-children=\"getDepNextList\">\r\n <template v-slot:title=\"{ item }\">\r\n <span :title=\"item.name\">{{ item.name }}</span>\r\n </template>\r\n </v-treeview>\r\n <div v-else class=\"text-center pt-4 d-flex flex-column align-center justify-center\">\r\n <v-icon size=\"64\" color=\"grey-lighten-2\" class=\"mb-4\">\r\n mdi-office-building-outline\r\n </v-icon>\r\n <div class=\"text-grey\">暂无</div>\r\n </div>\r\n </v-sheet>\r\n </v-col>\r\n <v-col md=\"3\" class=\"pr-0 pl-0\" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">人员</span>\r\n </v-card-title>\r\n <v-sheet height=\"550\" style=\"overflow: auto;\" class=\"mt-2\">\r\n <v-treeview v-if=\"personData && personData.length > 0\"\r\n item-value=\"id\"\r\n item-title=\"username\"\r\n return-object\r\n :items=\"personData\"\r\n density=\"compact\"\r\n color=\"primary\"\r\n item-props\r\n selectable\r\n :select-strategy=\"multiple ? 'leaf' : 'single-leaf'\"\r\n v-model:selected=\"selectedPersonData\">\r\n <template v-slot:title=\"{ item }\">\r\n <div class=\"d-flex align-center\" :title=\"item.username\">\r\n <v-avatar size=\"24\" class=\"mr-2\">\r\n <v-img v-if=\"item.avatar\" :src=\"item.avatar\"></v-img>\r\n <v-icon v-else size=\"20\">mdi-account-circle</v-icon>\r\n </v-avatar>\r\n <span>{{ item.username }}</span>\r\n </div>\r\n </template>\r\n </v-treeview>\r\n <div v-else class=\"text-center pt-4 d-flex flex-column align-center justify-center\">\r\n <v-icon size=\"64\" color=\"grey-lighten-2\" class=\"mb-4\">\r\n mdi-account-group\r\n </v-icon>\r\n <div class=\"text-grey\">暂无</div>\r\n </div>\r\n </v-sheet>\r\n </v-col>\r\n <v-col md=\"3\" class=\"pr-0 pl-0\" style=\"border-right: 1px #ccc solid;height: 600px;\">\r\n <v-card-title class=\"text-center py-0 text-body-1 font-weight-bold \">\r\n <span class=\"mx-auto\">已选中人员 ({{ selectedPersonList.length }})</span>\r\n </v-card-title>\r\n <v-sheet height=\"550\" style=\"overflow: auto\" class=\"mt-2 px-2\">\r\n <v-list v-if=\"selectedPersonList.length > 0\" density=\"compact\">\r\n <v-list-item\r\n v-for=\"person in selectedPersonList\"\r\n :key=\"person.id\"\r\n :title=\"person.username\"\r\n class=\"px-2 mb-1 mr-2\"\r\n rounded=\"lg\"\r\n color=\"primary\"\r\n variant=\"tonal\">\r\n <template v-slot:prepend>\r\n <v-avatar size=\"32\">\r\n <v-img v-if=\"person.avatar\" :src=\"person.avatar\"></v-img>\r\n <v-icon v-else>mdi-account-circle</v-icon>\r\n </v-avatar>\r\n </template>\r\n <template v-slot:append>\r\n <v-btn\r\n icon\r\n size=\"x-small\"\r\n variant=\"text\"\r\n @click=\"removeSelectedPerson(person.id)\">\r\n <v-icon size=\"16\">mdi-close</v-icon>\r\n </v-btn>\r\n </template>\r\n </v-list-item>\r\n </v-list>\r\n <div v-else class=\"text-center pt-4 d-flex flex-column align-center justify-center\">\r\n <v-icon size=\"64\" color=\"grey-lighten-2\" class=\"mb-4\">\r\n mdi-account\r\n </v-icon>\r\n <div class=\"text-grey\">暂无选中</div>\r\n </div>\r\n </v-sheet>\r\n </v-col>\r\n </v-row>\r\n </v-card-text>\r\n <v-divider />\r\n <v-card-actions>\r\n <v-spacer></v-spacer>\r\n <v-btn color=\"darken-1\" text @click=\"close\">取消</v-btn>\r\n <v-btn color=\"blue darken-1\" text @click=\"confirm\">确定</v-btn>\r\n </v-card-actions>\r\n </v-card>\r\n </v-dialog>\r\n</template>\r\n\r\n<style scoped>\r\n:deep() .v-sheet[style*=\"overflow: auto\"] {\r\n &::-webkit-scrollbar {\r\n width: 5px;\r\n }\r\n\r\n &::-webkit-scrollbar-thumb {\r\n background: #ccc;\r\n border-radius: 4px;\r\n }\r\n}\r\n</style>","<!-- 空页面 -->\r\n<template>\r\n <v-empty-state\r\n :headline=\"headline\"\r\n :title=\"title\"\r\n :text=\"text\"\r\n :image=\"image\"\r\n :icon=\"icon\"\r\n :rounded=\"rounded\"\r\n :elevation=\"elevation\"\r\n >\r\n <!-- 图像插槽 -->\r\n <template v-if=\"$slots.media\" #media>\r\n <slot name=\"media\"></slot>\r\n </template>\r\n\r\n <!-- 标题插槽 -->\r\n <template v-if=\"$slots.title\" #title>\r\n <slot name=\"title\"></slot>\r\n </template>\r\n\r\n <!-- 文本插槽 -->\r\n <template v-if=\"$slots.text\" #text>\r\n <slot name=\"text\"></slot>\r\n </template>\r\n\r\n <!-- 操作按钮插槽 -->\r\n <template v-if=\"$slots.actions\" #actions>\r\n <slot name=\"actions\"></slot>\r\n </template>\r\n\r\n <!-- 底部插槽 -->\r\n <template v-if=\"$slots.bottom\" #bottom>\r\n <slot name=\"bottom\"></slot>\r\n </template>\r\n </v-empty-state>\r\n</template>\r\n\r\n<script setup>\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkEmpty\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // 标题\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n // 副标题/文本\r\n text: {\r\n type: String,\r\n default: ''\r\n },\r\n // 头部文本(更大字体)\r\n headline: {\r\n type: String,\r\n default: ''\r\n },\r\n // 图标\r\n icon: {\r\n type: String,\r\n default: ''\r\n },\r\n // 图像\r\n image: {\r\n type: String,\r\n default: ''\r\n },\r\n // 圆角\r\n rounded: {\r\n type: [Boolean, String, Number],\r\n default: 'circle'\r\n },\r\n // 阴影\r\n elevation: {\r\n type: [Number, String],\r\n default: 0\r\n }\r\n});\r\n</script>\r\n\r\n<style scoped>\r\n/* 可以添加自定义样式 */\r\n:deep(.v-empty-state) {\r\n padding: 24px;\r\n}\r\n\r\n:deep(.v-empty-state__media) {\r\n margin-bottom: 16px;\r\n}\r\n\r\n:deep(.v-empty-state__headline) {\r\n margin-bottom: 8px;\r\n}\r\n\r\n:deep(.v-empty-state__title) {\r\n margin-bottom: 8px;\r\n}\r\n\r\n:deep(.v-empty-state__actions) {\r\n margin-top: 16px;\r\n}\r\n</style>","<!-- 悬浮按钮 -->\r\n<template>\r\n <transition name=\"slide-up\">\r\n <v-fab\r\n v-if=\"showFab\"\r\n :class=\"fabClass\"\r\n color=\"primary\"\r\n icon=\"mdi-arrow-up\"\r\n @click=\"scrollToTop\"\r\n ></v-fab>\r\n </transition>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, onBeforeUnmount } from 'vue'\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkFab\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 控制悬浮按钮显示状态\r\nconst showFab = ref(false)\r\n// 自定义类名用于样式调整\r\nconst fabClass = ref('scroll-to-top-fab')\r\n\r\n// 监听滚动事件\r\nconst handleScroll = () => {\r\n showFab.value = window.scrollY > 100\r\n}\r\n\r\n// 滚动到顶部\r\nconst scrollToTop = () => {\r\n window.scrollTo({\r\n top: 0,\r\n behavior: 'smooth'\r\n })\r\n}\r\n\r\n// 组件挂载时添加滚动监听\r\nonMounted(() => {\r\n window.addEventListener('scroll', handleScroll)\r\n})\r\n\r\n// 组件卸载前移除监听\r\nonBeforeUnmount(() => {\r\n window.removeEventListener('scroll', handleScroll)\r\n})\r\n</script>\r\n\r\n<style scoped>\r\n.scroll-to-top-fab {\r\n position: fixed;\r\n bottom: 24px;\r\n right: 24px;\r\n z-index: 1004;\r\n}\r\n\r\n/* 滑动动画 */\r\n.slide-up-enter-active {\r\n transition: all 0.2s ease-out;\r\n}\r\n\r\n.slide-up-leave-active {\r\n transition: all 0.2s ease-in;\r\n}\r\n\r\n.slide-up-enter-from {\r\n opacity: 0;\r\n transform: translateY(30px);\r\n}\r\n\r\n.slide-up-leave-to {\r\n opacity: 0;\r\n transform: translateY(30px);\r\n}\r\n</style>","<template>\r\n <div\r\n class=\"box\"\r\n :class=\"{\r\n 'form-item--vertical': top,\r\n 'form-item--horizontal': !top\r\n }\"\r\n style=\"position: relative\"\r\n >\r\n <!-- label 在上方 (top模式) -->\r\n <div\r\n v-if=\"label && top\"\r\n class=\"pb-2 text-left\"\r\n >\r\n <span v-if=\"must\" class=\"text-red mr-1\">*</span>\r\n <span>{{ label }}</span>\r\n </div>\r\n\r\n <!-- label 在左侧 (默认模式) -->\r\n <div\r\n v-if=\"label && !top\"\r\n :class=\"left ? '' : 'vtk-width-2'\"\r\n class=\"d-inline-block text-right\"\r\n :style=\"Tstyle\"\r\n style=\"min-width: 120px !important;vertical-align: top;padding-top: 11px;\"\r\n >\r\n <span v-if=\"must\" class=\"text-red\">*</span>\r\n <span>{{ label }}</span>\r\n </div>\r\n\r\n <!-- 输入框容器 (top模式) -->\r\n <div\r\n v-if=\"top\"\r\n :style=\"contentStyles\"\r\n >\r\n <slot></slot>\r\n </div>\r\n\r\n <!-- 输入框容器 (默认模式) -->\r\n <div\r\n v-if=\"!top\"\r\n class=\"d-inline-block vtk-width-7 \"\r\n style=\"min-width: 350px;\"\r\n >\r\n <slot></slot>\r\n </div>\r\n\r\n <!-- help提示 (仅left模式) -->\r\n <div\r\n v-if=\"left && help && !top\"\r\n class=\"box_help tips py-3 px-4\"\r\n style=\"width: calc(30% - 160px)\"\r\n >\r\n <p class=\"mb-2 font-weight-bold text-body-1\">{{ label }}</p>\r\n <span v-html=\"help\"></span>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\n\r\n// 定义组件名称和选项\r\ndefineOptions({\r\n name: \"VtkFormItem\",\r\n inheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n label: {\r\n type: String,\r\n default: null\r\n },\r\n must: {\r\n type: Boolean,\r\n default: false\r\n },\r\n left: {\r\n type: Boolean,\r\n default: false\r\n },\r\n // 标签在上方的垂直布局\r\n top: {\r\n type: Boolean,\r\n default: false\r\n },\r\n Tstyle: {\r\n type: String,\r\n default: null\r\n },\r\n help: {\r\n type: String,\r\n default: null\r\n },\r\n // 控制top模式下内容的最大宽度\r\n maxWidth: {\r\n type: [String, Number],\r\n default: '100%'\r\n }\r\n});\r\n\r\n// 处理maxWidth属性\r\nconst processedMaxWidth = computed(() => {\r\n if (typeof props.maxWidth === 'number') {\r\n return props.maxWidth + 'px';\r\n }\r\n return props.maxWidth;\r\n});\r\n\r\n// 内容样式(仅在top模式下应用maxWidth)\r\nconst contentStyles = computed(() => {\r\n const styles = {};\r\n\r\n // 在top模式下应用maxWidth\r\n if (props.top && props.maxWidth) {\r\n styles.maxWidth = processedMaxWidth.value;\r\n }\r\n\r\n return styles;\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.box:hover > .box_help {\r\n display: inline-block !important;\r\n border-top-right-radius: 24px;\r\n border-bottom-left-radius: 24px;\r\n}\r\n\r\n.box_help {\r\n display: none;\r\n}\r\n\r\n.tips {\r\n position: absolute;\r\n right: 8px;\r\n top: 0;\r\n border: 1px rgba(175, 175, 175, 0.341) solid;\r\n}\r\n\r\n.form-item--vertical {\r\n display: block;\r\n margin-bottom: 1rem;\r\n}\r\n\r\n.form-item--horizontal {\r\n display: block;\r\n margin-bottom: 0.5rem;\r\n}\r\n</style>\r\n","<template>\r\n <div class=\"vtk-img-container\">\r\n <VCard \r\n :class=\"['vtk-img-card', { 'vtk-img-card--preview': preview }]\"\r\n @click=\"openPreview\"\r\n >\r\n <v-img \r\n v-bind=\"$attrs\" \r\n :src=\"srcWithToken\"\r\n class=\"vtk-img\"\r\n :aspect-ratio=\"aspectRatio\"\r\n cover\r\n >\r\n <template v-slot:placeholder>\r\n <div class=\"d-flex align-center justify-center fill-height\">\r\n <v-progress-circular indeterminate color=\"grey-lighten-1\"></v-progress-circular>\r\n </div>\r\n </template>\r\n </v-img>\r\n \r\n <!-- 图片标题和描述 -->\r\n <div class=\"vtk-img-info\" v-if=\"showTitle || showDescription\">\r\n <VCardTitle v-if=\"showTitle\" class=\"vtk-img-title text-subtitle-2 pa-2\">\r\n {{ title }}\r\n </VCardTitle>\r\n <v-card-subtitle v-if=\"showDescription\" class=\"vtk-img-description text-caption pa-2\">\r\n {{ description }}\r\n </v-card-subtitle>\r\n </div>\r\n </VCard>\r\n \r\n <!-- 使用 v-dialog 的图片预览 -->\r\n <VDialog \r\n v-model=\"showPreview\" \r\n max-width=\"90%\" \r\n fullscreen\r\n @click:outside=\"closePreview\"\r\n >\r\n <VCard class=\"image-viewer-card\">\r\n <v-toolbar dark color=\"primary\">\n <v-toolbar-title>{{ currentImageTitle }}</v-toolbar-title>\n <VSpacer></VSpacer>\n <v-toolbar-items>\n <VBtn icon dark @click=\"zoomImage(-0.3)\">\r\n <VIcon>mdi-magnify-minus-outline</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"zoomImage(0.3)\">\r\n <VIcon>mdi-magnify-plus-outline</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"rotateImage(-90)\">\r\n <VIcon>mdi-rotate-left</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"rotateImage(90)\">\r\n <VIcon>mdi-rotate-right</VIcon>\r\n </VBtn>\r\n <VBtn icon dark @click=\"resetImageTransform\">\n <VIcon>mdi-refresh</VIcon>\n </VBtn>\n <VBtn icon dark @click=\"closePreview\">\n <VIcon>mdi-close</VIcon>\n </VBtn>\n </v-toolbar-items>\n </v-toolbar>\n \r\n <div class=\"image-viewer-content\">\r\n <VBtn \r\n v-if=\"hasPrev\" \r\n icon \r\n class=\"nav-button prev-button\" \r\n @click=\"prevImage\"\r\n >\r\n <VIcon>mdi-chevron-left</VIcon>\r\n </VBtn>\r\n \r\n <div class=\"image-container\" @wheel.prevent=\"handleImageWheel\">\r\n <v-img\r\n :src=\"currentImageUrl\"\r\n class=\"viewer-image\"\r\n :class=\"{ 'viewer-image--draggable': imageScale > 1 }\"\r\n :style=\"viewerImageStyle\"\r\n draggable=\"false\"\r\n @pointerdown=\"startImageDrag\"\r\n />\r\n </div>\r\n \r\n <VBtn \r\n v-if=\"hasNext\" \r\n icon \r\n class=\"nav-button next-button\" \r\n @click=\"nextImage\"\r\n >\r\n <VIcon>mdi-chevron-right</VIcon>\r\n </VBtn>\r\n </div>\r\n \r\n <div class=\"image-info\">\r\n <p class=\"text-center\">{{ currentImageDescription }}</p>\r\n <p class=\"text-center text--secondary\">{{ currentIndex + 1 }} / {{ imageList.length }}</p>\r\n </div>\r\n </VCard>\r\n </VDialog>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch } from 'vue';\r\n\r\ndefineOptions({\r\n name: 'VtkImg',\r\n inheritAttrs: true\r\n});\r\n\r\nconst props = defineProps({\r\n src: {\r\n type: String,\r\n default: null,\r\n },\r\n error: {\r\n type: String,\r\n default: new URL('../../assets/img/wxsq.png', import.meta.url).href,\r\n },\r\n preview: {\r\n type: Boolean,\r\n default: true\r\n },\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n description: {\r\n type: String,\r\n default: ''\r\n },\r\n // 图片列表,用于导航功能\r\n imageList: {\r\n type: Array,\r\n default: () => []\r\n },\r\n // 当前图片索引\r\n index: {\r\n type: Number,\r\n default: 0\r\n },\r\n // 是否显示标题\r\n showTitle: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 是否显示描述\r\n showDescription: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 图片宽高比\r\n aspectRatio: {\r\n type: [String, Number],\r\n default: 16/9\r\n }\r\n});\r\n\r\n// 预览状态\r\nconst showPreview = ref(false);\r\n// 图片旋转角度\r\nconst imageRotation = ref(0);\r\n// 图片缩放和拖动位置\r\nconst imageScale = ref(1);\r\nconst imageTranslateX = ref(0);\r\nconst imageTranslateY = ref(0);\r\nconst imageDragState = ref(null);\r\n// 当前图片索引(预览模式下使用)\r\nconst currentIndex = ref(0);\r\n\r\n// 使用计算属性处理带token的URL\r\nconst srcWithToken = computed(() => {\r\n if (!props.src) return props.src;\r\n \r\n try {\r\n // 首先尝试使用 $vtk.storage\r\n if (window.$vtk && typeof window.$vtk.storage?.get === 'function') {\r\n const token = window.$vtk.storage.get('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n // 如果 $vtk 不存在,尝试从 localStorage 获取 token\r\n else {\r\n const token = localStorage.getItem('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n } catch (error) {\r\n // 发生错误时返回原始src\r\n console.warn('VtkImg: Failed to get token, using src without token', error);\r\n return props.src;\r\n }\r\n});\r\n\r\n// 当前预览图片的URL\r\nconst currentImageUrl = computed(() => {\r\n if (props.imageList.length > 0 && currentIndex.value < props.imageList.length) {\r\n const currentImage = props.imageList[currentIndex.value];\r\n if (currentImage && currentImage.url) {\r\n try {\r\n // 为图片列表中的图片也添加token\r\n if (window.$vtk && typeof window.$vtk.storage?.get === 'function') {\r\n const token = window.$vtk.storage.get('_mis_acis_token');\r\n return token ? `${currentImage.url}?stoken=${token}` : currentImage.url;\r\n } else {\r\n const token = localStorage.getItem('_mis_acis_token');\r\n return token ? `${currentImage.url}?stoken=${token}` : currentImage.url;\r\n }\r\n } catch (error) {\r\n return currentImage.url;\r\n }\r\n }\r\n }\r\n return srcWithToken.value;\r\n});\r\n\r\n// 当前图片标题\r\nconst currentImageTitle = computed(() => {\r\n if (props.imageList.length > 0 && currentIndex.value < props.imageList.length) {\r\n const currentImage = props.imageList[currentIndex.value];\r\n return currentImage?.title || '';\r\n }\r\n return props.title;\r\n});\r\n\r\n// 当前图片描述\r\nconst currentImageDescription = computed(() => {\r\n if (props.imageList.length > 0 && currentIndex.value < props.imageList.length) {\r\n const currentImage = props.imageList[currentIndex.value];\r\n return currentImage?.description || '';\r\n }\r\n return props.description;\r\n});\r\n\r\n// 是否有上一张图片\r\nconst hasPrev = computed(() => {\r\n return props.imageList.length > 1 && currentIndex.value > 0;\r\n});\r\n\r\n// 是否有下一张图片\r\nconst hasNext = computed(() => {\r\n return props.imageList.length > 1 && currentIndex.value < props.imageList.length - 1;\r\n});\r\n\r\nconst viewerImageStyle = computed(() => ({\r\n transform: `translate(${imageTranslateX.value}px, ${imageTranslateY.value}px) scale(${imageScale.value}) rotate(${imageRotation.value}deg)`,\r\n}));\r\n\r\nconst resetImageTransform = () => {\r\n imageRotation.value = 0;\r\n imageScale.value = 1;\r\n imageTranslateX.value = 0;\r\n imageTranslateY.value = 0;\r\n imageDragState.value = null;\r\n};\r\n\r\n// 监听预览状态变化\r\nwatch(showPreview, (newVal) => {\r\n if (newVal) {\r\n // 打开预览时重置旋转角度和当前索引\r\n resetImageTransform();\r\n currentIndex.value = props.index;\r\n }\r\n});\r\n\r\n// 打开预览\r\nconst openPreview = () => {\r\n if (props.preview) {\r\n showPreview.value = true;\r\n }\r\n};\r\n\r\n// 关闭预览\r\nconst closePreview = () => {\r\n showPreview.value = false;\r\n};\r\n\r\n// 上一张图片\r\nconst prevImage = () => {\r\n if (hasPrev.value) {\r\n currentIndex.value--;\r\n resetImageTransform();\r\n }\r\n};\r\n\r\n// 下一张图片\r\nconst nextImage = () => {\r\n if (hasNext.value) {\r\n currentIndex.value++;\r\n resetImageTransform();\r\n }\r\n};\r\n\r\n// 旋转图片\r\nconst rotateImage = (degrees) => {\r\n imageRotation.value += degrees;\r\n};\r\n\r\nconst zoomImage = (step) => {\r\n const nextScale = Number((imageScale.value + step).toFixed(2));\r\n imageScale.value = Math.min(3, Math.max(0.2, nextScale));\r\n if (imageScale.value <= 1) {\r\n imageTranslateX.value = 0;\r\n imageTranslateY.value = 0;\r\n }\r\n};\r\n\r\nconst handleImageWheel = (event) => {\r\n zoomImage(event.deltaY < 0 ? 0.2 : -0.2);\r\n};\r\n\r\nconst startImageDrag = (event) => {\r\n if (imageScale.value <= 1) return;\r\n event.preventDefault();\r\n const target = event.currentTarget;\r\n imageDragState.value = {\r\n pointerId: event.pointerId,\r\n startX: event.clientX,\r\n startY: event.clientY,\r\n translateX: imageTranslateX.value,\r\n translateY: imageTranslateY.value,\r\n };\r\n target.setPointerCapture?.(event.pointerId);\r\n target.addEventListener('pointermove', moveImageDrag);\r\n target.addEventListener('pointerup', endImageDrag, { once: true });\r\n target.addEventListener('pointercancel', endImageDrag, { once: true });\r\n};\r\n\r\nconst moveImageDrag = (event) => {\r\n const state = imageDragState.value;\r\n if (!state || state.pointerId !== event.pointerId) return;\r\n imageTranslateX.value = state.translateX + event.clientX - state.startX;\r\n imageTranslateY.value = state.translateY + event.clientY - state.startY;\r\n};\r\n\r\nconst endImageDrag = (event) => {\r\n event.currentTarget?.releasePointerCapture?.(event.pointerId);\r\n event.currentTarget?.removeEventListener('pointermove', moveImageDrag);\r\n imageDragState.value = null;\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-img-container {\r\n position: relative;\r\n display: inline-block;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.vtk-img-card {\r\n height: 100%;\r\n}\r\n\r\n.vtk-img-card--preview {\r\n cursor: pointer;\r\n transition: transform 0.2s ease-in-out;\r\n}\r\n\r\n.vtk-img-card--preview:hover {\r\n transform: translateY(-5px);\r\n}\r\n\r\n.vtk-img {\r\n width: 100%;\r\n}\r\n\r\n.vtk-img-info {\r\n padding: 0;\r\n}\r\n\r\n.vtk-img-title {\r\n word-break: break-word;\r\n}\r\n\r\n.vtk-img-description {\r\n word-break: break-word;\r\n}\r\n\r\n/* 图片查看器样式 */\r\n.image-viewer-card {\r\n background-color: rgba(0, 0, 0, 0.9);\r\n color: white;\r\n}\r\n\r\n.image-viewer-content {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: calc(100vh - 150px);\r\n position: relative;\r\n}\r\n\r\n.image-container {\r\n flex: 1;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n overflow: hidden;\r\n}\r\n\r\n.viewer-image {\r\n max-width: 90%;\r\n max-height: 80vh;\r\n transform-origin: center center;\r\n transition: transform 0.3s ease;\r\n user-select: none;\r\n touch-action: none;\r\n}\r\n\r\n.viewer-image--draggable {\r\n cursor: grab;\r\n}\r\n\r\n.viewer-image--draggable:active {\r\n cursor: grabbing;\r\n}\r\n\r\n.nav-button {\r\n position: absolute;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n z-index: 10;\r\n background-color: rgba(0, 0, 0, 0.5);\r\n color: white;\r\n width: 50px;\r\n height: 50px;\r\n}\r\n\r\n.prev-button {\r\n left: 20px;\r\n}\r\n\r\n.next-button {\r\n right: 20px;\r\n}\r\n\r\n.image-info {\r\n padding: 20px;\r\n background-color: rgba(0, 0, 0, 0.7);\r\n}\r\n\r\n.image-info p {\r\n margin: 5px 0;\r\n}\r\n\r\n:deep(.v-img__img) {\r\n background: v-bind('props.error') no-repeat center;\r\n background-size: cover;\r\n}\r\n\r\n:deep(.v-img__placeholder) {\r\n filter: blur(0px);\r\n}\r\n</style>\r\n","<template>\r\n <div class=\"m_pagination\">\r\n <VRow v-if=\"pageDatas.rowCount > 0\" class=\"pagination box\" align=\"center\">\r\n <span class=\"page-total d-none d-md-flex align-center\">共{{ pageDatas.rowCount }}条</span>\r\n <VSelect\r\n v-model=\"pagination.limit\"\r\n :items=\"pageSizeObjs\"\r\n variant=\"outlined\"\r\n density=\"compact\"\r\n :menu-props=\"{ offsetY: true }\"\r\n hide-details\r\n class=\"page-select ml-2 d-none d-md-flex\"\r\n @update:model-value=\"pageSizeChange()\"\r\n />\r\n <span class=\"my-2\">\r\n <v-pagination\r\n v-model=\"pageDatas.pageno\"\r\n :total-visible=\"5\"\r\n :length=\"pageDatas.pageCount\"\r\n size=\"small\"\r\n @update:model-value=\"pageChange()\"\r\n />\r\n </span>\r\n <span class=\"page-total ml-3 d-none d-md-flex align-center\">到</span>\r\n <VTextField\r\n v-model=\"pagination.pageno\"\r\n variant=\"outlined\"\r\n density=\"compact\"\r\n hide-details\r\n class=\"page-go ml-2 d-none d-md-flex\"\r\n @keyup.enter=\"toPage()\"\r\n />\r\n <span class=\"page-total ml-2 d-none d-md-flex align-center\">页</span>\r\n </VRow>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, reactive, computed, watch, onMounted } from 'vue';\r\n\r\nconst props = defineProps({\r\n pageData: {\r\n type: Object,\r\n default: () => ({})\r\n },\r\n pageSizes: {\r\n type: Array,\r\n default: () => [10, 20, 30]\r\n }\r\n});\r\n\r\nconst emit = defineEmits(['pageChange']);\r\n\r\nconst pagination = reactive({\r\n pageno: 1,\r\n limit: 10\r\n});\r\n\r\nconst pageSizeObjs = ref([]);\r\nconst pageDatas = ref({ ...props.pageData });\r\n\r\nconst paginationChange = computed(() => pageDatas.value.pageno);\r\n\r\nwatch(paginationChange, () => {\r\n pagination.pageno = pageDatas.value.pageno;\r\n});\r\n\r\nwatch(() => props.pageData, (newVal) => {\r\n pageDatas.value = { ...newVal };\r\n if (newVal.rowCount < 1 && newVal.rows > 0) {\r\n pageDatas.value.pageno = newVal.pageno - 1;\r\n pageChange();\r\n }\r\n}, { deep: true });\r\n\r\nonMounted(() => {\r\n pageSizeFormat();\r\n});\r\n\r\nconst toPage = () => {\r\n const re = /^[0-9]+$/;\r\n if (re.test(pagination.pageno) && pagination.pageno <= pageDatas.value.pageCount) {\r\n pageDatas.value.pageno = parseInt(pagination.pageno);\r\n pageChange();\r\n } else {\r\n pagination.pageno = pageDatas.value.pageno;\r\n }\r\n};\r\n\r\nconst pageSizeChange = () => {\r\n pageDatas.value.pageCount = 1;\r\n pageChange();\r\n};\r\n\r\nconst pageSizeFormat = () => {\r\n const temp = props.pageSizes;\r\n temp.forEach((value) => {\r\n const obj = {\r\n title: value + \"条/页\",\r\n value: value\r\n };\r\n pageSizeObjs.value.push(obj);\r\n });\r\n pagination.limit = temp[0];\r\n};\r\n\r\nconst pageChange = () => {\r\n const page = {\r\n pageno: pageDatas.value.pageno,\r\n limit: pagination.limit\r\n };\r\n emit('pageChange', page);\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.mt-1 {\r\n margin-top: 11px !important;\r\n}\r\n.my-5 {\r\n margin-top: 20px !important;\r\n margin-bottom: 20px !important;\r\n}\r\n.m_pagination {\r\n width: 100%;\r\n min-height: 52px;\r\n display: flex;\r\n align-items: center;\r\n .box {\r\n position: absolute;\r\n right: 32px;\r\n }\r\n}\r\n.page-total {\r\n display: flex;\r\n align-items: center;\r\n height: 36px;\r\n font-size: 13px;\r\n padding-top: 4px;\r\n}\r\n.page-select {\r\n padding-top: 4px;\r\n max-width: 115px;\r\n :deep(.v-input__control) {\r\n min-height: 36px !important;\r\n height: 36px !important;\r\n }\r\n :deep(.v-field) {\r\n height: 36px !important;\r\n font-size: 13px !important;\r\n }\r\n :deep(.v-field__input) {\r\n padding-top: 6px !important;\r\n padding-bottom: 6px !important;\r\n min-height: 36px !important;\r\n }\r\n}\r\n.page-go {\r\n max-width: 75px;\r\n :deep(.v-input__control) {\r\n min-height: 36px !important;\r\n height: 36px !important;\r\n }\r\n :deep(.v-field) {\r\n height: 36px !important;\r\n font-size: 13px !important;\r\n }\r\n :deep(.v-field__input) {\r\n padding-top: 6px !important;\r\n padding-bottom: 6px !important;\r\n min-height: 36px !important;\r\n }\r\n}\r\n\r\n// 分页按钮缩小\r\n.my-2 {\r\n :deep(.v-pagination__item),\r\n :deep(.v-pagination__prev),\r\n :deep(.v-pagination__next) {\r\n min-width: 32px !important;\r\n height: 36px !important;\r\n font-size: 13px !important;\r\n }\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-pdf-container\">\r\n <VCard \r\n :class=\"['vtk-pdf-card', { 'vtk-pdf-card--preview': preview }]\"\r\n @click=\"openPreview\"\r\n >\r\n <!-- PDF封面或默认图标 -->\r\n <div class=\"vtk-pdf-cover\" :style=\"{ aspectRatio: aspectRatio }\">\r\n <VIcon size=\"48\" color=\"red\">mdi-file-pdf-box</VIcon>\r\n <div class=\"vtk-pdf-label\">PDF</div>\r\n </div>\r\n \r\n <!-- PDF标题和描述 -->\r\n <div class=\"vtk-pdf-info\" v-if=\"showTitle || showDescription\">\r\n <VCardTitle v-if=\"showTitle\" class=\"vtk-pdf-title text-subtitle-2 pa-2\">\r\n {{ title }}\r\n </VCardTitle>\r\n <v-card-subtitle v-if=\"showDescription\" class=\"vtk-pdf-description text-caption pa-2\">\r\n {{ description }}\r\n </v-card-subtitle>\r\n </div>\r\n </VCard>\r\n \r\n <!-- 使用 v-dialog 的PDF预览 -->\r\n <VDialog \r\n v-model=\"showPreview\" \r\n max-width=\"90%\" \r\n fullscreen\r\n @click:outside=\"closePreview\"\r\n >\r\n <VCard class=\"pdf-viewer-card\">\r\n <v-toolbar dark color=\"red darken-1\">\r\n <VBtn icon dark @click=\"closePreview\">\r\n <VIcon>mdi-close</VIcon>\r\n </VBtn>\r\n <v-toolbar-title>{{ title }}</v-toolbar-title>\r\n <VSpacer></VSpacer>\r\n <v-toolbar-items>\r\n <VBtn icon dark @click=\"downloadPdf\">\r\n <VIcon>mdi-download</VIcon>\r\n </VBtn>\r\n </v-toolbar-items>\r\n </v-toolbar>\r\n \r\n <div class=\"pdf-viewer-content\">\r\n <div class=\"pdf-container\" ref=\"pdfContainer\">\r\n <!-- PDF内容将通过PDF.js渲染 -->\r\n <div id=\"pdf-viewer\"></div>\r\n </div>\r\n </div>\r\n \r\n <div class=\"pdf-viewer-footer\" v-if=\"pdfLoaded\">\r\n <VRow align=\"center\" justify=\"center\">\r\n <VCol cols=\"12\" sm=\"6\" class=\"d-flex justify-center\">\r\n <VBtn icon @click=\"prevPage\" :disabled=\"currentPage <= 1\">\r\n <VIcon>mdi-chevron-left</VIcon>\r\n </VBtn>\r\n <div class=\"mx-4\">\r\n <span>第 {{ currentPage }} 页 / 共 {{ pageCount }} 页</span>\r\n </div>\r\n <VBtn icon @click=\"nextPage\" :disabled=\"currentPage >= pageCount\">\r\n <VIcon>mdi-chevron-right</VIcon>\r\n </VBtn>\r\n </VCol>\r\n <VCol cols=\"12\" sm=\"6\" class=\"d-flex justify-center\">\r\n <VSlider\r\n v-model=\"currentPage\"\r\n :min=\"1\"\r\n :max=\"pageCount\"\r\n hide-details\r\n class=\"mx-4\"\r\n ></VSlider>\r\n </VCol>\r\n </VRow>\r\n </div>\r\n \r\n <div class=\"pdf-loading\" v-if=\"loading\">\r\n <v-progress-circular indeterminate color=\"red\"></v-progress-circular>\r\n <p class=\"mt-2\">正在加载PDF...</p>\r\n </div>\r\n </VCard>\r\n </VDialog>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, onMounted, onBeforeUnmount } from 'vue';\r\n// import * as pdfjsLib from 'pdfjs-dist';\r\n// 注意:在实际项目中,您需要安装 pdfjs-dist 库\r\n// npm install pdfjs-dist\r\n// import * as pdfjsLib from 'pdfjs-dist';\r\n\r\ndefineOptions({\r\n name: 'VtkPdf',\r\n inheritAttrs: true\r\n});\r\n\r\nconst props = defineProps({\r\n src: {\r\n type: String,\r\n default: null,\r\n },\r\n preview: {\r\n type: Boolean,\r\n default: true\r\n },\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n description: {\r\n type: String,\r\n default: ''\r\n },\r\n // 是否显示标题\r\n showTitle: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 是否显示描述\r\n showDescription: {\r\n type: Boolean,\r\n default: true\r\n },\r\n // 封面宽高比\r\n aspectRatio: {\r\n type: [String, Number],\r\n default: 16/9\r\n }\r\n});\r\n\r\n// 预览状态\r\nconst showPreview = ref(false);\r\n// PDF相关状态\r\nconst loading = ref(false);\r\nconst pdfLoaded = ref(false);\r\nconst currentPage = ref(1);\r\nconst pageCount = ref(0);\r\nconst pdfContainer = ref(null);\r\n\r\n// PDF对象(实际使用时需要引入pdfjsLib)\r\nlet pdfDoc = null;\r\n\r\n// 使用计算属性处理带token的URL\r\nconst srcWithToken = computed(() => {\r\n if (!props.src) return props.src;\r\n \r\n try {\r\n // 首先尝试使用 $vtk.storage\r\n if (window.$vtk && typeof window.$vtk.storage?.get === 'function') {\r\n const token = window.$vtk.storage.get('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n // 如果 $vtk 不存在,尝试从 localStorage 获取 token\r\n else {\r\n const token = localStorage.getItem('_mis_acis_token');\r\n return token ? `${props.src}?stoken=${token}` : props.src;\r\n }\r\n } catch (error) {\r\n // 发生错误时返回原始src\r\n console.warn('VtkPdf: Failed to get token, using src without token', error);\r\n return props.src;\r\n }\r\n});\r\n\r\n// 打开预览\r\nconst openPreview = () => {\r\n if (props.preview) {\r\n showPreview.value = true;\r\n // 延迟加载PDF以确保DOM已准备好\r\n setTimeout(() => {\r\n loadPdf();\r\n }, 300);\r\n }\r\n};\r\n\r\n// 关闭预览\r\nconst closePreview = () => {\r\n showPreview.value = false;\r\n // 清理PDF对象\r\n pdfDoc = null;\r\n pdfLoaded.value = false;\r\n currentPage.value = 1;\r\n pageCount.value = 0;\r\n};\r\n\r\n// 加载PDF(示例实现,实际使用需要PDF.js库)\r\nconst loadPdf = async () => {\r\n if (!srcWithToken.value) return;\r\n \r\n loading.value = true;\r\n \r\n try {\r\n // 模拟PDF加载(实际实现需要使用PDF.js)\r\n /*\r\n // 实际使用时的代码示例:\r\n pdfjsLib.GlobalWorkerOptions.workerSrc = '//cdnjs.cloudflare.com/ajax/libs/pdf.js/2.11.338/pdf.worker.min.js';\r\n \r\n const loadingTask = pdfjsLib.getDocument(srcWithToken.value);\r\n pdfDoc = await loadingTask.promise;\r\n pageCount.value = pdfDoc.numPages;\r\n pdfLoaded.value = true;\r\n \r\n // 渲染第一页\r\n renderPage(currentPage.value);\r\n */\r\n \r\n // 模拟加载过程\r\n await new Promise(resolve => setTimeout(resolve, 1000));\r\n pageCount.value = 10; // 模拟10页PDF\r\n pdfLoaded.value = true;\r\n } catch (error) {\r\n console.error('加载PDF失败:', error);\r\n } finally {\r\n loading.value = false;\r\n }\r\n};\r\n\r\n// 渲染PDF页面(示例实现)\r\nconst renderPage = async (pageNum) => {\r\n if (!pdfDoc || !pdfContainer.value) return;\r\n \r\n try {\r\n /*\r\n // 实际使用时的代码示例:\r\n const page = await pdfDoc.getPage(pageNum);\r\n const viewport = page.getViewport({ scale: 1.5 });\r\n \r\n // 准备canvas\r\n const canvas = document.createElement('canvas');\r\n const context = canvas.getContext('2d');\r\n canvas.height = viewport.height;\r\n canvas.width = viewport.width;\r\n \r\n // 清空容器\r\n pdfContainer.value.innerHTML = '';\r\n pdfContainer.value.appendChild(canvas);\r\n \r\n // 渲染页面\r\n const renderContext = {\r\n canvasContext: context,\r\n viewport: viewport\r\n };\r\n await page.render(renderContext).promise;\r\n */\r\n } catch (error) {\r\n console.error('渲染PDF页面失败:', error);\r\n }\r\n};\r\n\r\n// 上一页\r\nconst prevPage = () => {\r\n if (currentPage.value > 1) {\r\n currentPage.value--;\r\n renderPage(currentPage.value);\r\n }\r\n};\r\n\r\n// 下一页\r\nconst nextPage = () => {\r\n if (currentPage.value < pageCount.value) {\r\n currentPage.value++;\r\n renderPage(currentPage.value);\r\n }\r\n};\r\n\r\n// 下载PDF\r\nconst downloadPdf = async () => {\r\n if (!srcWithToken.value) return;\r\n \r\n try {\r\n // 获取PDF文件的二进制数据\r\n const response = await fetch(srcWithToken.value);\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n \r\n const blob = await response.blob();\r\n const fileName = props.title && props.title.trim() !== '' \r\n ? `${props.title}.pdf` \r\n : 'document.pdf';\r\n \r\n // 创建下载链接\r\n const url = window.URL.createObjectURL(blob);\r\n const link = document.createElement('a');\r\n link.href = url;\r\n link.download = fileName;\r\n document.body.appendChild(link);\r\n link.click();\r\n \r\n // 清理\r\n document.body.removeChild(link);\r\n window.URL.revokeObjectURL(url);\r\n } catch (error) {\r\n console.error('下载PDF失败:', error);\r\n // 备用方案:在新窗口打开\r\n window.open(srcWithToken.value, '_blank');\r\n }\r\n};\r\n\r\n// 监听页码变化\r\nconst handlePageChange = (newPage) => {\r\n if (newPage >= 1 && newPage <= pageCount.value) {\r\n renderPage(newPage);\r\n }\r\n};\r\n\r\n// 监听 currentPage 变化\r\n// 在实际实现中,您需要使用 watch 监听 currentPage 变化\r\n// watch(currentPage, handlePageChange);\r\n\r\n// 组件销毁前清理\r\nonBeforeUnmount(() => {\r\n pdfDoc = null;\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-pdf-container {\r\n position: relative;\r\n display: inline-block;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.vtk-pdf-card {\r\n height: 100%;\r\n}\r\n\r\n.vtk-pdf-card--preview {\r\n cursor: pointer;\r\n transition: transform 0.2s ease-in-out;\r\n}\r\n\r\n.vtk-pdf-card--preview:hover {\r\n transform: translateY(-5px);\r\n}\r\n\r\n.vtk-pdf-cover {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n background-color: #f5f5f5;\r\n border: 1px solid #ddd;\r\n width: 100%;\r\n}\r\n\r\n.vtk-pdf-label {\r\n margin-top: 8px;\r\n font-weight: 500;\r\n color: #666;\r\n}\r\n\r\n.vtk-pdf-info {\r\n padding: 0;\r\n}\r\n\r\n.vtk-pdf-title {\r\n word-break: break-word;\r\n}\r\n\r\n.vtk-pdf-description {\r\n word-break: break-word;\r\n}\r\n\r\n/* PDF查看器样式 */\r\n.pdf-viewer-card {\r\n background-color: #e0e0e0;\r\n color: #333;\r\n}\r\n\r\n.pdf-viewer-content {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: calc(100vh - 150px);\r\n position: relative;\r\n background-color: #555;\r\n overflow: auto;\r\n}\r\n\r\n.pdf-container {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n#pdf-viewer {\r\n max-width: 100%;\r\n max-height: 100%;\r\n box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);\r\n background-color: white;\r\n /* 实际PDF内容将在此处渲染 */\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n min-height: 500px;\r\n min-width: 400px;\r\n}\r\n\r\n.pdf-viewer-footer {\r\n padding: 16px;\r\n background-color: #f5f5f5;\r\n border-top: 1px solid #ddd;\r\n}\r\n\r\n.pdf-loading {\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n background-color: rgba(255, 255, 255, 0.9);\r\n padding: 20px;\r\n border-radius: 8px;\r\n z-index: 100;\r\n}\r\n</style>","// composables/useMixins.js\r\nimport { ref, reactive } from 'vue'\r\nimport Request from '../commons/request.js'\r\nimport Message from '../components/message/index.js'\r\nimport storage from '../commons/storage.js'\r\n\r\n/**\r\n * 通用 mixins composable\r\n * @param {Object} urlConfig - URL 配置对象\r\n * @returns {Object} 包含所有状态和方法的对象\r\n */\r\nexport function useMixins(urlConfig = {}) {\r\n // 响应式数据\r\n const queryParam = reactive({})\r\n const desserts = ref([])\r\n const loading = ref(false)\r\n const superQueryParams = ref('')\r\n const page = reactive({\r\n pageno: 1,\r\n limit: 10\r\n })\r\n const pageData = ref({})\r\n const sumup = ref({})\r\n const pageDataCopy = ref([])\r\n const overlay = ref(false)\r\n const user = ref({})\r\n\r\n // URL 配置\r\n const url = reactive(urlConfig)\r\n\r\n /**\r\n * 获取查询参数\r\n * @returns {Object} 查询参数对象\r\n */\r\n const getQueryParams = () => {\r\n user.value = storage.get('_mis_acis_users')\r\n if (!queryParam.areaCode) {\r\n queryParam.areaCode = user.value?.areacode\r\n }\r\n const codex = Object.assign({}, queryParam)\r\n const params = {\r\n pageno: page.pageno,\r\n limit: page.limit,\r\n codex: codex\r\n }\r\n return params\r\n }\r\n\r\n /**\r\n * 加载页面数据\r\n */\r\n const loadPage = () => {\r\n if (!url.list) {\r\n Message.toast('请先设置url.list属性', { color: 'warning' })\r\n return\r\n }\r\n const params = getQueryParams()\r\n loading.value = true\r\n\r\n // 兼容处理 vtk 对象\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.show()\r\n }\r\n\r\n Request.postJson(url.list, params)\r\n .then((res) => {\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n\r\n if (res.meta.success || res.data) {\r\n desserts.value = res.data?.rows || []\r\n pageData.value = res.data\r\n sumup.value = res.data.sumup ? res.data.sumup : {}\r\n pageDataCopy.value = res.data\r\n }\r\n loading.value = false\r\n })\r\n .catch((error) => {\r\n console.error('加载页面数据失败:', error)\r\n loading.value = false\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n })\r\n }\r\n\r\n /**\r\n * 搜索查询\r\n */\r\n const searchQuery = () => {\r\n page.pageno = 1\r\n page.limit ??= 10\r\n loadPage()\r\n }\r\n\r\n /**\r\n * 分页变化处理\r\n * @param {Object} pageInfo - 分页信息\r\n */\r\n const getListPage = (pageInfo) => {\r\n page.pageno = pageInfo.pageno\r\n page.limit = pageInfo.limit\r\n loadPage()\r\n }\r\n\r\n /**\r\n * 删除项\r\n * @param {string|number} id - 要删除的项ID\r\n * @param {string} text - 确认提示文本\r\n */\r\n const deleteItem = (id, text) => {\r\n if (!url.delete) {\r\n Message.toast('请设置url.delete属性!', { color: 'warning' })\r\n return\r\n }\r\n\r\n Message.confirm(\r\n { title: '确认删除', text: text ? text : '是否删除?' },\r\n (result) => {\r\n if (result) {\r\n Request.getForm(url.delete, { id: id })\r\n .then((res) => {\r\n if (res.meta.success) {\r\n Message.toast('删除成功', { color: 'success' })\r\n loadPage()\r\n } else {\r\n Message.toast('删除失败', { color: 'warning' })\r\n }\r\n })\r\n .catch((error) => {\r\n console.error('删除失败:', error)\r\n Message.toast('删除失败', { color: 'warning' })\r\n })\r\n }\r\n }\r\n )\r\n }\r\n\r\n /**\r\n * 复制项\r\n * @param {string|number} id - 要复制的项ID\r\n * @param {string} text - 确认提示文本\r\n */\r\n const copyItem = (id, text) => {\r\n if (!url.copy) {\r\n Message.toast('请设置url.copy!', { color: 'warning' })\r\n return\r\n }\r\n\r\n Message.confirm(\r\n { title: '拷贝', text: text ? text : '是否确认拷贝当前数据?' },\r\n (result) => {\r\n if (result) {\r\n Request.getForm(url.copy, { id: id })\r\n .then((res) => {\r\n if (res.meta.success) {\r\n Message.toast('拷贝成功', { color: 'success' })\r\n loadPage()\r\n } else {\r\n Message.toast('拷贝失败', { color: 'warning' })\r\n }\r\n })\r\n .catch((error) => {\r\n console.error('拷贝失败:', error)\r\n Message.toast('拷贝失败', { color: 'warning' })\r\n })\r\n }\r\n }\r\n )\r\n }\r\n\r\n /**\r\n * 编辑项\r\n * @param {Object} record - 要编辑的记录\r\n * @param {Object} modalFormRef - 模态框引用\r\n */\r\n const edit = (record, modalFormRef) => {\r\n if (modalFormRef?.value) {\r\n modalFormRef.value.edit(record)\r\n }\r\n }\r\n\r\n /**\r\n * 添加新项\r\n * @param {Object} modalFormRef - 模态框引用\r\n */\r\n const add = (modalFormRef) => {\r\n if (modalFormRef?.value) {\r\n modalFormRef.value.add()\r\n }\r\n }\r\n\r\n /**\r\n * 模态框确认回调\r\n */\r\n const modalFormOk = () => {\r\n loadPage()\r\n }\r\n\r\n /**\r\n * 导出数据\r\n */\r\n const expData = () => {\r\n overlay.value = true\r\n\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.show()\r\n }\r\n\r\n const params = getQueryParams()\r\n Request.exp(url.exp, params)\r\n .then((res) => {\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n\r\n if (res) {\r\n const disposition = res.headers['content-disposition']\r\n const filename = decodeURI(\r\n disposition.substring(\r\n disposition.indexOf('filename=') + 9,\r\n disposition.length\r\n )\r\n )\r\n const blob = new Blob([res.data], {\r\n type: 'application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n })\r\n\r\n if (window.navigator.msSaveOrOpenBlob) {\r\n navigator.msSaveBlob(blob)\r\n } else {\r\n const link = document.createElement('a')\r\n link.style.display = 'none'\r\n link.href = URL.createObjectURL(blob)\r\n link.download = filename\r\n document.body.appendChild(link)\r\n link.click()\r\n document.body.removeChild(link)\r\n }\r\n }\r\n overlay.value = false\r\n })\r\n .catch((error) => {\r\n console.error('导出数据失败:', error)\r\n overlay.value = false\r\n if (window.$vtk?.message?.loading) {\r\n window.$vtk.message.loading.hide()\r\n }\r\n })\r\n }\r\n\r\n /**\r\n * 重置查询参数\r\n */\r\n const resetQueryParams = () => {\r\n Object.keys(queryParam).forEach(key => {\r\n delete queryParam[key]\r\n })\r\n }\r\n\r\n /**\r\n * 重置分页\r\n */\r\n const resetPage = () => {\r\n page.pageno = 1\r\n page.limit = 10\r\n }\r\n\r\n /**\r\n * 更新 URL 配置\r\n * @param {Object} newUrlConfig - 新的 URL 配置\r\n */\r\n const updateUrlConfig = (newUrlConfig) => {\r\n Object.assign(url, newUrlConfig)\r\n }\r\n\r\n // 返回所有状态和方法\r\n return {\r\n // 响应式数据\r\n queryParam,\r\n desserts,\r\n loading,\r\n superQueryParams,\r\n page,\r\n pageData,\r\n sumup,\r\n pageDataCopy,\r\n overlay,\r\n user,\r\n url,\r\n\r\n // 方法\r\n getQueryParams,\r\n loadPage,\r\n searchQuery,\r\n getListPage,\r\n deleteItem,\r\n copyItem,\r\n edit,\r\n add,\r\n modalFormOk,\r\n expData,\r\n resetQueryParams,\r\n resetPage,\r\n updateUrlConfig\r\n }\r\n}\r\n\r\n// 默认导出保持向后兼容\r\nexport default useMixins","<template>\r\n\t<VContainer fluid class=\"vtk-height pa-0\">\r\n\t\t<VTabs v-model=\"examType\" bg-color=\"transparent\" height=\"38\" style=\"width: 100%\">\r\n\t\t\t<VTab @click=\"examAll()\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-clipboard-arrow-up</VIcon>全部</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"list\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-star-circle</VIcon>审核</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"tip\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-hand-heart</VIcon>实施</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"tip\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-comment-minus</VIcon>评价</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VTab @click=\"tip\">\r\n\t\t\t\t<span><VIcon size=\"16\" class=\"mr-1\">mdi-credit-card-check</VIcon>支付</span>\r\n\t\t\t</VTab>\r\n\t\t\t<VSpacer />\r\n\t\t</VTabs>\r\n\t\t<VCard elevation=\"0\" style=\"min-height: calc(100% - 38px)\">\r\n\t\t\t<VCardTitle style=\"height: 88px\">\r\n\t\t\t\t<VMenu v-if=\"examType == '0' && (expShow || user.grole >= 2)\" offset-y :close-on-content-click=\"false\" location=\"bottom\">\r\n\t\t\t\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t\t\t\t<VBtn @click=\"exv\" v-bind=\"props\" class=\"bg-orange text-white mr-3\" elevation=\"0\">\r\n\t\t\t\t\t\t\t<VIcon>mdi-export-variant</VIcon> 导出\r\n\t\t\t\t\t\t</VBtn>\r\n\t\t\t\t\t</template>\r\n\t\t\t\t\t<VCard class=\"pa-3\" width=\"300\">\r\n\t\t\t\t\t\t<div>\r\n\t\t\t\t\t\t\t<p class=\"mb-2 font-weight-bold\">公共字段</p>\r\n\t\t\t\t\t\t\t<p class=\"text-caption\">\r\n\t\t\t\t\t\t\t\t服务事项\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t所属区县\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t所属镇街\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t所属社区\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t申请人证件号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t申请人姓名\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t残疾人证号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t性别\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t申请人手机号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t补助金额\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t开户银行\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t银行卡号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t收款人姓名\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t收款人证件号\r\n\t\t\t\t\t\t\t\t<span class=\"text-grey mx-1\">|</span>\r\n\t\t\t\t\t\t\t\t状态\r\n\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t<VDivider />\r\n\t\t\t\t\t\t\t<div v-if=\"queryParam.servState == '1' && projName\">\r\n\t\t\t\t\t\t\t\t<VCardTitle class=\"pa-0 text-body-1 mb-2 pt-3\">\r\n\t\t\t\t\t\t\t\t\t<VCheckbox @update:model-value=\"chkAll\" v-model=\"select\" class=\"mt-n1\" hide-details>\r\n\t\t\t\t\t\t\t\t\t\t<template v-slot:append>\r\n\t\t\t\t\t\t\t\t\t\t\t<VIcon class=\"active\" style=\"display: none\" size=\"18\">mdi-check-circle</VIcon>\r\n\t\t\t\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t\t\t</VCheckbox>\r\n\t\t\t\t\t\t\t\t\t<span class=\"font-weight-bold ml-n2\">拓展字段</span>\r\n\t\t\t\t\t\t\t\t\t<VSpacer />\r\n\t\t\t\t\t\t\t\t</VCardTitle>\r\n\t\t\t\t\t\t\t\t<p v-if=\"formArr?.length > 0\" class=\"mb-0 expBox\">\r\n\t\t\t\t\t\t\t\t\t<VCheckbox\r\n\t\t\t\t\t\t\t\t\t\tv-for=\"(item, index) in formArr\"\r\n\t\t\t\t\t\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\t\t\t\t\t\tv-model=\"expArr\"\r\n\t\t\t\t\t\t\t\t\t\t:label=\"item.label\"\r\n\t\t\t\t\t\t\t\t\t\t:value=\"{ name: item.name, valu: `${item.label}${item.valu && item.valu.includes('/') && item.valu.includes(':') ? `(${item.valu})` : ''}` }\"\r\n\t\t\t\t\t\t\t\t\t\tclass=\"mt-2\"\r\n\t\t\t\t\t\t\t\t\t\tmultiple\r\n\t\t\t\t\t\t\t\t\t\thide-details>\r\n\t\t\t\t\t\t\t\t\t\t<template v-slot:append>\r\n\t\t\t\t\t\t\t\t\t\t\t<VIcon class=\"active\" style=\"display: none\" size=\"18\">mdi-check-circle</VIcon>\r\n\t\t\t\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t\t\t</VCheckbox>\r\n\t\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t\t<p v-else class=\"text-red text-body-2 mb-2\">{{ projTip }}</p>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t<div v-else>\r\n\t\t\t\t\t\t\t\t<p class=\"mb-3 pt-3 font-weight-bold\">导出提示</p>\r\n\t\t\t\t\t\t\t\t<p :class=\"queryParam.servState == '1' ? 'text-green' : 'text-red'\" class=\"mb-3 text-body-2\">\r\n\t\t\t\t\t\t\t\t\t<VIcon size=\"20\" :color=\"queryParam.servState == '1' ? 'green' : 'red'\">{{ queryParam.servState == \"1\" ? \"mdi-progress-check\" : \"mdi-progress-close\" }}</VIcon>\r\n\t\t\t\t\t\t\t\t\t导出数据仅限已服务信息\r\n\t\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t\t<p class=\"mb-2 text-body-2\" :class=\"projName ? 'text-green' : 'text-red'\">\r\n\t\t\t\t\t\t\t\t\t<VIcon size=\"20\" :color=\"projName ? 'green' : 'red'\">{{ projName ? \"mdi-progress-check\" : \"mdi-progress-close\" }}</VIcon>\r\n\t\t\t\t\t\t\t\t\t至少选择一个服务事项导出\r\n\t\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<VBtn @click=\"exp\" :disabled=\"!(projName && queryParam.servState == '1')\" elevation=\"0\" color=\"primary\" class=\"vtk-width mt-3\" size=\"small\">确认导出</VBtn>\r\n\t\t\t\t\t</VCard>\r\n\t\t\t\t</VMenu>\r\n\t\t\t\t<VSpacer />\r\n\t\t\t\t<vtk-search v-model=\"queryParam\" @search=\"searchQuery\" placeholder=\"输入姓名/身份证查询\" :styles=\"'width:320px'\">\r\n\t\t\t\t\t<VTextField @click=\"searchProj\" v-model=\"projName\" :title=\"projName\" clearable readonly variant=\"outlined\" placeholder=\"服务事项\" density=\"compact\" hide-details class=\"my-3\"></VTextField>\r\n\t\t\t\t\t<vtk-area-tabs v-model=\"queryParam.areaCode\" :styles=\"'width:100%'\" />\r\n\t\t\t\t\t<div v-if=\"examType == 0\" style=\"width: 400px\">\r\n\t\t\t\t\t\t<vtk-select v-model=\"queryParam.servState\" @change=\"searchQuery\" placeholder=\"服务状态\" list=\"0:服务中/1:已服务\" class=\"mt-3 d-inline-block mr-3 mb-3\" style=\"width: calc(50% - 6px)\" hide-details density=\"compact\" variant=\"outlined\" clearable></vtk-select>\r\n\t\t\t\t\t\t<vtk-select v-model=\"queryParam.rateState\" @change=\"searchQuery\" placeholder=\"是否评价\" list=\"0:未评价/1:已评价\" class=\"mt-3 d-inline-block\" style=\"width: calc(50% - 6px)\" hide-details density=\"compact\" variant=\"outlined\" clearable></vtk-select>\r\n\t\t\t\t\t\t<VMenu v-model=\"menu\" :close-on-content-click=\"false\" transition=\"scale-transition\" location=\"bottom\" max-width=\"290px\" min-width=\"auto\">\r\n\t\t\t\t\t\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t\t\t\t\t\t<VTextField v-model=\"queryParam.servFtime0\" placeholder=\"开始时间\" persistent-hint append-icon=\"mdi-calendar\" class=\"d-inline-block\" style=\"width: calc(50% - 16px)\" hide-details variant=\"outlined\" density=\"compact\" v-bind=\"props\"></VTextField>\r\n\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t<VDatePicker v-model=\"queryParam.servFtime0\" title=\"\" @update:model-value=\"menu = false\" view-mode=\"month\" :max=\"queryParam.servFtime1\"></VDatePicker>\r\n\t\t\t\t\t\t</VMenu>\r\n\t\t\t\t\t\t<span class=\"mx-2\">至</span>\r\n\t\t\t\t\t\t<VMenu v-model=\"menu1\" :close-on-content-click=\"false\" transition=\"scale-transition\" location=\"bottom\" max-width=\"290px\" min-width=\"auto\">\r\n\t\t\t\t\t\t\t<template v-slot:activator=\"{ props }\">\r\n\t\t\t\t\t\t\t\t<VTextField v-model=\"queryParam.servFtime1\" placeholder=\"结束时间\" persistent-hint append-icon=\"mdi-calendar\" class=\"d-inline-block\" style=\"width: calc(50% - 15px)\" hide-details variant=\"outlined\" density=\"compact\" v-bind=\"props\"></VTextField>\r\n\t\t\t\t\t\t\t</template>\r\n\t\t\t\t\t\t\t<VDatePicker v-model=\"queryParam.servFtime1\" title=\"\" @update:model-value=\"menu1 = false\" view-mode=\"month\" :min=\"queryParam.servFtime0\"></VDatePicker>\r\n\t\t\t\t\t\t</VMenu>\r\n\t\t\t\t\t\t<vtk-select v-if=\"queryParam.servState == '1'\" @change=\"searchQuery\" v-model=\"queryParam.state\" class=\"mt-3\" placeholder=\"状态\" list=\"1:已通过/0:未通过\" hide-details density=\"compact\" variant=\"outlined\" clearable></vtk-select>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</vtk-search>\r\n\t\t\t</VCardTitle>\r\n\t\t\t<VCardText>\r\n\t\t\t\t<VDataTable :headers=\"headers\" :items=\"desserts\" :loading=\"loading\" disable-pagination loading-text=\"数据加载中...\" class=\"elevation-0\" hide-default-footer>\r\n\t\t\t\t\t<template v-slot:[`item.objsName`]=\"{ item }\">\r\n\t\t\t\t\t\t<div class=\"py-3\" @click=\"toView(item)\">\r\n\t\t\t\t\t\t\t<p class=\"vtk-cursor-pointer text-body-1 font-weight-bold mb-2\">\r\n\t\t\t\t\t\t\t\t{{ item.objsName }}<span class=\"ml-3 text-grey\">{{ formatIdCard(item.objsCode) }} </span>\r\n\t\t\t\t\t\t\t\t<VChip class=\"ml-2\" :class=\"getServStateClass(item.servState)\" size=\"small\" label>{{ getServStateText(item.servState) }} </VChip>\r\n\t\t\t\t\t\t\t\t<VChip class=\"ml-2\" :class=\"getRateStateClass(item.rateState)\" size=\"small\" label>{{ getRateStateText(item.rateState) }} </VChip>\r\n\t\t\t\t\t\t\t</p>\r\n\t\t\t\t\t\t\t<span>\r\n\t\t\t\t\t\t\t\t<VChip class=\"bg-orange-lighten-5 text-orange\" size=\"small\" label> 事项编码:{{ item.projCode }} </VChip>\r\n\t\t\t\t\t\t\t\t<VChip class=\"text-primary ml-2\" size=\"small\" label> 办件编号:{{ item.inst }} </VChip>\r\n\t\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t\t<div class=\"mb-0 mt-2 text-grey\">\r\n\t\t\t\t\t\t\t\t<div class=\"d-inline-block\" style=\"min-width: 320px\">\r\n\t\t\t\t\t\t\t\t\t服务名称:<span class=\"text-blue\">{{ item.projName }}</span>\r\n\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t\t<span>补助金额:{{ item.servAmts }}元</span>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t<VRow class=\"py-2\" style=\"color: #979797c2\">\r\n\t\t\t\t\t\t\t\t<VCol style=\"max-width: 320px\">\r\n\t\t\t\t\t\t\t\t\t<span :title=\"item.name\" class=\"d-block\" style=\"color: #979797c2\">申请途径:{{ getServFromText(item.servFrom) }}</span>\r\n\t\t\t\t\t\t\t\t</VCol>\r\n\t\t\t\t\t\t\t\t<VCol>\r\n\t\t\t\t\t\t\t\t\t<span :title=\"item.name\" class=\"d-block\" style=\"color: #979797c2\">申请时间:{{ formatDate(item.servCtime) }}</span>\r\n\t\t\t\t\t\t\t\t</VCol>\r\n\t\t\t\t\t\t\t</VRow>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</template>\r\n\t\t\t\t\t<template v-slot:[`item.actions`]=\"{ item }\">\r\n\t\t\t\t\t\t<a v-if=\"item.state != 0 && user.areacode?.length == 6 && item.servState == '1'\" @click=\"del(item)\" class=\"text-error\" text>作废</a>\r\n\t\t\t\t\t\t<div v-if=\"item.state == 0\" class=\"state_btg text-right\"></div>\r\n\t\t\t\t\t</template>\r\n\t\t\t\t\t<template v-slot:no-data>\r\n\t\t\t\t\t\t<vtk-empty />\r\n\t\t\t\t\t</template>\r\n\t\t\t\t</VDataTable>\r\n\t\t\t\t<vtk-page :page-sizes=\"[10, 20]\" :page-data=\"pageData\" @pageChange=\"getListPage\" />\r\n\t\t\t</VCardText>\r\n\t\t</VCard>\r\n\t\t<!-- 服务事项 -->\r\n\t\t<vtk-proj ref=\"MprojRef\" @toPage=\"toPage\" />\r\n\t\t<!-- 删除服务 -->\r\n\t\t<VDialog v-model=\"dialog\" persistent max-width=\"500\">\r\n\t\t\t<VCard>\r\n\t\t\t\t<VCardTitle>作废</VCardTitle>\r\n\t\t\t\t<VCardText class=\"pb-0\">\r\n\t\t\t\t\t服务作废后将无法恢复,请谨慎操作!!!\r\n\t\t\t\t\t<VTextarea v-model=\"delNote\" variant=\"outlined\" label=\"请填写作废原因\" class=\"mt-3\" hide-details density=\"compact\"></VTextarea>\r\n\t\t\t\t</VCardText>\r\n\t\t\t\t<VCardActions>\r\n\t\t\t\t\t<VSpacer />\r\n\t\t\t\t\t<VBtn @click=\"dialog = false\" variant=\"text\">取消</VBtn>\r\n\t\t\t\t\t<VBtn @click=\"delSave(true)\" variant=\"text\">确定</VBtn>\r\n\t\t\t\t</VCardActions>\r\n\t\t\t</VCard>\r\n\t\t</VDialog>\r\n\t</VContainer>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, watch, onActivated } from 'vue';\r\nimport { useMixins } from '../../composables/useMixins'\r\nimport Request from '../../commons/request';\r\n\r\n// 定义组件选项\r\ndefineOptions({\r\n\tname: 'VtkProj',\r\n\tinheritAttrs: false,\r\n});\r\n\r\n// 表单列表 URL 配置\r\nconst urlConfig = {\r\n\tlist: '/kudas/xfwez/page',\r\n\texp: '/kudas/xfwez/exp',\r\n\tdelete: '/kudas/xfwez/delete'\r\n};\r\n\r\n// 使用 mixins composable\r\nconst {\r\n\tpageData,\r\n\tgetListPage,\r\n\tloadPage,\r\n\texpData,\r\n\tdesserts,\r\n\tloading,\r\n\tqueryParam: mixinQueryParam,\r\n\turl\r\n} = useMixins(urlConfig);\r\n\r\n// 合并 queryParam\r\nObject.assign(mixinQueryParam, {});\r\nconst queryParam = mixinQueryParam;\r\n\r\n// 响应式数据\r\nconst user = ref({});\r\nconst examType = ref(1);\r\n\r\nconst headers = ref([\r\n\t{ title: '事项', key: 'objsName', sortable: false },\r\n\t{ title: '状态', key: 'actions', sortable: false, align: 'end' },\r\n]);\r\n\r\n// 主题筛选\r\nconst permits = ref([]);\r\nconst projName = ref('');\r\nconst projTip = ref('');\r\nconst bizType = ref('');\r\nconst expShow = ref(false);\r\nconst menu = ref(false);\r\nconst menu1 = ref(false);\r\n\r\n// 导出\r\nconst expArr = ref([]);\r\nconst formArr = ref([]);\r\nconst select = ref(false);\r\nconst selectAll = ref([]);\r\n\r\n// 删除\r\nconst dialog = ref(false);\r\nconst delItem = ref({});\r\nconst delNote = ref('');\r\n\r\n// ref\r\nconst MprojRef = ref(null);\r\n\r\n// 监听器\r\nwatch(expArr, (newVal) => {\r\n\tif (newVal.length < selectAll.value.length) {\r\n\t\tselect.value = false;\r\n\t}\r\n}, { deep: true });\r\n\r\n// 生命周期\r\nonActivated(() => {\r\n\talert('onActivated');\r\n\tlist();\r\n\t// 监听接收消息,刷新页面\r\n\twindow.addEventListener('storage', (event) => {\r\n\t\tif (JSON.parse(event?.newValue)?.fwez) {\r\n\t\t\texamType.value == '0' ? examAll() : loadPage();\r\n\t\t}\r\n\t});\r\n});\r\n\r\n// 方法\r\n// 全选\r\nconst chkAll = (e) => {\r\n\texpArr.value = e ? selectAll.value : [];\r\n};\r\n\r\nconst list = () => {\r\n\tbizType.value = '';\r\n\texpShow.value = false;\r\n\tuser.value = getUserInfo();\r\n\tpermits.value = [];\r\n\tuser.value.permits?.forEach((e) => {\r\n\t\tif (e.permNkey.includes('biz_type')) {\r\n\t\t\tpermits.value.push(e);\r\n\t\t\tbizType.value = bizType.value + e.permNkey.slice(9) + ',';\r\n\t\t} else if (e.permNkey == 'btn_expo') {\r\n\t\t\texpShow.value = true;\r\n\t\t}\r\n\t});\r\n\tqueryParam.bizType = bizType.value;\r\n\texamWait();\r\n};\r\n\r\n// 获取用户信息\r\nconst getUserInfo = () => {\r\n\ttry {\r\n\t\t// 实际项目中从存储或状态管理获取\r\n\t\treturn window.$vtk?.storage?.get('_mis_acis_users') || {};\r\n\t} catch (error) {\r\n\t\tconsole.warn('获取用户信息失败:', error);\r\n\t\treturn {};\r\n\t}\r\n};\r\n\r\n// 待审\r\nconst examWait = () => {\r\n\texamType.value = 1;\r\n\tqueryParam.operateLeve = user.value.areacode?.length;\r\n\tqueryParam.servState = '0';\r\n\tloadPage();\r\n};\r\n\r\n// 全部审核\r\nconst examAll = () => {\r\n\texamType.value = 0;\r\n\tdelete queryParam.operateLeve;\r\n\tdelete queryParam.servState;\r\n\tloadPage();\r\n};\r\n\r\n// 审核\r\nconst toView = (item) => {\r\n\tconst url = item.servState == 1\r\n\t\t? `#/mino/suse/view/${item.inst}?ddtab=true`\r\n\t\t: `#/mino/suse/exam/${item.inst}?ddtab=true`;\r\n\twindow.open(url);\r\n};\r\n\r\n// 服务事项查询/筛选\r\nconst searchProj = () => {\r\n\tMprojRef.value?.add(queryParam.projCode);\r\n};\r\n\r\nconst toPage = (param) => {\r\n\tprojName.value = param.projName;\r\n\tqueryParam.projCode = param.projCode;\r\n\tdelete queryParam.bizType;\r\n\tsearchQuery();\r\n};\r\n\r\nconst searchQuery = () => {\r\n\t// 搜索查询逻辑\r\n\tloadPage();\r\n};\r\n\r\n// 导出相关\r\nconst exv = () => {\r\n\tif (projName.value && queryParam.servState == '1') {\r\n\t\texpArr.value = [];\r\n\t\tformArr.value = [];\r\n\t\t// 显示加载状态\r\n\t\tRequest.postJson('/kudas/xfwez/exv', { codex: queryParam }).then((res) => {\r\n\t\t\tif (res.meta.success) {\r\n\t\t\t\tJSON.parse(res.data.formJson).forEach((item) => {\r\n\t\t\t\t\tif (['text', 'radio', 'number', 'time', 'checkbox', 'textarea', 'select'].includes(item.type)) {\r\n\t\t\t\t\t\titem.value = {\r\n\t\t\t\t\t\t\tname: item.name,\r\n\t\t\t\t\t\t\tvalu: `${item.label}${item.valu && item.valu.includes('/') && item.valu.includes(':') ? `(${item.valu})` : ''}`\r\n\t\t\t\t\t\t};\r\n\t\t\t\t\t\tformArr.value.push(item);\r\n\t\t\t\t\t\tselectAll.value.push(item.value);\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t} else {\r\n\t\t\t\tprojTip.value = res.meta.message;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n};\r\n\r\nconst exp = () => {\r\n\tqueryParam.fields = expArr.value;\r\n\texpData();\r\n};\r\n\r\n// 服务作废\r\nconst del = (item) => {\r\n\tdialog.value = true;\r\n\tdelItem.value = item;\r\n\tdelNote.value = '';\r\n};\r\n\r\nconst delSave = () => {\r\n\tif (delNote.value) {\r\n\t\tRequest.postForm(url.delete, { id: delItem.value.id, note: delNote.value }).then((res) => {\r\n\t\t\tif (res.meta.success) {\r\n\t\t\t\t// 显示成功消息\r\n\t\t\t\tdialog.value = false;\r\n\t\t\t\tloadPage();\r\n\t\t\t} else {\r\n\t\t\t\t// 显示失败消息\r\n\t\t\t}\r\n\t\t});\r\n\t} else {\r\n\t\t// 显示错误消息\r\n\t}\r\n};\r\n\r\n// 提示\r\nconst tip = () => {\r\n\t// 显示应用开发中的消息\r\n};\r\n\r\n// 工具函数\r\nconst formatIdCard = (idcard) => {\r\n\tif (!idcard) return '';\r\n\treturn idcard.replace(/^(.{6})(?:\\d+)(.{4})$/, '$1********$2');\r\n};\r\n\r\nconst formatDate = (dateStr) => {\r\n\tif (!dateStr) return '';\r\n\tconst date = new Date(dateStr);\r\n\treturn `${date.getFullYear()}年${String(date.getMonth() + 1).padStart(2, '0')}月${String(date.getDate()).padStart(2, '0')}日 ${String(date.getHours()).padStart(2, '0')}:${String(date.getMinutes()).padStart(2, '0')}:${String(date.getSeconds()).padStart(2, '0')}`;\r\n};\r\n\r\nconst getServStateClass = (state) => {\r\n\treturn state == '0' ? 'bg-blue-lighten-5 text-blue' : 'bg-green-lighten-5 text-green';\r\n};\r\n\r\nconst getServStateText = (state) => {\r\n\treturn state == '0' ? '服务中' : '已服务';\r\n};\r\n\r\nconst getRateStateClass = (state) => {\r\n\treturn state == '0' ? 'bg-orange-lighten-5 text-orange' : 'bg-blue-lighten-5 text-blue';\r\n};\r\n\r\nconst getRateStateText = (state) => {\r\n\treturn state == '0' ? '未评价' : '已评价';\r\n};\r\n\r\nconst getServFromText = (from) => {\r\n\tconst fromMap = {\r\n\t\t'100': '特殊渠道',\r\n\t\t'101': '移动端代办',\r\n\t\t'102': '窗口端通办',\r\n\t\t'200': '特殊渠道',\r\n\t\t'210': '浙里办App',\r\n\t\t'211': '浙里办微信小程序',\r\n\t\t'212': '浙里办支付宝小程序',\r\n\t\t'230': '微信小程序',\r\n\t\t'240': '支付宝小程序',\r\n\t\t'250': '自助机',\r\n\t\t'300': '特殊渠道',\r\n\t\t'310': '服务外包代办'\r\n\t};\r\n\treturn fromMap[from] || from;\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.state_btg {\r\n\tpadding-right: 0;\r\n\theight: 100%;\r\n\tbackground: url(../../assets/img/objs_btg.png) no-repeat;\r\n\tbackground-size: 80px;\r\n\tbackground-position: 100% 100%;\r\n}\r\n\r\n:deep(.v-tab) {\r\n\tbackground: url(../../assets/img/tab-2.png) no-repeat;\r\n\tbackground-size: 100% 100%;\r\n\twidth: 150px;\r\n\tmargin-left: -11px;\r\n\tborder-top-left-radius: 20px;\r\n\tborder-top-right-radius: 20px;\r\n\tspan {\r\n\t\tz-index: 99;\r\n\t}\r\n}\r\n\r\n/* Dark theme */\r\n.v-theme--dark {\r\n\t:deep(.v-tab) {\r\n\t\tbackground: url(../../assets/img/tab-4.png) no-repeat;\r\n\t\tbackground-size: 100% 100%;\r\n\t}\r\n\r\n\t:deep(.v-tabs__slider) {\r\n\t\tbackground: url(../../assets/img/tab-3.png) no-repeat !important;\r\n\t\tbackground-size: 100% 100% !important;\r\n\t}\r\n}\r\n\r\n:deep(.v-tab::before),\r\n:deep(.v-tab:focus::before),\r\n:deep(.v-tab:hover::before) {\r\n\tbackground-color: transparent !important;\r\n\topacity: 0 !important;\r\n}\r\n\r\n:deep(.v-tabs__slider) {\r\n\theight: 38px !important;\r\n\tbackground: url(../../assets/img/tab-1.png) no-repeat;\r\n\tbackground-size: 100% 100%;\r\n}\r\n\r\n.expBox {\r\n\t:deep(td) {\r\n\t\tborder-bottom: thin solid rgba(123, 123, 123, 0.22);\r\n\t}\r\n\r\n\t:deep(.v-data-table__empty-wrapper td) {\r\n\t\tborder: none;\r\n\t}\r\n\r\n\t:deep(.v-checkbox.v-selection-control--dirty) {\r\n\t\tbackground-color: rgba(33, 149, 243, 0.06) !important;\r\n\r\n\t\t.v-label {\r\n\t\t\tcolor: rgb(33, 150, 243) !important;\r\n\t\t}\r\n\r\n\t\t.active {\r\n\t\t\tcolor: rgb(33, 150, 243);\r\n\t\t\tdisplay: inline-block !important;\r\n\t\t}\r\n\t}\r\n\r\n\t:deep(.v-selection-control__input) {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t:deep(.v-checkbox) {\r\n\t\tpadding: 4px 8px 4px 10px;\r\n\t\tborder-radius: 6px;\r\n\t\tbackground-color: rgba(117, 117, 117, 0.06);\r\n\r\n\t\t.v-label {\r\n\t\t\tmargin-top: 3px;\r\n\t\t\tfont-size: 12px;\r\n\t\t}\r\n\t}\r\n}\r\n</style>\r\n","<template>\r\n <VRadioGroup v-bind=\"attrs\" :modelValue=\"modelValue\" @update:modelValue=\"onUpdate\">\r\n <VRadio\r\n v-for=\"item in items\"\r\n :key=\"item.id || item.code\"\r\n :label=\"item.codeValue\"\r\n :value=\"item.code\"\r\n />\r\n </VRadioGroup>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, useAttrs } from 'vue';\r\nimport Request from '../../commons/request';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n name: \"VtkRadio\",\r\n inheritAttrs: false,\r\n});\r\n// 定义 props\r\nconst props = defineProps({\r\n /**\r\n * 字典来源:\r\n * - 静态数据,如:\"0:否/1:是\"\r\n * - 字典键名,如:\"DISABLE_TYPE\"\r\n */\r\n list: {\r\n type: String,\r\n required: true,\r\n },\r\n modelValue: {\r\n type: [String, Number],\r\n default: null,\r\n },\r\n});\r\n\r\n// 定义 emit 事件\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 获取透传属性(替代 $attrs)\r\nconst attrs = useAttrs();\r\n\r\n// 响应式数据\r\nconst items = ref([]);\r\n\r\n// 处理静态数据\r\nconst statc = () => {\r\n props.list.split('/').forEach(it => {\r\n const [code, codeValue] = it.split(':');\r\n items.value.push({ code, codeValue });\r\n });\r\n};\r\n\r\n// 请求远程字典\r\nconst miscs = async () => {\r\n try {\r\n const res = await Request.getForm(`dict/misc/list/${props.list}`);\r\n items.value = res.data || [];\r\n } catch (error) {\r\n console.error('[VtkRadio] Failed to load dictionary:', error);\r\n items.value = [];\r\n }\r\n};\r\n\r\n// 更新 v-model 值\r\nconst onUpdate = (val) => {\r\n emit('update:modelValue', val);\r\n};\r\n\r\n// 初始化数据\r\nonMounted(() => {\r\n if (props.list.includes(':')) {\r\n statc();\r\n } else {\r\n miscs();\r\n }\r\n});\r\n</script>\r\n\r\n<style scoped>\r\n</style>","<template>\r\n <div class=\"search\">\r\n <VMenu\r\n v-model=\"menu\"\r\n @update:model-value=\"obtain\"\r\n location=\"bottom end\"\r\n origin=\"top end\"\r\n offset=\"12\"\r\n :close-on-content-click=\"false\"\r\n >\r\n <template v-slot:activator=\"{ props }\">\r\n <VTextField\r\n v-model=\"queryParam.condition\"\r\n :placeholder=\"$attrs.placeholder || '请输入查询内容'\"\r\n :style=\"$attrs.styles\"\r\n class=\"box\"\r\n density=\"compact\"\r\n variant=\"outlined\"\r\n hide-details\r\n @click:append=\"search\"\r\n @keyup.enter=\"search\"\r\n @click:clear=\"(queryParam.condition = ''), search()\"\r\n clearable\r\n >\r\n <template v-slot:append-inner>\r\n <VBadge\r\n dot\r\n :content=\"initialIndex\"\r\n :model-value=\"initialIndex > 0\"\r\n color=\"error\"\r\n class=\"advanced-badge\"\r\n >\r\n <span\r\n v-bind=\"props\"\r\n class=\"text-blue vtk-cursor-pointer d-inline-flex align-center text-body-2\"\r\n >\r\n 高级\r\n </span>\r\n </VBadge>\r\n </template>\r\n </VTextField>\r\n </template>\r\n\r\n <VCard class=\"search-panel\">\r\n <VCardTitle class=\"pr-3 d-flex justify-space-between align-center pb-5\">\r\n <span>高级搜索</span>\r\n <VBtn class=\"mx-0\" variant=\"text\" icon @click=\"close\" size=\"small\">\r\n <VIcon>mdi-close</VIcon>\r\n </VBtn>\r\n </VCardTitle>\r\n\r\n <VCardText class=\"search-panel__body\">\r\n <div class=\"search-panel__content\" :style=\"contentStyle\">\r\n <slot :query-param=\"queryParam\"></slot>\r\n </div>\r\n </VCardText>\r\n\r\n <VCardActions class=\"pt-0 px-4 pb-3\">\r\n <slot name=\"actions\"></slot>\r\n <VSpacer />\r\n <VBtn @click=\"search\" variant=\"flat\" color=\"primary\">\r\n <VIcon class=\"mr-1\">mdi-magnify</VIcon>搜索\r\n </VBtn>\r\n <VBtn @click=\"handleResetClick\" variant=\"flat\" color=\"error\">\r\n <VIcon class=\"mr-1\">mdi-sync</VIcon>重置\r\n </VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VMenu>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed, getCurrentInstance, onMounted, ref, watch } from 'vue';\r\n\r\ndefineOptions({\r\n name: \"VtkSearch\"\r\n});\r\n\r\nconst props = defineProps({\r\n value: {\r\n type: Object,\r\n default: () => ({})\r\n },\r\n contentMinHeight: {\r\n type: [Number, String],\r\n default: 0\r\n },\r\n contentMaxHeight: {\r\n type: [Number, String],\r\n default: 360\r\n }\r\n});\r\n\r\nconst emit = defineEmits(['update:value', 'search', 'reset']);\r\nconst instance = getCurrentInstance();\n\nconst user = ref({});\nconst menu = ref(false);\n\nconst cloneValue = (val) => {\n if (Array.isArray(val)) return [...val];\n if (val && typeof val === 'object') return { ...val };\n return val;\n};\n\nconst cloneQueryParam = (source = {}) => {\n return Object.fromEntries(Object.entries(source || {}).map(([key, val]) => [key, cloneValue(val)]));\n};\n\nconst isSameValue = (a, b) => {\n if (\n Array.isArray(a) ||\n Array.isArray(b) ||\n (a && typeof a === 'object') ||\n (b && typeof b === 'object')\n ) {\n return JSON.stringify(a) === JSON.stringify(b);\n }\n\n return a === b;\n};\n\nconst queryParam = ref(cloneQueryParam(props.value));\nconst initialQueryParam = ref(cloneQueryParam(props.value));\nconst externalQueryParam = ref(cloneQueryParam(props.value));\n\nconst initialIndex = computed(() => {\n return Object.entries(queryParam.value).filter(([key, val]) => {\n if (key === 'condition') return false;\n const initVal = initialQueryParam.value[key];\n return !isSameValue(val, initVal);\n }).length;\n});\n\r\nconst contentStyle = computed(() => {\r\n const minValue = props.contentMinHeight;\r\n const maxValue = props.contentMaxHeight;\r\n const minHeight = typeof minValue === 'number' ? `${minValue}px` : minValue;\r\n const maxHeight = typeof maxValue === 'number' ? `${maxValue}px` : maxValue;\r\n\r\n return {\r\n ...(minValue ? { minHeight } : {}),\r\n maxHeight,\r\n };\r\n});\r\n\r\nwatch(\n () => props.value,\n (newVal = {}) => {\n const nextExternalQueryParam = cloneQueryParam(newVal);\n const nextQueryParam = { ...queryParam.value };\n\n Object.entries(nextExternalQueryParam).forEach(([key, val]) => {\n if (!isSameValue(val, externalQueryParam.value[key])) {\n nextQueryParam[key] = cloneValue(val);\n }\n });\n\n Object.keys(externalQueryParam.value).forEach((key) => {\n if (!(key in nextExternalQueryParam)) {\n delete nextQueryParam[key];\n }\n });\n\n queryParam.value = nextQueryParam;\n externalQueryParam.value = nextExternalQueryParam;\n },\n { deep: true }\n);\n\r\nonMounted(() => {\r\n user.value = JSON.parse(localStorage.getItem(\"_mis_acis_users\") || \"{}\");\r\n});\r\n\r\nconst obtain = () => {};\r\n\r\nconst close = () => {\r\n menu.value = false;\r\n obtain();\r\n};\r\n\r\nconst filterNull = (obj) => {\r\n return Object.fromEntries(Object.entries(obj).filter(([, v]) => v !== null && v !== undefined));\r\n};\r\n\r\nconst search = () => {\r\n close();\r\n emit('update:value', filterNull(queryParam.value));\r\n emit(\"search\");\r\n};\r\n\r\nconst reset = () => {\r\n queryParam.value = {\r\n ...initialQueryParam.value,\r\n condition: ''\r\n };\r\n emit('update:value', filterNull(queryParam.value));\r\n emit(\"search\");\r\n menu.value = false;\r\n};\r\n\r\nconst handleResetClick = () => {\r\n const hasParentResetHandler = Boolean(instance?.vnode.props?.onReset);\r\n\r\n if (hasParentResetHandler) {\r\n emit('reset', { ...queryParam.value });\r\n return;\r\n }\r\n\r\n reset();\r\n};\r\n\r\ndefineExpose({ search, reset });\r\n\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.search {\r\n position: relative;\r\n min-width: 380px;\r\n min-height: 40px;\r\n}\r\n\r\n.box {\r\n min-width: 380px;\r\n min-height: 40px;\r\n}\r\n\r\n.search-panel {\r\n width: 380px;\r\n margin-right: -16px;\r\n overflow: visible;\r\n}\r\n\r\n.search-panel__body {\r\n overflow: visible;\r\n}\r\n\r\n.search-panel__content {\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n scrollbar-gutter: stable;\r\n scrollbar-color: rgb(var(--v-theme-primary)) transparent;\r\n scrollbar-width: thin;\r\n}\r\n\r\n\r\n.search-panel__content::-webkit-scrollbar-track {\r\n background: transparent;\r\n}\r\n\r\n.search-panel__content::-webkit-scrollbar-thumb {\r\n background: rgb(var(--v-theme-primary));\r\n}\r\n\r\n:deep(.box .v-field__append-inner) {\r\n cursor: pointer;\r\n padding-left: 16px !important;\r\n padding-right: 4px !important;\r\n border-left: 1px #cccccc88 solid;\r\n min-width: 50px;\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n:deep(.advanced-badge .v-badge__badge) {\r\n transform: translate(10px, -2px);\r\n}\r\n</style>\r\n","<template>\r\n <VSelect \r\n v-bind=\"filteredAttrs\" \r\n :items=\"items\" \r\n item-title=\"codeValue\" \r\n item-value=\"code\" \r\n :multiple=\"multi\"\r\n :menu-props=\"{ offsetY: true }\" \r\n @update:model-value=\"$emit('update:modelValue', $event)\"\r\n />\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, onMounted, useAttrs, computed } from 'vue'\r\nimport Request from \"../../commons/request\";\r\n\r\n// 定义组件名称和选项\r\ndefineOptions({\r\n name: \"VtkSelect\",\r\n inheritAttrs: false\r\n});\r\n\r\n// 定义 props\r\nconst props = defineProps({\r\n // 数据库字段名字(DISABLE_TYPE) 或 静态的字段(0:否/1:是)\r\n list: {\r\n type: String,\r\n default: null,\r\n },\r\n multi: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n});\r\n\r\n// 定义 emits\r\nconst emit = defineEmits(['update:modelValue']);\r\n\r\n// 获取所有传递的属性\r\nconst attrs = useAttrs();\r\n\r\n// 过滤属性,排除组件内部使用的属性\r\nconst filteredAttrs = computed(() => {\r\n const { list, multi, ...rest } = attrs;\r\n return rest;\r\n});\r\n\r\n// 响应式数据\r\nconst items = ref([]);\r\n\r\n// 方法定义\r\nconst miscs = () => {\r\n Request.getForm(`dict/misc/list/${props.list}`).then((res) => {\r\n items.value = res.data;\r\n });\r\n};\r\n\r\nconst statc = () => {\r\n if (!props.list) return;\r\n \r\n props.list.split(\"/\").forEach((it) => {\r\n const its = it.split(\":\");\r\n items.value.push({ code: its[0], codeValue: its[1] });\r\n });\r\n};\r\n\r\n// 生命周期钩子\r\nonMounted(() => {\r\n if (props.list) {\r\n if (props.list.includes(\":\")) {\r\n statc();\r\n } else {\r\n miscs();\r\n }\r\n }\r\n});\r\n\r\n// 使用方式\r\n// <vtk-select\r\n// v-model=\"value\"\r\n// list=\"YOUR_LIST\"\r\n// variant=\"outlined\" <!-- 样式变体 -->\r\n// density=\"compact\" <!-- 密度 'default' | 'comfortable' | 'compact' -->\r\n// clearable <!-- 可清除 -->\r\n// placeholder=\"请选择\" <!-- 占位符 -->\r\n// :rules=\"rules\" <!-- 验证规则 -->\r\n// disabled <!-- 禁用状态 -->\r\n// readonly <!-- 只读状态 -->\r\n// hide-details <!-- 隐藏详情信息 -->\r\n// />\r\n\r\n</script>\r\n\r\n<style scoped>\r\n::-webkit-scrollbar {\r\n width: 6px;\r\n}\r\n\r\n::-webkit-scrollbar-thumb {\r\n border-radius: 3px;\r\n height: 100px;\r\n background-color: #007acc;\r\n}\r\n</style>","<template>\r\n\t<VStepper class=\"elevation-0\" v-model=\"stepIndex\">\r\n\t\t<VStepperHeader class=\"elevation-0\" style=\"overflow: hidden;\">\r\n\t\t\t<VRow class=\"stepList\">\r\n\t\t\t\t<VCol class=\"pl-0 colItem\" v-for=\"(item, index) in step\" :key=\"index\" style=\"\">\r\n\t\t\t\t\t<div class=\"first-box1 last-box pl-10 py-5 stepItem\" :class=\"stepIndex > index? 'selected' : ''\"\r\n\t\t\t\t\t\t:complete=\"stepIndex > index\" :step=\"index + 1\">\r\n\t\t\t\t\t\t{{ item }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</VCol>\r\n\t\t\t</VRow>\r\n\t\t</VStepperHeader>\r\n\r\n\t\t<VStepperWindow>\r\n\t\t\t<VStepperWindowItem v-for=\"(item, index) in list\" :key=\"index\" :value=\"index + 1\">\r\n\t\t\t\t<slot :name=\"index + 1\"></slot>\r\n\t\t\t</VStepperWindowItem>\r\n\t\t\t<slot></slot>\r\n\t\t</VStepperWindow>\r\n\t</VStepper>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, watch, onMounted } from 'vue';\r\n\r\n// 定义组件名称\r\ndefineOptions({\r\n\tname: \"VtkStepper\",\r\n\tinheritAttrs: false,\r\n});\r\n\r\n// 定义props\r\nconst props = defineProps({\r\n\tlist: {\r\n\t\ttype: String,\r\n\t\tdefault: null,\r\n\t},\r\n\tel: {\r\n\t\ttype: Number,\r\n\t\tdefault: 1,\r\n\t},\r\n});\r\n\r\n// 响应式数据\r\nconst stepIndex = ref(props.el);\r\nconst step = ref([]);\r\n\r\n// 监听el属性变化\r\nwatch(() => props.el, (val) => {\r\n\tstepIndex.value = val;\r\n});\r\n\r\n// 处理内容\r\nconst content = () => {\r\n\tif (props.list) {\r\n\t\tstep.value = props.list.split(\",\");\r\n\t}\r\n};\r\n\r\n// 组件挂载时执行\r\nonMounted(() => {\r\n\tcontent();\r\n});\r\n\r\n// 监听list变化\r\nwatch(() => props.list, () => {\r\n\tcontent();\r\n});\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n// 颜色变量定义\r\n$color-background: #c7ccd538;\r\n$color-selected: #165dff;\r\n$color-white: #fff;\r\n$color-light-bg: #f2f3f5;\r\n$color-dark-bg: #1e1e1e;\r\n\r\n.v-stepper__step {\r\n\tbackground: $color-background;\r\n\tposition: relative;\r\n}\r\n\r\n// 隐藏步骤数字\r\n:deep(.v-stepper__step__step) {\r\n\tdisplay: none !important;\r\n}\r\n\r\n.stepItem {\r\n\talign-items: center;\r\n\tdisplay: flex;\r\n\tflex-direction: row;\r\n\tpadding: 24px;\r\n\tposition: relative;\r\n\tbackground: $color-background;\r\n\r\n\t// 暗色主题样式\r\n\t.v-theme--dark & {\r\n\t\tcolor: rgba(255, 255, 255, 0.5);\r\n\t}\r\n\r\n\t// 选中状态\r\n\t&.selected {\r\n\t\tbackground: $color-selected;\r\n\t\tcolor: $color-white !important;\r\n\r\n\t\t&.last-box::after {\r\n\t\t\tborder-color: transparent transparent transparent $color-selected;\r\n\t\t}\r\n\r\n\t\t:deep(.v-stepper__label) {\r\n\t\t\tcolor: $color-white !important;\r\n\t\t}\r\n\t}\r\n}\r\n\r\n.colItem {\r\n\t&:first-child .first-box1::before {\r\n\t\tborder-color: transparent !important;\r\n\t}\r\n\r\n\t&:last-child .last-box::after {\r\n\t\tborder-color: transparent !important;\r\n\t}\r\n}\r\n\r\n.first-box1::before {\r\n\tposition: absolute;\r\n\tleft: 0;\r\n\tcontent: \"\";\r\n\twidth: 0;\r\n\theight: 0;\r\n\tz-index: 0;\r\n\tborder: 30px solid;\r\n\tborder-color: transparent transparent transparent $color-white;\r\n\r\n\t.v-theme--dark & {\r\n\t\tborder-color: transparent transparent transparent $color-dark-bg;\r\n\t}\r\n}\r\n\r\n.last-box::after {\r\n\tposition: absolute;\r\n\tright: -69px;\r\n\tcontent: \"\";\r\n\tz-index: 1;\r\n\twidth: 0;\r\n\theight: 0;\r\n\tborder: 35px solid;\r\n\tborder-color: transparent transparent transparent $color-light-bg;\r\n\r\n\t.v-theme--dark & {\r\n\t\tborder-color: transparent transparent transparent $color-background;\r\n\t}\r\n}\r\n\r\n.theme--dark.v-stepper {\r\n\tbackground: transparent;\r\n}\r\n</style>","<template>\r\n <div class=\"vtk-upload\">\r\n <!-- 拖拽 / 点击上传区域 -->\r\n <div\r\n v-if=\"listType !== 'picture-card' && !detail\"\n :class=\"['vtk-upload__dragger', { 'is-dragover': isDragover, 'is-disabled': disabled }]\"\n title=\"点击上传\"\n @click=\"!disabled && triggerInput()\"\n @dragover.prevent=\"onDragover\"\r\n @dragleave.prevent=\"isDragover = false\"\r\n @drop.prevent=\"onDrop\"\r\n >\r\n <slot>\r\n <div class=\"vtk-upload__dragger-inner\">\r\n <VIcon size=\"40\" color=\"grey-lighten-1\">mdi-cloud-upload-outline</VIcon>\r\n <div class=\"text-body-2 mt-2 text-grey\">将文件拖到此处,或 <span class=\"text-primary\" style=\"cursor:pointer\">点击上传</span></div>\r\n <div v-if=\"tip\" class=\"text-caption text-grey-lighten-1 mt-1\">{{ tip }}</div>\r\n </div>\r\n </slot>\r\n </div>\r\n\r\n <!-- picture-card 模式 -->\r\n <div v-if=\"listType === 'picture-card'\" class=\"vtk-upload__picture-card-wrap\">\r\n <div\r\n v-for=\"file in fileList\"\r\n :key=\"file.uid\"\r\n class=\"vtk-upload__picture-card-item\"\r\n >\r\n <v-img :src=\"file.url || file.preview\" cover class=\"fill-height\" />\r\n <div class=\"vtk-upload__picture-card-mask\">\r\n <VBtn icon size=\"x-small\" variant=\"text\" color=\"white\" title=\"查看\" @click.stop=\"handlePreview(file)\">\n <VIcon>mdi-eye</VIcon>\n </VBtn>\n <VBtn v-if=\"!disabled && !detail\" icon size=\"x-small\" variant=\"text\" color=\"white\" title=\"删除\" @click.stop=\"handleRemove(file)\">\n <VIcon>mdi-delete</VIcon>\n </VBtn>\n </div>\r\n <!-- 上传进度 -->\r\n <div v-if=\"file.status === 'uploading'\" class=\"vtk-upload__picture-card-progress\">\r\n <v-progress-circular :model-value=\"file.percentage\" size=\"36\" color=\"white\" />\r\n </div>\r\n </div>\r\n\r\n <!-- 添加按钮 -->\r\n <div\r\n v-if=\"!disabled && !detail && (limit === 0 || fileList.length < limit)\"\n :class=\"['vtk-upload__picture-card-add', { 'is-dragover': isDragover }]\"\n title=\"添加文件\"\n @click=\"triggerInput()\"\n @dragover.prevent=\"onDragover\"\r\n @dragleave.prevent=\"isDragover = false\"\r\n @drop.prevent=\"onDrop\"\r\n >\r\n <VIcon size=\"28\" color=\"grey-lighten-1\">mdi-plus</VIcon>\r\n </div>\r\n </div>\r\n\r\n <!-- 隐藏的 input -->\r\n <input\r\n ref=\"inputRef\"\r\n type=\"file\"\r\n class=\"vtk-upload__input\"\r\n :accept=\"accept\"\r\n :multiple=\"multiple\"\r\n @change=\"onInputChange\"\r\n />\r\n\r\n <!-- 文件列表 (非 picture-card) -->\r\n <div v-if=\"showFileList && listType !== 'picture-card' && fileList.length > 0\" class=\"vtk-upload__list mt-2\">\r\n <div\r\n v-for=\"file in fileList\"\r\n :key=\"file.uid\"\r\n :class=\"['vtk-upload__list-item', `is-${file.status}`]\"\r\n style=\"cursor: pointer;\"\r\n >\r\n <VIcon size=\"18\" class=\"mr-1\" :color=\"file.status === 'error' ? 'error' : 'primary'\">\r\n {{ fileIcon(file) }}\r\n </VIcon>\r\n <span class=\"vtk-upload__list-item-name flex-grow-1 text-truncate\" @click=\"handlePreview(file)\" :title=\"file.name\">{{ file.name }}</span>\r\n <span v-if=\"file.status === 'uploading'\" class=\"text-caption text-grey ml-2\">{{ file.percentage }}%</span>\r\n <VBtn\r\n v-if=\"!disabled && !detail\"\n icon\r\n size=\"x-small\"\r\n variant=\"text\"\n color=\"grey\"\n class=\"ml-1\"\n title=\"删除\"\n @click=\"handleRemove(file)\"\n >\r\n <VIcon size=\"16\">mdi-close</VIcon>\r\n </VBtn>\r\n <!-- 进度条 -->\r\n <v-progress-linear\r\n v-if=\"file.status === 'uploading'\"\r\n :model-value=\"file.percentage\"\r\n color=\"primary\"\r\n class=\"vtk-upload__list-progress\"\r\n height=\"2\"\r\n />\r\n </div>\r\n </div>\r\n\r\n <!-- 预览 Dialog -->\r\n <VDialog v-model=\"previewVisible\" fullscreen scrollable @click:outside=\"closePreview\">\r\n <VCard class=\"vtk-upload__preview-card\">\r\n <v-toolbar color=\"primary\" density=\"comfortable\">\r\n <v-toolbar-title class=\"text-truncate\">{{ previewFile?.name }}</v-toolbar-title>\n <VSpacer />\n <VBtn icon variant=\"text\" title=\"新窗口打开\" @click=\"openCurrentPreview\">\n <VIcon>mdi-open-in-new</VIcon>\n </VBtn>\n <template v-if=\"isImage(previewFile)\">\n <VBtn icon variant=\"text\" title=\"缩小\" @click=\"zoomPreview(-0.3)\">\n <VIcon>mdi-magnify-minus-outline</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"放大\" @click=\"zoomPreview(0.3)\">\n <VIcon>mdi-magnify-plus-outline</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"向左旋转\" @click=\"rotatePreview(-90)\">\n <VIcon>mdi-rotate-left</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"向右旋转\" @click=\"rotatePreview(90)\">\n <VIcon>mdi-rotate-right</VIcon>\n </VBtn>\n <VBtn icon variant=\"text\" title=\"重置\" @click=\"resetPreviewTransform\">\n <VIcon>mdi-refresh</VIcon>\n </VBtn>\n </template>\n <VBtn icon variant=\"text\" title=\"关闭\" @click=\"closePreview\">\n <VIcon>mdi-close</VIcon>\n </VBtn>\n </v-toolbar>\r\n <div class=\"vtk-upload__preview-body\">\r\n <div v-if=\"isImage(previewFile)\" class=\"vtk-upload__preview-image-wrap\">\r\n <img\r\n class=\"vtk-upload__preview-image\"\r\n :src=\"previewFile?._previewSrc\"\r\n :alt=\"previewFile?.name\"\r\n :style=\"previewImageStyle\"\r\n draggable=\"false\"\r\n @pointerdown=\"startPreviewDrag\"\r\n />\r\n </div>\r\n <div v-else class=\"vtk-upload__preview-empty\">\r\n <VIcon size=\"64\">{{ isExcel(previewFile) ? 'mdi-microsoft-excel' : 'mdi-file-outline' }}</VIcon>\r\n <div class=\"mt-2\">{{ previewFile?.name }}</div>\r\n <div class=\"text-caption mt-1\">This file cannot be previewed online.</div>\r\n </div>\r\n </div>\r\n </VCard>\r\n </VDialog>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed, nextTick, ref, watch } from 'vue';\nimport Request from '../../commons/request.js';\r\n\r\ndefineOptions({\r\n name: 'VtkUpload',\r\n inheritAttrs: false,\r\n});\r\n\r\nconst props = defineProps({\r\n /** v-model 文件列表 */\r\n modelValue: {\r\n type: Array,\r\n default: () => [],\r\n },\r\n /** 上传地址 */\r\n action: {\r\n type: String,\r\n default: '',\r\n },\r\n /** 接受的文件类型,同原生 accept */\r\n accept: {\r\n type: String,\r\n default: '',\r\n },\r\n /** 是否多选 */\r\n multiple: {\r\n type: Boolean,\r\n default: false,\r\n },\r\n /** 最大上传数量,0 表示不限制 */\r\n limit: {\r\n type: Number,\r\n default: 0,\r\n },\r\n /** 单文件最大体积,单位 MB,0 表示不限制 */\r\n maxSize: {\r\n type: Number,\r\n default: 0,\r\n },\r\n /** 列表类型:text | picture | picture-card */\r\n listType: {\r\n type: String,\r\n default: 'text',\r\n validator: (v) => ['text', 'picture', 'picture-card'].includes(v),\r\n },\r\n /** 是否显示文件列表 */\r\n showFileList: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n /** 是否自动上传 */\r\n autoUpload: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n /** 是否禁用 */\r\n disabled: {\n type: Boolean,\n default: false,\n },\n /** 详情模式:隐藏上传和删除入口,仅展示已上传文件并保留查看 */\n detail: {\n type: Boolean,\n default: false,\n },\n /** 附加请求头 */\r\n headers: {\r\n type: Object,\r\n default: () => ({}),\r\n },\r\n /** 附加请求数据 */\r\n data: {\r\n type: Object,\r\n default: () => ({}),\r\n },\r\n /** 文件字段名 */\r\n name: {\r\n type: String,\r\n default: 'file',\r\n },\r\n /** 提示文字 */\r\n tip: {\r\n type: String,\r\n default: '',\r\n },\r\n /** 上传前钩子,返回 false 或 rejected Promise 则停止上传 */\r\n beforeUpload: {\r\n type: Function,\r\n default: null,\r\n },\r\n /** 移除前钩子 */\r\n beforeRemove: {\r\n type: Function,\r\n default: null,\r\n },\r\n});\r\n\r\nconst emit = defineEmits([\r\n 'update:modelValue',\r\n 'change',\r\n 'success',\r\n 'error',\r\n 'progress',\r\n 'remove',\r\n 'exceed',\r\n 'preview',\r\n]);\r\n\r\n/* -------------------- 内部状态 -------------------- */\r\nconst inputRef = ref(null);\r\nconst isDragover = ref(false);\r\nconst previewVisible = ref(false);\r\nconst previewFile = ref(null);\r\nconst previewScale = ref(1);\r\nconst previewRotation = ref(0);\r\nconst previewTranslateX = ref(0);\r\nconst previewTranslateY = ref(0);\r\nconst previewDragState = ref(null);\r\n\r\n// 内部维护文件列表\nconst fileList = ref([]);\nlet isSyncingModel = false;\n\nwatch(\n () => props.modelValue,\n (val) => {\n if (isSyncingModel) {\n isSyncingModel = false;\n return;\n }\n\n // Accept external URL lists or file object lists.\n fileList.value = normalizeFileList(val || []);\n },\n);\n\r\n/* -------------------- 工具函数 -------------------- */\r\nlet uidCounter = 0;\nconst genUid = () => `vtk-upload-${Date.now()}-${uidCounter++}`;\n\nconst getFileNameFromUrl = (url) => {\n const cleanUrl = String(url || '').split('?')[0].split('#')[0];\n const name = cleanUrl.substring(cleanUrl.lastIndexOf('/') + 1);\n try {\n return decodeURIComponent(name || cleanUrl || 'file');\n } catch (e) {\n return name || cleanUrl || 'file';\n }\n};\n\nconst normalizeFileList = (value) => {\n if (!Array.isArray(value)) return [];\n\n return value\n .filter((item) => item)\n .map((item) => {\n if (typeof item === 'string') {\n return {\n uid: genUid(),\n name: getFileNameFromUrl(item),\n size: 0,\n type: '',\n status: 'success',\n percentage: 100,\n raw: null,\n url: item,\n preview: '',\n response: null,\n };\n }\n\n return {\n uid: item.uid || genUid(),\n name: item.name || getFileNameFromUrl(item.url || item.preview),\n size: item.size || 0,\n type: item.type || '',\n status: item.status || 'success',\n percentage: item.percentage ?? 100,\n raw: item.raw || null,\n url: item.url || '',\n preview: item.preview || '',\n response: item.response || null,\n ...item,\n };\n });\n};\n\nfileList.value = normalizeFileList(props.modelValue || []);\n\nconst isImage = (file) => {\n if (!file) return false;\r\n return /image\\//.test(file.type) || /\\.(png|jpg|jpeg|gif|bmp|webp|svg)$/i.test(file.name || '');\r\n};\r\n\r\nconst fileIcon = (file) => {\r\n if (file.status === 'error') return 'mdi-file-alert-outline';\r\n if (isImage(file)) return 'mdi-file-image-outline';\r\n return 'mdi-file-outline';\r\n};\r\n\r\nconst previewImageStyle = computed(() => ({\r\n transform: `translate(${previewTranslateX.value}px, ${previewTranslateY.value}px) scale(${previewScale.value}) rotate(${previewRotation.value}deg)`,\r\n}));\r\n\r\n/* -------------------- 触发 input -------------------- */\r\nconst triggerInput = () => {\r\n inputRef.value && inputRef.value.click();\r\n};\r\n\r\n/* -------------------- 拖拽 -------------------- */\r\nconst onDragover = () => {\n if (!props.disabled && !props.detail) isDragover.value = true;\n};\n\nconst onDrop = (e) => {\n isDragover.value = false;\n if (props.disabled || props.detail) return;\n processFiles(Array.from(e.dataTransfer.files));\n};\n\r\n/* -------------------- input change -------------------- */\r\nconst onInputChange = (e) => {\n if (props.disabled || props.detail) return;\n processFiles(Array.from(e.target.files));\n // 清空,允许重复选同一文件\r\n e.target.value = '';\r\n};\r\n\r\n/* -------------------- 文件处理 -------------------- */\r\nconst processFiles = (rawFiles) => {\r\n if (!rawFiles.length) return;\r\n\r\n // 数量限制检查\r\n if (props.limit > 0 && fileList.value.length + rawFiles.length > props.limit) {\r\n emit('exceed', rawFiles, fileList.value);\r\n return;\r\n }\r\n\r\n rawFiles.forEach((raw) => {\r\n // 体积检查\r\n if (props.maxSize > 0 && raw.size / 1024 / 1024 > props.maxSize) {\r\n const errFile = buildFile(raw, 'error');\r\n emit('error', new Error(`文件 ${raw.name} 超过最大限制 ${props.maxSize}MB`), errFile, fileList.value);\r\n return;\r\n }\r\n\r\n const file = buildFile(raw, 'ready');\r\n\r\n // 生成预览\r\n if (isImage(raw)) {\r\n const reader = new FileReader();\r\n reader.onload = (e) => { file.preview = e.target.result; };\r\n reader.readAsDataURL(raw);\r\n }\r\n\r\n const beforeHook = props.beforeUpload ? props.beforeUpload(raw) : true;\r\n Promise.resolve(beforeHook).then((result) => {\r\n if (result === false) return;\r\n addFile(file);\r\n if (props.autoUpload && props.action) {\r\n uploadFile(file);\r\n }\r\n }).catch(() => {});\r\n });\r\n};\r\n\r\nconst buildFile = (raw, status) => ({\r\n uid: genUid(),\r\n name: raw.name,\r\n size: raw.size,\r\n type: raw.type,\r\n status,\r\n percentage: 0,\r\n raw,\r\n url: '',\r\n preview: '',\r\n response: null,\r\n});\r\n\r\nconst addFile = (file) => {\r\n fileList.value.push(file);\r\n syncModel();\r\n emit('change', file, fileList.value);\r\n};\r\n\r\nconst syncModel = () => {\n const urls = fileList.value\n .filter((f) => f.status === 'success' && f.url)\n .map((f) => String(f.url));\n isSyncingModel = true;\n emit('update:modelValue', urls);\n nextTick(() => {\n isSyncingModel = false;\n });\n};\n\r\n/* -------------------- 上传逻辑 -------------------- */\r\nconst uploadFile = (file) => {\r\n file.status = 'uploading';\r\n const formData = new FormData();\r\n formData.append(props.name, file.raw);\r\n Object.entries(props.data).forEach(([k, v]) => formData.append(k, v));\r\n\r\n // 使用 axios 直接调,以获得 onUploadProgress\r\n const tokenKey = window.VTK_CONFIG?.storageKeys?.token || '_mis_acis_token';\r\n const token = window.$vtk?.storage?.get(tokenKey) || localStorage.getItem(tokenKey);\r\n\r\n const headers = {\r\n 'content-type': 'multipart/form-data',\r\n ...props.headers,\r\n };\r\n if (token) headers['Authorization'] = `Bearer ${token}`;\r\n\r\n Request.http(props.action, formData, 'POST', headers).then((res) => {\r\n file.status = 'success';\r\n file.response = res;\r\n // 兼容 { data: 'url' } 和 { data: { url: '...' } } 两种结构\r\n const url = typeof res?.data === 'string' ? res.data : (res?.data?.url || res?.url || '');\r\n if (url) file.url = url;\r\n console.log('[VtkUpload] res:', res, '| file.url:', file.url, '| fileList:', JSON.parse(JSON.stringify(fileList.value)));\r\n syncModel();\r\n emit('success', res, file, fileList.value);\r\n emit('change', file, fileList.value);\r\n }).catch((err) => {\r\n file.status = 'error';\r\n syncModel();\r\n emit('error', err, file, fileList.value);\r\n emit('change', file, fileList.value);\r\n });\r\n};\r\n\r\n/* -------------------- 移除文件 -------------------- */\r\nconst handleRemove = (file) => {\r\n const doRemove = () => {\r\n fileList.value = fileList.value.filter((f) => f.uid !== file.uid);\r\n syncModel();\r\n emit('remove', file, fileList.value);\r\n };\r\n\r\n if (props.beforeRemove) {\r\n Promise.resolve(props.beforeRemove(file, fileList.value)).then((result) => {\r\n if (result !== false) doRemove();\r\n }).catch(() => {});\r\n } else {\r\n doRemove();\r\n }\r\n};\r\n\r\n/* -------------------- 预览 -------------------- */\r\nconst isExcel = (file) => /\\.(xlsx|xls)$/i.test(file?.name || '');\r\n\r\nconst resetPreviewTransform = () => {\r\n previewScale.value = 1;\r\n previewRotation.value = 0;\r\n previewTranslateX.value = 0;\r\n previewTranslateY.value = 0;\r\n};\r\n\r\nconst closePreview = () => {\r\n previewVisible.value = false;\r\n};\r\n\r\nconst rotatePreview = (degrees) => {\r\n previewRotation.value += degrees;\r\n};\r\n\r\nconst zoomPreview = (step) => {\r\n const nextScale = Number((previewScale.value + step).toFixed(2));\r\n previewScale.value = Math.min(3, Math.max(0.2, nextScale));\r\n};\r\n\r\nconst startPreviewDrag = (event) => {\r\n if (previewScale.value <= 1) return;\r\n event.preventDefault();\r\n const target = event.currentTarget;\r\n previewDragState.value = {\r\n pointerId: event.pointerId,\r\n startX: event.clientX,\r\n startY: event.clientY,\r\n translateX: previewTranslateX.value,\r\n translateY: previewTranslateY.value,\r\n };\r\n target.setPointerCapture?.(event.pointerId);\r\n target.addEventListener('pointermove', movePreviewDrag);\r\n target.addEventListener('pointerup', endPreviewDrag, { once: true });\r\n target.addEventListener('pointercancel', endPreviewDrag, { once: true });\r\n};\r\n\r\nconst movePreviewDrag = (event) => {\r\n const state = previewDragState.value;\r\n if (!state || state.pointerId !== event.pointerId) return;\r\n previewTranslateX.value = state.translateX + event.clientX - state.startX;\r\n previewTranslateY.value = state.translateY + event.clientY - state.startY;\r\n};\r\n\r\nconst endPreviewDrag = (event) => {\r\n event.currentTarget?.releasePointerCapture?.(event.pointerId);\r\n event.currentTarget?.removeEventListener('pointermove', movePreviewDrag);\r\n previewDragState.value = null;\r\n};\r\n\r\nconst openFileInNewTab = (file, fileUrl) => {\n if (fileUrl) {\n window.open(fileUrl, '_blank');\n return;\n }\n\r\n if (file.raw instanceof File || file.raw instanceof Blob) {\r\n const blobUrl = URL.createObjectURL(file.raw);\r\n const win = window.open(blobUrl, '_blank');\r\n win?.addEventListener('unload', () => URL.revokeObjectURL(blobUrl));\n }\n};\n\nconst openCurrentPreview = () => {\n if (!previewFile.value) return;\n openFileInNewTab(previewFile.value, previewFile.value._previewSrc || previewFile.value.url || previewFile.value.preview);\n};\n\nconst handlePreview = (file) => {\n emit('preview', file);\r\n\r\n const fileUrl = file.url || file.preview;\r\n\r\n // Non-image files open in a new tab.\r\n if (!isImage(file) && !isExcel(file)) {\r\n openFileInNewTab(file, fileUrl);\r\n return;\r\n }\r\n\r\n // Excel:Office Online 查看器(需要文件有公网 URL)\r\n if (isExcel(file)) {\r\n if (fileUrl && /^https?:\\/\\//.test(fileUrl)) {\n window.open(`https://view.officeapps.live.com/op/view.aspx?src=${encodeURIComponent(fileUrl)}`, '_blank');\n } else {\n // Excel without a public URL falls back to the dialog hint.\n previewFile.value = { ...file, _previewSrc: fileUrl };\n resetPreviewTransform();\n previewVisible.value = true;\n }\r\n return;\r\n }\r\n\r\n // Images preview inside the dialog.\n previewFile.value = {\r\n ...file,\r\n _previewSrc: fileUrl,\r\n };\r\n resetPreviewTransform();\r\n previewVisible.value = true;\r\n};\r\n\r\nwatch(previewVisible, (visible) => {\r\n if (!visible) resetPreviewTransform();\r\n});\r\n\r\n/* -------------------- 对外暴露方法 -------------------- */\r\n/** 手动触发未上传文件的上传 */\r\nconst submit = () => {\r\n fileList.value\r\n .filter((f) => f.status === 'ready' && props.action)\r\n .forEach(uploadFile);\r\n};\r\n\r\n/** 清空文件列表 */\r\nconst clearFiles = () => {\r\n fileList.value = [];\r\n syncModel();\r\n};\r\n\r\n/** 手动移除某个文件 */\r\nconst remove = (file) => handleRemove(file);\r\n\r\ndefineExpose({ submit, clearFiles, remove });\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.vtk-upload {\r\n width: 100%;\r\n}\r\n\r\n/* ---- 拖拽区域 ---- */\r\n.vtk-upload__dragger {\r\n border: 1px dashed rgba(0, 0, 0, 0.2);\r\n border-radius: 6px;\r\n padding: 24px 16px;\r\n text-align: center;\r\n cursor: pointer;\r\n transition: border-color 0.2s, background 0.2s;\r\n background: transparent;\r\n\r\n &:hover:not(.is-disabled) {\r\n border-color: rgb(var(--v-theme-primary));\r\n }\r\n\r\n &.is-dragover {\r\n border-color: rgb(var(--v-theme-primary));\r\n background: rgba(var(--v-theme-primary), 0.05);\r\n }\r\n\r\n &.is-disabled {\r\n cursor: not-allowed;\r\n opacity: 0.6;\r\n }\r\n}\r\n\r\n/* ---- 文件列表 ---- */\r\n.vtk-upload__list {\r\n border-top: 1px solid rgba(0, 0, 0, 0.08);\r\n}\r\n\r\n.vtk-upload__list-item {\r\n position: relative;\r\n display: flex;\r\n align-items: center;\r\n padding: 4px 4px 4px 8px;\r\n border-radius: 4px;\r\n font-size: 13px;\r\n transition: background 0.15s;\r\n\r\n &:hover {\r\n background: rgba(0, 0, 0, 0.04);\r\n }\r\n\r\n &.is-error {\r\n color: rgb(var(--v-theme-error));\r\n }\r\n\r\n &.is-success .vtk-upload__list-item-name {\r\n cursor: pointer;\r\n &:hover { color: rgb(var(--v-theme-primary)); }\r\n }\r\n}\r\n\r\n.vtk-upload__list-item-name {\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n max-width: 500px;\r\n}\r\n\r\n.vtk-upload__list-progress {\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n}\r\n\r\n/* ---- picture-card ---- */\r\n.vtk-upload__picture-card-wrap {\r\n display: flex;\r\n flex-wrap: wrap;\r\n gap: 8px;\r\n}\r\n\r\n.vtk-upload__picture-card-item,\r\n.vtk-upload__picture-card-add {\r\n width: 100px;\r\n height: 100px;\r\n border-radius: 6px;\r\n overflow: hidden;\r\n}\r\n\r\n.vtk-upload__picture-card-item {\r\n position: relative;\r\n border: 1px solid rgba(0, 0, 0, 0.12);\r\n\r\n &:hover .vtk-upload__picture-card-mask {\r\n opacity: 1;\r\n }\r\n}\r\n\r\n.vtk-upload__picture-card-mask {\r\n position: absolute;\r\n inset: 0;\r\n background: rgba(0, 0, 0, 0.45);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n gap: 4px;\r\n opacity: 0;\r\n transition: opacity 0.2s;\r\n}\r\n\r\n.vtk-upload__picture-card-progress {\r\n position: absolute;\r\n inset: 0;\r\n background: rgba(0, 0, 0, 0.4);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.vtk-upload__picture-card-add {\r\n border: 1px dashed rgba(0, 0, 0, 0.2);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n cursor: pointer;\r\n transition: border-color 0.2s, background 0.2s;\r\n\r\n &:hover, &.is-dragover {\r\n border-color: rgb(var(--v-theme-primary));\r\n background: rgba(var(--v-theme-primary), 0.04);\r\n }\r\n}\r\n\r\n/* ---- 隐藏 input ---- */\r\n.vtk-upload__input {\r\n display: none;\r\n}\r\n\r\n/* ---- preview ---- */\r\n.vtk-upload__preview-card {\r\n height: 100vh;\r\n background: #111;\r\n}\r\n\r\n.vtk-upload__preview-body {\r\n height: calc(100vh - 64px);\r\n overflow: auto;\r\n background: #111;\r\n}\r\n\r\n.vtk-upload__preview-image-wrap {\r\n min-width: 100%;\r\n min-height: 100%;\r\n padding: 32px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n\r\n.vtk-upload__preview-image {\r\n display: block;\r\n max-width: 90vw;\r\n max-height: calc(100vh - 128px);\r\n object-fit: contain;\r\n transform-origin: center center;\r\n transition: transform 0.2s ease;\r\n user-select: none;\r\n cursor: grab;\r\n touch-action: none;\r\n\r\n &:active {\r\n cursor: grabbing;\r\n }\r\n}\r\n\r\n.vtk-upload__preview-empty {\r\n min-height: 100%;\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 32px;\r\n color: rgba(255, 255, 255, 0.72);\r\n text-align: center;\r\n}\r\n</style>\r\n","import Request from \"./request.js\";\r\nimport Storage from \"./storage.js\";\r\nimport Message from \"../components/message/index.js\";\r\n\r\nfunction isAid(value) {\r\n const str = String(value || \"\");\r\n return !!str && !/^(https?:)?\\/\\//i.test(str) && !str.includes(\"/\") && !str.includes(\"?\");\r\n\r\n \r\n}\r\n\r\nfunction getLinkFromResponse(data) {\r\n if (!data) {\r\n return \"\";\r\n }\r\n\r\n if (typeof data === \"string\") {\r\n return data;\r\n }\r\n\r\n return data.puri || \"\";\r\n}\r\n\r\nfunction buildUrlWithParams(target, appendParams) {\r\n const queryString = target.includes(\"?\") ? target.split(\"?\")[1] : \"\";\r\n const queryParams = new URLSearchParams(queryString);\r\n const newParams = [];\r\n\r\n Object.entries(appendParams).forEach(([key, value]) => {\r\n if (!key || value === undefined || value === null || value === \"\") {\r\n return;\r\n }\r\n\r\n if (!queryParams.has(key)) {\r\n newParams.push(`${encodeURIComponent(key)}=${encodeURIComponent(value)}`);\r\n }\r\n });\r\n\r\n if (!newParams.length) {\r\n return target;\r\n }\r\n\r\n const joinSymbol = target.includes(\"?\") ? \"&\" : \"?\";\r\n return `${target}${joinSymbol}${newParams.join(\"&\")}`;\r\n}\r\n\r\nfunction appendParamsToUrl(targetUrl, appendParams) {\r\n const hashIndex = targetUrl.indexOf(\"#\");\r\n\r\n if (hashIndex === -1) {\r\n return buildUrlWithParams(targetUrl, appendParams);\r\n }\r\n\r\n const baseUrl = targetUrl.slice(0, hashIndex);\r\n const hashRoute = targetUrl.slice(hashIndex + 1);\r\n const newHashRoute = buildUrlWithParams(hashRoute, appendParams);\r\n return `${baseUrl}#${newHashRoute}`;\r\n}\r\n\r\nasync function resolveAidUrl(aid) {\r\n if (!aid) {\r\n return aid;\r\n }\r\n\r\n try {\r\n const res = await Request.postForm(\"/kudas/xfwez/apps\", { aid });\r\n const realUrl = res?.meta?.success ? getLinkFromResponse(res.data) : \"\";\r\n return realUrl || aid;\r\n } catch (error) {\r\n return aid;\r\n }\r\n}\r\n\r\nfunction buildAppendParams(sobject, sroute, stokenKey) {\r\n const appendParams = {};\r\n const storageKey = stokenKey || \"_mis_acis_token\";\r\n const stoken = Storage.get(storageKey);\r\n\r\n if (stoken !== undefined && stoken !== null && stoken !== \"\") {\r\n appendParams.stoken = stoken;\r\n }\r\n\r\n if (sroute) {\r\n appendParams.sroute = sroute;\r\n }\r\n\r\n if (sobject && typeof sobject === \"object\" && Object.keys(sobject).length) {\r\n appendParams.sobject = btoa(encodeURIComponent(JSON.stringify(sobject)));\r\n }\r\n\r\n return appendParams;\r\n}\r\n\r\n/**\r\n * 解析地址中的指定参数值。\r\n * @param {string} name 参数名。\r\n * @param {string} url 要解析的地址,不传时默认使用当前地址。\r\n * @return {string} 参数值;未找到时返回空字符串。\r\n */\r\nexport function GetQueryString(name, url = window.location.href) {\r\n const reg = new RegExp(`[?&]${name}=([^&^#^/]*)`, \"i\");\r\n const res = String(url || \"\").match(reg);\r\n return res ? decodeURIComponent(res[1]) : \"\";\r\n}\r\n\r\n/**\r\n * 追加应用访问参数。\r\n * @param {string} url 链接地址或应用 aid;不传时默认取当前地址。\r\n * @param {Object} sobject 参数对象;会按 `btoa(encodeURIComponent(JSON.stringify(sobject)))` 编码后追加为 `sobject` 参数。\r\n * @param {string} sroute 页面路由标识;传值后会在最终地址中追加 `sroute=xxx`。\r\n * @param {string} stokenKey 取 `stoken` 的存储键名,默认 `_mis_acis_token`。\r\n * @return {Promise<string>} 拼接后的链接地址。\r\n */\r\nexport async function appendAppParams(url, sobject = {}, sroute = \"\", stokenKey = \"_mis_acis_token\") {\r\n if (url === undefined || url === null || url === \"\" || url === 0 || url === \"0\") {\r\n Message.toast(\"应用标识错误\", { color: \"error\" });\r\n return \"\";\r\n }\r\n\r\n const source = url || window.location.href;\r\n\r\n if (!source) {\r\n return \"\";\r\n }\r\n\r\n const targetUrl = isAid(source) ? await resolveAidUrl(source) : source;\r\n return appendParamsToUrl(targetUrl, buildAppendParams(sobject, sroute, stokenKey));\r\n}\r\n","/**\r\n * 将数值转换成中文 '0:未启/1:已启'\r\n * \r\n * @param {*} val 数值\r\n * @param {*} map 值对\r\n * @return {string} 中文值\r\n */\r\nexport function dict(val, map) {\r\n let value = \"\";\r\n if (val && val.includes(\",\")) {\r\n value = val.split(\",\").map(item => pre(item, map)).join();\r\n } else {\r\n value = pre(val, map)\r\n }\r\n return value;\r\n}\r\n\r\nfunction pre(value, map) {\r\n if (value) {\r\n var val = Array.isArray(value) ? value : value.split(\",\");\r\n var maps = map?.split(\"/\");\r\n var results = []; // 创建一个空数组,用于存储匹配到的值\r\n // 遍历 val 数组\r\n for (var j = 0; j < val?.length; j++) {\r\n var currentVal = val[j]; // 获取当前要查找的键\r\n for (var i in maps) {\r\n var kv = maps[i].split(\":\");\r\n if (kv[0] == currentVal) {\r\n results.push(kv[1]); // 将匹配到的值添加到结果数组中\r\n break; // 找到匹配项后,跳出内层循环\r\n }\r\n }\r\n }\r\n return results.length > 0 ? results.join() : \"其他\";\r\n }\r\n\r\n}\r\n\r\n\r\n/**\r\n * 1,2字符残疾类别转换\r\n * \r\n * @param {*} val 数值\r\n * @return {string} 中文值\r\n */\r\nexport function analyType(val) {\r\n if (!val) {\r\n return ''\r\n }\r\n let newVal = ''\r\n let arr = ['视力', '听力', '言语', '肢体', '智力', '精神', '多重']\r\n for (let i = 1; i < 8; i++) {\r\n if (i === 1) {\r\n newVal = val.replace(i.toString(), arr[i - 1])\r\n } else {\r\n newVal = newVal.replace(i.toString(), arr[i - 1])\r\n }\r\n }\r\n return newVal;\r\n}\r\nexport function analyLevel(val) {\r\n if (!val) {\r\n return ''\r\n }\r\n let newVal = ''\r\n let arr = ['一级', '二级', '三级', '四级', '不限等级']\r\n for (let i = 1; i < 7; i++) {\r\n if (i === 1) {\r\n newVal = val.replace(i.toString(), arr[i - 1])\r\n } else {\r\n newVal = newVal.replace(i.toString(), arr[i - 1])\r\n }\r\n }\r\n return newVal;\r\n}","/**\r\n * \r\n * @param {*} value 需格式化的时间\r\n * @param {*} fmt 格式\r\n */\r\nexport function date(value, fmt) {\r\n if (!value || value == '无' || value == null) {\r\n fmt = '无';\r\n return fmt;\r\n }\r\n let getDate = new Date(value)\r\n let o = {\r\n 'M+': getDate.getMonth() + 1,\r\n 'd+': getDate.getDate(),\r\n 'H+': getDate.getHours(),\r\n 'h+': getDate.getHours(),\r\n 'm+': getDate.getMinutes(),\r\n 's+': getDate.getSeconds(),\r\n 'q+': Math.floor((getDate.getMonth() + 3) / 3),\r\n 'S': getDate.getMilliseconds()\r\n }\r\n if (/(y+)/.test(fmt)) {\r\n fmt = fmt.replace(RegExp.$1, (getDate.getFullYear() + '').substr(4 - RegExp.$1.length))\r\n }\r\n for (let k in o) {\r\n if (new RegExp('(' + k + ')').test(fmt)) {\r\n fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))\r\n }\r\n }\r\n return fmt\r\n\r\n}\r\n\r\n\r\n/**\r\n * 数字格式化 '0,000.00'\r\n * @param {*} val 数值\r\n * @param {*} fmt 格式\r\n * @return {string} 数字字符串\r\n */\r\nexport function num(val, fmt) {\r\n if (isNaN(val) || val === '' || val === null) {\r\n return val;\r\n }\r\n\r\n // 移除了对Strings和Datetime的依赖,这些在当前上下文中未定义\r\n var numValue = parseFloat(val);\r\n var neg = numValue < 0 ? \"-\" : \"\"; // 正负数\r\n var absValue = Math.abs(numValue);\r\n\r\n // 解析格式字符串,确定小数位数\r\n var fix = 0;\r\n if (fmt && fmt.includes('.')) {\r\n fix = fmt.length - fmt.lastIndexOf('.') - 1;\r\n }\r\n\r\n // 是否需要千分位分隔符\r\n var needSep = fmt && fmt.includes(',');\r\n\r\n // 处理小数部分\r\n var xs = fix > 0 ? absValue.toFixed(fix) : Math.round(absValue);\r\n var decimalPart = fix > 0 ? '.' + xs.toString().split('.')[1] : '';\r\n\r\n // 处理整数部分\r\n var integerPart = fix > 0 ? Math.floor(absValue).toString() : xs.toString();\r\n\r\n // 添加千分位分隔符\r\n if (needSep && integerPart.length > 3) {\r\n integerPart = integerPart.replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\");\r\n }\r\n\r\n return neg + integerPart + decimalPart;\r\n}\r\n\r\n\r\n/**\r\n * 年龄\r\n * @param {*} val 时间 yyyy-MM-dd\r\n * @return {string} 年龄\r\n */\r\nexport function age(val) {\r\n let birthdays = new Date(val.slice(0, 10).replace(/-/g, \"/\"));\r\n let d = new Date();\r\n let age = d.getFullYear() - birthdays.getFullYear() - ((d.getMonth() < birthdays.getMonth() || (d.getMonth() === birthdays.getMonth() && d.getDate() < birthdays.getDate())) ? 1 : 0);\r\n return age;\r\n}\r\n\r\n/**\r\n * 指定中文大于len,用...省略号表示,达到美观效果\r\n * @param {*} val 需格式的中文\r\n * @param {*} len 需格式的长度\r\n */\r\nexport function txt(val, len) {\r\n if (val?.length > len) {\r\n return val.slice(0, len) + \"...\";\r\n } else {\r\n return val;\r\n }\r\n\r\n}\r\n\r\n/**\r\n * 取数据绝对值\r\n * @param {*} val 手机号\r\n */\r\nexport function abs(val) {\r\n return isNaN(val) ? 0 : Math.abs(val)\r\n}\r\n\r\n\r\n\r\n\r\n\r\n","/**\r\n * 脱敏手机号码\r\n * @param {*} val 手机号\r\n * @return {string} 手机号码\r\n */\r\nexport function mobile(val) {\r\n return val.replace(/(\\d{3})\\d{4}(\\d{4})/, \"$1****$2\");\r\n}\r\n\r\n\r\n/**\r\n * 脱敏身份证号\r\n * @param {*} val 身份证号\r\n * @return {string} 身份证号\r\n */\r\nexport function idcard(val) {\r\n if (val) {\r\n return val.replace(/^(.{4})(?:\\d+)(.{4})$/, \"$1** **** ****$2\");\r\n }\r\n}\r\n\r\n\r\n\r\n\r\n\r\n","export const red = {\n base: '#f44336',\n lighten5: '#ffebee',\n lighten4: '#ffcdd2',\n lighten3: '#ef9a9a',\n lighten2: '#e57373',\n lighten1: '#ef5350',\n darken1: '#e53935',\n darken2: '#d32f2f',\n darken3: '#c62828',\n darken4: '#b71c1c',\n accent1: '#ff8a80',\n accent2: '#ff5252',\n accent3: '#ff1744',\n accent4: '#d50000'\n};\nexport const pink = {\n base: '#e91e63',\n lighten5: '#fce4ec',\n lighten4: '#f8bbd0',\n lighten3: '#f48fb1',\n lighten2: '#f06292',\n lighten1: '#ec407a',\n darken1: '#d81b60',\n darken2: '#c2185b',\n darken3: '#ad1457',\n darken4: '#880e4f',\n accent1: '#ff80ab',\n accent2: '#ff4081',\n accent3: '#f50057',\n accent4: '#c51162'\n};\nexport const purple = {\n base: '#9c27b0',\n lighten5: '#f3e5f5',\n lighten4: '#e1bee7',\n lighten3: '#ce93d8',\n lighten2: '#ba68c8',\n lighten1: '#ab47bc',\n darken1: '#8e24aa',\n darken2: '#7b1fa2',\n darken3: '#6a1b9a',\n darken4: '#4a148c',\n accent1: '#ea80fc',\n accent2: '#e040fb',\n accent3: '#d500f9',\n accent4: '#aa00ff'\n};\nexport const deepPurple = {\n base: '#673ab7',\n lighten5: '#ede7f6',\n lighten4: '#d1c4e9',\n lighten3: '#b39ddb',\n lighten2: '#9575cd',\n lighten1: '#7e57c2',\n darken1: '#5e35b1',\n darken2: '#512da8',\n darken3: '#4527a0',\n darken4: '#311b92',\n accent1: '#b388ff',\n accent2: '#7c4dff',\n accent3: '#651fff',\n accent4: '#6200ea'\n};\nexport const indigo = {\n base: '#3f51b5',\n lighten5: '#e8eaf6',\n lighten4: '#c5cae9',\n lighten3: '#9fa8da',\n lighten2: '#7986cb',\n lighten1: '#5c6bc0',\n darken1: '#3949ab',\n darken2: '#303f9f',\n darken3: '#283593',\n darken4: '#1a237e',\n accent1: '#8c9eff',\n accent2: '#536dfe',\n accent3: '#3d5afe',\n accent4: '#304ffe'\n};\nexport const blue = {\n base: '#2196f3',\n lighten5: '#e3f2fd',\n lighten4: '#bbdefb',\n lighten3: '#90caf9',\n lighten2: '#64b5f6',\n lighten1: '#42a5f5',\n darken1: '#1e88e5',\n darken2: '#1976d2',\n darken3: '#1565c0',\n darken4: '#0d47a1',\n accent1: '#82b1ff',\n accent2: '#448aff',\n accent3: '#2979ff',\n accent4: '#2962ff'\n};\nexport const lightBlue = {\n base: '#03a9f4',\n lighten5: '#e1f5fe',\n lighten4: '#b3e5fc',\n lighten3: '#81d4fa',\n lighten2: '#4fc3f7',\n lighten1: '#29b6f6',\n darken1: '#039be5',\n darken2: '#0288d1',\n darken3: '#0277bd',\n darken4: '#01579b',\n accent1: '#80d8ff',\n accent2: '#40c4ff',\n accent3: '#00b0ff',\n accent4: '#0091ea'\n};\nexport const cyan = {\n base: '#00bcd4',\n lighten5: '#e0f7fa',\n lighten4: '#b2ebf2',\n lighten3: '#80deea',\n lighten2: '#4dd0e1',\n lighten1: '#26c6da',\n darken1: '#00acc1',\n darken2: '#0097a7',\n darken3: '#00838f',\n darken4: '#006064',\n accent1: '#84ffff',\n accent2: '#18ffff',\n accent3: '#00e5ff',\n accent4: '#00b8d4'\n};\nexport const teal = {\n base: '#009688',\n lighten5: '#e0f2f1',\n lighten4: '#b2dfdb',\n lighten3: '#80cbc4',\n lighten2: '#4db6ac',\n lighten1: '#26a69a',\n darken1: '#00897b',\n darken2: '#00796b',\n darken3: '#00695c',\n darken4: '#004d40',\n accent1: '#a7ffeb',\n accent2: '#64ffda',\n accent3: '#1de9b6',\n accent4: '#00bfa5'\n};\nexport const green = {\n base: '#4caf50',\n lighten5: '#e8f5e9',\n lighten4: '#c8e6c9',\n lighten3: '#a5d6a7',\n lighten2: '#81c784',\n lighten1: '#66bb6a',\n darken1: '#43a047',\n darken2: '#388e3c',\n darken3: '#2e7d32',\n darken4: '#1b5e20',\n accent1: '#b9f6ca',\n accent2: '#69f0ae',\n accent3: '#00e676',\n accent4: '#00c853'\n};\nexport const lightGreen = {\n base: '#8bc34a',\n lighten5: '#f1f8e9',\n lighten4: '#dcedc8',\n lighten3: '#c5e1a5',\n lighten2: '#aed581',\n lighten1: '#9ccc65',\n darken1: '#7cb342',\n darken2: '#689f38',\n darken3: '#558b2f',\n darken4: '#33691e',\n accent1: '#ccff90',\n accent2: '#b2ff59',\n accent3: '#76ff03',\n accent4: '#64dd17'\n};\nexport const lime = {\n base: '#cddc39',\n lighten5: '#f9fbe7',\n lighten4: '#f0f4c3',\n lighten3: '#e6ee9c',\n lighten2: '#dce775',\n lighten1: '#d4e157',\n darken1: '#c0ca33',\n darken2: '#afb42b',\n darken3: '#9e9d24',\n darken4: '#827717',\n accent1: '#f4ff81',\n accent2: '#eeff41',\n accent3: '#c6ff00',\n accent4: '#aeea00'\n};\nexport const yellow = {\n base: '#ffeb3b',\n lighten5: '#fffde7',\n lighten4: '#fff9c4',\n lighten3: '#fff59d',\n lighten2: '#fff176',\n lighten1: '#ffee58',\n darken1: '#fdd835',\n darken2: '#fbc02d',\n darken3: '#f9a825',\n darken4: '#f57f17',\n accent1: '#ffff8d',\n accent2: '#ffff00',\n accent3: '#ffea00',\n accent4: '#ffd600'\n};\nexport const amber = {\n base: '#ffc107',\n lighten5: '#fff8e1',\n lighten4: '#ffecb3',\n lighten3: '#ffe082',\n lighten2: '#ffd54f',\n lighten1: '#ffca28',\n darken1: '#ffb300',\n darken2: '#ffa000',\n darken3: '#ff8f00',\n darken4: '#ff6f00',\n accent1: '#ffe57f',\n accent2: '#ffd740',\n accent3: '#ffc400',\n accent4: '#ffab00'\n};\nexport const orange = {\n base: '#ff9800',\n lighten5: '#fff3e0',\n lighten4: '#ffe0b2',\n lighten3: '#ffcc80',\n lighten2: '#ffb74d',\n lighten1: '#ffa726',\n darken1: '#fb8c00',\n darken2: '#f57c00',\n darken3: '#ef6c00',\n darken4: '#e65100',\n accent1: '#ffd180',\n accent2: '#ffab40',\n accent3: '#ff9100',\n accent4: '#ff6d00'\n};\nexport const deepOrange = {\n base: '#ff5722',\n lighten5: '#fbe9e7',\n lighten4: '#ffccbc',\n lighten3: '#ffab91',\n lighten2: '#ff8a65',\n lighten1: '#ff7043',\n darken1: '#f4511e',\n darken2: '#e64a19',\n darken3: '#d84315',\n darken4: '#bf360c',\n accent1: '#ff9e80',\n accent2: '#ff6e40',\n accent3: '#ff3d00',\n accent4: '#dd2c00'\n};\nexport const brown = {\n base: '#795548',\n lighten5: '#efebe9',\n lighten4: '#d7ccc8',\n lighten3: '#bcaaa4',\n lighten2: '#a1887f',\n lighten1: '#8d6e63',\n darken1: '#6d4c41',\n darken2: '#5d4037',\n darken3: '#4e342e',\n darken4: '#3e2723'\n};\nexport const blueGrey = {\n base: '#607d8b',\n lighten5: '#eceff1',\n lighten4: '#cfd8dc',\n lighten3: '#b0bec5',\n lighten2: '#90a4ae',\n lighten1: '#78909c',\n darken1: '#546e7a',\n darken2: '#455a64',\n darken3: '#37474f',\n darken4: '#263238'\n};\nexport const grey = {\n base: '#9e9e9e',\n lighten5: '#fafafa',\n lighten4: '#f5f5f5',\n lighten3: '#eeeeee',\n lighten2: '#e0e0e0',\n lighten1: '#bdbdbd',\n darken1: '#757575',\n darken2: '#616161',\n darken3: '#424242',\n darken4: '#212121'\n};\nexport const shades = {\n black: '#000000',\n white: '#ffffff',\n transparent: '#ffffff00'\n};\nexport default {\n red,\n pink,\n purple,\n deepPurple,\n indigo,\n blue,\n lightBlue,\n cyan,\n teal,\n green,\n lightGreen,\n lime,\n yellow,\n amber,\n orange,\n deepOrange,\n brown,\n blueGrey,\n grey,\n shades\n};\n//# sourceMappingURL=colors.js.map","import colors from 'vuetify/lib/util/colors';\r\n\r\nconst theme_colors = [\r\n {\r\n name: 'Blue-light',\r\n scheme: 'md-blue-500-scheme',\r\n dark: true,\r\n primary: colors.blue.base,\r\n secondary: colors.blue.lighten4, // #FFCDD2\r\n accent: colors.blue.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Yellow-light',\r\n scheme: 'md-amber-a700-scheme',\r\n dark: true,\r\n primary: colors.amber.darken1,\r\n secondary: colors.amber.lighten4, // #FFCDD2\r\n accent: colors.amber.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Red-light',\r\n scheme: 'md-red-a400-scheme',\r\n dark: true,\r\n primary: colors.red.accent3,\r\n secondary: colors.red.lighten4, // #FFCDD2\r\n accent: colors.red.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Pink-light',\r\n dark: false,\r\n scheme: 'md-pink-a100-scheme',\r\n primary: colors.pink.accent1,\r\n secondary: colors.pink.lighten4, // #FFCDD2\r\n accent: colors.pink.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'Purple-light',\r\n dark: false,\r\n scheme: 'md-purple-a700-scheme',\r\n primary: colors.purple.accent4,\r\n secondary: colors.purple.lighten4, // #FFCDD2\r\n accent: colors.purple.accent2, // #3F51B5\r\n },\r\n {\r\n name: 'DeepPurple-light',\r\n dark: false,\r\n scheme: 'md-deep-purple-a700-scheme',\r\n primary: colors.deepPurple.base,\r\n secondary: colors.deepPurple.lighten4, // #FFCDD2\r\n accent: colors.deepPurple.accent2, // #3F51B5\r\n }\r\n];\r\n\r\nconst navi_colors = [\r\n {\r\n name: 'black',\r\n class: 'black'\r\n },\r\n {\r\n name: 'red-pink',\r\n class: 'gradient-red-pink'\r\n },\r\n {\r\n name: 'blue-grey-blue',\r\n class: 'gradient-blue-grey-blue'\r\n },\r\n {\r\n name: 'green-teal',\r\n class: 'gradient-green-teal'\r\n },\r\n {\r\n name: 'purple-deep-purple',\r\n class: 'gradient-purple-deep-purple'\r\n },\r\n {\r\n name: 'purple-amber',\r\n class: 'gradient-purple-amber'\r\n },\r\n {\r\n name: 'indigo-purple',\r\n class: 'gradient-indigo-purple'\r\n },\r\n {\r\n name: 'deep-purple-blue',\r\n class: 'gradient-deep-purple-blue'\r\n },\r\n {\r\n name: 'deep-orange-orange',\r\n class: 'gradient-deep-orange-orange'\r\n },\r\n {\r\n name: 'light-blue-cyan',\r\n class: 'gradient-light-blue-cyan'\r\n },\r\n {\r\n name: 'timber',\r\n class: 'gradient-timber'\r\n },\r\n {\r\n name: 'strawberry',\r\n class: 'gradient-strawberry'\r\n },\r\n {\r\n name: 'orange',\r\n class: 'gradient-orange'\r\n },\r\n {\r\n name: 'pomegranate',\r\n class: 'gradient-pomegranate'\r\n },\r\n {\r\n name: 'green-tea',\r\n class: 'gradient-green-tea'\r\n },\r\n {\r\n name: 'blackberry',\r\n class: 'gradient-blackberry'\r\n },\r\n {\r\n name: 'plum',\r\n class: 'gradient-plum'\r\n },\r\n {\r\n name: 'passion-fruit',\r\n class: 'gradient-passion-fruit'\r\n },\r\n {\r\n name: 'sublime-vivid',\r\n class: 'gradient-sublime-vivid'\r\n },\r\n {\r\n name: 'summer',\r\n class: 'gradient-summer'\r\n },\r\n {\r\n name: 'crystal-clear',\r\n class: 'gradient-crystal-clear'\r\n },\r\n {\r\n name: 'dawn',\r\n class: 'gradient-dawn'\r\n },\r\n {\r\n name: 'grapefruit-sunset',\r\n class: 'gradient-grapefruit-sunset'\r\n },\r\n {\r\n name: 'man-of-steel',\r\n class: 'gradient-man-of-steel'\r\n }\r\n]\r\n\r\nexport default { theme_colors, navi_colors }\r\n","/** https://github.com/shadowOfCode/bee.js */\r\nconst Validation = {\r\n //手机号码\r\n isMobile: function (input) {\r\n return /^(?:\\+86)?(?:13\\d|14[57]|15[0-35-9]|17[35-8]|18\\d)\\d{8}$|^(?:\\+86)?170[057-9]\\d{7}$/.test(input);\r\n },\r\n //手机号码简单校验,只校验长度\r\n isMobileSize: function (input) {\r\n return /^(?:\\+86)?1\\d{10}$/.test(input);\r\n },\r\n isPhone: function (input) {\r\n return /^(?:\\(\\d{3,4}\\)|\\d{3,4}-)?\\d{7,8}(?:-\\d{1,4})?$/.test(input);\r\n },\r\n isCall: (input) => {\r\n return this.isPhone(input) || this.isMobile(input);\r\n },\r\n //邮箱格式校验\r\n isEmail: function (input) {\r\n return /^[-\\w+]+(?:\\.[-\\w]+)*@[-a-z0-9]+(?:\\.[a-z0-9]+)*(?:\\.[a-z]{2,})$/i.test(input);\r\n },\r\n //18位身份证简单校验\r\n isIdCardSimple: function (idCard) {\r\n return /^(?:1[1-5]|2[1-3]|3[1-7]|4[1-6]|5[0-4]|6[1-5])\\d{4}(?:1[89]|20)\\d{2}(?:0[1-9]|1[0-2])(?:0[1-9]|[12]\\d|3[01])\\d{3}(?:\\d|[xX])$/.test(idCard);\r\n },\r\n // 真实姓名校验\r\n isName: function (input) {\r\n return /^([\\u4e00-\\u9fa5]{1,20}|[a-zA-Z.\\s]{1,20})$/.test(input);\r\n },\r\n //\r\n //18位身份证严格校验\r\n isIdCard: function (idCard) {\r\n let checkCode = (input) => {\r\n var multiplier = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];\r\n var ids = input.split(\"\");\r\n var len = 17, sum = 0;\r\n for (var i = 0; i < len; i++) {\r\n sum += ids[i] * multiplier[i];\r\n }\r\n var remainder = sum % 11;\r\n var checkCodeArr = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];\r\n var result = checkCodeArr[remainder];\r\n return result === input[17];\r\n }\r\n //先校验格式\r\n if (this.isIdCardSimple(idCard)) {\r\n //校验日期时间是否合法\r\n var dateStr = idCard.substr(6, 8);\r\n var dateStrNew = dateStr.replace(/(\\d{4})(\\d{2})(\\d{2})/, \"$1/$2/$3\");\r\n var dateObj = new Date(dateStrNew);\r\n var month = dateObj.getMonth() + 1;\r\n if (parseInt(dateStr.substr(4, 2)) === month) {\r\n return checkCode(idCard);\r\n }\r\n }\r\n return false;\r\n },\r\n getFromIdCard: (idCard) => {\r\n var area = idCard.substr(0, 6);\r\n var birth = idCard.substr(6, 8).replace(/(\\d{4})(\\d{2})(\\d{2})/, '$1年$2月$3日');\r\n var age = new Date().getFullYear() - idCard.substr(6, 4) + 1;\r\n var sex = (idCard.substr(16, 1) % 2 === 0) ? '女' : '男';\r\n\r\n return {\r\n 'area': area,\r\n 'birth': birth,\r\n 'age': age,\r\n 'sex': sex\r\n };\r\n }\r\n};\r\n\r\nexport default Validation;","<template>\r\n <VDialog v-model=\"isActive\" persistent :width=\"options.width\">\r\n <VCard :color=\"options.color\">\r\n <VCardTitle>{{ options.title }}</VCardTitle>\r\n <VCardText v-if=\"options.text\">\r\n {{ options.text }}\r\n </VCardText>\r\n <VCardActions>\r\n <VSpacer />\r\n <VBtn text @click=\"close_modal\">确定</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VDialog>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js' // 根据实际路径调整\r\n\r\nconst messageStore = useMessageStore()\r\n\r\n\r\n// 使用 computed 获取响应式数据\r\nconst isActive = computed(() => messageStore.alert?.isActive || false)\r\nconst options = computed(() => messageStore.alert?.options || {})\r\n\r\n// 关闭模态框方法\r\nconst close_modal = () => {\r\n messageStore.hide('alert')\r\n}\r\n</script>","<template>\r\n <VDialog v-model=\"isActive\" persistent :max-width=\"options.width || 400\">\r\n <VCard :color=\"options.color\">\r\n <VCardTitle>{{ options.title }}</VCardTitle>\r\n <VCardText v-if=\"options.text\">\r\n {{ options.text }}\r\n </VCardText>\r\n <VCardActions>\r\n <VSpacer />\r\n <VBtn text @click=\"cancel\">{{ options.cancelText || '取消' }}</VBtn>\r\n <VBtn text @click=\"confirm\">{{ options.confirmText || '确定' }}</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VDialog>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst messageStore = useMessageStore()\r\n\r\n// 使用 computed 获取响应式数据\r\nconst isActive = computed(() => messageStore.confirm?.isActive || false)\r\nconst options = computed(() => messageStore.confirm?.options || {})\r\n\r\n// 确认操作\r\nconst confirm = () => {\r\n // 如果 options.onConfirm 存在则执行回调\r\n if (typeof options.value.onConfirm === 'function') {\r\n options.value.onConfirm()\r\n }\r\n messageStore.hide('confirm')\r\n}\r\n\r\n// 取消操作\r\nconst cancel = () => {\r\n // 如果 options.onCancel 存在则执行回调\r\n if (typeof options.value.onCancel === 'function') {\r\n options.value.onCancel()\r\n }\r\n messageStore.hide('confirm')\r\n}\r\n</script>","<template>\r\n <v-overlay v-model=\"isActive\" persistent class=\"align-center justify-center\" :style=\"{ zIndex: 9999 }\">\r\n <v-progress-circular indeterminate size=\"64\" width=\"6\" color=\"primary\"></v-progress-circular>\r\n </v-overlay>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst messageStore = useMessageStore()\r\n\r\nconst isActive = computed(() => messageStore.loading?.isActive || false)\r\n</script>\r\n","<template>\r\n <div class=\"text-center\">\r\n <vtk-alert />\r\n <vtk-confirm />\r\n <vtk-loading />\r\n <vtk-prompt />\r\n <vtk-toast />\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport vtkAlert from \"./alert.vue\";\r\nimport vtkConfirm from \"./confirm.vue\";\r\nimport vtkLoading from \"./loading.vue\";\r\nimport vtkPrompt from \"./prompt.vue\";\r\nimport vtkToast from \"./toast.vue\";\r\nexport default {\r\n name: \"vtkMessage\",\r\n components: {\r\n vtkAlert,\r\n vtkConfirm,\r\n vtkLoading,\r\n vtkPrompt,\r\n vtkToast,\r\n },\r\n};\r\n</script>","<template>\r\n <VDialog v-model=\"isActive\" persistent :width=\"options.width\">\r\n <VCard :color=\"options.color\">\r\n <VCardTitle>{{ options.title }}</VCardTitle>\r\n <VCardText>\r\n <VTextField\r\n v-model=\"inputValue\"\r\n :label=\"options.label\"\r\n :placeholder=\"options.placeholder\"\r\n :type=\"options.inputType || 'text'\"\r\n outlined\r\n dense\r\n />\r\n <div v-if=\"options.text\" class=\"mt-2\">\r\n {{ options.text }}\r\n </div>\r\n </VCardText>\r\n <VCardActions>\r\n <VSpacer />\r\n <VBtn text @click=\"cancel\">{{ options.cancelText || '取消' }}</VBtn>\r\n <VBtn text @click=\"confirm\">{{ options.confirmText || '确定' }}</VBtn>\r\n </VCardActions>\r\n </VCard>\r\n </VDialog>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed } from 'vue'\r\nimport { useMessageStore } from '../../stores/message.js'\r\n\r\nconst messageStore = useMessageStore()\r\nconst inputValue = ref('')\r\n\r\n// 使用 computed 获取响应式数据\r\nconst isActive = computed(() => messageStore.prompt?.isActive || false)\r\nconst options = computed(() => messageStore.prompt?.options || {})\r\n\r\n// 确认操作\r\nconst confirm = () => {\r\n // 如果 options.onConfirm 存在则执行回调\r\n if (typeof options.value.onConfirm === 'function') {\r\n options.value.onConfirm(inputValue.value)\r\n }\r\n messageStore.hide('prompt')\r\n inputValue.value = '' // 清空输入值\r\n}\r\n\r\n// 取消操作\r\nconst cancel = () => {\r\n // 如果 options.onCancel 存在则执行回调\r\n if (typeof options.value.onCancel === 'function') {\r\n options.value.onCancel()\r\n }\r\n messageStore.hide('prompt')\r\n inputValue.value = '' // 清空输入值\r\n}\r\n</script>","<template>\r\n\t<VSnackbar v-model=\"isActive\" :timeout=\"options.timeout > 0 ? options.timeout : 3000\" :color=\"options.color\" centered @update:modelValue=\"onModelUpdate\">\r\n\t\t{{ options.text }}\r\n\t\t<template v-slot:actions>\r\n\t\t\t<VBtn text icon @click=\"close_modal()\">\r\n\t\t\t\t<VIcon>mdi-close</VIcon>\r\n\t\t\t</VBtn>\r\n\t\t</template>\r\n\t</VSnackbar>\r\n</template>\r\n\r\n<script setup>\r\nimport { computed } from \"vue\";\r\nimport { useMessageStore } from \"../../stores/message.js\";\r\n\r\nconst messageStore = useMessageStore();\r\n\r\nconst isActive = computed({\r\n\tget: () => messageStore.toast?.isActive || false,\r\n\tset: (value) => {\r\n\t\tif (messageStore.toast) {\r\n\t\t\tmessageStore.toast.isActive = value;\r\n\t\t}\r\n\t},\r\n});\r\n\r\nconst options = computed(() => messageStore.toast?.options || {});\r\n\r\nconst close_modal = () => {\r\n\tmessageStore.hide(\"toast\");\r\n};\r\n\r\n// 监听模型值更新\r\nconst onModelUpdate = (value) => {\r\n\tif (!value) {\r\n\t\t// Snackbar 关闭时确保 store 状态同步\r\n\t\tmessageStore.hide(\"toast\");\r\n\t}\r\n};\r\n</script>\r\n<style lang=\"scss\" scoped>\r\n:deep(.v-snackbar__wrapper) {\r\n\ttop: 24px;\r\n}\r\n</style>\r\n","/**\r\n * Specter PUI - Vue 3 组件库\r\n */\r\n\r\nexport { default as VtkArea } from \"./components/assembly/VtkArea.vue\";\r\nexport { default as VtkAreaTabs } from \"./components/assembly/VtkAreaTabs.vue\";\r\nexport { default as VtkBreadcrumb } from \"./components/assembly/VtkBreadcrumb.vue\";\r\nexport { default as VtkCheckbox } from \"./components/assembly/VtkCheckbox.vue\";\r\nexport { default as VtkCount } from \"./components/assembly/VtkCount.vue\";\nexport { default as VtkDatePicker } from \"./components/assembly/VtkDatePicker.vue\";\nexport { default as VtkDateSelector } from \"./components/assembly/VtkDateSelector.vue\";\nexport { default as VtkDateTimePicker } from \"./components/assembly/VtkDateTimePicker.vue\";\nexport { default as VtkDept } from \"./components/assembly/VtkDept.vue\";\nexport { default as VtkEmpty } from \"./components/assembly/VtkEmpty.vue\";\r\nexport { default as VtkFab } from \"./components/assembly/VtkFab.vue\";\r\nexport { default as VtkFormItem } from \"./components/assembly/VtkFormItem.vue\";\r\nexport { default as VtkImg } from \"./components/assembly/VtkImg.vue\";\r\nexport { default as VtkPage } from \"./components/assembly/VtkPage.vue\";\r\nexport { default as VtkPdf } from \"./components/assembly/VtkPdf.vue\";\r\nexport { default as VtkProj } from \"./components/assembly/VtkProj.vue\";\r\nexport { default as VtkRadio } from \"./components/assembly/VtkRadio.vue\";\r\nexport { default as VtkSearch } from \"./components/assembly/VtkSearch.vue\";\r\nexport { default as VtkSelect } from \"./components/assembly/VtkSelect.vue\";\r\nexport { default as VtkStepper } from \"./components/assembly/VtkStepper.vue\";\r\nexport { default as VtkUpload } from \"./components/assembly/VtkUpload.vue\";\r\n\r\nexport * from \"./commons/location.js\";\r\nexport * from \"./commons/filters/dictionary.js\";\r\nexport * from \"./commons/filters/format.js\";\r\nexport * from \"./commons/filters/mask.js\";\r\nexport { default as request } from \"./commons/request.js\";\r\nexport { default as storage } from \"./commons/storage.js\";\r\nexport { default as themes } from \"./commons/themes.js\";\r\nexport * from \"./commons/validation.js\";\r\n\r\nexport { useMixins } from \"./composables/usePage.js\";\r\nexport { default as vtkMessage } from \"./components/message/index.js\";\r\n\r\nimport vtkMessage from \"./components/message/index.js\";\r\nimport storage from \"./commons/storage.js\";\r\nimport themes from \"./commons/themes.js\";\r\nimport request from \"./commons/request.js\";\r\nimport * as location from \"./commons/location.js\";\r\nimport Validation from \"./commons/validation.js\";\r\nimport * as dictionary from \"./commons/filters/dictionary.js\";\r\nimport * as mask from \"./commons/filters/mask.js\";\r\nimport * as format from \"./commons/filters/format.js\";\r\n\r\nimport VtkArea from \"./components/assembly/VtkArea.vue\";\r\nimport VtkAreaTabs from \"./components/assembly/VtkAreaTabs.vue\";\r\nimport VtkBreadcrumb from \"./components/assembly/VtkBreadcrumb.vue\";\r\nimport VtkCheckbox from \"./components/assembly/VtkCheckbox.vue\";\r\nimport VtkCount from \"./components/assembly/VtkCount.vue\";\nimport VtkDatePicker from \"./components/assembly/VtkDatePicker.vue\";\nimport VtkDateSelector from \"./components/assembly/VtkDateSelector.vue\";\nimport VtkDateTimePicker from \"./components/assembly/VtkDateTimePicker.vue\";\nimport VtkDept from \"./components/assembly/VtkDept.vue\";\nimport VtkEmpty from \"./components/assembly/VtkEmpty.vue\";\r\nimport VtkFab from \"./components/assembly/VtkFab.vue\";\r\nimport VtkFormItem from \"./components/assembly/VtkFormItem.vue\";\r\nimport VtkImg from \"./components/assembly/VtkImg.vue\";\r\nimport VtkPage from \"./components/assembly/VtkPage.vue\";\r\nimport VtkPdf from \"./components/assembly/VtkPdf.vue\";\r\nimport VtkProj from \"./components/assembly/VtkProj.vue\";\r\nimport VtkRadio from \"./components/assembly/VtkRadio.vue\";\r\nimport VtkSearch from \"./components/assembly/VtkSearch.vue\";\r\nimport VtkSelect from \"./components/assembly/VtkSelect.vue\";\r\nimport VtkStepper from \"./components/assembly/VtkStepper.vue\";\r\nimport VtkUpload from \"./components/assembly/VtkUpload.vue\";\r\nimport VtkMessageComponent from \"./components/message/vtkMessage.vue\";\r\n\r\nfunction install(app, options = {}) {\r\n const components = {\r\n VtkArea,\r\n VtkAreaTabs,\r\n VtkBreadcrumb,\r\n VtkCheckbox,\r\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDateTimePicker,\n VtkDept,\n VtkEmpty,\r\n VtkFab,\r\n VtkFormItem,\r\n VtkImg,\r\n VtkPage,\r\n VtkPdf,\r\n VtkProj,\r\n VtkRadio,\r\n VtkSearch,\r\n VtkSelect,\r\n VtkStepper,\r\n VtkUpload,\r\n VtkMessage: VtkMessageComponent\r\n };\r\n\r\n Object.keys(components).forEach(name => {\r\n app.component(name, components[name]);\r\n });\r\n\r\n app.config.globalProperties.$vtk = {\r\n message: vtkMessage,\r\n request,\r\n storage,\r\n themes,\r\n location,\r\n Validation,\r\n filters: {\r\n ...dictionary,\r\n ...mask,\r\n ...format\r\n },\r\n ...options\r\n };\r\n\r\n return app;\r\n}\r\n\r\nexport default {\r\n install,\r\n VtkArea,\r\n VtkAreaTabs,\r\n VtkBreadcrumb,\r\n VtkCheckbox,\r\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDateTimePicker,\n VtkDept,\n VtkEmpty,\r\n VtkFab,\r\n VtkFormItem,\r\n VtkImg,\r\n VtkPage,\r\n VtkPdf,\r\n VtkProj,\r\n VtkRadio,\r\n VtkSearch,\r\n VtkSelect,\r\n VtkStepper,\r\n VtkUpload,\r\n request,\r\n storage,\r\n themes,\r\n vtkMessage\r\n};\r\n"],"names":["Storage","storage","type","key","js","value","useMessageStore","defineStore","options","Message","messageStore","defaultOptions","text","toastOptions","service","axios","config","tokenKey","_b","_a","error","response","res","header","handleRedirect","url","index","newUrl","Request","data","method","headers","responseType","proxy","getCurrentInstance","emit","__emit","entity","reactive","user","ref","areaData","onMounted","userKey","area","nextArea","areaCode","inputFn","e","clear","arr","_openBlock","_createElementBlock","_hoisted_1","_createVNode","_component_VSelect","_cache","$event","__props","_createBlock","_c","_normalizeClass","_d","_e","_f","_g","_h","_i","_normalizeStyle","_j","props","menu","tab","tabItems","areaStorage","areaItems","current","itemValue","itemText","view","code","province","city","district","town","village","tabArea","areaChange","item","getTree","nextTick","getAreaName","save","val","lastItem","close","textClear","initCode","watch","newVal","oldVal","_component_v_menu","_withCtx","_component_v_btn","_mergeProps","$attrs","_createElementVNode","_toDisplayString","_component_v_icon","_component_v_card","_hoisted_2","_Fragment","_renderList","link","_component_v_sheet","_component_v_tabs","_component_v_tab","_createTextVNode","_vShow","_component_v_chip_group","_component_v_chip","_component_v_card_actions","_component_v_spacer","router","inject","route","breadcrumbItems","computed","matched","r","pathArray","p","path","routePath","handleBack","_component_v_breadcrumbs","_component_v_breadcrumbs_item","localValue","isUpdatingLocal","isUpdatingModel","attrs","useAttrs","inputAttrs","list","inline","modelValue","rest","checkboxAttrs","errorMessages","rules","hint","persistentHint","inputValue","items","statc","it","codeValue","miscs","_component_VInput","_component_VCheckbox","currentNumber","currentDigits","digitKey","isAnimating","formatNumber","num","result","targetNumberString","startNumberString","maxDigitString","target","start","getCurrentDigit","initDigitsArray","startStr","char","startChar","getDigitStyle","currentValue","digitValue","offset","translateY","startAnimation","startTime","startValue","endValue","diff","animate","currentTime","elapsed","progress","easeOutQuart","updateDigitArray","valueStr","maxStr","i","newStr","oldStr","endStr","__expose","digitChar","_hoisted_4","_hoisted_3","n","_hoisted_5","dateRange","startDateRange","endDateRange","displayValue","formatDate","textFieldProps","placeholder","disabled","min","max","showCurrent","format","separator","date","year","month","day","minDate","maxDate","newValue","dates","onStartDateChange","onEndDateChange","clearValue","cancel","confirm","sortedRange","date1","date2","_component_VMenu","activatorProps","_component_VTextField","_component_VIcon","_component_VCard","_component_VCardText","_component_VDatePicker","_component_VDivider","_component_VCardActions","_component_VSpacer","_component_VBtn","YEAR_PANEL_SIZE","YEAR_PANEL_CENTER_OFFSET","showPicker","viewMode","currentYear","currentMonth","rightYear","rightMonth","selectedValue","tempValue","today","todayYear","todayMonth","todayDate","weekDays","monthList","menuAttach","menuLocation","menuOrigin","formatDisplay","week","yearList","startYear","_","weekList","weeks","firstDay","lastDay","currentDate","weekNumber","getWeekNumber","isToday","dayList","days","startDate","endDate","nextMonthYear","nextMonthMonth","nextMonthDayList","d","dayNum","yearStart","isYearSelected","v","isYearInRange","end","isMonthSelected","monthStr","isMonthInRange","isWeekSelected","weekStr","isWeekInRange","isDaySelected","isDayInRange","isDayRangeStart","isDayRangeEnd","isFutureYear","isFutureMonth","isFutureDay","selectYear","yearStr","first","selectMonth","selectMonthRight","isMonthSelectedRight","isMonthInRangeRight","selectWeek","selectDay","prevPeriod","nextPeriod","prevMonth","nextMonthLeft","prevMonthRight","nextMonth","prevYear","nextYearLeft","prevYearRight","nextYear","changeViewMode","mode","initializePicker","isOpen","closePicker","handleCancel","handleConfirm","menuProps","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","_hoisted_16","_hoisted_17","_hoisted_18","_hoisted_19","_hoisted_20","_hoisted_21","_hoisted_22","_hoisted_23","_hoisted_24","_hoisted_25","_hoisted_27","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","_hoisted_36","_hoisted_37","_hoisted_38","_hoisted_39","_hoisted_40","_hoisted_41","_hoisted_42","_hoisted_43","_hoisted_44","_hoisted_45","_hoisted_46","_hoisted_47","_hoisted_48","_hoisted_49","_hoisted_50","_hoisted_51","_hoisted_52","_hoisted_53","_hoisted_54","_hoisted_55","_hoisted_56","_hoisted_57","_hoisted_58","_hoisted_59","_hoisted_60","_hoisted_61","_hoisted_62","_hoisted_63","_hoisted_64","_hoisted_65","_hoisted_66","_hoisted_67","_hoisted_68","_hoisted_69","_hoisted_70","_hoisted_71","_hoisted_73","_hoisted_74","_hoisted_75","_hoisted_76","_hoisted_77","_hoisted_78","_hoisted_79","_hoisted_80","_hoisted_81","_hoisted_82","_hoisted_83","_hoisted_84","_hoisted_85","_hoisted_86","_hoisted_87","_hoisted_88","_hoisted_89","_hoisted_90","_hoisted_91","_hoisted_92","_hoisted_93","_hoisted_94","defaultStartTime","defaultEndTime","selectedDateTime","selectedRange","tempDate","tempRange","leftYear","leftMonth","selectedHour","selectedMinute","selectedSecond","activeRangeSide","activeTimeSide","activeSingleTime","isRange","menuWidth","minDateTime","parseValue","maxDateTime","hourOptions","minuteOptions","buildStepOptions","secondOptions","getDayList","leftDayList","rightDayList","formatByPattern","buildTempDateTime","singleTimeValue","pattern","canConfirm","isDateTimeDisabled","activeRangeDate","activeRangeHour","activeRangeMinute","activeRangeSecond","step","normalizedStep","startDay","daysInMonth","daysInPrevMonth","createDay","otherMonth","isSameDate","padTime","replacements","token","formatDatePart","formatTimePart","match","fallback","hour","minute","second","parseRangeValue","toModelValue","toModelRange","range","left","right","isYearDisabled","isMonthDisabled","isDayDisabled","isTimePartDisabled","isRangeDaySelected","side","isRangeDayInRange","rangeDayClass","setSinglePanelFromDate","setRangePanelsFromDate","base","prevLeftMonth","nextRightMonth","selectRangeDay","selected","currentStart","currentEnd","selectHour","selectMinute","selectSecond","openRangeTime","selectRangeTime","part","clearTempRange","nextValue","handleNow","now","_hoisted_26","pause","ms","resolve","dialog","areaSelectedData","areaActivatedData","getDeptList","getAreaList","getAreaNextList","parentCode","deptData","deptSelectedData","deptActivatedData","getPersonList","node","params","getDepNextList","selectAreaCode","selectPid","personData","selectedPersonData","allSelectedPersons","isRestoringSelection","selectedPersonList","uniqueMap","person","oldPerson","newPersonData","currentSelected","removeSelectedPerson","personId","globalIndex","currentIndex","add","selectedPersons","_component_v_dialog","_component_v_card_title","_component_v_divider","_component_v_card_text","_component_v_row","_component_v_col","_component_v_treeview","_component_v_avatar","_component_v_img","_component_v_list","_component_v_list_item","_component_v_empty_state","$slots","_renderSlot","_ctx","showFab","fabClass","handleScroll","scrollToTop","onBeforeUnmount","_Transition","_component_v_fab","processedMaxWidth","contentStyles","styles","showPreview","imageRotation","imageScale","imageTranslateX","imageTranslateY","imageDragState","srcWithToken","currentImageUrl","currentImage","currentImageTitle","currentImageDescription","hasPrev","hasNext","viewerImageStyle","resetImageTransform","openPreview","closePreview","prevImage","nextImage","rotateImage","degrees","zoomImage","nextScale","handleImageWheel","event","startImageDrag","moveImageDrag","endImageDrag","state","_component_v_progress_circular","_component_VCardTitle","_component_v_card_subtitle","_component_VDialog","_component_v_toolbar","_component_v_toolbar_title","_component_v_toolbar_items","pagination","pageSizeObjs","pageDatas","paginationChange","pageChange","pageSizeFormat","toPage","pageSizeChange","temp","obj","page","_component_VRow","_component_v_pagination","loading","pdfLoaded","currentPage","pageCount","pdfContainer","pdfDoc","loadPdf","renderPage","pageNum","prevPage","nextPage","downloadPdf","blob","fileName","_component_VCol","_component_VSlider","useMixins","urlConfig","queryParam","desserts","superQueryParams","pageData","sumup","pageDataCopy","overlay","getQueryParams","codex","loadPage","pageInfo","id","record","modalFormRef","disposition","filename","newUrlConfig","getListPage","expData","mixinQueryParam","examType","permits","projName","projTip","bizType","expShow","menu1","expArr","formArr","select","selectAll","delItem","delNote","MprojRef","onActivated","examAll","chkAll","getUserInfo","examWait","toView","searchProj","param","searchQuery","exv","exp","del","delSave","tip","formatIdCard","idcard","dateStr","getServStateClass","getServStateText","getRateStateClass","getRateStateText","getServFromText","from","_component_VContainer","_component_VTabs","_component_VTab","_unref","_component_vtk_search","_component_vtk_area_tabs","_component_vtk_select","_component_VDataTable","_component_VChip","_component_vtk_empty","_component_vtk_page","_component_vtk_proj","_component_VTextarea","onUpdate","_component_VRadioGroup","_component_VRadio","instance","cloneValue","cloneQueryParam","source","isSameValue","a","b","initialQueryParam","externalQueryParam","initialIndex","initVal","contentStyle","minValue","maxValue","minHeight","maxHeight","nextExternalQueryParam","nextQueryParam","obtain","filterNull","search","reset","handleResetClick","_component_VBadge","filteredAttrs","multi","its","$emit","stepIndex","content","_component_VStepper","_component_VStepperHeader","_component_VStepperWindow","_component_VStepperWindowItem","inputRef","isDragover","previewVisible","previewFile","previewScale","previewRotation","previewTranslateX","previewTranslateY","previewDragState","fileList","isSyncingModel","normalizeFileList","uidCounter","genUid","getFileNameFromUrl","cleanUrl","name","isImage","file","fileIcon","previewImageStyle","triggerInput","onDragover","onDrop","processFiles","onInputChange","rawFiles","raw","errFile","buildFile","reader","beforeHook","addFile","uploadFile","status","syncModel","urls","f","formData","k","err","handleRemove","doRemove","isExcel","resetPreviewTransform","rotatePreview","zoomPreview","startPreviewDrag","movePreviewDrag","endPreviewDrag","openFileInNewTab","fileUrl","blobUrl","win","openCurrentPreview","handlePreview","visible","_withModifiers","_component_v_progress_linear","isAid","str","getLinkFromResponse","buildUrlWithParams","appendParams","queryString","queryParams","newParams","joinSymbol","appendParamsToUrl","targetUrl","hashIndex","baseUrl","hashRoute","newHashRoute","resolveAidUrl","aid","buildAppendParams","sobject","sroute","stokenKey","storageKey","stoken","GetQueryString","reg","appendAppParams","dict","map","pre","maps","results","j","currentVal","kv","analyType","analyLevel","fmt","getDate","o","numValue","neg","absValue","fix","needSep","xs","decimalPart","integerPart","age","birthdays","txt","len","abs","mobile","colors","themes","Validation","input","this","idCard","checkCode","multiplier","ids","sum","remainder","checkCodeArr","dateStrNew","dateObj","birth","sex","isActive","close_modal","_component_v_overlay","_sfc_main","vtkAlert","vtkConfirm","vtkLoading","onModelUpdate","_component_VSnackbar","_component_vtk_alert","_component_vtk_confirm","_component_vtk_loading","_component_vtk_prompt","_component_vtk_toast","install","app","components","VtkArea","VtkAreaTabs","VtkBreadcrumb","VtkCheckbox","VtkCount","VtkDatePicker","VtkDateSelector","VtkDateTimePicker","VtkDept","VtkEmpty","VtkFab","VtkFormItem","VtkImg","VtkPage","VtkPdf","VtkProj","VtkRadio","VtkSearch","VtkSelect","VtkStepper","VtkUpload","VtkMessageComponent","vtkMessage","request","location","dictionary","mask"],"mappings":"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","x_google_ignoreList":[30]}
|