Compare commits
	
		
			4 Commits
		
	
	
		
			f1fa0208c1
			...
			e782b72b74
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e782b72b74 | |||
| ba0a5384e0 | |||
| ea73fa8b9b | |||
| c9eb55ed5f | 
							
								
								
									
										75
									
								
								auto-imports.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								auto-imports.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,75 @@ | |||||||
|  | /* 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
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | |||||||
|  | /* 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,12 +58,15 @@ | |||||||
|     "@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.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))) |         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))) | ||||||
|       '@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,6 +144,9 @@ 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)) | ||||||
| @ -161,7 +164,13 @@ 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.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))) |         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))) | ||||||
|  |       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) | ||||||
| @ -856,6 +865,16 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -968,6 +987,9 @@ 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'} | ||||||
| @ -1679,6 +1701,9 @@ 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'} | ||||||
| @ -1863,6 +1888,15 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2299,6 +2333,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2569,6 +2606,9 @@ 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} | ||||||
| @ -2639,6 +2679,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2661,6 +2704,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2668,6 +2714,14 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2691,6 +2745,15 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2899,6 +2962,9 @@ 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'} | ||||||
| @ -2922,6 +2988,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -2953,8 +3022,8 @@ packages: | |||||||
|   fb-watchman@2.0.2: |   fb-watchman@2.0.2: | ||||||
|     resolution: {integrity: sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==} |     resolution: {integrity: sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==} | ||||||
| 
 | 
 | ||||||
|   fdir@6.3.0: |   fdir@6.4.3: | ||||||
|     resolution: {integrity: sha512-QOnuT+BOtivR77wYvCWHfGt9s4Pz1VIMbD463vegT5MLqNXy8rYFT/lPVEqf/bhYeT6qmqrNHhsX+rWwe3rOCQ==} |     resolution: {integrity: sha512-PMXmW2y1hDDfTSRc9gaXIuCCRpuoz3Kaz8cUelp3smouvfT632ozg2vrT6lJsHKKOF59YLbOGfAWGUcKEfRMQw==} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
|       picomatch: ^3 || ^4 |       picomatch: ^3 || ^4 | ||||||
|     peerDependenciesMeta: |     peerDependenciesMeta: | ||||||
| @ -3128,6 +3197,10 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -3490,6 +3563,9 @@ 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 | ||||||
| @ -3607,6 +3683,10 @@ 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'} | ||||||
| @ -3643,8 +3723,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.13: |   magic-string@0.30.17: | ||||||
|     resolution: {integrity: sha512-8rYBO+MsWkgjDSOvLomYnzhdwEG51olQ4zL5KXnNJWV5MNmrb4rTZdrtkhxjnD/QyZUqR/Z/XDsUs/4ej2nx0g==} |     resolution: {integrity: sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==} | ||||||
| 
 | 
 | ||||||
|   make-dir@2.1.0: |   make-dir@2.1.0: | ||||||
|     resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} |     resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} | ||||||
| @ -3749,12 +3829,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==} | ||||||
| 
 | 
 | ||||||
| @ -3781,6 +3861,11 @@ 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} | ||||||
| @ -3972,6 +4057,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -4051,6 +4139,12 @@ 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'} | ||||||
| @ -4158,6 +4252,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -4319,6 +4416,9 @@ 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 | ||||||
| @ -4486,6 +4586,9 @@ 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'} | ||||||
| @ -4548,8 +4651,8 @@ packages: | |||||||
|   tinyexec@0.3.0: |   tinyexec@0.3.0: | ||||||
|     resolution: {integrity: sha512-tVGE0mVJPGb0chKhqmsoosjsS+qUnJVGJpZgsHYQcGoPlG3B51R3PouqTgEGH2Dc9jjFyOqOpix6ZHNMXp1FZg==} |     resolution: {integrity: sha512-tVGE0mVJPGb0chKhqmsoosjsS+qUnJVGJpZgsHYQcGoPlG3B51R3PouqTgEGH2Dc9jjFyOqOpix6ZHNMXp1FZg==} | ||||||
| 
 | 
 | ||||||
|   tinyglobby@0.2.5: |   tinyglobby@0.2.12: | ||||||
|     resolution: {integrity: sha512-Dlqgt6h0QkoHttG53/WGADNh9QhcjCAIZMTERAVhdpmIBEejSuLI9ZmGKWzB7tweBjlk30+s/ofi4SLmBeTYhw==} |     resolution: {integrity: sha512-qkf4trmKSIiMTs/E63cxH+ojC2unam7rJ0WrauAzpT3ECNTxGRMlaXxVbfxMUC/w0LaYk6jQ4y/nGR9uBO3tww==} | ||||||
|     engines: {node: '>=12.0.0'} |     engines: {node: '>=12.0.0'} | ||||||
| 
 | 
 | ||||||
|   tmpl@1.0.5: |   tmpl@1.0.5: | ||||||
| @ -4579,6 +4682,9 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -4651,6 +4757,10 @@ 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'} | ||||||
| @ -4696,6 +4806,35 @@ 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'} | ||||||
| @ -4704,6 +4843,10 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -4747,6 +4890,11 @@ 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} | ||||||
| @ -4775,6 +4923,11 @@ 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'} | ||||||
| @ -4847,6 +5000,11 @@ 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. | ||||||
| @ -5982,6 +6140,14 @@ 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))': | ||||||
| @ -6505,6 +6671,8 @@ 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 | ||||||
| 
 | 
 | ||||||
| @ -6726,7 +6894,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.1 |       mlly: 1.7.3 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
| @ -7236,6 +7404,8 @@ 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 | ||||||
| @ -7283,7 +7453,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.2.1 |       pkg-types: 1.3.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 | ||||||
| @ -7423,6 +7593,14 @@ 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 | ||||||
| @ -7472,12 +7650,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.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/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)))': | ||||||
|     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.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-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))) | ||||||
|     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)) | ||||||
| @ -7506,11 +7684,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.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-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)))': | ||||||
|     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.13 |       magic-string: 0.30.17 | ||||||
| 
 | 
 | ||||||
|   '@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: | ||||||
| @ -7663,12 +7841,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.11 |       magic-string: 0.30.17 | ||||||
| 
 | 
 | ||||||
|   '@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.13 |       magic-string: 0.30.17 | ||||||
| 
 | 
 | ||||||
|   '@unocss/scope@0.58.9': {} |   '@unocss/scope@0.58.9': {} | ||||||
| 
 | 
 | ||||||
| @ -7735,8 +7913,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.13 |       magic-string: 0.30.17 | ||||||
|       tinyglobby: 0.2.5 |       tinyglobby: 0.2.12 | ||||||
|       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 | ||||||
| @ -7983,7 +8161,7 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   agent-base@6.0.2: |   agent-base@6.0.2: | ||||||
|     dependencies: |     dependencies: | ||||||
|       debug: 4.3.6 |       debug: 4.4.0 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
| @ -8031,6 +8209,8 @@ 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): | ||||||
| @ -8215,11 +8395,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.3 |       mlly: 1.7.4 | ||||||
|       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.2.1 |       pkg-types: 1.3.1 | ||||||
|       rc9: 2.1.2 |       rc9: 2.1.2 | ||||||
| 
 | 
 | ||||||
|   cac@6.7.14: {} |   cac@6.7.14: {} | ||||||
| @ -8346,6 +8526,8 @@ 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: | ||||||
| @ -8401,6 +8583,11 @@ 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: | ||||||
| @ -8418,6 +8605,8 @@ 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: | ||||||
| @ -8426,6 +8615,12 @@ 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: {} | ||||||
| @ -8438,6 +8633,10 @@ 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: {} | ||||||
| @ -8675,6 +8874,8 @@ 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 | ||||||
| @ -8746,6 +8947,8 @@ 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: {} | ||||||
| @ -8776,10 +8979,9 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       bser: 2.1.1 |       bser: 2.1.1 | ||||||
| 
 | 
 | ||||||
|   fdir@6.3.0(picomatch@4.0.2): |   fdir@6.4.3(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: {} | ||||||
| 
 | 
 | ||||||
| @ -8946,6 +9148,8 @@ 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: | ||||||
| @ -8968,14 +9172,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.3.6 |       debug: 4.4.0 | ||||||
|     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.3.6 |       debug: 4.4.0 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| 
 | 
 | ||||||
| @ -9017,12 +9221,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.3.6 |       debug: 4.4.0 | ||||||
|       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.2.1 |       pkg-types: 1.3.1 | ||||||
|       tsx: 4.17.0 |       tsx: 4.17.0 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - supports-color |       - supports-color | ||||||
| @ -9123,7 +9327,7 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   istanbul-lib-source-maps@4.0.1: |   istanbul-lib-source-maps@4.0.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       debug: 4.3.6 |       debug: 4.4.0 | ||||||
|       istanbul-lib-coverage: 3.2.2 |       istanbul-lib-coverage: 3.2.2 | ||||||
|       source-map: 0.6.1 |       source-map: 0.6.1 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
| @ -9515,6 +9719,8 @@ 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 | ||||||
| @ -9661,6 +9867,12 @@ 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: | ||||||
| @ -9695,7 +9907,7 @@ snapshots: | |||||||
|     dependencies: |     dependencies: | ||||||
|       '@jridgewell/sourcemap-codec': 1.5.0 |       '@jridgewell/sourcemap-codec': 1.5.0 | ||||||
| 
 | 
 | ||||||
|   magic-string@0.30.13: |   magic-string@0.30.17: | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@jridgewell/sourcemap-codec': 1.5.0 |       '@jridgewell/sourcemap-codec': 1.5.0 | ||||||
| 
 | 
 | ||||||
| @ -9779,18 +9991,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.2.1 |       pkg-types: 1.3.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: {} | ||||||
| @ -9809,6 +10021,29 @@ 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: {} | ||||||
| @ -9847,7 +10082,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.2.1 |       pkg-types: 1.3.1 | ||||||
|       ufo: 1.5.4 |       ufo: 1.5.4 | ||||||
| 
 | 
 | ||||||
|   nzh@1.0.13: {} |   nzh@1.0.13: {} | ||||||
| @ -9973,6 +10208,8 @@ 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: {} | ||||||
| @ -10031,16 +10268,28 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   pkg-types@1.1.3: |   pkg-types@1.1.3: | ||||||
|     dependencies: |     dependencies: | ||||||
|       confbox: 0.1.7 |       confbox: 0.1.8 | ||||||
|       mlly: 1.7.1 |       mlly: 1.7.4 | ||||||
|       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.3 |       mlly: 1.7.4 | ||||||
|       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): | ||||||
| @ -10141,6 +10390,8 @@ 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: {} | ||||||
| @ -10327,6 +10578,8 @@ 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 | ||||||
| 
 | 
 | ||||||
| @ -10514,6 +10767,10 @@ 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 | ||||||
| @ -10576,11 +10833,10 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   tinyexec@0.3.0: {} |   tinyexec@0.3.0: {} | ||||||
| 
 | 
 | ||||||
|   tinyglobby@0.2.5: |   tinyglobby@0.2.12: | ||||||
|     dependencies: |     dependencies: | ||||||
|       fdir: 6.3.0(picomatch@4.0.2) |       fdir: 6.4.3(picomatch@4.0.2) | ||||||
|       picomatch: 4.0.2 |       picomatch: 4.0.2 | ||||||
|     optional: true |  | ||||||
| 
 | 
 | ||||||
|   tmpl@1.0.5: {} |   tmpl@1.0.5: {} | ||||||
| 
 | 
 | ||||||
| @ -10605,6 +10861,8 @@ 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: | ||||||
| @ -10651,10 +10909,10 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   unctx@2.3.1: |   unctx@2.3.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       acorn: 8.12.1 |       acorn: 8.14.0 | ||||||
|       estree-walker: 3.0.3 |       estree-walker: 3.0.3 | ||||||
|       magic-string: 0.30.11 |       magic-string: 0.30.17 | ||||||
|       unplugin: 1.12.0 |       unplugin: 1.16.0 | ||||||
| 
 | 
 | ||||||
|   undici-types@5.26.5: {} |   undici-types@5.26.5: {} | ||||||
| 
 | 
 | ||||||
| @ -10679,10 +10937,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.13 |       magic-string: 0.30.17 | ||||||
|       mlly: 1.7.3 |       mlly: 1.7.4 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.2.1 |       pkg-types: 1.3.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 | ||||||
| @ -10697,25 +10955,42 @@ 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.11 |       magic-string: 0.30.17 | ||||||
|       mlly: 1.7.1 |       mlly: 1.7.3 | ||||||
|       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.12.0 |       unplugin: 1.16.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.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-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))): | ||||||
|     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.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-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: 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 | ||||||
| @ -10771,6 +11046,40 @@ 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 | ||||||
| @ -10783,6 +11092,11 @@ 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: | ||||||
| @ -10837,6 +11151,11 @@ 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 | ||||||
| @ -10849,6 +11168,11 @@ 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 | ||||||
| @ -10924,6 +11248,17 @@ 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,43 +1,55 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import {useStatus} from "@/store/status"; | import { useStatus } from '@/store/status' | ||||||
| import { useUserStore } from '@/store' | import { useUserStore } from '@/store' | ||||||
| import { | import { useProvideUserModal } from '@/hooks' | ||||||
|   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,6 +5,7 @@ | |||||||
|     :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,7 +20,8 @@ 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 }"> | ||||||
|  | |||||||
							
								
								
									
										95
									
								
								src/components/talk/message/LinkMessage.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								src/components/talk/message/LinkMessage.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,95 @@ | |||||||
|  | <!-- 完全复制的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,6 +11,7 @@ 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 // 创建群聊消息
 | ||||||
| @ -40,6 +41,7 @@ export const ChatMsgTypeMapping = { | |||||||
|   [ChatMsgTypeCode]: '[代码消息]', |   [ChatMsgTypeCode]: '[代码消息]', | ||||||
|   [ChatMsgTypeMixed]: '[图文消息]', |   [ChatMsgTypeMixed]: '[图文消息]', | ||||||
|   [ChatMsgTypeGroupNotice]: '[群公告]', |   [ChatMsgTypeGroupNotice]: '[群公告]', | ||||||
|  |   [ChatMsgTypeLink]: '[链接]', | ||||||
|   [ChatMsgSysText]: '[系统消息]', |   [ChatMsgSysText]: '[系统消息]', | ||||||
|   [ChatMsgSysGroupCreate]: '[创建群消息]', |   [ChatMsgSysGroupCreate]: '[创建群消息]', | ||||||
|   [ChatMsgSysGroupMemberJoin]: '[加入群消息]', |   [ChatMsgSysGroupMemberJoin]: '[加入群消息]', | ||||||
| @ -69,6 +71,7 @@ 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', | ||||||
| @ -92,5 +95,6 @@ export const ForwardableMessageType = [ | |||||||
|   ChatMsgTypeVideo, |   ChatMsgTypeVideo, | ||||||
|   ChatMsgTypeFile, |   ChatMsgTypeFile, | ||||||
|   ChatMsgTypeLocation, |   ChatMsgTypeLocation, | ||||||
|   ChatMsgTypeCard |   ChatMsgTypeCard, | ||||||
|  |   ChatMsgTypeLink | ||||||
| ] | ] | ||||||
|  | |||||||
| @ -7,25 +7,29 @@ import lodash from 'lodash' | |||||||
| 
 | 
 | ||||||
| export const useTalkRecord = (uid) => { | export const useTalkRecord = (uid) => { | ||||||
|   const dialogueStore = useDialogueStore() |   const dialogueStore = useDialogueStore() | ||||||
|   const { getDialogueList,addDialogueRecord,zpagingComplete } = useDialogueListStore() |   const { | ||||||
|  |     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) => { | ||||||
| @ -49,7 +53,7 @@ export const useTalkRecord = (uid) => { | |||||||
| 
 | 
 | ||||||
|       return el?.scrollTo({ |       return el?.scrollTo({ | ||||||
|         top: 0, |         top: 0, | ||||||
|         behavior: 'smooth' |         behavior: 'smooth', | ||||||
|       }) |       }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -57,7 +61,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') | ||||||
| @ -70,7 +74,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, | ||||||
| @ -81,9 +85,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) | ||||||
| @ -104,8 +108,11 @@ export const useTalkRecord = (uid) => { | |||||||
| 
 | 
 | ||||||
|     const reverseItems = lodash.cloneDeep(items).reverse() |     const reverseItems = lodash.cloneDeep(items).reverse() | ||||||
|     dialogueStore.unshiftDialogueRecord(reverseItems) |     dialogueStore.unshiftDialogueRecord(reverseItems) | ||||||
|     addDialogueRecord(params.direction=='down'?reverseItems:items,params.direction=='down'?'add':'unshift') |     addDialogueRecord( | ||||||
|     zpagingComplete(dialogueStore.index_name) |       params.direction == 'down' ? reverseItems : items, | ||||||
|  |       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
 | ||||||
| @ -133,17 +140,19 @@ 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(item=>item.sequence !== -1) |       let filterList = dialogueList.records.filter( | ||||||
|  |         (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, | ||||||
|       }) |       }) | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @ -152,12 +161,14 @@ 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(item=>item.sequence !== -1) |       let filterList = dialogueList.records.filter( | ||||||
|       if(params.direction=='up'){ |         (item) => item.sequence !== -1, | ||||||
|  |       ) | ||||||
|  |       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,6 +115,7 @@ 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,12 +21,15 @@ | |||||||
|             <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 class="base-info_num text-[32rpx] font-medium"> |                 <span | ||||||
|  |                   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" |                 v-if="groupParams?.groupInfo?.group_type !== 1 && groupType" | ||||||
|                 class="base-info-tag" |                 class="base-info-tag" | ||||||
|                 :style="{ |                 :style="{ | ||||||
|                   borderColor: |                   borderColor: | ||||||
| @ -292,10 +295,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,7 +27,10 @@ | |||||||
|               <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 class="text-[28rpx] font-medium user-info-job-num"> |               <span | ||||||
|  |                 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,19 +2,17 @@ | |||||||
|   <div class="dialog-page"> |   <div class="dialog-page"> | ||||||
|     <ZPaging |     <ZPaging | ||||||
|       use-chat-record-mode |       use-chat-record-mode | ||||||
|       :refresher-enabled="false" |       use-virtual-list | ||||||
|  |       cell-height-mode="dynamic" | ||||||
|  |       :refresher-enabled="true" | ||||||
|       :show-scrollbar="false" |       :show-scrollbar="false" | ||||||
|       :loading-more-enabled="false" |       :loading-more-enabled="true" | ||||||
|       :hide-empty-view="true" |       :hide-empty-view="true" | ||||||
|       height="100%" |       height="100%" | ||||||
|       ref="zpagingRef" |       ref="zpagingRef" | ||||||
|       :use-virtual-list="true" |       v-model="virtualList" | ||||||
|       :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' }" | ||||||
|       @virtualListChange="virtualListChange" |       @scrolltolower="onScrollToLower" | ||||||
|       @scrolltolower="onRefreshLoad" |  | ||||||
|     > |     > | ||||||
|       <template #top> |       <template #top> | ||||||
|         <customNavbar :title="talkParams.username"> |         <customNavbar :title="talkParams.username"> | ||||||
| @ -39,13 +37,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="onRefreshLoad"> 查看更多消息 ... </span> |               <span v-else-if="loadConfig.status == 1" @click="onScrollToLower"> 查看更多消息 ... </span> | ||||||
|               <span v-else class="no-more"> 没有更多消息了 </span> |               <span v-else class="no-more"> 没有更多消息了 </span> | ||||||
|             </div> |             </div> | ||||||
|           </template> --> |           </template> --> | ||||||
| 
 | 
 | ||||||
|       <!-- 数据加载状态栏 --> |       <!-- 数据加载状态栏 --> | ||||||
|       <div class="dialog-list"> |       <div class="dialog-list" @touchstart="handleHidePanel"> | ||||||
|         <div |         <div | ||||||
|           class="message-item" |           class="message-item" | ||||||
|           v-for="item in virtualList" |           v-for="item in virtualList" | ||||||
| @ -170,10 +168,19 @@ | |||||||
|         </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="onRefreshLoad"> |           <span v-else-if="loadConfig.status == 1" @click="onScrollToLower"> | ||||||
|             查看更多消息 ... |             查看更多消息 ... | ||||||
|           </span> |           </span> | ||||||
|           <span v-else class="no-more">没有更多消息了</span> |           <span | ||||||
|  |             v-else-if=" | ||||||
|  |               loadConfig.status != 0 && | ||||||
|  |               loadConfig.status != 1 && | ||||||
|  |               state.localPageLoadDone | ||||||
|  |             " | ||||||
|  |             class="no-more" | ||||||
|  |           > | ||||||
|  |             没有更多消息了 | ||||||
|  |           </span> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <template #bottom> |       <template #bottom> | ||||||
| @ -189,6 +196,7 @@ | |||||||
|                   :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> --> | ||||||
| @ -392,11 +400,12 @@ 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.sessionId = options.sessionId |     state.value.sessionId = options.sessionId | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| @ -409,7 +418,18 @@ 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: { | ||||||
| @ -421,7 +441,9 @@ const onSendMessage = (data = {}) => { | |||||||
|   ServePublishMessage(message) |   ServePublishMessage(message) | ||||||
|     .then(({ code, message }) => { |     .then(({ code, message }) => { | ||||||
|       if (code == 200) { |       if (code == 200) { | ||||||
|         // callBack(true) |         if (callBack) { | ||||||
|  |           callBack(true) | ||||||
|  |         } | ||||||
|       } else { |       } else { | ||||||
|         message.warning(message) |         message.warning(message) | ||||||
|       } |       } | ||||||
| @ -466,7 +488,7 @@ const onSendTextEvent = lodash.throttle((value) => { | |||||||
|     mentions: data.mentionUids, |     mentions: data.mentionUids, | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   onSendMessage(message) |   onSendMessage(message, callBack) | ||||||
| }, 1000) | }, 1000) | ||||||
| 
 | 
 | ||||||
| // 编辑器输入事件 | // 编辑器输入事件 | ||||||
| @ -804,6 +826,35 @@ 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) => { | ||||||
| @ -823,7 +874,7 @@ const initData = async () => { | |||||||
|     no_limit: dialogueList ? 1 : 0, |     no_limit: dialogueList ? 1 : 0, | ||||||
|   } |   } | ||||||
|   await onLoad({ ...objT }) |   await onLoad({ ...objT }) | ||||||
|   zpagingRef.value?.complete(records.value) |   zpagingRef.value?.setLocalPaging(records.value) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //点击跳转到聊天设置页面 | //点击跳转到聊天设置页面 | ||||||
| @ -833,7 +884,7 @@ const toChatSettingsPage = () => { | |||||||
|       '/pages/chatSettings/index?groupId=' + |       '/pages/chatSettings/index?groupId=' + | ||||||
|       talkParams?.receiver_id + |       talkParams?.receiver_id + | ||||||
|       '&sessionId=' + |       '&sessionId=' + | ||||||
|       state.sessionId, |       state.value.sessionId, | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -47,7 +47,7 @@ | |||||||
|               </div> |               </div> | ||||||
| 
 | 
 | ||||||
| 						</div> | 						</div> | ||||||
| 						<div | 						<div style="flex-shrink: 0;" | ||||||
| 							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,104 +1,106 @@ | |||||||
| <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> |     > | ||||||
| 				<div> |       <template #top> | ||||||
| 					<tm-navbar |         <div> | ||||||
| 						class="index_top_navbar" |           <tm-navbar | ||||||
| 						:hideBack="false" |             class="index_top_navbar" | ||||||
| 						hideHome |             :hideBack="false" | ||||||
| 						title="" |             hideHome | ||||||
| 						:leftWidth="420" |             title="" | ||||||
| 					> |             :leftWidth="420" | ||||||
| 						<template v-slot:left> |             :showStatusBar="false" | ||||||
| 							<div class="flex items-center ml-[48rpx]"> |           > | ||||||
| 								<image |             <template v-slot:left> | ||||||
| 									class="w-[72rpx] h-[72rpx]" |               <div class="flex items-center ml-[48rpx]"> | ||||||
| 									style="border-radius: 50%" |                 <image | ||||||
| 									:src="userStore.avatar" |                   class="w-[72rpx] h-[72rpx]" | ||||||
| 									mode="scaleToFill" |                   style="border-radius: 50%;" | ||||||
| 								/> |                   :src="userStore.avatar" | ||||||
| 								<div class="ml-[24rpx] text-[36rpx] font-bold"> |                   mode="scaleToFill" | ||||||
| 									{{ userStore.nickname }} |                 /> | ||||||
| 								</div> |                 <div class="ml-[24rpx] text-[36rpx] font-bold"> | ||||||
| 							</div> |                   {{ userStore.nickname }} | ||||||
| 						</template> |                 </div> | ||||||
| 						<template v-slot:right> |               </div> | ||||||
| 							<div class="mr-[48rpx] popoverBox"> |             </template> | ||||||
| 								<tm-popover position="br" color="#333333" :width="260"> |             <template v-slot:right> | ||||||
| 									<image |               <div class="mr-[48rpx] popoverBox"> | ||||||
| 										class="w-[48rpx] h-[48rpx]" |                 <tm-popover position="br" color="#333333" :width="260"> | ||||||
| 										style="border-radius: 50%" |                   <image | ||||||
| 										:src="addCircle" |                     class="w-[48rpx] h-[48rpx]" | ||||||
| 										mode="scaleToFill" |                     style="border-radius: 50%;" | ||||||
| 									/> |                     :src="addCircle" | ||||||
| 									<template v-slot:label> |                     mode="scaleToFill" | ||||||
| 										<div |                   /> | ||||||
| 											class="w-full h-[208rpx] pt-[22rpx] pb-[32rpx] pl-[14rpx] pr-[12rpx]" |                   <template v-slot:label> | ||||||
| 										> |                     <div | ||||||
| 											<div |                       class="w-full h-[208rpx] pt-[22rpx] pb-[32rpx] pl-[14rpx] pr-[12rpx]" | ||||||
| 												@click="creatGroupChat" |                     > | ||||||
| 												class="flex items-center pl-[22rpx] mb-[32rpx]" |                       <div | ||||||
| 											> |                         @click="creatGroupChat" | ||||||
| 												<div class="mr-[26rpx] flex items-center"> |                         class="flex items-center pl-[22rpx] mb-[32rpx]" | ||||||
| 													<tm-image |                       > | ||||||
| 														:width="40" |                         <div class="mr-[26rpx] flex items-center"> | ||||||
| 														:height="39" |                           <tm-image | ||||||
| 														:src="cahtPopover" |                             :width="40" | ||||||
| 													></tm-image> |                             :height="39" | ||||||
| 												</div> |                             :src="cahtPopover" | ||||||
| 												<div |                           ></tm-image> | ||||||
| 													class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" |                         </div> | ||||||
| 												> |                         <div | ||||||
| 													发起群聊 |                           class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" | ||||||
| 												</div> |                         > | ||||||
| 											</div> |                           发起群聊 | ||||||
| 											<div class="divider"></div> |                         </div> | ||||||
| 											<div |                       </div> | ||||||
| 												@click="toAddressBookPage" |                       <div class="divider"></div> | ||||||
| 												class="flex items-center pl-[22rpx] mt-[32rpx]" |                       <div | ||||||
| 											> |                         @click="toAddressBookPage" | ||||||
| 												<div class="mr-[26rpx] flex items-center"> |                         class="flex items-center pl-[22rpx] mt-[32rpx]" | ||||||
| 													<tm-image |                       > | ||||||
| 														:width="40" |                         <div class="mr-[26rpx] flex items-center"> | ||||||
| 														:height="43" |                           <tm-image | ||||||
| 														:src="zu3289" |                             :width="40" | ||||||
| 													></tm-image> |                             :height="43" | ||||||
| 												</div> |                             :src="zu3289" | ||||||
| 												<div |                           ></tm-image> | ||||||
| 													class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" |                         </div> | ||||||
| 												> |                         <div | ||||||
| 													通讯录 |                           class="leading-[54rpx] text-[32rpx] text-[#FFFFFF] font-bold" | ||||||
| 												</div> |                         > | ||||||
| 											</div> |                           通讯录 | ||||||
| 										</div> |                         </div> | ||||||
| 									</template> |                       </div> | ||||||
| 								</tm-popover> |                     </div> | ||||||
| 							</div> |                   </template> | ||||||
| 						</template> |                 </tm-popover> | ||||||
| 					</tm-navbar> |               </div> | ||||||
| 				</div> |             </template> | ||||||
| 			</template> |           </tm-navbar> | ||||||
| 			<template #refresher="{ refresherStatus }"> |         </div> | ||||||
| 				<custom-refresher :status="refresherStatus" /> |       </template> | ||||||
| 			</template> |       <template #refresher="{ refresherStatus }"> | ||||||
|  |         <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"> | ||||||
| @ -121,88 +123,94 @@ | |||||||
|             /> |             /> | ||||||
|           </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.loadTalkList().then(() => { |   talkStore | ||||||
|     isEmptyViewShow.value = talkStore.talkItems.length === 0; |     .loadTalkList() | ||||||
|   // 数据加载成功 |     .then(() => { | ||||||
|   paging.value.complete(talkStore.talkItems); |       isEmptyViewShow.value = talkStore.talkItems.length === 0 | ||||||
| }).catch(error => { |       // 数据加载成功 | ||||||
|   // 数据加载失败 |       paging.value.complete(talkStore.talkItems) | ||||||
|   console.error('加载失败', error); |     }) | ||||||
|   paging.value.complete(false); |     .catch((error) => { | ||||||
| }); |       // 数据加载失败 | ||||||
| }; |       console.error('加载失败', error) | ||||||
|  |       paging.value.complete(false) | ||||||
|  |     }) | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| // 添加下拉刷新处理函数 | // 添加下拉刷新处理函数 | ||||||
| const onRefresh = () => { | const onRefresh = () => { | ||||||
|   console.log('触发下拉刷新'); |   console.log('触发下拉刷新') | ||||||
|   talkStore.loadTalkList().then(() => { |   talkStore | ||||||
|   // 数据加载成功 |     .loadTalkList() | ||||||
|   paging.value.complete(talkStore.talkItems); |     .then(() => { | ||||||
| }).catch(error => { |       // 数据加载成功 | ||||||
|   // 数据加载失败 |       paging.value.complete(talkStore.talkItems) | ||||||
|   console.error('加载失败', error); |     }) | ||||||
|   paging.value.complete(false); |     .catch((error) => { | ||||||
| }); |       // 数据加载失败 | ||||||
| }; |       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, | ||||||
| @ -214,106 +222,108 @@ const toAddressBookPage = () => { | |||||||
| 
 | 
 | ||||||
| onShow(() => { | onShow(() => { | ||||||
|   // 页面显示时重新加载数据 |   // 页面显示时重新加载数据 | ||||||
| 	talkStore.loadTalkList().then(() => { |   talkStore | ||||||
|     // 如果paging已经初始化,则刷新列表 |     .loadTalkList() | ||||||
|     if (paging.value) { |     .then(() => { | ||||||
|       paging.value.reload(); |       // 如果paging已经初始化,则刷新列表 | ||||||
|     } |       if (paging.value) { | ||||||
|   }).catch(error => { |         paging.value.reload() | ||||||
|     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('79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caaef1334d640773710f8cd96473bacfb190cba595a5d6a9c87d70f0999a3ebb41147213b31b4bdccffca66a56acf3baab5af0154f0dce360079f37709f78e13711036899344bddb0fb4cf0f2890287cb62c3fcbe33368caa5e213624577be8b8420ab75b1f50775ee16142a4321c5d56995f37354a66a969da98d95ba6e65d142ed097e04b411c1ebad2f62866d0ec7e1838420530a9941dbbcd00490199f8b8989ec7fe774a82b3f1c4a71a1a6338dec73760f6e72184147caceb1e8a1884e7251c809c440eb394f5df08a384a639a4710527561343785f238745ba9057ec3d4d5fdf5130d4666761c69db08d31abb01') |   const token = ref('79b5c732d96d2b27a48a99dfd4a5566c43aaa5796242e854ebe3ffc198d6876b9628e7b764d9af65ab5dbb2d517ced88170491b74b048c0ba827c0d3741462cb89dc59ed46653a449af837a8262941caaef1334d640773710f8cd96473bacfb190cba595a5d6a9c87d70f0999a3ebb41147213b31b4bdccffca66a56acf3baab5af0154f0dce360079f37709f78e13711036899344bddb0fb4cf0f2890287cb62c3fcbe33368caa5e213624577be8b8420ab75b1f50775ee16142a4321c5d56995f37354a66a969da98d95ba6e65d142ed097e04b411c1ebad2f62866d0ec7e1838420530a9941dbbcd00490199f8b894b54078d04d4ee86e494023bfc12a4fe79d044f22bef01b0b5f132e8ca151dcd3a1a4150e348641300c622b8af98cfd5d41fb24a8409b2b49446a766ea3886f587db124e0eb7d849ed33e6618fdf2c7f') | ||||||
|   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,9 +99,8 @@ export const useDialogueListStore = createGlobalState(() => { | |||||||
|     zpagingRef.value = params |     zpagingRef.value = params | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const zpagingComplete = (index_name) => { |   const zpagingComplete = (index_name, newRecords) => { | ||||||
|     const item = getDialogueList(index_name) |     zpagingRef.value?.complete(lodash.cloneDeep(newRecords).reverse()) | ||||||
|     zpagingRef.value?.complete(lodash.cloneDeep(item.records).reverse()) |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const addChatRecord = (indexName, item) => { |   const addChatRecord = (indexName, item) => { | ||||||
|  | |||||||
| @ -1,78 +1,98 @@ | |||||||
| <template> | <template> | ||||||
| 	<view> |   <view> | ||||||
| 		<view v-if="props.isPlace" class="statusHeight" :style="{ height: _barHeight + 'px' }"></view> |     <view | ||||||
| 		<view class="fixed l-0 t-0 statusHeightTop flex" :style="{ width: _width + 'px', height: _barHeight + 'px' }"> |       v-if="props.isPlace" | ||||||
| 			<tm-sheet |       class="statusHeight" | ||||||
| 				@click="emits('click', $event)" |       :style="{ height: _barHeight + 'px' }" | ||||||
| 				:blur="_blur" |     ></view> | ||||||
| 				:color="props.color" |     <view | ||||||
| 				:_class="_class" |       class="fixed l-0 t-0 statusHeightTop flex" | ||||||
| 				:_style="_style" |       :style="{ width: _width + 'px', height: _barHeight + 'px' }" | ||||||
| 				:followTheme="props.followTheme" |     > | ||||||
| 				:follow-dark="props.followDark" |       <tm-sheet | ||||||
| 				:dark="props.dark" |         @click="emits('click', $event)" | ||||||
| 				:round="props.round" |         :blur="_blur" | ||||||
| 				:shadow="props.shadow" |         :color="props.color" | ||||||
| 				:outlined="props.outlined" |         :_class="_class" | ||||||
| 				:border="props.border" |         :_style="_style" | ||||||
| 				:borderStyle="props.borderStyle" |         :followTheme="props.followTheme" | ||||||
| 				:borderDirection="props.borderDirection" |         :follow-dark="props.followDark" | ||||||
| 				:text="props.text" |         :dark="props.dark" | ||||||
| 				:transprent="props.transprent" |         :round="props.round" | ||||||
| 				:linear="props.linear" |         :shadow="props.shadow" | ||||||
| 				:linearDeep="props.linearDeep" |         :outlined="props.outlined" | ||||||
| 				:margin="props.margin" |         :border="props.border" | ||||||
| 				:padding="props.padding" |         :borderStyle="props.borderStyle" | ||||||
| 				:height="_barHeight" |         :borderDirection="props.borderDirection" | ||||||
| 				:width="_width" |         :text="props.text" | ||||||
| 				unit="px" |         :transprent="props.transprent" | ||||||
| 				:darkBgColor="props.darkBgColor" |         :linear="props.linear" | ||||||
| 			> |         :linearDeep="props.linearDeep" | ||||||
| 				<view class="statusHeight" :style="{ height: statusBarHeight + 'px' }"></view> |         :margin="props.margin" | ||||||
|  |         :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 class="flex-row flex flex-row-center-start" :style="{ width: _leftWidth + 'rpx' }"> |           <view | ||||||
| 						<!-- #ifndef MP-ALIPAY --> |             class="flex-row flex flex-row-center-start" | ||||||
| 						<tm-icon |             :style="{ width: _leftWidth + 'rpx' }" | ||||||
| 							:unit="props.unit" |           > | ||||||
| 							:font-size="props.iconFontSize" |             <!-- #ifndef MP-ALIPAY --> | ||||||
| 							_class="pointer pb-12 pt-12 px-24" |             <tm-icon | ||||||
| 							:color="_homeColor" |               :unit="props.unit" | ||||||
| 							@click="goback" |               :font-size="props.iconFontSize" | ||||||
| 							v-if="_pages > 1 && !props.hideBack" |               _class="pointer pb-12 pt-12 px-24" | ||||||
| 							name="tmicon-angle-left" |               :color="_homeColor" | ||||||
| 						></tm-icon> |               @click="goback" | ||||||
| 						<tm-icon |               v-if="_pages > 1 && !props.hideBack" | ||||||
| 							:unit="props.unit" |               name="tmicon-angle-left" | ||||||
| 							_class="pointer  pb-12 pt-12 px-24" |             ></tm-icon> | ||||||
| 							@click="backhome" |             <tm-icon | ||||||
| 							v-if="_pages == 1 && !hideHome" |               :unit="props.unit" | ||||||
| 							:color="_homeColor" |               _class="pointer  pb-12 pt-12 px-24" | ||||||
| 							:font-size="props.iconFontSize" |               @click="backhome" | ||||||
| 							name="tmicon-md-home" |               v-if="_pages == 1 && !hideHome" | ||||||
| 						></tm-icon> |               :color="_homeColor" | ||||||
| 						<!-- #endif --> |               :font-size="props.iconFontSize" | ||||||
| 						<slot name="left"></slot> |               name="tmicon-md-home" | ||||||
| 					</view> |             ></tm-icon> | ||||||
| 					<view class="flex flex-row-center-center flex-col" :style="{ width: contentwidth + 'px' }"> |             <!-- #endif --> | ||||||
| 						<slot> |             <slot name="left"></slot> | ||||||
| 							<tm-text |           </view> | ||||||
| 								:unit="props.unit" |           <view | ||||||
| 								_class="text-weight-b text-overflow-1" |             class="flex flex-row-center-center flex-col" | ||||||
| 								:color="_fontColor" |             :style="{ width: contentwidth + 'px' }" | ||||||
| 								:font-size="props.fontSize" |           > | ||||||
| 								:label="_title" |             <slot> | ||||||
| 							></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 class="flex-row flex flex-row-center-end" :style="{ width: _rightWidth + 'rpx' }"> |           <view | ||||||
| 						<slot name="right"></slot> |             class="flex-row flex flex-row-center-end" | ||||||
| 					</view> |             :style="{ width: _rightWidth + 'rpx' }" | ||||||
| 				</view> |           > | ||||||
| 			</tm-sheet> |             <slot name="right"></slot> | ||||||
| 		</view> |           </view> | ||||||
| 	</view> |         </view> | ||||||
|  |       </tm-sheet> | ||||||
|  |     </view> | ||||||
|  |   </view> | ||||||
| </template> | </template> | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| /** | /** | ||||||
| @ -83,148 +103,167 @@ 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 { getCurrentInstance, computed, ref, provide, inject, onUpdated, onMounted, onUnmounted, nextTick, watch, PropType } from 'vue' | import { | ||||||
|  |   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(() => statusBarHeight + _height.value) | const _barHeight = computed(() => | ||||||
|  |   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) | ||||||
| @ -232,53 +271,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,3 +1,8 @@ | |||||||
|  | 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' | ||||||
| @ -30,7 +35,23 @@ 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