@yxhl/specter-pui-vtk 1.0.74 → 1.0.76

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/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\" ref=\"selectorRef\">\r\n <div v-if=\"!inline\" class=\"date-input\" ref=\"inputRef\" @click=\"togglePicker\">\r\n <input type=\"text\" :value=\"displayValue\" :placeholder=\"placeholder\" :disabled=\"disabled\" readonly\r\n class=\"date-input-field\" />\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 />\r\n </svg>\r\n </span>\r\n <span v-if=\"displayValue && !disabled\" class=\"clear-icon\" @click.stop=\"clearValue\">✕</span>\r\n </div>\r\n\r\n <!-- 使用 Teleport 将下拉框渲染到 body 下,避免被父容器裁剪 -->\r\n <Teleport to=\"body\" :disabled=\"inline || noTeleport\">\r\n <div v-if=\"showPicker && !inline\" class=\"date-picker-mask\" @click=\"closePicker\"></div>\r\n <div v-if=\"showPicker || inline\" :class=\"['date-picker-dropdown', { 'inline-mode': inline, 'no-teleport-mode': noTeleport, 'align-right': noTeleport && placement === 'right' }]\"\r\n :style=\"noTeleport ? {} : dropdownStyle\" @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')\" class=\"clickable\">{{ 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 </Teleport>\r\n </div>\r\n</template>\r\n\r\n<script setup>\r\nimport { ref, computed, watch, nextTick } 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 树内(用于嵌套在 VMenu 等弹窗组件中时)\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\nconst selectorRef = ref(null);\r\nconst inputRef = ref(null);\r\nconst dropdownStyle = ref({});\r\n\r\n// 当前日期(用于判断未来日期)\r\nconst today = new Date();\r\nconst todayYear = today.getFullYear();\nconst todayMonth = today.getMonth();\nconst todayDate = today.getDate();\n\n// 年份面板固定展示 12 个年份,并尽量让锚点年份落在中间偏前位置\nconst YEAR_PANEL_SIZE = 12;\nconst YEAR_PANEL_CENTER_OFFSET = 4;\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 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(() => {\n // 年份面板打开时,以当前锚点年份为中心生成 12 个年份选项\n const startYear = currentYear.value - YEAR_PANEL_CENTER_OFFSET;\n return Array.from({ length: YEAR_PANEL_SIZE }, (_, i) => startYear + i);\n});\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 console.log('selectMonth', month);\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 togglePicker = () => {\n if (props.disabled) return;\n showPicker.value = !showPicker.value;\n if (showPicker.value) {\n // 年份单选打开面板时,优先围绕当前自然年展示年份列表\n if (props.displayMode === 'year' && props.mode === 'single') {\n currentYear.value = todayYear;\n }\n\n tempValue.value = selectedValue.value ?\n (Array.isArray(selectedValue.value) ? [...selectedValue.value] : selectedValue.value) :\n (props.mode === 'range' ? [] : null);\n viewMode.value = props.displayMode;\r\n\r\n // 初始化右侧日历/年份\r\n if (props.displayMode === 'month') {\r\n // 月份范围选择:右侧年份为左侧年份+1\r\n rightYear.value = currentYear.value + 1;\r\n } else {\r\n // 日期范围选择:右侧日历为左侧日历的下一个月\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\n nextTick(() => {\r\n if (inputRef.value) {\r\n const rect = inputRef.value.getBoundingClientRect();\r\n // 根据模式和面板数量确定宽度\r\n let dropdownWidth = 360; // 默认单面板宽度\r\n if (props.mode === 'range' && !props.singlePanel) {\r\n // 双面板模式\r\n dropdownWidth = 465;\r\n } else if (props.displayMode === 'week') {\r\n // 周选择模式需要更宽的空间\r\n dropdownWidth = 465;\r\n }\r\n const alignStyle = props.placement === 'right'\r\n ? { right: `${window.innerWidth - rect.right}px` }\r\n : { left: `${rect.left}px` };\r\n dropdownStyle.value = {\r\n position: 'fixed',\r\n top: `${rect.bottom + 4}px`,\r\n ...alignStyle,\r\n width: `${dropdownWidth}px`,\r\n zIndex: 99999\r\n };\r\n }\r\n });\r\n }\r\n};\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 position: relative;\r\n display: flex;\r\n align-items: center;\r\n border: 1px solid rgb(var(--v-theme-on-surface), 0.3);\r\n border-radius: 4px;\r\n padding: 0 12px;\r\n background: rgb(var(--v-theme-surface));\r\n cursor: pointer;\r\n transition: border-color 0.2s;\r\n}\r\n\r\n.date-input:hover {\r\n border-color: rgb(var(--v-theme-on-surface), 0.8);\r\n}\r\n\r\n.date-input-field {\r\n flex: 1;\r\n border: none;\r\n outline: none;\r\n padding: 8px 0;\r\n font-size: 14px;\r\n cursor: pointer;\r\n background: transparent;\r\n color: rgb(var(--v-theme-on-surface), 0.8);\r\n}\r\n\r\n.date-input-field::placeholder {\r\n color: rgba(var(--v-theme-on-surface), var(--v-disabled-opacity));\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: 8px;\r\n color: rgb(var(--v-theme-on-surface), 0.6);\r\n font-size: 14px;\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-mask {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n z-index: 99998;\r\n}\r\n\r\n.date-picker-dropdown {\r\n position: fixed;\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 z-index: 99999;\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 position: relative;\r\n top: 0;\r\n left: 0;\r\n box-shadow: none;\r\n width: fit-content;\r\n border: none;\r\n}\r\n\r\n.date-picker-dropdown.no-teleport-mode {\r\n position: absolute;\r\n top: calc(100% + 4px);\r\n left: 0;\r\n z-index: 99999;\r\n}\r\n\r\n.date-picker-dropdown.no-teleport-mode.align-right {\r\n left: auto;\r\n right: 0;\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","<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 console.log('user.areacode=', user.areacode);\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>\n <div class=\"search\">\n <VMenu\n v-model=\"menu\"\n @update:model-value=\"obtain\"\n location=\"bottom end\"\n origin=\"top end\"\n offset=\"12\"\n :close-on-content-click=\"false\"\n >\n <template v-slot:activator=\"{ props }\">\n <VTextField\n v-model=\"queryParam.condition\"\n :placeholder=\"$attrs.placeholder || '请输入查询内容'\"\n :style=\"$attrs.styles\"\n class=\"box\"\n density=\"compact\"\n variant=\"outlined\"\n hide-details\n @click:append=\"search\"\n @keyup.enter=\"search\"\n @click:clear=\"(queryParam.condition = ''), search()\"\n clearable\n >\n <template v-slot:append-inner>\n <VBadge\n dot\n :content=\"initialIndex\"\n :model-value=\"initialIndex > 0\"\n color=\"error\"\n class=\"advanced-badge\"\n >\n <span\n v-bind=\"props\"\n class=\"text-blue vtk-cursor-pointer d-inline-flex align-center text-body-2\"\n >\n 高级\n </span>\n </VBadge>\n </template>\n </VTextField>\n </template>\n\n <VCard style=\"width: 380px; margin-right: -16px; overflow: visible;\">\n <VCardTitle class=\"pr-3 d-flex justify-space-between align-center pb-5\">\n <span>高级搜索</span>\n <VBtn class=\"mx-0\" variant=\"text\" icon @click=\"close\" size=\"small\">\n <VIcon>mdi-close</VIcon>\n </VBtn>\n </VCardTitle>\n\n <VCardText style=\"overflow: visible;\">\n <slot :query-param=\"queryParam\"></slot>\n </VCardText>\n\n <VCardActions class=\"pt-0 px-4 pb-3\">\n <slot name=\"actions\"></slot>\n <VSpacer />\n <VBtn @click=\"search\" variant=\"flat\" color=\"primary\">\n <VIcon class=\"mr-1\">mdi-magnify</VIcon>搜索\n </VBtn>\n <VBtn @click=\"handleResetClick\" variant=\"flat\" color=\"error\">\n <VIcon class=\"mr-1\">mdi-sync</VIcon>重置\n </VBtn>\n </VCardActions>\n </VCard>\n </VMenu>\n </div>\n</template>\n\n<script setup>\nimport { computed, getCurrentInstance, onMounted, ref, watch } from 'vue';\n\ndefineOptions({\n name: \"VtkSearch\"\n});\n\nconst props = defineProps({\n value: {\n type: Object,\n default: () => ({})\n }\n});\n\nconst emit = defineEmits(['update:value', 'search', 'reset']);\nconst instance = getCurrentInstance();\n\nconst user = ref({});\nconst menu = ref(false);\nconst queryParam = ref({ ...props.value });\nconst initialQueryParam = ref({ ...props.value });\n\nconst initialIndex = computed(() => {\n return Object.entries(queryParam.value).filter(([key, val]) => {\n if (key === 'condition') return false;\n const initVal = initialQueryParam.value[key];\n if (Array.isArray(val) && Array.isArray(initVal)) {\n return JSON.stringify(val) !== JSON.stringify(initVal);\n }\n return val !== initVal;\n }).length;\n});\n\nwatch(\n () => props.value,\n (newVal) => {\n queryParam.value = { ...newVal };\n }\n);\n\nonMounted(() => {\n user.value = JSON.parse(localStorage.getItem(\"_mis_acis_users\") || \"{}\");\n});\n\nconst obtain = () => {};\n\nconst close = () => {\n menu.value = false;\n obtain();\n};\n\nconst filterNull = (obj) => {\n return Object.fromEntries(Object.entries(obj).filter(([, v]) => v !== null && v !== undefined));\n};\n\nconst search = () => {\n close();\n emit('update:value', filterNull(queryParam.value));\n emit(\"search\");\n};\n\nconst reset = () => {\n queryParam.value = {\n ...initialQueryParam.value,\n condition: ''\n };\n emit('update:value', filterNull(queryParam.value));\n emit(\"search\");\n menu.value = false;\n};\n\nconst handleResetClick = () => {\n const hasParentResetHandler = Boolean(instance?.vnode.props?.onReset);\n\n if (hasParentResetHandler) {\n emit('reset', { ...queryParam.value });\n return;\n }\n\n reset();\n};\n\ndefineExpose({ search, reset });\n\n</script>\n\n<style lang=\"scss\" scoped>\n.search {\n position: relative;\n min-width: 380px;\n min-height: 40px;\n}\n\n.box {\n min-width: 380px;\n min-height: 40px;\n}\n\n:deep(.box .v-field__append-inner) {\n cursor: pointer;\n padding-left: 16px !important;\n padding-right: 4px !important;\n border-left: 1px #cccccc88 solid;\n min-width: 50px;\n display: flex;\n align-items: center;\n}\n\n:deep(.advanced-badge .v-badge__badge) {\n transform: translate(10px, -2px);\n}\n</style>\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: -70px;\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>\n <div class=\"vtk-upload\">\n <!-- 拖拽 / 点击上传区域 -->\n <div\n v-if=\"listType !== 'picture-card'\"\n :class=\"['vtk-upload__dragger', { 'is-dragover': isDragover, 'is-disabled': disabled }]\"\n @click=\"!disabled && triggerInput()\"\n @dragover.prevent=\"onDragover\"\n @dragleave.prevent=\"isDragover = false\"\n @drop.prevent=\"onDrop\"\n >\n <slot>\n <div class=\"vtk-upload__dragger-inner\">\n <VIcon size=\"40\" color=\"grey-lighten-1\">mdi-cloud-upload-outline</VIcon>\n <div class=\"text-body-2 mt-2 text-grey\">将文件拖到此处,或<span class=\"text-primary\" style=\"cursor:pointer\">点击上传</span></div>\n <div v-if=\"tip\" class=\"text-caption text-grey-lighten-1 mt-1\">{{ tip }}</div>\n </div>\n </slot>\n </div>\n\n <!-- picture-card 模式 -->\n <div v-if=\"listType === 'picture-card'\" class=\"vtk-upload__picture-card-wrap\">\n <div\n v-for=\"file in fileList\"\n :key=\"file.uid\"\n class=\"vtk-upload__picture-card-item\"\n >\n <v-img :src=\"file.url || file.preview\" cover class=\"fill-height\" />\n <div class=\"vtk-upload__picture-card-mask\">\n <VBtn v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handlePreview(file)\">\n <VIcon>mdi-eye</VIcon>\n </VBtn>\n <VBtn v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handleRemove(file)\">\n <VIcon>mdi-delete</VIcon>\n </VBtn>\n </div>\n <!-- 上传进度 -->\n <div v-if=\"file.status === 'uploading'\" class=\"vtk-upload__picture-card-progress\">\n <v-progress-circular :model-value=\"file.percentage\" size=\"36\" color=\"white\" />\n </div>\n </div>\n\n <!-- 添加按钮 -->\n <div\n v-if=\"!disabled && (limit === 0 || fileList.length < limit)\"\n :class=\"['vtk-upload__picture-card-add', { 'is-dragover': isDragover }]\"\n @click=\"triggerInput()\"\n @dragover.prevent=\"onDragover\"\n @dragleave.prevent=\"isDragover = false\"\n @drop.prevent=\"onDrop\"\n >\n <VIcon size=\"28\" color=\"grey-lighten-1\">mdi-plus</VIcon>\n </div>\n </div>\n\n <!-- 隐藏的 input -->\n <input\n ref=\"inputRef\"\n type=\"file\"\n class=\"vtk-upload__input\"\n :accept=\"accept\"\n :multiple=\"multiple\"\n @change=\"onInputChange\"\n />\n\n <!-- 文件列表 (非 picture-card) -->\n <div v-if=\"showFileList && listType !== 'picture-card' && fileList.length > 0\" class=\"vtk-upload__list mt-2\">\n <div\n v-for=\"file in fileList\"\n :key=\"file.uid\"\n :class=\"['vtk-upload__list-item', `is-${file.status}`]\"\n style=\"cursor: pointer;\"\n >\n <VIcon size=\"18\" class=\"mr-1\" :color=\"file.status === 'error' ? 'error' : 'primary'\">\n {{ fileIcon(file) }}\n </VIcon>\n <span class=\"vtk-upload__list-item-name flex-grow-1 text-truncate\" @click=\"handlePreview(file)\" :title=\"file.name\">{{ file.name }}</span>\n <span v-if=\"file.status === 'uploading'\" class=\"text-caption text-grey ml-2\">{{ file.percentage }}%</span>\n <VBtn\n v-if=\"!disabled\"\n icon\n size=\"x-small\"\n variant=\"text\"\n color=\"grey\"\n class=\"ml-1\"\n @click=\"handleRemove(file)\"\n >\n <VIcon size=\"16\">mdi-close</VIcon>\n </VBtn>\n <!-- 进度条 -->\n <v-progress-linear\n v-if=\"file.status === 'uploading'\"\n :model-value=\"file.percentage\"\n color=\"primary\"\n class=\"vtk-upload__list-progress\"\n height=\"2\"\n />\n </div>\n </div>\n\n <!-- 预览 Dialog -->\n <VDialog v-model=\"previewVisible\" max-width=\"800\">\n <VCard>\n <v-card-title class=\"d-flex align-center bg-primary\">\n\t\t\t\t{{ previewFile?.name }}\n\t\t\t\t<v-spacer></v-spacer>\n\t\t\t\t<v-btn class=\"mx-0\" icon @click=\"previewVisible = false\" variant=\"plain\">\n\t\t\t\t\t<v-icon>mdi-close</v-icon>\n\t\t\t\t</v-btn>\n\t\t\t</v-card-title>\n <div class=\"pa-4 d-flex justify-center\">\n <v-img v-if=\"isImage(previewFile)\" :src=\"previewFile?._previewSrc\" max-height=\"600\" contain />\n <div v-else class=\"text-center pa-8 text-grey\">\n <VIcon size=\"64\">{{ isExcel(previewFile) ? 'mdi-microsoft-excel' : 'mdi-file-outline' }}</VIcon>\n <div class=\"mt-2\">{{ previewFile?.name }}</div>\n <div class=\"text-caption mt-1\">该文件暂时无法在线预览</div>\n </div>\n </div>\n </VCard>\n </VDialog>\n </div>\n</template>\n\n<script setup>\nimport { ref, watch } from 'vue';\nimport Request from '../../commons/request.js';\n\ndefineOptions({\n name: 'VtkUpload',\n inheritAttrs: false,\n});\n\nconst props = defineProps({\n /** v-model 文件列表 */\n modelValue: {\n type: Array,\n default: () => [],\n },\n /** 上传地址 */\n action: {\n type: String,\n default: '',\n },\n /** 接受的文件类型,同原生 accept */\n accept: {\n type: String,\n default: '',\n },\n /** 是否多选 */\n multiple: {\n type: Boolean,\n default: false,\n },\n /** 最大上传数量,0 表示不限制 */\n limit: {\n type: Number,\n default: 0,\n },\n /** 单文件最大体积,单位 MB,0 表示不限制 */\n maxSize: {\n type: Number,\n default: 0,\n },\n /** 列表类型:text | picture | picture-card */\n listType: {\n type: String,\n default: 'text',\n validator: (v) => ['text', 'picture', 'picture-card'].includes(v),\n },\n /** 是否显示文件列表 */\n showFileList: {\n type: Boolean,\n default: true,\n },\n /** 是否自动上传 */\n autoUpload: {\n type: Boolean,\n default: true,\n },\n /** 是否禁用 */\n disabled: {\n type: Boolean,\n default: false,\n },\n /** 附加请求头 */\n headers: {\n type: Object,\n default: () => ({}),\n },\n /** 附加请求数据 */\n data: {\n type: Object,\n default: () => ({}),\n },\n /** 文件字段名 */\n name: {\n type: String,\n default: 'file',\n },\n /** 提示文字 */\n tip: {\n type: String,\n default: '',\n },\n /** 上传前钩子,返回 false 或 rejected Promise 则停止上传 */\n beforeUpload: {\n type: Function,\n default: null,\n },\n /** 移除前钩子 */\n beforeRemove: {\n type: Function,\n default: null,\n },\n});\n\nconst emit = defineEmits([\n 'update:modelValue',\n 'change',\n 'success',\n 'error',\n 'progress',\n 'remove',\n 'exceed',\n 'preview',\n]);\n\n/* -------------------- 内部状态 -------------------- */\nconst inputRef = ref(null);\nconst isDragover = ref(false);\nconst previewVisible = ref(false);\nconst previewFile = ref(null);\n\n// 内部维护文件列表\nconst fileList = ref([...(props.modelValue || [])]);\n\nwatch(\n () => props.modelValue,\n (val) => {\n // 外部传入字符串数组(url 列表)时跳过,避免覆盖内部状态\n if (!val?.length || typeof val[0] === 'string') return;\n fileList.value = [...val];\n },\n);\n\n/* -------------------- 工具函数 -------------------- */\nlet uidCounter = 0;\nconst genUid = () => `vtk-upload-${Date.now()}-${uidCounter++}`;\n\nconst isImage = (file) => {\n if (!file) return false;\n return /image\\//.test(file.type) || /\\.(png|jpg|jpeg|gif|bmp|webp|svg)$/i.test(file.name || '');\n};\n\nconst fileIcon = (file) => {\n if (file.status === 'error') return 'mdi-file-alert-outline';\n if (isImage(file)) return 'mdi-file-image-outline';\n return 'mdi-file-outline';\n};\n\n/* -------------------- 触发 input -------------------- */\nconst triggerInput = () => {\n inputRef.value && inputRef.value.click();\n};\n\n/* -------------------- 拖拽 -------------------- */\nconst onDragover = () => {\n if (!props.disabled) isDragover.value = true;\n};\n\nconst onDrop = (e) => {\n isDragover.value = false;\n if (props.disabled) return;\n processFiles(Array.from(e.dataTransfer.files));\n};\n\n/* -------------------- input change -------------------- */\nconst onInputChange = (e) => {\n processFiles(Array.from(e.target.files));\n // 清空,允许重复选同一文件\n e.target.value = '';\n};\n\n/* -------------------- 文件处理 -------------------- */\nconst processFiles = (rawFiles) => {\n if (!rawFiles.length) return;\n\n // 数量限制检查\n if (props.limit > 0 && fileList.value.length + rawFiles.length > props.limit) {\n emit('exceed', rawFiles, fileList.value);\n return;\n }\n\n rawFiles.forEach((raw) => {\n // 体积检查\n if (props.maxSize > 0 && raw.size / 1024 / 1024 > props.maxSize) {\n const errFile = buildFile(raw, 'error');\n emit('error', new Error(`文件 ${raw.name} 超过最大限制 ${props.maxSize}MB`), errFile, fileList.value);\n return;\n }\n\n const file = buildFile(raw, 'ready');\n\n // 生成预览\n if (isImage(raw)) {\n const reader = new FileReader();\n reader.onload = (e) => { file.preview = e.target.result; };\n reader.readAsDataURL(raw);\n }\n\n const beforeHook = props.beforeUpload ? props.beforeUpload(raw) : true;\n Promise.resolve(beforeHook).then((result) => {\n if (result === false) return;\n addFile(file);\n if (props.autoUpload && props.action) {\n uploadFile(file);\n }\n }).catch(() => {});\n });\n};\n\nconst buildFile = (raw, status) => ({\n uid: genUid(),\n name: raw.name,\n size: raw.size,\n type: raw.type,\n status,\n percentage: 0,\n raw,\n url: '',\n preview: '',\n response: null,\n});\n\nconst addFile = (file) => {\n fileList.value.push(file);\n syncModel();\n emit('change', file, fileList.value);\n};\n\nconst syncModel = () => {\n const urls = fileList.value\n .filter((f) => f.status === 'success' && f.url)\n .map((f) => String(f.url));\n emit('update:modelValue', urls);\n};\n\n/* -------------------- 上传逻辑 -------------------- */\nconst uploadFile = (file) => {\n file.status = 'uploading';\n const formData = new FormData();\n formData.append(props.name, file.raw);\n Object.entries(props.data).forEach(([k, v]) => formData.append(k, v));\n\n // 使用 axios 直接调,以获得 onUploadProgress\n const tokenKey = window.VTK_CONFIG?.storageKeys?.token || '_mis_acis_token';\n const token = window.$vtk?.storage?.get(tokenKey) || localStorage.getItem(tokenKey);\n\n const headers = {\n 'content-type': 'multipart/form-data',\n ...props.headers,\n };\n if (token) headers['Authorization'] = `Bearer ${token}`;\n\n Request.http(props.action, formData, 'POST', headers).then((res) => {\n file.status = 'success';\n file.response = res;\n // 兼容 { data: 'url' } 和 { data: { url: '...' } } 两种结构\n const url = typeof res?.data === 'string' ? res.data : (res?.data?.url || res?.url || '');\n if (url) file.url = url;\n console.log('[VtkUpload] res:', res, '| file.url:', file.url, '| fileList:', JSON.parse(JSON.stringify(fileList.value)));\n syncModel();\n emit('success', res, file, fileList.value);\n emit('change', file, fileList.value);\n }).catch((err) => {\n file.status = 'error';\n syncModel();\n emit('error', err, file, fileList.value);\n emit('change', file, fileList.value);\n });\n};\n\n/* -------------------- 移除文件 -------------------- */\nconst handleRemove = (file) => {\n const doRemove = () => {\n fileList.value = fileList.value.filter((f) => f.uid !== file.uid);\n syncModel();\n emit('remove', file, fileList.value);\n };\n\n if (props.beforeRemove) {\n Promise.resolve(props.beforeRemove(file, fileList.value)).then((result) => {\n if (result !== false) doRemove();\n }).catch(() => {});\n } else {\n doRemove();\n }\n};\n\n/* -------------------- 预览 -------------------- */\nconst isPdf = (file) => /\\.pdf$/i.test(file?.name || '') || file?.type === 'application/pdf';\nconst isExcel = (file) => /\\.(xlsx|xls)$/i.test(file?.name || '');\n\nconst handlePreview = (file) => {\n emit('preview', file);\n\n const fileUrl = file.url || file.preview;\n\n // PDF:新标签页直接打开(浏览器原生支持)\n if (isPdf(file)) {\n if (fileUrl) {\n window.open(fileUrl, '_blank');\n } else if (file.raw instanceof File || file.raw instanceof Blob) {\n // 本地未上传文件,用 Blob URL 打开\n const blobUrl = URL.createObjectURL(file.raw);\n const win = window.open(blobUrl, '_blank');\n win?.addEventListener('unload', () => URL.revokeObjectURL(blobUrl));\n } else {\n // 无可用地址也无本地文件,降级到 Dialog\n previewFile.value = { ...file, _previewSrc: fileUrl };\n previewVisible.value = true;\n }\n return;\n }\n\n // Excel:Office Online 查看器(需要文件有公网 URL)\n if (isExcel(file)) {\n if (fileUrl && /^https?:\\/\\//.test(fileUrl)) {\n window.open(`https://view.officeapps.live.com/op/view.aspx?src=${encodeURIComponent(fileUrl)}`, '_blank');\n } else {\n // 无公网地址,降级为 Dialog 显示提示\n previewFile.value = { ...file, _previewSrc: fileUrl };\n previewVisible.value = true;\n }\n return;\n }\n\n // 图片及其他:Dialog 内嵌预览\n // 统一挂载可用的预览地址,供 Dialog 使用\n previewFile.value = {\n ...file,\n _previewSrc: fileUrl,\n };\n previewVisible.value = true;\n};\n\n/* -------------------- 对外暴露方法 -------------------- */\n/** 手动触发未上传文件的上传 */\nconst submit = () => {\n fileList.value\n .filter((f) => f.status === 'ready' && props.action)\n .forEach(uploadFile);\n};\n\n/** 清空文件列表 */\nconst clearFiles = () => {\n fileList.value = [];\n syncModel();\n};\n\n/** 手动移除某个文件 */\nconst remove = (file) => handleRemove(file);\n\ndefineExpose({ submit, clearFiles, remove });\n</script>\n\n<style lang=\"scss\" scoped>\n.vtk-upload {\n width: 100%;\n}\n\n/* ---- 拖拽区域 ---- */\n.vtk-upload__dragger {\n border: 1px dashed rgba(0, 0, 0, 0.2);\n border-radius: 6px;\n padding: 24px 16px;\n text-align: center;\n cursor: pointer;\n transition: border-color 0.2s, background 0.2s;\n background: transparent;\n\n &:hover:not(.is-disabled) {\n border-color: rgb(var(--v-theme-primary));\n }\n\n &.is-dragover {\n border-color: rgb(var(--v-theme-primary));\n background: rgba(var(--v-theme-primary), 0.05);\n }\n\n &.is-disabled {\n cursor: not-allowed;\n opacity: 0.6;\n }\n}\n\n/* ---- 文件列表 ---- */\n.vtk-upload__list {\n border-top: 1px solid rgba(0, 0, 0, 0.08);\n}\n\n.vtk-upload__list-item {\n position: relative;\n display: flex;\n align-items: center;\n padding: 4px 4px 4px 8px;\n border-radius: 4px;\n font-size: 13px;\n transition: background 0.15s;\n\n &:hover {\n background: rgba(0, 0, 0, 0.04);\n }\n\n &.is-error {\n color: rgb(var(--v-theme-error));\n }\n\n &.is-success .vtk-upload__list-item-name {\n cursor: pointer;\n &:hover { color: rgb(var(--v-theme-primary)); }\n }\n}\n\n.vtk-upload__list-item-name {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n max-width: 500px;\n}\n\n.vtk-upload__list-progress {\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n}\n\n/* ---- picture-card ---- */\n.vtk-upload__picture-card-wrap {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n}\n\n.vtk-upload__picture-card-item,\n.vtk-upload__picture-card-add {\n width: 100px;\n height: 100px;\n border-radius: 6px;\n overflow: hidden;\n}\n\n.vtk-upload__picture-card-item {\n position: relative;\n border: 1px solid rgba(0, 0, 0, 0.12);\n\n &:hover .vtk-upload__picture-card-mask {\n opacity: 1;\n }\n}\n\n.vtk-upload__picture-card-mask {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.45);\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 4px;\n opacity: 0;\n transition: opacity 0.2s;\n}\n\n.vtk-upload__picture-card-progress {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.4);\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.vtk-upload__picture-card-add {\n border: 1px dashed rgba(0, 0, 0, 0.2);\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n transition: border-color 0.2s, background 0.2s;\n\n &:hover, &.is-dragover {\n border-color: rgb(var(--v-theme-primary));\n background: rgba(var(--v-theme-primary), 0.04);\n }\n}\n\n/* ---- 隐藏 input ---- */\n.vtk-upload__input {\n display: none;\n}\n</style>\n","import Request from \"./request.js\";\nimport Storage from \"./storage.js\";\nimport Message from \"../components/message/index.js\";\n\nfunction isAid(value) {\n const str = String(value || \"\");\n return !!str && !/^(https?:)?\\/\\//i.test(str) && !str.includes(\"/\") && !str.includes(\"?\");\n\n \n}\n\nfunction getLinkFromResponse(data) {\n if (!data) {\n return \"\";\n }\n\n if (typeof data === \"string\") {\n return data;\n }\n\n return data.puri || \"\";\n}\n\nfunction buildUrlWithParams(target, appendParams) {\n const queryString = target.includes(\"?\") ? target.split(\"?\")[1] : \"\";\n const queryParams = new URLSearchParams(queryString);\n const newParams = [];\n\n Object.entries(appendParams).forEach(([key, value]) => {\n if (!key || value === undefined || value === null || value === \"\") {\n return;\n }\n\n if (!queryParams.has(key)) {\n newParams.push(`${encodeURIComponent(key)}=${encodeURIComponent(value)}`);\n }\n });\n\n if (!newParams.length) {\n return target;\n }\n\n const joinSymbol = target.includes(\"?\") ? \"&\" : \"?\";\n return `${target}${joinSymbol}${newParams.join(\"&\")}`;\n}\n\nfunction appendParamsToUrl(targetUrl, appendParams) {\n const hashIndex = targetUrl.indexOf(\"#\");\n\n if (hashIndex === -1) {\n return buildUrlWithParams(targetUrl, appendParams);\n }\n\n const baseUrl = targetUrl.slice(0, hashIndex);\n const hashRoute = targetUrl.slice(hashIndex + 1);\n const newHashRoute = buildUrlWithParams(hashRoute, appendParams);\n return `${baseUrl}#${newHashRoute}`;\n}\n\nasync function resolveAidUrl(aid) {\n if (!aid) {\n return aid;\n }\n\n try {\n const res = await Request.postForm(\"/kudas/xfwez/apps\", { aid });\n const realUrl = res?.meta?.success ? getLinkFromResponse(res.data) : \"\";\n return realUrl || aid;\n } catch (error) {\n return aid;\n }\n}\n\nfunction buildAppendParams(sobject, sroute, stokenKey) {\n const appendParams = {};\n const storageKey = stokenKey || \"_mis_acis_token\";\n const stoken = Storage.get(storageKey);\n\n if (stoken !== undefined && stoken !== null && stoken !== \"\") {\n appendParams.stoken = stoken;\n }\n\n if (sroute) {\n appendParams.sroute = sroute;\n }\n\n if (sobject && typeof sobject === \"object\" && Object.keys(sobject).length) {\n appendParams.sobject = btoa(encodeURIComponent(JSON.stringify(sobject)));\n }\n\n return appendParams;\n}\n\n/**\n * 解析地址中的指定参数值。\n * @param {string} name 参数名。\n * @param {string} url 要解析的地址,不传时默认使用当前地址。\n * @return {string} 参数值;未找到时返回空字符串。\n */\nexport function GetQueryString(name, url = window.location.href) {\n const reg = new RegExp(`[?&]${name}=([^&^#^/]*)`, \"i\");\n const res = String(url || \"\").match(reg);\n return res ? decodeURIComponent(res[1]) : \"\";\n}\n\n/**\n * 追加应用访问参数。\n * @param {string} url 链接地址或应用 aid;不传时默认取当前地址。\n * @param {Object} sobject 参数对象;会按 `btoa(encodeURIComponent(JSON.stringify(sobject)))` 编码后追加为 `sobject` 参数。\n * @param {string} sroute 页面路由标识;传值后会在最终地址中追加 `sroute=xxx`。\n * @param {string} stokenKey 取 `stoken` 的存储键名,默认 `_mis_acis_token`。\n * @return {Promise<string>} 拼接后的链接地址。\n */\nexport async function appendAppParams(url, sobject = {}, sroute = \"\", stokenKey = \"_mis_acis_token\") {\n if (url === undefined || url === null || url === \"\" || url === 0 || url === \"0\") {\n Message.toast(\"应用标识错误\", { color: \"error\" });\n return \"\";\n }\n\n const source = url || window.location.href;\n\n if (!source) {\n return \"\";\n }\n\n const targetUrl = isAid(source) ? await resolveAidUrl(source) : source;\n return appendParamsToUrl(targetUrl, buildAppendParams(sobject, sroute, stokenKey));\n}\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::v-deep .v-snackbar__wrapper {\r\n\ttop: 24px;\r\n}\r\n</style>\r\n","/**\n * Specter PUI - Vue 3 组件库\n */\n\nexport { default as VtkArea } from \"./components/assembly/VtkArea.vue\";\nexport { default as VtkAreaTabs } from \"./components/assembly/VtkAreaTabs.vue\";\nexport { default as VtkBreadcrumb } from \"./components/assembly/VtkBreadcrumb.vue\";\nexport { default as VtkCheckbox } from \"./components/assembly/VtkCheckbox.vue\";\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 VtkDept } from \"./components/assembly/VtkDept.vue\";\nexport { default as VtkEmpty } from \"./components/assembly/VtkEmpty.vue\";\nexport { default as VtkFab } from \"./components/assembly/VtkFab.vue\";\nexport { default as VtkFormItem } from \"./components/assembly/VtkFormItem.vue\";\nexport { default as VtkImg } from \"./components/assembly/VtkImg.vue\";\nexport { default as VtkPage } from \"./components/assembly/VtkPage.vue\";\nexport { default as VtkPdf } from \"./components/assembly/VtkPdf.vue\";\nexport { default as VtkProj } from \"./components/assembly/VtkProj.vue\";\nexport { default as VtkRadio } from \"./components/assembly/VtkRadio.vue\";\nexport { default as VtkSearch } from \"./components/assembly/VtkSearch.vue\";\nexport { default as VtkSelect } from \"./components/assembly/VtkSelect.vue\";\nexport { default as VtkStepper } from \"./components/assembly/VtkStepper.vue\";\nexport { default as VtkUpload } from \"./components/assembly/VtkUpload.vue\";\n\nexport * from \"./commons/location.js\";\nexport * from \"./commons/filters/dictionary.js\";\nexport * from \"./commons/filters/format.js\";\nexport * from \"./commons/filters/mask.js\";\nexport { default as request } from \"./commons/request.js\";\nexport { default as storage } from \"./commons/storage.js\";\nexport { default as themes } from \"./commons/themes.js\";\nexport * from \"./commons/validation.js\";\n\nexport { useMixins } from \"./composables/usePage.js\";\nexport { default as vtkMessage } from \"./components/message/index.js\";\n\nimport vtkMessage from \"./components/message/index.js\";\nimport storage from \"./commons/storage.js\";\nimport themes from \"./commons/themes.js\";\nimport request from \"./commons/request.js\";\nimport * as location from \"./commons/location.js\";\nimport Validation from \"./commons/validation.js\";\nimport * as dictionary from \"./commons/filters/dictionary.js\";\nimport * as mask from \"./commons/filters/mask.js\";\nimport * as format from \"./commons/filters/format.js\";\n\nimport VtkArea from \"./components/assembly/VtkArea.vue\";\nimport VtkAreaTabs from \"./components/assembly/VtkAreaTabs.vue\";\nimport VtkBreadcrumb from \"./components/assembly/VtkBreadcrumb.vue\";\nimport VtkCheckbox from \"./components/assembly/VtkCheckbox.vue\";\nimport VtkCount from \"./components/assembly/VtkCount.vue\";\nimport VtkDatePicker from \"./components/assembly/VtkDatePicker.vue\";\nimport VtkDateSelector from \"./components/assembly/VtkDateSelector.vue\";\nimport VtkDept from \"./components/assembly/VtkDept.vue\";\nimport VtkEmpty from \"./components/assembly/VtkEmpty.vue\";\nimport VtkFab from \"./components/assembly/VtkFab.vue\";\nimport VtkFormItem from \"./components/assembly/VtkFormItem.vue\";\nimport VtkImg from \"./components/assembly/VtkImg.vue\";\nimport VtkPage from \"./components/assembly/VtkPage.vue\";\nimport VtkPdf from \"./components/assembly/VtkPdf.vue\";\nimport VtkProj from \"./components/assembly/VtkProj.vue\";\nimport VtkRadio from \"./components/assembly/VtkRadio.vue\";\nimport VtkSearch from \"./components/assembly/VtkSearch.vue\";\nimport VtkSelect from \"./components/assembly/VtkSelect.vue\";\nimport VtkStepper from \"./components/assembly/VtkStepper.vue\";\nimport VtkUpload from \"./components/assembly/VtkUpload.vue\";\nimport VtkMessageComponent from \"./components/message/vtkMessage.vue\";\n\nfunction install(app, options = {}) {\n const components = {\n VtkArea,\n VtkAreaTabs,\n VtkBreadcrumb,\n VtkCheckbox,\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDept,\n VtkEmpty,\n VtkFab,\n VtkFormItem,\n VtkImg,\n VtkPage,\n VtkPdf,\n VtkProj,\n VtkRadio,\n VtkSearch,\n VtkSelect,\n VtkStepper,\n VtkUpload,\n VtkMessage: VtkMessageComponent\n };\n\n Object.keys(components).forEach(name => {\n app.component(name, components[name]);\n });\n\n app.config.globalProperties.$vtk = {\n message: vtkMessage,\n request,\n storage,\n themes,\n location,\n Validation,\n filters: {\n ...dictionary,\n ...mask,\n ...format\n },\n ...options\n };\n\n return app;\n}\n\nexport default {\n install,\n VtkArea,\n VtkAreaTabs,\n VtkBreadcrumb,\n VtkCheckbox,\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDept,\n VtkEmpty,\n VtkFab,\n VtkFormItem,\n VtkImg,\n VtkPage,\n VtkPdf,\n VtkProj,\n VtkRadio,\n VtkSearch,\n VtkSelect,\n VtkStepper,\n VtkUpload,\n request,\n storage,\n themes,\n vtkMessage\n};\n"],"names":["Storage","storage","type","key","js","value","useMessageStore","defineStore","options","Message","messageStore","defaultOptions","text","toastOptions","service","axios","config","tokenKey","_b","_a","error","response","res","header","handleRedirect","url","index","newUrl","Request","data","method","headers","responseType","proxy","getCurrentInstance","emit","__emit","entity","reactive","user","ref","areaData","onMounted","userKey","area","nextArea","areaCode","inputFn","e","clear","arr","_openBlock","_createElementBlock","_hoisted_1","_createVNode","_component_VSelect","_cache","$event","__props","_createBlock","_c","_normalizeClass","_d","_e","_f","_g","_h","_i","_normalizeStyle","_j","props","menu","tab","tabItems","areaStorage","areaItems","current","itemValue","itemText","view","code","province","city","district","town","village","tabArea","areaChange","item","getTree","nextTick","getAreaName","save","val","lastItem","close","textClear","initCode","watch","newVal","oldVal","_component_v_menu","_withCtx","_component_v_btn","_mergeProps","$attrs","_createElementVNode","_toDisplayString","_component_v_icon","_component_v_card","_hoisted_2","_Fragment","_renderList","link","_component_v_sheet","_component_v_tabs","_component_v_tab","_createTextVNode","_vShow","_component_v_chip_group","_component_v_chip","_component_v_card_actions","_component_v_spacer","router","inject","route","breadcrumbItems","computed","matched","r","pathArray","p","path","routePath","handleBack","_component_v_breadcrumbs","_component_v_breadcrumbs_item","localValue","isUpdatingLocal","isUpdatingModel","attrs","useAttrs","inputAttrs","list","inline","modelValue","rest","checkboxAttrs","errorMessages","rules","hint","persistentHint","inputValue","items","statc","it","codeValue","miscs","_component_VInput","_component_VCheckbox","currentNumber","currentDigits","digitKey","isAnimating","formatNumber","num","result","targetNumberString","startNumberString","maxDigitString","target","start","getCurrentDigit","initDigitsArray","startStr","char","startChar","getDigitStyle","currentValue","digitValue","offset","translateY","startAnimation","startTime","startValue","endValue","diff","animate","currentTime","elapsed","progress","easeOutQuart","updateDigitArray","valueStr","maxStr","i","newStr","oldStr","endStr","__expose","digitChar","_hoisted_4","_hoisted_3","n","_hoisted_5","dateRange","startDateRange","endDateRange","displayValue","formatDate","textFieldProps","placeholder","disabled","min","max","showCurrent","format","separator","date","year","month","day","minDate","maxDate","newValue","dates","onStartDateChange","onEndDateChange","clearValue","cancel","confirm","sortedRange","date1","date2","_component_VMenu","activatorProps","_component_VTextField","_component_VIcon","_component_VCard","_component_VCardText","_component_VDatePicker","_component_VDivider","_component_VCardActions","_component_VSpacer","_component_VBtn","YEAR_PANEL_SIZE","YEAR_PANEL_CENTER_OFFSET","showPicker","viewMode","currentYear","currentMonth","rightYear","rightMonth","selectedValue","tempValue","selectorRef","inputRef","dropdownStyle","today","todayYear","todayMonth","todayDate","weekDays","monthList","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","togglePicker","rect","dropdownWidth","alignStyle","closePicker","handleCancel","handleConfirm","_Teleport","_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_26","_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","pause","ms","resolve","dialog","areaSelectedData","areaActivatedData","getDeptList","getAreaList","getAreaNextList","parentCode","deptData","deptSelectedData","deptActivatedData","getPersonList","node","params","getDepNextList","selectAreaCode","selectPid","personData","selectedPersonData","allSelectedPersons","isRestoringSelection","selectedPersonList","uniqueMap","person","oldPerson","newPersonData","currentSelected","removeSelectedPerson","personId","globalIndex","currentIndex","add","selectedPersons","_component_v_dialog","_component_v_card_title","_component_v_divider","_component_v_card_text","_component_v_row","_component_v_col","_component_v_treeview","_component_v_avatar","_component_v_img","_component_v_list","_component_v_list_item","_component_v_empty_state","$slots","_renderSlot","_ctx","showFab","fabClass","handleScroll","scrollToTop","onBeforeUnmount","_Transition","_component_v_fab","processedMaxWidth","contentStyles","styles","showPreview","imageRotation","srcWithToken","token","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","obtain","filterNull","search","reset","handleResetClick","_component_VBadge","filteredAttrs","multi","its","$emit","stepIndex","step","content","_component_VStepper","_component_VStepperHeader","_component_VStepperWindow","_component_VStepperWindowItem","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","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":[29]}
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/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\">\n <VMenu\n v-if=\"!inline\"\n v-model=\"showPicker\"\n :attach=\"menuAttach\"\n :location=\"menuLocation\"\n :origin=\"menuOrigin\"\n offset=\"4\"\n :close-on-content-click=\"false\"\n >\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>\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 树内\n noTeleport: {\n type: Boolean,\n default: false\n },\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);\nconst viewMode = ref(props.displayMode);\nconst currentYear = ref(new Date().getFullYear());\nconst currentMonth = ref(new Date().getMonth());\nconst rightYear = ref(new Date().getFullYear());\nconst rightMonth = ref(new Date().getMonth() + 1);\nconst selectedValue = ref(null);\nconst tempValue = ref(null);\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// 显示值\nconst menuAttach = computed(() => (props.noTeleport ? true : false));\n\nconst menuLocation = computed(() => props.placement === 'right' ? 'bottom end' : 'bottom start');\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 {\n background: rgb(var(--v-theme-surface));\n border-radius: 8px;\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}\n\r\n.date-picker-dropdown.inline-mode {\n box-shadow: none;\n width: fit-content;\n border: none;\n}\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>\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>\n <div class=\"vtk-upload\">\n <!-- 拖拽 / 点击上传区域 -->\n <div\n v-if=\"listType !== 'picture-card'\"\n :class=\"['vtk-upload__dragger', { 'is-dragover': isDragover, 'is-disabled': disabled }]\"\n @click=\"!disabled && triggerInput()\"\n @dragover.prevent=\"onDragover\"\n @dragleave.prevent=\"isDragover = false\"\n @drop.prevent=\"onDrop\"\n >\n <slot>\n <div class=\"vtk-upload__dragger-inner\">\n <VIcon size=\"40\" color=\"grey-lighten-1\">mdi-cloud-upload-outline</VIcon>\n <div class=\"text-body-2 mt-2 text-grey\">将文件拖到此处,或<span class=\"text-primary\" style=\"cursor:pointer\">点击上传</span></div>\n <div v-if=\"tip\" class=\"text-caption text-grey-lighten-1 mt-1\">{{ tip }}</div>\n </div>\n </slot>\n </div>\n\n <!-- picture-card 模式 -->\n <div v-if=\"listType === 'picture-card'\" class=\"vtk-upload__picture-card-wrap\">\n <div\n v-for=\"file in fileList\"\n :key=\"file.uid\"\n class=\"vtk-upload__picture-card-item\"\n >\n <v-img :src=\"file.url || file.preview\" cover class=\"fill-height\" />\n <div class=\"vtk-upload__picture-card-mask\">\n <VBtn v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handlePreview(file)\">\n <VIcon>mdi-eye</VIcon>\n </VBtn>\n <VBtn v-if=\"!disabled\" icon size=\"x-small\" variant=\"text\" color=\"white\" @click.stop=\"handleRemove(file)\">\n <VIcon>mdi-delete</VIcon>\n </VBtn>\n </div>\n <!-- 上传进度 -->\n <div v-if=\"file.status === 'uploading'\" class=\"vtk-upload__picture-card-progress\">\n <v-progress-circular :model-value=\"file.percentage\" size=\"36\" color=\"white\" />\n </div>\n </div>\n\n <!-- 添加按钮 -->\n <div\n v-if=\"!disabled && (limit === 0 || fileList.length < limit)\"\n :class=\"['vtk-upload__picture-card-add', { 'is-dragover': isDragover }]\"\n @click=\"triggerInput()\"\n @dragover.prevent=\"onDragover\"\n @dragleave.prevent=\"isDragover = false\"\n @drop.prevent=\"onDrop\"\n >\n <VIcon size=\"28\" color=\"grey-lighten-1\">mdi-plus</VIcon>\n </div>\n </div>\n\n <!-- 隐藏的 input -->\n <input\n ref=\"inputRef\"\n type=\"file\"\n class=\"vtk-upload__input\"\n :accept=\"accept\"\n :multiple=\"multiple\"\n @change=\"onInputChange\"\n />\n\n <!-- 文件列表 (非 picture-card) -->\n <div v-if=\"showFileList && listType !== 'picture-card' && fileList.length > 0\" class=\"vtk-upload__list mt-2\">\n <div\n v-for=\"file in fileList\"\n :key=\"file.uid\"\n :class=\"['vtk-upload__list-item', `is-${file.status}`]\"\n style=\"cursor: pointer;\"\n >\n <VIcon size=\"18\" class=\"mr-1\" :color=\"file.status === 'error' ? 'error' : 'primary'\">\n {{ fileIcon(file) }}\n </VIcon>\n <span class=\"vtk-upload__list-item-name flex-grow-1 text-truncate\" @click=\"handlePreview(file)\" :title=\"file.name\">{{ file.name }}</span>\n <span v-if=\"file.status === 'uploading'\" class=\"text-caption text-grey ml-2\">{{ file.percentage }}%</span>\n <VBtn\n v-if=\"!disabled\"\n icon\n size=\"x-small\"\n variant=\"text\"\n color=\"grey\"\n class=\"ml-1\"\n @click=\"handleRemove(file)\"\n >\n <VIcon size=\"16\">mdi-close</VIcon>\n </VBtn>\n <!-- 进度条 -->\n <v-progress-linear\n v-if=\"file.status === 'uploading'\"\n :model-value=\"file.percentage\"\n color=\"primary\"\n class=\"vtk-upload__list-progress\"\n height=\"2\"\n />\n </div>\n </div>\n\n <!-- 预览 Dialog -->\n <VDialog v-model=\"previewVisible\" max-width=\"800\">\n <VCard>\n <v-card-title class=\"d-flex align-center bg-primary\">\n\t\t\t\t{{ previewFile?.name }}\n\t\t\t\t<v-spacer></v-spacer>\n\t\t\t\t<v-btn class=\"mx-0\" icon @click=\"previewVisible = false\" variant=\"plain\">\n\t\t\t\t\t<v-icon>mdi-close</v-icon>\n\t\t\t\t</v-btn>\n\t\t\t</v-card-title>\n <div class=\"pa-4 d-flex justify-center\">\n <v-img v-if=\"isImage(previewFile)\" :src=\"previewFile?._previewSrc\" max-height=\"600\" contain />\n <div v-else class=\"text-center pa-8 text-grey\">\n <VIcon size=\"64\">{{ isExcel(previewFile) ? 'mdi-microsoft-excel' : 'mdi-file-outline' }}</VIcon>\n <div class=\"mt-2\">{{ previewFile?.name }}</div>\n <div class=\"text-caption mt-1\">该文件暂时无法在线预览</div>\n </div>\n </div>\n </VCard>\n </VDialog>\n </div>\n</template>\n\n<script setup>\nimport { ref, watch } from 'vue';\nimport Request from '../../commons/request.js';\n\ndefineOptions({\n name: 'VtkUpload',\n inheritAttrs: false,\n});\n\nconst props = defineProps({\n /** v-model 文件列表 */\n modelValue: {\n type: Array,\n default: () => [],\n },\n /** 上传地址 */\n action: {\n type: String,\n default: '',\n },\n /** 接受的文件类型,同原生 accept */\n accept: {\n type: String,\n default: '',\n },\n /** 是否多选 */\n multiple: {\n type: Boolean,\n default: false,\n },\n /** 最大上传数量,0 表示不限制 */\n limit: {\n type: Number,\n default: 0,\n },\n /** 单文件最大体积,单位 MB,0 表示不限制 */\n maxSize: {\n type: Number,\n default: 0,\n },\n /** 列表类型:text | picture | picture-card */\n listType: {\n type: String,\n default: 'text',\n validator: (v) => ['text', 'picture', 'picture-card'].includes(v),\n },\n /** 是否显示文件列表 */\n showFileList: {\n type: Boolean,\n default: true,\n },\n /** 是否自动上传 */\n autoUpload: {\n type: Boolean,\n default: true,\n },\n /** 是否禁用 */\n disabled: {\n type: Boolean,\n default: false,\n },\n /** 附加请求头 */\n headers: {\n type: Object,\n default: () => ({}),\n },\n /** 附加请求数据 */\n data: {\n type: Object,\n default: () => ({}),\n },\n /** 文件字段名 */\n name: {\n type: String,\n default: 'file',\n },\n /** 提示文字 */\n tip: {\n type: String,\n default: '',\n },\n /** 上传前钩子,返回 false 或 rejected Promise 则停止上传 */\n beforeUpload: {\n type: Function,\n default: null,\n },\n /** 移除前钩子 */\n beforeRemove: {\n type: Function,\n default: null,\n },\n});\n\nconst emit = defineEmits([\n 'update:modelValue',\n 'change',\n 'success',\n 'error',\n 'progress',\n 'remove',\n 'exceed',\n 'preview',\n]);\n\n/* -------------------- 内部状态 -------------------- */\nconst inputRef = ref(null);\nconst isDragover = ref(false);\nconst previewVisible = ref(false);\nconst previewFile = ref(null);\n\n// 内部维护文件列表\nconst fileList = ref([...(props.modelValue || [])]);\n\nwatch(\n () => props.modelValue,\n (val) => {\n // 外部传入字符串数组(url 列表)时跳过,避免覆盖内部状态\n if (!val?.length || typeof val[0] === 'string') return;\n fileList.value = [...val];\n },\n);\n\n/* -------------------- 工具函数 -------------------- */\nlet uidCounter = 0;\nconst genUid = () => `vtk-upload-${Date.now()}-${uidCounter++}`;\n\nconst isImage = (file) => {\n if (!file) return false;\n return /image\\//.test(file.type) || /\\.(png|jpg|jpeg|gif|bmp|webp|svg)$/i.test(file.name || '');\n};\n\nconst fileIcon = (file) => {\n if (file.status === 'error') return 'mdi-file-alert-outline';\n if (isImage(file)) return 'mdi-file-image-outline';\n return 'mdi-file-outline';\n};\n\n/* -------------------- 触发 input -------------------- */\nconst triggerInput = () => {\n inputRef.value && inputRef.value.click();\n};\n\n/* -------------------- 拖拽 -------------------- */\nconst onDragover = () => {\n if (!props.disabled) isDragover.value = true;\n};\n\nconst onDrop = (e) => {\n isDragover.value = false;\n if (props.disabled) return;\n processFiles(Array.from(e.dataTransfer.files));\n};\n\n/* -------------------- input change -------------------- */\nconst onInputChange = (e) => {\n processFiles(Array.from(e.target.files));\n // 清空,允许重复选同一文件\n e.target.value = '';\n};\n\n/* -------------------- 文件处理 -------------------- */\nconst processFiles = (rawFiles) => {\n if (!rawFiles.length) return;\n\n // 数量限制检查\n if (props.limit > 0 && fileList.value.length + rawFiles.length > props.limit) {\n emit('exceed', rawFiles, fileList.value);\n return;\n }\n\n rawFiles.forEach((raw) => {\n // 体积检查\n if (props.maxSize > 0 && raw.size / 1024 / 1024 > props.maxSize) {\n const errFile = buildFile(raw, 'error');\n emit('error', new Error(`文件 ${raw.name} 超过最大限制 ${props.maxSize}MB`), errFile, fileList.value);\n return;\n }\n\n const file = buildFile(raw, 'ready');\n\n // 生成预览\n if (isImage(raw)) {\n const reader = new FileReader();\n reader.onload = (e) => { file.preview = e.target.result; };\n reader.readAsDataURL(raw);\n }\n\n const beforeHook = props.beforeUpload ? props.beforeUpload(raw) : true;\n Promise.resolve(beforeHook).then((result) => {\n if (result === false) return;\n addFile(file);\n if (props.autoUpload && props.action) {\n uploadFile(file);\n }\n }).catch(() => {});\n });\n};\n\nconst buildFile = (raw, status) => ({\n uid: genUid(),\n name: raw.name,\n size: raw.size,\n type: raw.type,\n status,\n percentage: 0,\n raw,\n url: '',\n preview: '',\n response: null,\n});\n\nconst addFile = (file) => {\n fileList.value.push(file);\n syncModel();\n emit('change', file, fileList.value);\n};\n\nconst syncModel = () => {\n const urls = fileList.value\n .filter((f) => f.status === 'success' && f.url)\n .map((f) => String(f.url));\n emit('update:modelValue', urls);\n};\n\n/* -------------------- 上传逻辑 -------------------- */\nconst uploadFile = (file) => {\n file.status = 'uploading';\n const formData = new FormData();\n formData.append(props.name, file.raw);\n Object.entries(props.data).forEach(([k, v]) => formData.append(k, v));\n\n // 使用 axios 直接调,以获得 onUploadProgress\n const tokenKey = window.VTK_CONFIG?.storageKeys?.token || '_mis_acis_token';\n const token = window.$vtk?.storage?.get(tokenKey) || localStorage.getItem(tokenKey);\n\n const headers = {\n 'content-type': 'multipart/form-data',\n ...props.headers,\n };\n if (token) headers['Authorization'] = `Bearer ${token}`;\n\n Request.http(props.action, formData, 'POST', headers).then((res) => {\n file.status = 'success';\n file.response = res;\n // 兼容 { data: 'url' } 和 { data: { url: '...' } } 两种结构\n const url = typeof res?.data === 'string' ? res.data : (res?.data?.url || res?.url || '');\n if (url) file.url = url;\n console.log('[VtkUpload] res:', res, '| file.url:', file.url, '| fileList:', JSON.parse(JSON.stringify(fileList.value)));\n syncModel();\n emit('success', res, file, fileList.value);\n emit('change', file, fileList.value);\n }).catch((err) => {\n file.status = 'error';\n syncModel();\n emit('error', err, file, fileList.value);\n emit('change', file, fileList.value);\n });\n};\n\n/* -------------------- 移除文件 -------------------- */\nconst handleRemove = (file) => {\n const doRemove = () => {\n fileList.value = fileList.value.filter((f) => f.uid !== file.uid);\n syncModel();\n emit('remove', file, fileList.value);\n };\n\n if (props.beforeRemove) {\n Promise.resolve(props.beforeRemove(file, fileList.value)).then((result) => {\n if (result !== false) doRemove();\n }).catch(() => {});\n } else {\n doRemove();\n }\n};\n\n/* -------------------- 预览 -------------------- */\nconst isPdf = (file) => /\\.pdf$/i.test(file?.name || '') || file?.type === 'application/pdf';\nconst isExcel = (file) => /\\.(xlsx|xls)$/i.test(file?.name || '');\n\nconst handlePreview = (file) => {\n emit('preview', file);\n\n const fileUrl = file.url || file.preview;\n\n // PDF:新标签页直接打开(浏览器原生支持)\n if (isPdf(file)) {\n if (fileUrl) {\n window.open(fileUrl, '_blank');\n } else if (file.raw instanceof File || file.raw instanceof Blob) {\n // 本地未上传文件,用 Blob URL 打开\n const blobUrl = URL.createObjectURL(file.raw);\n const win = window.open(blobUrl, '_blank');\n win?.addEventListener('unload', () => URL.revokeObjectURL(blobUrl));\n } else {\n // 无可用地址也无本地文件,降级到 Dialog\n previewFile.value = { ...file, _previewSrc: fileUrl };\n previewVisible.value = true;\n }\n return;\n }\n\n // Excel:Office Online 查看器(需要文件有公网 URL)\n if (isExcel(file)) {\n if (fileUrl && /^https?:\\/\\//.test(fileUrl)) {\n window.open(`https://view.officeapps.live.com/op/view.aspx?src=${encodeURIComponent(fileUrl)}`, '_blank');\n } else {\n // 无公网地址,降级为 Dialog 显示提示\n previewFile.value = { ...file, _previewSrc: fileUrl };\n previewVisible.value = true;\n }\n return;\n }\n\n // 图片及其他:Dialog 内嵌预览\n // 统一挂载可用的预览地址,供 Dialog 使用\n previewFile.value = {\n ...file,\n _previewSrc: fileUrl,\n };\n previewVisible.value = true;\n};\n\n/* -------------------- 对外暴露方法 -------------------- */\n/** 手动触发未上传文件的上传 */\nconst submit = () => {\n fileList.value\n .filter((f) => f.status === 'ready' && props.action)\n .forEach(uploadFile);\n};\n\n/** 清空文件列表 */\nconst clearFiles = () => {\n fileList.value = [];\n syncModel();\n};\n\n/** 手动移除某个文件 */\nconst remove = (file) => handleRemove(file);\n\ndefineExpose({ submit, clearFiles, remove });\n</script>\n\n<style lang=\"scss\" scoped>\n.vtk-upload {\n width: 100%;\n}\n\n/* ---- 拖拽区域 ---- */\n.vtk-upload__dragger {\n border: 1px dashed rgba(0, 0, 0, 0.2);\n border-radius: 6px;\n padding: 24px 16px;\n text-align: center;\n cursor: pointer;\n transition: border-color 0.2s, background 0.2s;\n background: transparent;\n\n &:hover:not(.is-disabled) {\n border-color: rgb(var(--v-theme-primary));\n }\n\n &.is-dragover {\n border-color: rgb(var(--v-theme-primary));\n background: rgba(var(--v-theme-primary), 0.05);\n }\n\n &.is-disabled {\n cursor: not-allowed;\n opacity: 0.6;\n }\n}\n\n/* ---- 文件列表 ---- */\n.vtk-upload__list {\n border-top: 1px solid rgba(0, 0, 0, 0.08);\n}\n\n.vtk-upload__list-item {\n position: relative;\n display: flex;\n align-items: center;\n padding: 4px 4px 4px 8px;\n border-radius: 4px;\n font-size: 13px;\n transition: background 0.15s;\n\n &:hover {\n background: rgba(0, 0, 0, 0.04);\n }\n\n &.is-error {\n color: rgb(var(--v-theme-error));\n }\n\n &.is-success .vtk-upload__list-item-name {\n cursor: pointer;\n &:hover { color: rgb(var(--v-theme-primary)); }\n }\n}\n\n.vtk-upload__list-item-name {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n max-width: 500px;\n}\n\n.vtk-upload__list-progress {\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n}\n\n/* ---- picture-card ---- */\n.vtk-upload__picture-card-wrap {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n}\n\n.vtk-upload__picture-card-item,\n.vtk-upload__picture-card-add {\n width: 100px;\n height: 100px;\n border-radius: 6px;\n overflow: hidden;\n}\n\n.vtk-upload__picture-card-item {\n position: relative;\n border: 1px solid rgba(0, 0, 0, 0.12);\n\n &:hover .vtk-upload__picture-card-mask {\n opacity: 1;\n }\n}\n\n.vtk-upload__picture-card-mask {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.45);\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 4px;\n opacity: 0;\n transition: opacity 0.2s;\n}\n\n.vtk-upload__picture-card-progress {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.4);\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.vtk-upload__picture-card-add {\n border: 1px dashed rgba(0, 0, 0, 0.2);\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n transition: border-color 0.2s, background 0.2s;\n\n &:hover, &.is-dragover {\n border-color: rgb(var(--v-theme-primary));\n background: rgba(var(--v-theme-primary), 0.04);\n }\n}\n\n/* ---- 隐藏 input ---- */\n.vtk-upload__input {\n display: none;\n}\n</style>\n","import Request from \"./request.js\";\nimport Storage from \"./storage.js\";\nimport Message from \"../components/message/index.js\";\n\nfunction isAid(value) {\n const str = String(value || \"\");\n return !!str && !/^(https?:)?\\/\\//i.test(str) && !str.includes(\"/\") && !str.includes(\"?\");\n\n \n}\n\nfunction getLinkFromResponse(data) {\n if (!data) {\n return \"\";\n }\n\n if (typeof data === \"string\") {\n return data;\n }\n\n return data.puri || \"\";\n}\n\nfunction buildUrlWithParams(target, appendParams) {\n const queryString = target.includes(\"?\") ? target.split(\"?\")[1] : \"\";\n const queryParams = new URLSearchParams(queryString);\n const newParams = [];\n\n Object.entries(appendParams).forEach(([key, value]) => {\n if (!key || value === undefined || value === null || value === \"\") {\n return;\n }\n\n if (!queryParams.has(key)) {\n newParams.push(`${encodeURIComponent(key)}=${encodeURIComponent(value)}`);\n }\n });\n\n if (!newParams.length) {\n return target;\n }\n\n const joinSymbol = target.includes(\"?\") ? \"&\" : \"?\";\n return `${target}${joinSymbol}${newParams.join(\"&\")}`;\n}\n\nfunction appendParamsToUrl(targetUrl, appendParams) {\n const hashIndex = targetUrl.indexOf(\"#\");\n\n if (hashIndex === -1) {\n return buildUrlWithParams(targetUrl, appendParams);\n }\n\n const baseUrl = targetUrl.slice(0, hashIndex);\n const hashRoute = targetUrl.slice(hashIndex + 1);\n const newHashRoute = buildUrlWithParams(hashRoute, appendParams);\n return `${baseUrl}#${newHashRoute}`;\n}\n\nasync function resolveAidUrl(aid) {\n if (!aid) {\n return aid;\n }\n\n try {\n const res = await Request.postForm(\"/kudas/xfwez/apps\", { aid });\n const realUrl = res?.meta?.success ? getLinkFromResponse(res.data) : \"\";\n return realUrl || aid;\n } catch (error) {\n return aid;\n }\n}\n\nfunction buildAppendParams(sobject, sroute, stokenKey) {\n const appendParams = {};\n const storageKey = stokenKey || \"_mis_acis_token\";\n const stoken = Storage.get(storageKey);\n\n if (stoken !== undefined && stoken !== null && stoken !== \"\") {\n appendParams.stoken = stoken;\n }\n\n if (sroute) {\n appendParams.sroute = sroute;\n }\n\n if (sobject && typeof sobject === \"object\" && Object.keys(sobject).length) {\n appendParams.sobject = btoa(encodeURIComponent(JSON.stringify(sobject)));\n }\n\n return appendParams;\n}\n\n/**\n * 解析地址中的指定参数值。\n * @param {string} name 参数名。\n * @param {string} url 要解析的地址,不传时默认使用当前地址。\n * @return {string} 参数值;未找到时返回空字符串。\n */\nexport function GetQueryString(name, url = window.location.href) {\n const reg = new RegExp(`[?&]${name}=([^&^#^/]*)`, \"i\");\n const res = String(url || \"\").match(reg);\n return res ? decodeURIComponent(res[1]) : \"\";\n}\n\n/**\n * 追加应用访问参数。\n * @param {string} url 链接地址或应用 aid;不传时默认取当前地址。\n * @param {Object} sobject 参数对象;会按 `btoa(encodeURIComponent(JSON.stringify(sobject)))` 编码后追加为 `sobject` 参数。\n * @param {string} sroute 页面路由标识;传值后会在最终地址中追加 `sroute=xxx`。\n * @param {string} stokenKey 取 `stoken` 的存储键名,默认 `_mis_acis_token`。\n * @return {Promise<string>} 拼接后的链接地址。\n */\nexport async function appendAppParams(url, sobject = {}, sroute = \"\", stokenKey = \"_mis_acis_token\") {\n if (url === undefined || url === null || url === \"\" || url === 0 || url === \"0\") {\n Message.toast(\"应用标识错误\", { color: \"error\" });\n return \"\";\n }\n\n const source = url || window.location.href;\n\n if (!source) {\n return \"\";\n }\n\n const targetUrl = isAid(source) ? await resolveAidUrl(source) : source;\n return appendParamsToUrl(targetUrl, buildAppendParams(sobject, sroute, stokenKey));\n}\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) {\n\ttop: 24px;\n}\n</style>\r\n","/**\n * Specter PUI - Vue 3 组件库\n */\n\nexport { default as VtkArea } from \"./components/assembly/VtkArea.vue\";\nexport { default as VtkAreaTabs } from \"./components/assembly/VtkAreaTabs.vue\";\nexport { default as VtkBreadcrumb } from \"./components/assembly/VtkBreadcrumb.vue\";\nexport { default as VtkCheckbox } from \"./components/assembly/VtkCheckbox.vue\";\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 VtkDept } from \"./components/assembly/VtkDept.vue\";\nexport { default as VtkEmpty } from \"./components/assembly/VtkEmpty.vue\";\nexport { default as VtkFab } from \"./components/assembly/VtkFab.vue\";\nexport { default as VtkFormItem } from \"./components/assembly/VtkFormItem.vue\";\nexport { default as VtkImg } from \"./components/assembly/VtkImg.vue\";\nexport { default as VtkPage } from \"./components/assembly/VtkPage.vue\";\nexport { default as VtkPdf } from \"./components/assembly/VtkPdf.vue\";\nexport { default as VtkProj } from \"./components/assembly/VtkProj.vue\";\nexport { default as VtkRadio } from \"./components/assembly/VtkRadio.vue\";\nexport { default as VtkSearch } from \"./components/assembly/VtkSearch.vue\";\nexport { default as VtkSelect } from \"./components/assembly/VtkSelect.vue\";\nexport { default as VtkStepper } from \"./components/assembly/VtkStepper.vue\";\nexport { default as VtkUpload } from \"./components/assembly/VtkUpload.vue\";\n\nexport * from \"./commons/location.js\";\nexport * from \"./commons/filters/dictionary.js\";\nexport * from \"./commons/filters/format.js\";\nexport * from \"./commons/filters/mask.js\";\nexport { default as request } from \"./commons/request.js\";\nexport { default as storage } from \"./commons/storage.js\";\nexport { default as themes } from \"./commons/themes.js\";\nexport * from \"./commons/validation.js\";\n\nexport { useMixins } from \"./composables/usePage.js\";\nexport { default as vtkMessage } from \"./components/message/index.js\";\n\nimport vtkMessage from \"./components/message/index.js\";\nimport storage from \"./commons/storage.js\";\nimport themes from \"./commons/themes.js\";\nimport request from \"./commons/request.js\";\nimport * as location from \"./commons/location.js\";\nimport Validation from \"./commons/validation.js\";\nimport * as dictionary from \"./commons/filters/dictionary.js\";\nimport * as mask from \"./commons/filters/mask.js\";\nimport * as format from \"./commons/filters/format.js\";\n\nimport VtkArea from \"./components/assembly/VtkArea.vue\";\nimport VtkAreaTabs from \"./components/assembly/VtkAreaTabs.vue\";\nimport VtkBreadcrumb from \"./components/assembly/VtkBreadcrumb.vue\";\nimport VtkCheckbox from \"./components/assembly/VtkCheckbox.vue\";\nimport VtkCount from \"./components/assembly/VtkCount.vue\";\nimport VtkDatePicker from \"./components/assembly/VtkDatePicker.vue\";\nimport VtkDateSelector from \"./components/assembly/VtkDateSelector.vue\";\nimport VtkDept from \"./components/assembly/VtkDept.vue\";\nimport VtkEmpty from \"./components/assembly/VtkEmpty.vue\";\nimport VtkFab from \"./components/assembly/VtkFab.vue\";\nimport VtkFormItem from \"./components/assembly/VtkFormItem.vue\";\nimport VtkImg from \"./components/assembly/VtkImg.vue\";\nimport VtkPage from \"./components/assembly/VtkPage.vue\";\nimport VtkPdf from \"./components/assembly/VtkPdf.vue\";\nimport VtkProj from \"./components/assembly/VtkProj.vue\";\nimport VtkRadio from \"./components/assembly/VtkRadio.vue\";\nimport VtkSearch from \"./components/assembly/VtkSearch.vue\";\nimport VtkSelect from \"./components/assembly/VtkSelect.vue\";\nimport VtkStepper from \"./components/assembly/VtkStepper.vue\";\nimport VtkUpload from \"./components/assembly/VtkUpload.vue\";\nimport VtkMessageComponent from \"./components/message/vtkMessage.vue\";\n\nfunction install(app, options = {}) {\n const components = {\n VtkArea,\n VtkAreaTabs,\n VtkBreadcrumb,\n VtkCheckbox,\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDept,\n VtkEmpty,\n VtkFab,\n VtkFormItem,\n VtkImg,\n VtkPage,\n VtkPdf,\n VtkProj,\n VtkRadio,\n VtkSearch,\n VtkSelect,\n VtkStepper,\n VtkUpload,\n VtkMessage: VtkMessageComponent\n };\n\n Object.keys(components).forEach(name => {\n app.component(name, components[name]);\n });\n\n app.config.globalProperties.$vtk = {\n message: vtkMessage,\n request,\n storage,\n themes,\n location,\n Validation,\n filters: {\n ...dictionary,\n ...mask,\n ...format\n },\n ...options\n };\n\n return app;\n}\n\nexport default {\n install,\n VtkArea,\n VtkAreaTabs,\n VtkBreadcrumb,\n VtkCheckbox,\n VtkCount,\n VtkDatePicker,\n VtkDateSelector,\n VtkDept,\n VtkEmpty,\n VtkFab,\n VtkFormItem,\n VtkImg,\n VtkPage,\n VtkPdf,\n VtkProj,\n VtkRadio,\n VtkSearch,\n VtkSelect,\n VtkStepper,\n VtkUpload,\n request,\n storage,\n themes,\n vtkMessage\n};\n"],"names":["Storage","storage","type","key","js","value","useMessageStore","defineStore","options","Message","messageStore","defaultOptions","text","toastOptions","service","axios","config","tokenKey","_b","_a","error","response","res","header","handleRedirect","url","index","newUrl","Request","data","method","headers","responseType","proxy","getCurrentInstance","emit","__emit","entity","reactive","user","ref","areaData","onMounted","userKey","area","nextArea","areaCode","inputFn","e","clear","arr","_openBlock","_createElementBlock","_hoisted_1","_createVNode","_component_VSelect","_cache","$event","__props","_createBlock","_c","_normalizeClass","_d","_e","_f","_g","_h","_i","_normalizeStyle","_j","props","menu","tab","tabItems","areaStorage","areaItems","current","itemValue","itemText","view","code","province","city","district","town","village","tabArea","areaChange","item","getTree","nextTick","getAreaName","save","val","lastItem","close","textClear","initCode","watch","newVal","oldVal","_component_v_menu","_withCtx","_component_v_btn","_mergeProps","$attrs","_createElementVNode","_toDisplayString","_component_v_icon","_component_v_card","_hoisted_2","_Fragment","_renderList","link","_component_v_sheet","_component_v_tabs","_component_v_tab","_createTextVNode","_vShow","_component_v_chip_group","_component_v_chip","_component_v_card_actions","_component_v_spacer","router","inject","route","breadcrumbItems","computed","matched","r","pathArray","p","path","routePath","handleBack","_component_v_breadcrumbs","_component_v_breadcrumbs_item","localValue","isUpdatingLocal","isUpdatingModel","attrs","useAttrs","inputAttrs","list","inline","modelValue","rest","checkboxAttrs","errorMessages","rules","hint","persistentHint","inputValue","items","statc","it","codeValue","miscs","_component_VInput","_component_VCheckbox","currentNumber","currentDigits","digitKey","isAnimating","formatNumber","num","result","targetNumberString","startNumberString","maxDigitString","target","start","getCurrentDigit","initDigitsArray","startStr","char","startChar","getDigitStyle","currentValue","digitValue","offset","translateY","startAnimation","startTime","startValue","endValue","diff","animate","currentTime","elapsed","progress","easeOutQuart","updateDigitArray","valueStr","maxStr","i","newStr","oldStr","endStr","__expose","digitChar","_hoisted_4","_hoisted_3","n","_hoisted_5","dateRange","startDateRange","endDateRange","displayValue","formatDate","textFieldProps","placeholder","disabled","min","max","showCurrent","format","separator","date","year","month","day","minDate","maxDate","newValue","dates","onStartDateChange","onEndDateChange","clearValue","cancel","confirm","sortedRange","date1","date2","_component_VMenu","activatorProps","_component_VTextField","_component_VIcon","_component_VCard","_component_VCardText","_component_VDatePicker","_component_VDivider","_component_VCardActions","_component_VSpacer","_component_VBtn","YEAR_PANEL_SIZE","YEAR_PANEL_CENTER_OFFSET","showPicker","viewMode","currentYear","currentMonth","rightYear","rightMonth","selectedValue","tempValue","today","todayYear","todayMonth","todayDate","weekDays","monthList","menuAttach","menuLocation","menuOrigin","formatDisplay","week","yearList","startYear","_","weekList","weeks","firstDay","lastDay","currentDate","weekNumber","getWeekNumber","isToday","dayList","days","startDate","endDate","nextMonthYear","nextMonthMonth","nextMonthDayList","d","dayNum","yearStart","isYearSelected","v","isYearInRange","end","isMonthSelected","monthStr","isMonthInRange","isWeekSelected","weekStr","isWeekInRange","isDaySelected","isDayInRange","isDayRangeStart","isDayRangeEnd","isFutureYear","isFutureMonth","isFutureDay","selectYear","yearStr","first","selectMonth","selectMonthRight","isMonthSelectedRight","isMonthInRangeRight","selectWeek","selectDay","prevPeriod","nextPeriod","prevMonth","nextMonthLeft","prevMonthRight","nextMonth","prevYear","nextYearLeft","prevYearRight","nextYear","changeViewMode","mode","initializePicker","isOpen","closePicker","handleCancel","handleConfirm","menuProps","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","_hoisted_16","_hoisted_17","_hoisted_18","_hoisted_19","_hoisted_20","_hoisted_21","_hoisted_22","_hoisted_23","_hoisted_24","_hoisted_25","_hoisted_27","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","_hoisted_36","_hoisted_37","_hoisted_38","_hoisted_39","_hoisted_40","_hoisted_41","_hoisted_42","_hoisted_43","_hoisted_44","_hoisted_45","_hoisted_46","_hoisted_47","_hoisted_48","_hoisted_49","_hoisted_50","_hoisted_51","_hoisted_52","_hoisted_53","_hoisted_54","_hoisted_55","_hoisted_56","_hoisted_57","_hoisted_58","_hoisted_59","_hoisted_60","_hoisted_61","_hoisted_62","_hoisted_63","_hoisted_64","_hoisted_65","_hoisted_66","_hoisted_67","_hoisted_68","_hoisted_69","_hoisted_70","_hoisted_71","_hoisted_73","_hoisted_74","_hoisted_75","_hoisted_76","_hoisted_77","_hoisted_78","_hoisted_79","_hoisted_80","_hoisted_81","_hoisted_82","_hoisted_83","_hoisted_84","_hoisted_85","_hoisted_86","_hoisted_87","_hoisted_88","_hoisted_89","_hoisted_90","_hoisted_91","_hoisted_92","_hoisted_93","_hoisted_94","pause","ms","resolve","dialog","areaSelectedData","areaActivatedData","getDeptList","getAreaList","getAreaNextList","parentCode","deptData","deptSelectedData","deptActivatedData","getPersonList","node","params","getDepNextList","selectAreaCode","selectPid","personData","selectedPersonData","allSelectedPersons","isRestoringSelection","selectedPersonList","uniqueMap","person","oldPerson","newPersonData","currentSelected","removeSelectedPerson","personId","globalIndex","currentIndex","add","selectedPersons","_component_v_dialog","_component_v_card_title","_component_v_divider","_component_v_card_text","_component_v_row","_component_v_col","_component_v_treeview","_component_v_avatar","_component_v_img","_component_v_list","_component_v_list_item","_component_v_empty_state","$slots","_renderSlot","_ctx","showFab","fabClass","handleScroll","scrollToTop","onBeforeUnmount","_Transition","_component_v_fab","processedMaxWidth","contentStyles","styles","showPreview","imageRotation","srcWithToken","token","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","step","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","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":[29]}