@gkd-kit/inspect 0.0.1749439290229 → 0.0.1750946288791

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.
Files changed (82) hide show
  1. package/dist/assets/ActionCard.vue_vue_type_script_setup_true_lang-Cnaxemvq.js +17 -0
  2. package/dist/assets/ActionCard.vue_vue_type_script_setup_true_lang-Cnaxemvq.js.map +1 -0
  3. package/dist/assets/DevicePage-irWCBZJk.js +49 -0
  4. package/dist/assets/DevicePage-irWCBZJk.js.map +1 -0
  5. package/dist/assets/HomePage-CpMvv5BD.js +112 -0
  6. package/dist/assets/HomePage-CpMvv5BD.js.map +1 -0
  7. package/dist/assets/ImportPage-siV6sg_N.js +2 -0
  8. package/dist/assets/ImportPage-siV6sg_N.js.map +1 -0
  9. package/dist/assets/{Input-DgyUdul6.js → Input-LBE_dSWh.js} +36 -36
  10. package/dist/assets/Input-LBE_dSWh.js.map +1 -0
  11. package/dist/assets/SelectorPage-CO9K0gOJ.js +2 -0
  12. package/dist/assets/SelectorPage-CO9K0gOJ.js.map +1 -0
  13. package/dist/assets/SnapshotPage-B8VO0pfz.js +272 -0
  14. package/dist/assets/SnapshotPage-B8VO0pfz.js.map +1 -0
  15. package/dist/assets/SnapshotPage-DYZIR4dQ.css +1 -0
  16. package/dist/assets/SvgPage-TP2u1ol-.js +2 -0
  17. package/dist/assets/SvgPage-TP2u1ol-.js.map +1 -0
  18. package/dist/assets/TrackGraph-Co0PHU9P.js +134 -0
  19. package/dist/assets/TrackGraph-Co0PHU9P.js.map +1 -0
  20. package/dist/assets/_404Page-CQh1DVF5.js +2 -0
  21. package/dist/assets/_404Page-CQh1DVF5.js.map +1 -0
  22. package/dist/assets/chunk-Bh54nOoC.js +3 -0
  23. package/dist/assets/chunk-Bh54nOoC.js.map +1 -0
  24. package/dist/assets/{dayjs.min-CMwzZYWK.js → dayjs.min-BDtMCPxg.js} +10 -14
  25. package/dist/assets/dayjs.min-BDtMCPxg.js.map +1 -0
  26. package/dist/assets/{error-DLcDz2op.js → error-C-6YN-2R.js} +13 -13
  27. package/dist/assets/{error-DLcDz2op.js.map → error-C-6YN-2R.js.map} +1 -1
  28. package/dist/assets/import-DNz3f_43.js +2 -0
  29. package/dist/assets/import-DNz3f_43.js.map +1 -0
  30. package/dist/assets/index-C3FL7Em4.js +977 -0
  31. package/dist/assets/index-C3FL7Em4.js.map +1 -0
  32. package/dist/assets/{index-CHaIZrD6.css → index-C98pF2u5.css} +1 -1
  33. package/dist/assets/index-CY51Ezeg.js +10 -0
  34. package/dist/assets/{index-nrmjhBDW.js.map → index-CY51Ezeg.js.map} +1 -1
  35. package/dist/assets/{jszip.min-Dn-oymRr.js → jszip.min-D-_xaZtC.js} +3 -3
  36. package/dist/assets/{jszip.min-Dn-oymRr.js.map → jszip.min-D-_xaZtC.js.map} +1 -1
  37. package/dist/assets/node-Byj22vOu.js +126 -0
  38. package/dist/assets/{node-BU-u7VcN.js.map → node-Byj22vOu.js.map} +1 -1
  39. package/dist/assets/polyfills-DHsnwdd7.js +2 -0
  40. package/dist/assets/polyfills-DHsnwdd7.js.map +1 -0
  41. package/dist/assets/snapshot-YJJVxAwu.js +3 -0
  42. package/dist/assets/{snapshot-LXrnvSmm.js.map → snapshot-YJJVxAwu.js.map} +1 -1
  43. package/dist/assets/{table-JTn0xZC1.js → table-Dcza-KRw.js} +18 -17
  44. package/dist/assets/table-Dcza-KRw.js.map +1 -0
  45. package/dist/assets/worker-DFsORLo-.js +10 -0
  46. package/dist/assets/worker-DFsORLo-.js.map +1 -0
  47. package/dist/index.html +4 -2
  48. package/package.json +37 -36
  49. package/dist/assets/ActionCard.vue_vue_type_script_setup_true_lang-Ddm4FDEW.js +0 -17
  50. package/dist/assets/ActionCard.vue_vue_type_script_setup_true_lang-Ddm4FDEW.js.map +0 -1
  51. package/dist/assets/DevicePage-8odSV3Hq.js +0 -49
  52. package/dist/assets/DevicePage-8odSV3Hq.js.map +0 -1
  53. package/dist/assets/HomePage-PzBg6JK7.js +0 -112
  54. package/dist/assets/HomePage-PzBg6JK7.js.map +0 -1
  55. package/dist/assets/ImportPage-BjIx-_N1.js +0 -2
  56. package/dist/assets/ImportPage-BjIx-_N1.js.map +0 -1
  57. package/dist/assets/Input-DgyUdul6.js.map +0 -1
  58. package/dist/assets/SelectorPage-Dq0IIsjv.js +0 -2
  59. package/dist/assets/SelectorPage-Dq0IIsjv.js.map +0 -1
  60. package/dist/assets/SnapshotPage-BKYM296L.js +0 -273
  61. package/dist/assets/SnapshotPage-BKYM296L.js.map +0 -1
  62. package/dist/assets/SnapshotPage-DHogz4lw.css +0 -1
  63. package/dist/assets/SvgPage-Ub-pRGhU.js +0 -2
  64. package/dist/assets/SvgPage-Ub-pRGhU.js.map +0 -1
  65. package/dist/assets/TrackGraph-lKQE5cUJ.js +0 -134
  66. package/dist/assets/TrackGraph-lKQE5cUJ.js.map +0 -1
  67. package/dist/assets/_404Page-DRLShDBE.js +0 -2
  68. package/dist/assets/_404Page-DRLShDBE.js.map +0 -1
  69. package/dist/assets/chunk-CPNWa47E.js +0 -3
  70. package/dist/assets/chunk-CPNWa47E.js.map +0 -1
  71. package/dist/assets/dayjs.min-CMwzZYWK.js.map +0 -1
  72. package/dist/assets/import-Ck1vFpon.js +0 -2
  73. package/dist/assets/import-Ck1vFpon.js.map +0 -1
  74. package/dist/assets/index-DJ3BflFD.js +0 -978
  75. package/dist/assets/index-DJ3BflFD.js.map +0 -1
  76. package/dist/assets/index-nrmjhBDW.js +0 -10
  77. package/dist/assets/node-BU-u7VcN.js +0 -127
  78. package/dist/assets/snapshot-LXrnvSmm.js +0 -3
  79. package/dist/assets/table-JTn0xZC1.js.map +0 -1
  80. package/dist/assets/worker-lNTWuAmw.js +0 -10
  81. package/dist/assets/worker-lNTWuAmw.js.map +0 -1
  82. package/dist/test.xml +0 -26
@@ -1 +0,0 @@
1
- {"version":3,"file":"DevicePage-8odSV3Hq.js","sources":["../../src/utils/api.ts","../../src/views/DevicePage.vue"],"sourcesContent":["import { message } from './discrete';\nimport { enhanceFetch } from './fetch';\nimport type { Device, RpcError, Snapshot } from './types';\n\ntype RpcOptions = {\n query?: Record<string, unknown>;\n init?: RequestInit;\n};\n\nexport const useDeviceApi = (initOrigin?: string) => {\n const origin = shallowRef(initOrigin);\n const rpc = async (rpcName: string, options: RpcOptions = {}) => {\n if (!origin.value) {\n throw new Error(`origin must exist`);\n }\n const u = new URL(`/api/` + rpcName, origin.value);\n Object.entries(options.query || {}).forEach(([key, value]) => {\n if (value === undefined) return;\n u.searchParams.set(key, String(value));\n });\n const response = await enhanceFetch(u, options.init).catch((e) => {\n message.error(`网络错误:/` + rpcName);\n throw e;\n });\n if (!response.ok) {\n message.error(`接口错误:/` + rpcName + `:` + response.status);\n throw response;\n }\n if (response.headers.get(`Content-Type`)?.includes(`application/json`)) {\n const error = (await response.clone().json()) as RpcError;\n if (error.__error) {\n message.error(error.message);\n throw response;\n }\n }\n return response;\n };\n const jsonRpc = async <T>(...args: Parameters<typeof rpc>) => {\n const response = await rpc(...args);\n return (await response.json()) as T;\n };\n const blobRpc = async (...args: Parameters<typeof rpc>) => {\n const response = await rpc(...args);\n return await response.blob();\n };\n const arrayBufferRpc = async (...args: Parameters<typeof rpc>) => {\n const response = await rpc(...args);\n return await response.arrayBuffer();\n };\n const api = {\n device: async () => jsonRpc<Device>(`device`),\n snapshot: async (query?: { id?: string | number }) => {\n return jsonRpc<Snapshot>(`snapshot`, { query });\n },\n screenshot: async (query: { id: string | number }) => {\n return arrayBufferRpc(`screenshot`, { query });\n },\n captureSnapshot: async () => {\n return jsonRpc<Snapshot>(`captureSnapshot`);\n },\n snapshots: async () => {\n return jsonRpc<Snapshot[]>(`snapshots`);\n },\n updateSubsApps: async (data: unknown[]) => {\n return blobRpc(`updateSubsApps`, {\n init: {\n method: 'POST',\n body: JSON.stringify(data),\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n });\n },\n updateSubscription: async (data: any) => {\n return blobRpc(`updateSubscription`, {\n init: {\n method: 'POST',\n body: JSON.stringify({\n ...data,\n id: -1,\n name: '内存订阅',\n version: 0,\n }),\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n });\n },\n execSelector: async (data: {\n selector: string;\n action?: string;\n quickFind?: boolean;\n fastQuery?: boolean;\n }) => {\n data = structuredClone(data);\n data.action ||= undefined;\n return jsonRpc<{ message: string; action: string; result: boolean }>(\n `execSelector`,\n {\n init: {\n method: 'POST',\n body: JSON.stringify(data),\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n },\n );\n },\n };\n return { origin, api };\n};\n","<script setup lang=\"tsx\">\nimport { useDeviceApi } from '@/utils/api';\nimport { toValidURL } from '@/utils/check';\nimport { message } from '@/utils/discrete';\nimport { errorWrap } from '@/utils/error';\nimport { delay } from '@/utils/others';\nimport { screenshotStorage, snapshotStorage } from '@/utils/snapshot';\nimport { useSnapshotColumns } from '@/utils/table';\nimport { useBatchTask, useTask } from '@/utils/task';\nimport type { Device, Snapshot } from '@/utils/types';\nimport type { DataTableColumns, PaginationProps } from 'naive-ui';\nimport type { SortState } from 'naive-ui/es/data-table/src/interface';\nimport pLimit from 'p-limit';\n\nconst router = useRouter();\nconst { api, origin } = useDeviceApi();\nconst link = useStorage(`device_link`, ``);\nconst device = shallowRef<Device>();\nconst connect = useTask(async () => {\n if (!link.value) return;\n origin.value = errorWrap(\n () => new URL(link.value.trim()),\n () => `非法设备地址`,\n ).origin;\n link.value = origin.value;\n device.value = await api.device();\n});\nonMounted(async () => {\n await delay(500);\n if (toValidURL(link.value)) {\n connect.invoke();\n }\n});\n\nconst snapshots = shallowRef<Snapshot[]>([]);\nwatchEffect(async () => {\n if (!device.value) return;\n document.title = `已连接 ` + device.value.manufacturer;\n const result = await api.snapshots();\n result.sort((a, b) => b.id - a.id);\n snapshots.value = result;\n subsText.value = '';\n});\n\nconst captureSnapshot = useTask(async () => {\n const snapshot = await api.captureSnapshot();\n const screenshot = await api.screenshot({ id: snapshot.id });\n await snapshotStorage.setItem(snapshot.id, snapshot);\n await screenshotStorage.setItem(snapshot.id, screenshot);\n message.success(`保存快照成功`);\n const result = await api.snapshots();\n result.sort((a, b) => b.id - a.id);\n snapshots.value = result;\n});\nconst downloadAllSnapshot = useTask(async () => {\n const snapshotIds = (await api.snapshots()).map((s) => s.id);\n const existSnapshotIds = new Set(\n (await screenshotStorage.keys()).map((s) => parseInt(s)),\n );\n const unimportSnapshotIds = snapshotIds.filter(\n (k) => !existSnapshotIds.has(k),\n );\n if (unimportSnapshotIds.length == 0) {\n message.success(`没有新记录可导入`);\n return;\n }\n let r = 0;\n const limit = pLimit(3);\n await Promise.all(\n unimportSnapshotIds.map((snapshotId) =>\n limit(async () => {\n const [newSnapshot, newScreenshot] = await Promise.all([\n api.snapshot({ id: snapshotId }),\n api.screenshot({ id: snapshotId }),\n ] as const);\n if (!newSnapshot.nodes) return;\n await Promise.all([\n snapshotStorage.setItem(snapshotId, newSnapshot),\n screenshotStorage.setItem(snapshotId, newScreenshot),\n ]);\n r++;\n }),\n ),\n );\n message.success(`导入${r}条新记录`);\n});\n\nconst {\n activityIdCol,\n appIdCol,\n appNameCol,\n ctimeCol,\n appVersionCodeCol,\n appVersionNameCol,\n resetColWidth,\n} = useSnapshotColumns();\nconst handleSorterChange = (sorter: SortState) => {\n if (sorter.columnKey == ctimeCol.key) {\n ctimeCol.sortOrder = sorter.order;\n }\n};\nconst previewSnapshot = useBatchTask(\n async (row: Snapshot) => {\n if (!(await snapshotStorage.hasItem(row.id))) {\n await snapshotStorage.setItem(row.id, await api.snapshot({ id: row.id }));\n }\n if (!(await screenshotStorage.hasItem(row.id))) {\n const bf = await api.screenshot({ id: row.id });\n await screenshotStorage.setItem(row.id, bf);\n }\n window.open(\n router.resolve({\n name: 'snapshot',\n params: { snapshotId: row.id },\n }).href,\n );\n },\n (r) => r.id,\n);\n\nconst columns: DataTableColumns<Snapshot> = [\n ctimeCol,\n appNameCol,\n appIdCol,\n appVersionCodeCol,\n appVersionNameCol,\n activityIdCol,\n {\n key: `actions`,\n title: `操作`,\n fixed: 'right',\n width: `120px`,\n render(row) {\n return (\n <NSpace size=\"small\">\n <NButton\n size=\"small\"\n loading={previewSnapshot.loading[row.id]}\n onClick={() => previewSnapshot.invoke(row)}\n >\n 查看\n </NButton>\n </NSpace>\n );\n },\n },\n];\n\nconst pagination = shallowReactive<PaginationProps>({\n page: 1,\n pageSize: 50,\n showSizePicker: true,\n pageSizes: [50, 100],\n onChange: (page: number) => {\n pagination.page = page;\n },\n onUpdatePageSize: (pageSize: number) => {\n pagination.pageSize = pageSize;\n pagination.page = 1;\n },\n});\nwatch(pagination, resetColWidth);\n\nconst showSubsModel = shallowRef(false);\nconst subsText = shallowRef(``);\nconst updateSubs = useTask(async () => {\n const data = errorWrap(() => JSON5.parse(subsText.value.trim()));\n if (!data) return;\n if (data.categories || data.globalGroups || data.apps) {\n await api.updateSubscription(data);\n } else if (typeof data.id == 'string') {\n await api.updateSubscription({\n apps: [data],\n });\n } else if (Array.isArray(data) && typeof data[0].id == 'string') {\n await api.updateSubscription({\n apps: data,\n });\n } else if (typeof data.key == 'number') {\n await api.updateSubscription({\n globalGroups: [data],\n });\n } else if (Array.isArray(data) && typeof data[0].key == 'number') {\n await api.updateSubscription({\n globalGroups: data,\n });\n } else {\n message.error(`无法识别的订阅文本`);\n return;\n }\n message.success(`修改成功`);\n});\n\nconst showSelectorModel = shallowRef(false);\n\nconst actionOptions: {\n value?: string;\n label: string;\n}[] = [\n {\n label: '仅查询',\n value: ``,\n },\n {\n value: 'click',\n label: 'click',\n },\n {\n value: 'clickNode',\n label: 'clickNode',\n },\n {\n value: 'clickCenter',\n label: 'clickCenter',\n },\n {\n value: 'back',\n label: 'back',\n },\n {\n value: 'longClick',\n label: 'longClick',\n },\n {\n value: 'longClickNode',\n label: 'longClickNode',\n },\n {\n value: 'longClickCenter',\n label: 'longClickCenter',\n },\n];\nconst clickAction = shallowReactive({\n selector: ``,\n action: 'click',\n quickFind: false,\n});\nconst execSelector = useTask(async () => {\n const result = await api.execSelector({\n ...clickAction,\n fastQuery: clickAction.quickFind,\n });\n if (result.message) {\n message.success(`操作成功:` + result.message);\n return;\n }\n if (result.action) {\n message.success((result.result ? `操作成功:` : `操作失败`) + result.action);\n } else if (!result.action && result.result) {\n message.success(`查询成功`);\n }\n});\n\nconst placeholder = `\n请输入订阅文本(JSON5语法):\n示例1-更新单个应用的规则:\n{\n id: 'appId',\n groups: []\n}\n\n示例2-更新多个应用的规则:\n[\n {\n id: 'appId1',\n groups: []\n },\n {\n id: 'appId2',\n groups: []\n }\n]\n\n示例3-更新全局规则(1.7.0):\n{\n name: '全局规则-1',\n key: 0,\n rules: []\n}\n\n示例3-更新多个全局规则(1.7.0):\n[\n {\n name: '全局规则-1',\n key: 0,\n rules: []\n },\n {\n name: '全局规则-2',\n key: 1,\n rules: []\n }\n]\n\n示例4-更新整个订阅(1.7.0):\n{\n apps: [],\n globalGroups: [],\n categories: [],\n}\n`.trim();\n</script>\n<template>\n <NModal\n v-model:show=\"showSubsModel\"\n preset=\"dialog\"\n style=\"width: 800px\"\n title=\"修改内存订阅\"\n positive-text=\"确认\"\n :positiveButtonProps=\"{\n loading: updateSubs.loading,\n onClick() {\n updateSubs.invoke();\n },\n }\"\n >\n <NInput\n v-model:value=\"subsText\"\n :disabled=\"updateSubs.loading\"\n type=\"textarea\"\n class=\"gkd_code\"\n :autosize=\"{\n minRows: 20,\n maxRows: 25,\n }\"\n :placeholder=\"placeholder\"\n />\n </NModal>\n <NModal\n v-model:show=\"showSelectorModel\"\n preset=\"dialog\"\n style=\"width: 800px\"\n title=\"执行选择器\"\n positive-text=\"确认\"\n :positiveButtonProps=\"{\n loading: execSelector.loading,\n onClick() {\n execSelector.invoke();\n },\n }\"\n >\n <NInput\n v-model:value=\"clickAction.selector\"\n :disabled=\"execSelector.loading\"\n type=\"textarea\"\n class=\"gkd_code\"\n :autosize=\"{\n minRows: 4,\n maxRows: 10,\n }\"\n placeholder=\"请输入合法的选择器\"\n />\n <div h-15px></div>\n <NSpace>\n <NCheckbox v-model:checked=\"clickAction.quickFind\"> 快速查找 </NCheckbox>\n <a\n href=\"https://gkd.li/api/interfaces/RawCommonProps.html#quickfind\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n 查找说明\n </a>\n </NSpace>\n <div h-10px></div>\n <div flex gap-10px flex-items-center>\n <NSelect\n v-model:value=\"clickAction.action\"\n :options=\"actionOptions\"\n class=\"w-150px\"\n />\n <a\n href=\"https://gkd.li/api/interfaces/RawRuleProps#action\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n 操作说明\n </a>\n </div>\n </NModal>\n <div flex flex-col p-10px gap-10px h-full>\n <div flex items-center gap-24px>\n <RouterLink to=\"/\" flex ml-12px title=\"首页\">\n <NButton text style=\"--n-icon-size: 24px\">\n <template #icon>\n <SvgIcon name=\"home\" />\n </template>\n </NButton>\n </RouterLink>\n <NInputGroup>\n <NInput\n v-model:value=\"link\"\n placeholder=\"请输入设备地址\"\n :style=\"{ width: `320px` }\"\n @keyup.enter=\"connect.invoke\"\n ></NInput>\n <NButton @click=\"connect.invoke\" :loading=\"connect.loading\">\n 刷新连接\n </NButton>\n </NInputGroup>\n <template v-if=\"device\">\n <div whitespace-nowrap>\n {{ `已连接 ${device.manufacturer} Android ${device.release}` }}\n </div>\n <NButton\n @click=\"captureSnapshot.invoke\"\n :loading=\"captureSnapshot.loading\"\n >\n 快照\n </NButton>\n <NButton\n @click=\"downloadAllSnapshot.invoke\"\n :loading=\"downloadAllSnapshot.loading\"\n >\n 下载设备所有快照\n </NButton>\n <NButton @click=\"showSubsModel = true\"> 修改内存订阅 </NButton>\n <NButton @click=\"showSelectorModel = true\"> 执行选择器 </NButton>\n </template>\n </div>\n <NDataTable\n striped\n flexHeight\n :data=\"snapshots\"\n :columns=\"columns\"\n :pagination=\"pagination\"\n @update:sorter=\"handleSorterChange\"\n size=\"small\"\n class=\"flex-1\"\n :scrollX=\"1200\"\n />\n </div>\n</template>\n"],"names":["useDeviceApi","initOrigin","origin","shallowRef","rpc","rpcName","options","u","key","value","response","enhanceFetch","e","message","_a","error","jsonRpc","args","blobRpc","arrayBufferRpc","query","data","router","useRouter","api","link","useStorage","device","connect","useTask","errorWrap","URL","trim","onMounted","delay","toValidURL","invoke","snapshots","watchEffect","document","title","manufacturer","result","sort","a","b","id","subsText","captureSnapshot","snapshot","screenshot","snapshotStorage","setItem","screenshotStorage","success","downloadAllSnapshot","snapshotIds","map","s","existSnapshotIds","Set","keys","parseInt","unimportSnapshotIds","filter","k","has","length","r","limit","pLimit","Promise","all","snapshotId","newSnapshot","newScreenshot","nodes","activityIdCol","appIdCol","appNameCol","ctimeCol","appVersionCodeCol","appVersionNameCol","resetColWidth","useSnapshotColumns","handleSorterChange","sorter","columnKey","sortOrder","order","previewSnapshot","useBatchTask","row","hasItem","bf","window","open","resolve","name","params","href","columns","fixed","width","render","_createVNode2","_resolveComponent2","default","loading","onClick","_createTextVNode2","pagination","shallowReactive","page","pageSize","showSizePicker","pageSizes","onChange","onUpdatePageSize","watch","showSubsModel","updateSubs","JSON5","parse","categories","globalGroups","apps","updateSubscription","Array","isArray","showSelectorModel","actionOptions","label","clickAction","selector","action","quickFind","execSelector","fastQuery","placeholder"],"mappings":"iiBASa,MAAAA,GAAgBC,GAAwB,CAC7C,MAAAC,EAASC,EAAWF,CAAU,EAC9BG,EAAM,MAAOC,EAAiBC,EAAsB,CAAA,IAAO,OAC3D,GAAA,CAACJ,EAAO,MACJ,MAAA,IAAI,MAAM,mBAAmB,EAErC,MAAMK,EAAI,IAAI,IAAI,QAAUF,EAASH,EAAO,KAAK,EAC1C,OAAA,QAAQI,EAAQ,OAAS,CAAA,CAAE,EAAE,QAAQ,CAAC,CAACE,EAAKC,CAAK,IAAM,CACxDA,IAAU,QACdF,EAAE,aAAa,IAAIC,EAAK,OAAOC,CAAK,CAAC,CAAA,CACtC,EACK,MAAAC,EAAW,MAAMC,GAAaJ,EAAGD,EAAQ,IAAI,EAAE,MAAOM,GAAM,CACxD,MAAAC,EAAA,MAAM,SAAWR,CAAO,EAC1BO,CAAA,CACP,EACG,GAAA,CAACF,EAAS,GACZ,MAAAG,EAAQ,MAAM,SAAWR,EAAU,IAAMK,EAAS,MAAM,EAClDA,EAER,IAAII,EAAAJ,EAAS,QAAQ,IAAI,cAAc,IAAnC,MAAAI,EAAsC,SAAS,oBAAqB,CACtE,MAAMC,EAAS,MAAML,EAAS,MAAA,EAAQ,KAAK,EAC3C,GAAIK,EAAM,QACA,MAAAF,EAAA,MAAME,EAAM,OAAO,EACrBL,CACR,CAEK,OAAAA,CACT,EACMM,EAAU,SAAaC,IAEnB,MADS,MAAMb,EAAI,GAAGa,CAAI,GACX,KAAK,EAExBC,EAAU,SAAUD,IAEjB,MADU,MAAMb,EAAI,GAAGa,CAAI,GACZ,KAAK,EAEvBE,EAAiB,SAAUF,IAExB,MADU,MAAMb,EAAI,GAAGa,CAAI,GACZ,YAAY,EAiE7B,MAAA,CAAE,OAAAf,EAAQ,IA/DL,CACV,OAAQ,SAAYc,EAAgB,QAAQ,EAC5C,SAAU,MAAOI,GACRJ,EAAkB,WAAY,CAAE,MAAAI,CAAA,CAAO,EAEhD,WAAY,MAAOA,GACVD,EAAe,aAAc,CAAE,MAAAC,CAAA,CAAO,EAE/C,gBAAiB,SACRJ,EAAkB,iBAAiB,EAE5C,UAAW,SACFA,EAAoB,WAAW,EAExC,eAAgB,MAAOK,GACdH,EAAQ,iBAAkB,CAC/B,KAAM,CACJ,OAAQ,OACR,KAAM,KAAK,UAAUG,CAAI,EACzB,QAAS,CACP,eAAgB,kBAAA,CAClB,CACF,CACD,EAEH,mBAAoB,MAAOA,GAClBH,EAAQ,qBAAsB,CACnC,KAAM,CACJ,OAAQ,OACR,KAAM,KAAK,UAAU,CACnB,GAAGG,EACH,GAAI,GACJ,KAAM,OACN,QAAS,CAAA,CACV,EACD,QAAS,CACP,eAAgB,kBAAA,CAClB,CACF,CACD,EAEH,aAAc,MAAOA,IAMnBA,EAAO,gBAAgBA,CAAI,EAC3BA,EAAK,SAALA,EAAK,OAAW,QACTL,EACL,eACA,CACE,KAAM,CACJ,OAAQ,OACR,KAAM,KAAK,UAAUK,CAAI,EACzB,QAAS,CACP,eAAgB,kBAAA,CAClB,CACF,CAEJ,EAEJ,CACqB,CACvB,kOCnGA,MAAMC,EAASC,GAAW,EACpB,CAAEC,IAAAA,EAAKtB,OAAAA,CAAQ,EAAGF,GAAc,EAChCyB,EAAOC,GAAW,cAAe,EAAE,EACnCC,EAASxB,EAAoB,EAC7ByB,EAAUC,EAAQ,SAAY,CAC7BJ,EAAKhB,QACVP,EAAOO,MAAQqB,EACb,IAAM,IAAIC,IAAIN,EAAKhB,MAAMuB,KAAM,CAAA,EAC/B,IAAM,QACR,EAAE9B,OACFuB,EAAKhB,MAAQP,EAAOO,MACpBkB,EAAOlB,MAAQ,MAAMe,EAAIG,OAAQ,EACnC,CAAC,EACDM,GAAU,SAAY,CACpB,MAAMC,GAAM,GAAG,EACXC,GAAWV,EAAKhB,KAAK,GACvBmB,EAAQQ,OAAQ,CAEpB,CAAC,EAED,MAAMC,EAAYlC,EAAuB,EAAE,EAC3CmC,GAAY,SAAY,CACtB,GAAI,CAACX,EAAOlB,MAAO,OACnB8B,SAASC,MAAQ,OAASb,EAAOlB,MAAMgC,aACvC,MAAMC,EAAS,MAAMlB,EAAIa,UAAW,EACpCK,EAAOC,KAAK,CAACC,EAAGC,IAAMA,EAAEC,GAAKF,EAAEE,EAAE,EACjCT,EAAU5B,MAAQiC,EAClBK,EAAStC,MAAQ,EACnB,CAAC,EAED,MAAMuC,EAAkBnB,EAAQ,SAAY,CAC1C,MAAMoB,EAAW,MAAMzB,EAAIwB,gBAAiB,EACtCE,EAAa,MAAM1B,EAAI0B,WAAW,CAAEJ,GAAIG,EAASH,EAAG,CAAC,EAC3D,MAAMK,EAAgBC,QAAQH,EAASH,GAAIG,CAAQ,EACnD,MAAMI,EAAkBD,QAAQH,EAASH,GAAII,CAAU,EACvDrC,EAAQyC,QAAQ,QAAQ,EACxB,MAAMZ,EAAS,MAAMlB,EAAIa,UAAW,EACpCK,EAAOC,KAAK,CAACC,EAAGC,IAAMA,EAAEC,GAAKF,EAAEE,EAAE,EACjCT,EAAU5B,MAAQiC,CACpB,CAAC,EACKa,EAAsB1B,EAAQ,SAAY,CAC9C,MAAM2B,GAAe,MAAMhC,EAAIa,UAAW,GAAEoB,IAAKC,GAAMA,EAAEZ,EAAE,EACrDa,EAAmB,IAAIC,KAC1B,MAAMP,EAAkBQ,QAAQJ,IAAKC,GAAMI,SAASJ,CAAC,CAAC,CACzD,EACMK,EAAsBP,EAAYQ,OACrCC,GAAM,CAACN,EAAiBO,IAAID,CAAC,CAChC,EACA,GAAIF,EAAoBI,QAAU,EAAG,CACnCtD,EAAQyC,QAAQ,UAAU,EAC1B,MACF,CACA,IAAIc,EAAI,EACR,MAAMC,EAAQC,GAAO,CAAC,EACtB,MAAMC,QAAQC,IACZT,EAAoBN,IAAKgB,GACvBJ,EAAM,SAAY,CAChB,KAAM,CAACK,EAAaC,CAAa,EAAI,MAAMJ,QAAQC,IAAI,CACrDhD,EAAIyB,SAAS,CAAEH,GAAI2B,CAAW,CAAC,EAC/BjD,EAAI0B,WAAW,CAAEJ,GAAI2B,CAAY,CAAA,CAAC,CAC1B,EACLC,EAAYE,QACjB,MAAML,QAAQC,IAAI,CAChBrB,EAAgBC,QAAQqB,EAAYC,CAAW,EAC/CrB,EAAkBD,QAAQqB,EAAYE,CAAa,CAAC,CACrD,EACDP,IACD,CAAA,CACH,CACF,EACAvD,EAAQyC,QAAQ,KAAKc,CAAC,MAAM,CAC9B,CAAC,EAEK,CACJS,cAAAA,EACAC,SAAAA,EACAC,WAAAA,EACAC,SAAAA,EACAC,kBAAAA,EACAC,kBAAAA,EACAC,cAAAA,CACD,EAAGC,GAAoB,EAClBC,GAAsBC,GAAsB,CAC5CA,EAAOC,WAAaP,EAASxE,MAC/BwE,EAASQ,UAAYF,EAAOG,MAE/B,EACKC,EAAkBC,GACtB,MAAOC,GAAkB,CAIvB,GAHM,MAAMzC,EAAgB0C,QAAQD,EAAI9C,EAAE,GACxC,MAAMK,EAAgBC,QAAQwC,EAAI9C,GAAI,MAAMtB,EAAIyB,SAAS,CAAEH,GAAI8C,EAAI9C,EAAG,CAAC,CAAC,EAEtE,CAAE,MAAMO,EAAkBwC,QAAQD,EAAI9C,EAAE,EAAI,CAC9C,MAAMgD,EAAK,MAAMtE,EAAI0B,WAAW,CAAEJ,GAAI8C,EAAI9C,EAAG,CAAC,EAC9C,MAAMO,EAAkBD,QAAQwC,EAAI9C,GAAIgD,CAAE,CAC5C,CACAC,OAAOC,KACL1E,EAAO2E,QAAQ,CACbC,KAAM,WACNC,OAAQ,CAAE1B,WAAYmB,EAAI9C,EAAG,CAC9B,CAAA,EAAEsD,IACL,CACF,EACChC,GAAMA,EAAEtB,EACX,EAEMuD,GAAsC,CAC1CrB,EACAD,EACAD,EACAG,EACAC,EACAL,EACA,CACErE,IAAK,UACLgC,MAAO,KACP8D,MAAO,QACPC,MAAO,QACPC,OAAOZ,EAAK,CACV,OAAAa,EAAAC,EAAA,CAAA,KAAA,OAAA,EAAA,CAAAC,QAAAA,IAAAF,CAAAA,EAAAC,EAAA,CAAA,KAAA,QAAA,QAIehB,EAAgBkB,QAAQhB,EAAI9C,EAAE,EAAC,QAC/B+D,IAAMnB,EAAgBtD,OAAOwD,CAAG,CAAC,EAAA,CAAAe,QAAAA,IAAA,CAAAG,EAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAMlD,CACF,CAAC,EAGGC,EAAaC,EAAiC,CAClDC,KAAM,EACNC,SAAU,GACVC,eAAgB,GAChBC,UAAW,CAAC,GAAI,GAAG,EACnBC,SAAWJ,GAAiB,CAC1BF,EAAWE,KAAOA,CACnB,EACDK,iBAAmBJ,GAAqB,CACtCH,EAAWG,SAAWA,EACtBH,EAAWE,KAAO,CACpB,CACF,CAAC,EACDM,GAAMR,EAAY5B,CAAa,EAE/B,MAAMqC,EAAgBrH,EAAW,EAAK,EAChC4C,EAAW5C,EAAW,EAAE,EACxBsH,EAAa5F,EAAQ,SAAY,CACrC,MAAMR,EAAOS,EAAU,IAAM4F,GAAMC,MAAM5E,EAAStC,MAAMuB,KAAI,CAAE,CAAC,EAC/D,GAAKX,EACL,IAAIA,EAAKuG,YAAcvG,EAAKwG,cAAgBxG,EAAKyG,KAC/C,MAAMtG,EAAIuG,mBAAmB1G,CAAI,UACxB,OAAOA,EAAKyB,IAAM,SAC3B,MAAMtB,EAAIuG,mBAAmB,CAC3BD,KAAM,CAACzG,CAAI,CACb,CAAC,UACQ2G,MAAMC,QAAQ5G,CAAI,GAAK,OAAOA,EAAK,CAAC,EAAEyB,IAAM,SACrD,MAAMtB,EAAIuG,mBAAmB,CAC3BD,KAAMzG,CACR,CAAC,UACQ,OAAOA,EAAKb,KAAO,SAC5B,MAAMgB,EAAIuG,mBAAmB,CAC3BF,aAAc,CAACxG,CAAI,CACrB,CAAC,UACQ2G,MAAMC,QAAQ5G,CAAI,GAAK,OAAOA,EAAK,CAAC,EAAEb,KAAO,SACtD,MAAMgB,EAAIuG,mBAAmB,CAC3BF,aAAcxG,CAChB,CAAC,MACI,CACLR,EAAQE,MAAM,WAAW,EACzB,MACF,CACAF,EAAQyC,QAAQ,MAAM,EACxB,CAAC,EAEK4E,EAAoB/H,EAAW,EAAK,EAEpCgI,GAGA,CACJ,CACEC,MAAO,MACP3H,MAAO,EACT,EACA,CACEA,MAAO,QACP2H,MAAO,OACT,EACA,CACE3H,MAAO,YACP2H,MAAO,WACT,EACA,CACE3H,MAAO,cACP2H,MAAO,aACT,EACA,CACE3H,MAAO,OACP2H,MAAO,MACT,EACA,CACE3H,MAAO,YACP2H,MAAO,WACT,EACA,CACE3H,MAAO,gBACP2H,MAAO,eACT,EACA,CACE3H,MAAO,kBACP2H,MAAO,iBACT,CAAC,EAEGC,EAAcrB,EAAgB,CAClCsB,SAAU,GACVC,OAAQ,QACRC,UAAW,EACb,CAAC,EACKC,EAAe5G,EAAQ,SAAY,CACvC,MAAMa,EAAS,MAAMlB,EAAIiH,aAAa,CACpC,GAAGJ,EACHK,UAAWL,EAAYG,SACzB,CAAC,EACD,GAAI9F,EAAO7B,QAAS,CAClBA,EAAQyC,QAAQ,QAAUZ,EAAO7B,OAAO,EACxC,MACF,CACI6B,EAAO6F,OACT1H,EAAQyC,SAASZ,EAAOA,OAAS,QAAU,QAAUA,EAAO6F,MAAM,EACzD,CAAC7F,EAAO6F,QAAU7F,EAAOA,QAClC7B,EAAQyC,QAAQ,MAAM,CAE1B,CAAC,EAEKqF,GAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA+ClB3G,KAAM"}
@@ -1,112 +0,0 @@
1
- import{d as Ie,c as Ve,a as fe,b as r,e as re,f as N,g as ve,i as me,h as $e,j as se,k as b,r as K,N as ze,l as Ne,u as We,m as Be,n as De,o as de,t as Ue,p as Te,q as J,s as H,v as ue,w as W,x as Fe,y as ce,z as Pe,A as G,B as Le,C as be,D as pe,E as Me,F as he,G as Oe,H as t,I as Ke,J as we,K as xe,L as ke,M as k,O as o,P as He,Q as i,R as Ae,S as Ee,T as ye,U as g,V as Qe,W as ge,_ as je,X as Ze,Y as qe,Z as Ge,$ as Xe}from"./index-DJ3BflFD.js";import{_ as Ye,b as Je,a as et,w as _e,c as tt,s as Ce,d as nt}from"./ActionCard.vue_vue_type_script_setup_true_lang-Ddm4FDEW.js";import{i as ot,a as at}from"./import-Ck1vFpon.js";import{g as Se,_ as it,a as lt}from"./node-BU-u7VcN.js";import{s as rt,a as Re}from"./snapshot-LXrnvSmm.js";import{u as st,_ as dt,r as ut}from"./table-JTn0xZC1.js";import{u as A,_ as ct,a as pt}from"./dayjs.min-CMwzZYWK.js";import{_ as ht}from"./Input-DgyUdul6.js";import"./chunk-CPNWa47E.js";const gt={buttonHeightSmall:"14px",buttonHeightMedium:"18px",buttonHeightLarge:"22px",buttonWidthSmall:"14px",buttonWidthMedium:"18px",buttonWidthLarge:"22px",buttonWidthPressedSmall:"20px",buttonWidthPressedMedium:"24px",buttonWidthPressedLarge:"28px",railHeightSmall:"18px",railHeightMedium:"22px",railHeightLarge:"26px",railWidthSmall:"32px",railWidthMedium:"40px",railWidthLarge:"48px"};function ft(a){const{primaryColor:f,opacityDisabled:C,borderRadius:v,textColor3:h}=a;return Object.assign(Object.assign({},gt),{iconColor:h,textColor:"white",loadingColor:f,opacityDisabled:C,railColor:"rgba(0, 0, 0, .14)",railColorActive:f,buttonBoxShadow:"0 1px 4px 0 rgba(0, 0, 0, 0.3), inset 0 0 1px 0 rgba(0, 0, 0, 0.05)",buttonColor:"#FFF",railBorderRadiusSmall:v,railBorderRadiusMedium:v,railBorderRadiusLarge:v,buttonBorderRadiusSmall:v,buttonBorderRadiusMedium:v,buttonBorderRadiusLarge:v,boxShadowFocus:`0 0 0 2px ${Ve(f,{alpha:.2})}`})}const vt={common:Ie,self:ft},mt=fe("switch",`
2
- height: var(--n-height);
3
- min-width: var(--n-width);
4
- vertical-align: middle;
5
- user-select: none;
6
- -webkit-user-select: none;
7
- display: inline-flex;
8
- outline: none;
9
- justify-content: center;
10
- align-items: center;
11
- `,[r("children-placeholder",`
12
- height: var(--n-rail-height);
13
- display: flex;
14
- flex-direction: column;
15
- overflow: hidden;
16
- pointer-events: none;
17
- visibility: hidden;
18
- `),r("rail-placeholder",`
19
- display: flex;
20
- flex-wrap: none;
21
- `),r("button-placeholder",`
22
- width: calc(1.75 * var(--n-rail-height));
23
- height: var(--n-rail-height);
24
- `),fe("base-loading",`
25
- position: absolute;
26
- top: 50%;
27
- left: 50%;
28
- transform: translateX(-50%) translateY(-50%);
29
- font-size: calc(var(--n-button-width) - 4px);
30
- color: var(--n-loading-color);
31
- transition: color .3s var(--n-bezier);
32
- `,[me({left:"50%",top:"50%",originalTransform:"translateX(-50%) translateY(-50%)"})]),r("checked, unchecked",`
33
- transition: color .3s var(--n-bezier);
34
- color: var(--n-text-color);
35
- box-sizing: border-box;
36
- position: absolute;
37
- white-space: nowrap;
38
- top: 0;
39
- bottom: 0;
40
- display: flex;
41
- align-items: center;
42
- line-height: 1;
43
- `),r("checked",`
44
- right: 0;
45
- padding-right: calc(1.25 * var(--n-rail-height) - var(--n-offset));
46
- `),r("unchecked",`
47
- left: 0;
48
- justify-content: flex-end;
49
- padding-left: calc(1.25 * var(--n-rail-height) - var(--n-offset));
50
- `),re("&:focus",[r("rail",`
51
- box-shadow: var(--n-box-shadow-focus);
52
- `)]),N("round",[r("rail","border-radius: calc(var(--n-rail-height) / 2);",[r("button","border-radius: calc(var(--n-button-height) / 2);")])]),ve("disabled",[ve("icon",[N("rubber-band",[N("pressed",[r("rail",[r("button","max-width: var(--n-button-width-pressed);")])]),r("rail",[re("&:active",[r("button","max-width: var(--n-button-width-pressed);")])]),N("active",[N("pressed",[r("rail",[r("button","left: calc(100% - var(--n-offset) - var(--n-button-width-pressed));")])]),r("rail",[re("&:active",[r("button","left: calc(100% - var(--n-offset) - var(--n-button-width-pressed));")])])])])])]),N("active",[r("rail",[r("button","left: calc(100% - var(--n-button-width) - var(--n-offset))")])]),r("rail",`
53
- overflow: hidden;
54
- height: var(--n-rail-height);
55
- min-width: var(--n-rail-width);
56
- border-radius: var(--n-rail-border-radius);
57
- cursor: pointer;
58
- position: relative;
59
- transition:
60
- opacity .3s var(--n-bezier),
61
- background .3s var(--n-bezier),
62
- box-shadow .3s var(--n-bezier);
63
- background-color: var(--n-rail-color);
64
- `,[r("button-icon",`
65
- color: var(--n-icon-color);
66
- transition: color .3s var(--n-bezier);
67
- font-size: calc(var(--n-button-height) - 4px);
68
- position: absolute;
69
- left: 0;
70
- right: 0;
71
- top: 0;
72
- bottom: 0;
73
- display: flex;
74
- justify-content: center;
75
- align-items: center;
76
- line-height: 1;
77
- `,[me()]),r("button",`
78
- align-items: center;
79
- top: var(--n-offset);
80
- left: var(--n-offset);
81
- height: var(--n-button-height);
82
- width: var(--n-button-width-pressed);
83
- max-width: var(--n-button-width);
84
- border-radius: var(--n-button-border-radius);
85
- background-color: var(--n-button-color);
86
- box-shadow: var(--n-button-box-shadow);
87
- box-sizing: border-box;
88
- cursor: inherit;
89
- content: "";
90
- position: absolute;
91
- transition:
92
- background-color .3s var(--n-bezier),
93
- left .3s var(--n-bezier),
94
- opacity .3s var(--n-bezier),
95
- max-width .3s var(--n-bezier),
96
- box-shadow .3s var(--n-bezier);
97
- `)]),N("active",[r("rail","background-color: var(--n-rail-color-active);")]),N("loading",[r("rail",`
98
- cursor: wait;
99
- `)]),N("disabled",[r("rail",`
100
- cursor: not-allowed;
101
- opacity: .5;
102
- `)])]),bt=Object.assign(Object.assign({},Be.props),{size:{type:String,default:"medium"},value:{type:[String,Number,Boolean],default:void 0},loading:Boolean,defaultValue:{type:[String,Number,Boolean],default:!1},disabled:{type:Boolean,default:void 0},round:{type:Boolean,default:!0},"onUpdate:value":[Function,Array],onUpdateValue:[Function,Array],checkedValue:{type:[String,Number,Boolean],default:!0},uncheckedValue:{type:[String,Number,Boolean],default:!1},railStyle:Function,rubberBand:{type:Boolean,default:!0},onChange:[Function,Array]});let Y;const wt=$e({name:"Switch",props:bt,slots:Object,setup(a){Y===void 0&&(typeof CSS<"u"?typeof CSS.supports<"u"?Y=CSS.supports("width","max(1px)"):Y=!1:Y=!0);const{mergedClsPrefixRef:f,inlineThemeDisabled:C}=We(a),v=Be("Switch","-switch",mt,vt,a,f),h=De(a),{mergedSizeRef:m,mergedDisabledRef:y}=h,R=de(a.defaultValue),D=Ue(a,"value"),$=Te(D,R),B=J(()=>$.value===a.checkedValue),I=de(!1),d=de(!1),_=J(()=>{const{railStyle:l}=a;if(l)return l({focused:d.value,checked:B.value})});function S(l){const{"onUpdate:value":E,onChange:L,onUpdateValue:M}=a,{nTriggerFormInput:Q,nTriggerFormChange:j}=h;E&&ce(E,l),M&&ce(M,l),L&&ce(L,l),R.value=l,Q(),j()}function te(){const{nTriggerFormFocus:l}=h;l()}function ne(){const{nTriggerFormBlur:l}=h;l()}function oe(){a.loading||y.value||($.value!==a.checkedValue?S(a.checkedValue):S(a.uncheckedValue))}function F(){d.value=!0,te()}function ae(){d.value=!1,ne(),I.value=!1}function U(l){a.loading||y.value||l.key===" "&&($.value!==a.checkedValue?S(a.checkedValue):S(a.uncheckedValue),I.value=!1)}function T(l){a.loading||y.value||l.key===" "&&(l.preventDefault(),I.value=!0)}const P=J(()=>{const{value:l}=m,{self:{opacityDisabled:E,railColor:L,railColorActive:M,buttonBoxShadow:Q,buttonColor:j,boxShadowFocus:O,loadingColor:n,textColor:e,iconColor:w,[H("buttonHeight",l)]:u,[H("buttonWidth",l)]:c,[H("buttonWidthPressed",l)]:ie,[H("railHeight",l)]:x,[H("railWidth",l)]:V,[H("railBorderRadius",l)]:z,[H("buttonBorderRadius",l)]:ee},common:{cubicBezierEaseInOut:le}}=v.value;let Z,q,X;return Y?(Z=`calc((${x} - ${u}) / 2)`,q=`max(${x}, ${u})`,X=`max(${V}, calc(${V} + ${u} - ${x}))`):(Z=ue((W(x)-W(u))/2),q=ue(Math.max(W(x),W(u))),X=W(x)>W(u)?V:ue(W(V)+W(u)-W(x))),{"--n-bezier":le,"--n-button-border-radius":ee,"--n-button-box-shadow":Q,"--n-button-color":j,"--n-button-width":c,"--n-button-width-pressed":ie,"--n-button-height":u,"--n-height":q,"--n-offset":Z,"--n-opacity-disabled":E,"--n-rail-border-radius":z,"--n-rail-color":L,"--n-rail-color-active":M,"--n-rail-height":x,"--n-rail-width":V,"--n-width":X,"--n-box-shadow-focus":O,"--n-loading-color":n,"--n-text-color":e,"--n-icon-color":w}}),p=C?Fe("switch",J(()=>m.value[0]),P,a):void 0;return{handleClick:oe,handleBlur:ae,handleFocus:F,handleKeyup:U,handleKeydown:T,mergedRailStyle:_,pressed:I,mergedClsPrefix:f,mergedValue:$,checked:B,mergedDisabled:y,cssVars:C?void 0:P,themeClass:p==null?void 0:p.themeClass,onRender:p==null?void 0:p.onRender}},render(){const{mergedClsPrefix:a,mergedDisabled:f,checked:C,mergedRailStyle:v,onRender:h,$slots:m}=this;h==null||h();const{checked:y,unchecked:R,icon:D,"checked-icon":$,"unchecked-icon":B}=m,I=!(se(D)&&se($)&&se(B));return b("div",{role:"switch","aria-checked":C,class:[`${a}-switch`,this.themeClass,I&&`${a}-switch--icon`,C&&`${a}-switch--active`,f&&`${a}-switch--disabled`,this.round&&`${a}-switch--round`,this.loading&&`${a}-switch--loading`,this.pressed&&`${a}-switch--pressed`,this.rubberBand&&`${a}-switch--rubber-band`],tabindex:this.mergedDisabled?void 0:0,style:this.cssVars,onClick:this.handleClick,onFocus:this.handleFocus,onBlur:this.handleBlur,onKeyup:this.handleKeyup,onKeydown:this.handleKeydown},b("div",{class:`${a}-switch__rail`,"aria-hidden":"true",style:v},K(y,d=>K(R,_=>d||_?b("div",{"aria-hidden":!0,class:`${a}-switch__children-placeholder`},b("div",{class:`${a}-switch__rail-placeholder`},b("div",{class:`${a}-switch__button-placeholder`}),d),b("div",{class:`${a}-switch__rail-placeholder`},b("div",{class:`${a}-switch__button-placeholder`}),_)):null)),b("div",{class:`${a}-switch__button`},K(D,d=>K($,_=>K(B,S=>b(ze,null,{default:()=>this.loading?b(Ne,{key:"loading",clsPrefix:a,strokeWidth:20}):this.checked&&(_||d)?b("div",{class:`${a}-switch__button-icon`,key:_?"checked-icon":"icon"},_||d):!this.checked&&(S||d)?b("div",{class:`${a}-switch__button-icon`,key:S?"unchecked-icon":"icon"},S||d):null})))),K(y,d=>d&&b("div",{key:"checked",class:`${a}-switch__checked`},d)),K(R,d=>d&&b("div",{key:"unchecked",class:`${a}-switch__unchecked`},d)))))}}),xt={flex:"","flex-col":"","p-10px":"","gap-10px":"","h-full":""},kt={flex:""},yt={"h-full":"",flex:"","flex-items-center":""},_t={flex:"","gap-24px":"","items-center":"","pr-8px":"",class:"[--svg-h:24px]"},Ct={flex:"",href:"https://github.com/orgs/gkd-kit/discussions",target:"_blank",rel:"noopener noreferrer"},St={flex:"",href:"https://github.com/gkd-kit/inspect",target:"_blank",rel:"noopener noreferrer"},Rt={flex:"","gap-10px":""},Tt=$e({__name:"HomePage",setup(a){const f=Pe(),C=G([]),v=G(!0),h=async()=>{v.value=!0,C.value=(await rt.getAllItems()).reverse(),p.value=[],v.value=!1};Le(h);const m=be({query:"",actualQuery:"",updateQuery:()=>{m.actualQuery=m.query.trim(),p.value=[]}}),y=J(()=>{const n=m.actualQuery;return n?C.value.filter(e=>(Se(e).name||"").includes(n)||(e.appId||"").includes(n)||(e.activityId||"").includes(n)):C.value}),R=A(async n=>{await ot(n)&&await h()});pe(document.body,"drop",async n=>{n.preventDefault(),await R.invoke(Me(n))}),pe(document.body,"dragover",n=>{n.preventDefault()});const{activityIdCol:D,appIdCol:$,appNameCol:B,ctimeCol:I,mtimeCol:d,deviceCol:_,appVersionCodeCol:S,appVersionNameCol:te,resetColWidth:ne}=st();he(()=>{const n=y.value.reduce((e,w)=>(e.add(ut(w)),e),new Set);if(n.size<=1){_.filterOptions=void 0;return}_.filterOptions=[...n.values()].map(e=>({value:e,label:e}))}),he(()=>{const n=y.value.reduce((e,w)=>(e.add(Se(w).name),e),new Set);if(n.size<=1){B.filterOptions=void 0;return}B.filterOptions=[...n.values()].map(e=>({value:e,label:e}))}),he(()=>{const n=y.value.reduce((e,w)=>(e.add(w.activityId),e),new Set);if(n.size<=1){D.filterOptions=void 0;return}D.filterOptions=[...n.values()].map(e=>({value:e,label:e}))});const oe=Oe([{type:"selection"},I,d,_,B,$,S,te,D,{key:"actions",title:"操作",fixed:"right",width:"160px",render(n){return t(Ye,{snapshot:n,onDelete:h},null)}}]),F=be({page:1,pageSize:50,showSizePicker:!0,pageSizes:[50,100],onChange:n=>{F.page=n},onUpdatePageSize:n=>{F.pageSize=n,F.page=1}});Ke(F,ne);const ae=n=>{[I,d].forEach(e=>{n.columnKey!=e.key?e.sortOrder=void 0:e.sortOrder=n.order})};d.sortOrder="descend";const U=G(!1),T=G(""),P=A(async()=>{const n=T.value.trim().split(`
103
- `).map(e=>e.trim()).filter(e=>Xe(e));n.length!=0&&(await at(n),await h(),T.value="")});pe(document.body,"paste",n=>{if(U.value)return;const e=n.target;if(e instanceof HTMLInputElement||e instanceof HTMLTextAreaElement||(e.className||"").includes("input"))return;const w=n.clipboardData;if(!w)return;const u=(w.getData("text")||"").trim();(u.startsWith("https://")||u.startsWith("http://"))&&(T.value=u,U.value=!0)});const p=G([]),l=()=>Promise.all(p.value.map(n=>Re.getItem(n))),E=A(async()=>{await new Promise((n,e)=>{Ge.warning({title:"删除",content:`是否批量删除 ${p.value.length} 个快照`,negativeText:"取消",positiveText:"确认",onClose:e,onEsc:e,onMaskClick:e,onNegativeClick:e,onPositiveClick:n})}),await Promise.all(p.value.map(n=>Re.removeItem(n))),await h()}),L=A(async()=>{await et(await l())}),M=A(async()=>{await Je(await l())}),Q=A(async()=>{await _e();const n=await nt(await l());Ce({content:n.map(e=>qe(e)).join(`
104
- `)+`
105
- `})}),j=A(async()=>{await _e();const n=await tt(await l());Ce({content:n.map(e=>location.origin+"/i/"+e).join(`
106
- `)+`
107
- `})}),O=G(!1);return(n,e)=>{const w=ht,u=we("SvgIcon"),c=Ee,ie=ct,x=pt,V=it,z=lt,ee=we("RouterLink"),le=dt,Z=je,q=Ze,X=wt;return ke(),xe(ye,null,[k("div",xt,[k("div",kt,[t(x,null,{default:o(()=>[t(ie,null,{default:o(()=>[t(w,{placeholder:"请输入应用名称/应用ID/界面ID",clearable:"",class:"min-w-320px",value:i(m).query,"onUpdate:value":e[0]||(e[0]=s=>i(m).query=s),onKeyup:Ae(i(m).updateQuery,["enter"]),onChange:i(m).updateQuery},null,8,["value","onKeyup","onChange"]),t(c,{onClick:i(m).updateQuery},{icon:o(()=>[t(u,{name:"search"})]),_:1},8,["onClick"])]),_:1}),i(p).length?(ke(),xe(ye,{key:0},[t(V,null,{trigger:o(()=>[t(c,null,{default:o(()=>e[13]||(e[13]=[g(" 批量下载 ")])),_:1})]),default:o(()=>[t(x,{vertical:""},{default:o(()=>[t(c,{onClick:i(M).invoke,loading:i(M).loading},{default:o(()=>e[14]||(e[14]=[g(" 批量下载-快照 ")])),_:1},8,["onClick","loading"]),t(c,{onClick:i(L).invoke,loading:i(L).loading},{default:o(()=>e[15]||(e[15]=[g(" 批量下载-图片 ")])),_:1},8,["onClick","loading"])]),_:1})]),_:1}),t(V,null,{trigger:o(()=>[t(c,null,{default:o(()=>e[16]||(e[16]=[g(" 批量分享 ")])),_:1})]),default:o(()=>[t(x,{vertical:""},{default:o(()=>[t(c,{onClick:i(j).invoke,loading:i(j).loading},{default:o(()=>e[17]||(e[17]=[g(" 批量生成链接-快照 ")])),_:1},8,["onClick","loading"]),t(c,{onClick:i(Q).invoke,loading:i(Q).loading},{default:o(()=>e[18]||(e[18]=[g(" 批量生成链接-图片 ")])),_:1},8,["onClick","loading"])]),_:1})]),_:1}),t(c,{onClick:i(E).invoke},{default:o(()=>e[19]||(e[19]=[g(" 批量删除 ")])),_:1},8,["onClick"]),k("div",yt,Qe(`已选中 ${i(p).length} 个快照`),1)],64)):He("",!0)]),_:1}),e[29]||(e[29]=k("div",{"flex-1":""},null,-1)),k("div",_t,[t(z,null,{trigger:o(()=>[t(c,{text:"",onClick:e[1]||(e[1]=s=>O.value=!0)},{default:o(()=>[t(u,{name:"settings"})]),_:1})]),default:o(()=>[e[20]||(e[20]=g(" 设置 "))]),_:1}),t(z,null,{trigger:o(()=>[t(ee,{flex:"",to:"/selector"},{default:o(()=>[t(c,{text:""},{default:o(()=>[t(u,{name:"terminal"})]),_:1})]),_:1})]),default:o(()=>[e[21]||(e[21]=g(" 测试选择器 "))]),_:1}),t(V,null,{trigger:o(()=>[t(c,{text:""},{default:o(()=>[t(u,{name:"import"})]),_:1})]),default:o(()=>[t(x,{vertical:""},{default:o(()=>[t(z,{placement:"left"},{trigger:o(()=>[t(c,{onClick:e[2]||(e[2]=s=>i(R).invoke()),loading:i(R).loading},{default:o(()=>e[22]||(e[22]=[g(" 导入本地文件 ")])),_:1},8,["loading"])]),default:o(()=>[e[23]||(e[23]=k("div",{class:"whitespace-nowrap"},"支持拖拽文件到页面任意位置",-1))]),_:1}),t(z,{placement:"left"},{trigger:o(()=>[t(c,{onClick:e[3]||(e[3]=s=>U.value=!0),loading:i(P).loading},{default:o(()=>e[24]||(e[24]=[g(" 导入网络文件 ")])),_:1},8,["loading"])]),default:o(()=>[e[25]||(e[25]=k("div",{class:"whitespace-nowrap"}," 支持任意位置粘贴(Ctrl+V)文本触发导入 ",-1))]),_:1})]),_:1})]),_:1}),t(z,null,{trigger:o(()=>[t(ee,{flex:"",to:"/device"},{default:o(()=>[t(c,{text:""},{default:o(()=>[t(u,{name:"device"})]),_:1})]),_:1})]),default:o(()=>[e[26]||(e[26]=g(" 连接设备 "))]),_:1}),t(z,null,{trigger:o(()=>[k("a",Ct,[t(c,{text:""},{default:o(()=>[t(u,{name:"discussion"})]),_:1})])]),default:o(()=>[e[27]||(e[27]=g(" 讨论交流 "))]),_:1}),t(z,null,{trigger:o(()=>[k("a",St,[t(c,{text:""},{default:o(()=>[t(u,{name:"github"})]),_:1})])]),default:o(()=>[e[28]||(e[28]=g(" Github "))]),_:1})])]),t(le,{striped:"",data:i(y),columns:i(oe),scrollX:1800,pagination:i(F),checkedRowKeys:i(p),"onUpdate:checkedRowKeys":e[4]||(e[4]=s=>ge(p)?p.value=s:null),rowKey:s=>s.id,"onUpdate:sorter":ae,size:"small",class:"flex-1",flexHeight:"",loading:i(v)},null,8,["data","columns","pagination","checkedRowKeys","rowKey","loading"])]),t(Z,{show:i(U),"onUpdate:show":e[6]||(e[6]=s=>ge(U)?U.value=s:null),preset:"dialog",title:"导入网络文件",showIcon:!1,positiveText:"确认",negativeText:"取消",style:{width:"800px"},onPositiveClick:i(P).invoke,loading:i(P).loading,onAfterLeave:e[7]||(e[7]=s=>T.value="")},{default:o(()=>[t(w,{value:i(T),"onUpdate:value":e[5]||(e[5]=s=>{i(P).loading||(T.value=s)}),type:"textarea",placeholder:`1.支持ZIP文件链接
108
- 2.支持快照链接
109
- 每行一个
110
- 空白行自动忽略
111
- 非法链接行自动忽略`,autosize:{minRows:8,maxRows:16},inputProps:{style:"white-space: nowrap;"}},null,8,["value"])]),_:1},8,["show","onPositiveClick","loading"]),t(Z,{show:i(O),"onUpdate:show":e[11]||(e[11]=s=>ge(O)?O.value=s:null),preset:"dialog",title:"设置",showIcon:!1,positiveText:"关闭",style:{width:"600px"},onPositiveClick:e[12]||(e[12]=s=>O.value=!1)},{default:o(()=>[t(q,{checked:i(f).ignoreUploadWarn,"onUpdate:checked":e[8]||(e[8]=s=>i(f).ignoreUploadWarn=s)},{default:o(()=>e[30]||(e[30]=[g(" 关闭生成分享链接弹窗提醒 ")])),_:1},8,["checked"]),e[33]||(e[33]=k("div",{"h-1px":"","my-10px":"",bg:"#eee"},null,-1)),t(q,{checked:i(f).ignoreWasmWarn,"onUpdate:checked":e[9]||(e[9]=s=>i(f).ignoreWasmWarn=s)},{default:o(()=>e[31]||(e[31]=[g(" 关闭浏览器版本正则表达式 WASM(GC) 提醒 ")])),_:1},8,["checked"]),e[34]||(e[34]=k("div",{"h-1px":"","my-10px":"",bg:"#eee"},null,-1)),k("div",Rt,[t(X,{value:i(f).autoUploadImport,"onUpdate:value":e[10]||(e[10]=s=>i(f).autoUploadImport=s)},null,8,["value"]),e[32]||(e[32]=k("div",null,"打开快照页面自动生成分享链接(请确保不含隐私)",-1))])]),_:1},8,["show"])],64)}}});export{Tt as default};
112
- //# sourceMappingURL=HomePage-PzBg6JK7.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"HomePage-PzBg6JK7.js","sources":["../../node_modules/.pnpm/naive-ui@2.41.0_vue@3.5.13_typescript@5.7.3_/node_modules/naive-ui/es/switch/styles/_common.mjs","../../node_modules/.pnpm/naive-ui@2.41.0_vue@3.5.13_typescript@5.7.3_/node_modules/naive-ui/es/switch/styles/light.mjs","../../node_modules/.pnpm/naive-ui@2.41.0_vue@3.5.13_typescript@5.7.3_/node_modules/naive-ui/es/switch/src/styles/index.cssr.mjs","../../node_modules/.pnpm/naive-ui@2.41.0_vue@3.5.13_typescript@5.7.3_/node_modules/naive-ui/es/switch/src/Switch.mjs","../../src/views/home/HomePage.vue"],"sourcesContent":["export default {\n buttonHeightSmall: '14px',\n buttonHeightMedium: '18px',\n buttonHeightLarge: '22px',\n buttonWidthSmall: '14px',\n buttonWidthMedium: '18px',\n buttonWidthLarge: '22px',\n buttonWidthPressedSmall: '20px',\n buttonWidthPressedMedium: '24px',\n buttonWidthPressedLarge: '28px',\n railHeightSmall: '18px',\n railHeightMedium: '22px',\n railHeightLarge: '26px',\n railWidthSmall: '32px',\n railWidthMedium: '40px',\n railWidthLarge: '48px'\n};","import { changeColor } from 'seemly';\nimport { commonLight } from \"../../_styles/common/index.mjs\";\nimport commonVars from \"./_common.mjs\";\nfunction self(vars) {\n const {\n primaryColor,\n opacityDisabled,\n borderRadius,\n textColor3\n } = vars;\n const railOverlayColor = 'rgba(0, 0, 0, .14)';\n return Object.assign(Object.assign({}, commonVars), {\n iconColor: textColor3,\n textColor: 'white',\n loadingColor: primaryColor,\n opacityDisabled,\n railColor: railOverlayColor,\n railColorActive: primaryColor,\n buttonBoxShadow: '0 1px 4px 0 rgba(0, 0, 0, 0.3), inset 0 0 1px 0 rgba(0, 0, 0, 0.05)',\n buttonColor: '#FFF',\n railBorderRadiusSmall: borderRadius,\n railBorderRadiusMedium: borderRadius,\n railBorderRadiusLarge: borderRadius,\n buttonBorderRadiusSmall: borderRadius,\n buttonBorderRadiusMedium: borderRadius,\n buttonBorderRadiusLarge: borderRadius,\n boxShadowFocus: `0 0 0 2px ${changeColor(primaryColor, {\n alpha: 0.2\n })}`\n });\n}\nconst switchLight = {\n name: 'Switch',\n common: commonLight,\n self\n};\nexport default switchLight;","import { iconSwitchTransition } from \"../../../_styles/transitions/icon-switch.cssr.mjs\";\nimport { c, cB, cE, cM, cNotM } from \"../../../_utils/cssr/index.mjs\";\n// vars:\n// --n-bezier\n// --n-button-border-radius\n// --n-button-box-shadow\n// --n-button-color\n// --n-button-width\n// --n-button-width-pressed\n// --n-height\n// --n-offset\n// --n-rail-border-radius\n// --n-rail-color\n// --n-rail-color-active\n// --n-rail-height\n// --n-rail-width\n// --n-width\n// --n-box-shadow-focus\n// --n-loading-color\n// --n-text-color\n// --n-icon-color\nexport default cB('switch', `\n height: var(--n-height);\n min-width: var(--n-width);\n vertical-align: middle;\n user-select: none;\n -webkit-user-select: none;\n display: inline-flex;\n outline: none;\n justify-content: center;\n align-items: center;\n`, [cE('children-placeholder', `\n height: var(--n-rail-height);\n display: flex;\n flex-direction: column;\n overflow: hidden;\n pointer-events: none;\n visibility: hidden;\n `), cE('rail-placeholder', `\n display: flex;\n flex-wrap: none;\n `), cE('button-placeholder', `\n width: calc(1.75 * var(--n-rail-height));\n height: var(--n-rail-height);\n `), cB('base-loading', `\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translateX(-50%) translateY(-50%);\n font-size: calc(var(--n-button-width) - 4px);\n color: var(--n-loading-color);\n transition: color .3s var(--n-bezier);\n `, [iconSwitchTransition({\n left: '50%',\n top: '50%',\n originalTransform: 'translateX(-50%) translateY(-50%)'\n})]), cE('checked, unchecked', `\n transition: color .3s var(--n-bezier);\n color: var(--n-text-color);\n box-sizing: border-box;\n position: absolute;\n white-space: nowrap;\n top: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n line-height: 1;\n `), cE('checked', `\n right: 0;\n padding-right: calc(1.25 * var(--n-rail-height) - var(--n-offset));\n `), cE('unchecked', `\n left: 0;\n justify-content: flex-end;\n padding-left: calc(1.25 * var(--n-rail-height) - var(--n-offset));\n `), c('&:focus', [cE('rail', `\n box-shadow: var(--n-box-shadow-focus);\n `)]), cM('round', [cE('rail', 'border-radius: calc(var(--n-rail-height) / 2);', [cE('button', 'border-radius: calc(var(--n-button-height) / 2);')])]), cNotM('disabled', [cNotM('icon', [cM('rubber-band', [cM('pressed', [cE('rail', [cE('button', 'max-width: var(--n-button-width-pressed);')])]), cE('rail', [c('&:active', [cE('button', 'max-width: var(--n-button-width-pressed);')])]), cM('active', [cM('pressed', [cE('rail', [cE('button', 'left: calc(100% - var(--n-offset) - var(--n-button-width-pressed));')])]), cE('rail', [c('&:active', [cE('button', 'left: calc(100% - var(--n-offset) - var(--n-button-width-pressed));')])])])])])]), cM('active', [cE('rail', [cE('button', 'left: calc(100% - var(--n-button-width) - var(--n-offset))')])]), cE('rail', `\n overflow: hidden;\n height: var(--n-rail-height);\n min-width: var(--n-rail-width);\n border-radius: var(--n-rail-border-radius);\n cursor: pointer;\n position: relative;\n transition:\n opacity .3s var(--n-bezier),\n background .3s var(--n-bezier),\n box-shadow .3s var(--n-bezier);\n background-color: var(--n-rail-color);\n `, [cE('button-icon', `\n color: var(--n-icon-color);\n transition: color .3s var(--n-bezier);\n font-size: calc(var(--n-button-height) - 4px);\n position: absolute;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n line-height: 1;\n `, [iconSwitchTransition()]), cE('button', `\n align-items: center; \n top: var(--n-offset);\n left: var(--n-offset);\n height: var(--n-button-height);\n width: var(--n-button-width-pressed);\n max-width: var(--n-button-width);\n border-radius: var(--n-button-border-radius);\n background-color: var(--n-button-color);\n box-shadow: var(--n-button-box-shadow);\n box-sizing: border-box;\n cursor: inherit;\n content: \"\";\n position: absolute;\n transition:\n background-color .3s var(--n-bezier),\n left .3s var(--n-bezier),\n opacity .3s var(--n-bezier),\n max-width .3s var(--n-bezier),\n box-shadow .3s var(--n-bezier);\n `)]), cM('active', [cE('rail', 'background-color: var(--n-rail-color-active);')]), cM('loading', [cE('rail', `\n cursor: wait;\n `)]), cM('disabled', [cE('rail', `\n cursor: not-allowed;\n opacity: .5;\n `)])]);","import { depx, pxfy } from 'seemly';\nimport { useMergedState } from 'vooks';\nimport { computed, defineComponent, h, ref, toRef, watchEffect } from 'vue';\nimport { NBaseLoading, NIconSwitchTransition } from \"../../_internal/index.mjs\";\nimport { useConfig, useFormItem, useTheme, useThemeClass } from \"../../_mixins/index.mjs\";\nimport { call, createKey, isSlotEmpty, resolveWrappedSlot, warnOnce } from \"../../_utils/index.mjs\";\nimport { switchLight } from \"../styles/index.mjs\";\nimport style from \"./styles/index.cssr.mjs\";\nexport const switchProps = Object.assign(Object.assign({}, useTheme.props), {\n size: {\n type: String,\n default: 'medium'\n },\n value: {\n type: [String, Number, Boolean],\n default: undefined\n },\n loading: Boolean,\n defaultValue: {\n type: [String, Number, Boolean],\n default: false\n },\n disabled: {\n type: Boolean,\n default: undefined\n },\n round: {\n type: Boolean,\n default: true\n },\n 'onUpdate:value': [Function, Array],\n onUpdateValue: [Function, Array],\n checkedValue: {\n type: [String, Number, Boolean],\n default: true\n },\n uncheckedValue: {\n type: [String, Number, Boolean],\n default: false\n },\n railStyle: Function,\n rubberBand: {\n type: Boolean,\n default: true\n },\n /** @deprecated */\n onChange: [Function, Array]\n});\nlet supportCssMax;\nexport default defineComponent({\n name: 'Switch',\n props: switchProps,\n slots: Object,\n setup(props) {\n if (process.env.NODE_ENV !== 'production') {\n watchEffect(() => {\n if (props.onChange) {\n warnOnce('switch', '`on-change` is deprecated, please use `on-update:value` instead.');\n }\n });\n }\n if (supportCssMax === undefined) {\n if (typeof CSS !== 'undefined') {\n if (typeof CSS.supports !== 'undefined') {\n supportCssMax = CSS.supports('width', 'max(1px)');\n } else {\n supportCssMax = false;\n }\n } else {\n // If you are using SSR, we assume that you are targeting browsers with\n // recent versions\n supportCssMax = true;\n }\n }\n const {\n mergedClsPrefixRef,\n inlineThemeDisabled\n } = useConfig(props);\n const themeRef = useTheme('Switch', '-switch', style, switchLight, props, mergedClsPrefixRef);\n const formItem = useFormItem(props);\n const {\n mergedSizeRef,\n mergedDisabledRef\n } = formItem;\n const uncontrolledValueRef = ref(props.defaultValue);\n const controlledValueRef = toRef(props, 'value');\n const mergedValueRef = useMergedState(controlledValueRef, uncontrolledValueRef);\n const checkedRef = computed(() => {\n return mergedValueRef.value === props.checkedValue;\n });\n const pressedRef = ref(false);\n const focusedRef = ref(false);\n const mergedRailStyleRef = computed(() => {\n const {\n railStyle\n } = props;\n if (!railStyle) return undefined;\n return railStyle({\n focused: focusedRef.value,\n checked: checkedRef.value\n });\n });\n function doUpdateValue(value) {\n const {\n 'onUpdate:value': _onUpdateValue,\n onChange,\n onUpdateValue\n } = props;\n const {\n nTriggerFormInput,\n nTriggerFormChange\n } = formItem;\n if (_onUpdateValue) call(_onUpdateValue, value);\n if (onUpdateValue) call(onUpdateValue, value);\n if (onChange) call(onChange, value);\n uncontrolledValueRef.value = value;\n nTriggerFormInput();\n nTriggerFormChange();\n }\n function doFocus() {\n const {\n nTriggerFormFocus\n } = formItem;\n nTriggerFormFocus();\n }\n function doBlur() {\n const {\n nTriggerFormBlur\n } = formItem;\n nTriggerFormBlur();\n }\n function handleClick() {\n if (props.loading || mergedDisabledRef.value) return;\n if (mergedValueRef.value !== props.checkedValue) {\n doUpdateValue(props.checkedValue);\n } else {\n doUpdateValue(props.uncheckedValue);\n }\n }\n function handleFocus() {\n focusedRef.value = true;\n doFocus();\n }\n function handleBlur() {\n focusedRef.value = false;\n doBlur();\n pressedRef.value = false;\n }\n function handleKeyup(e) {\n if (props.loading || mergedDisabledRef.value) return;\n if (e.key === ' ') {\n if (mergedValueRef.value !== props.checkedValue) {\n doUpdateValue(props.checkedValue);\n } else {\n doUpdateValue(props.uncheckedValue);\n }\n pressedRef.value = false;\n }\n }\n function handleKeydown(e) {\n if (props.loading || mergedDisabledRef.value) return;\n if (e.key === ' ') {\n e.preventDefault();\n pressedRef.value = true;\n }\n }\n const cssVarsRef = computed(() => {\n const {\n value: size\n } = mergedSizeRef;\n const {\n self: {\n opacityDisabled,\n railColor,\n railColorActive,\n buttonBoxShadow,\n buttonColor,\n boxShadowFocus,\n loadingColor,\n textColor,\n iconColor,\n [createKey('buttonHeight', size)]: buttonHeight,\n [createKey('buttonWidth', size)]: buttonWidth,\n [createKey('buttonWidthPressed', size)]: buttonWidthPressed,\n [createKey('railHeight', size)]: railHeight,\n [createKey('railWidth', size)]: railWidth,\n [createKey('railBorderRadius', size)]: railBorderRadius,\n [createKey('buttonBorderRadius', size)]: buttonBorderRadius\n },\n common: {\n cubicBezierEaseInOut\n }\n } = themeRef.value;\n let offset;\n let height;\n let width;\n if (supportCssMax) {\n offset = `calc((${railHeight} - ${buttonHeight}) / 2)`;\n height = `max(${railHeight}, ${buttonHeight})`;\n width = `max(${railWidth}, calc(${railWidth} + ${buttonHeight} - ${railHeight}))`;\n } else {\n offset = pxfy((depx(railHeight) - depx(buttonHeight)) / 2);\n height = pxfy(Math.max(depx(railHeight), depx(buttonHeight)));\n width = depx(railHeight) > depx(buttonHeight) ? railWidth : pxfy(depx(railWidth) + depx(buttonHeight) - depx(railHeight));\n }\n return {\n '--n-bezier': cubicBezierEaseInOut,\n '--n-button-border-radius': buttonBorderRadius,\n '--n-button-box-shadow': buttonBoxShadow,\n '--n-button-color': buttonColor,\n '--n-button-width': buttonWidth,\n '--n-button-width-pressed': buttonWidthPressed,\n '--n-button-height': buttonHeight,\n '--n-height': height,\n '--n-offset': offset,\n '--n-opacity-disabled': opacityDisabled,\n '--n-rail-border-radius': railBorderRadius,\n '--n-rail-color': railColor,\n '--n-rail-color-active': railColorActive,\n '--n-rail-height': railHeight,\n '--n-rail-width': railWidth,\n '--n-width': width,\n '--n-box-shadow-focus': boxShadowFocus,\n '--n-loading-color': loadingColor,\n '--n-text-color': textColor,\n '--n-icon-color': iconColor\n };\n });\n const themeClassHandle = inlineThemeDisabled ? useThemeClass('switch', computed(() => {\n return mergedSizeRef.value[0];\n }), cssVarsRef, props) : undefined;\n return {\n handleClick,\n handleBlur,\n handleFocus,\n handleKeyup,\n handleKeydown,\n mergedRailStyle: mergedRailStyleRef,\n pressed: pressedRef,\n mergedClsPrefix: mergedClsPrefixRef,\n mergedValue: mergedValueRef,\n checked: checkedRef,\n mergedDisabled: mergedDisabledRef,\n cssVars: inlineThemeDisabled ? undefined : cssVarsRef,\n themeClass: themeClassHandle === null || themeClassHandle === void 0 ? void 0 : themeClassHandle.themeClass,\n onRender: themeClassHandle === null || themeClassHandle === void 0 ? void 0 : themeClassHandle.onRender\n };\n },\n render() {\n const {\n mergedClsPrefix,\n mergedDisabled,\n checked,\n mergedRailStyle,\n onRender,\n $slots\n } = this;\n onRender === null || onRender === void 0 ? void 0 : onRender();\n const {\n checked: checkedSlot,\n unchecked: uncheckedSlot,\n icon: iconSlot,\n 'checked-icon': checkedIconSlot,\n 'unchecked-icon': uncheckedIconSlot\n } = $slots;\n const hasIcon = !(isSlotEmpty(iconSlot) && isSlotEmpty(checkedIconSlot) && isSlotEmpty(uncheckedIconSlot));\n return h(\"div\", {\n role: \"switch\",\n \"aria-checked\": checked,\n class: [`${mergedClsPrefix}-switch`, this.themeClass, hasIcon && `${mergedClsPrefix}-switch--icon`, checked && `${mergedClsPrefix}-switch--active`, mergedDisabled && `${mergedClsPrefix}-switch--disabled`, this.round && `${mergedClsPrefix}-switch--round`, this.loading && `${mergedClsPrefix}-switch--loading`, this.pressed && `${mergedClsPrefix}-switch--pressed`, this.rubberBand && `${mergedClsPrefix}-switch--rubber-band`],\n tabindex: !this.mergedDisabled ? 0 : undefined,\n style: this.cssVars,\n onClick: this.handleClick,\n onFocus: this.handleFocus,\n onBlur: this.handleBlur,\n onKeyup: this.handleKeyup,\n onKeydown: this.handleKeydown\n }, h(\"div\", {\n class: `${mergedClsPrefix}-switch__rail`,\n \"aria-hidden\": \"true\",\n style: mergedRailStyle\n }, resolveWrappedSlot(checkedSlot, checkedSlotChildren => resolveWrappedSlot(uncheckedSlot, uncheckedSlotChildren => {\n if (checkedSlotChildren || uncheckedSlotChildren) {\n return h(\"div\", {\n \"aria-hidden\": true,\n class: `${mergedClsPrefix}-switch__children-placeholder`\n }, h(\"div\", {\n class: `${mergedClsPrefix}-switch__rail-placeholder`\n }, h(\"div\", {\n class: `${mergedClsPrefix}-switch__button-placeholder`\n }), checkedSlotChildren), h(\"div\", {\n class: `${mergedClsPrefix}-switch__rail-placeholder`\n }, h(\"div\", {\n class: `${mergedClsPrefix}-switch__button-placeholder`\n }), uncheckedSlotChildren));\n }\n return null;\n })), h(\"div\", {\n class: `${mergedClsPrefix}-switch__button`\n }, resolveWrappedSlot(iconSlot, icon => resolveWrappedSlot(checkedIconSlot, checkedIcon => resolveWrappedSlot(uncheckedIconSlot, uncheckedIcon => {\n return h(NIconSwitchTransition, null, {\n default: () => this.loading ? h(NBaseLoading, {\n key: \"loading\",\n clsPrefix: mergedClsPrefix,\n strokeWidth: 20\n }) : this.checked && (checkedIcon || icon) ? h(\"div\", {\n class: `${mergedClsPrefix}-switch__button-icon`,\n key: checkedIcon ? 'checked-icon' : 'icon'\n }, checkedIcon || icon) : !this.checked && (uncheckedIcon || icon) ? h(\"div\", {\n class: `${mergedClsPrefix}-switch__button-icon`,\n key: uncheckedIcon ? 'unchecked-icon' : 'icon'\n }, uncheckedIcon || icon) : null\n });\n }))), resolveWrappedSlot(checkedSlot, children => children && h(\"div\", {\n key: \"checked\",\n class: `${mergedClsPrefix}-switch__checked`\n }, children)), resolveWrappedSlot(uncheckedSlot, children => children && h(\"div\", {\n key: \"unchecked\",\n class: `${mergedClsPrefix}-switch__unchecked`\n }, children)))));\n }\n});","<script lang=\"tsx\" setup>\nimport ActionCard from '@/components/ActionCard.vue';\nimport { toValidURL } from '@/utils/check';\nimport { showTextDLg, waitShareAgree } from '@/utils/dialog';\nimport { dialog } from '@/utils/discrete';\nimport {\n batchCreateImageId,\n batchCreateZipUrl,\n batchImageDownloadZip,\n batchZipDownloadZip,\n} from '@/utils/export';\nimport { importFromLocal, importFromNetwork } from '@/utils/import';\nimport { getAppInfo } from '@/utils/node';\nimport { getDragEventFiles } from '@/utils/others';\nimport { shallowSnapshotStorage, snapshotStorage } from '@/utils/snapshot';\nimport { renderDevice, useSnapshotColumns } from '@/utils/table';\nimport { useTask } from '@/utils/task';\nimport type { Snapshot } from '@/utils/types';\nimport { getImagUrl } from '@/utils/url';\nimport type { DataTableColumns, PaginationProps } from 'naive-ui';\nimport type { SortState } from 'naive-ui/es/data-table/src/interface';\n\nconst settingsStore = useSettingsStore();\n\nconst snapshots = shallowRef<Snapshot[]>([]);\nconst loading = shallowRef(true);\nconst updateSnapshots = async () => {\n loading.value = true;\n snapshots.value = (await shallowSnapshotStorage.getAllItems()).reverse();\n checkedRowKeys.value = [];\n loading.value = false;\n};\nonMounted(updateSnapshots);\nconst filterOption = shallowReactive({\n query: ``,\n actualQuery: ``,\n updateQuery: () => {\n filterOption.actualQuery = filterOption.query.trim();\n checkedRowKeys.value = [];\n },\n});\nconst filterSnapshots = computed(() => {\n const actualQuery = filterOption.actualQuery;\n if (!actualQuery) return snapshots.value;\n return snapshots.value.filter((s) => {\n return (\n (getAppInfo(s).name || ``).includes(actualQuery) ||\n (s.appId || ``).includes(actualQuery) ||\n (s.activityId || ``).includes(actualQuery)\n );\n });\n});\n\nconst importLocal = useTask(async (_files?: File[]) => {\n if (await importFromLocal(_files)) {\n await updateSnapshots();\n }\n});\n\nuseEventListener(document.body, 'drop', async (e) => {\n e.preventDefault();\n await importLocal.invoke(getDragEventFiles(e));\n});\nuseEventListener(document.body, 'dragover', (e) => {\n e.preventDefault();\n});\n\nconst {\n activityIdCol,\n appIdCol,\n appNameCol,\n ctimeCol,\n mtimeCol,\n deviceCol,\n appVersionCodeCol,\n appVersionNameCol,\n resetColWidth,\n} = useSnapshotColumns();\n\nwatchEffect(() => {\n const set = filterSnapshots.value.reduce(\n (p, c) => (p.add(renderDevice(c)), p),\n new Set<string>(),\n );\n if (set.size <= 1) {\n deviceCol.filterOptions = undefined;\n return;\n }\n deviceCol.filterOptions = [...set.values()].map((s) => ({\n value: s,\n label: s,\n }));\n});\n\nwatchEffect(() => {\n const set = filterSnapshots.value.reduce(\n (p, c) => (p.add(getAppInfo(c).name), p),\n new Set<string>(),\n );\n if (set.size <= 1) {\n appNameCol.filterOptions = undefined;\n return;\n }\n appNameCol.filterOptions = [...set.values()].map((s) => ({\n value: s,\n label: s,\n }));\n});\n\nwatchEffect(() => {\n const set = filterSnapshots.value.reduce(\n (p, c) => (p.add(c.activityId), p),\n new Set<string>(),\n );\n if (set.size <= 1) {\n activityIdCol.filterOptions = undefined;\n return;\n }\n activityIdCol.filterOptions = [...set.values()].map((s) => ({\n value: s,\n label: s,\n }));\n});\n\nconst columns: DataTableColumns<Snapshot> = reactive([\n {\n type: 'selection',\n },\n ctimeCol,\n mtimeCol,\n deviceCol,\n appNameCol,\n appIdCol,\n appVersionCodeCol,\n appVersionNameCol,\n activityIdCol,\n {\n key: `actions`,\n title: `操作`,\n fixed: 'right',\n width: `160px`,\n render(row) {\n return <ActionCard snapshot={row} onDelete={updateSnapshots} />;\n },\n },\n]);\n\nconst pagination = shallowReactive<PaginationProps>({\n page: 1,\n pageSize: 50,\n showSizePicker: true,\n pageSizes: [50, 100],\n onChange: (page: number) => {\n pagination.page = page;\n },\n onUpdatePageSize: (pageSize: number) => {\n pagination.pageSize = pageSize;\n pagination.page = 1;\n },\n});\nwatch(pagination, resetColWidth);\n\nconst handleSorterChange = (sorter: SortState) => {\n [ctimeCol, mtimeCol].forEach((c) => {\n if (sorter.columnKey != c.key) {\n c.sortOrder = undefined;\n } else {\n c.sortOrder = sorter.order;\n }\n });\n};\nmtimeCol.sortOrder = `descend`;\nconst showImportModal = shallowRef(false);\nconst textImportValue = shallowRef(``);\nconst importNetwork = useTask(async () => {\n const urls = textImportValue.value\n .trim()\n .split(`\\n`)\n .map((u) => u.trim())\n .filter((u) => toValidURL(u));\n if (urls.length == 0) return;\n await importFromNetwork(urls);\n await updateSnapshots();\n textImportValue.value = ``;\n});\n\nuseEventListener(document.body, 'paste', (e) => {\n if (showImportModal.value) return;\n const target = e.target as HTMLElement;\n if (\n target instanceof HTMLInputElement ||\n target instanceof HTMLTextAreaElement ||\n (target.className || '').includes('input')\n ) {\n return;\n }\n const dataTransfer = e.clipboardData;\n if (!dataTransfer) return;\n const text = (dataTransfer.getData('text') || '').trim();\n if (text.startsWith('https://') || text.startsWith('http://')) {\n textImportValue.value = text;\n showImportModal.value = true;\n }\n});\n\nconst checkedRowKeys = shallowRef<number[]>([]);\nconst checkedSnapshots = () => {\n return Promise.all(\n checkedRowKeys.value.map(\n (id) => snapshotStorage.getItem(id) as Promise<Snapshot>,\n ),\n );\n};\nconst batchDelete = useTask(async () => {\n await new Promise((res, rej) => {\n dialog.warning({\n title: `删除`,\n content: `是否批量删除 ${checkedRowKeys.value.length} 个快照`,\n negativeText: `取消`,\n positiveText: `确认`,\n onClose: rej,\n onEsc: rej,\n onMaskClick: rej,\n onNegativeClick: rej,\n onPositiveClick: res,\n });\n });\n\n await Promise.all(\n checkedRowKeys.value.map((k) => snapshotStorage.removeItem(k)),\n );\n await updateSnapshots();\n});\nconst batchDownloadImage = useTask(async () => {\n await batchImageDownloadZip(await checkedSnapshots());\n});\nconst batchDownloadZip = useTask(async () => {\n await batchZipDownloadZip(await checkedSnapshots());\n});\n\nconst batchShareImageUrl = useTask(async () => {\n await waitShareAgree();\n const imageIds = await batchCreateImageId(await checkedSnapshots());\n showTextDLg({\n content: imageIds.map((s) => getImagUrl(s)).join(`\\n`) + `\\n`,\n });\n});\nconst batchShareZipUrl = useTask(async () => {\n await waitShareAgree();\n const zipUrls = await batchCreateZipUrl(await checkedSnapshots());\n showTextDLg({\n content: zipUrls.map((s) => location.origin + '/i/' + s).join(`\\n`) + `\\n`,\n });\n});\n\nconst settingsDlgShow = shallowRef(false);\n</script>\n<template>\n <div flex flex-col p-10px gap-10px h-full>\n <div flex>\n <NSpace>\n <NInputGroup>\n <NInput\n placeholder=\"请输入应用名称/应用ID/界面ID\"\n clearable\n class=\"min-w-320px\"\n v-model:value=\"filterOption.query\"\n @keyup.enter=\"filterOption.updateQuery\"\n @change=\"filterOption.updateQuery\"\n ></NInput>\n <NButton @click=\"filterOption.updateQuery\">\n <template #icon>\n <SvgIcon name=\"search\" />\n </template>\n </NButton>\n </NInputGroup>\n <template v-if=\"checkedRowKeys.length\">\n <NPopover>\n <template #trigger>\n <NButton> 批量下载 </NButton>\n </template>\n <NSpace vertical>\n <NButton\n @click=\"batchDownloadZip.invoke\"\n :loading=\"batchDownloadZip.loading\"\n >\n 批量下载-快照\n </NButton>\n <NButton\n @click=\"batchDownloadImage.invoke\"\n :loading=\"batchDownloadImage.loading\"\n >\n 批量下载-图片\n </NButton>\n </NSpace>\n </NPopover>\n <NPopover>\n <template #trigger>\n <NButton> 批量分享 </NButton>\n </template>\n <NSpace vertical>\n <NButton\n @click=\"batchShareZipUrl.invoke\"\n :loading=\"batchShareZipUrl.loading\"\n >\n 批量生成链接-快照\n </NButton>\n <NButton\n @click=\"batchShareImageUrl.invoke\"\n :loading=\"batchShareImageUrl.loading\"\n >\n 批量生成链接-图片\n </NButton>\n </NSpace>\n </NPopover>\n <NButton @click=\"batchDelete.invoke\"> 批量删除 </NButton>\n <div h-full flex flex-items-center>\n {{ `已选中 ${checkedRowKeys.length} 个快照` }}\n </div>\n </template>\n </NSpace>\n <div flex-1></div>\n <div flex gap-24px items-center pr-8px class=\"[--svg-h:24px]\">\n <NTooltip>\n <template #trigger>\n <NButton text @click=\"settingsDlgShow = true\">\n <SvgIcon name=\"settings\" />\n </NButton>\n </template>\n 设置\n </NTooltip>\n <NTooltip>\n <template #trigger>\n <RouterLink flex to=\"/selector\">\n <NButton text>\n <SvgIcon name=\"terminal\" />\n </NButton>\n </RouterLink>\n </template>\n 测试选择器\n </NTooltip>\n <NPopover>\n <template #trigger>\n <NButton text>\n <SvgIcon name=\"import\" />\n </NButton>\n </template>\n <NSpace vertical>\n <NTooltip placement=\"left\">\n <template #trigger>\n <NButton\n @click=\"importLocal.invoke()\"\n :loading=\"importLocal.loading\"\n >\n 导入本地文件\n </NButton>\n </template>\n <div class=\"whitespace-nowrap\">支持拖拽文件到页面任意位置</div>\n </NTooltip>\n <NTooltip placement=\"left\">\n <template #trigger>\n <NButton\n @click=\"showImportModal = true\"\n :loading=\"importNetwork.loading\"\n >\n 导入网络文件\n </NButton>\n </template>\n <div class=\"whitespace-nowrap\">\n 支持任意位置粘贴(Ctrl+V)文本触发导入\n </div>\n </NTooltip>\n </NSpace>\n </NPopover>\n <NTooltip>\n <template #trigger>\n <RouterLink flex to=\"/device\">\n <NButton text>\n <SvgIcon name=\"device\" />\n </NButton>\n </RouterLink>\n </template>\n 连接设备\n </NTooltip>\n <NTooltip>\n <template #trigger>\n <a\n flex\n href=\"https://github.com/orgs/gkd-kit/discussions\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <NButton text>\n <SvgIcon name=\"discussion\" />\n </NButton>\n </a>\n </template>\n 讨论交流\n </NTooltip>\n <NTooltip>\n <template #trigger>\n <a\n flex\n href=\"https://github.com/gkd-kit/inspect\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <NButton text>\n <SvgIcon name=\"github\" />\n </NButton>\n </a>\n </template>\n Github\n </NTooltip>\n </div>\n </div>\n <NDataTable\n striped\n :data=\"filterSnapshots\"\n :columns=\"columns\"\n :scrollX=\"1800\"\n :pagination=\"pagination\"\n v-model:checkedRowKeys=\"checkedRowKeys\"\n :rowKey=\"(r:Snapshot)=>r.id\"\n @update:sorter=\"handleSorterChange\"\n size=\"small\"\n class=\"flex-1\"\n flexHeight\n :loading=\"loading\"\n />\n </div>\n <NModal\n v-model:show=\"showImportModal\"\n preset=\"dialog\"\n title=\"导入网络文件\"\n :showIcon=\"false\"\n positiveText=\"确认\"\n negativeText=\"取消\"\n style=\"width: 800px\"\n @positiveClick=\"importNetwork.invoke\"\n :loading=\"importNetwork.loading\"\n @afterLeave=\"textImportValue = ``\"\n >\n <NInput\n :value=\"textImportValue\"\n @update:value=\"\n if (!importNetwork.loading) {\n textImportValue = $event;\n }\n \"\n type=\"textarea\"\n :placeholder=\"`1.支持ZIP文件链接\\n2.支持快照链接\\n每行一个\\n空白行自动忽略\\n非法链接行自动忽略`\"\n :autosize=\"{\n minRows: 8,\n maxRows: 16,\n }\"\n :inputProps=\"{\n style: `white-space: nowrap;`,\n }\"\n />\n </NModal>\n\n <NModal\n v-model:show=\"settingsDlgShow\"\n preset=\"dialog\"\n title=\"设置\"\n :showIcon=\"false\"\n positiveText=\"关闭\"\n style=\"width: 600px\"\n @positiveClick=\"settingsDlgShow = false\"\n >\n <NCheckbox v-model:checked=\"settingsStore.ignoreUploadWarn\">\n 关闭生成分享链接弹窗提醒\n </NCheckbox>\n <div h-1px my-10px bg=\"#eee\"></div>\n <NCheckbox v-model:checked=\"settingsStore.ignoreWasmWarn\">\n 关闭浏览器版本正则表达式 WASM(GC) 提醒\n </NCheckbox>\n <div h-1px my-10px bg=\"#eee\"></div>\n <div flex gap-10px>\n <NSwitch v-model:value=\"settingsStore.autoUploadImport\" />\n <div>打开快照页面自动生成分享链接(请确保不含隐私)</div>\n </div>\n </NModal>\n</template>\n"],"names":["commonVars","self","vars","primaryColor","opacityDisabled","borderRadius","textColor3","changeColor","switchLight","commonLight","style","cB","cE","iconSwitchTransition","c","cM","cNotM","switchProps","useTheme","supportCssMax","__unplugin_components_9","defineComponent","props","mergedClsPrefixRef","inlineThemeDisabled","useConfig","themeRef","formItem","useFormItem","mergedSizeRef","mergedDisabledRef","uncontrolledValueRef","ref","controlledValueRef","toRef","mergedValueRef","useMergedState","checkedRef","computed","pressedRef","focusedRef","mergedRailStyleRef","railStyle","doUpdateValue","value","_onUpdateValue","onChange","onUpdateValue","nTriggerFormInput","nTriggerFormChange","call","doFocus","nTriggerFormFocus","doBlur","nTriggerFormBlur","handleClick","handleFocus","handleBlur","handleKeyup","e","handleKeydown","cssVarsRef","size","railColor","railColorActive","buttonBoxShadow","buttonColor","boxShadowFocus","loadingColor","textColor","iconColor","createKey","buttonHeight","buttonWidth","buttonWidthPressed","railHeight","railWidth","railBorderRadius","buttonBorderRadius","cubicBezierEaseInOut","offset","height","width","pxfy","depx","themeClassHandle","useThemeClass","mergedClsPrefix","mergedDisabled","checked","mergedRailStyle","onRender","$slots","checkedSlot","uncheckedSlot","iconSlot","checkedIconSlot","uncheckedIconSlot","hasIcon","isSlotEmpty","h","resolveWrappedSlot","checkedSlotChildren","uncheckedSlotChildren","icon","checkedIcon","uncheckedIcon","NIconSwitchTransition","NBaseLoading","children","settingsStore","useSettingsStore","snapshots","shallowRef","loading","updateSnapshots","shallowSnapshotStorage","getAllItems","reverse","checkedRowKeys","onMounted","filterOption","shallowReactive","query","actualQuery","updateQuery","trim","filterSnapshots","filter","s","getAppInfo","name","includes","appId","activityId","importLocal","useTask","_files","importFromLocal","useEventListener","document","body","preventDefault","invoke","getDragEventFiles","activityIdCol","appIdCol","appNameCol","ctimeCol","mtimeCol","deviceCol","appVersionCodeCol","appVersionNameCol","resetColWidth","useSnapshotColumns","watchEffect","set","reduce","p","add","renderDevice","Set","filterOptions","undefined","values","map","label","columns","reactive","type","key","title","fixed","render","row","_createVNode2","ActionCard","pagination","page","pageSize","showSizePicker","pageSizes","onUpdatePageSize","watch","handleSorterChange","sorter","forEach","columnKey","sortOrder","order","showImportModal","textImportValue","importNetwork","urls","split","u","toValidURL","length","importFromNetwork","target","HTMLInputElement","HTMLTextAreaElement","className","dataTransfer","clipboardData","text","getData","startsWith","checkedSnapshots","Promise","all","id","snapshotStorage","getItem","batchDelete","res","rej","dialog","warning","content","negativeText","positiveText","onClose","onEsc","onMaskClick","onNegativeClick","onPositiveClick","k","removeItem","batchDownloadImage","batchImageDownloadZip","batchDownloadZip","batchZipDownloadZip","batchShareImageUrl","waitShareAgree","imageIds","batchCreateImageId","showTextDLg","getImagUrl","join","batchShareZipUrl","zipUrls","batchCreateZipUrl","location","origin","settingsDlgShow"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}
@@ -1,2 +0,0 @@
1
- import{h as k,aJ as y,aK as v,A as f,b7 as S,B as b,b8 as V,aV as B,aX as h,aL as N,aZ as i,b9 as R,K as g,L as w,P as U,a7 as q,Q as l,U as x,M as I,a8 as L,V as C,ba as D}from"./index-DJ3BflFD.js";import{a as F,g as K}from"./snapshot-LXrnvSmm.js";import{a as M}from"./import-Ck1vFpon.js";import"./chunk-CPNWa47E.js";const P={class:"h-[calc(100%-10px)]",flex:"","gap-5px":"","pt-40px":"","flex-col":"","flex-items-center":""},Q={key:0,"mb-20px":""},X=k({__name:"ImportPage",setup(T){const p=y(),c=v(),u=f(!0),r=f("加载中..."),m=async s=>{c.replace({name:"snapshot",params:{snapshotId:s},query:D(p.query,["str","gkd"])})},n=String(p.query.url||""),e=S(n);return b(async()=>{var d;if(!V(n)){B.error("非法URL参数"),await h(1e3),c.replace({path:"/"});return}const{importSnapshotId:s,snapshotImportId:o,waitInit:_}=N();if(await _(),e){const t=s[e];if(t)if(await F.getItem(t)){m(t);return}else delete s[e]}i.start();try{const[t]=(d=await M(e?R(e):n))!=null?d:[];if(t.status=="fulfilled"){i.finish();const a=t.value;a!=null&&a.id?(e&&(s[e]=a.id,o[a.id]=e),u.value=!1,await h(500),m(a.id)):r.value="获取资源失败"}else throw t.reason}catch{i.error(),r.value="加载资源失败"}}),(s,o)=>(w(),g("div",P,[l(K)()?U("",!0):(w(),g("div",Q,o[0]||(o[0]=[x(" 建议安装并启用 "),I("a",{href:"https://github.com/gkd-kit/network-extension",target:"_blank",rel:"noopener noreferrer"}," 油猴脚本 ",-1),x(" 获取更快加载速度 ")]))),q(I("div",null,C(l(r)),513),[[L,l(u)]])]))}});export{X as default};
2
- //# sourceMappingURL=ImportPage-BjIx-_N1.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ImportPage-BjIx-_N1.js","sources":["../../src/views/ImportPage.vue"],"sourcesContent":["<script setup lang=\"tsx\">\nimport { loadingBar, message } from '@/utils/discrete';\nimport { gmOk } from '@/utils/gm';\nimport { importFromNetwork } from '@/utils/import';\nimport { delay, filterQuery } from '@/utils/others';\nimport { snapshotStorage } from '@/utils/snapshot';\nimport { getImportFileUrl, getImportId, isValidUrl } from '@/utils/url';\n\nconst route = useRoute();\nconst router = useRouter();\n\nconst loading = shallowRef(true);\nconst tip = shallowRef(`加载中...`);\n\nconst goToSnapshot = async (snapshotId: number) => {\n router.replace({\n name: 'snapshot',\n params: { snapshotId },\n query: filterQuery(route.query, ['str', 'gkd']),\n });\n};\n\nconst url = String(route.query.url || ``);\nconst importId = getImportId(url);\n\nonMounted(async () => {\n if (!isValidUrl(url)) {\n message.error(`非法URL参数`);\n await delay(1000);\n router.replace({\n path: `/`,\n });\n return;\n }\n const { importSnapshotId, snapshotImportId, waitInit } = useStorageStore();\n await waitInit();\n if (importId) {\n const snapshotId = importSnapshotId[importId];\n if (snapshotId) {\n const snapshot = await snapshotStorage.getItem(snapshotId);\n if (snapshot) {\n goToSnapshot(snapshotId);\n return;\n } else {\n delete importSnapshotId[importId];\n }\n }\n }\n loadingBar.start();\n try {\n const [result] =\n (await importFromNetwork(importId ? getImportFileUrl(importId) : url)) ??\n [];\n\n if (result.status == 'fulfilled') {\n loadingBar.finish();\n const snapshot = result.value;\n if (snapshot?.id) {\n if (importId) {\n importSnapshotId[importId] = snapshot.id;\n snapshotImportId[snapshot.id] = importId;\n }\n loading.value = false;\n await delay(500);\n goToSnapshot(snapshot.id);\n } else {\n tip.value = `获取资源失败`;\n }\n } else {\n throw result.reason;\n }\n } catch {\n loadingBar.error();\n tip.value = `加载资源失败`;\n }\n});\n</script>\n<template>\n <div\n class=\"h-[calc(100%-10px)]\"\n flex\n gap-5px\n pt-40px\n flex-col\n flex-items-center\n >\n <div v-if=\"!gmOk()\" mb-20px>\n 建议安装并启用\n <a\n href=\"https://github.com/gkd-kit/network-extension\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n 油猴脚本\n </a>\n 获取更快加载速度\n </div>\n <div v-show=\"loading\">\n {{ tip }}\n </div>\n </div>\n</template>\n"],"names":["route","useRoute","router","useRouter","loading","shallowRef","tip","goToSnapshot","snapshotId","replace","name","params","query","filterQuery","url","String","importId","getImportId","onMounted","isValidUrl","message","error","delay","path","importSnapshotId","snapshotImportId","waitInit","useStorageStore","snapshotStorage","getItem","loadingBar","start","result","_a","importFromNetwork","getImportFileUrl","status","finish","snapshot","value","id","reason"],"mappings":"oeAQA,MAAMA,EAAQC,EAAU,EAClBC,EAASC,EAAW,EAEpBC,EAAUC,EAAW,EAAI,EACzBC,EAAMD,EAAW,QAAQ,EAEzBE,EAAe,MAAOC,GAAuB,CACjDN,EAAOO,QAAQ,CACbC,KAAM,WACNC,OAAQ,CAAEH,WAAAA,CAAY,EACtBI,MAAOC,EAAYb,EAAMY,MAAO,CAAC,MAAO,KAAK,CAAC,CAChD,CAAC,CACF,EAEKE,EAAMC,OAAOf,EAAMY,MAAME,KAAO,EAAE,EAClCE,EAAWC,EAAYH,CAAG,EAEhCI,OAAAA,EAAU,SAAY,OACpB,GAAI,CAACC,EAAWL,CAAG,EAAG,CACpBM,EAAQC,MAAM,SAAS,EACvB,MAAMC,EAAM,GAAI,EAChBpB,EAAOO,QAAQ,CACbc,KAAM,GACR,CAAC,EACD,MACF,CACA,KAAM,CAAEC,iBAAAA,EAAkBC,iBAAAA,EAAkBC,SAAAA,CAAU,EAAGC,EAAiB,EAE1E,GADA,MAAMD,EAAU,EACZV,EAAU,CACZ,MAAMR,EAAagB,EAAiBR,CAAQ,EAC5C,GAAIR,EAEF,GADiB,MAAMoB,EAAgBC,QAAQrB,CAAU,EAC3C,CACZD,EAAaC,CAAU,EACvB,MACF,MACE,OAAOgB,EAAiBR,CAAQ,CAGtC,CACAc,EAAWC,MAAO,EAClB,GAAI,CACF,KAAM,CAACC,CAAM,GACVC,EAAA,MAAMC,EAAkBlB,EAAWmB,EAAiBnB,CAAQ,EAAIF,CAAG,IAAnE,KAAAmB,EACD,CAAE,EAEJ,GAAID,EAAOI,QAAU,YAAa,CAChCN,EAAWO,OAAQ,EACnB,MAAMC,EAAWN,EAAOO,MACpBD,GAAAA,MAAAA,EAAUE,IACRxB,IACFQ,EAAiBR,CAAQ,EAAIsB,EAASE,GACtCf,EAAiBa,EAASE,EAAE,EAAIxB,GAElCZ,EAAQmC,MAAQ,GAChB,MAAMjB,EAAM,GAAG,EACff,EAAa+B,EAASE,EAAE,GAExBlC,EAAIiC,MAAQ,QAEhB,KACE,OAAMP,EAAOS,MAEjB,MAAQ,CACNX,EAAWT,MAAO,EAClBf,EAAIiC,MAAQ,QACd,CACF,CAAC"}