Compare commits
	
		
			No commits in common. "e782b72b74619f985976f22265ae8e6fedbf1c91" and "f1fa0208c19ec48d2d6e5312165bdfca4dfdf719" have entirely different histories.
		
	
	
		
			e782b72b74
			...
			f1fa0208c1
		
	
		
							
								
								
									
										75
									
								
								auto-imports.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										75
									
								
								auto-imports.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -1,75 +0,0 @@ | |||||||
| /* eslint-disable */ |  | ||||||
| /* prettier-ignore */ |  | ||||||
| // @ts-nocheck
 |  | ||||||
| // noinspection JSUnusedGlobalSymbols
 |  | ||||||
| // Generated by unplugin-auto-import
 |  | ||||||
| // biome-ignore lint: disable
 |  | ||||||
| export {} |  | ||||||
| declare global { |  | ||||||
|   const EffectScope: typeof import('vue')['EffectScope'] |  | ||||||
|   const computed: typeof import('vue')['computed'] |  | ||||||
|   const createApp: typeof import('vue')['createApp'] |  | ||||||
|   const customRef: typeof import('vue')['customRef'] |  | ||||||
|   const defineAsyncComponent: typeof import('vue')['defineAsyncComponent'] |  | ||||||
|   const defineComponent: typeof import('vue')['defineComponent'] |  | ||||||
|   const effectScope: typeof import('vue')['effectScope'] |  | ||||||
|   const getCurrentInstance: typeof import('vue')['getCurrentInstance'] |  | ||||||
|   const getCurrentScope: typeof import('vue')['getCurrentScope'] |  | ||||||
|   const h: typeof import('vue')['h'] |  | ||||||
|   const inject: typeof import('vue')['inject'] |  | ||||||
|   const isProxy: typeof import('vue')['isProxy'] |  | ||||||
|   const isReactive: typeof import('vue')['isReactive'] |  | ||||||
|   const isReadonly: typeof import('vue')['isReadonly'] |  | ||||||
|   const isRef: typeof import('vue')['isRef'] |  | ||||||
|   const markRaw: typeof import('vue')['markRaw'] |  | ||||||
|   const nextTick: typeof import('vue')['nextTick'] |  | ||||||
|   const onActivated: typeof import('vue')['onActivated'] |  | ||||||
|   const onBeforeMount: typeof import('vue')['onBeforeMount'] |  | ||||||
|   const onBeforeUnmount: typeof import('vue')['onBeforeUnmount'] |  | ||||||
|   const onBeforeUpdate: typeof import('vue')['onBeforeUpdate'] |  | ||||||
|   const onDeactivated: typeof import('vue')['onDeactivated'] |  | ||||||
|   const onErrorCaptured: typeof import('vue')['onErrorCaptured'] |  | ||||||
|   const onMounted: typeof import('vue')['onMounted'] |  | ||||||
|   const onRenderTracked: typeof import('vue')['onRenderTracked'] |  | ||||||
|   const onRenderTriggered: typeof import('vue')['onRenderTriggered'] |  | ||||||
|   const onScopeDispose: typeof import('vue')['onScopeDispose'] |  | ||||||
|   const onServerPrefetch: typeof import('vue')['onServerPrefetch'] |  | ||||||
|   const onUnmounted: typeof import('vue')['onUnmounted'] |  | ||||||
|   const onUpdated: typeof import('vue')['onUpdated'] |  | ||||||
|   const onWatcherCleanup: typeof import('vue')['onWatcherCleanup'] |  | ||||||
|   const provide: typeof import('vue')['provide'] |  | ||||||
|   const reactive: typeof import('vue')['reactive'] |  | ||||||
|   const readonly: typeof import('vue')['readonly'] |  | ||||||
|   const ref: typeof import('vue')['ref'] |  | ||||||
|   const resolveComponent: typeof import('vue')['resolveComponent'] |  | ||||||
|   const shallowReactive: typeof import('vue')['shallowReactive'] |  | ||||||
|   const shallowReadonly: typeof import('vue')['shallowReadonly'] |  | ||||||
|   const shallowRef: typeof import('vue')['shallowRef'] |  | ||||||
|   const toRaw: typeof import('vue')['toRaw'] |  | ||||||
|   const toRef: typeof import('vue')['toRef'] |  | ||||||
|   const toRefs: typeof import('vue')['toRefs'] |  | ||||||
|   const toValue: typeof import('vue')['toValue'] |  | ||||||
|   const triggerRef: typeof import('vue')['triggerRef'] |  | ||||||
|   const unref: typeof import('vue')['unref'] |  | ||||||
|   const useAttrs: typeof import('vue')['useAttrs'] |  | ||||||
|   const useCssModule: typeof import('vue')['useCssModule'] |  | ||||||
|   const useCssVars: typeof import('vue')['useCssVars'] |  | ||||||
|   const useDialog: typeof import('naive-ui')['useDialog'] |  | ||||||
|   const useId: typeof import('vue')['useId'] |  | ||||||
|   const useLoadingBar: typeof import('naive-ui')['useLoadingBar'] |  | ||||||
|   const useMessage: typeof import('naive-ui')['useMessage'] |  | ||||||
|   const useModel: typeof import('vue')['useModel'] |  | ||||||
|   const useNotification: typeof import('naive-ui')['useNotification'] |  | ||||||
|   const useSlots: typeof import('vue')['useSlots'] |  | ||||||
|   const useTemplateRef: typeof import('vue')['useTemplateRef'] |  | ||||||
|   const watch: typeof import('vue')['watch'] |  | ||||||
|   const watchEffect: typeof import('vue')['watchEffect'] |  | ||||||
|   const watchPostEffect: typeof import('vue')['watchPostEffect'] |  | ||||||
|   const watchSyncEffect: typeof import('vue')['watchSyncEffect'] |  | ||||||
| } |  | ||||||
| // for type re-export
 |  | ||||||
| declare global { |  | ||||||
|   // @ts-ignore
 |  | ||||||
|   export type { Component, ComponentPublicInstance, ComputedRef, DirectiveBinding, ExtractDefaultPropTypes, ExtractPropTypes, ExtractPublicPropTypes, InjectionKey, PropType, Ref, MaybeRef, MaybeRefOrGetter, VNode, WritableComputedRef } from 'vue' |  | ||||||
|   import('vue') |  | ||||||
| } |  | ||||||
							
								
								
									
										66
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										66
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -1,66 +0,0 @@ | |||||||
| /* eslint-disable */ |  | ||||||
| // @ts-nocheck
 |  | ||||||
| // Generated by unplugin-vue-components
 |  | ||||||
| // Read more: https://github.com/vuejs/core/pull/3399
 |  | ||||||
| // biome-ignore lint: disable
 |  | ||||||
| export {} |  | ||||||
| 
 |  | ||||||
| /* prettier-ignore */ |  | ||||||
| declare module 'vue' { |  | ||||||
|   export interface GlobalComponents { |  | ||||||
|     AudioMessage: typeof import('./src/components/talk/message/AudioMessage.vue')['default'] |  | ||||||
|     Avatar: typeof import('./src/components/base/Avatar.vue')['default'] |  | ||||||
|     AvatarCropper: typeof import('./src/components/base/AvatarCropper.vue')['default'] |  | ||||||
|     AvatarModule: typeof import('./src/components/avatar-module/index.vue')['default'] |  | ||||||
|     CheckBox: typeof import('./src/components/checkBox/index.vue')['default'] |  | ||||||
|     CodeMessage: typeof import('./src/components/talk/message/CodeMessage.vue')['default'] |  | ||||||
|     CustomBtn: typeof import('./src/components/custom-btn/custom-btn.vue')['default'] |  | ||||||
|     CustomInput: typeof import('./src/components/custom-input/custom-input.vue')['default'] |  | ||||||
|     CustomNavbar: typeof import('./src/components/custom-navbar/index.vue')['default'] |  | ||||||
|     CustomRefresher: typeof import('./src/components/custom-refresher/custom-refresher.vue')['default'] |  | ||||||
|     DeepBubble: typeof import('./src/components/deep-bubble/deep-bubble.vue')['default'] |  | ||||||
|     FileMessage: typeof import('./src/components/talk/message/FileMessage.vue')['default'] |  | ||||||
|     ForwardMessage: typeof import('./src/components/talk/message/ForwardMessage.vue')['default'] |  | ||||||
|     ForwardRecord: typeof import('./src/components/talk/ForwardRecord.vue')['default'] |  | ||||||
|     GroupNoticeMessage: typeof import('./src/components/talk/message/GroupNoticeMessage.vue')['default'] |  | ||||||
|     HistoryRecord: typeof import('./src/components/talk/HistoryRecord.vue')['default'] |  | ||||||
|     ImageMessage: typeof import('./src/components/talk/message/ImageMessage.vue')['default'] |  | ||||||
|     LinkMessage: typeof import('./src/components/talk/message/LinkMessage.vue')['default'] |  | ||||||
|     Loading: typeof import('./src/components/base/Loading.vue')['default'] |  | ||||||
|     LoginMessage: typeof import('./src/components/talk/message/LoginMessage.vue')['default'] |  | ||||||
|     Message: typeof import('./src/components/x-message/message/index.vue')['default'] |  | ||||||
|     MixedMessage: typeof import('./src/components/talk/message/MixedMessage.vue')['default'] |  | ||||||
|     NButton: typeof import('naive-ui')['NButton'] |  | ||||||
|     NIcon: typeof import('naive-ui')['NIcon'] |  | ||||||
|     PageAnimation: typeof import('./src/components/page-animation/index.vue')['default'] |  | ||||||
|     RevokeMessage: typeof import('./src/components/talk/message/RevokeMessage.vue')['default'] |  | ||||||
|     RouterLink: typeof import('vue-router')['RouterLink'] |  | ||||||
|     RouterView: typeof import('vue-router')['RouterView'] |  | ||||||
|     SysGroupCancelMutedMessage: typeof import('./src/components/talk/message/system/SysGroupCancelMutedMessage.vue')['default'] |  | ||||||
|     SysGroupCreateMessage: typeof import('./src/components/talk/message/system/SysGroupCreateMessage.vue')['default'] |  | ||||||
|     SysGroupJoinMessage: typeof import('./src/components/talk/message/system/SysGroupJoinMessage.vue')['default'] |  | ||||||
|     SysGroupMemberCancelMutedMessage: typeof import('./src/components/talk/message/system/SysGroupMemberCancelMutedMessage.vue')['default'] |  | ||||||
|     SysGroupMemberKickedMessage: typeof import('./src/components/talk/message/system/SysGroupMemberKickedMessage.vue')['default'] |  | ||||||
|     SysGroupMemberMutedMessage: typeof import('./src/components/talk/message/system/SysGroupMemberMutedMessage.vue')['default'] |  | ||||||
|     SysGroupMemberQuitMessage: typeof import('./src/components/talk/message/system/SysGroupMemberQuitMessage.vue')['default'] |  | ||||||
|     SysGroupMutedMessage: typeof import('./src/components/talk/message/system/SysGroupMutedMessage.vue')['default'] |  | ||||||
|     SysGroupTransferMessage: typeof import('./src/components/talk/message/system/SysGroupTransferMessage.vue')['default'] |  | ||||||
|     SysTextMessage: typeof import('./src/components/talk/message/system/SysTextMessage.vue')['default'] |  | ||||||
|     TabbarItem: typeof import('./src/components/x-tabbar/components/tabbar-item/index.vue')['default'] |  | ||||||
|     TextMessage: typeof import('./src/components/talk/message/TextMessage.vue')['default'] |  | ||||||
|     UnknownMessage: typeof import('./src/components/talk/message/UnknownMessage.vue')['default'] |  | ||||||
|     UploadsModal: typeof import('./src/components/base/UploadsModal.vue')['default'] |  | ||||||
|     VideoMessage: typeof import('./src/components/talk/message/VideoMessage.vue')['default'] |  | ||||||
|     VoteMessage: typeof import('./src/components/talk/message/VoteMessage.vue')['default'] |  | ||||||
|     XCalendar: typeof import('./src/components/x-calendar/index.vue')['default'] |  | ||||||
|     XCaptcha: typeof import('./src/components/x-captcha/index.vue')['default'] |  | ||||||
|     XConfirm: typeof import('./src/components/x-confirm/index.vue')['default'] |  | ||||||
|     XDateSelect: typeof import('./src/components/x-date-select/index.vue')['default'] |  | ||||||
|     XLoaderror: typeof import('./src/components/x-loaderror/index.vue')['default'] |  | ||||||
|     XLoading: typeof import('./src/components/x-loading/index.vue')['default'] |  | ||||||
|     XMessage: typeof import('./src/components/x-message/index.vue')['default'] |  | ||||||
|     XPaging: typeof import('./src/components/x-paging/index.vue')['default'] |  | ||||||
|     XTabbar: typeof import('./src/components/x-tabbar/index.vue')['default'] |  | ||||||
|     Xtime: typeof import('./src/components/base/Xtime.vue')['default'] |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @ -58,15 +58,12 @@ | |||||||
|     "@vue/runtime-core": "^3.3.8", |     "@vue/runtime-core": "^3.3.8", | ||||||
|     "@vue/tsconfig": "^0.5.1", |     "@vue/tsconfig": "^0.5.1", | ||||||
|     "lint-staged": "^15.2.0", |     "lint-staged": "^15.2.0", | ||||||
|     "naive-ui": "^2.41.0", |  | ||||||
|     "pinia": "2.0.36", |     "pinia": "2.0.36", | ||||||
|     "sass": "^1.77.8", |     "sass": "^1.77.8", | ||||||
|     "simple-git-hooks": "^2.9.0", |     "simple-git-hooks": "^2.9.0", | ||||||
|     "typescript": "^5.3.3", |     "typescript": "^5.3.3", | ||||||
|     "unocss": "^0.58.9", |     "unocss": "^0.58.9", | ||||||
|     "unocss-applet": "^0.8.2", |     "unocss-applet": "^0.8.2", | ||||||
|     "unplugin-auto-import": "^19.1.1", |  | ||||||
|     "unplugin-vue-components": "^28.4.1", |  | ||||||
|     "vite": "^5.0.11", |     "vite": "^5.0.11", | ||||||
|     "vue-tsc": "^1.8.27" |     "vue-tsc": "^1.8.27" | ||||||
|   } |   } | ||||||
|  | |||||||
							
								
								
									
										451
									
								
								pnpm-lock.yaml
									
									
									
									
									
								
							
							
						
						
									
										451
									
								
								pnpm-lock.yaml
									
									
									
									
									
								
							| @ -128,7 +128,7 @@ importers: | |||||||
|         version: 0.1.4 |         version: 0.1.4 | ||||||
|       '@uni-helper/unocss-preset-uni': |       '@uni-helper/unocss-preset-uni': | ||||||
|         specifier: ^0.2.9 |         specifier: ^0.2.9 | ||||||
|         version: 0.2.9(@unocss/preset-mini@0.62.3)(@unocss/rule-utils@0.62.3)(@unocss/vite@0.62.3(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))(unocss-applet@0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))))(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) |         version: 0.2.9(@unocss/preset-mini@0.62.3)(@unocss/rule-utils@0.62.3)(@unocss/vite@0.62.3(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))(unocss-applet@0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))))(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) | ||||||
|       '@uni-helper/volar-service-uni-pages': |       '@uni-helper/volar-service-uni-pages': | ||||||
|         specifier: ^0.2.14 |         specifier: ^0.2.14 | ||||||
|         version: 0.2.26 |         version: 0.2.26 | ||||||
| @ -144,9 +144,6 @@ importers: | |||||||
|       lint-staged: |       lint-staged: | ||||||
|         specifier: ^15.2.0 |         specifier: ^15.2.0 | ||||||
|         version: 15.2.7 |         version: 15.2.7 | ||||||
|       naive-ui: |  | ||||||
|         specifier: ^2.41.0 |  | ||||||
|         version: 2.41.0(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       pinia: |       pinia: | ||||||
|         specifier: 2.0.36 |         specifier: 2.0.36 | ||||||
|         version: 2.0.36(typescript@5.5.4)(vue@3.4.35(typescript@5.5.4)) |         version: 2.0.36(typescript@5.5.4)(vue@3.4.35(typescript@5.5.4)) | ||||||
| @ -164,13 +161,7 @@ importers: | |||||||
|         version: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) |         version: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) | ||||||
|       unocss-applet: |       unocss-applet: | ||||||
|         specifier: ^0.8.2 |         specifier: ^0.8.2 | ||||||
|         version: 0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) |         version: 0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) | ||||||
|       unplugin-auto-import: |  | ||||||
|         specifier: ^19.1.1 |  | ||||||
|         version: 19.1.1(@nuxt/kit@3.14.1592(rollup@4.19.2))(@vueuse/core@9.13.0(vue@3.4.35(typescript@5.5.4))) |  | ||||||
|       unplugin-vue-components: |  | ||||||
|         specifier: ^28.4.1 |  | ||||||
|         version: 28.4.1(@babel/parser@7.26.2)(@nuxt/kit@3.14.1592(rollup@4.19.2))(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       vite: |       vite: | ||||||
|         specifier: ^5.0.11 |         specifier: ^5.0.11 | ||||||
|         version: 5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3) |         version: 5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3) | ||||||
| @ -865,16 +856,6 @@ packages: | |||||||
|   '@bcoe/v8-coverage@0.2.3': |   '@bcoe/v8-coverage@0.2.3': | ||||||
|     resolution: {integrity: sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==} |     resolution: {integrity: sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==} | ||||||
| 
 | 
 | ||||||
|   '@css-render/plugin-bem@0.15.14': |  | ||||||
|     resolution: {integrity: sha512-QK513CJ7yEQxm/P3EwsI+d+ha8kSOcjGvD6SevM41neEMxdULE+18iuQK6tEChAWMOQNQPLG/Rw3Khb69r5neg==} |  | ||||||
|     peerDependencies: |  | ||||||
|       css-render: ~0.15.14 |  | ||||||
| 
 |  | ||||||
|   '@css-render/vue3-ssr@0.15.14': |  | ||||||
|     resolution: {integrity: sha512-//8027GSbxE9n3QlD73xFY6z4ZbHbvrOVB7AO6hsmrEzGbg+h2A09HboUyDgu+xsmj7JnvJD39Irt+2D0+iV8g==} |  | ||||||
|     peerDependencies: |  | ||||||
|       vue: ^3.0.11 |  | ||||||
| 
 |  | ||||||
|   '@dcloudio/types@3.4.12': |   '@dcloudio/types@3.4.12': | ||||||
|     resolution: {integrity: sha512-xSFDhBCm4bqdRBO9mBj7wySz7fzOv9sMeK9VMI21tHvZbT2bIdGMU5o+kJ/J4H2+N5+7SW2kDY+aIzZs94DAOg==} |     resolution: {integrity: sha512-xSFDhBCm4bqdRBO9mBj7wySz7fzOv9sMeK9VMI21tHvZbT2bIdGMU5o+kJ/J4H2+N5+7SW2kDY+aIzZs94DAOg==} | ||||||
| 
 | 
 | ||||||
| @ -987,9 +968,6 @@ packages: | |||||||
|     peerDependencies: |     peerDependencies: | ||||||
|       vite: ^4.0.0 |       vite: ^4.0.0 | ||||||
| 
 | 
 | ||||||
|   '@emotion/hash@0.8.0': |  | ||||||
|     resolution: {integrity: sha512-kBJtf7PH6aWwZ6fka3zQ0p6SBYzx4fl1LoZXE2RrnYST9Xljm7WfKJrU4g/Xr3Beg72MLrp1AWNUmuYJTL7Cow==} |  | ||||||
| 
 |  | ||||||
|   '@esbuild/aix-ppc64@0.21.5': |   '@esbuild/aix-ppc64@0.21.5': | ||||||
|     resolution: {integrity: sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==} |     resolution: {integrity: sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==} | ||||||
|     engines: {node: '>=12'} |     engines: {node: '>=12'} | ||||||
| @ -1701,9 +1679,6 @@ packages: | |||||||
|   '@jridgewell/trace-mapping@0.3.25': |   '@jridgewell/trace-mapping@0.3.25': | ||||||
|     resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==} |     resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==} | ||||||
| 
 | 
 | ||||||
|   '@juggle/resize-observer@3.4.0': |  | ||||||
|     resolution: {integrity: sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA==} |  | ||||||
| 
 |  | ||||||
|   '@nodelib/fs.scandir@2.1.5': |   '@nodelib/fs.scandir@2.1.5': | ||||||
|     resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==} |     resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==} | ||||||
|     engines: {node: '>= 8'} |     engines: {node: '>= 8'} | ||||||
| @ -1888,15 +1863,6 @@ packages: | |||||||
|   '@types/istanbul-reports@3.0.4': |   '@types/istanbul-reports@3.0.4': | ||||||
|     resolution: {integrity: sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==} |     resolution: {integrity: sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==} | ||||||
| 
 | 
 | ||||||
|   '@types/katex@0.16.7': |  | ||||||
|     resolution: {integrity: sha512-HMwFiRujE5PjrgwHQ25+bsLJgowjGjm5Z8FVSf0N6PwgJrwxH0QxzHYDcKsTfV3wva0vzrpqMTJS2jXPr5BMEQ==} |  | ||||||
| 
 |  | ||||||
|   '@types/lodash-es@4.17.12': |  | ||||||
|     resolution: {integrity: sha512-0NgftHUcV4v34VhXm8QBSftKVXtbkBG3ViCjs6+eJ5a6y6Mi/jiFGPc1sC7QK+9BFhWrURE3EOggmWaSxL9OzQ==} |  | ||||||
| 
 |  | ||||||
|   '@types/lodash@4.17.16': |  | ||||||
|     resolution: {integrity: sha512-HX7Em5NYQAXKW+1T+FiuG27NGwzJfCX3s1GjOa7ujxZa52kjJLOr4FUxT+giF6Tgxv1e+/czV/iTtBw27WTU9g==} |  | ||||||
| 
 |  | ||||||
|   '@types/node@20.14.14': |   '@types/node@20.14.14': | ||||||
|     resolution: {integrity: sha512-d64f00982fS9YoOgJkAMolK7MN8Iq3TDdVjchbYHdEmjth/DHowx82GnoA+tVUAN+7vxfYUgAzi+JXbKNd2SDQ==} |     resolution: {integrity: sha512-d64f00982fS9YoOgJkAMolK7MN8Iq3TDdVjchbYHdEmjth/DHowx82GnoA+tVUAN+7vxfYUgAzi+JXbKNd2SDQ==} | ||||||
| 
 | 
 | ||||||
| @ -2333,9 +2299,6 @@ packages: | |||||||
|   array-flatten@1.1.1: |   array-flatten@1.1.1: | ||||||
|     resolution: {integrity: sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==} |     resolution: {integrity: sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==} | ||||||
| 
 | 
 | ||||||
|   async-validator@4.2.5: |  | ||||||
|     resolution: {integrity: sha512-7HhHjtERjqlNbZtqNqy2rckN/SpOOlmDliet+lP7k+eKZEjPk3DgyeU9lIXLdeLz0uBbbVp+9Qdow9wJWgwwfg==} |  | ||||||
| 
 |  | ||||||
|   asynckit@0.4.0: |   asynckit@0.4.0: | ||||||
|     resolution: {integrity: sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==} |     resolution: {integrity: sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==} | ||||||
| 
 | 
 | ||||||
| @ -2606,9 +2569,6 @@ packages: | |||||||
|   confbox@0.1.8: |   confbox@0.1.8: | ||||||
|     resolution: {integrity: sha512-RMtmw0iFkeR4YV+fUOSucriAQNb9g8zFR52MWCtl+cCZOFRNL6zeB395vPzFhEjjn4fMxXudmELnl/KF/WrK6w==} |     resolution: {integrity: sha512-RMtmw0iFkeR4YV+fUOSucriAQNb9g8zFR52MWCtl+cCZOFRNL6zeB395vPzFhEjjn4fMxXudmELnl/KF/WrK6w==} | ||||||
| 
 | 
 | ||||||
|   confbox@0.2.1: |  | ||||||
|     resolution: {integrity: sha512-hkT3yDPFbs95mNCy1+7qNKC6Pro+/ibzYxtM2iqEigpf0sVw+bg4Zh9/snjsBcf990vfIsg5+1U7VyiyBb3etg==} |  | ||||||
| 
 |  | ||||||
|   consola@3.2.3: |   consola@3.2.3: | ||||||
|     resolution: {integrity: sha512-I5qxpzLv+sJhTVEoLYNcTW+bThDCPsit0vLNKShZx6rLtpilNpmmeTPaeqJb9ZE9dV3DGaeby6Vuhrw38WjeyQ==} |     resolution: {integrity: sha512-I5qxpzLv+sJhTVEoLYNcTW+bThDCPsit0vLNKShZx6rLtpilNpmmeTPaeqJb9ZE9dV3DGaeby6Vuhrw38WjeyQ==} | ||||||
|     engines: {node: ^14.18.0 || >=16.10.0} |     engines: {node: ^14.18.0 || >=16.10.0} | ||||||
| @ -2679,9 +2639,6 @@ packages: | |||||||
|   css-list-helpers@2.0.0: |   css-list-helpers@2.0.0: | ||||||
|     resolution: {integrity: sha512-9Bj8tZ0jWbAM3u/U6m/boAzAwLPwtjzFvwivr2piSvyVa3K3rChJzQy4RIHkNkKiZCHrEMWDJWtTR8UyVhdDnQ==} |     resolution: {integrity: sha512-9Bj8tZ0jWbAM3u/U6m/boAzAwLPwtjzFvwivr2piSvyVa3K3rChJzQy4RIHkNkKiZCHrEMWDJWtTR8UyVhdDnQ==} | ||||||
| 
 | 
 | ||||||
|   css-render@0.15.14: |  | ||||||
|     resolution: {integrity: sha512-9nF4PdUle+5ta4W5SyZdLCCmFd37uVimSjg1evcTqKJCyvCEEj12WKzOSBNak6r4im4J4iYXKH1OWpUV5LBYFg==} |  | ||||||
| 
 |  | ||||||
|   css-system-font-keywords@1.0.0: |   css-system-font-keywords@1.0.0: | ||||||
|     resolution: {integrity: sha512-1umTtVd/fXS25ftfjB71eASCrYhilmEsvDEI6wG/QplnmlfmVM5HkZ/ZX46DT5K3eblFPgLUHt5BRCb0YXkSFA==} |     resolution: {integrity: sha512-1umTtVd/fXS25ftfjB71eASCrYhilmEsvDEI6wG/QplnmlfmVM5HkZ/ZX46DT5K3eblFPgLUHt5BRCb0YXkSFA==} | ||||||
| 
 | 
 | ||||||
| @ -2704,9 +2661,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==} |     resolution: {integrity: sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==} | ||||||
|     engines: {node: '>=8'} |     engines: {node: '>=8'} | ||||||
| 
 | 
 | ||||||
|   csstype@3.0.11: |  | ||||||
|     resolution: {integrity: sha512-sa6P2wJ+CAbgyy4KFssIb/JNMLxFvKF1pCYCSXS8ZMuqZnMsrxqI2E5sPyoTpxoPU/gVZMzr2zjOfg8GIZOMsw==} |  | ||||||
| 
 |  | ||||||
|   csstype@3.1.3: |   csstype@3.1.3: | ||||||
|     resolution: {integrity: sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==} |     resolution: {integrity: sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==} | ||||||
| 
 | 
 | ||||||
| @ -2714,14 +2668,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==} |     resolution: {integrity: sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==} | ||||||
|     engines: {node: '>=10'} |     engines: {node: '>=10'} | ||||||
| 
 | 
 | ||||||
|   date-fns-tz@3.2.0: |  | ||||||
|     resolution: {integrity: sha512-sg8HqoTEulcbbbVXeg84u5UnlsQa8GS5QXMqjjYIhS4abEVVKIUwe0/l/UhrZdKaL/W5eWZNlbTeEIiOXTcsBQ==} |  | ||||||
|     peerDependencies: |  | ||||||
|       date-fns: ^3.0.0 || ^4.0.0 |  | ||||||
| 
 |  | ||||||
|   date-fns@3.6.0: |  | ||||||
|     resolution: {integrity: sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==} |  | ||||||
| 
 |  | ||||||
|   dayjs@1.11.12: |   dayjs@1.11.12: | ||||||
|     resolution: {integrity: sha512-Rt2g+nTbLlDWZTwwrIXjy9MeiZmSDI375FvZs72ngxx8PDC6YXOeR3q5LAuPzjZQxhiWdRKac7RKV+YyQYfYIg==} |     resolution: {integrity: sha512-Rt2g+nTbLlDWZTwwrIXjy9MeiZmSDI375FvZs72ngxx8PDC6YXOeR3q5LAuPzjZQxhiWdRKac7RKV+YyQYfYIg==} | ||||||
| 
 | 
 | ||||||
| @ -2745,15 +2691,6 @@ packages: | |||||||
|       supports-color: |       supports-color: | ||||||
|         optional: true |         optional: true | ||||||
| 
 | 
 | ||||||
|   debug@4.4.0: |  | ||||||
|     resolution: {integrity: sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==} |  | ||||||
|     engines: {node: '>=6.0'} |  | ||||||
|     peerDependencies: |  | ||||||
|       supports-color: '*' |  | ||||||
|     peerDependenciesMeta: |  | ||||||
|       supports-color: |  | ||||||
|         optional: true |  | ||||||
| 
 |  | ||||||
|   decimal.js@10.4.3: |   decimal.js@10.4.3: | ||||||
|     resolution: {integrity: sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==} |     resolution: {integrity: sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==} | ||||||
| 
 | 
 | ||||||
| @ -2962,9 +2899,6 @@ packages: | |||||||
|   eventemitter3@5.0.1: |   eventemitter3@5.0.1: | ||||||
|     resolution: {integrity: sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==} |     resolution: {integrity: sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==} | ||||||
| 
 | 
 | ||||||
|   evtd@0.2.4: |  | ||||||
|     resolution: {integrity: sha512-qaeGN5bx63s/AXgQo8gj6fBkxge+OoLddLniox5qtLAEY5HSnuSlISXVPxnSae1dWblvTh4/HoMIB+mbMsvZzw==} |  | ||||||
| 
 |  | ||||||
|   execa@5.1.1: |   execa@5.1.1: | ||||||
|     resolution: {integrity: sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==} |     resolution: {integrity: sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==} | ||||||
|     engines: {node: '>=10'} |     engines: {node: '>=10'} | ||||||
| @ -2988,9 +2922,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==} |     resolution: {integrity: sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==} | ||||||
|     engines: {node: '>= 0.10.0'} |     engines: {node: '>= 0.10.0'} | ||||||
| 
 | 
 | ||||||
|   exsolve@1.0.1: |  | ||||||
|     resolution: {integrity: sha512-Smf0iQtkQVJLaph8r/qS8C8SWfQkaq9Q/dFcD44MLbJj6DNhlWefVuaS21SjfqOsBbjVlKtbCj6L9ekXK6EZUg==} |  | ||||||
| 
 |  | ||||||
|   extend@3.0.2: |   extend@3.0.2: | ||||||
|     resolution: {integrity: sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==} |     resolution: {integrity: sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==} | ||||||
| 
 | 
 | ||||||
| @ -3022,8 +2953,8 @@ packages: | |||||||
|   fb-watchman@2.0.2: |   fb-watchman@2.0.2: | ||||||
|     resolution: {integrity: sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==} |     resolution: {integrity: sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==} | ||||||
| 
 | 
 | ||||||
|   fdir@6.4.3: |   fdir@6.3.0: | ||||||
|     resolution: {integrity: sha512-PMXmW2y1hDDfTSRc9gaXIuCCRpuoz3Kaz8cUelp3smouvfT632ozg2vrT6lJsHKKOF59YLbOGfAWGUcKEfRMQw==} |     resolution: {integrity: sha512-QOnuT+BOtivR77wYvCWHfGt9s4Pz1VIMbD463vegT5MLqNXy8rYFT/lPVEqf/bhYeT6qmqrNHhsX+rWwe3rOCQ==} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
|       picomatch: ^3 || ^4 |       picomatch: ^3 || ^4 | ||||||
|     peerDependenciesMeta: |     peerDependenciesMeta: | ||||||
| @ -3197,10 +3128,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} |     resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| 
 | 
 | ||||||
|   highlight.js@11.11.1: |  | ||||||
|     resolution: {integrity: sha512-Xwwo44whKBVCYoliBQwaPvtd/2tYFkRQtXDWj1nackaV2JPXx3L0+Jvd8/qCJ2p+ML0/XVkJ2q+Mr+UVdpJK5w==} |  | ||||||
|     engines: {node: '>=12.0.0'} |  | ||||||
| 
 |  | ||||||
|   hookable@5.5.3: |   hookable@5.5.3: | ||||||
|     resolution: {integrity: sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==} |     resolution: {integrity: sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==} | ||||||
| 
 | 
 | ||||||
| @ -3563,9 +3490,6 @@ packages: | |||||||
|   js-tokens@9.0.0: |   js-tokens@9.0.0: | ||||||
|     resolution: {integrity: sha512-WriZw1luRMlmV3LGJaR6QOJjWwgLUTf89OwT2lUOyjX2dJGBwgmIkbcz+7WFZjrZM635JOIR517++e/67CP9dQ==} |     resolution: {integrity: sha512-WriZw1luRMlmV3LGJaR6QOJjWwgLUTf89OwT2lUOyjX2dJGBwgmIkbcz+7WFZjrZM635JOIR517++e/67CP9dQ==} | ||||||
| 
 | 
 | ||||||
|   js-tokens@9.0.1: |  | ||||||
|     resolution: {integrity: sha512-mxa9E9ITFOt0ban3j6L5MpjwegGz6lBQmM1IJkWeBZGcMxto50+eWdjC/52xDbS2vy0k7vIMK0Fe2wfL9OQSpQ==} |  | ||||||
| 
 |  | ||||||
|   js-yaml@3.14.1: |   js-yaml@3.14.1: | ||||||
|     resolution: {integrity: sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==} |     resolution: {integrity: sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| @ -3683,10 +3607,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-ok6z3qlYyCDS4ZEU27HaU6x/xZa9Whf8jD4ptH5UZTQYZVYeb9bnZ3ojVhiJNLiXK1Hfc0GNbLXcmZ5plLDDBg==} |     resolution: {integrity: sha512-ok6z3qlYyCDS4ZEU27HaU6x/xZa9Whf8jD4ptH5UZTQYZVYeb9bnZ3ojVhiJNLiXK1Hfc0GNbLXcmZ5plLDDBg==} | ||||||
|     engines: {node: '>=14'} |     engines: {node: '>=14'} | ||||||
| 
 | 
 | ||||||
|   local-pkg@1.1.1: |  | ||||||
|     resolution: {integrity: sha512-WunYko2W1NcdfAFpuLUoucsgULmgDBRkdxHxWQ7mK0cQqwPiy8E1enjuRBrhLtZkB5iScJ1XIPdhVEFK8aOLSg==} |  | ||||||
|     engines: {node: '>=14'} |  | ||||||
| 
 |  | ||||||
|   localstorage-polyfill@1.0.1: |   localstorage-polyfill@1.0.1: | ||||||
|     resolution: {integrity: sha512-m4iHVZxFH5734oQcPKU08025gIz2+4bjWR9lulP8ZYxEJR0BpA0w32oJmkzh8y3UI9ci7xCBehQDc3oA1X+VHw==} |     resolution: {integrity: sha512-m4iHVZxFH5734oQcPKU08025gIz2+4bjWR9lulP8ZYxEJR0BpA0w32oJmkzh8y3UI9ci7xCBehQDc3oA1X+VHw==} | ||||||
|     engines: {node: '>=6'} |     engines: {node: '>=6'} | ||||||
| @ -3723,8 +3643,8 @@ packages: | |||||||
|   magic-string@0.30.11: |   magic-string@0.30.11: | ||||||
|     resolution: {integrity: sha512-+Wri9p0QHMy+545hKww7YAu5NyzF8iomPL/RQazugQ9+Ez4Ic3mERMd8ZTX5rfK944j+560ZJi8iAwgak1Ac7A==} |     resolution: {integrity: sha512-+Wri9p0QHMy+545hKww7YAu5NyzF8iomPL/RQazugQ9+Ez4Ic3mERMd8ZTX5rfK944j+560ZJi8iAwgak1Ac7A==} | ||||||
| 
 | 
 | ||||||
|   magic-string@0.30.17: |   magic-string@0.30.13: | ||||||
|     resolution: {integrity: sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==} |     resolution: {integrity: sha512-8rYBO+MsWkgjDSOvLomYnzhdwEG51olQ4zL5KXnNJWV5MNmrb4rTZdrtkhxjnD/QyZUqR/Z/XDsUs/4ej2nx0g==} | ||||||
| 
 | 
 | ||||||
|   make-dir@2.1.0: |   make-dir@2.1.0: | ||||||
|     resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} |     resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} | ||||||
| @ -3829,12 +3749,12 @@ packages: | |||||||
|     engines: {node: '>=10'} |     engines: {node: '>=10'} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| 
 | 
 | ||||||
|  |   mlly@1.7.1: | ||||||
|  |     resolution: {integrity: sha512-rrVRZRELyQzrIUAVMHxP97kv+G786pHmOKzuFII8zDYahFBS7qnHh2AlYSl1GAHhaMPCz6/oHjVMcfFYgFYHgA==} | ||||||
|  | 
 | ||||||
|   mlly@1.7.3: |   mlly@1.7.3: | ||||||
|     resolution: {integrity: sha512-xUsx5n/mN0uQf4V548PKQ+YShA4/IW0KI1dZhrNrPCLG+xizETbHTkOa1f8/xut9JRPp8kQuMnz0oqwkTiLo/A==} |     resolution: {integrity: sha512-xUsx5n/mN0uQf4V548PKQ+YShA4/IW0KI1dZhrNrPCLG+xizETbHTkOa1f8/xut9JRPp8kQuMnz0oqwkTiLo/A==} | ||||||
| 
 | 
 | ||||||
|   mlly@1.7.4: |  | ||||||
|     resolution: {integrity: sha512-qmdSIPC4bDJXgZTCR7XosJiNKySV7O215tsPtDN9iEO/7q/76b/ijtgRu/+epFXSJhijtTCCGp3DWS549P3xKw==} |  | ||||||
| 
 |  | ||||||
|   module-alias@2.2.3: |   module-alias@2.2.3: | ||||||
|     resolution: {integrity: sha512-23g5BFj4zdQL/b6tor7Ji+QY4pEfNH784BMslY9Qb0UnJWRAt+lQGLYmRaM0KDBwIG23ffEBELhZDP2rhi9f/Q==} |     resolution: {integrity: sha512-23g5BFj4zdQL/b6tor7Ji+QY4pEfNH784BMslY9Qb0UnJWRAt+lQGLYmRaM0KDBwIG23ffEBELhZDP2rhi9f/Q==} | ||||||
| 
 | 
 | ||||||
| @ -3861,11 +3781,6 @@ packages: | |||||||
|   mutation-observer@1.0.3: |   mutation-observer@1.0.3: | ||||||
|     resolution: {integrity: sha512-M/O/4rF2h776hV7qGMZUH3utZLO/jK7p8rnNgGkjKUw8zCGjRQPxB8z6+5l8+VjRUQ3dNYu4vjqXYLr+U8ZVNA==} |     resolution: {integrity: sha512-M/O/4rF2h776hV7qGMZUH3utZLO/jK7p8rnNgGkjKUw8zCGjRQPxB8z6+5l8+VjRUQ3dNYu4vjqXYLr+U8ZVNA==} | ||||||
| 
 | 
 | ||||||
|   naive-ui@2.41.0: |  | ||||||
|     resolution: {integrity: sha512-KnmLg+xPLwXV8QVR7ZZ69eCjvel7R5vru8+eFe4VoAJHEgqAJgVph6Zno9K2IVQRpSF3GBGea3tjavslOR4FAA==} |  | ||||||
|     peerDependencies: |  | ||||||
|       vue: ^3.0.0 |  | ||||||
| 
 |  | ||||||
|   nanoid@3.3.7: |   nanoid@3.3.7: | ||||||
|     resolution: {integrity: sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==} |     resolution: {integrity: sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==} | ||||||
|     engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} |     engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} | ||||||
| @ -4057,9 +3972,6 @@ packages: | |||||||
|   pathe@1.1.2: |   pathe@1.1.2: | ||||||
|     resolution: {integrity: sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==} |     resolution: {integrity: sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==} | ||||||
| 
 | 
 | ||||||
|   pathe@2.0.3: |  | ||||||
|     resolution: {integrity: sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w==} |  | ||||||
| 
 |  | ||||||
|   perfect-debounce@1.0.0: |   perfect-debounce@1.0.0: | ||||||
|     resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==} |     resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==} | ||||||
| 
 | 
 | ||||||
| @ -4139,12 +4051,6 @@ packages: | |||||||
|   pkg-types@1.2.1: |   pkg-types@1.2.1: | ||||||
|     resolution: {integrity: sha512-sQoqa8alT3nHjGuTjuKgOnvjo4cljkufdtLMnO2LBP/wRwuDlo1tkaEdMxCRhyGRPacv/ztlZgDPm2b7FAmEvw==} |     resolution: {integrity: sha512-sQoqa8alT3nHjGuTjuKgOnvjo4cljkufdtLMnO2LBP/wRwuDlo1tkaEdMxCRhyGRPacv/ztlZgDPm2b7FAmEvw==} | ||||||
| 
 | 
 | ||||||
|   pkg-types@1.3.1: |  | ||||||
|     resolution: {integrity: sha512-/Jm5M4RvtBFVkKWRu2BLUTNP8/M2a+UwuAX+ae4770q1qVGtfjG+WTCupoZixokjmHiry8uI+dlY8KXYV5HVVQ==} |  | ||||||
| 
 |  | ||||||
|   pkg-types@2.1.0: |  | ||||||
|     resolution: {integrity: sha512-wmJwA+8ihJixSoHKxZJRBQG1oY8Yr9pGLzRmSsNms0iNWyHHAlZCa7mmKiFR10YPZuz/2k169JiS/inOjBCZ2A==} |  | ||||||
| 
 |  | ||||||
|   pngjs@3.4.0: |   pngjs@3.4.0: | ||||||
|     resolution: {integrity: sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w==} |     resolution: {integrity: sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w==} | ||||||
|     engines: {node: '>=4.0.0'} |     engines: {node: '>=4.0.0'} | ||||||
| @ -4252,9 +4158,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==} |     resolution: {integrity: sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==} | ||||||
|     engines: {node: '>=0.6'} |     engines: {node: '>=0.6'} | ||||||
| 
 | 
 | ||||||
|   quansync@0.2.8: |  | ||||||
|     resolution: {integrity: sha512-4+saucphJMazjt7iOM27mbFCk+D9dd/zmgMDCzRZ8MEoBfYp7lAvoN38et/phRQF6wOPMy/OROBGgoWeSKyluA==} |  | ||||||
| 
 |  | ||||||
|   querystringify@2.2.0: |   querystringify@2.2.0: | ||||||
|     resolution: {integrity: sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==} |     resolution: {integrity: sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==} | ||||||
| 
 | 
 | ||||||
| @ -4416,9 +4319,6 @@ packages: | |||||||
|   scule@1.3.0: |   scule@1.3.0: | ||||||
|     resolution: {integrity: sha512-6FtHJEvt+pVMIB9IBY+IcCJ6Z5f1iQnytgyfKMhDKgmzYG+TeH/wx1y3l27rshSbLiSanrR9ffZDrEsmjlQF2g==} |     resolution: {integrity: sha512-6FtHJEvt+pVMIB9IBY+IcCJ6Z5f1iQnytgyfKMhDKgmzYG+TeH/wx1y3l27rshSbLiSanrR9ffZDrEsmjlQF2g==} | ||||||
| 
 | 
 | ||||||
|   seemly@0.3.10: |  | ||||||
|     resolution: {integrity: sha512-2+SMxtG1PcsL0uyhkumlOU6Qo9TAQ/WyH7tthnPIOQB05/12jz9naq6GZ6iZ6ApVsO3rr2gsnTf3++OV63kE1Q==} |  | ||||||
| 
 |  | ||||||
|   semver@5.7.2: |   semver@5.7.2: | ||||||
|     resolution: {integrity: sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==} |     resolution: {integrity: sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| @ -4586,9 +4486,6 @@ packages: | |||||||
|   strip-literal@2.1.0: |   strip-literal@2.1.0: | ||||||
|     resolution: {integrity: sha512-Op+UycaUt/8FbN/Z2TWPBLge3jWrP3xj10f3fnYxf052bKuS3EKs1ZQcVGjnEMdsNVAM+plXRdmjrZ/KgG3Skw==} |     resolution: {integrity: sha512-Op+UycaUt/8FbN/Z2TWPBLge3jWrP3xj10f3fnYxf052bKuS3EKs1ZQcVGjnEMdsNVAM+plXRdmjrZ/KgG3Skw==} | ||||||
| 
 | 
 | ||||||
|   strip-literal@3.0.0: |  | ||||||
|     resolution: {integrity: sha512-TcccoMhJOM3OebGhSBEmp3UZ2SfDMZUEBdRA/9ynfLi8yYajyWX3JiXArcJt4Umh4vISpspkQIY8ZZoCqjbviA==} |  | ||||||
| 
 |  | ||||||
|   supports-color@5.5.0: |   supports-color@5.5.0: | ||||||
|     resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} |     resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} | ||||||
|     engines: {node: '>=4'} |     engines: {node: '>=4'} | ||||||
| @ -4651,8 +4548,8 @@ packages: | |||||||
|   tinyexec@0.3.0: |   tinyexec@0.3.0: | ||||||
|     resolution: {integrity: sha512-tVGE0mVJPGb0chKhqmsoosjsS+qUnJVGJpZgsHYQcGoPlG3B51R3PouqTgEGH2Dc9jjFyOqOpix6ZHNMXp1FZg==} |     resolution: {integrity: sha512-tVGE0mVJPGb0chKhqmsoosjsS+qUnJVGJpZgsHYQcGoPlG3B51R3PouqTgEGH2Dc9jjFyOqOpix6ZHNMXp1FZg==} | ||||||
| 
 | 
 | ||||||
|   tinyglobby@0.2.12: |   tinyglobby@0.2.5: | ||||||
|     resolution: {integrity: sha512-qkf4trmKSIiMTs/E63cxH+ojC2unam7rJ0WrauAzpT3ECNTxGRMlaXxVbfxMUC/w0LaYk6jQ4y/nGR9uBO3tww==} |     resolution: {integrity: sha512-Dlqgt6h0QkoHttG53/WGADNh9QhcjCAIZMTERAVhdpmIBEejSuLI9ZmGKWzB7tweBjlk30+s/ofi4SLmBeTYhw==} | ||||||
|     engines: {node: '>=12.0.0'} |     engines: {node: '>=12.0.0'} | ||||||
| 
 | 
 | ||||||
|   tmpl@1.0.5: |   tmpl@1.0.5: | ||||||
| @ -4682,9 +4579,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==} |     resolution: {integrity: sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==} | ||||||
|     engines: {node: '>=8'} |     engines: {node: '>=8'} | ||||||
| 
 | 
 | ||||||
|   treemate@0.3.11: |  | ||||||
|     resolution: {integrity: sha512-M8RGFoKtZ8dF+iwJfAJTOH/SM4KluKOKRJpjCMhI8bG3qB74zrFoArKZ62ll0Fr3mqkMJiQOmWYkdYgDeITYQg==} |  | ||||||
| 
 |  | ||||||
|   tslib@2.8.1: |   tslib@2.8.1: | ||||||
|     resolution: {integrity: sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==} |     resolution: {integrity: sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==} | ||||||
| 
 | 
 | ||||||
| @ -4757,10 +4651,6 @@ packages: | |||||||
|   unimport@3.9.1: |   unimport@3.9.1: | ||||||
|     resolution: {integrity: sha512-4gtacoNH6YPx2Aa5Xfyrf8pU2RdXjWUACb/eF7bH1AcZtqs+6ijbNB0M3BPENbtVjnCcg8tw9UJ1jQGbCzKA6g==} |     resolution: {integrity: sha512-4gtacoNH6YPx2Aa5Xfyrf8pU2RdXjWUACb/eF7bH1AcZtqs+6ijbNB0M3BPENbtVjnCcg8tw9UJ1jQGbCzKA6g==} | ||||||
| 
 | 
 | ||||||
|   unimport@4.1.2: |  | ||||||
|     resolution: {integrity: sha512-oVUL7PSlyVV3QRhsdcyYEMaDX8HJyS/CnUonEJTYA3//bWO+o/4gG8F7auGWWWkrrxBQBYOO8DKe+C53ktpRXw==} |  | ||||||
|     engines: {node: '>=18.12.0'} |  | ||||||
| 
 |  | ||||||
|   universalify@0.2.0: |   universalify@0.2.0: | ||||||
|     resolution: {integrity: sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==} |     resolution: {integrity: sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==} | ||||||
|     engines: {node: '>= 4.0.0'} |     engines: {node: '>= 4.0.0'} | ||||||
| @ -4806,35 +4696,6 @@ packages: | |||||||
|       '@vueuse/core': |       '@vueuse/core': | ||||||
|         optional: true |         optional: true | ||||||
| 
 | 
 | ||||||
|   unplugin-auto-import@19.1.1: |  | ||||||
|     resolution: {integrity: sha512-sCGZZrSR1Bc8RfN8Q0RUDxXtC20rdAt7UB4lDyq8MNtKVHiXXh+5af6Nz4JRp9Q+7HjnbgQfQox0TkEymjdUAQ==} |  | ||||||
|     engines: {node: '>=14'} |  | ||||||
|     peerDependencies: |  | ||||||
|       '@nuxt/kit': ^3.2.2 |  | ||||||
|       '@vueuse/core': '*' |  | ||||||
|     peerDependenciesMeta: |  | ||||||
|       '@nuxt/kit': |  | ||||||
|         optional: true |  | ||||||
|       '@vueuse/core': |  | ||||||
|         optional: true |  | ||||||
| 
 |  | ||||||
|   unplugin-utils@0.2.4: |  | ||||||
|     resolution: {integrity: sha512-8U/MtpkPkkk3Atewj1+RcKIjb5WBimZ/WSLhhR3w6SsIj8XJuKTacSP8g+2JhfSGw0Cb125Y+2zA/IzJZDVbhA==} |  | ||||||
|     engines: {node: '>=18.12.0'} |  | ||||||
| 
 |  | ||||||
|   unplugin-vue-components@28.4.1: |  | ||||||
|     resolution: {integrity: sha512-niGSc0vJD9ueAnsqcfAldmtpkppZ09B6p2G1dL7X5S8KPdgbk1P+txPwaaDCe7N+eZh2VG1aAypLXkuJs3OSUg==} |  | ||||||
|     engines: {node: '>=14'} |  | ||||||
|     peerDependencies: |  | ||||||
|       '@babel/parser': ^7.15.8 |  | ||||||
|       '@nuxt/kit': ^3.2.2 |  | ||||||
|       vue: 2 || 3 |  | ||||||
|     peerDependenciesMeta: |  | ||||||
|       '@babel/parser': |  | ||||||
|         optional: true |  | ||||||
|       '@nuxt/kit': |  | ||||||
|         optional: true |  | ||||||
| 
 |  | ||||||
|   unplugin@1.12.0: |   unplugin@1.12.0: | ||||||
|     resolution: {integrity: sha512-KeczzHl2sATPQUx1gzo+EnUkmN4VmGBYRRVOZSGvGITE9rGHRDGqft6ONceP3vgXcyJ2XjX5axG5jMWUwNCYLw==} |     resolution: {integrity: sha512-KeczzHl2sATPQUx1gzo+EnUkmN4VmGBYRRVOZSGvGITE9rGHRDGqft6ONceP3vgXcyJ2XjX5axG5jMWUwNCYLw==} | ||||||
|     engines: {node: '>=14.0.0'} |     engines: {node: '>=14.0.0'} | ||||||
| @ -4843,10 +4704,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-5liCNPuJW8dqh3+DM6uNM2EI3MLLpCKp/KY+9pB5M2S2SR2qvvDHhKgBOaTWEbZTAws3CXfB0rKTIolWKL05VQ==} |     resolution: {integrity: sha512-5liCNPuJW8dqh3+DM6uNM2EI3MLLpCKp/KY+9pB5M2S2SR2qvvDHhKgBOaTWEbZTAws3CXfB0rKTIolWKL05VQ==} | ||||||
|     engines: {node: '>=14.0.0'} |     engines: {node: '>=14.0.0'} | ||||||
| 
 | 
 | ||||||
|   unplugin@2.2.0: |  | ||||||
|     resolution: {integrity: sha512-m1ekpSwuOT5hxkJeZGRxO7gXbXT3gF26NjQ7GdVHoLoF8/nopLcd/QfPigpCy7i51oFHiRJg/CyHhj4vs2+KGw==} |  | ||||||
|     engines: {node: '>=18.12.0'} |  | ||||||
| 
 |  | ||||||
|   unquote@1.1.1: |   unquote@1.1.1: | ||||||
|     resolution: {integrity: sha512-vRCqFv6UhXpWxZPyGDh/F3ZpNv8/qo7w6iufLpQg9aKnQ71qM4B5KiI7Mia9COcjEhrO9LueHpMYjYzsWH3OIg==} |     resolution: {integrity: sha512-vRCqFv6UhXpWxZPyGDh/F3ZpNv8/qo7w6iufLpQg9aKnQ71qM4B5KiI7Mia9COcjEhrO9LueHpMYjYzsWH3OIg==} | ||||||
| 
 | 
 | ||||||
| @ -4890,11 +4747,6 @@ packages: | |||||||
|   vconsole@3.15.1: |   vconsole@3.15.1: | ||||||
|     resolution: {integrity: sha512-KH8XLdrq9T5YHJO/ixrjivHfmF2PC2CdVoK6RWZB4yftMykYIaXY1mxZYAic70vADM54kpMQF+dYmvl5NRNy1g==} |     resolution: {integrity: sha512-KH8XLdrq9T5YHJO/ixrjivHfmF2PC2CdVoK6RWZB4yftMykYIaXY1mxZYAic70vADM54kpMQF+dYmvl5NRNy1g==} | ||||||
| 
 | 
 | ||||||
|   vdirs@0.1.8: |  | ||||||
|     resolution: {integrity: sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw==} |  | ||||||
|     peerDependencies: |  | ||||||
|       vue: ^3.0.11 |  | ||||||
| 
 |  | ||||||
|   vite@5.3.5: |   vite@5.3.5: | ||||||
|     resolution: {integrity: sha512-MdjglKR6AQXQb9JGiS7Rc2wC6uMjcm7Go/NHNO63EwiJXfuk9PgqiP/n5IDJCziMkfw9n4Ubp7lttNwz+8ZVKA==} |     resolution: {integrity: sha512-MdjglKR6AQXQb9JGiS7Rc2wC6uMjcm7Go/NHNO63EwiJXfuk9PgqiP/n5IDJCziMkfw9n4Ubp7lttNwz+8ZVKA==} | ||||||
|     engines: {node: ^18.0.0 || >=20.0.0} |     engines: {node: ^18.0.0 || >=20.0.0} | ||||||
| @ -4923,11 +4775,6 @@ packages: | |||||||
|       terser: |       terser: | ||||||
|         optional: true |         optional: true | ||||||
| 
 | 
 | ||||||
|   vooks@0.2.12: |  | ||||||
|     resolution: {integrity: sha512-iox0I3RZzxtKlcgYaStQYKEzWWGAduMmq+jS7OrNdQo1FgGfPMubGL3uGHOU9n97NIvfFDBGnpSvkWyb/NSn/Q==} |  | ||||||
|     peerDependencies: |  | ||||||
|       vue: ^3.0.0 |  | ||||||
| 
 |  | ||||||
|   vscode-json-languageservice@4.1.8: |   vscode-json-languageservice@4.1.8: | ||||||
|     resolution: {integrity: sha512-0vSpg6Xd9hfV+eZAaYN63xVVMOTmJ4GgHxXnkLCh+9RsQBkWKIghzLhW2B9ebfG+LQQg8uLtsQ2aUKjTgE+QOg==} |     resolution: {integrity: sha512-0vSpg6Xd9hfV+eZAaYN63xVVMOTmJ4GgHxXnkLCh+9RsQBkWKIghzLhW2B9ebfG+LQQg8uLtsQ2aUKjTgE+QOg==} | ||||||
|     engines: {npm: '>=7.0.0'} |     engines: {npm: '>=7.0.0'} | ||||||
| @ -5000,11 +4847,6 @@ packages: | |||||||
|       typescript: |       typescript: | ||||||
|         optional: true |         optional: true | ||||||
| 
 | 
 | ||||||
|   vueuc@0.4.64: |  | ||||||
|     resolution: {integrity: sha512-wlJQj7fIwKK2pOEoOq4Aro8JdPOGpX8aWQhV8YkTW9OgWD2uj2O8ANzvSsIGjx7LTOc7QbS7sXdxHi6XvRnHPA==} |  | ||||||
|     peerDependencies: |  | ||||||
|       vue: ^3.0.11 |  | ||||||
| 
 |  | ||||||
|   w3c-hr-time@1.0.2: |   w3c-hr-time@1.0.2: | ||||||
|     resolution: {integrity: sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==} |     resolution: {integrity: sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==} | ||||||
|     deprecated: Use your platform's native performance.now() and performance.timeOrigin. |     deprecated: Use your platform's native performance.now() and performance.timeOrigin. | ||||||
| @ -6140,14 +5982,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   '@bcoe/v8-coverage@0.2.3': {} |   '@bcoe/v8-coverage@0.2.3': {} | ||||||
| 
 | 
 | ||||||
|   '@css-render/plugin-bem@0.15.14(css-render@0.15.14)': |  | ||||||
|     dependencies: |  | ||||||
|       css-render: 0.15.14 |  | ||||||
| 
 |  | ||||||
|   '@css-render/vue3-ssr@0.15.14(vue@3.4.35(typescript@5.5.4))': |  | ||||||
|     dependencies: |  | ||||||
|       vue: 3.4.35(typescript@5.5.4) |  | ||||||
| 
 |  | ||||||
|   '@dcloudio/types@3.4.12': {} |   '@dcloudio/types@3.4.12': {} | ||||||
| 
 | 
 | ||||||
|   '@dcloudio/uni-app-plus@3.0.0-alpha-4000020240111001(@nuxt/kit@3.14.1592(rollup@4.19.2))(@vueuse/core@9.13.0(vue@3.4.35(typescript@5.5.4)))(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35(typescript@5.5.4))': |   '@dcloudio/uni-app-plus@3.0.0-alpha-4000020240111001(@nuxt/kit@3.14.1592(rollup@4.19.2))(@vueuse/core@9.13.0(vue@3.4.35(typescript@5.5.4)))(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35(typescript@5.5.4))': | ||||||
| @ -6671,8 +6505,6 @@ snapshots: | |||||||
|       - ts-node |       - ts-node | ||||||
|       - vue |       - vue | ||||||
| 
 | 
 | ||||||
|   '@emotion/hash@0.8.0': {} |  | ||||||
| 
 |  | ||||||
|   '@esbuild/aix-ppc64@0.21.5': |   '@esbuild/aix-ppc64@0.21.5': | ||||||
|     optional: true |     optional: true | ||||||
| 
 | 
 | ||||||
| @ -6894,7 +6726,7 @@ snapshots: | |||||||
|       debug: 4.3.6 |       debug: 4.3.6 | ||||||
|       kolorist: 1.8.0 |       kolorist: 1.8.0 | ||||||
|       local-pkg: 0.5.0 |       local-pkg: 0.5.0 | ||||||
|       mlly: 1.7.3 |       mlly: 1.7.1 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
| @ -7404,8 +7236,6 @@ snapshots: | |||||||
|       '@jridgewell/resolve-uri': 3.1.2 |       '@jridgewell/resolve-uri': 3.1.2 | ||||||
|       '@jridgewell/sourcemap-codec': 1.5.0 |       '@jridgewell/sourcemap-codec': 1.5.0 | ||||||
| 
 | 
 | ||||||
|   '@juggle/resize-observer@3.4.0': {} |  | ||||||
| 
 |  | ||||||
|   '@nodelib/fs.scandir@2.1.5': |   '@nodelib/fs.scandir@2.1.5': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@nodelib/fs.stat': 2.0.5 |       '@nodelib/fs.stat': 2.0.5 | ||||||
| @ -7453,7 +7283,7 @@ snapshots: | |||||||
|       defu: 6.1.4 |       defu: 6.1.4 | ||||||
|       hookable: 5.5.3 |       hookable: 5.5.3 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.3.1 |       pkg-types: 1.2.1 | ||||||
|       scule: 1.3.0 |       scule: 1.3.0 | ||||||
|       std-env: 3.8.0 |       std-env: 3.8.0 | ||||||
|       ufo: 1.5.4 |       ufo: 1.5.4 | ||||||
| @ -7593,14 +7423,6 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       '@types/istanbul-lib-report': 3.0.3 |       '@types/istanbul-lib-report': 3.0.3 | ||||||
| 
 | 
 | ||||||
|   '@types/katex@0.16.7': {} |  | ||||||
| 
 |  | ||||||
|   '@types/lodash-es@4.17.12': |  | ||||||
|     dependencies: |  | ||||||
|       '@types/lodash': 4.17.16 |  | ||||||
| 
 |  | ||||||
|   '@types/lodash@4.17.16': {} |  | ||||||
| 
 |  | ||||||
|   '@types/node@20.14.14': |   '@types/node@20.14.14': | ||||||
|     dependencies: |     dependencies: | ||||||
|       undici-types: 5.26.5 |       undici-types: 5.26.5 | ||||||
| @ -7650,12 +7472,12 @@ snapshots: | |||||||
|       - supports-color |       - supports-color | ||||||
|       - ts-node |       - ts-node | ||||||
| 
 | 
 | ||||||
|   '@uni-helper/unocss-preset-uni@0.2.9(@unocss/preset-mini@0.62.3)(@unocss/rule-utils@0.62.3)(@unocss/vite@0.62.3(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))(unocss-applet@0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))))(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))': |   '@uni-helper/unocss-preset-uni@0.2.9(@unocss/preset-mini@0.62.3)(@unocss/rule-utils@0.62.3)(@unocss/vite@0.62.3(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))(unocss-applet@0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))))(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@uni-helper/uni-env': 0.1.4 |       '@uni-helper/uni-env': 0.1.4 | ||||||
|       '@unocss/rule-utils': 0.62.3 |       '@unocss/rule-utils': 0.62.3 | ||||||
|       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) |       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) | ||||||
|       unocss-applet: 0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) |       unocss-applet: 0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) | ||||||
|     optionalDependencies: |     optionalDependencies: | ||||||
|       '@unocss/preset-mini': 0.62.3 |       '@unocss/preset-mini': 0.62.3 | ||||||
|       '@unocss/vite': 0.62.3(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) |       '@unocss/vite': 0.62.3(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) | ||||||
| @ -7684,11 +7506,11 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) |       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) | ||||||
| 
 | 
 | ||||||
|   '@unocss-applet/transformer-attributify@0.8.2(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))': |   '@unocss-applet/transformer-attributify@0.8.2(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)))': | ||||||
|     dependencies: |     dependencies: | ||||||
|       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) |       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) | ||||||
|     optionalDependencies: |     optionalDependencies: | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.13 | ||||||
| 
 | 
 | ||||||
|   '@unocss/astro@0.58.9(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))': |   '@unocss/astro@0.58.9(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))': | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -7841,12 +7663,12 @@ snapshots: | |||||||
|   '@unocss/rule-utils@0.58.9': |   '@unocss/rule-utils@0.58.9': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@unocss/core': 0.58.9 |       '@unocss/core': 0.58.9 | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.11 | ||||||
| 
 | 
 | ||||||
|   '@unocss/rule-utils@0.62.3': |   '@unocss/rule-utils@0.62.3': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@unocss/core': 0.62.3 |       '@unocss/core': 0.62.3 | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.13 | ||||||
| 
 | 
 | ||||||
|   '@unocss/scope@0.58.9': {} |   '@unocss/scope@0.58.9': {} | ||||||
| 
 | 
 | ||||||
| @ -7913,8 +7735,8 @@ snapshots: | |||||||
|       '@unocss/scope': 0.62.3 |       '@unocss/scope': 0.62.3 | ||||||
|       '@unocss/transformer-directives': 0.62.3 |       '@unocss/transformer-directives': 0.62.3 | ||||||
|       chokidar: 3.6.0 |       chokidar: 3.6.0 | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.13 | ||||||
|       tinyglobby: 0.2.12 |       tinyglobby: 0.2.5 | ||||||
|       vite: 5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3) |       vite: 5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3) | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - rollup |       - rollup | ||||||
| @ -8161,7 +7983,7 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   agent-base@6.0.2: |   agent-base@6.0.2: | ||||||
|     dependencies: |     dependencies: | ||||||
|       debug: 4.4.0 |       debug: 4.3.6 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
| @ -8209,8 +8031,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   array-flatten@1.1.1: {} |   array-flatten@1.1.1: {} | ||||||
| 
 | 
 | ||||||
|   async-validator@4.2.5: {} |  | ||||||
| 
 |  | ||||||
|   asynckit@0.4.0: {} |   asynckit@0.4.0: {} | ||||||
| 
 | 
 | ||||||
|   autoprefixer@10.4.19(postcss@8.4.40): |   autoprefixer@10.4.19(postcss@8.4.40): | ||||||
| @ -8395,11 +8215,11 @@ snapshots: | |||||||
|       dotenv: 16.4.5 |       dotenv: 16.4.5 | ||||||
|       giget: 1.2.3 |       giget: 1.2.3 | ||||||
|       jiti: 2.4.0 |       jiti: 2.4.0 | ||||||
|       mlly: 1.7.4 |       mlly: 1.7.3 | ||||||
|       ohash: 1.1.4 |       ohash: 1.1.4 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       perfect-debounce: 1.0.0 |       perfect-debounce: 1.0.0 | ||||||
|       pkg-types: 1.3.1 |       pkg-types: 1.2.1 | ||||||
|       rc9: 2.1.2 |       rc9: 2.1.2 | ||||||
| 
 | 
 | ||||||
|   cac@6.7.14: {} |   cac@6.7.14: {} | ||||||
| @ -8526,8 +8346,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   confbox@0.1.8: {} |   confbox@0.1.8: {} | ||||||
| 
 | 
 | ||||||
|   confbox@0.2.1: {} |  | ||||||
| 
 |  | ||||||
|   consola@3.2.3: {} |   consola@3.2.3: {} | ||||||
| 
 | 
 | ||||||
|   content-disposition@0.5.4: |   content-disposition@0.5.4: | ||||||
| @ -8583,11 +8401,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   css-list-helpers@2.0.0: {} |   css-list-helpers@2.0.0: {} | ||||||
| 
 | 
 | ||||||
|   css-render@0.15.14: |  | ||||||
|     dependencies: |  | ||||||
|       '@emotion/hash': 0.8.0 |  | ||||||
|       csstype: 3.0.11 |  | ||||||
| 
 |  | ||||||
|   css-system-font-keywords@1.0.0: {} |   css-system-font-keywords@1.0.0: {} | ||||||
| 
 | 
 | ||||||
|   css-tree@2.3.1: |   css-tree@2.3.1: | ||||||
| @ -8605,8 +8418,6 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       cssom: 0.3.8 |       cssom: 0.3.8 | ||||||
| 
 | 
 | ||||||
|   csstype@3.0.11: {} |  | ||||||
| 
 |  | ||||||
|   csstype@3.1.3: {} |   csstype@3.1.3: {} | ||||||
| 
 | 
 | ||||||
|   data-urls@2.0.0: |   data-urls@2.0.0: | ||||||
| @ -8615,12 +8426,6 @@ snapshots: | |||||||
|       whatwg-mimetype: 2.3.0 |       whatwg-mimetype: 2.3.0 | ||||||
|       whatwg-url: 8.7.0 |       whatwg-url: 8.7.0 | ||||||
| 
 | 
 | ||||||
|   date-fns-tz@3.2.0(date-fns@3.6.0): |  | ||||||
|     dependencies: |  | ||||||
|       date-fns: 3.6.0 |  | ||||||
| 
 |  | ||||||
|   date-fns@3.6.0: {} |  | ||||||
| 
 |  | ||||||
|   dayjs@1.11.12: {} |   dayjs@1.11.12: {} | ||||||
| 
 | 
 | ||||||
|   de-indent@1.0.2: {} |   de-indent@1.0.2: {} | ||||||
| @ -8633,10 +8438,6 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       ms: 2.1.2 |       ms: 2.1.2 | ||||||
| 
 | 
 | ||||||
|   debug@4.4.0: |  | ||||||
|     dependencies: |  | ||||||
|       ms: 2.1.3 |  | ||||||
| 
 |  | ||||||
|   decimal.js@10.4.3: {} |   decimal.js@10.4.3: {} | ||||||
| 
 | 
 | ||||||
|   dedent@0.7.0: {} |   dedent@0.7.0: {} | ||||||
| @ -8874,8 +8675,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   eventemitter3@5.0.1: {} |   eventemitter3@5.0.1: {} | ||||||
| 
 | 
 | ||||||
|   evtd@0.2.4: {} |  | ||||||
| 
 |  | ||||||
|   execa@5.1.1: |   execa@5.1.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       cross-spawn: 7.0.3 |       cross-spawn: 7.0.3 | ||||||
| @ -8947,8 +8746,6 @@ snapshots: | |||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
|   exsolve@1.0.1: {} |  | ||||||
| 
 |  | ||||||
|   extend@3.0.2: {} |   extend@3.0.2: {} | ||||||
| 
 | 
 | ||||||
|   fast-deep-equal@3.1.3: {} |   fast-deep-equal@3.1.3: {} | ||||||
| @ -8979,9 +8776,10 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       bser: 2.1.1 |       bser: 2.1.1 | ||||||
| 
 | 
 | ||||||
|   fdir@6.4.3(picomatch@4.0.2): |   fdir@6.3.0(picomatch@4.0.2): | ||||||
|     optionalDependencies: |     optionalDependencies: | ||||||
|       picomatch: 4.0.2 |       picomatch: 4.0.2 | ||||||
|  |     optional: true | ||||||
| 
 | 
 | ||||||
|   file-type@9.0.0: {} |   file-type@9.0.0: {} | ||||||
| 
 | 
 | ||||||
| @ -9148,8 +8946,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   he@1.2.0: {} |   he@1.2.0: {} | ||||||
| 
 | 
 | ||||||
|   highlight.js@11.11.1: {} |  | ||||||
| 
 |  | ||||||
|   hookable@5.5.3: {} |   hookable@5.5.3: {} | ||||||
| 
 | 
 | ||||||
|   html-encoding-sniffer@2.0.1: |   html-encoding-sniffer@2.0.1: | ||||||
| @ -9172,14 +8968,14 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       '@tootallnate/once': 1.1.2 |       '@tootallnate/once': 1.1.2 | ||||||
|       agent-base: 6.0.2 |       agent-base: 6.0.2 | ||||||
|       debug: 4.4.0 |       debug: 4.3.6 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
|   https-proxy-agent@5.0.1: |   https-proxy-agent@5.0.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       agent-base: 6.0.2 |       agent-base: 6.0.2 | ||||||
|       debug: 4.4.0 |       debug: 4.3.6 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
| @ -9221,12 +9017,12 @@ snapshots: | |||||||
|   importx@0.4.3: |   importx@0.4.3: | ||||||
|     dependencies: |     dependencies: | ||||||
|       bundle-require: 5.0.0(esbuild@0.23.1) |       bundle-require: 5.0.0(esbuild@0.23.1) | ||||||
|       debug: 4.4.0 |       debug: 4.3.6 | ||||||
|       esbuild: 0.23.1 |       esbuild: 0.23.1 | ||||||
|       jiti: 2.0.0-beta.2 |       jiti: 2.0.0-beta.2 | ||||||
|       jiti-v1: jiti@1.21.6 |       jiti-v1: jiti@1.21.6 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.3.1 |       pkg-types: 1.2.1 | ||||||
|       tsx: 4.17.0 |       tsx: 4.17.0 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| @ -9327,7 +9123,7 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   istanbul-lib-source-maps@4.0.1: |   istanbul-lib-source-maps@4.0.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       debug: 4.4.0 |       debug: 4.3.6 | ||||||
|       istanbul-lib-coverage: 3.2.2 |       istanbul-lib-coverage: 3.2.2 | ||||||
|       source-map: 0.6.1 |       source-map: 0.6.1 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
| @ -9719,8 +9515,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   js-tokens@9.0.0: {} |   js-tokens@9.0.0: {} | ||||||
| 
 | 
 | ||||||
|   js-tokens@9.0.1: {} |  | ||||||
| 
 |  | ||||||
|   js-yaml@3.14.1: |   js-yaml@3.14.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       argparse: 1.0.10 |       argparse: 1.0.10 | ||||||
| @ -9867,12 +9661,6 @@ snapshots: | |||||||
|       mlly: 1.7.3 |       mlly: 1.7.3 | ||||||
|       pkg-types: 1.2.1 |       pkg-types: 1.2.1 | ||||||
| 
 | 
 | ||||||
|   local-pkg@1.1.1: |  | ||||||
|     dependencies: |  | ||||||
|       mlly: 1.7.4 |  | ||||||
|       pkg-types: 2.1.0 |  | ||||||
|       quansync: 0.2.8 |  | ||||||
| 
 |  | ||||||
|   localstorage-polyfill@1.0.1: {} |   localstorage-polyfill@1.0.1: {} | ||||||
| 
 | 
 | ||||||
|   locate-path@5.0.0: |   locate-path@5.0.0: | ||||||
| @ -9907,7 +9695,7 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       '@jridgewell/sourcemap-codec': 1.5.0 |       '@jridgewell/sourcemap-codec': 1.5.0 | ||||||
| 
 | 
 | ||||||
|   magic-string@0.30.17: |   magic-string@0.30.13: | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@jridgewell/sourcemap-codec': 1.5.0 |       '@jridgewell/sourcemap-codec': 1.5.0 | ||||||
| 
 | 
 | ||||||
| @ -9991,18 +9779,18 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   mkdirp@1.0.4: {} |   mkdirp@1.0.4: {} | ||||||
| 
 | 
 | ||||||
|  |   mlly@1.7.1: | ||||||
|  |     dependencies: | ||||||
|  |       acorn: 8.12.1 | ||||||
|  |       pathe: 1.1.2 | ||||||
|  |       pkg-types: 1.1.3 | ||||||
|  |       ufo: 1.5.4 | ||||||
|  | 
 | ||||||
|   mlly@1.7.3: |   mlly@1.7.3: | ||||||
|     dependencies: |     dependencies: | ||||||
|       acorn: 8.14.0 |       acorn: 8.14.0 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.3.1 |       pkg-types: 1.2.1 | ||||||
|       ufo: 1.5.4 |  | ||||||
| 
 |  | ||||||
|   mlly@1.7.4: |  | ||||||
|     dependencies: |  | ||||||
|       acorn: 8.14.0 |  | ||||||
|       pathe: 2.0.3 |  | ||||||
|       pkg-types: 1.3.1 |  | ||||||
|       ufo: 1.5.4 |       ufo: 1.5.4 | ||||||
| 
 | 
 | ||||||
|   module-alias@2.2.3: {} |   module-alias@2.2.3: {} | ||||||
| @ -10021,29 +9809,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   mutation-observer@1.0.3: {} |   mutation-observer@1.0.3: {} | ||||||
| 
 | 
 | ||||||
|   naive-ui@2.41.0(vue@3.4.35(typescript@5.5.4)): |  | ||||||
|     dependencies: |  | ||||||
|       '@css-render/plugin-bem': 0.15.14(css-render@0.15.14) |  | ||||||
|       '@css-render/vue3-ssr': 0.15.14(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       '@types/katex': 0.16.7 |  | ||||||
|       '@types/lodash': 4.17.16 |  | ||||||
|       '@types/lodash-es': 4.17.12 |  | ||||||
|       async-validator: 4.2.5 |  | ||||||
|       css-render: 0.15.14 |  | ||||||
|       csstype: 3.1.3 |  | ||||||
|       date-fns: 3.6.0 |  | ||||||
|       date-fns-tz: 3.2.0(date-fns@3.6.0) |  | ||||||
|       evtd: 0.2.4 |  | ||||||
|       highlight.js: 11.11.1 |  | ||||||
|       lodash: 4.17.21 |  | ||||||
|       lodash-es: 4.17.21 |  | ||||||
|       seemly: 0.3.10 |  | ||||||
|       treemate: 0.3.11 |  | ||||||
|       vdirs: 0.1.8(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       vooks: 0.2.12(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       vue: 3.4.35(typescript@5.5.4) |  | ||||||
|       vueuc: 0.4.64(vue@3.4.35(typescript@5.5.4)) |  | ||||||
| 
 |  | ||||||
|   nanoid@3.3.7: {} |   nanoid@3.3.7: {} | ||||||
| 
 | 
 | ||||||
|   natural-compare@1.4.0: {} |   natural-compare@1.4.0: {} | ||||||
| @ -10082,7 +9847,7 @@ snapshots: | |||||||
|       consola: 3.2.3 |       consola: 3.2.3 | ||||||
|       execa: 8.0.1 |       execa: 8.0.1 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.3.1 |       pkg-types: 1.2.1 | ||||||
|       ufo: 1.5.4 |       ufo: 1.5.4 | ||||||
| 
 | 
 | ||||||
|   nzh@1.0.13: {} |   nzh@1.0.13: {} | ||||||
| @ -10208,8 +9973,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   pathe@1.1.2: {} |   pathe@1.1.2: {} | ||||||
| 
 | 
 | ||||||
|   pathe@2.0.3: {} |  | ||||||
| 
 |  | ||||||
|   perfect-debounce@1.0.0: {} |   perfect-debounce@1.0.0: {} | ||||||
| 
 | 
 | ||||||
|   phin@2.9.3: {} |   phin@2.9.3: {} | ||||||
| @ -10268,28 +10031,16 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   pkg-types@1.1.3: |   pkg-types@1.1.3: | ||||||
|     dependencies: |     dependencies: | ||||||
|       confbox: 0.1.8 |       confbox: 0.1.7 | ||||||
|       mlly: 1.7.4 |       mlly: 1.7.1 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
| 
 | 
 | ||||||
|   pkg-types@1.2.1: |   pkg-types@1.2.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       confbox: 0.1.8 |       confbox: 0.1.8 | ||||||
|       mlly: 1.7.4 |       mlly: 1.7.3 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
| 
 | 
 | ||||||
|   pkg-types@1.3.1: |  | ||||||
|     dependencies: |  | ||||||
|       confbox: 0.1.8 |  | ||||||
|       mlly: 1.7.4 |  | ||||||
|       pathe: 2.0.3 |  | ||||||
| 
 |  | ||||||
|   pkg-types@2.1.0: |  | ||||||
|     dependencies: |  | ||||||
|       confbox: 0.2.1 |  | ||||||
|       exsolve: 1.0.1 |  | ||||||
|       pathe: 2.0.3 |  | ||||||
| 
 |  | ||||||
|   pngjs@3.4.0: {} |   pngjs@3.4.0: {} | ||||||
| 
 | 
 | ||||||
|   postcss-import@14.1.0(postcss@8.4.40): |   postcss-import@14.1.0(postcss@8.4.40): | ||||||
| @ -10390,8 +10141,6 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       side-channel: 1.0.6 |       side-channel: 1.0.6 | ||||||
| 
 | 
 | ||||||
|   quansync@0.2.8: {} |  | ||||||
| 
 |  | ||||||
|   querystringify@2.2.0: {} |   querystringify@2.2.0: {} | ||||||
| 
 | 
 | ||||||
|   queue-microtask@1.2.3: {} |   queue-microtask@1.2.3: {} | ||||||
| @ -10578,8 +10327,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   scule@1.3.0: {} |   scule@1.3.0: {} | ||||||
| 
 | 
 | ||||||
|   seemly@0.3.10: {} |  | ||||||
| 
 |  | ||||||
|   semver@5.7.2: |   semver@5.7.2: | ||||||
|     optional: true |     optional: true | ||||||
| 
 | 
 | ||||||
| @ -10767,10 +10514,6 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       js-tokens: 9.0.0 |       js-tokens: 9.0.0 | ||||||
| 
 | 
 | ||||||
|   strip-literal@3.0.0: |  | ||||||
|     dependencies: |  | ||||||
|       js-tokens: 9.0.1 |  | ||||||
| 
 |  | ||||||
|   supports-color@5.5.0: |   supports-color@5.5.0: | ||||||
|     dependencies: |     dependencies: | ||||||
|       has-flag: 3.0.0 |       has-flag: 3.0.0 | ||||||
| @ -10833,10 +10576,11 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   tinyexec@0.3.0: {} |   tinyexec@0.3.0: {} | ||||||
| 
 | 
 | ||||||
|   tinyglobby@0.2.12: |   tinyglobby@0.2.5: | ||||||
|     dependencies: |     dependencies: | ||||||
|       fdir: 6.4.3(picomatch@4.0.2) |       fdir: 6.3.0(picomatch@4.0.2) | ||||||
|       picomatch: 4.0.2 |       picomatch: 4.0.2 | ||||||
|  |     optional: true | ||||||
| 
 | 
 | ||||||
|   tmpl@1.0.5: {} |   tmpl@1.0.5: {} | ||||||
| 
 | 
 | ||||||
| @ -10861,8 +10605,6 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       punycode: 2.3.1 |       punycode: 2.3.1 | ||||||
| 
 | 
 | ||||||
|   treemate@0.3.11: {} |  | ||||||
| 
 |  | ||||||
|   tslib@2.8.1: {} |   tslib@2.8.1: {} | ||||||
| 
 | 
 | ||||||
|   tsx@4.17.0: |   tsx@4.17.0: | ||||||
| @ -10909,10 +10651,10 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   unctx@2.3.1: |   unctx@2.3.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       acorn: 8.14.0 |       acorn: 8.12.1 | ||||||
|       estree-walker: 3.0.3 |       estree-walker: 3.0.3 | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.11 | ||||||
|       unplugin: 1.16.0 |       unplugin: 1.12.0 | ||||||
| 
 | 
 | ||||||
|   undici-types@5.26.5: {} |   undici-types@5.26.5: {} | ||||||
| 
 | 
 | ||||||
| @ -10937,10 +10679,10 @@ snapshots: | |||||||
|       estree-walker: 3.0.3 |       estree-walker: 3.0.3 | ||||||
|       fast-glob: 3.3.2 |       fast-glob: 3.3.2 | ||||||
|       local-pkg: 0.5.0 |       local-pkg: 0.5.0 | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.13 | ||||||
|       mlly: 1.7.4 |       mlly: 1.7.3 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.3.1 |       pkg-types: 1.2.1 | ||||||
|       scule: 1.3.0 |       scule: 1.3.0 | ||||||
|       strip-literal: 2.1.0 |       strip-literal: 2.1.0 | ||||||
|       unplugin: 1.16.0 |       unplugin: 1.16.0 | ||||||
| @ -10955,42 +10697,25 @@ snapshots: | |||||||
|       estree-walker: 3.0.3 |       estree-walker: 3.0.3 | ||||||
|       fast-glob: 3.3.2 |       fast-glob: 3.3.2 | ||||||
|       local-pkg: 0.5.0 |       local-pkg: 0.5.0 | ||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.11 | ||||||
|       mlly: 1.7.3 |       mlly: 1.7.1 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.1.3 |       pkg-types: 1.1.3 | ||||||
|       scule: 1.3.0 |       scule: 1.3.0 | ||||||
|       strip-literal: 2.1.0 |       strip-literal: 2.1.0 | ||||||
|       unplugin: 1.16.0 |       unplugin: 1.12.0 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - rollup |       - rollup | ||||||
| 
 | 
 | ||||||
|   unimport@4.1.2: |  | ||||||
|     dependencies: |  | ||||||
|       acorn: 8.14.0 |  | ||||||
|       escape-string-regexp: 5.0.0 |  | ||||||
|       estree-walker: 3.0.3 |  | ||||||
|       local-pkg: 1.1.1 |  | ||||||
|       magic-string: 0.30.17 |  | ||||||
|       mlly: 1.7.4 |  | ||||||
|       pathe: 2.0.3 |  | ||||||
|       picomatch: 4.0.2 |  | ||||||
|       pkg-types: 1.3.1 |  | ||||||
|       scule: 1.3.0 |  | ||||||
|       strip-literal: 3.0.0 |  | ||||||
|       tinyglobby: 0.2.12 |  | ||||||
|       unplugin: 2.2.0 |  | ||||||
|       unplugin-utils: 0.2.4 |  | ||||||
| 
 |  | ||||||
|   universalify@0.2.0: {} |   universalify@0.2.0: {} | ||||||
| 
 | 
 | ||||||
|   universalify@2.0.1: {} |   universalify@2.0.1: {} | ||||||
| 
 | 
 | ||||||
|   unocss-applet@0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))): |   unocss-applet@0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))): | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@unocss-applet/preset-applet': 0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) |       '@unocss-applet/preset-applet': 0.8.2(@unocss/core@0.62.3)(@unocss/preset-mini@0.62.3)(@unocss/preset-uno@0.62.3)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) | ||||||
|       '@unocss-applet/preset-rem-rpx': 0.8.2(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) |       '@unocss-applet/preset-rem-rpx': 0.8.2(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) | ||||||
|       '@unocss-applet/transformer-attributify': 0.8.2(magic-string@0.30.17)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) |       '@unocss-applet/transformer-attributify': 0.8.2(magic-string@0.30.13)(unocss@0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3))) | ||||||
|       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) |       unocss: 0.58.9(postcss@8.4.40)(rollup@4.19.2)(vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3)) | ||||||
|     optionalDependencies: |     optionalDependencies: | ||||||
|       '@unocss/preset-uno': 0.62.3 |       '@unocss/preset-uno': 0.62.3 | ||||||
| @ -11046,40 +10771,6 @@ snapshots: | |||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - rollup |       - rollup | ||||||
| 
 | 
 | ||||||
|   unplugin-auto-import@19.1.1(@nuxt/kit@3.14.1592(rollup@4.19.2))(@vueuse/core@9.13.0(vue@3.4.35(typescript@5.5.4))): |  | ||||||
|     dependencies: |  | ||||||
|       local-pkg: 1.1.1 |  | ||||||
|       magic-string: 0.30.17 |  | ||||||
|       picomatch: 4.0.2 |  | ||||||
|       unimport: 4.1.2 |  | ||||||
|       unplugin: 2.2.0 |  | ||||||
|       unplugin-utils: 0.2.4 |  | ||||||
|     optionalDependencies: |  | ||||||
|       '@nuxt/kit': 3.14.1592(rollup@4.19.2) |  | ||||||
|       '@vueuse/core': 9.13.0(vue@3.4.35(typescript@5.5.4)) |  | ||||||
| 
 |  | ||||||
|   unplugin-utils@0.2.4: |  | ||||||
|     dependencies: |  | ||||||
|       pathe: 2.0.3 |  | ||||||
|       picomatch: 4.0.2 |  | ||||||
| 
 |  | ||||||
|   unplugin-vue-components@28.4.1(@babel/parser@7.26.2)(@nuxt/kit@3.14.1592(rollup@4.19.2))(vue@3.4.35(typescript@5.5.4)): |  | ||||||
|     dependencies: |  | ||||||
|       chokidar: 3.6.0 |  | ||||||
|       debug: 4.4.0 |  | ||||||
|       local-pkg: 1.1.1 |  | ||||||
|       magic-string: 0.30.17 |  | ||||||
|       mlly: 1.7.4 |  | ||||||
|       tinyglobby: 0.2.12 |  | ||||||
|       unplugin: 2.2.0 |  | ||||||
|       unplugin-utils: 0.2.4 |  | ||||||
|       vue: 3.4.35(typescript@5.5.4) |  | ||||||
|     optionalDependencies: |  | ||||||
|       '@babel/parser': 7.26.2 |  | ||||||
|       '@nuxt/kit': 3.14.1592(rollup@4.19.2) |  | ||||||
|     transitivePeerDependencies: |  | ||||||
|       - supports-color |  | ||||||
| 
 |  | ||||||
|   unplugin@1.12.0: |   unplugin@1.12.0: | ||||||
|     dependencies: |     dependencies: | ||||||
|       acorn: 8.12.1 |       acorn: 8.12.1 | ||||||
| @ -11092,11 +10783,6 @@ snapshots: | |||||||
|       acorn: 8.14.0 |       acorn: 8.14.0 | ||||||
|       webpack-virtual-modules: 0.6.2 |       webpack-virtual-modules: 0.6.2 | ||||||
| 
 | 
 | ||||||
|   unplugin@2.2.0: |  | ||||||
|     dependencies: |  | ||||||
|       acorn: 8.14.0 |  | ||||||
|       webpack-virtual-modules: 0.6.2 |  | ||||||
| 
 |  | ||||||
|   unquote@1.1.1: {} |   unquote@1.1.1: {} | ||||||
| 
 | 
 | ||||||
|   untyped@1.5.1: |   untyped@1.5.1: | ||||||
| @ -11151,11 +10837,6 @@ snapshots: | |||||||
|       core-js: 3.37.1 |       core-js: 3.37.1 | ||||||
|       mutation-observer: 1.0.3 |       mutation-observer: 1.0.3 | ||||||
| 
 | 
 | ||||||
|   vdirs@0.1.8(vue@3.4.35(typescript@5.5.4)): |  | ||||||
|     dependencies: |  | ||||||
|       evtd: 0.2.4 |  | ||||||
|       vue: 3.4.35(typescript@5.5.4) |  | ||||||
| 
 |  | ||||||
|   vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3): |   vite@5.3.5(@types/node@20.14.14)(less@4.2.0)(sass@1.77.8)(terser@5.31.3): | ||||||
|     dependencies: |     dependencies: | ||||||
|       esbuild: 0.21.5 |       esbuild: 0.21.5 | ||||||
| @ -11168,11 +10849,6 @@ snapshots: | |||||||
|       sass: 1.77.8 |       sass: 1.77.8 | ||||||
|       terser: 5.31.3 |       terser: 5.31.3 | ||||||
| 
 | 
 | ||||||
|   vooks@0.2.12(vue@3.4.35(typescript@5.5.4)): |  | ||||||
|     dependencies: |  | ||||||
|       evtd: 0.2.4 |  | ||||||
|       vue: 3.4.35(typescript@5.5.4) |  | ||||||
| 
 |  | ||||||
|   vscode-json-languageservice@4.1.8: |   vscode-json-languageservice@4.1.8: | ||||||
|     dependencies: |     dependencies: | ||||||
|       jsonc-parser: 3.3.1 |       jsonc-parser: 3.3.1 | ||||||
| @ -11248,17 +10924,6 @@ snapshots: | |||||||
|     optionalDependencies: |     optionalDependencies: | ||||||
|       typescript: 5.5.4 |       typescript: 5.5.4 | ||||||
| 
 | 
 | ||||||
|   vueuc@0.4.64(vue@3.4.35(typescript@5.5.4)): |  | ||||||
|     dependencies: |  | ||||||
|       '@css-render/vue3-ssr': 0.15.14(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       '@juggle/resize-observer': 3.4.0 |  | ||||||
|       css-render: 0.15.14 |  | ||||||
|       evtd: 0.2.4 |  | ||||||
|       seemly: 0.3.10 |  | ||||||
|       vdirs: 0.1.8(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       vooks: 0.2.12(vue@3.4.35(typescript@5.5.4)) |  | ||||||
|       vue: 3.4.35(typescript@5.5.4) |  | ||||||
| 
 |  | ||||||
|   w3c-hr-time@1.0.2: |   w3c-hr-time@1.0.2: | ||||||
|     dependencies: |     dependencies: | ||||||
|       browser-process-hrtime: 1.0.0 |       browser-process-hrtime: 1.0.0 | ||||||
|  | |||||||
							
								
								
									
										42
									
								
								src/App.vue
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								src/App.vue
									
									
									
									
									
								
							| @ -1,55 +1,43 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useStatus } from '@/store/status' | import {useStatus} from "@/store/status"; | ||||||
| import { useUserStore } from '@/store' | import { useUserStore } from '@/store' | ||||||
| import { useProvideUserModal } from '@/hooks' | import { | ||||||
|  |   useProvideUserModal, | ||||||
|  | } from '@/hooks' | ||||||
| import ws from '@/connect' | import ws from '@/connect' | ||||||
| const { statusBarHeight } = useStatus() | const {statusBarHeight}= useStatus() | ||||||
| const { uid, isShow } = useProvideUserModal() | const { uid, isShow } = useProvideUserModal() | ||||||
| const userStore = useUserStore() | const userStore = useUserStore() | ||||||
| const root = document.documentElement | const root = document.documentElement | ||||||
| root.style.setProperty('--statusBarHeight', `${statusBarHeight.value}px`) | root.style.setProperty('--statusBarHeight',`${statusBarHeight.value}px`) | ||||||
| const handleWebview = () => { |  | ||||||
|   let statusBarHeight = window?.plus?.navigator?.getStatusbarHeight() |  | ||||||
|   plus.webview.currentWebview().setStyle({ |  | ||||||
|     top: statusBarHeight, |  | ||||||
|     bottom: 0, |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| const init = () => { | const init = () => { | ||||||
|   userStore.loadSetting() |   userStore.loadSetting() | ||||||
|   ws.connect() |   ws.connect() | ||||||
|   if (typeof plus !== 'undefined') { |  | ||||||
|     handleWebview() |  | ||||||
|   } else { |  | ||||||
|     document.addEventListener('plusready', () => { |  | ||||||
|       handleWebview() |  | ||||||
|     }) |  | ||||||
|   } |  | ||||||
| } | } | ||||||
| init() | init() | ||||||
| </script> | </script> | ||||||
| <style lang="scss"> | <style   lang="scss"> | ||||||
| @import '@/static/css/color.scss'; | @import "@/static/css/color.scss"; | ||||||
| @import '@/static/css/font.scss'; | @import "@/static/css/font.scss"; | ||||||
| /* #ifdef APP-NVUE */ | /* #ifdef APP-NVUE */ | ||||||
| @import '@/uni_modules/tmui/scss/nvue.css'; | @import '@/uni_modules/tmui/scss/nvue.css'; | ||||||
| /* #endif */ | /* #endif */ | ||||||
| /* #ifndef APP-NVUE */ | /* #ifndef APP-NVUE */ | ||||||
| @import '@/uni_modules/tmui/scss/noNvue.css'; | @import '@/uni_modules/tmui/scss/noNvue.css'; | ||||||
| /* #endif */ | /* #endif */ | ||||||
| * { | *{ | ||||||
|   box-sizing: border-box; |   box-sizing: border-box; | ||||||
| } | } | ||||||
| /*解决阅览图片关闭按钮会显示在状态栏区域的问题*/ | /*解决阅览图片关闭按钮会显示在状态栏区域的问题*/ | ||||||
| #u-a-p > div > div { | #u-a-p>div>div{ | ||||||
|   margin-top: var(--statusBarHeight); |   margin-top:var(--statusBarHeight) | ||||||
| } | } | ||||||
| /*不显示滚动条的类*/ | /*不显示滚动条的类*/ | ||||||
| .no-scroll { | .no-scroll { | ||||||
|   -ms-overflow-style: none; /* IE 和 Edge */ |   -ms-overflow-style: none;  /* IE 和 Edge */ | ||||||
|   scrollbar-width: none; /* Firefox */ |   scrollbar-width: none;  /* Firefox */ | ||||||
| } | } | ||||||
| .no-scroll::-webkit-scrollbar { | .no-scroll::-webkit-scrollbar { | ||||||
|   display: none; /* Webkit 浏览器 */ |   display: none;  /* Webkit 浏览器 */ | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  | |||||||
| @ -5,7 +5,6 @@ | |||||||
|     :title="props.title" |     :title="props.title" | ||||||
|     :shadow="props.shadowNum" |     :shadow="props.shadowNum" | ||||||
|     :fontSize="34" |     :fontSize="34" | ||||||
|     :showStatusBar="false" |  | ||||||
|   > |   > | ||||||
|     <template #left> |     <template #left> | ||||||
|       <slot name="left"></slot> |       <slot name="left"></slot> | ||||||
|  | |||||||
| @ -20,8 +20,7 @@ let show = ref(false) | |||||||
|     }" |     }" | ||||||
|   > |   > | ||||||
|     <div class="title"> |     <div class="title"> | ||||||
|       <!-- <n-tag :bordered="false" size="small" type="primary">群公告</n-tag> --> |       <n-tag :bordered="false" size="small" type="primary">群公告</n-tag> | ||||||
|        <text>群公告</text> |  | ||||||
|       <!-- 《{{ extra.title }}》 --> |       <!-- 《{{ extra.title }}》 --> | ||||||
|     </div> |     </div> | ||||||
|     <div class="title" :class="{ ellipsis: !show }"> |     <div class="title" :class="{ ellipsis: !show }"> | ||||||
|  | |||||||
| @ -1,95 +0,0 @@ | |||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <!-- 完全复制的textMessage组件,没有用处,仅兜底真有14类型时的场景。后续会单独做制作分享卡片功能,到时再根据分享卡片样式重做本页面 --> |  | ||||||
| <script lang="ts" setup> |  | ||||||
| import { textReplaceEmoji } from '@/utils/emojis' |  | ||||||
| import { textReplaceLink, textReplaceMention } from '@/utils/strings' |  | ||||||
| import { ITalkRecordExtraText, ITalkRecord } from '@/types/chat' |  | ||||||
| 
 |  | ||||||
| const props = defineProps<{ |  | ||||||
|   extra: ITalkRecordExtraText |  | ||||||
|   data: ITalkRecord |  | ||||||
|   maxWidth?: boolean |  | ||||||
|   source?: 'panel' | 'forward' | 'history' |  | ||||||
| }>() |  | ||||||
| 
 |  | ||||||
| const float = props.data.float |  | ||||||
| 
 |  | ||||||
| let textContent = props.extra?.content || '' |  | ||||||
| 
 |  | ||||||
| textContent = textReplaceLink(textContent) |  | ||||||
| 
 |  | ||||||
| if (props.data.talk_type == 2) { |  | ||||||
|   textContent = textReplaceMention(textContent, '#1890ff') |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| textContent = textReplaceEmoji(textContent) |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|   <div |  | ||||||
|     class="im-message-text" |  | ||||||
|     :class="{ |  | ||||||
|       left: float == 'left', |  | ||||||
|       right: float == 'right', |  | ||||||
|       maxwidth: maxWidth, |  | ||||||
|       'radius-reset': source != 'panel', |  | ||||||
|     }" |  | ||||||
|   > |  | ||||||
|     <pre v-html="textContent" /> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style lang="less" scoped> |  | ||||||
| .im-message-text { |  | ||||||
|   min-width: 40rpx; |  | ||||||
|   min-height: 40rpx; |  | ||||||
|   padding: 22rpx 30rpx; |  | ||||||
|   color: #1a1a1a; |  | ||||||
|   background: #ffffff; |  | ||||||
|   border-radius: 0 16rpx 16rpx 16rpx; |  | ||||||
| 
 |  | ||||||
|   &.right { |  | ||||||
|     background-color: #46299d; |  | ||||||
|     color: #ffffff; |  | ||||||
|     border-radius: 16rpx 0 16rpx 16rpx; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   &.maxwidth { |  | ||||||
|     max-width: 486rpx; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   &.radius-reset { |  | ||||||
|     border-radius: 0; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   pre { |  | ||||||
|     white-space: pre-wrap; |  | ||||||
|     overflow: hidden; |  | ||||||
|     word-break: break-word; |  | ||||||
|     word-wrap: break-word; |  | ||||||
|     font-size: 32rpx; |  | ||||||
|     font-family: 'PingFang SC', 'Microsoft YaHei', 'Alibaba PuHuiTi 2.0 45'; |  | ||||||
|     line-height: 44rpx; |  | ||||||
| 
 |  | ||||||
|     :deep(.emoji) { |  | ||||||
|       vertical-align: text-bottom; |  | ||||||
|       margin: 0 10rpx; |  | ||||||
|       width: 44rpx; |  | ||||||
|       height: 44rpx; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     :deep(a) { |  | ||||||
|       color: #2196f3; |  | ||||||
|       text-decoration: revert; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -11,7 +11,6 @@ export const ChatMsgTypeLogin = 10 // 登录消息 | |||||||
| export const ChatMsgTypeVote = 11 // 投票消息
 | export const ChatMsgTypeVote = 11 // 投票消息
 | ||||||
| export const ChatMsgTypeMixed = 12 // 混合消息
 | export const ChatMsgTypeMixed = 12 // 混合消息
 | ||||||
| export const ChatMsgTypeGroupNotice = 13 // 群公告消息
 | export const ChatMsgTypeGroupNotice = 13 // 群公告消息
 | ||||||
| export const ChatMsgTypeLink = 14 // 链接消息
 |  | ||||||
| 
 | 
 | ||||||
| export const ChatMsgSysText = 1000 // 系统文本消息
 | export const ChatMsgSysText = 1000 // 系统文本消息
 | ||||||
| export const ChatMsgSysGroupCreate = 1101 // 创建群聊消息
 | export const ChatMsgSysGroupCreate = 1101 // 创建群聊消息
 | ||||||
| @ -41,7 +40,6 @@ export const ChatMsgTypeMapping = { | |||||||
|   [ChatMsgTypeCode]: '[代码消息]', |   [ChatMsgTypeCode]: '[代码消息]', | ||||||
|   [ChatMsgTypeMixed]: '[图文消息]', |   [ChatMsgTypeMixed]: '[图文消息]', | ||||||
|   [ChatMsgTypeGroupNotice]: '[群公告]', |   [ChatMsgTypeGroupNotice]: '[群公告]', | ||||||
|   [ChatMsgTypeLink]: '[链接]', |  | ||||||
|   [ChatMsgSysText]: '[系统消息]', |   [ChatMsgSysText]: '[系统消息]', | ||||||
|   [ChatMsgSysGroupCreate]: '[创建群消息]', |   [ChatMsgSysGroupCreate]: '[创建群消息]', | ||||||
|   [ChatMsgSysGroupMemberJoin]: '[加入群消息]', |   [ChatMsgSysGroupMemberJoin]: '[加入群消息]', | ||||||
| @ -71,7 +69,6 @@ export const MessageComponents = { | |||||||
|   [ChatMsgTypeCode]: 'code-message', |   [ChatMsgTypeCode]: 'code-message', | ||||||
|   [ChatMsgTypeMixed]: 'mixed-message', |   [ChatMsgTypeMixed]: 'mixed-message', | ||||||
|   [ChatMsgTypeGroupNotice]: 'group-notice-message', |   [ChatMsgTypeGroupNotice]: 'group-notice-message', | ||||||
|   [ChatMsgTypeLink]: 'link-message', |  | ||||||
|   [ChatMsgSysText]: 'sys-text-message', |   [ChatMsgSysText]: 'sys-text-message', | ||||||
|   [ChatMsgSysGroupCreate]: 'sys-group-create-message', |   [ChatMsgSysGroupCreate]: 'sys-group-create-message', | ||||||
|   [ChatMsgSysGroupMemberJoin]: 'sys-group-join-message', |   [ChatMsgSysGroupMemberJoin]: 'sys-group-join-message', | ||||||
| @ -95,6 +92,5 @@ export const ForwardableMessageType = [ | |||||||
|   ChatMsgTypeVideo, |   ChatMsgTypeVideo, | ||||||
|   ChatMsgTypeFile, |   ChatMsgTypeFile, | ||||||
|   ChatMsgTypeLocation, |   ChatMsgTypeLocation, | ||||||
|   ChatMsgTypeCard, |   ChatMsgTypeCard | ||||||
|   ChatMsgTypeLink |  | ||||||
| ] | ] | ||||||
|  | |||||||
| @ -7,29 +7,25 @@ import lodash from 'lodash' | |||||||
| 
 | 
 | ||||||
| export const useTalkRecord = (uid) => { | export const useTalkRecord = (uid) => { | ||||||
|   const dialogueStore = useDialogueStore() |   const dialogueStore = useDialogueStore() | ||||||
|   const { |   const { getDialogueList,addDialogueRecord,zpagingComplete } = useDialogueListStore() | ||||||
|     getDialogueList, |  | ||||||
|     addDialogueRecord, |  | ||||||
|     zpagingComplete, |  | ||||||
|   } = useDialogueListStore() |  | ||||||
|   const records = computed(() => { |   const records = computed(() => { | ||||||
|     const dialogueList = getDialogueList(dialogueStore.index_name) |     const dialogueList = getDialogueList(dialogueStore.index_name) | ||||||
|     if (dialogueList) { |     if(dialogueList){ | ||||||
|       return lodash.cloneDeep(dialogueList.records).reverse() |       return lodash.cloneDeep(dialogueList.records).reverse() | ||||||
|     } |     } | ||||||
|     return lodash.cloneDeep(dialogueStore.records)?.reverse() |     return lodash.cloneDeep(dialogueStore.records)?.reverse() | ||||||
|   }) |   } ) | ||||||
| 
 | 
 | ||||||
|   const location = reactive({ |   const location = reactive({ | ||||||
|     msgid: '', |     msgid: '', | ||||||
|     num: 0, |     num: 0 | ||||||
|   }) |   }) | ||||||
| 
 | 
 | ||||||
|   const loadConfig = reactive({ |   const loadConfig = reactive({ | ||||||
|     receiver_id: 0, |     receiver_id: 0, | ||||||
|     talk_type: 0, |     talk_type: 0, | ||||||
|     status: 0, |     status: 0, | ||||||
|     cursor: 0, |     cursor: 0 | ||||||
|   }) |   }) | ||||||
| 
 | 
 | ||||||
|   const onJumpMessage = (msgid) => { |   const onJumpMessage = (msgid) => { | ||||||
| @ -53,7 +49,7 @@ export const useTalkRecord = (uid) => { | |||||||
| 
 | 
 | ||||||
|       return el?.scrollTo({ |       return el?.scrollTo({ | ||||||
|         top: 0, |         top: 0, | ||||||
|         behavior: 'smooth', |         behavior: 'smooth' | ||||||
|       }) |       }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -61,7 +57,7 @@ export const useTalkRecord = (uid) => { | |||||||
|     location.num = 0 |     location.num = 0 | ||||||
| 
 | 
 | ||||||
|     element?.scrollIntoView({ |     element?.scrollIntoView({ | ||||||
|       behavior: 'smooth', |       behavior: 'smooth' | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     addClass(element, 'border') |     addClass(element, 'border') | ||||||
| @ -74,7 +70,7 @@ export const useTalkRecord = (uid) => { | |||||||
|   // 加载数据列表
 |   // 加载数据列表
 | ||||||
|   const load = async (params) => { |   const load = async (params) => { | ||||||
|     const request = { |     const request = { | ||||||
|       limit: 30, |       limit:30, | ||||||
|       ...params, |       ...params, | ||||||
|       talk_type: params.talk_type, |       talk_type: params.talk_type, | ||||||
|       receiver_id: params.receiver_id, |       receiver_id: params.receiver_id, | ||||||
| @ -85,9 +81,9 @@ export const useTalkRecord = (uid) => { | |||||||
| 
 | 
 | ||||||
|     let scrollHeight = 0 |     let scrollHeight = 0 | ||||||
|     const el = document.getElementById('imChatPanel') |     const el = document.getElementById('imChatPanel') | ||||||
|     if (el) { |     // if (el) {
 | ||||||
|       scrollHeight = el.scrollHeight |     //   scrollHeight = el.scrollHeight
 | ||||||
|     } |     // }
 | ||||||
|     const { data, code } = await ServeTalkRecords(request) |     const { data, code } = await ServeTalkRecords(request) | ||||||
|     if (code != 200) { |     if (code != 200) { | ||||||
|       return (loadConfig.status = 1) |       return (loadConfig.status = 1) | ||||||
| @ -108,11 +104,8 @@ export const useTalkRecord = (uid) => { | |||||||
| 
 | 
 | ||||||
|     const reverseItems = lodash.cloneDeep(items).reverse() |     const reverseItems = lodash.cloneDeep(items).reverse() | ||||||
|     dialogueStore.unshiftDialogueRecord(reverseItems) |     dialogueStore.unshiftDialogueRecord(reverseItems) | ||||||
|     addDialogueRecord( |     addDialogueRecord(params.direction=='down'?reverseItems:items,params.direction=='down'?'add':'unshift') | ||||||
|       params.direction == 'down' ? reverseItems : items, |     zpagingComplete(dialogueStore.index_name) | ||||||
|       params.direction == 'down' ? 'add' : 'unshift', |  | ||||||
|     ) |  | ||||||
|     zpagingComplete(dialogueStore.index_name, reverseItems) |  | ||||||
|     const dialogueList = getDialogueList(dialogueStore.index_name) |     const dialogueList = getDialogueList(dialogueStore.index_name) | ||||||
|     loadConfig.status = dialogueList.records?.[0]?.sequence > 1 ? 1 : 2 |     loadConfig.status = dialogueList.records?.[0]?.sequence > 1 ? 1 : 2 | ||||||
|     // loadConfig.cursor = data.cursor
 |     // loadConfig.cursor = data.cursor
 | ||||||
| @ -140,19 +133,17 @@ export const useTalkRecord = (uid) => { | |||||||
| 
 | 
 | ||||||
|   const onRefreshLoad = () => { |   const onRefreshLoad = () => { | ||||||
|     let dialogueList = getDialogueList(dialogueStore.index_name) |     let dialogueList = getDialogueList(dialogueStore.index_name) | ||||||
|     if (dialogueList.records[0].sequence === 1) { |     if (dialogueList.records[0].sequence === 1 ) { | ||||||
|       return false |       return false | ||||||
|     } |     } | ||||||
|     if (loadConfig.status == 1) { |     if (loadConfig.status == 1) { | ||||||
|       let filterList = dialogueList.records.filter( |       let filterList = dialogueList.records.filter(item=>item.sequence !== -1) | ||||||
|         (item) => item.sequence !== -1, |  | ||||||
|       ) |  | ||||||
|       loadConfig.cursor = filterList[0].sequence |       loadConfig.cursor = filterList[0].sequence | ||||||
|       load({ |       load({ | ||||||
|         receiver_id: loadConfig.receiver_id, |         receiver_id: loadConfig.receiver_id, | ||||||
|         talk_type: loadConfig.talk_type, |         talk_type: loadConfig.talk_type, | ||||||
|         direction: 'up', |         direction:'up', | ||||||
|         no_limit: 0, |         no_limit:0, | ||||||
|       }) |       }) | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @ -161,14 +152,12 @@ export const useTalkRecord = (uid) => { | |||||||
|     let dialogueList = getDialogueList(params.index_name) |     let dialogueList = getDialogueList(params.index_name) | ||||||
|     if (!dialogueList) { |     if (!dialogueList) { | ||||||
|       loadConfig.cursor = 0 |       loadConfig.cursor = 0 | ||||||
|     } else { |     }else{ | ||||||
|       let filterList = dialogueList.records.filter( |       let filterList = dialogueList.records.filter(item=>item.sequence !== -1) | ||||||
|         (item) => item.sequence !== -1, |       if(params.direction=='up'){ | ||||||
|       ) |  | ||||||
|       if (params.direction == 'up') { |  | ||||||
|         loadConfig.cursor = filterList?.[0]?.sequence |         loadConfig.cursor = filterList?.[0]?.sequence | ||||||
|       } else { |       }else{ | ||||||
|         loadConfig.cursor = filterList?.[filterList.length - 1]?.sequence |         loadConfig.cursor = filterList?.[filterList.length-1]?.sequence | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     loadConfig.receiver_id = params.receiver_id |     loadConfig.receiver_id = params.receiver_id | ||||||
|  | |||||||
| @ -115,7 +115,6 @@ const changeSwitch = (e, item) => { | |||||||
|       flex-direction: row; |       flex-direction: row; | ||||||
|       align-items: center; |       align-items: center; | ||||||
|       justify-content: flex-end; |       justify-content: flex-end; | ||||||
|       padding: 0 0 0 20rpx; |  | ||||||
|       span { |       span { | ||||||
|         line-height: 44rpx; |         line-height: 44rpx; | ||||||
|         color: #747474; |         color: #747474; | ||||||
|  | |||||||
| @ -21,15 +21,12 @@ | |||||||
|             <div class="base-info"> |             <div class="base-info"> | ||||||
|               <div class="base-info-name"> |               <div class="base-info-name"> | ||||||
|                 <span class="text-[32rpx] font-medium">{{ groupName }}</span> |                 <span class="text-[32rpx] font-medium">{{ groupName }}</span> | ||||||
|                 <span |                 <span class="base-info_num text-[32rpx] font-medium"> | ||||||
|                   class="base-info_num text-[32rpx] font-medium" |  | ||||||
|                   v-if="groupNum" |  | ||||||
|                 > |  | ||||||
|                   {{ '(' + groupNum + ')' }} |                   {{ '(' + groupNum + ')' }} | ||||||
|                 </span> |                 </span> | ||||||
|               </div> |               </div> | ||||||
|               <div |               <div | ||||||
|                 v-if="groupParams?.groupInfo?.group_type !== 1 && groupType" |                 v-if="groupParams?.groupInfo?.group_type !== 1" | ||||||
|                 class="base-info-tag" |                 class="base-info-tag" | ||||||
|                 :style="{ |                 :style="{ | ||||||
|                   borderColor: |                   borderColor: | ||||||
| @ -295,10 +292,10 @@ onMounted(() => { | |||||||
|       value: t('record.searchType.files'), |       value: t('record.searchType.files'), | ||||||
|       typeIcon: recordSearchTypeIcon_files, |       typeIcon: recordSearchTypeIcon_files, | ||||||
|     }, |     }, | ||||||
|     // { |     { | ||||||
|     //   value: t('record.searchType.link'), |       value: t('record.searchType.link'), | ||||||
|     //   typeIcon: recordSearchTypeIcon_link, |       typeIcon: recordSearchTypeIcon_link, | ||||||
|     // }, |     }, | ||||||
|   ] |   ] | ||||||
|   if (dialogueParams.type === 2) { |   if (dialogueParams.type === 2) { | ||||||
|     state.recordSearchTypeList.unshift({ |     state.recordSearchTypeList.unshift({ | ||||||
|  | |||||||
| @ -27,10 +27,7 @@ | |||||||
|               <span class="text-[40rpx] font-medium user-info-name"> |               <span class="text-[40rpx] font-medium user-info-name"> | ||||||
|                 {{ state?.userInfo?.nickname }} |                 {{ state?.userInfo?.nickname }} | ||||||
|               </span> |               </span> | ||||||
|               <span |               <span class="text-[28rpx] font-medium user-info-job-num"> | ||||||
|                 class="text-[28rpx] font-medium user-info-job-num" |  | ||||||
|                 v-if="state?.userInfo?.job_num" |  | ||||||
|               > |  | ||||||
|                 {{ $t('user.info.jobNum') + ':' + state?.userInfo?.job_num }} |                 {{ $t('user.info.jobNum') + ':' + state?.userInfo?.job_num }} | ||||||
|               </span> |               </span> | ||||||
|             </div> |             </div> | ||||||
|  | |||||||
| @ -2,17 +2,19 @@ | |||||||
|   <div class="dialog-page"> |   <div class="dialog-page"> | ||||||
|     <ZPaging |     <ZPaging | ||||||
|       use-chat-record-mode |       use-chat-record-mode | ||||||
|       use-virtual-list |       :refresher-enabled="false" | ||||||
|       cell-height-mode="dynamic" |  | ||||||
|       :refresher-enabled="true" |  | ||||||
|       :show-scrollbar="false" |       :show-scrollbar="false" | ||||||
|       :loading-more-enabled="true" |       :loading-more-enabled="false" | ||||||
|       :hide-empty-view="true" |       :hide-empty-view="true" | ||||||
|       height="100%" |       height="100%" | ||||||
|       ref="zpagingRef" |       ref="zpagingRef" | ||||||
|       v-model="virtualList" |       :use-virtual-list="true" | ||||||
|  |       :preload-page="1" | ||||||
|  |       cell-height-mode="dynamic" | ||||||
|  |       virtual-scroll-fps="80" | ||||||
|       :loading-more-custom-style="{ display: 'none', height: '0' }" |       :loading-more-custom-style="{ display: 'none', height: '0' }" | ||||||
|       @scrolltolower="onScrollToLower" |       @virtualListChange="virtualListChange" | ||||||
|  |       @scrolltolower="onRefreshLoad" | ||||||
|     > |     > | ||||||
|       <template #top> |       <template #top> | ||||||
|         <customNavbar :title="talkParams.username"> |         <customNavbar :title="talkParams.username"> | ||||||
| @ -37,13 +39,13 @@ | |||||||
|       <!-- <template #top> |       <!-- <template #top> | ||||||
|             <div class="load-toolbar pointer"> |             <div class="load-toolbar pointer"> | ||||||
|               <span v-if="loadConfig.status == 0"> 正在加载数据中 ... </span> |               <span v-if="loadConfig.status == 0"> 正在加载数据中 ... </span> | ||||||
|               <span v-else-if="loadConfig.status == 1" @click="onScrollToLower"> 查看更多消息 ... </span> |               <span v-else-if="loadConfig.status == 1" @click="onRefreshLoad"> 查看更多消息 ... </span> | ||||||
|               <span v-else class="no-more"> 没有更多消息了 </span> |               <span v-else class="no-more"> 没有更多消息了 </span> | ||||||
|             </div> |             </div> | ||||||
|           </template> --> |           </template> --> | ||||||
| 
 | 
 | ||||||
|       <!-- 数据加载状态栏 --> |       <!-- 数据加载状态栏 --> | ||||||
|       <div class="dialog-list" @touchstart="handleHidePanel"> |       <div class="dialog-list"> | ||||||
|         <div |         <div | ||||||
|           class="message-item" |           class="message-item" | ||||||
|           v-for="item in virtualList" |           v-for="item in virtualList" | ||||||
| @ -168,19 +170,10 @@ | |||||||
|         </div> |         </div> | ||||||
|         <div class="load-toolbar pointer" style="transform: scaleY(-1);"> |         <div class="load-toolbar pointer" style="transform: scaleY(-1);"> | ||||||
|           <span v-if="loadConfig.status == 0">正在加载数据中 ...</span> |           <span v-if="loadConfig.status == 0">正在加载数据中 ...</span> | ||||||
|           <span v-else-if="loadConfig.status == 1" @click="onScrollToLower"> |           <span v-else-if="loadConfig.status == 1" @click="onRefreshLoad"> | ||||||
|             查看更多消息 ... |             查看更多消息 ... | ||||||
|           </span> |           </span> | ||||||
|           <span |           <span v-else class="no-more">没有更多消息了</span> | ||||||
|             v-else-if=" |  | ||||||
|               loadConfig.status != 0 && |  | ||||||
|               loadConfig.status != 1 && |  | ||||||
|               state.localPageLoadDone |  | ||||||
|             " |  | ||||||
|             class="no-more" |  | ||||||
|           > |  | ||||||
|             没有更多消息了 |  | ||||||
|           </span> |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <template #bottom> |       <template #bottom> | ||||||
| @ -196,7 +189,6 @@ | |||||||
|                   :options="editorOption" |                   :options="editorOption" | ||||||
|                   @editorChange="onEditorChange" |                   @editorChange="onEditorChange" | ||||||
|                   style="height: 100%; border: none;" |                   style="height: 100%; border: none;" | ||||||
|                   @click="onEditorClick" |  | ||||||
|                 /> |                 /> | ||||||
|                 <!-- <tm-input type=textarea autoHeight focusColor="#F9F9F9" color="#F9F9F9" :inputPadding="[12]" |                 <!-- <tm-input type=textarea autoHeight focusColor="#F9F9F9" color="#F9F9F9" :inputPadding="[12]" | ||||||
|               placeholder=""></tm-input> --> |               placeholder=""></tm-input> --> | ||||||
| @ -400,12 +392,11 @@ const state = ref({ | |||||||
|   showWin: false, |   showWin: false, | ||||||
|   onfocusItem: null, |   onfocusItem: null, | ||||||
|   sessionId: '', |   sessionId: '', | ||||||
|   localPageLoadDone: true, //分页加载缓存中的聊天记录是否完毕 |  | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| uniOnload((options) => { | uniOnload((options) => { | ||||||
|   if (options.sessionId) { |   if (options.sessionId) { | ||||||
|     state.value.sessionId = options.sessionId |     state.sessionId = options.sessionId | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| @ -418,18 +409,7 @@ const handleFilePanel = () => { | |||||||
|   state.value.isOpenFilePanel = !state.value.isOpenFilePanel |   state.value.isOpenFilePanel = !state.value.isOpenFilePanel | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //点击隐藏表情/文件上传 面板 | const onSendMessage = (data = {}) => { | ||||||
| const handleHidePanel = () => { |  | ||||||
|   state.value.isOpenFilePanel = false |  | ||||||
|   state.value.isOpenEmojiPanel = false |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //点击编辑区聚焦输入框 |  | ||||||
| const onEditorClick = () => { |  | ||||||
|   handleHidePanel() |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const onSendMessage = (data = {}, callBack) => { |  | ||||||
|   let message = { |   let message = { | ||||||
|     ...data, |     ...data, | ||||||
|     receiver: { |     receiver: { | ||||||
| @ -441,9 +421,7 @@ const onSendMessage = (data = {}, callBack) => { | |||||||
|   ServePublishMessage(message) |   ServePublishMessage(message) | ||||||
|     .then(({ code, message }) => { |     .then(({ code, message }) => { | ||||||
|       if (code == 200) { |       if (code == 200) { | ||||||
|         if (callBack) { |         // callBack(true) | ||||||
|           callBack(true) |  | ||||||
|         } |  | ||||||
|       } else { |       } else { | ||||||
|         message.warning(message) |         message.warning(message) | ||||||
|       } |       } | ||||||
| @ -488,7 +466,7 @@ const onSendTextEvent = lodash.throttle((value) => { | |||||||
|     mentions: data.mentionUids, |     mentions: data.mentionUids, | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   onSendMessage(message, callBack) |   onSendMessage(message) | ||||||
| }, 1000) | }, 1000) | ||||||
| 
 | 
 | ||||||
| // 编辑器输入事件 | // 编辑器输入事件 | ||||||
| @ -826,35 +804,6 @@ watch( | |||||||
|   }, |   }, | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| watch( |  | ||||||
|   () => virtualList.value, |  | ||||||
|   (newValue, oldValue) => { |  | ||||||
|     if (newValue) { |  | ||||||
|       const dialogueList = getDialogueList(talkParams.index_name) |  | ||||||
|       console.log(newValue[newValue.length - 1].sequence, dialogueList.records?.[0]?.sequence) |  | ||||||
|       if ( |  | ||||||
|         newValue[newValue.length - 1].sequence === |  | ||||||
|         dialogueList.records?.[0]?.sequence |  | ||||||
|       ) { |  | ||||||
|         //相同意味着分页加载缓存中的聊天记录完毕 |  | ||||||
|         state.value.localPageLoadDone = true |  | ||||||
|       } else { |  | ||||||
|         state.value.localPageLoadDone = false |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     deep: true, |  | ||||||
|   }, |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| const onScrollToLower = () => { |  | ||||||
|   if (state.value.localPageLoadDone) { |  | ||||||
|     //本地缓存的聊天记录分页加载完之后,才可以请求接口 |  | ||||||
|     onRefreshLoad() |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const clearMultiSelect = () => { | const clearMultiSelect = () => { | ||||||
|   dialogueStore.setMultiSelect(false) |   dialogueStore.setMultiSelect(false) | ||||||
|   virtualList.value.forEach((item) => { |   virtualList.value.forEach((item) => { | ||||||
| @ -874,7 +823,7 @@ const initData = async () => { | |||||||
|     no_limit: dialogueList ? 1 : 0, |     no_limit: dialogueList ? 1 : 0, | ||||||
|   } |   } | ||||||
|   await onLoad({ ...objT }) |   await onLoad({ ...objT }) | ||||||
|   zpagingRef.value?.setLocalPaging(records.value) |   zpagingRef.value?.complete(records.value) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //点击跳转到聊天设置页面 | //点击跳转到聊天设置页面 | ||||||
| @ -884,7 +833,7 @@ const toChatSettingsPage = () => { | |||||||
|       '/pages/chatSettings/index?groupId=' + |       '/pages/chatSettings/index?groupId=' + | ||||||
|       talkParams?.receiver_id + |       talkParams?.receiver_id + | ||||||
|       '&sessionId=' + |       '&sessionId=' + | ||||||
|       state.value.sessionId, |       state.sessionId, | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -47,7 +47,7 @@ | |||||||
|               </div> |               </div> | ||||||
| 
 | 
 | ||||||
| 						</div> | 						</div> | ||||||
| 						<div style="flex-shrink: 0;" | 						<div | ||||||
| 							class="text-[#000000] text-[28rpx] font-medium opacity-26 ml-[24rpx] time_right" | 							class="text-[#000000] text-[28rpx] font-medium opacity-26 ml-[24rpx] time_right" | ||||||
| 						> | 						> | ||||||
| 							{{ beautifyTime(props.data.updated_at) }} | 							{{ beautifyTime(props.data.updated_at) }} | ||||||
|  | |||||||
| @ -1,106 +1,104 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="outer-layer"> | 	<div class="outer-layer"> | ||||||
|     <ZPaging | 		<ZPaging | ||||||
|       class="paging_container" |       class="paging_container" | ||||||
|       ref="paging" | 			ref="paging" | ||||||
|       refresher-enabled | 			refresher-enabled | ||||||
|       :refresher-threshold="80" | 			:refresher-threshold="80" | ||||||
|       :refresher-max-angle="0" |       :refresher-max-angle="0" | ||||||
|       :refresher-pull-rate="0.5" |       :refresher-pull-rate="0.5" | ||||||
|       :refresher-fixed-bac-height="80" |       :refresher-fixed-bac-height="80" | ||||||
|       refresher-fixed-background="#F9F9FD" |       refresher-fixed-background="#F9F9FD" | ||||||
|       refresher-background="#F9F9FD" |       refresher-background="#F9F9FD" | ||||||
|       v-model="items" | 			v-model="items" | ||||||
|       @query="queryList" | 			@query="queryList" | ||||||
|       :loading-more-enabled="false" |       :loading-more-enabled="false" | ||||||
|       :refresher-end-bounce-enabled="false" |       :refresher-end-bounce-enabled="false" | ||||||
|       :auto="true" |       :auto="true" | ||||||
|       :empty-view-show="isEmptyViewShow" |       :empty-view-show="isEmptyViewShow" | ||||||
|       @refresherRefresh="onRefresh" |       @refresherRefresh="onRefresh" | ||||||
|       :show-scrollbar="false" | 		> | ||||||
|     > | 			<template #top> | ||||||
|       <template #top> | 				<div> | ||||||
|         <div> | 					<tm-navbar | ||||||
|           <tm-navbar | 						class="index_top_navbar" | ||||||
|             class="index_top_navbar" | 						:hideBack="false" | ||||||
|             :hideBack="false" | 						hideHome | ||||||
|             hideHome | 						title="" | ||||||
|             title="" | 						:leftWidth="420" | ||||||
|             :leftWidth="420" | 					> | ||||||
|             :showStatusBar="false" | 						<template v-slot:left> | ||||||
|           > | 							<div class="flex items-center ml-[48rpx]"> | ||||||
|             <template v-slot:left> | 								<image | ||||||
|               <div class="flex items-center ml-[48rpx]"> | 									class="w-[72rpx] h-[72rpx]" | ||||||
|                 <image | 									style="border-radius: 50%" | ||||||
|                   class="w-[72rpx] h-[72rpx]" | 									:src="userStore.avatar" | ||||||
|                   style="border-radius: 50%;" | 									mode="scaleToFill" | ||||||
|                   :src="userStore.avatar" | 								/> | ||||||
|                   mode="scaleToFill" | 								<div class="ml-[24rpx] text-[36rpx] font-bold"> | ||||||
|                 /> | 									{{ userStore.nickname }} | ||||||
|                 <div class="ml-[24rpx] text-[36rpx] font-bold"> | 								</div> | ||||||
|                   {{ userStore.nickname }} | 							</div> | ||||||
|                 </div> | 						</template> | ||||||
|               </div> | 						<template v-slot:right> | ||||||
|             </template> | 							<div class="mr-[48rpx] popoverBox"> | ||||||
|             <template v-slot:right> | 								<tm-popover position="br" color="#333333" :width="260"> | ||||||
|               <div class="mr-[48rpx] popoverBox"> | 									<image | ||||||
|                 <tm-popover position="br" color="#333333" :width="260"> | 										class="w-[48rpx] h-[48rpx]" | ||||||
|                   <image | 										style="border-radius: 50%" | ||||||
|                     class="w-[48rpx] h-[48rpx]" | 										:src="addCircle" | ||||||
|                     style="border-radius: 50%;" | 										mode="scaleToFill" | ||||||
|                     :src="addCircle" | 									/> | ||||||
|                     mode="scaleToFill" | 									<template v-slot:label> | ||||||
|                   /> | 										<div | ||||||
|                   <template v-slot:label> | 											class="w-full h-[208rpx] pt-[22rpx] pb-[32rpx] pl-[14rpx] pr-[12rpx]" | ||||||
|                     <div | 										> | ||||||
|                       class="w-full h-[208rpx] pt-[22rpx] pb-[32rpx] pl-[14rpx] pr-[12rpx]" | 											<div | ||||||
|                     > | 												@click="creatGroupChat" | ||||||
|                       <div | 												class="flex items-center pl-[22rpx] mb-[32rpx]" | ||||||
|                         @click="creatGroupChat" | 											> | ||||||
|                         class="flex items-center pl-[22rpx] mb-[32rpx]" | 												<div class="mr-[26rpx] flex items-center"> | ||||||
|                       > | 													<tm-image | ||||||
|                         <div class="mr-[26rpx] flex items-center"> | 														:width="40" | ||||||
|                           <tm-image | 														:height="39" | ||||||
|                             :width="40" | 														:src="cahtPopover" | ||||||
|                             :height="39" | 													></tm-image> | ||||||
|                             :src="cahtPopover" | 												</div> | ||||||
|                           ></tm-image> | 												<div | ||||||
|                         </div> | 													class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" | ||||||
|                         <div | 												> | ||||||
|                           class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" | 													发起群聊 | ||||||
|                         > | 												</div> | ||||||
|                           发起群聊 | 											</div> | ||||||
|                         </div> | 											<div class="divider"></div> | ||||||
|                       </div> | 											<div | ||||||
|                       <div class="divider"></div> | 												@click="toAddressBookPage" | ||||||
|                       <div | 												class="flex items-center pl-[22rpx] mt-[32rpx]" | ||||||
|                         @click="toAddressBookPage" | 											> | ||||||
|                         class="flex items-center pl-[22rpx] mt-[32rpx]" | 												<div class="mr-[26rpx] flex items-center"> | ||||||
|                       > | 													<tm-image | ||||||
|                         <div class="mr-[26rpx] flex items-center"> | 														:width="40" | ||||||
|                           <tm-image | 														:height="43" | ||||||
|                             :width="40" | 														:src="zu3289" | ||||||
|                             :height="43" | 													></tm-image> | ||||||
|                             :src="zu3289" | 												</div> | ||||||
|                           ></tm-image> | 												<div | ||||||
|                         </div> | 													class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" | ||||||
|                         <div | 												> | ||||||
|                           class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" | 													通讯录 | ||||||
|                         > | 												</div> | ||||||
|                           通讯录 | 											</div> | ||||||
|                         </div> | 										</div> | ||||||
|                       </div> | 									</template> | ||||||
|                     </div> | 								</tm-popover> | ||||||
|                   </template> | 							</div> | ||||||
|                 </tm-popover> | 						</template> | ||||||
|               </div> | 					</tm-navbar> | ||||||
|             </template> | 				</div> | ||||||
|           </tm-navbar> | 			</template> | ||||||
|         </div> | 			<template #refresher="{ refresherStatus }"> | ||||||
|       </template> | 				<custom-refresher :status="refresherStatus" /> | ||||||
|       <template #refresher="{ refresherStatus }"> | 			</template> | ||||||
|         <custom-refresher :status="refresherStatus" /> |  | ||||||
|       </template> |  | ||||||
|       <div class="content"> |       <div class="content"> | ||||||
|         <div class="root"> |         <div class="root"> | ||||||
|           <div class="searchRoot" @click="toSearchPage"> |           <div class="searchRoot" @click="toSearchPage"> | ||||||
| @ -123,94 +121,88 @@ | |||||||
|             /> |             /> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> | 			</div> | ||||||
|     </ZPaging> | 		</ZPaging> | ||||||
|   </div> | 	</div> | ||||||
| </template> | </template> | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, watch, computed } from 'vue' | import { ref, watch, computed } from "vue"; | ||||||
| import { onShow, onLoad } from '@dcloudio/uni-app' | import { onShow, onLoad } from "@dcloudio/uni-app"; | ||||||
| import { useChatList } from '@/store/chatList/index.js' | import { useChatList } from "@/store/chatList/index.js"; | ||||||
| import { useAuth } from '@/store/auth' | import { useAuth } from "@/store/auth"; | ||||||
| import { useTalkStore, useUserStore, useDialogueStore } from '@/store' | import { useTalkStore, useUserStore, useDialogueStore } from "@/store"; | ||||||
| import chatItem from './components/chatItem.vue' | import chatItem from "./components/chatItem.vue"; | ||||||
| import addCircle from '@/static/image/chatList/addCircle.png' | import addCircle from "@/static/image/chatList/addCircle.png"; | ||||||
| import cahtPopover from '@/static/image/chatList/cahtPopover.png' | import cahtPopover from "@/static/image/chatList/cahtPopover.png"; | ||||||
| import zu3289 from '@/static/image/chatList/zu3289@2x.png' | import zu3289 from "@/static/image/chatList/zu3289@2x.png"; | ||||||
| import ZPaging from '@/uni_modules/z-paging/components/z-paging/z-paging.vue' | import ZPaging from "@/uni_modules/z-paging/components/z-paging/z-paging.vue"; | ||||||
| const paging = ref() | const paging = ref(); | ||||||
| const isEmptyViewShow = ref(false) | const isEmptyViewShow = ref(false); | ||||||
| const talkStore = useTalkStore() | const talkStore = useTalkStore(); | ||||||
| const userStore = useUserStore() | const userStore = useUserStore(); | ||||||
| const dialogueStore = useDialogueStore() | const dialogueStore = useDialogueStore(); | ||||||
| const { userInfo } = useAuth() | const { userInfo } = useAuth(); | ||||||
| 
 | 
 | ||||||
| const topItems = computed(() => talkStore.topItems) | const topItems = computed(() => talkStore.topItems); | ||||||
| const items = computed(() => { | const items = computed(() => { | ||||||
|   // if (searchKeyword.value.length === 0) { | 	// if (searchKeyword.value.length === 0) { | ||||||
|   console.log(talkStore.talkItems) | 	console.log(talkStore.talkItems); | ||||||
| 
 | 
 | ||||||
|   return talkStore.talkItems | 	return talkStore.talkItems; | ||||||
|   // } | 	// } | ||||||
| 
 | 
 | ||||||
|   // return talkStore.talkItems.filter((item) => { | 	// return talkStore.talkItems.filter((item) => { | ||||||
|   //   let keyword = item.remark || item.name | 	//   let keyword = item.remark || item.name | ||||||
| 
 | 
 | ||||||
|   //   return keyword.toLowerCase().indexOf(searchKeyword.value.toLowerCase()) != -1 | 	//   return keyword.toLowerCase().indexOf(searchKeyword.value.toLowerCase()) != -1 | ||||||
|   // }) | 	// }) | ||||||
| }) | }); | ||||||
| 
 | 
 | ||||||
| const queryList = (pageNo, pageSize) => { | const queryList = (pageNo, pageSize) => { | ||||||
|   // paging.value.complete(res.data.list); | 	// paging.value.complete(res.data.list); | ||||||
|   console.log(talkStore) | 	console.log(talkStore); | ||||||
|   talkStore |   talkStore.loadTalkList().then(() => { | ||||||
|     .loadTalkList() |     isEmptyViewShow.value = talkStore.talkItems.length === 0; | ||||||
|     .then(() => { |   // 数据加载成功 | ||||||
|       isEmptyViewShow.value = talkStore.talkItems.length === 0 |   paging.value.complete(talkStore.talkItems); | ||||||
|       // 数据加载成功 | }).catch(error => { | ||||||
|       paging.value.complete(talkStore.talkItems) |   // 数据加载失败 | ||||||
|     }) |   console.error('加载失败', error); | ||||||
|     .catch((error) => { |   paging.value.complete(false); | ||||||
|       // 数据加载失败 | }); | ||||||
|       console.error('加载失败', error) | }; | ||||||
|       paging.value.complete(false) |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| // 添加下拉刷新处理函数 | // 添加下拉刷新处理函数 | ||||||
| const onRefresh = () => { | const onRefresh = () => { | ||||||
|   console.log('触发下拉刷新') |   console.log('触发下拉刷新'); | ||||||
|   talkStore |   talkStore.loadTalkList().then(() => { | ||||||
|     .loadTalkList() |   // 数据加载成功 | ||||||
|     .then(() => { |   paging.value.complete(talkStore.talkItems); | ||||||
|       // 数据加载成功 | }).catch(error => { | ||||||
|       paging.value.complete(talkStore.talkItems) |   // 数据加载失败 | ||||||
|     }) |   console.error('加载失败', error); | ||||||
|     .catch((error) => { |   paging.value.complete(false); | ||||||
|       // 数据加载失败 | }); | ||||||
|       console.error('加载失败', error) | }; | ||||||
|       paging.value.complete(false) |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| const creatGroupChat = () => { | const creatGroupChat = () => { | ||||||
|   uni.navigateTo({ | 	uni.navigateTo({ | ||||||
|     url: '/pages/creatGroupChat/index', | 		url: "/pages/creatGroupChat/index", | ||||||
|   }) | 	}); | ||||||
| } | }; | ||||||
| 
 | 
 | ||||||
| const toSearchPage = () => { | const toSearchPage = () => { | ||||||
|   uni.navigateTo({ | 	uni.navigateTo({ | ||||||
|     url: '/pages/search/index', | 		url: "/pages/search/index", | ||||||
|   }) | 	}); | ||||||
| } | }; | ||||||
| 
 | 
 | ||||||
| //点击跳转到通讯录页面 | //点击跳转到通讯录页面 | ||||||
| const toAddressBookPage = () => { | const toAddressBookPage = () => { | ||||||
|   uni.navigateTo({ | 	uni.navigateTo({ | ||||||
|     url: '/pages/chooseByDeps/index?chooseMode=3', | 		url: "/pages/chooseByDeps/index?chooseMode=3", | ||||||
|   }) | 	}); | ||||||
| } | }; | ||||||
| 
 | 
 | ||||||
| /* watch( | /* watch( | ||||||
| 	() => talkStore, | 	() => talkStore, | ||||||
| @ -222,108 +214,106 @@ const toAddressBookPage = () => { | |||||||
| 
 | 
 | ||||||
| onShow(() => { | onShow(() => { | ||||||
|   // 页面显示时重新加载数据 |   // 页面显示时重新加载数据 | ||||||
|   talkStore | 	talkStore.loadTalkList().then(() => { | ||||||
|     .loadTalkList() |     // 如果paging已经初始化,则刷新列表 | ||||||
|     .then(() => { |     if (paging.value) { | ||||||
|       // 如果paging已经初始化,则刷新列表 |       paging.value.reload(); | ||||||
|       if (paging.value) { |     } | ||||||
|         paging.value.reload() |   }).catch(error => { | ||||||
|       } |     console.error('页面显示时数据加载失败', error); | ||||||
|     }) |   }); | ||||||
|     .catch((error) => { | }); | ||||||
|       console.error('页面显示时数据加载失败', error) |  | ||||||
|     }) |  | ||||||
| }) |  | ||||||
| 
 | 
 | ||||||
| onLoad((options) => { | onLoad((options) => { | ||||||
|   console.log(options) | 	console.log(options); | ||||||
| 
 | 
 | ||||||
|   if (options?.openSessionIndexName) { | 	if (options?.openSessionIndexName) { | ||||||
|     if (items?.value?.length > 0) { | 		if (items?.value?.length > 0) { | ||||||
|       items.value.forEach((openSession) => { | 			items.value.forEach((openSession) => { | ||||||
|         if (openSession.index_name === options?.openSessionIndexName) { | 				if (openSession.index_name === options?.openSessionIndexName) { | ||||||
|           dialogueStore.setDialogue(openSession) | 					dialogueStore.setDialogue(openSession); | ||||||
|           if (openSession.unread_num > 0) { | 					if (openSession.unread_num > 0) { | ||||||
|             ServeClearTalkUnreadNum({ | 						ServeClearTalkUnreadNum({ | ||||||
|               talk_type: openSession.talk_type, | 							talk_type: openSession.talk_type, | ||||||
|               receiver_id: openSession.receiver_id, | 							receiver_id: openSession.receiver_id, | ||||||
|             }).then(() => { | 						}).then(() => { | ||||||
|               talkStore.updateItem({ | 							talkStore.updateItem({ | ||||||
|                 index_name: openSession.index_name, | 								index_name: openSession.index_name, | ||||||
|                 unread_num: 0, | 								unread_num: 0, | ||||||
|               }) | 							}); | ||||||
|             }) | 						}); | ||||||
|           } | 					} | ||||||
|           uni.navigateTo({ | 					uni.navigateTo({ | ||||||
|             url: '/pages/dialog/index?sessionId=' + openSession.id, | 						url: "/pages/dialog/index?sessionId=" + openSession.id, | ||||||
|           }) | 					}); | ||||||
|         } | 				} | ||||||
|       }) | 			}); | ||||||
|     } | 		} | ||||||
|   } | 	} | ||||||
| }) | }); | ||||||
| </script> | </script> | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| uni-page-body, | uni-page-body, | ||||||
| page { | page { | ||||||
|   height: 100vh; | 	height: 100vh; | ||||||
|   background-image: url('@/static/image/clockIn/z3280@3x.png'); |   background-image: url("@/static/image/clockIn/z3280@3x.png"); | ||||||
|   background-size: cover; | 	background-size: cover; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
| } | } | ||||||
| .outer-layer { | .outer-layer { | ||||||
|   height: 100%; |   height: 100%; | ||||||
| } | } | ||||||
| .paging_container { | .paging_container{ | ||||||
|   // border: 1px solid red; |   // border: 1px solid red; | ||||||
|   background: #fff; |   background: #fff; | ||||||
|   margin: 0 32rpx 20rpx 32rpx; |   margin: 0 32rpx 20rpx 32rpx; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ::v-deep .index_top_navbar > .statusHeight:first-child { | ::v-deep .index_top_navbar > .statusHeight:first-child { | ||||||
|   height: 70px !important; | 	height: 70px !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ::v-deep .index_top_navbar .statusHeightTop { | ::v-deep .index_top_navbar .statusHeightTop { | ||||||
|   height: 70px !important; | 	height: 70px !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ::v-deep .index_top_navbar .statusHeightTop > .noNvueBorder:first-child { | ::v-deep .index_top_navbar .statusHeightTop > .noNvueBorder:first-child { | ||||||
|   height: 70px !important; | 	height: 70px !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .content { | .content{ | ||||||
|   // overflow: auto; | 
 | ||||||
|  | 	// overflow: auto; | ||||||
| } | } | ||||||
| .root { | .root { | ||||||
|   flex: 1; | 	flex: 1; | ||||||
|   padding: 20rpx 0; | 	padding: 20rpx 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .searchRoot { | .searchRoot { | ||||||
|   background-color: #fff; | 	background-color: #fff; | ||||||
|   padding: 22rpx 18rpx; | 	padding: 22rpx 18rpx; | ||||||
|   border-bottom: 16rpx rgba(249, 249, 253, 1) solid; |   border-bottom: 16rpx rgba(249, 249, 253, 1) solid; | ||||||
|   ::v-deep .noNvueBorder > .noNvueBorder > .noNvueBorder { | 	::v-deep .noNvueBorder > .noNvueBorder > .noNvueBorder { | ||||||
|     background: #f9f9fd !important; | 		background: #f9f9fd !important; | ||||||
|   } | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .contentRoot { | .contentRoot { | ||||||
|   margin-top: 20rpx; | 	margin-top: 20rpx; | ||||||
|   background-color: #fff; | 	background-color: #fff; | ||||||
|   // min-height: calc(100vh - 180px); | 	// min-height: calc(100vh - 180px); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .divider { | .divider { | ||||||
|   height: 1rpx; | 	height: 1rpx; | ||||||
|   background-color: #7c7c7c; | 	background-color: #7c7c7c; | ||||||
|   opacity: 0.6; | 	opacity: 0.6; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .popoverBox { | .popoverBox { | ||||||
|   :deep(.popover-bcc) { | 	:deep(.popover-bcc) { | ||||||
|     transform: translateX(16rpx) translateY(48rpx); | 		transform: translateX(16rpx) translateY(48rpx); | ||||||
|   } | 	} | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ import { userInfoApi } from "@/api/user"; | |||||||
| import {ref} from 'vue' | import {ref} from 'vue' | ||||||
| export const useAuth = createGlobalState(() => { | export const useAuth = createGlobalState(() => { | ||||||
|   // const token = useStorage('token', '', uniStorage)
 |   // const token = useStorage('token', '', uniStorage)
 | ||||||
|   const token = ref('79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caaef1334d640773710f8cd96473bacfb190cba595a5d6a9c87d70f0999a3ebb41147213b31b4bdccffca66a56acf3baab5af0154f0dce360079f37709f78e13711036899344bddb0fb4cf0f2890287cb62c3fcbe33368caa5e213624577be8b8420ab75b1f50775ee16142a4321c5d56995f37354a66a969da98d95ba6e65d142ed097e04b411c1ebad2f62866d0ec7e1838420530a9941dbbcd00490199f8b894b54078d04d4ee86e494023bfc12a4fe79d044f22bef01b0b5f132e8ca151dcd3a1a4150e348641300c622b8af98cfd5d41fb24a8409b2b49446a766ea3886f587db124e0eb7d849ed33e6618fdf2c7f') |   const token = ref('79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caaef1334d640773710f8cd96473bacfb190cba595a5d6a9c87d70f0999a3ebb41147213b31b4bdccffca66a56acf3baab5af0154f0dce360079f37709f78e13711036899344bddb0fb4cf0f2890287cb62c3fcbe33368caa5e213624577be8b8420ab75b1f50775ee16142a4321c5d56995f37354a66a969da98d95ba6e65d142ed097e04b411c1ebad2f62866d0ec7e1838420530a9941dbbcd00490199f8b8989ec7fe774a82b3f1c4a71a1a6338dec73760f6e72184147caceb1e8a1884e7251c809c440eb394f5df08a384a639a4710527561343785f238745ba9057ec3d4d5fdf5130d4666761c69db08d31abb01') | ||||||
|   const refreshToken = useStorage('refreshToken', '', uniStorage) |   const refreshToken = useStorage('refreshToken', '', uniStorage) | ||||||
|   const userInfo = useStorage('userInfo', {}, uniStorage) |   const userInfo = useStorage('userInfo', {}, uniStorage) | ||||||
|   const leaderList = useStorage('leaderList', [], uniStorage) |   const leaderList = useStorage('leaderList', [], uniStorage) | ||||||
|  | |||||||
| @ -99,8 +99,9 @@ export const useDialogueListStore = createGlobalState(() => { | |||||||
|     zpagingRef.value = params |     zpagingRef.value = params | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const zpagingComplete = (index_name, newRecords) => { |   const zpagingComplete = (index_name) => { | ||||||
|     zpagingRef.value?.complete(lodash.cloneDeep(newRecords).reverse()) |     const item = getDialogueList(index_name) | ||||||
|  |     zpagingRef.value?.complete(lodash.cloneDeep(item.records).reverse()) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const addChatRecord = (indexName, item) => { |   const addChatRecord = (indexName, item) => { | ||||||
|  | |||||||
| @ -1,98 +1,78 @@ | |||||||
| <template> | <template> | ||||||
|   <view> | 	<view> | ||||||
|     <view | 		<view v-if="props.isPlace" class="statusHeight" :style="{ height: _barHeight + 'px' }"></view> | ||||||
|       v-if="props.isPlace" | 		<view class="fixed l-0 t-0 statusHeightTop flex" :style="{ width: _width + 'px', height: _barHeight + 'px' }"> | ||||||
|       class="statusHeight" | 			<tm-sheet | ||||||
|       :style="{ height: _barHeight + 'px' }" | 				@click="emits('click', $event)" | ||||||
|     ></view> | 				:blur="_blur" | ||||||
|     <view | 				:color="props.color" | ||||||
|       class="fixed l-0 t-0 statusHeightTop flex" | 				:_class="_class" | ||||||
|       :style="{ width: _width + 'px', height: _barHeight + 'px' }" | 				:_style="_style" | ||||||
|     > | 				:followTheme="props.followTheme" | ||||||
|       <tm-sheet | 				:follow-dark="props.followDark" | ||||||
|         @click="emits('click', $event)" | 				:dark="props.dark" | ||||||
|         :blur="_blur" | 				:round="props.round" | ||||||
|         :color="props.color" | 				:shadow="props.shadow" | ||||||
|         :_class="_class" | 				:outlined="props.outlined" | ||||||
|         :_style="_style" | 				:border="props.border" | ||||||
|         :followTheme="props.followTheme" | 				:borderStyle="props.borderStyle" | ||||||
|         :follow-dark="props.followDark" | 				:borderDirection="props.borderDirection" | ||||||
|         :dark="props.dark" | 				:text="props.text" | ||||||
|         :round="props.round" | 				:transprent="props.transprent" | ||||||
|         :shadow="props.shadow" | 				:linear="props.linear" | ||||||
|         :outlined="props.outlined" | 				:linearDeep="props.linearDeep" | ||||||
|         :border="props.border" | 				:margin="props.margin" | ||||||
|         :borderStyle="props.borderStyle" | 				:padding="props.padding" | ||||||
|         :borderDirection="props.borderDirection" | 				:height="_barHeight" | ||||||
|         :text="props.text" | 				:width="_width" | ||||||
|         :transprent="props.transprent" | 				unit="px" | ||||||
|         :linear="props.linear" | 				:darkBgColor="props.darkBgColor" | ||||||
|         :linearDeep="props.linearDeep" | 			> | ||||||
|         :margin="props.margin" | 				<view class="statusHeight" :style="{ height: statusBarHeight + 'px' }"></view> | ||||||
|         :padding="props.padding" |  | ||||||
|         :height="_barHeight" |  | ||||||
|         :width="_width" |  | ||||||
|         unit="px" |  | ||||||
|         :darkBgColor="props.darkBgColor" |  | ||||||
|       > |  | ||||||
|         <view |  | ||||||
|           class="statusHeight" |  | ||||||
|           :style="{ height: statusBarHeight + 'px' }" |  | ||||||
|           v-if="props?.showStatusBar" |  | ||||||
|         ></view> |  | ||||||
| 
 | 
 | ||||||
|         <view class="flex flex-row flex-1 flex-row flex-row-center-between"> | 				<view class="flex flex-row flex-1 flex-row flex-row-center-between"> | ||||||
|           <view | 					<view class="flex-row flex flex-row-center-start" :style="{ width: _leftWidth + 'rpx' }"> | ||||||
|             class="flex-row flex flex-row-center-start" | 						<!-- #ifndef MP-ALIPAY --> | ||||||
|             :style="{ width: _leftWidth + 'rpx' }" | 						<tm-icon | ||||||
|           > | 							:unit="props.unit" | ||||||
|             <!-- #ifndef MP-ALIPAY --> | 							:font-size="props.iconFontSize" | ||||||
|             <tm-icon | 							_class="pointer pb-12 pt-12 px-24" | ||||||
|               :unit="props.unit" | 							:color="_homeColor" | ||||||
|               :font-size="props.iconFontSize" | 							@click="goback" | ||||||
|               _class="pointer pb-12 pt-12 px-24" | 							v-if="_pages > 1 && !props.hideBack" | ||||||
|               :color="_homeColor" | 							name="tmicon-angle-left" | ||||||
|               @click="goback" | 						></tm-icon> | ||||||
|               v-if="_pages > 1 && !props.hideBack" | 						<tm-icon | ||||||
|               name="tmicon-angle-left" | 							:unit="props.unit" | ||||||
|             ></tm-icon> | 							_class="pointer  pb-12 pt-12 px-24" | ||||||
|             <tm-icon | 							@click="backhome" | ||||||
|               :unit="props.unit" | 							v-if="_pages == 1 && !hideHome" | ||||||
|               _class="pointer  pb-12 pt-12 px-24" | 							:color="_homeColor" | ||||||
|               @click="backhome" | 							:font-size="props.iconFontSize" | ||||||
|               v-if="_pages == 1 && !hideHome" | 							name="tmicon-md-home" | ||||||
|               :color="_homeColor" | 						></tm-icon> | ||||||
|               :font-size="props.iconFontSize" | 						<!-- #endif --> | ||||||
|               name="tmicon-md-home" | 						<slot name="left"></slot> | ||||||
|             ></tm-icon> | 					</view> | ||||||
|             <!-- #endif --> | 					<view class="flex flex-row-center-center flex-col" :style="{ width: contentwidth + 'px' }"> | ||||||
|             <slot name="left"></slot> | 						<slot> | ||||||
|           </view> | 							<tm-text | ||||||
|           <view | 								:unit="props.unit" | ||||||
|             class="flex flex-row-center-center flex-col" | 								_class="text-weight-b text-overflow-1" | ||||||
|             :style="{ width: contentwidth + 'px' }" | 								:color="_fontColor" | ||||||
|           > | 								:font-size="props.fontSize" | ||||||
|             <slot> | 								:label="_title" | ||||||
|               <tm-text | 							></tm-text> | ||||||
|                 :unit="props.unit" |  | ||||||
|                 _class="text-weight-b text-overflow-1" |  | ||||||
|                 :color="_fontColor" |  | ||||||
|                 :font-size="props.fontSize" |  | ||||||
|                 :label="_title" |  | ||||||
|               ></tm-text> |  | ||||||
|               <slot name="subTitle"></slot> |               <slot name="subTitle"></slot> | ||||||
|             </slot> | 						</slot> | ||||||
|           </view> | 					</view> | ||||||
|           <view | 					<view class="flex-row flex flex-row-center-end" :style="{ width: _rightWidth + 'rpx' }"> | ||||||
|             class="flex-row flex flex-row-center-end" | 						<slot name="right"></slot> | ||||||
|             :style="{ width: _rightWidth + 'rpx' }" | 					</view> | ||||||
|           > | 				</view> | ||||||
|             <slot name="right"></slot> | 			</tm-sheet> | ||||||
|           </view> | 		</view> | ||||||
|         </view> | 	</view> | ||||||
|       </tm-sheet> |  | ||||||
|     </view> |  | ||||||
|   </view> |  | ||||||
| </template> | </template> | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| /** | /** | ||||||
| @ -103,167 +83,148 @@ import tmSheet from '../tm-sheet/tm-sheet.vue' | |||||||
| import tmText from '../tm-text/tm-text.vue' | import tmText from '../tm-text/tm-text.vue' | ||||||
| import tmIcon from '../tm-icon/tm-icon.vue' | import tmIcon from '../tm-icon/tm-icon.vue' | ||||||
| import { custom_props } from '../../tool/lib/minxs' | import { custom_props } from '../../tool/lib/minxs' | ||||||
| import { | import { getCurrentInstance, computed, ref, provide, inject, onUpdated, onMounted, onUnmounted, nextTick, watch, PropType } from 'vue' | ||||||
|   getCurrentInstance, |  | ||||||
|   computed, |  | ||||||
|   ref, |  | ||||||
|   provide, |  | ||||||
|   inject, |  | ||||||
|   onUpdated, |  | ||||||
|   onMounted, |  | ||||||
|   onUnmounted, |  | ||||||
|   nextTick, |  | ||||||
|   watch, |  | ||||||
|   PropType, |  | ||||||
| } from 'vue' |  | ||||||
| import { useTmpiniaStore } from '../../tool/lib/tmpinia' | import { useTmpiniaStore } from '../../tool/lib/tmpinia' | ||||||
| const store = useTmpiniaStore() | const store = useTmpiniaStore() | ||||||
| const emits = defineEmits(['click', 'close']) | const emits = defineEmits(['click', 'close']) | ||||||
| const proxy = getCurrentInstance()?.proxy ?? null | const proxy = getCurrentInstance()?.proxy ?? null | ||||||
| const props = defineProps({ | const props = defineProps({ | ||||||
|   ...custom_props, | 	...custom_props, | ||||||
|   followTheme: { | 	followTheme: { | ||||||
|     type: [Boolean, String], | 		type: [Boolean, String], | ||||||
|     default: true, | 		default: true | ||||||
|   }, | 	}, | ||||||
|   transprent: { | 	transprent: { | ||||||
|     type: [Boolean, String], | 		type: [Boolean, String], | ||||||
|     default: false, | 		default: false | ||||||
|   }, | 	}, | ||||||
|   color: { | 	color: { | ||||||
|     type: [String], | 		type: [String], | ||||||
|     default: 'white', | 		default: 'white' | ||||||
|   }, | 	}, | ||||||
|   text: { | 	text: { | ||||||
|     type: [Boolean], | 		type: [Boolean], | ||||||
|     default: false, | 		default: false | ||||||
|   }, | 	}, | ||||||
|   border: { | 	border: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 0, | 		default: 0 | ||||||
|   }, | 	}, | ||||||
|   shadow: { | 	shadow: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 1, | 		default: 1 | ||||||
|   }, | 	}, | ||||||
|   borderDirection: { | 	borderDirection: { | ||||||
|     type: String as PropType< | 		type: String as PropType< | ||||||
|       | 'all' | 			| 'all' | ||||||
|       | 'bottom' | 			| 'bottom' | ||||||
|       | 'bottomleft' | 			| 'bottomleft' | ||||||
|       | 'bottomright' | 			| 'bottomright' | ||||||
|       | 'left' | 			| 'left' | ||||||
|       | 'leftright' | 			| 'leftright' | ||||||
|       | 'right' | 			| 'right' | ||||||
|       | 'top' | 			| 'top' | ||||||
|       | 'topbottom' | 			| 'topbottom' | ||||||
|       | 'topleft' | 			| 'topleft' | ||||||
|       | 'topright' | 			| 'topright' | ||||||
|       | 'x' | 			| 'x' | ||||||
|       | 'y' | 			| 'y' | ||||||
|     >, | 		>, | ||||||
|     default: 'bottom', | 		default: 'bottom' | ||||||
|   }, | 	}, | ||||||
|   round: { | 	round: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 0, | 		default: 0 | ||||||
|   }, | 	}, | ||||||
|   margin: { | 	margin: { | ||||||
|     type: Array as PropType<Array<number>>, | 		type: Array as PropType<Array<number>>, | ||||||
|     default: () => [0, 0], | 		default: () => [0, 0] | ||||||
|   }, | 	}, | ||||||
|   padding: { | 	padding: { | ||||||
|     type: Array as PropType<Array<number>>, | 		type: Array as PropType<Array<number>>, | ||||||
|     default: () => [0, 0], | 		default: () => [0, 0] | ||||||
|   }, | 	}, | ||||||
|   height: { | 	height: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 44, | 		default: 44 | ||||||
|   }, | 	}, | ||||||
|   //指两边,左宽度除了中间,中间标题宽度为自动 | 	//指两边,左宽度除了中间,中间标题宽度为自动 | ||||||
|   leftWidth: { | 	leftWidth: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 220, | 		default: 220 | ||||||
|   }, | 	}, | ||||||
|   //指两边,左宽度除了中间,中间标题宽度为自动 | 	//指两边,左宽度除了中间,中间标题宽度为自动 | ||||||
|   rightWidth: { | 	rightWidth: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 220, | 		default: 220 | ||||||
|   }, | 	}, | ||||||
|   fontSize: { | 	fontSize: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 30, | 		default: 30 | ||||||
|   }, | 	}, | ||||||
|   iconFontSize: { | 	iconFontSize: { | ||||||
|     type: [Number], | 		type: [Number], | ||||||
|     default: 37, | 		default: 37 | ||||||
|   }, | 	}, | ||||||
|   title: { | 	title: { | ||||||
|     type: [String], | 		type: [String], | ||||||
|     default: '标题标题标题标题标题标题标题标题标题标题标题标题标题标题标题标题', | 		default: '标题标题标题标题标题标题标题标题标题标题标题标题标题标题标题标题' | ||||||
|   }, | 	}, | ||||||
|   //默认为自动,提供了,将强制使用本主题色。 | 	//默认为自动,提供了,将强制使用本主题色。 | ||||||
|   fontColor: { | 	fontColor: { | ||||||
|     type: [String], | 		type: [String], | ||||||
|     default: '', | 		default: '' | ||||||
|   }, | 	}, | ||||||
|   homeColor: { | 	homeColor: { | ||||||
|     type: [String], | 		type: [String], | ||||||
|     default: '', | 		default: '' | ||||||
|   }, | 	}, | ||||||
|   hideHome: { | 	hideHome: { | ||||||
|     type: Boolean, | 		type: Boolean, | ||||||
|     default: false, | 		default: false | ||||||
|   }, | 	}, | ||||||
|   hideBack: { | 	hideBack: { | ||||||
|     type: Boolean, | 		type: Boolean, | ||||||
|     default: false, | 		default: false | ||||||
|   }, | 	}, | ||||||
|   //返回首页的路径,默认/pages/index/index | 	//返回首页的路径,默认/pages/index/index | ||||||
|   homePath: { | 	homePath: { | ||||||
|     type: [String], | 		type: [String], | ||||||
|     default: '/pages/index/index', | 		default: '/pages/index/index' | ||||||
|   }, | 	}, | ||||||
|   beforeBack: { | 	beforeBack: { | ||||||
|     type: [Boolean, Function], | 		type: [Boolean, Function], | ||||||
|     default: () => true, | 		default: () => true | ||||||
|   }, | 	}, | ||||||
|   blur: { | 	blur: { | ||||||
|     type: Boolean, | 		type: Boolean, | ||||||
|     default: false, | 		default: false | ||||||
|   }, | 	}, | ||||||
|   unit: { | 	unit: { | ||||||
|     type: String, | 		type: String, | ||||||
|     default: 'rpx', | 		default: 'rpx' | ||||||
|   }, | 	}, | ||||||
|   //暗下强制的背景色, | 	//暗下强制的背景色, | ||||||
|   //有时自动的背景,可能不是你想要暗黑背景,此时可以使用此参数,强制使用背景色, | 	//有时自动的背景,可能不是你想要暗黑背景,此时可以使用此参数,强制使用背景色, | ||||||
|   //只能是颜色值。 | 	//只能是颜色值。 | ||||||
|   darkBgColor: { | 	darkBgColor: { | ||||||
|     type: String, | 		type: String, | ||||||
|     default: '', | 		default: '' | ||||||
|   }, | 	}, | ||||||
|   /**是否占位,如果为false,底部内容会被导航遮盖,true则会店内内容位置. */ | 	/**是否占位,如果为false,底部内容会被导航遮盖,true则会店内内容位置. */ | ||||||
|   isPlace: { | 	isPlace: { | ||||||
|     type: Boolean, | 		type: Boolean, | ||||||
|     default: true, | 		default: true | ||||||
|   }, | 	} | ||||||
|   //是否显示状态栏 |  | ||||||
|   showStatusBar: { |  | ||||||
|     type: Boolean, |  | ||||||
|     default: true, |  | ||||||
|   }, |  | ||||||
| }) | }) | ||||||
| const _height = computed(() => props.height) | const _height = computed(() => props.height) | ||||||
| const _width = uni.getSystemInfoSync().windowWidth | const _width = uni.getSystemInfoSync().windowWidth | ||||||
| const statusBarHeight = window?.plus?.navigator?.getStatusbarHeight() ?? 0 | const statusBarHeight=window?.plus?.navigator?.getStatusbarHeight() ?? 0 | ||||||
| const _barHeight = computed(() => | const _barHeight = computed(() => statusBarHeight + _height.value) | ||||||
|   props?.showStatusBar ? statusBarHeight + _height.value : _height.value, |  | ||||||
| ) |  | ||||||
| const _leftWidth = computed(() => props.leftWidth) | const _leftWidth = computed(() => props.leftWidth) | ||||||
| const _rightWidth = computed(() => props.rightWidth) | const _rightWidth = computed(() => props.rightWidth) | ||||||
| const contentwidth = computed(() => { | const contentwidth = computed(() => { | ||||||
|   return _width - uni.upx2px(_leftWidth.value) - uni.upx2px(_rightWidth.value) | 	return _width - uni.upx2px(_leftWidth.value) - uni.upx2px(_rightWidth.value) | ||||||
| }) | }) | ||||||
| const _title = computed(() => props.title) | const _title = computed(() => props.title) | ||||||
| const _fontColor = computed(() => props.fontColor) | const _fontColor = computed(() => props.fontColor) | ||||||
| @ -271,53 +232,53 @@ const _homeColor = computed(() => props.homeColor) | |||||||
| const _blur = computed(() => props.blur) | const _blur = computed(() => props.blur) | ||||||
| const _pages = ref(0) | const _pages = ref(0) | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   _pages.value = getCurrentPages().length | 	_pages.value = getCurrentPages().length | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| const backhome = () => { | const backhome = () => { | ||||||
|   uni.reLaunch({ | 	uni.reLaunch({ | ||||||
|     url: props.homePath, | 		url: props.homePath | ||||||
|   }) | 	}) | ||||||
| } | } | ||||||
| let timerId = NaN | let timerId = NaN | ||||||
| function debounce(func: Function, wait = 500, immediate = false) { | function debounce(func: Function, wait = 500, immediate = false) { | ||||||
|   // 清除定时器 | 	// 清除定时器 | ||||||
|   if (!isNaN(timerId)) clearTimeout(timerId) | 	if (!isNaN(timerId)) clearTimeout(timerId) | ||||||
|   // 立即执行,此类情况一般用不到 | 	// 立即执行,此类情况一般用不到 | ||||||
|   if (immediate) { | 	if (immediate) { | ||||||
|     var callNow = !timerId | 		var callNow = !timerId | ||||||
|     timerId = setTimeout(() => { | 		timerId = setTimeout(() => { | ||||||
|       timerId = NaN | 			timerId = NaN | ||||||
|     }, wait) | 		}, wait) | ||||||
|     if (callNow) typeof func === 'function' && func() | 		if (callNow) typeof func === 'function' && func() | ||||||
|   } else { | 	} else { | ||||||
|     // 设置定时器,当最后一次操作后,timeout不会再被清除,所以在延时wait毫秒后执行func回调方法 | 		// 设置定时器,当最后一次操作后,timeout不会再被清除,所以在延时wait毫秒后执行func回调方法 | ||||||
|     timerId = setTimeout(() => { | 		timerId = setTimeout(() => { | ||||||
|       typeof func === 'function' && func() | 			typeof func === 'function' && func() | ||||||
|     }, wait) | 		}, wait) | ||||||
|   } | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const goback = () => { | const goback = () => { | ||||||
|   debounce( | 	debounce( | ||||||
|     async () => { | 		async () => { | ||||||
|       if (typeof props.beforeBack === 'function') { | 			if (typeof props.beforeBack === 'function') { | ||||||
|         let p = await props.beforeBack() | 				let p = await props.beforeBack() | ||||||
|         if (typeof p === 'function') { | 				if (typeof p === 'function') { | ||||||
|           p = await p() | 					p = await p() | ||||||
|         } | 				} | ||||||
|         if (!p) return | 				if (!p) return | ||||||
|       } | 			} | ||||||
|       uni.navigateBack({}) | 			uni.navigateBack({}) | ||||||
|     }, | 		}, | ||||||
|     250, | 		250, | ||||||
|     true, | 		true | ||||||
|   ) | 	) | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped> | <style scoped> | ||||||
| .statusHeightTop { | .statusHeightTop { | ||||||
|   z-index: 400; | 	z-index: 400; | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  | |||||||
| @ -1,8 +1,3 @@ | |||||||
| import vue from '@vitejs/plugin-vue' |  | ||||||
| import AutoImport from 'unplugin-auto-import/vite' |  | ||||||
| import { NaiveUiResolver } from 'unplugin-vue-components/resolvers' |  | ||||||
| import Components from 'unplugin-vue-components/vite' |  | ||||||
| 
 |  | ||||||
| import { defineConfig } from 'vite' | import { defineConfig } from 'vite' | ||||||
| import Uni from '@dcloudio/vite-plugin-uni' | import Uni from '@dcloudio/vite-plugin-uni' | ||||||
| import UniKuRoot from '@uni-ku/root' | import UniKuRoot from '@uni-ku/root' | ||||||
| @ -35,23 +30,7 @@ export default async () => { | |||||||
|     plugins: [ |     plugins: [ | ||||||
|       Uni(), |       Uni(), | ||||||
|       UniKuRoot(), |       UniKuRoot(), | ||||||
|       UnoCSS(), |       UnoCSS() | ||||||
|     AutoImport({ |  | ||||||
|       imports: [ |  | ||||||
|         'vue', |  | ||||||
|         { |  | ||||||
|           'naive-ui': [ |  | ||||||
|             'useDialog', |  | ||||||
|             'useMessage', |  | ||||||
|             'useNotification', |  | ||||||
|             'useLoadingBar' |  | ||||||
|           ] |  | ||||||
|         } |  | ||||||
|       ] |  | ||||||
|     }), |  | ||||||
|     Components({ |  | ||||||
|       resolvers: [NaiveUiResolver()] |  | ||||||
|     }) |  | ||||||
|     ], |     ], | ||||||
|     css: { |     css: { | ||||||
|       preprocessorOptions: { |       preprocessorOptions: { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user