@yxhl/specter-pui-vtk 1.0.78 → 1.0.79
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.
|
@@ -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\"\r\n :class=\"left && !help ? 'vtk-width-9' : '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\">\r\n <VBtn icon dark @click=\"closePreview\">\r\n <VIcon>mdi-close</VIcon>\r\n </VBtn>\r\n <v-toolbar-title>{{ currentImageTitle }}</v-toolbar-title>\r\n <VSpacer></VSpacer>\r\n <v-toolbar-items>\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 </v-toolbar-items>\r\n </v-toolbar>\r\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\">\r\n <v-img\r\n :src=\"currentImageUrl\"\r\n class=\"viewer-image\"\r\n :style=\"{ transform: `rotate(${imageRotation}deg)` }\"\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 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\n// 监听预览状态变化\r\nwatch(showPreview, (newVal) => {\r\n if (newVal) {\r\n // 打开预览时重置旋转角度和当前索引\r\n imageRotation.value = 0;\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 imageRotation.value = 0; // 切换图片时重置旋转\r\n }\r\n};\r\n\r\n// 下一张图片\r\nconst nextImage = () => {\r\n if (hasNext.value) {\r\n currentIndex.value++;\r\n imageRotation.value = 0; // 切换图片时重置旋转\r\n }\r\n};\r\n\r\n// 旋转图片\r\nconst rotateImage = (degrees) => {\r\n imageRotation.value += degrees;\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 transition: transform 0.3s ease;\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>","<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'\"\r\n :class=\"['vtk-upload__dragger', { 'is-dragover': isDragover, 'is-disabled': disabled }]\"\r\n @click=\"!disabled && triggerInput()\"\r\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 v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handlePreview(file)\">\r\n <VIcon>mdi-eye</VIcon>\r\n </VBtn>\r\n <VBtn v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handleRemove(file)\">\r\n <VIcon>mdi-delete</VIcon>\r\n </VBtn>\r\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 && (limit === 0 || fileList.length < limit)\"\r\n :class=\"['vtk-upload__picture-card-add', { 'is-dragover': isDragover }]\"\r\n @click=\"triggerInput()\"\r\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\"\r\n icon\r\n size=\"x-small\"\r\n variant=\"text\"\r\n color=\"grey\"\r\n class=\"ml-1\"\r\n @click=\"handleRemove(file)\"\r\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\" max-width=\"800\">\r\n <VCard>\r\n <v-card-title class=\"d-flex align-center bg-primary\">\r\n\t\t\t\t{{ previewFile?.name }}\r\n\t\t\t\t<v-spacer></v-spacer>\r\n\t\t\t\t<v-btn class=\"mx-0\" icon @click=\"previewVisible = false\" variant=\"plain\">\r\n\t\t\t\t\t<v-icon>mdi-close</v-icon>\r\n\t\t\t\t</v-btn>\r\n\t\t\t</v-card-title>\r\n <div class=\"pa-4 d-flex justify-center\">\r\n <v-img v-if=\"isImage(previewFile)\" :src=\"previewFile?._previewSrc\" max-height=\"600\" contain />\r\n <div v-else class=\"text-center pa-8 text-grey\">\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\">该文件暂时无法在线预览</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 { 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: {\r\n type: Boolean,\r\n default: false,\r\n },\r\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\n\r\n// 内部维护文件列表\r\nconst fileList = ref([...(props.modelValue || [])]);\r\n\r\nwatch(\r\n () => props.modelValue,\r\n (val) => {\r\n // 外部传入字符串数组(url 列表)时跳过,避免覆盖内部状态\r\n if (!val?.length || typeof val[0] === 'string') return;\r\n fileList.value = [...val];\r\n },\r\n);\r\n\r\n/* -------------------- 工具函数 -------------------- */\r\nlet uidCounter = 0;\r\nconst genUid = () => `vtk-upload-${Date.now()}-${uidCounter++}`;\r\n\r\nconst isImage = (file) => {\r\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\n/* -------------------- 触发 input -------------------- */\r\nconst triggerInput = () => {\r\n inputRef.value && inputRef.value.click();\r\n};\r\n\r\n/* -------------------- 拖拽 -------------------- */\r\nconst onDragover = () => {\r\n if (!props.disabled) isDragover.value = true;\r\n};\r\n\r\nconst onDrop = (e) => {\r\n isDragover.value = false;\r\n if (props.disabled) return;\r\n processFiles(Array.from(e.dataTransfer.files));\r\n};\r\n\r\n/* -------------------- input change -------------------- */\r\nconst onInputChange = (e) => {\r\n processFiles(Array.from(e.target.files));\r\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 isPdf = (file) => /\\.pdf$/i.test(file?.name || '') || file?.type === 'application/pdf';\r\nconst isExcel = (file) => /\\.(xlsx|xls)$/i.test(file?.name || '');\r\n\r\nconst handlePreview = (file) => {\r\n emit('preview', file);\r\n\r\n const fileUrl = file.url || file.preview;\r\n\r\n // PDF:新标签页直接打开(浏览器原生支持)\r\n if (isPdf(file)) {\r\n if (fileUrl) {\r\n window.open(fileUrl, '_blank');\r\n } else if (file.raw instanceof File || file.raw instanceof Blob) {\r\n // 本地未上传文件,用 Blob URL 打开\r\n const blobUrl = URL.createObjectURL(file.raw);\r\n const win = window.open(blobUrl, '_blank');\r\n win?.addEventListener('unload', () => URL.revokeObjectURL(blobUrl));\r\n } else {\r\n // 无可用地址也无本地文件,降级到 Dialog\r\n previewFile.value = { ...file, _previewSrc: fileUrl };\r\n previewVisible.value = true;\r\n }\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)) {\r\n window.open(`https://view.officeapps.live.com/op/view.aspx?src=${encodeURIComponent(fileUrl)}`, '_blank');\r\n } else {\r\n // 无公网地址,降级为 Dialog 显示提示\r\n previewFile.value = { ...file, _previewSrc: fileUrl };\r\n previewVisible.value = true;\r\n }\r\n return;\r\n }\r\n\r\n // 图片及其他:Dialog 内嵌预览\r\n // 统一挂载可用的预览地址,供 Dialog 使用\r\n previewFile.value = {\r\n ...file,\r\n _previewSrc: fileUrl,\r\n };\r\n previewVisible.value = true;\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</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","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","p","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","srcWithToken","currentImageUrl","currentImage","currentImageTitle","currentImageDescription","hasPrev","hasNext","openPreview","closePreview","prevImage","nextImage","rotateImage","degrees","_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","event","examAll","chkAll","getUserInfo","examWait","toView","searchProj","param","searchQuery","exv","exp","del","delSave","tip","formatIdCard","idcard","dateStr","getServStateClass","state","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","fileList","uidCounter","genUid","isImage","file","fileIcon","triggerInput","onDragover","onDrop","processFiles","onInputChange","rawFiles","raw","errFile","buildFile","reader","beforeHook","addFile","uploadFile","status","syncModel","urls","f","formData","k","err","handleRemove","doRemove","isPdf","isExcel","handlePreview","fileUrl","blobUrl","win","_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","name","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\">\r\n <VBtn icon dark @click=\"closePreview\">\r\n <VIcon>mdi-close</VIcon>\r\n </VBtn>\r\n <v-toolbar-title>{{ currentImageTitle }}</v-toolbar-title>\r\n <VSpacer></VSpacer>\r\n <v-toolbar-items>\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 </v-toolbar-items>\r\n </v-toolbar>\r\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\">\r\n <v-img\r\n :src=\"currentImageUrl\"\r\n class=\"viewer-image\"\r\n :style=\"{ transform: `rotate(${imageRotation}deg)` }\"\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 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\n// 监听预览状态变化\r\nwatch(showPreview, (newVal) => {\r\n if (newVal) {\r\n // 打开预览时重置旋转角度和当前索引\r\n imageRotation.value = 0;\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 imageRotation.value = 0; // 切换图片时重置旋转\r\n }\r\n};\r\n\r\n// 下一张图片\r\nconst nextImage = () => {\r\n if (hasNext.value) {\r\n currentIndex.value++;\r\n imageRotation.value = 0; // 切换图片时重置旋转\r\n }\r\n};\r\n\r\n// 旋转图片\r\nconst rotateImage = (degrees) => {\r\n imageRotation.value += degrees;\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 transition: transform 0.3s ease;\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>","<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'\"\r\n :class=\"['vtk-upload__dragger', { 'is-dragover': isDragover, 'is-disabled': disabled }]\"\r\n @click=\"!disabled && triggerInput()\"\r\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 v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handlePreview(file)\">\r\n <VIcon>mdi-eye</VIcon>\r\n </VBtn>\r\n <VBtn v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handleRemove(file)\">\r\n <VIcon>mdi-delete</VIcon>\r\n </VBtn>\r\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 && (limit === 0 || fileList.length < limit)\"\r\n :class=\"['vtk-upload__picture-card-add', { 'is-dragover': isDragover }]\"\r\n @click=\"triggerInput()\"\r\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\"\r\n icon\r\n size=\"x-small\"\r\n variant=\"text\"\r\n color=\"grey\"\r\n class=\"ml-1\"\r\n @click=\"handleRemove(file)\"\r\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\" max-width=\"800\">\r\n <VCard>\r\n <v-card-title class=\"d-flex align-center bg-primary\">\r\n\t\t\t\t{{ previewFile?.name }}\r\n\t\t\t\t<v-spacer></v-spacer>\r\n\t\t\t\t<v-btn class=\"mx-0\" icon @click=\"previewVisible = false\" variant=\"plain\">\r\n\t\t\t\t\t<v-icon>mdi-close</v-icon>\r\n\t\t\t\t</v-btn>\r\n\t\t\t</v-card-title>\r\n <div class=\"pa-4 d-flex justify-center\">\r\n <v-img v-if=\"isImage(previewFile)\" :src=\"previewFile?._previewSrc\" max-height=\"600\" contain />\r\n <div v-else class=\"text-center pa-8 text-grey\">\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\">该文件暂时无法在线预览</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 { 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: {\r\n type: Boolean,\r\n default: false,\r\n },\r\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\n\r\n// 内部维护文件列表\r\nconst fileList = ref([...(props.modelValue || [])]);\r\n\r\nwatch(\r\n () => props.modelValue,\r\n (val) => {\r\n // 外部传入字符串数组(url 列表)时跳过,避免覆盖内部状态\r\n if (!val?.length || typeof val[0] === 'string') return;\r\n fileList.value = [...val];\r\n },\r\n);\r\n\r\n/* -------------------- 工具函数 -------------------- */\r\nlet uidCounter = 0;\r\nconst genUid = () => `vtk-upload-${Date.now()}-${uidCounter++}`;\r\n\r\nconst isImage = (file) => {\r\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\n/* -------------------- 触发 input -------------------- */\r\nconst triggerInput = () => {\r\n inputRef.value && inputRef.value.click();\r\n};\r\n\r\n/* -------------------- 拖拽 -------------------- */\r\nconst onDragover = () => {\r\n if (!props.disabled) isDragover.value = true;\r\n};\r\n\r\nconst onDrop = (e) => {\r\n isDragover.value = false;\r\n if (props.disabled) return;\r\n processFiles(Array.from(e.dataTransfer.files));\r\n};\r\n\r\n/* -------------------- input change -------------------- */\r\nconst onInputChange = (e) => {\r\n processFiles(Array.from(e.target.files));\r\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 isPdf = (file) => /\\.pdf$/i.test(file?.name || '') || file?.type === 'application/pdf';\r\nconst isExcel = (file) => /\\.(xlsx|xls)$/i.test(file?.name || '');\r\n\r\nconst handlePreview = (file) => {\r\n emit('preview', file);\r\n\r\n const fileUrl = file.url || file.preview;\r\n\r\n // PDF:新标签页直接打开(浏览器原生支持)\r\n if (isPdf(file)) {\r\n if (fileUrl) {\r\n window.open(fileUrl, '_blank');\r\n } else if (file.raw instanceof File || file.raw instanceof Blob) {\r\n // 本地未上传文件,用 Blob URL 打开\r\n const blobUrl = URL.createObjectURL(file.raw);\r\n const win = window.open(blobUrl, '_blank');\r\n win?.addEventListener('unload', () => URL.revokeObjectURL(blobUrl));\r\n } else {\r\n // 无可用地址也无本地文件,降级到 Dialog\r\n previewFile.value = { ...file, _previewSrc: fileUrl };\r\n previewVisible.value = true;\r\n }\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)) {\r\n window.open(`https://view.officeapps.live.com/op/view.aspx?src=${encodeURIComponent(fileUrl)}`, '_blank');\r\n } else {\r\n // 无公网地址,降级为 Dialog 显示提示\r\n previewFile.value = { ...file, _previewSrc: fileUrl };\r\n previewVisible.value = true;\r\n }\r\n return;\r\n }\r\n\r\n // 图片及其他:Dialog 内嵌预览\r\n // 统一挂载可用的预览地址,供 Dialog 使用\r\n previewFile.value = {\r\n ...file,\r\n _previewSrc: fileUrl,\r\n };\r\n previewVisible.value = true;\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</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","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","p","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","srcWithToken","currentImageUrl","currentImage","currentImageTitle","currentImageDescription","hasPrev","hasNext","openPreview","closePreview","prevImage","nextImage","rotateImage","degrees","_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","event","examAll","chkAll","getUserInfo","examWait","toView","searchProj","param","searchQuery","exv","exp","del","delSave","tip","formatIdCard","idcard","dateStr","getServStateClass","state","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","fileList","uidCounter","genUid","isImage","file","fileIcon","triggerInput","onDragover","onDrop","processFiles","onInputChange","rawFiles","raw","errFile","buildFile","reader","beforeHook","addFile","uploadFile","status","syncModel","urls","f","formData","k","err","handleRemove","doRemove","isPdf","isExcel","handlePreview","fileUrl","blobUrl","win","_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","name","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]}
|