Compare commits
	
		
			37 Commits
		
	
	
		
			bad576f5f3
			...
			21b2ca5a07
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 21b2ca5a07 | ||
|  | 19e1c3b1f6 | ||
|  | dee871759e | ||
|  | e23fed8c74 | ||
|  | f3d5a3440c | ||
|  | 7a968f1fe6 | ||
|  | 1b996eafca | ||
|  | bad45f8d82 | ||
|  | efc47a27fd | ||
|  | bda4666782 | ||
|  | 0f92a99b32 | ||
|  | 9e6788dbb2 | ||
|  | 6ec8c46c55 | ||
|  | 6f67273a9a | ||
|  | fbbb30040e | ||
|  | 49f908b174 | ||
|  | 0beaa774e9 | ||
|  | d345b66026 | ||
|  | a43bdaf157 | ||
|  | b7c38704f5 | ||
|  | 2e73eb7e34 | ||
|  | bbf3466085 | ||
|  | 4ab0a5ca81 | ||
|  | 0107ff6217 | ||
|  | 89a3652003 | ||
|  | 7dfda1a3d3 | ||
|  | 5315b0fc0c | ||
|  | e86c8dbf3b | ||
|  | 9ca23ceca7 | ||
|  | 38e0cfcdb6 | ||
|  | f37f283f09 | ||
|  | 8cbb9f3e76 | ||
|  | b6bd978a7a | ||
|  | df440e49e5 | ||
|  | 3c6a3b8370 | ||
|  | 2f2066f3e5 | ||
|  | 7026357c09 | 
							
								
								
									
										23
									
								
								app/api/auth/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								app/api/auth/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | import { getHttp } from '~/api/http.js' | ||||||
|  | 
 | ||||||
|  | export async function senCode(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/user/send', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
|  | export async function userLogin(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/user/login', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
|  | export async function userUpdate(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/user/update', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								app/api/goods/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								app/api/goods/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | |||||||
|  | import { getHttp } from '~/api/http.js' | ||||||
|  | 
 | ||||||
|  | export async function artworkList(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/auction/default/artwork/list', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
|  | export async function defaultDetail(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/auction/default/detail', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
|  | export async function artworkDetail(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/artwork/detail', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
|  | export async function userArtworks(data) { | ||||||
|  |     const http = getHttp() | ||||||
|  |     return await http('/api/v1/m/user/artworks', { | ||||||
|  |         method: 'POST', | ||||||
|  |         body: data, | ||||||
|  |     }) | ||||||
|  | } | ||||||
| @ -1,31 +1,37 @@ | |||||||
| import type { $Fetch } from 'ofetch' |  | ||||||
| 
 | 
 | ||||||
| import { useRuntimeConfig } from '#app' | import { useRuntimeConfig } from '#app' | ||||||
| import { ofetch } from 'ofetch' | import { ofetch } from 'ofetch' | ||||||
|  | import {message} from '@/components/x-message/useMessage.js' | ||||||
|  | import {authStore} from "@/stores/auth/index.js"; | ||||||
|  | let httpStatusErrorHandler | ||||||
| 
 | 
 | ||||||
| type HttpStatusErrorHandler = (message: string, statusCode: number) => void | let http | ||||||
| let httpStatusErrorHandler: HttpStatusErrorHandler |  | ||||||
| 
 |  | ||||||
| let http: $Fetch |  | ||||||
| 
 | 
 | ||||||
| export function setupHttp() { | export function setupHttp() { | ||||||
|   if (http) |   if (http) | ||||||
|     return http |     return http | ||||||
| 
 | 
 | ||||||
|   const config = useRuntimeConfig() |   const config = useRuntimeConfig() | ||||||
|   const baseURL = config.public.apiBase as string |   const baseURL = config.public.NUXT_PUBLIC_API_BASE | ||||||
| 
 |   const {token}= authStore() | ||||||
|  |   const router = useRouter() | ||||||
|   http = ofetch.create({ |   http = ofetch.create({ | ||||||
|     baseURL, |     baseURL, | ||||||
|     headers: { 'Content-Type': 'application/json' }, |     headers: { 'Content-Type': 'application/json' }, | ||||||
|     async onRequest({ options }) { |     async onRequest({ options }) { | ||||||
|       const token = localStorage.getItem('token') |  | ||||||
| 
 |  | ||||||
|       options.headers = { |       options.headers = { | ||||||
|         ...options.headers, |         ...options.headers, | ||||||
|         ...(token && { Authorization: `Bearer ${token}` }), |         Authorization:token.value | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     async onResponse({ response }) { | ||||||
|  |      if (response._data.status===1){ | ||||||
|  |        message.error(response._data.msg) | ||||||
|  |      } | ||||||
|  |      if (response._data.status===401){ | ||||||
|  |        router.replace('/login') | ||||||
|  |      } | ||||||
|  |     }, | ||||||
|     async onResponseError({ response }) { |     async onResponseError({ response }) { | ||||||
|       const { message } = response._data |       const { message } = response._data | ||||||
|       if (Array.isArray(message)) { |       if (Array.isArray(message)) { | ||||||
| @ -43,7 +49,7 @@ export function setupHttp() { | |||||||
|   }) |   }) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export function injectHttpStatusErrorHandler(handler: HttpStatusErrorHandler) { | export function injectHttpStatusErrorHandler(handler) { | ||||||
|   httpStatusErrorHandler = handler |   httpStatusErrorHandler = handler | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1,8 +0,0 @@ | |||||||
| import { getHttp } from './http' |  | ||||||
| 
 |  | ||||||
| export async function getProse() { |  | ||||||
|   const http = getHttp() |  | ||||||
|   return await http('/api/prose', { |  | ||||||
|     method: 'GET', |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
							
								
								
									
										62
									
								
								app/app.vue
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								app/app.vue
									
									
									
									
									
								
							| @ -14,27 +14,71 @@ const mode = computed(() => { | |||||||
|   return color.value |   return color.value | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
|  | // 添加路由中间件来处理过渡方向 | ||||||
|  | const router = useRouter() | ||||||
|  | const route = useRoute() | ||||||
|  | const slideDirection = ref('slide-left') | ||||||
|  | 
 | ||||||
|  | // 记录路由历史 | ||||||
|  | const routeHistory = ref([]) | ||||||
|  | 
 | ||||||
|  | router.beforeEach((to, from) => { | ||||||
|  |   // 记录路由历史 | ||||||
|  |   routeHistory.value.push(from.path) | ||||||
|  |    | ||||||
|  |   // 如果是返回操作(在历史记录中找到目标路由) | ||||||
|  |   if (routeHistory.value.includes(to.path)) { | ||||||
|  |     slideDirection.value = 'slide-right' | ||||||
|  |     // 清除历史记录到返回的位置 | ||||||
|  |     const index = routeHistory.value.indexOf(to.path) | ||||||
|  |     routeHistory.value = routeHistory.value.slice(0, index) | ||||||
|  |   } else { | ||||||
|  |     slideDirection.value = 'slide-left' | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | // 提供过渡名称给页面组件 | ||||||
|  | provide('slideDirection', slideDirection) | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <VanConfigProvider :theme="mode" > |   <VanConfigProvider :theme="mode"> | ||||||
|     <NuxtLoadingIndicator |     <NuxtLoadingIndicator | ||||||
|       color="repeating-linear-gradient(to right,var(--c-primary) 0%,var(--c-primary-active) 100%)" /> |       color="repeating-linear-gradient(to right,var(--c-primary) 0%,var(--c-primary-active) 100%)" /> | ||||||
|     <NuxtLayout> |     <NuxtLayout> | ||||||
|       <NuxtPage/> |       <NuxtPage :transition="{ | ||||||
|  |         name: slideDirection | ||||||
|  |       }" /> | ||||||
|     </NuxtLayout> |     </NuxtLayout> | ||||||
|   </VanConfigProvider> |   </VanConfigProvider> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <style> | <style> | ||||||
| .page-enter-active, | .slide-left-enter-active, | ||||||
| .page-leave-active { | .slide-left-leave-active, | ||||||
|   transition: all 0.2s; | .slide-right-enter-active, | ||||||
|  | .slide-right-leave-active { | ||||||
|  |   transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .page-enter-from, | .slide-left-enter-from { | ||||||
| .page-leave-to { |   transform: translateX(100%); | ||||||
|   opacity: 0; | } | ||||||
|   filter: blur(1rem); | 
 | ||||||
|  | .slide-left-leave-to { | ||||||
|  |   transform: translateX(-100%); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .slide-right-enter-from { | ||||||
|  |   transform: translateX(-100%); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .slide-right-leave-to { | ||||||
|  |   transform: translateX(100%); | ||||||
|  | } | ||||||
|  | :root{ | ||||||
|  |   --safe-area-inset-bottom: env(safe-area-inset-bottom); | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
| @ -11,13 +11,17 @@ const show = computed(() => { | |||||||
|   return false |   return false | ||||||
| }) | }) | ||||||
| const initData=()=>{ | const initData=()=>{ | ||||||
|   active.value=route.path==='/'?0:1 |   active.value=route.path==='/profile'?1:0 | ||||||
| } | } | ||||||
| initData() | 
 | ||||||
|  | onMounted(()=>{ | ||||||
|  |   initData() | ||||||
|  | }) | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|  <div v-if="show"> |  <div v-if="show"> | ||||||
|  | 
 | ||||||
|    <van-tabbar  v-model="active" route placeholder fixed> |    <van-tabbar  v-model="active" route placeholder fixed> | ||||||
|      <van-tabbar-item replace to="/"> |      <van-tabbar-item replace to="/"> | ||||||
|        <span>{{ $t('tabbar.home') }}</span> |        <span>{{ $t('tabbar.home') }}</span> | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useAppHeaderRouteNames as routeWhiteList } from '~/config' | import { useAppHeaderRouteNames as routeWhiteList } from '~/config' | ||||||
| import { homeStore } from "@/stores/home/index.js"; | import { goodStore } from "@/stores/goods/index.js"; | ||||||
| const { fullLive } = homeStore() | const { fullLive } = goodStore() | ||||||
| const route = useRoute() | const route = useRoute() | ||||||
| const router = useRouter() | const router = useRouter() | ||||||
| 
 | 
 | ||||||
| @ -40,7 +40,7 @@ const showLeftArrow = computed(() => route.name && routeWhiteList.includes(route | |||||||
|     placeholder clickable fixed |     placeholder clickable fixed | ||||||
|     @click-left="onBack" |     @click-left="onBack" | ||||||
|   > |   > | ||||||
|     <template #title v-if="route.meta.i18n==='menu.home'"> |     <template #title v-if="route.meta.i18n==='menu.goods'"> | ||||||
| 
 | 
 | ||||||
|       <div class="flex flex-col items-center justify-center"> |       <div class="flex flex-col items-center justify-center"> | ||||||
|         <div class="text-#000000 text-17px mb-5px font-600">{{ title }}</div> |         <div class="text-#000000 text-17px mb-5px font-600">{{ title }}</div> | ||||||
|  | |||||||
| @ -1,13 +0,0 @@ | |||||||
| <script setup> |  | ||||||
| 
 |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
| <div> |  | ||||||
|    |  | ||||||
| </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style scoped> |  | ||||||
| 
 |  | ||||||
| </style> |  | ||||||
| @ -1,12 +0,0 @@ | |||||||
| <script setup> |  | ||||||
| 
 |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
| <div class="w-full h-full bg-[] bg-#606165"> |  | ||||||
| </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style scoped> |  | ||||||
| 
 |  | ||||||
| </style> |  | ||||||
| @ -28,7 +28,7 @@ defineExpose({ showMessage }) | |||||||
|       v-if="visible"  |       v-if="visible"  | ||||||
|       :text="messageText"  |       :text="messageText"  | ||||||
|       :type="messageType"  |       :type="messageType"  | ||||||
|       class="fixed top-20px left-1/2 -translate-x-1/2 z-9999" |       class="fixed top-50px left-1/2 -translate-x-1/2 z-9999" | ||||||
|     /> |     /> | ||||||
|   </transition> |   </transition> | ||||||
| </template> | </template> | ||||||
|  | |||||||
| @ -1,4 +1,5 @@ | |||||||
| <script setup> | <script setup> | ||||||
|  | 
 | ||||||
| import error from '../images/error.png' | import error from '../images/error.png' | ||||||
| import success from '../images/success.png' | import success from '../images/success.png' | ||||||
| import warning from '../images/warning.png' | import warning from '../images/warning.png' | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								app/config/live/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								app/config/live/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -7,7 +7,7 @@ By default, `default.vue` will be used unless an alternative is specified in the | |||||||
| ```vue | ```vue | ||||||
| <script setup lang="ts"> | <script setup lang="ts"> | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
|   layout: 'home', |   layout: 'goods', | ||||||
| }) | }) | ||||||
| </script> | </script> | ||||||
| ``` | ``` | ||||||
|  | |||||||
| @ -2,12 +2,14 @@ | |||||||
|   <main class="flex flex-col min-h-svh"> |   <main class="flex flex-col min-h-svh"> | ||||||
|     <AppHeader class="h-[var(--van-nav-bar-height)]" /> |     <AppHeader class="h-[var(--van-nav-bar-height)]" /> | ||||||
|     <div class="flex-1 flex flex-col"> |     <div class="flex-1 flex flex-col"> | ||||||
|       <slot /> |       <keep-alive> | ||||||
|  |         <slot /> | ||||||
|  |       </keep-alive> | ||||||
|     </div> |     </div> | ||||||
|     <AppFooter v-if="!fullLive" /> |     <AppFooter  /> | ||||||
|   </main> |   </main> | ||||||
| </template> | </template> | ||||||
| <script setup > | <script setup > | ||||||
| import { homeStore } from "@/stores/home/index.js"; | import { goodStore } from "@/stores/goods/index.js"; | ||||||
| const { fullLive } = homeStore() | const { fullLive } = goodStore() | ||||||
| </script> | </script> | ||||||
							
								
								
									
										78
									
								
								app/pages/LiveRoom/components/Broadcast/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								app/pages/LiveRoom/components/Broadcast/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | |||||||
|  | <script setup> | ||||||
|  | import { ref, onMounted, onUnmounted, nextTick } from 'vue'; | ||||||
|  | 
 | ||||||
|  | const list = ref([ | ||||||
|  |   { | ||||||
|  |     a: '领先', | ||||||
|  |     b: '现场竞价', | ||||||
|  |     c: '10:12:12', | ||||||
|  |     d: 'RMB5,500', | ||||||
|  |     e: '我' | ||||||
|  |   } | ||||||
|  | ]); | ||||||
|  | 
 | ||||||
|  | let intervalId = null; | ||||||
|  | 
 | ||||||
|  | const addItem = () => { | ||||||
|  |   list.value.push({ | ||||||
|  |     a: '领先', | ||||||
|  |     b: '现场竞价', | ||||||
|  |     c: '10:12:12', | ||||||
|  |     d: 'RMB5,500', | ||||||
|  |     e: '' | ||||||
|  |   }); | ||||||
|  |   nextTick(() => { | ||||||
|  |     scrollToBottom(); | ||||||
|  |   }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | const scrollToBottom = () => { | ||||||
|  |   const container = document.getElementById('list-container'); | ||||||
|  |   if (container) { | ||||||
|  |     setTimeout(() => { | ||||||
|  |       container.scrollTop = container.scrollHeight; | ||||||
|  |     }, 100); | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | onMounted(() => { | ||||||
|  |   // 每秒添加一条数据 | ||||||
|  | /*  intervalId = setInterval(() => { | ||||||
|  |     addItem(); | ||||||
|  |   }, 1000);*/ | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | onUnmounted(() => { | ||||||
|  |   // 清理定时器 | ||||||
|  |   if (intervalId) { | ||||||
|  |     clearInterval(intervalId); | ||||||
|  |   } | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div | ||||||
|  |       id="list-container" | ||||||
|  |       class="w-344px h-86px overflow-y-auto bg-#fff rounded-4px text-14px text-#939393 pt-7px pb-7px flex flex-col justify-between" | ||||||
|  |   > | ||||||
|  |     <transition-group name="list" tag="div"> | ||||||
|  |       <div v-for="(item, index) in list" :key="index" class="flex flex-shrink-0 h-25px"> | ||||||
|  |         <div class="flex-grow-1 text-center">{{ item.a }}</div> | ||||||
|  |         <div class="flex-grow-1 text-center">{{ item.b }}</div> | ||||||
|  |         <div class="flex-grow-1 text-center">{{ item.c }}</div> | ||||||
|  |         <div class="flex-grow-1 text-center">{{ item.d }}</div> | ||||||
|  |         <div class="flex-grow-1 text-center">{{ item.e }}</div> | ||||||
|  |       </div> | ||||||
|  |     </transition-group> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped> | ||||||
|  | .list-enter-active, .list-leave-active { | ||||||
|  |   transition: all 0.5s ease; | ||||||
|  | } | ||||||
|  | .list-enter-from, .list-leave-to { | ||||||
|  |   opacity: 0; | ||||||
|  |   transform: translateY(20px); | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										55
									
								
								app/pages/LiveRoom/components/PaymentInput/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								app/pages/LiveRoom/components/PaymentInput/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | |||||||
|  | <script setup> | ||||||
|  | const props = defineProps({ | ||||||
|  |   show: { | ||||||
|  |     type: Boolean, | ||||||
|  |     default: false | ||||||
|  |   }, | ||||||
|  |   price: { | ||||||
|  |     type: Number, | ||||||
|  |     default: 0 | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | const emit = defineEmits(['update:show']) | ||||||
|  | const payStatus=ref(0) | ||||||
|  | const changePayStatus=()=>{ | ||||||
|  |   payStatus.value=payStatus.value===0?1:0 | ||||||
|  | } | ||||||
|  | const close=()=>{ | ||||||
|  |   emit('update:show',false) | ||||||
|  | } | ||||||
|  | const confirm=()=>{ | ||||||
|  |   emit('update:show',false) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div> | ||||||
|  |     <van-dialog :show="show"  show-cancel-button @close="close" @confirm="confirm"> | ||||||
|  |       <div class="flex flex-col pt-18px pb-13px justify-between items-center h-144px"> | ||||||
|  |         <template v-if="payStatus===0"> | ||||||
|  |           <div class="text-#000 text-16px font-600 ">支付全部</div> | ||||||
|  |           <div class="text-#000 text-16px ">RMB 5,000</div> | ||||||
|  |         </template> | ||||||
|  |         <template v-if="payStatus===1"> | ||||||
|  |           <div class="text-#000 text-16px font-600 ">支付部分</div> | ||||||
|  |           <input class="w-272px h-48px bg-#F3F3F3 px-11px text-16px" type="text" placeholder="最多RMB5,000"> | ||||||
|  |         </template> | ||||||
|  | 
 | ||||||
|  |         <div class="text-#2B53AC text-14px" @click="changePayStatus">{{payStatus===0 ? '支付部分' : '支付全部'}}</div> | ||||||
|  |       </div> | ||||||
|  |     </van-dialog> | ||||||
|  |   </div> | ||||||
|  | 
 | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | :deep(.van-hairline--top.van-dialog__footer){ | ||||||
|  | &>.van-button{ | ||||||
|  |   border-top: 1px solid #E7E7E7; | ||||||
|  |   &.van-dialog__cancel{ | ||||||
|  |     border-right: 1px solid #E7E7E7; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										44
									
								
								app/pages/LiveRoom/components/PaymentResults/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								app/pages/LiveRoom/components/PaymentResults/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,44 @@ | |||||||
|  | <script setup> | ||||||
|  | import successImg from '@/static/images/zu5554@2x.png' | ||||||
|  | import errorImg from '@/static/images/zu5561@2x.png' | ||||||
|  | const props = defineProps({ | ||||||
|  |   show: { | ||||||
|  |     type: Boolean, | ||||||
|  |     default: false | ||||||
|  |   }, | ||||||
|  |   type: { | ||||||
|  |     type: String, | ||||||
|  |     default: 'success' | ||||||
|  |   }, | ||||||
|  |   price: { | ||||||
|  |     type: Number, | ||||||
|  |     default: 0 | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | const emit = defineEmits(['cancel','update:show']) | ||||||
|  | const cancel= () => { | ||||||
|  |   emit('update:show', false) | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div> | ||||||
|  |     <van-dialog :show="show"  show-cancel-button :show-confirm-button="false" cancelButtonText="返回" cancelButtonColor="#2B53AC" @cancel="cancel"> | ||||||
|  |       <div class="h-145px relative flex justify-center"> | ||||||
|  |         <img :src="type==='success' ? successImg : errorImg" class="w-119px h-120px absolute top--74px z-9999 left-1/2 transform translate-x--1/2" alt=""> | ||||||
|  |         <div class="mt-94px text-#A9A9A9 text-16px">{{price}}</div> | ||||||
|  |       </div> | ||||||
|  |     </van-dialog> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped> | ||||||
|  | :deep(.van-dialog) { | ||||||
|  |   overflow: visible!important; | ||||||
|  | } | ||||||
|  | :deep(.van-hairline--top.van-dialog__footer){ | ||||||
|  |   border-top: 1px solid #E7E7E7; | ||||||
|  |   border-bottom-left-radius:8px ; | ||||||
|  |   border-bottom-right-radius:8px ; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										27
									
								
								app/pages/LiveRoom/components/SideButton/PressableButton.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								app/pages/LiveRoom/components/SideButton/PressableButton.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | |||||||
|  | <script setup> | ||||||
|  | import {ref, defineEmits} from "vue"; | ||||||
|  | 
 | ||||||
|  | const emit = defineEmits(["click"]); | ||||||
|  | 
 | ||||||
|  | const isButtonActive = ref(false); | ||||||
|  | 
 | ||||||
|  | const handleButtonPress = () => { | ||||||
|  |   isButtonActive.value = true; | ||||||
|  | }; | ||||||
|  | const handleButtonRelease = () => { | ||||||
|  |   isButtonActive.value = false; | ||||||
|  |   emit("click") | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | <template> | ||||||
|  |   <div | ||||||
|  |       :class="[ | ||||||
|  |       'transition-all duration-200', | ||||||
|  |       isButtonActive ? 'scale-95' : '' | ||||||
|  |     ]" | ||||||
|  |       @touchstart="handleButtonPress" | ||||||
|  |       @touchend="handleButtonRelease" | ||||||
|  |   > | ||||||
|  |     <slot></slot> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
							
								
								
									
										44
									
								
								app/pages/LiveRoom/components/SideButton/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								app/pages/LiveRoom/components/SideButton/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,44 @@ | |||||||
|  | <script setup> | ||||||
|  | import { ref } from "vue"; | ||||||
|  | import lockClosed from "~/static/images/lockdfd@2x.png"; | ||||||
|  | import lockOpen from "~/static/images/lock4@2x.png"; | ||||||
|  | import { liveStore } from "~/stores/live/index.js"; | ||||||
|  | import PressableButton from './PressableButton.vue' | ||||||
|  | const { quoteStatus, changeStatus,show,show1 } = liveStore(); | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div class="bg-white w-60px rounded-l-4px overflow-hidden"> | ||||||
|  |     <!-- 拍品信息 --> | ||||||
|  |     <PressableButton> | ||||||
|  |       <div class="w-60px h-60px text-center border-b border-gray-300 flex flex-col justify-center items-center text-#7D7D7F text-12px"> | ||||||
|  |         <div>拍品</div> | ||||||
|  |         <div>(1/188)</div> | ||||||
|  |       </div> | ||||||
|  |     </PressableButton> | ||||||
|  |     <!-- 出价开关 --> | ||||||
|  |     <PressableButton @click="changeStatus"> | ||||||
|  |       <div class="w-60px h-60px text-center border-b border-gray-300 flex flex-col justify-center items-center"> | ||||||
|  |         <div class="mb-1"> | ||||||
|  |           <img | ||||||
|  |               :src="quoteStatus ? lockClosed : lockOpen" | ||||||
|  |               class="w-16px h-21px" | ||||||
|  |               alt="锁图标" | ||||||
|  |           /> | ||||||
|  |         </div> | ||||||
|  |         <div :class="quoteStatus ? 'text-gray-500' : 'text-blue-600'" class="text-10px transition-colors duration-200"> | ||||||
|  |           {{ quoteStatus ? '关闭出价' : '开启出价' }} | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </PressableButton> | ||||||
|  |     <!-- 支付 --> | ||||||
|  |     <PressableButton @click="show = true"> | ||||||
|  |       <div class="w-60px h-60px text-center border-b border-gray-300 flex flex-col justify-center items-center text-yellow-600"> | ||||||
|  |         <div class="text-10px">RMB</div> | ||||||
|  |         <div class="text-12px">5,000</div> | ||||||
|  |         <div class="text-10px">去支付</div> | ||||||
|  |       </div> | ||||||
|  |     </PressableButton> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
| @ -2,21 +2,31 @@ | |||||||
| import {ref, onMounted, onBeforeUnmount} from 'vue' | import {ref, onMounted, onBeforeUnmount} from 'vue' | ||||||
| import Aliplayer from 'aliyun-aliplayer' | import Aliplayer from 'aliyun-aliplayer' | ||||||
| import 'aliyun-aliplayer/build/skins/default/aliplayer-min.css' | import 'aliyun-aliplayer/build/skins/default/aliplayer-min.css' | ||||||
| import lock4 from '@/static/images/lock4@2x.png' | import sideButton from '~/pages/LiveRoom/components/SideButton/index.vue' | ||||||
| import lockdfd from '@/static/images/lockdfd@2x.png' | import broadcast from '~/pages/LiveRoom/components/Broadcast/index.vue' | ||||||
|  | import {liveStore} from "~/stores/live/index.js"; | ||||||
|  | import paymentResults from '~/pages/LiveRoom/components/PaymentResults/index.vue' | ||||||
|  | import paymentInput from '~/pages/LiveRoom/components/PaymentInput/index.vue' | ||||||
|  | import PressableButton from '~/pages/LiveRoom/components/SideButton/PressableButton.vue' | ||||||
|  | 
 | ||||||
| const player = ref(null) | const player = ref(null) | ||||||
| const quoteStatus = ref(false) | const {quoteStatus, changeStatus, show, playerId, show1} = liveStore() | ||||||
| const isPlayerReady = ref(false) | const isPlayerReady = ref(false) | ||||||
| const config = useRuntimeConfig() |  | ||||||
| const props = defineProps({ | const props = defineProps({ | ||||||
|   fullLive: { |   fullLive: { | ||||||
|     type: Boolean, |     type: Boolean, | ||||||
|     default: true, |     default: true, | ||||||
|   }, |   }, | ||||||
| }) | }) | ||||||
|  | 
 | ||||||
|  | definePageMeta({ | ||||||
|  |   title: '主页', | ||||||
|  |   i18n: 'login.title', | ||||||
|  | }) | ||||||
|  | const config = useRuntimeConfig() | ||||||
| const playerConfig = { | const playerConfig = { | ||||||
|   id: 'J_prismPlayer', |   id: playerId.value, | ||||||
|   source: 'artc://live-pull-sh-01.szjixun.cn/live/live?auth_key=1736748343-0-0-feef65166e5cc62957c35b6e3eec82a1', |   source: config.public.NUXT_PUBLIC_PLAYER_SOURCE, | ||||||
|   isLive: true, |   isLive: true, | ||||||
|   preload: true, |   preload: true, | ||||||
|   autoplayPolicy: {fallbackToMute: true}, |   autoplayPolicy: {fallbackToMute: true}, | ||||||
| @ -47,12 +57,9 @@ const initializePlayer = () => { | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const changeStatus = () => { |  | ||||||
|   quoteStatus.value = !quoteStatus.value |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   initializePlayer() | /*  initializePlayer()*/ | ||||||
| }) | }) | ||||||
| onBeforeUnmount(() => { | onBeforeUnmount(() => { | ||||||
|   if (player.value) { |   if (player.value) { | ||||||
| @ -60,90 +67,88 @@ onBeforeUnmount(() => { | |||||||
|     player.value = null |     player.value = null | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
|  | const goPay = () => { | ||||||
|  |   show.value = true | ||||||
|  | } | ||||||
|  | const fullLive1 = ref(false) | ||||||
|  | 
 | ||||||
|  | watch(()=>{ | ||||||
|  |   return props.fullLive | ||||||
|  | }, (newVal) => { | ||||||
|  |   if (newVal) { | ||||||
|  |     setTimeout(() => { | ||||||
|  |       fullLive1.value = true | ||||||
|  |     }, 400) | ||||||
|  |   }else { | ||||||
|  |     fullLive1.value = false | ||||||
|  |   } | ||||||
|  | }) | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="relative h-full"> |   <div class="relative h-full"> | ||||||
|     <div id="J_prismPlayer" class="w-screen" |     <div class="w-full h-full"> | ||||||
|          :style="fullLive?'height: calc(100vh - var(--van-nav-bar-height))':'height:100%'"></div> |       <video | ||||||
|     <template v-if="fullLive"> |           class="h-full w-full" | ||||||
|       <div class="absolute bg-#fff w-60px top-196px right-0 z-999 rounded-l-4px"> |           autoplay | ||||||
|         <div |           loop | ||||||
|             class="w-full h-60px text-#7D7D7F text-12px flex flex-col justify-center items-center border-b-1px border-b-#D3D3D3"> |           muted | ||||||
|           <div>拍品</div> |           playsinline | ||||||
|           <div>(1/188)</div> |           style="  object-fit: cover" | ||||||
|         </div> |       > | ||||||
|         <div class="w-full h-60px flex flex-col items-center justify-center border-b-1px border-b-#D3D3D3" |         <source src="@/static/video/example.mp4" type="video/mp4" /> | ||||||
|              @click="changeStatus"> |         您的浏览器不支持 HTML5 视频。 | ||||||
|           <div class="mb-3px"> |       </video> | ||||||
|             <img :src="quoteStatus ? lockdfd : lock4" |     </div> | ||||||
|                  class="w-16px h-21px" | <!--    <div :id="playerId" class="w-screen" | ||||||
|                  alt=""> |          :style="fullLive?'height: calc(100vh - var(--van-nav-bar-height))':'height:100%'"></div>--> | ||||||
|  | 
 | ||||||
|  |     <transition> | ||||||
|  |       <div v-if="fullLive1"> | ||||||
|  | 
 | ||||||
|  |         <sideButton class="absolute  top-196px right-0 z-999"></sideButton> | ||||||
|  |         <div class="absolute left-1/2 transform -translate-x-1/2 flex flex-col items-center" style="bottom:calc(var(--safe-area-inset-bottom) + 26px)"> | ||||||
|  |           <div class="text-16px text-#FFB25F font-600"> | ||||||
|  |             当前价:RMB | ||||||
|  |             <van-rolling-text class="my-rolling-text" :start-num="0" :target-num="3000" direction="up"/> | ||||||
|           </div> |           </div> | ||||||
|           <div :class="quoteStatus ? 'text-#7D7D7F' : 'text-#2B53AC'" |           <div class="text-16px text-#fff font-600"> | ||||||
|                class="text-10px"> |             下口价:RMB | ||||||
|             {{ quoteStatus ? '关闭出价' : '开启出价' }} |             <van-rolling-text class="my-rolling-text1" :start-num="0" :target-num="3500" direction="up"/> | ||||||
|           </div> |           </div> | ||||||
|  |           <PressableButton> | ||||||
|  |             <div | ||||||
|  |                 :class="`w-344px h-[40px] ${quoteStatus ? 'bg-#FFB25F' : 'bg-#D6D6D8'} rounded-4px ${quoteStatus ? 'text-#fff' : 'text-#7D7D7F'} text-14px flex justify-center items-center mt-10px mb-10px`"> | ||||||
|  |               {{ quoteStatus ? '确认出价 RMB 3,000' : '点击"开启出价",即刻参与竞拍 ' }} | ||||||
|  |             </div> | ||||||
|  |           </PressableButton> | ||||||
|  |           <broadcast></broadcast> | ||||||
|         </div> |         </div> | ||||||
|         <div |         <paymentInput v-model:show="show"/> | ||||||
|             class="w-full h-60px text-#DD9C56  flex flex-col justify-center items-center "> |         <div> | ||||||
|           <div class="text-10px ">RMB</div> |  | ||||||
|           <div class="text-12px">5,000</div> |  | ||||||
|           <div class="text-10px">去支付</div> |  | ||||||
|         </div> |         </div> | ||||||
|  |         <paymentResults v-model:show="show1" type="error"/> | ||||||
|       </div> |       </div> | ||||||
|       <div class="absolute top-505px left-1/2 transform -translate-x-1/2 flex flex-col items-center"> | 
 | ||||||
|         <div class="text-16px text-#FFB25F font-600"> |     </transition> | ||||||
|           当前价:RMB | 
 | ||||||
|           <van-rolling-text class="my-rolling-text" :start-num="0" :target-num="3000" direction="up"/> |  | ||||||
|         </div> |  | ||||||
|         <div class="text-16px text-#fff font-600"> |  | ||||||
|           下口价:RMB |  | ||||||
|           <van-rolling-text class="my-rolling-text1" :start-num="0" :target-num="3500" direction="up"/> |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|             :class="`w-344px h-[40px] ${quoteStatus ? 'bg-#FFB25F' : 'bg-#D6D6D8'} rounded-4px ${quoteStatus ? 'text-#fff' : 'text-#7D7D7F'} text-14px flex justify-center items-center mt-10px mb-10px`"> |  | ||||||
|           {{ quoteStatus ? '确认出价 RMB 3,000' : '点击"开启出价",即刻参与竞拍 ' }} |  | ||||||
|         </div> |  | ||||||
|         <div class="w-344px h-86px bg-#fff rounded-4px text-14px text-#939393 pt-7px pb-7px flex flex-col justify-between"> |  | ||||||
|           <div class="flex"> |  | ||||||
|             <div class="flex-grow-1 text-center">领先</div> |  | ||||||
|             <div class="flex-grow-1 text-center">现场竞价</div> |  | ||||||
|             <div class="flex-grow-1 text-center">10:12:12</div> |  | ||||||
|             <div class="flex-grow-1 text-center">RMB5,500</div> |  | ||||||
|             <div class="flex-grow-1 text-center">我</div> |  | ||||||
|           </div> |  | ||||||
|           <div class="flex"> |  | ||||||
|             <div class="flex-grow-1 text-center">领先</div> |  | ||||||
|             <div class="flex-grow-1 text-center">现场竞价</div> |  | ||||||
|             <div class="flex-grow-1 text-center">10:12:12</div> |  | ||||||
|             <div class="flex-grow-1 text-center">RMB5,500</div> |  | ||||||
|             <div class="flex-grow-1 text-center">我</div> |  | ||||||
|           </div> |  | ||||||
|           <div class="flex"> |  | ||||||
|             <div class="flex-grow-1 text-center">领先</div> |  | ||||||
|             <div class="flex-grow-1 text-center">现场竞价</div> |  | ||||||
|             <div class="flex-grow-1 text-center">10:12:12</div> |  | ||||||
|             <div class="flex-grow-1 text-center">RMB5,500</div> |  | ||||||
|             <div class="flex-grow-1 text-center">我</div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </template> |  | ||||||
| 
 | 
 | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | <style> | ||||||
| <style scoped> | :root:root { | ||||||
| .grid-container { |   --van-dialog-radius: 8px | ||||||
|   display: grid; |  | ||||||
|   grid-template-columns: repeat(5, 1fr); |  | ||||||
|   grid-template-rows: repeat(3, 1fr); |  | ||||||
| } | } | ||||||
| .grid-item { | </style> | ||||||
|   display: flex; | <style scoped> | ||||||
|   justify-content: center; | .v-enter-active, | ||||||
|   align-items: center; | .v-leave-active { | ||||||
|  |   transition: opacity 0.3s ease; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .v-enter-from, | ||||||
|  | .v-leave-to { | ||||||
|  |   opacity: 0; | ||||||
| } | } | ||||||
| .my-rolling-text { | .my-rolling-text { | ||||||
|   --van-rolling-text-item-width: 10px; |   --van-rolling-text-item-width: 10px; | ||||||
|  | |||||||
							
								
								
									
										15
									
								
								app/pages/home/components/Cescribe/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								app/pages/home/components/Cescribe/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | |||||||
|  | <script setup> | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div class="px-16px pt-14px"> | ||||||
|  |     <div class="text-#575757 text-14px"> | ||||||
|  |       这里是后台富文本配置的说明,啊即可打开三等奖撒度老师的湿答答是快乐的阿四大皆空 | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped> | ||||||
|  | 
 | ||||||
|  | </style> | ||||||
							
								
								
									
										53
									
								
								app/pages/home/components/Column/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								app/pages/home/components/Column/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="flex flex-1 flex-col gap-[16px]"> | ||||||
|  |     <div | ||||||
|  |         v-for="(item, index) in items" | ||||||
|  |         :key="index" | ||||||
|  |         class="w-full" | ||||||
|  |         @click="openShow(item,index)" | ||||||
|  |     > | ||||||
|  |       <div class="relative w-full"> | ||||||
|  |         <img | ||||||
|  |             :src="item.artwork?.hdPic" | ||||||
|  |             class="w-full object-cover rounded-4px" | ||||||
|  | 
 | ||||||
|  |         /> | ||||||
|  |         <div | ||||||
|  |             class="absolute left-[8px] top-[8px] h-[17px] w-[45px] flex items-center justify-center bg-[#2b53ac] text-[12px] text-[#fff]" | ||||||
|  |         > | ||||||
|  |           LOT{{ item.index+1 }} | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="pt-[8px]"> | ||||||
|  |         <div class="text-[14px] text-[#000000] leading-[20px]"> | ||||||
|  |           {{ item.name }} | ||||||
|  |         </div> | ||||||
|  |         <div class="mt-[4px] text-[12px] text-[#575757]"> | ||||||
|  |           起拍价:{{ item?.startPrice??0 }} | ||||||
|  |         </div> | ||||||
|  |         <div | ||||||
|  |             v-if="item.soldPrice" | ||||||
|  |             class="mt-[4px] text-[12px] text-[#b58047]" | ||||||
|  |         > | ||||||
|  |           成交价:{{  item?.startPrice??0  }} | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script setup> | ||||||
|  | const props = defineProps({ | ||||||
|  |   items: Array, | ||||||
|  |   colIndex: { | ||||||
|  |     type: Number, | ||||||
|  |     default: 0 | ||||||
|  |   } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | const emit = defineEmits(['openShow']); | ||||||
|  | 
 | ||||||
|  | const openShow = (item,index) => { | ||||||
|  |   emit('openShow', item,index); | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										78
									
								
								app/pages/home/components/ItemList/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								app/pages/home/components/ItemList/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | |||||||
|  | <script setup> | ||||||
|  | import Column from "~/pages/home/components/Column/index.vue"; | ||||||
|  | import {goodStore} from "~/stores/goods"; | ||||||
|  | import {artworkDetail, artworkList} from "~/api/goods"; | ||||||
|  | import {useRect} from "@vant/use"; | ||||||
|  | const {itemList, pageRef,auctionDetail,liveRef,artWorkDetail,currentItem} = goodStore(); | ||||||
|  | const loading = ref(false); | ||||||
|  | const showHeight = ref(''); | ||||||
|  | const show = ref(false); | ||||||
|  | const loading1 = ref(false); | ||||||
|  | const finished = ref(false); | ||||||
|  | const getArtworkList=async ()=>{ | ||||||
|  |   const res= await artworkList({auctionUuid: auctionDetail.value.uuid,...pageRef.value}) | ||||||
|  |   if (res.status===0){ | ||||||
|  |     itemList.value.push(...res.data.data) | ||||||
|  |     pageRef.value.itemCount=res.data.count | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | const loadData = async () => { | ||||||
|  |   pageRef.value.page++ | ||||||
|  |   await getArtworkList() | ||||||
|  |   loading.value = false; | ||||||
|  |   if (pageRef.value.itemCount <= itemList.value.length) { | ||||||
|  |     finished.value = true | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  | const columns = computed(() => { | ||||||
|  |   const result = [[], []]; | ||||||
|  |   itemList.value.forEach((item, index) => { | ||||||
|  |     result[index % 2].push({...item, index}); | ||||||
|  |   }); | ||||||
|  |   return result; | ||||||
|  | }); | ||||||
|  | const refreshData = async () => { | ||||||
|  |   pageRef.value.page = 1 | ||||||
|  |   finished.value=false | ||||||
|  |   const res= await artworkList({auctionUuid: auctionDetail.value.uuid,...pageRef.value}) | ||||||
|  |   if (res.status===0){ | ||||||
|  |     itemList.value=res.data.data | ||||||
|  |     pageRef.value.itemCount=res.data.count | ||||||
|  |   } | ||||||
|  |   loading1.value = false | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const getDetail=async ()=>{ | ||||||
|  |  const res=await artworkDetail({uuid:currentItem.value.artworkUuid}) | ||||||
|  |   if (res.status===0){ | ||||||
|  |     artWorkDetail.value | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | const openShow = (item,index) => { | ||||||
|  |   currentItem.value=item | ||||||
|  |   getDetail() | ||||||
|  |   const rect = useRect(liveRef.value.$el); | ||||||
|  |   showHeight.value = rect.height; | ||||||
|  |   nextTick(() => { | ||||||
|  |     show.value = true; | ||||||
|  |   }); | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | <template> | ||||||
|  |   <div class="px-[16px] pt-[16px]"> | ||||||
|  |     <van-pull-refresh v-model="loading1" success-text="刷新成功" @refresh="refreshData"> | ||||||
|  |       <van-list :immediate-check="false" v-model:loading="loading" :finished="finished" finished-text="没有更多了" | ||||||
|  |                 @load="loadData"> | ||||||
|  |         <div class="w-full flex gap-[16px]"> | ||||||
|  |           <Column v-for="(column, colIndex) in columns" :key="colIndex" :colIndex="colIndex" :items="column" @openShow="openShow" /> | ||||||
|  |         </div> | ||||||
|  |       </van-list> | ||||||
|  |     </van-pull-refresh> | ||||||
|  |     <van-action-sheet teleport="#__nuxt" :round="false" v-model:show="show" title="拍品详情"> | ||||||
|  |       <div class="content bg-[#F0F0F0]" :style="`height: calc(100vh - ${showHeight + 85}px)`"> | ||||||
|  |         <itemDetail/> | ||||||
|  |       </div> | ||||||
|  |     </van-action-sheet> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
| @ -1,257 +1,69 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import liveBroadcast from '@/components/liveBroadcast/index.vue' | import LiveRoom from '@/pages/LiveRoom/index.client.vue'; | ||||||
| import {useRect} from '@vant/use'; | import {goodStore} from "@/stores/goods/index.js"; | ||||||
| import LiveRoom  from '@/pages/LiveRoom/index.client.vue' | import ItemList from './components/ItemList/index.vue' | ||||||
| import itemDetail from '@/components/itemDetail/index.vue' | import Cescribe from './components/Cescribe/index.vue' | ||||||
| 
 | import {artworkList} from "~/api/goods/index.js"; | ||||||
| import { homeStore } from "@/stores/home/index.js"; | const {fullLive,getAuctionDetail,auctionDetail,itemList,pageRef,liveRef} = goodStore(); | ||||||
| const { fullLive } = homeStore() |  | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
|   layout: 'default', |   layout: 'default', | ||||||
|   i18n: 'menu.home', |   i18n: 'menu.home', | ||||||
| }) | }) | ||||||
| const liveRef = ref(null) | const changeLive = () => { | ||||||
| const loading = ref(false) |   fullLive.value = true; | ||||||
| const finished = ref(false) | }; | ||||||
| const refreshing = ref(false) | const initData=async ()=>{ | ||||||
| const list = ref([{ |   await getAuctionDetail() | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/637d95b4-2ae9-4a74-bd60-a3a9d2ca2ca0.png', |  const res= await artworkList({auctionUuid: auctionDetail.value.uuid,...pageRef.value}) | ||||||
|   title: '张天赐 | 日出而作,日落而息', |   if (res.status===0){ | ||||||
|   startingPrice: 'RMB 1,000', |     itemList.value=res.data.data | ||||||
|   transactionPrice: 'RMB 10,000', |     pageRef.value.itemCount=res.data.count | ||||||
| }, { |   } | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/f7b65e23-ce21-41b4-8e58-9e6dc6950727.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: '', |  | ||||||
| }, { |  | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/41eceb23-d168-4049-ae8e-48c5328b192f.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: '', |  | ||||||
| }, { |  | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/25c3f03c-9e0b-456b-963f-79b3d812c89a.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: '', |  | ||||||
| }, { |  | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/25c3f03c-9e0b-456b-963f-79b3d812c89a.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: '', |  | ||||||
| }, { |  | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/25c3f03c-9e0b-456b-963f-79b3d812c89a.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: '', |  | ||||||
| },{ |  | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/637d95b4-2ae9-4a74-bd60-a3a9d2ca2ca0.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: 'RMB 10,000', |  | ||||||
| },{ |  | ||||||
|   image: 'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/637d95b4-2ae9-4a74-bd60-a3a9d2ca2ca0.png', |  | ||||||
|   title: '张天赐 | 日出而作,日落而息', |  | ||||||
|   startingPrice: 'RMB 1,000', |  | ||||||
|   transactionPrice: 'RMB 10,000', |  | ||||||
| }]) |  | ||||||
| const page = ref(1) |  | ||||||
| 
 |  | ||||||
| // 加载数据 |  | ||||||
| async function loadData() { |  | ||||||
|   // try { |  | ||||||
|   //   loading.value = true |  | ||||||
|   //   // 模拟API请求 |  | ||||||
|   //   const {data} = await fetchAuctionList({page: page.value}) |  | ||||||
|   // |  | ||||||
|   //   if (refreshing.value) { |  | ||||||
|   //     list.value = [] |  | ||||||
|   //     refreshing.value = false |  | ||||||
|   //   } |  | ||||||
|   // |  | ||||||
|   //   list.value.push(...data) |  | ||||||
|   //   page.value++ |  | ||||||
|   // |  | ||||||
|   //   // 如果没有更多数据了 |  | ||||||
|   //   if (data.length < 10) { |  | ||||||
|   //     finished.value = true |  | ||||||
|   //   } |  | ||||||
|   // } catch (error) { |  | ||||||
|   //   console.error(error) |  | ||||||
|   // } finally { |  | ||||||
|   //   loading.value = false |  | ||||||
|   // } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 下拉刷新 |  | ||||||
| function onRefresh() { |  | ||||||
|   finished.value = false |  | ||||||
|   page.value = 1 |  | ||||||
|   refreshing.value = true |  | ||||||
|   loadData() |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const leftColumn = computed(() => { |  | ||||||
|   return list.value.filter((_, index) => index % 2 === 0) |  | ||||||
| }) |  | ||||||
| const rightColumn = computed(() => { |  | ||||||
|   return list.value.filter((_, index) => index % 2 === 1) |  | ||||||
| }) |  | ||||||
| const show = ref(false) |  | ||||||
| const showHeight = ref('') |  | ||||||
| const openShow = () => { |  | ||||||
|   const rect = useRect(liveRef.value.$el); |  | ||||||
|   showHeight.value = rect.height |  | ||||||
|   nextTick(() => { |  | ||||||
|     show.value = true |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| const changeLive=()=>{ |  | ||||||
|   fullLive.value=true |  | ||||||
| } | } | ||||||
|  | initData() | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="flex-grow-1"> |   <div class="flex-grow-1"> | ||||||
|     <div |     <client-only> | ||||||
|         @click="changeLive" |       <LiveRoom @click="changeLive" :class="['changeLive', fullLive ? 'expanded' : 'collapsed']" ref="liveRef" :fullLive="fullLive"/> | ||||||
|         :class="[ |     </client-only> | ||||||
|           'changeLive', |     <div v-show="!fullLive" class="bg-#fff"> | ||||||
|           fullLive ? 'expanded' : 'collapsed' |  | ||||||
|         ]" |  | ||||||
|     > |  | ||||||
|       <client-only> |  | ||||||
|         <LiveRoom ref="liveRef" :fullLive="fullLive" /> |  | ||||||
|       </client-only> |  | ||||||
|     </div> |  | ||||||
|     <transition name="fade"> |  | ||||||
|     <div v-show="!fullLive" class="bg-#fff" > |  | ||||||
|       <van-tabs sticky animated> |       <van-tabs sticky animated> | ||||||
|         <van-tab title="拍品列表"> |         <van-tab title="拍品列表"> | ||||||
|           <div class="px-[16px] pt-[16px]"> |           <ItemList></ItemList> | ||||||
|             <van-pull-refresh> |  | ||||||
|               <van-list |  | ||||||
|                   v-model:loading="loading" |  | ||||||
|                   :finished="finished" |  | ||||||
|                   finished-text="没有更多了" |  | ||||||
|                   @load="loadData" |  | ||||||
|               > |  | ||||||
|                 <div class="w-full flex gap-[16px]"> |  | ||||||
|                   <div class="flex flex-1 flex-col gap-[16px]"> |  | ||||||
|                     <div |  | ||||||
|                         v-for="(item, index) in leftColumn" |  | ||||||
|                         :key="index" |  | ||||||
|                         class="w-full" |  | ||||||
|                         @click="openShow" |  | ||||||
|                     > |  | ||||||
|                       <div class="relative w-full"> |  | ||||||
|                         <van-image |  | ||||||
|                             :src="item.image" |  | ||||||
|                             :style="{ aspectRatio: item.ratio }" |  | ||||||
|                             fit="cover" |  | ||||||
|                             class="w-full" |  | ||||||
|                         /> |  | ||||||
|                         <div |  | ||||||
|                             class="absolute left-[8px] top-[8px] h-[17px] w-[45px] flex items-center justify-center bg-[#2b53ac] text-[12px] text-[#fff]"> |  | ||||||
|                           LOT{{ index * 2 + 1 }} |  | ||||||
|                         </div> |  | ||||||
|                       </div> |  | ||||||
|                       <div class="pt-[8px]"> |  | ||||||
|                         <div class="text-[14px] text-[#000000] leading-[20px]"> |  | ||||||
|                           {{ item.title }} |  | ||||||
|                         </div> |  | ||||||
|                         <div class="mt-[4px] text-[12px] text-[#575757]"> |  | ||||||
|                           起拍价:{{ item.startingPrice }} |  | ||||||
|                         </div> |  | ||||||
|                         <div |  | ||||||
|                             v-if="item.transactionPrice" |  | ||||||
|                             class="mt-[4px] text-[12px] text-[#b58047]" |  | ||||||
|                         > |  | ||||||
|                           成交价:{{ item.transactionPrice }} |  | ||||||
|                         </div> |  | ||||||
|                       </div> |  | ||||||
|                     </div> |  | ||||||
|                   </div> |  | ||||||
|                   <div class="flex flex-1 flex-col gap-[16px]"> |  | ||||||
|                     <div |  | ||||||
|                         v-for="(item, index) in rightColumn" |  | ||||||
|                         :key="index" |  | ||||||
|                         class="w-full" |  | ||||||
|                         @click="openShow" |  | ||||||
|                     > |  | ||||||
|                       <div class="relative w-full"> |  | ||||||
|                         <van-image |  | ||||||
|                             :src="item.image" |  | ||||||
|                             :style="{ aspectRatio: item.ratio }" |  | ||||||
|                             fit="cover" |  | ||||||
|                             class="w-full" |  | ||||||
|                         /> |  | ||||||
|                         <div |  | ||||||
|                             class="absolute left-[8px] top-[8px] h-[17px] w-[45px] flex items-center justify-center bg-[#2b53ac] text-[12px] text-[#fff]"> |  | ||||||
|                           LOT{{ index * 2 + 2 }} |  | ||||||
|                         </div> |  | ||||||
|                       </div> |  | ||||||
|                       <div class="pt-[8px]"> |  | ||||||
|                         <div class="text-[14px] text-[#000000] leading-[20px]"> |  | ||||||
|                           {{ item.title }} |  | ||||||
|                         </div> |  | ||||||
|                         <div class="mt-[4px] text-[12px] text-[#575757]"> |  | ||||||
|                           起拍价:{{ item.startingPrice }} |  | ||||||
|                         </div> |  | ||||||
|                         <div |  | ||||||
|                             v-if="item.transactionPrice" |  | ||||||
|                             class="mt-[4px] text-[12px] text-[#b58047]" |  | ||||||
|                         > |  | ||||||
|                           成交价:{{ item.transactionPrice }} |  | ||||||
|                         </div> |  | ||||||
|                       </div> |  | ||||||
|                     </div> |  | ||||||
|                   </div> |  | ||||||
|                 </div> |  | ||||||
|               </van-list> |  | ||||||
|             </van-pull-refresh> |  | ||||||
|           </div> |  | ||||||
|         </van-tab> |         </van-tab> | ||||||
|         <van-tab title="拍卖说明"> |         <van-tab title="拍卖说明"> | ||||||
|           <div class="px-16px pt-14px"> |           <Cescribe></Cescribe> | ||||||
|             <div class="text-#575757 text-14px"> |  | ||||||
|               这里是后台富文本配置的说明,啊即可打开三等奖撒度老师的湿答答是快乐的阿四大皆空 |  | ||||||
|             </div> |  | ||||||
|             <div></div> |  | ||||||
|           </div> |  | ||||||
|         </van-tab> |         </van-tab> | ||||||
|       </van-tabs> |       </van-tabs> | ||||||
|       <van-back-top right="15vw" bottom="10vh"/> |       <van-back-top right="15vw" bottom="10vh"/> | ||||||
|       <van-action-sheet :round="false" v-model:show="show" title="拍品详情"> |  | ||||||
|         <div class="content bg-[#F0F0F0]" :style="`height: calc(100vh - ${showHeight+85}px)`"> |  | ||||||
|           <itemDetail></itemDetail> |  | ||||||
|         </div> |  | ||||||
|       </van-action-sheet> |  | ||||||
|     </div> |     </div> | ||||||
|     </transition> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 |  | ||||||
| <style> | <style> | ||||||
| :root:root { | :root:root { | ||||||
|   --van-action-sheet-header-height: 39px; |   --van-action-sheet-header-height: 39px; | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| :deep(.van-swipe__indicator) { | :deep(.van-swipe__indicator) { | ||||||
|   width: 8px; |   width: 8px; | ||||||
|   height: 8px; |   height: 8px; | ||||||
| } | } | ||||||
|  | 
 | ||||||
| .fade-enter-active, .fade-leave-active { | .fade-enter-active, .fade-leave-active { | ||||||
|   transition: opacity 1s; |   transition: opacity 1s; | ||||||
| } | } | ||||||
| .fade-enter, .fade-leave-to /* .fade-leave-active in <2.1.8 */ { | 
 | ||||||
|  | .fade-enter, .fade-leave-to { | ||||||
|   opacity: 0; |   opacity: 0; | ||||||
| } | } | ||||||
| :deep(.van-swipe__indicator:not(.van-swipe__indicator--active) ) { | 
 | ||||||
|  | :deep(.van-swipe__indicator:not(.van-swipe__indicator--active)) { | ||||||
|   background: rgba(0, 0, 0, 0.8); |   background: rgba(0, 0, 0, 0.8); | ||||||
| } | } | ||||||
|  | 
 | ||||||
| .changeLive { | .changeLive { | ||||||
|   width: 100%; |   width: 100%; | ||||||
|   overflow: hidden; |   overflow: hidden; | ||||||
| @ -263,7 +75,8 @@ const changeLive=()=>{ | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .changeLive.expanded { | .changeLive.expanded { | ||||||
|  |   position: absolute; | ||||||
|  |   z-index: 10; | ||||||
|   height: calc(100vh - var(--van-nav-bar-height)); |   height: calc(100vh - var(--van-nav-bar-height)); | ||||||
|   transform: translateY(0); |  | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
| @ -2,24 +2,45 @@ | |||||||
| import { useRouter, useRoute } from 'vue-router'; | import { useRouter, useRoute } from 'vue-router'; | ||||||
| import { useI18n } from 'vue-i18n' | import { useI18n } from 'vue-i18n' | ||||||
| import countryCode from '../countryRegion/data/index.js' | import countryCode from '../countryRegion/data/index.js' | ||||||
| 
 | import {senCode, userLogin} from "@/api/auth/index.js"; | ||||||
|  | import {authStore} from "~/stores/auth/index.js"; | ||||||
|  | import {message} from '@/components/x-message/useMessage.js' | ||||||
|  | const {userInfo,token}= authStore() | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| const { locale } = useI18n() | const { locale } = useI18n() | ||||||
| 
 |  | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
|   title: '登录', |   title: '登录', | ||||||
|   i18n: 'login.title', |   i18n: 'login.title', | ||||||
| }) | }) | ||||||
| 
 | const loadingRef=ref({ | ||||||
|  |   loading1:false, | ||||||
|  |   loading2:false, | ||||||
|  | }) | ||||||
|  | const isExist=ref(false)//帐号是否存在  true存在 | ||||||
|  | const isReal=ref(false) //isReal 是否实名过 | ||||||
| function goToPage() { | function goToPage() { | ||||||
|   router.push('/countryRegion'); |   router.push('/countryRegion'); | ||||||
| } | } | ||||||
| 
 | const interval=ref(null) | ||||||
| const phoneNum = ref('') | const startCountdown=()=> { | ||||||
| const code = ref('') |   if (interval.value){ | ||||||
|  |     clearInterval(interval.value); | ||||||
|  |   } | ||||||
|  |   countdown.value = 60; | ||||||
|  |   interval.value = setInterval(() => { | ||||||
|  |     if (countdown.value > 0) { | ||||||
|  |       countdown.value--; | ||||||
|  |     } else { | ||||||
|  |       clearInterval(interval.value); | ||||||
|  |     } | ||||||
|  |   }, 1000); | ||||||
|  | } | ||||||
|  | const countdown = ref(0); | ||||||
|  | const phoneNum = ref('17630920520') | ||||||
|  | const code = ref('123789') | ||||||
| const pane = ref(0) | const pane = ref(0) | ||||||
| const showKeyboard = ref(true); | const showKeyboard = ref(false); | ||||||
| // 根据语言获取默认国家 | // 根据语言获取默认国家 | ||||||
| const getDefaultCountry = () => { | const getDefaultCountry = () => { | ||||||
|   let defaultCode = 'CN' // 默认中国大陆 |   let defaultCode = 'CN' // 默认中国大陆 | ||||||
| @ -62,17 +83,51 @@ watch(locale, () => { | |||||||
|     selectedCountry.value = newDefault.name |     selectedCountry.value = newDefault.name | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
|  | const vanSwipeRef=ref(null) | ||||||
|  | const getCode =async () => { | ||||||
|  |   loadingRef.value.loading1=true | ||||||
|  |  const res=await senCode({ | ||||||
|  |    telNum:phoneNum.value, | ||||||
|  |    zone:selectedZone.value | ||||||
|  |  }) | ||||||
|  |   loadingRef.value.loading1=false | ||||||
|  |   if (res.status===0){ | ||||||
|  |     pane.value = 1 | ||||||
|  |     vanSwipeRef.value?.swipeTo(pane.value) | ||||||
|  |     showKeyboard.value=true | ||||||
|  |     startCountdown(); | ||||||
|  | 
 | ||||||
|  |   } | ||||||
|  | /*  pane.value = 1 | ||||||
|  |   vanSwipeRef.value?.swipeTo(pane.value) | ||||||
|  |   showKeyboard.value=true | ||||||
|  |   startCountdown();*/ | ||||||
| 
 | 
 | ||||||
| const getCode = () => { |  | ||||||
|   pane.value = 1 |  | ||||||
| } | } | ||||||
| const goBack = () => { | const goBack = () => { | ||||||
|   code.value = '' |   code.value = '' | ||||||
|   pane.value = 0 |   pane.value = 0 | ||||||
|  |   vanSwipeRef.value?.swipeTo(pane.value) | ||||||
|  | } | ||||||
|  | const goLogin =async () => { | ||||||
|  |   loadingRef.value.loading2=true | ||||||
|  |  const res=await userLogin({ | ||||||
|  |    telNum:phoneNum.value, | ||||||
|  |    zone:selectedZone.value, | ||||||
|  |    code:code.value | ||||||
|  |  }) | ||||||
|  |   if (res.status===0){ | ||||||
|  |     userInfo.value=res.data.accountInfo | ||||||
|  |     token.value=res.data.token | ||||||
|  | 
 | ||||||
|  |     if (!res.data.isReal){ | ||||||
|  |       await router.push('/realAuth'); | ||||||
|  |     }else { | ||||||
|  |       await router.push('/'); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   loadingRef.value.loading2=false | ||||||
| } | } | ||||||
| const goLogin = () => { |  | ||||||
|   router.push('/realAuth'); |  | ||||||
| }  |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| @ -80,52 +135,59 @@ const goLogin = () => { | |||||||
|     <div class="w-full flex justify-center mb-[100px]"> |     <div class="w-full flex justify-center mb-[100px]"> | ||||||
|       <img class="h-[105px] w-[189px]" src="@/static/images/ghfggff.png" alt=""> |       <img class="h-[105px] w-[189px]" src="@/static/images/ghfggff.png" alt=""> | ||||||
|     </div> |     </div> | ||||||
|     <div v-if="pane === 0"> |     <van-swipe ref="vanSwipeRef" :show-indicators="false" :touchable="false" :lazy-render="true" :loop="false"> | ||||||
|       <div class=""> |       <van-swipe-item > | ||||||
|         <div class="w-full flex justify-between" @click="goToPage"> |         <div v-show="pane===0"> | ||||||
|           <div class="text-[16px] text-[#000]"> |           <div class=""> | ||||||
|             {{ selectedCountry }} |             <div class="w-full flex justify-between" @click="goToPage"> | ||||||
|           </div> |               <div class="text-[16px] text-[#000]"> | ||||||
|           <div><van-icon color="#777" name="arrow" size="14" /></div> |                 {{ selectedCountry }} | ||||||
|         </div> |  | ||||||
|         <div class="border-b-[1.7px] mt-[8px]"> |  | ||||||
|           <van-field v-model="phoneNum" clearable :placeholder="$t('login.phonePlaceholder')"> |  | ||||||
|             <template #label> |  | ||||||
|               <div class="text-[16px] text-[#1A1A1A] flex align-center justify-start"> |  | ||||||
|                 +{{ selectedZone }} |  | ||||||
|               </div> |               </div> | ||||||
|             </template> |               <div><van-icon color="#777" name="arrow" size="14" /></div> | ||||||
|           </van-field> |             </div> | ||||||
|  |             <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|  |               <van-field v-model="phoneNum" clearable :placeholder="$t('login.phonePlaceholder')"> | ||||||
|  |                 <template #label> | ||||||
|  |                   <div class="text-[16px] text-[#1A1A1A] flex align-center justify-start"> | ||||||
|  |                     +{{ selectedZone }} | ||||||
|  |                   </div> | ||||||
|  |                 </template> | ||||||
|  |               </van-field> | ||||||
|  |             </div> | ||||||
|  |             <div /> | ||||||
|  |           </div> | ||||||
|  |           <div class="mt-[55px]"> | ||||||
|  |             <van-button :loading="loadingRef.loading1" v-if="phoneNum" :loading-text="$t('login.getCode')" type="primary" block style="height: 48px" @click="getCode">{{ $t('login.getCode') | ||||||
|  |               }}</van-button> | ||||||
|  |             <van-button v-else type="primary" color="#D3D3D3" block style="height: 48px">{{ $t('login.getCode') | ||||||
|  |               }}</van-button> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div /> |       </van-swipe-item> | ||||||
|       </div> |       <van-swipe-item> | ||||||
|       <div class="mt-[55px]"> |         <div v-show="pane===1"> | ||||||
|         <van-button v-if="phoneNum" type="primary" block style="height: 48px" @click="getCode">{{ $t('login.getCode') |           <div class="flex mb-[16px]"> | ||||||
|           }}</van-button> |             <div class="text-[16px] text-[#BDBDBD] mr-[10px]">{{ $t('login.hasSendTo') }}</div> | ||||||
|         <van-button v-else type="primary" color="#D3D3D3" block style="height: 48px">{{ $t('login.getCode') |             <div class="text-[16px] text-[#000]">+{{ selectedZone }} {{ phoneNum }}</div> | ||||||
|           }}</van-button> |           </div> | ||||||
|       </div> |           <van-password-input :value="code" :gutter="10" :mask="false" focused @focus="showKeyboard = true" /> | ||||||
|     </div> |           <div :class="`${countdown>0?'text-#BDBDBD':'text-#2B53AC'}  text-14px`"> | ||||||
|     <div v-else> |             {{ $t('login.reSend') }}<span v-if="countdown>0">({{countdown}})</span> | ||||||
|       <div class="flex mb-[16px]"> |           </div> | ||||||
|         <div class="text-[16px] text-[#BDBDBD] mr-[10px]">{{ $t('login.hasSendTo') }}</div> |           <div class="mt-[17px]"> | ||||||
|         <div class="text-[16px] text-[#000]">+{{ selectedZone }} {{ phoneNum }}</div> |             <van-button v-if="code.length === 6" type="primary" block :loading="loadingRef.loading2" :loading-text="$t('login.login')" style="height: 48px" @click="goLogin">{{ | ||||||
|       </div> |                 $t('login.login') | ||||||
|       <van-password-input :value="code" :gutter="10" :mask="false" focused @focus="showKeyboard = true" /> |               }}</van-button> | ||||||
|       <van-number-keyboard v-model="code" :show="showKeyboard" @blur="showKeyboard = false" /> |             <van-button v-else type="primary" color="#D3D3D3" block style="height: 48px">{{ $t('login.login') }}</van-button> | ||||||
|       <div class="text-#2B53AC text-14px"> |           </div> | ||||||
|         {{ $t('login.reSend') }} |           <div class="mt-[17px]"> | ||||||
|       </div> |             <van-button type="primary" @click="goBack" block style="height: 48px">{{ $t('login.back') }}</van-button> | ||||||
|       <div class="mt-[17px]"> |           </div> | ||||||
|         <van-button v-if="code.length === 6" type="primary" block style="height: 48px" @click="goLogin">{{ |         </div> | ||||||
|           $t('login.login') |       </van-swipe-item> | ||||||
|           }}</van-button> |     </van-swipe> | ||||||
|         <van-button v-else type="primary" color="#D3D3D3" block style="height: 48px">{{ $t('login.login') }}</van-button> |     <van-number-keyboard v-model="code" :show="showKeyboard" @blur="showKeyboard = false" /> | ||||||
|       </div> | 
 | ||||||
|       <div class="mt-[17px]"> |  | ||||||
|         <van-button type="primary" @click="goBack" block style="height: 48px">{{ $t('login.back') }}</van-button> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,9 +1,20 @@ | |||||||
| <script setup> | <script setup> | ||||||
|  | import {userArtworks} from "~/api/goods/index.js"; | ||||||
|  | import {authStore} from "~/stores/auth/index.js"; | ||||||
|  | 
 | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
|   layout: 'default', |   layout: 'default', | ||||||
|   title: '我的', |   title: '我的', | ||||||
|   i18n: 'menu.profile', |   i18n: 'menu.profile', | ||||||
| }) | }) | ||||||
|  | const {userInfo}= authStore() | ||||||
|  | const initData=async ()=>{ | ||||||
|  |  const res=await userArtworks({}) | ||||||
|  |   if (res.status===0){ | ||||||
|  | 
 | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | initData() | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| @ -13,8 +24,8 @@ definePageMeta({ | |||||||
|       <img class="w-57px h-57px" src="@/static/images/5514@2x.png" alt=""> |       <img class="w-57px h-57px" src="@/static/images/5514@2x.png" alt=""> | ||||||
|     </div> |     </div> | ||||||
|     <div class="flex flex-col"> |     <div class="flex flex-col"> | ||||||
|       <div class="text-18px text-#181818">张三</div> |       <div class="text-18px text-#181818">{{userInfo.realName}}</div> | ||||||
|       <div class="text-#575757 text-14px">15834362333</div> |       <div class="text-#575757 text-14px">{{userInfo.telNum}}</div> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
|     <div class="flex-grow-1"> |     <div class="flex-grow-1"> | ||||||
|  | |||||||
							
								
								
									
										65
									
								
								app/pages/realAuth/components/detail.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								app/pages/realAuth/components/detail.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,65 @@ | |||||||
|  | <script setup> | ||||||
|  | import {authStore} from "@/stores/auth/index.js"; | ||||||
|  | 
 | ||||||
|  | const props = defineProps({ | ||||||
|  |   type: { | ||||||
|  |     type: Number, | ||||||
|  |     default: 0 | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | const {userInfo}= authStore() | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div class="text-#1A1A1A text-16px"> | ||||||
|  |   <template v-if="type===0"> | ||||||
|  |     <div class="flex mb-20px" > | ||||||
|  |       <div class="mr-10px">姓名:</div> | ||||||
|  |       <div>{{userInfo.realName}}</div> | ||||||
|  |     </div> | ||||||
|  |     <div class="flex mb-20px"> | ||||||
|  |       <div class="mr-10px">性别:</div> | ||||||
|  |       <div>{{userInfo.sex}}</div> | ||||||
|  |     </div> | ||||||
|  |     <div class="flex mb-20px"> | ||||||
|  |       <div class="mr-10px">出生日期:</div> | ||||||
|  |       <div>{{userInfo.birthDate}}</div> | ||||||
|  |     </div> | ||||||
|  |     <div class="flex"> | ||||||
|  |       <div class="mr-10px">身份证号:</div> | ||||||
|  |       <div>{{userInfo.idNum}}</div> | ||||||
|  |     </div> | ||||||
|  |   </template> | ||||||
|  |     <template v-if="type===1"> | ||||||
|  |       <div class="flex mb-20px" > | ||||||
|  |         <div class="mr-10px">姓名:</div> | ||||||
|  |         <div>{{userInfo.realName}}</div> | ||||||
|  |       </div> | ||||||
|  |       <div class="flex mb-20px"> | ||||||
|  |         <div class="mr-10px">性别:</div> | ||||||
|  |         <div>{{userInfo.sex}}</div> | ||||||
|  |       </div> | ||||||
|  |       <div class="flex mb-20px"> | ||||||
|  |         <div class="mr-10px">出生日期:</div> | ||||||
|  |         <div>{{userInfo.birthDate}}</div> | ||||||
|  |       </div> | ||||||
|  |       <div class="flex"> | ||||||
|  |         <div class="mr-10px">家庭住址:</div> | ||||||
|  |         <div>{{userInfo.idNum}}</div> | ||||||
|  |       </div> | ||||||
|  |       <div class="flex"> | ||||||
|  |         <div class="mr-10px">所属银行:</div> | ||||||
|  |         <div>{{userInfo.idNum}}</div> | ||||||
|  |       </div> | ||||||
|  |       <div class="flex"> | ||||||
|  |         <div class="mr-10px">银行卡号码:</div> | ||||||
|  |         <div>{{userInfo.idNum}}</div> | ||||||
|  |       </div> | ||||||
|  |     </template> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped> | ||||||
|  | 
 | ||||||
|  | </style> | ||||||
| @ -1,35 +1,78 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useRouter, useRoute } from 'vue-router'; | import { useRouter, useRoute } from 'vue-router'; | ||||||
| import { useI18n } from 'vue-i18n' | import { useI18n } from 'vue-i18n' | ||||||
| 
 | import {userUpdate} from "~/api/auth/index.js"; | ||||||
|  | import {message} from '@/components/x-message/useMessage.js' | ||||||
|  | import detail from './components/detail.vue' | ||||||
|  | import {authStore} from "~/stores/auth/index.js"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| const showPicker = ref(false); | const showPicker = ref(false); | ||||||
| const pickerValue = ref([]); | const {userInfo}= authStore() | ||||||
| const gender = ref('男') |  | ||||||
| const birthday = ref('') |  | ||||||
| const birthdayDate = ref([]) | const birthdayDate = ref([]) | ||||||
| const showBirthdayPicker = ref(false) | const showBirthdayPicker = ref(false) | ||||||
| const minDate = new Date(1950, 0, 1) | const minDate = new Date(1950, 0, 1) | ||||||
| const maxDate = new Date(2025, 12, 31) | const maxDate = new Date(2025, 12, 31) | ||||||
| 
 | const active=ref(0) | ||||||
| const { t } = useI18n() | const { t } = useI18n() | ||||||
| 
 | const form=ref({ | ||||||
| const columns = computed(() => [ |   idNum: "", | ||||||
|   { text: t('realAuth.male'), value: t('realAuth.male') }, |   realName: "", | ||||||
|   { text: t('realAuth.female'), value: t('realAuth.female') }, |   sex:'', | ||||||
| ]); |   birthDate:'', | ||||||
|  |   userExtend: { | ||||||
|  |     address: "", | ||||||
|  |     bankName: "", | ||||||
|  |     bankNo: "" | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | const form1=ref({ | ||||||
|  |   idNum:'', | ||||||
|  |   realName:'' | ||||||
|  | }) | ||||||
|  | const columns=ref([ | ||||||
|  |   { text: t('realAuth.male'), value: 1 }, | ||||||
|  |   { text: t('realAuth.female'), value: 2 }, | ||||||
|  | ]) | ||||||
| const onConfirm = ({ selectedValues, selectedOptions }) => { | const onConfirm = ({ selectedValues, selectedOptions }) => { | ||||||
|   pickerValue.value = selectedValues | form.value.sex=selectedValues?.[0] | ||||||
|   gender.value = selectedOptions[0].text |  | ||||||
|   showPicker.value = false |   showPicker.value = false | ||||||
| } | } | ||||||
| const onBirthdayConfirm = (value) => { | const onBirthdayConfirm = (value) => { | ||||||
|   console.log(value) |   form.value.birthDate=value.selectedValues.join('-') | ||||||
|   birthdayDate.value = value.selectedValues |  | ||||||
|   birthday.value = value.selectedValues.join('-') |  | ||||||
|   showBirthdayPicker.value = false |   showBirthdayPicker.value = false | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | function isFormComplete(obj) { | ||||||
|  |   for (const key in obj) { | ||||||
|  |     if (typeof obj[key] === 'object' && obj[key] !== null) { | ||||||
|  |       if (!isFormComplete(obj[key])) { | ||||||
|  |         return false; | ||||||
|  |       } | ||||||
|  |     } else if (obj[key] === "") { | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  | const statusCode=ref(0) | ||||||
|  | const confirm=async ()=>{ | ||||||
|  |   const thatForm=active.value===0?form1.value:form.value | ||||||
|  |   if (isFormComplete(thatForm)){ | ||||||
|  |    const res=await userUpdate(thatForm) | ||||||
|  |     if (res.status===0){ | ||||||
|  |       userInfo.value=res.data | ||||||
|  |       message.success('提交成功') | ||||||
|  |       statusCode.value=1 | ||||||
|  |     } | ||||||
|  |   }else { | ||||||
|  |     message.error('请填写身份证相关信息') | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const goHome=()=>{ | ||||||
|  |   router.push('/') | ||||||
|  | } | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
|   title: '实名认证', |   title: '实名认证', | ||||||
|   i18n: 'realAuth.title', |   i18n: 'realAuth.title', | ||||||
| @ -37,27 +80,21 @@ definePageMeta({ | |||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="px-[31px] bg-#fff w-100vw h-100vh pt-[46px]"> |   <div class="px-[31px] bg-[url('@/static/images/asdfsdd.png')] bg-cover w-100vw flex-grow-1 pt-[46px] relative flex flex-col"> | ||||||
|     <van-tabs animated swipeable> |     <van-tabs v-if="statusCode===0" v-model:active="active" animated swipeable> | ||||||
|       <van-tab :title="$t('realAuth.cnTab')" class="pt-[80px]"> |       <van-tab :title="$t('realAuth.cnTab')" class="pt-[80px]"> | ||||||
|         <div class="text-[#BDBDBD] text-[16px] mb-[34px]">{{ $t('realAuth.cnTabDesc') }}</div> |         <template v-if="statusCode===0"> | ||||||
|         <div class="mb-[100px]"> |           <div class="text-[#BDBDBD] text-[16px] mb-[34px]">{{ $t('realAuth.cnTabDesc') }}</div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |           <div class="mb-[100px]"> | ||||||
|             <van-field :label="$t('realAuth.idCard')" clearable |             <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|               :placeholder="$t('realAuth.idCardPlaceholder')"></van-field> |               <van-field v-model="form1.idNum" :label="$t('realAuth.idCard')" clearable | ||||||
|  |                          :placeholder="$t('realAuth.idCardPlaceholder')"></van-field> | ||||||
|  |             </div> | ||||||
|  |             <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|  |               <van-field v-model="form1.realName" :label="$t('realAuth.name')" clearable :placeholder="$t('realAuth.namePlaceholder')"></van-field> | ||||||
|  |             </div> | ||||||
|           </div> |           </div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |         </template> | ||||||
|             <van-field :label="$t('realAuth.name')" clearable :placeholder="$t('realAuth.namePlaceholder')"></van-field> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|         <div class="flex justify-between"> |  | ||||||
|           <van-button style="width: 151px;height: 48px" color="#E9F1F8"> |  | ||||||
|             <div class="text-#2B53AC text-16px">{{ $t('realAuth.cancel') }}</div> |  | ||||||
|           </van-button> |  | ||||||
|           <van-button style="width: 151px;height: 48px" color="#2B53AC"> |  | ||||||
|             <div class="text-#FFFFFF text-16px">{{ $t('realAuth.confirm') }}</div> |  | ||||||
|           </van-button> |  | ||||||
|         </div> |  | ||||||
|       </van-tab> |       </van-tab> | ||||||
|       <van-tab :title="$t('realAuth.otherTab')" class="pt-[80px]"> |       <van-tab :title="$t('realAuth.otherTab')" class="pt-[80px]"> | ||||||
|         <div class="text-[#BDBDBD] text-[16px] mb-[34px]">{{ $t('realAuth.otherTabDesc') }}</div> |         <div class="text-[#BDBDBD] text-[16px] mb-[34px]">{{ $t('realAuth.otherTabDesc') }}</div> | ||||||
| @ -66,39 +103,49 @@ definePageMeta({ | |||||||
|             <van-field :label="$t('realAuth.name')" clearable :placeholder="$t('realAuth.namePlaceholder')"></van-field> |             <van-field :label="$t('realAuth.name')" clearable :placeholder="$t('realAuth.namePlaceholder')"></van-field> | ||||||
|           </div> |           </div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |           <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|             <van-field v-model="gender" is-link readonly name="picker" :label="$t('realAuth.gender')" |             <van-field :modelValue="columns.find(x=>x.value===form.sex)?.text" is-link readonly name="picker" :label="$t('realAuth.gender')" | ||||||
|               @click="showPicker = true" /> |               @click="showPicker = true" /> | ||||||
| 
 |  | ||||||
|           </div> |           </div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |           <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|             <van-field v-model="birthday" is-link readonly name="birthdayPicker" :label="$t('realAuth.birthday')" |             <van-field v-model="form.birthDate" is-link readonly name="birthdayPicker" :label="$t('realAuth.birthday')" | ||||||
|               :placeholder="$t('realAuth.birthdayPlaceholder')" @click="showBirthdayPicker = true" /> |               :placeholder="$t('realAuth.birthdayPlaceholder')" @click="showBirthdayPicker = true" /> | ||||||
| 
 | 
 | ||||||
|           </div> |           </div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |           <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|             <van-field :label="$t('realAuth.adress')" clearable |             <van-field v-model="form.userExtend.address" :label="$t('realAuth.adress')" clearable | ||||||
|               :placeholder="$t('realAuth.adressPlaceholder')"></van-field> |               :placeholder="$t('realAuth.adressPlaceholder')"></van-field> | ||||||
|           </div> |           </div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |           <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|             <van-field :label="$t('realAuth.bank')" clearable :placeholder="$t('realAuth.bankPlaceholder')"></van-field> |             <van-field v-model="form.userExtend.bankName" :label="$t('realAuth.bank')" clearable :placeholder="$t('realAuth.bankPlaceholder')"></van-field> | ||||||
|           </div> |           </div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |           <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|             <van-field :label="$t('realAuth.bankCard')" clearable |             <van-field v-model="form.userExtend.bankNo" :label="$t('realAuth.bankCard')" clearable | ||||||
|               :placeholder="$t('realAuth.bankCardPlaceholder')"></van-field> |               :placeholder="$t('realAuth.bankCardPlaceholder')"></van-field> | ||||||
|           </div> |           </div> | ||||||
|           <div class="flex justify-between mt-[100px]"> |  | ||||||
|             <van-button style="width: 151px;height: 48px" color="#E9F1F8"> |  | ||||||
|               <div class="text-#2B53AC text-16px">{{ $t('realAuth.cancel') }}</div> |  | ||||||
|             </van-button> |  | ||||||
|             <van-button style="width: 151px;height: 48px" color="#2B53AC"> |  | ||||||
|               <div class="text-#FFFFFF text-16px">{{ $t('realAuth.confirm') }}</div> |  | ||||||
|             </van-button> |  | ||||||
|           </div> |  | ||||||
|         </div> |         </div> | ||||||
|       </van-tab> |       </van-tab> | ||||||
|     </van-tabs> |     </van-tabs> | ||||||
|  |     <van-tabs v-else-if="statusCode===1" v-model:active="active" animated swipeable> | ||||||
|  |       <van-tab :title="$t('realAuth.cnTab')" class="pt-[80px]"> | ||||||
|  |         <detail :type="active"></detail> | ||||||
|  |       </van-tab> | ||||||
|  |       <van-tab :title="$t('realAuth.otherTab')" class="pt-[80px]"> | ||||||
|  |         <detail :type="active"></detail> | ||||||
|  |       </van-tab> | ||||||
|  |     </van-tabs> | ||||||
|  |     <div class="flex justify-between" v-if="statusCode===0"> | ||||||
|  |       <van-button style="width: 151px;height: 48px" color="#E9F1F8"> | ||||||
|  |         <div class="text-#2B53AC text-16px">{{ $t('realAuth.cancel') }}</div> | ||||||
|  |       </van-button> | ||||||
|  |       <van-button @click="confirm" style="width: 151px;height: 48px" color="#2B53AC"> | ||||||
|  |         <div class="text-#FFFFFF text-16px">{{ $t('realAuth.confirm') }}</div> | ||||||
|  |       </van-button> | ||||||
|  |     </div> | ||||||
|  |     <div v-else class="mt-auto pb-94px"> | ||||||
|  |       <van-button color="#E9F1F8" @click="goHome" style="color: #2B53AC;font-weight: 600" block>去首页</van-button> | ||||||
|  |     </div> | ||||||
|     <van-popup v-model:show="showPicker" destroy-on-close position="bottom"> |     <van-popup v-model:show="showPicker" destroy-on-close position="bottom"> | ||||||
|       <van-picker :columns="columns" :model-value="pickerValue" @confirm="onConfirm" @cancel="showPicker = false" /> |       <van-picker :columns="columns"  @confirm="onConfirm" @cancel="showPicker = false" /> | ||||||
|     </van-popup> |     </van-popup> | ||||||
|     <van-popup v-model:show="showBirthdayPicker" destroy-on-close position="bottom"> |     <van-popup v-model:show="showBirthdayPicker" destroy-on-close position="bottom"> | ||||||
|       <van-date-picker v-model="birthdayDate" :min-date="minDate" :max-date="maxDate" |       <van-date-picker v-model="birthdayDate" :min-date="minDate" :max-date="maxDate" | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								app/static/images/close@2x.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/static/images/close@2x.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 818 B | 
							
								
								
									
										
											BIN
										
									
								
								app/static/images/zu5554@2x.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/static/images/zu5554@2x.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/static/images/zu5561@2x.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/static/images/zu5561@2x.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/static/video/example.mp4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/static/video/example.mp4
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										11
									
								
								app/stores/auth/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								app/stores/auth/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | |||||||
|  | import { createGlobalState,useLocalStorage } from '@vueuse/core' | ||||||
|  | export const authStore = createGlobalState(() => { | ||||||
|  |     const token=useLocalStorage('token','') | ||||||
|  |     const RefreshToken=useLocalStorage('RefreshToken','') | ||||||
|  |     const userInfo=useLocalStorage('userInfo',{}) | ||||||
|  |     return{ | ||||||
|  |         userInfo, | ||||||
|  |         RefreshToken, | ||||||
|  |         token | ||||||
|  |     } | ||||||
|  | }) | ||||||
							
								
								
									
										40
									
								
								app/stores/goods/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								app/stores/goods/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | |||||||
|  | import {createGlobalState} from '@vueuse/core' | ||||||
|  | import {artworkList, defaultDetail} from "~/api/goods/index.js"; | ||||||
|  | 
 | ||||||
|  | export const goodStore = createGlobalState(() => { | ||||||
|  |     const actionDetails = ref({}) | ||||||
|  |     const fullLive = ref(false) | ||||||
|  |     const liveRef = ref(null); | ||||||
|  |     const currentItem=ref({}) | ||||||
|  |     const myArtWorks=ref([]) | ||||||
|  |     const pageRef = ref({ | ||||||
|  |         page: 1, | ||||||
|  |         pageSize: 5, | ||||||
|  |         itemCount: 0 | ||||||
|  |     }) | ||||||
|  |     const artWorkDetail=ref(null) | ||||||
|  |     const itemList = ref([]) | ||||||
|  |     const auctionDetail = ref({}) | ||||||
|  |     const getAuctionDetail = async () => { | ||||||
|  |         const res = await defaultDetail({}) | ||||||
|  |         if (res.status === 0) { | ||||||
|  |             auctionDetail.value = res.data | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     const getArtworkList = async (page = pageRef.value) => { | ||||||
|  |         return artworkList({auctionUuid: auctionDetail.value.uuid, ...page}) | ||||||
|  |     } | ||||||
|  |     return { | ||||||
|  |         myArtWorks, | ||||||
|  |         currentItem, | ||||||
|  |         artWorkDetail, | ||||||
|  |         liveRef, | ||||||
|  |         pageRef, | ||||||
|  |         getArtworkList, | ||||||
|  |         auctionDetail, | ||||||
|  |         getAuctionDetail, | ||||||
|  |         actionDetails, | ||||||
|  |         itemList, | ||||||
|  |         fullLive | ||||||
|  |     } | ||||||
|  | }) | ||||||
| @ -1,7 +0,0 @@ | |||||||
| import { createGlobalState } from '@vueuse/core' |  | ||||||
| export const homeStore = createGlobalState(() => { |  | ||||||
|     const fullLive=ref(false) |  | ||||||
|     return{ |  | ||||||
|         fullLive |  | ||||||
|     } |  | ||||||
| }) |  | ||||||
							
								
								
									
										18
									
								
								app/stores/live/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								app/stores/live/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | |||||||
|  | import { createGlobalState } from '@vueuse/core' | ||||||
|  | import {ref} from "vue"; | ||||||
|  | export const liveStore = createGlobalState(() => { | ||||||
|  |     const quoteStatus = ref(false) | ||||||
|  |     const show = ref(false) | ||||||
|  |     const show1=ref(false) | ||||||
|  |     const playerId=ref('J_prismPlayer') | ||||||
|  |     const changeStatus = () => { | ||||||
|  |         quoteStatus.value = !quoteStatus.value | ||||||
|  |     } | ||||||
|  |     return{ | ||||||
|  |         show1, | ||||||
|  |         playerId, | ||||||
|  |         show, | ||||||
|  |         quoteStatus, | ||||||
|  |         changeStatus | ||||||
|  |     } | ||||||
|  | }) | ||||||
							
								
								
									
										7
									
								
								env/.env.prod
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								env/.env.prod
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | # 生产环境配置 | ||||||
|  | NUXT_PUBLIC_API_BASE=http://api.example.com | ||||||
|  | NUXT_PUBLIC_WS_URL=ws://ws.example.com | ||||||
|  | NUXT_API_SECRET=prod-secret | ||||||
|  | 
 | ||||||
|  | # 阿里云播放器配置 | ||||||
|  | NUXT_PUBLIC_PLAYER_SOURCE=artc://live-pull-sh-01.szjixun.cn/live/live?auth_key=1736748343-0-0-feef65166e5cc62957c35b6e3eec82a1 | ||||||
							
								
								
									
										7
									
								
								env/.env.test
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								env/.env.test
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | # 测试环境配置 | ||||||
|  | NUXT_PUBLIC_API_BASE=http://172.16.100.99:8005 | ||||||
|  | NUXT_PUBLIC_WS_URL=ws://test-ws.example.com | ||||||
|  | NUXT_API_SECRET=test-secret | ||||||
|  | 
 | ||||||
|  | # 阿里云播放器配置 | ||||||
|  | NUXT_PUBLIC_PLAYER_SOURCE=artc://live-pull-sh-01.szjixun.cn/live/live?auth_key=1737080180-0-0-42ad4cf26ba26eee78ca7de9c524d1e0 | ||||||
| @ -1,6 +1,16 @@ | |||||||
|  | import dotenv from 'dotenv' | ||||||
| import process from 'node:process' | import process from 'node:process' | ||||||
| import preload from './app/utils/preload' | import preload from './app/utils/preload' | ||||||
| import { currentLocales } from './i18n/i18n' | import { currentLocales } from './i18n/i18n' | ||||||
|  | const envFile = process.env.ENV_FILE || '.env.test' | ||||||
|  | dotenv.config({ path: `./env/${envFile}` }) | ||||||
|  | const publicConfig = Object.entries(process.env) | ||||||
|  |   .filter(([key]) => key.startsWith('NUXT_PUBLIC_')) | ||||||
|  |   .reduce((config, [key, value]) => { | ||||||
|  |     config[key] = value | ||||||
|  |     return config | ||||||
|  |   }, {}) | ||||||
|  | 
 | ||||||
| export default defineNuxtConfig({ | export default defineNuxtConfig({ | ||||||
| 
 | 
 | ||||||
|   hooks: { |   hooks: { | ||||||
| @ -23,9 +33,10 @@ export default defineNuxtConfig({ | |||||||
|     '@nuxtjs/i18n', |     '@nuxtjs/i18n', | ||||||
|   ], |   ], | ||||||
|   runtimeConfig: { |   runtimeConfig: { | ||||||
|     public: { |     // 私有配置,只有在服务端可用
 | ||||||
|       apiBase: process.env.NUXT_PUBLIC_API_BASE, |     apiSecret: process.env.NUXT_API_SECRET || 'default_secret', | ||||||
|     }, |     // 公共配置,客户端和服务端都可用
 | ||||||
|  |     public: publicConfig, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   css: [ |   css: [ | ||||||
| @ -79,9 +90,9 @@ export default defineNuxtConfig({ | |||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   app: { |   app: { | ||||||
|     pageTransition: { |     layoutTransition: {  | ||||||
|       name: 'page', |       name: 'layout', | ||||||
|       mode: 'out-in', |       mode: 'out-in' | ||||||
|     }, |     }, | ||||||
|     head: { |     head: { | ||||||
|       viewport: 'width=device-width,initial-scale=1,viewport-fit=cover', |       viewport: 'width=device-width,initial-scale=1,viewport-fit=cover', | ||||||
|  | |||||||
							
								
								
									
										14
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								package.json
									
									
									
									
									
								
							| @ -5,21 +5,24 @@ | |||||||
|   "packageManager": "pnpm@9.15.1", |   "packageManager": "pnpm@9.15.1", | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "build": "nuxt build", |     "build": "nuxt build", | ||||||
|     "dev": "nuxt dev --mode test", |     "dev": "cross-env ENV_FILE=.env.test nuxt dev", | ||||||
|     "dev:prod": "nuxt dev --mode prod", |     "dev:prod": "NODE_ENV=production ENV_FILE=.env.prod nuxt dev", | ||||||
|     "build:test": "nuxt build --mode test", |     "build:test": "cross-env ENV_FILE=.env.test nuxt build", | ||||||
|     "build:prod": "nuxt build --mode prod", |     "build:prod": "cross-env ENV_FILE=.env.prod nuxt build", | ||||||
|     "generate": "nuxt generate", |     "generate": "nuxt generate", | ||||||
|     "preview": "nuxt preview", |     "preview": "nuxt preview", | ||||||
|     "postinstall": "nuxt prepare", |     "postinstall": "nuxt prepare", | ||||||
|     "typecheck": "vue-tsc --noEmit", |     "typecheck": "vue-tsc --noEmit", | ||||||
|     "release": "bumpp --commit --push --tag" |     "release": "bumpp --commit --push --tag", | ||||||
|  |     "start": "cross-env ENV_FILE=.env.prod nuxt start" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@nuxtjs/color-mode": "^3.5.2", |     "@nuxtjs/color-mode": "^3.5.2", | ||||||
|     "@nuxtjs/i18n": "^9.1.1", |     "@nuxtjs/i18n": "^9.1.1", | ||||||
|     "@vueuse/core": "^12.4.0", |     "@vueuse/core": "^12.4.0", | ||||||
|     "aliyun-aliplayer": "^2.28.5", |     "aliyun-aliplayer": "^2.28.5", | ||||||
|  |     "axios": "^1.7.9", | ||||||
|  |     "dotenv": "^16.4.7", | ||||||
|     "nuxt": "^3.15.0", |     "nuxt": "^3.15.0", | ||||||
|     "pinyin": "4.0.0-alpha.2", |     "pinyin": "4.0.0-alpha.2", | ||||||
|     "segmentit": "^2.0.3", |     "segmentit": "^2.0.3", | ||||||
| @ -32,6 +35,7 @@ | |||||||
|     "@unocss/preset-rem-to-px": "0.65.2", |     "@unocss/preset-rem-to-px": "0.65.2", | ||||||
|     "@vant/nuxt": "^1.0.6", |     "@vant/nuxt": "^1.0.6", | ||||||
|     "bumpp": "^9.9.2", |     "bumpp": "^9.9.2", | ||||||
|  |     "cross-env": "^7.0.3", | ||||||
|     "postcss-mobile-forever": "^4.3.1", |     "postcss-mobile-forever": "^4.3.1", | ||||||
|     "sass": "^1.83.1", |     "sass": "^1.83.1", | ||||||
|     "sass-loader": "^16.0.4", |     "sass-loader": "^16.0.4", | ||||||
|  | |||||||
| @ -23,6 +23,12 @@ importers: | |||||||
|       aliyun-aliplayer: |       aliyun-aliplayer: | ||||||
|         specifier: ^2.28.5 |         specifier: ^2.28.5 | ||||||
|         version: 2.28.5 |         version: 2.28.5 | ||||||
|  |       axios: | ||||||
|  |         specifier: ^1.7.9 | ||||||
|  |         version: 1.7.9 | ||||||
|  |       dotenv: | ||||||
|  |         specifier: ^16.4.7 | ||||||
|  |         version: 16.4.7 | ||||||
|       nuxt: |       nuxt: | ||||||
|         specifier: ^3.15.0 |         specifier: ^3.15.0 | ||||||
|         version: 3.15.0(@parcel/watcher@2.5.0)(@types/node@22.10.2)(db0@0.2.1)(eslint@9.17.0(jiti@2.4.2))(ioredis@5.4.2)(magicast@0.3.5)(optionator@0.9.4)(rollup@4.29.1)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))(yaml@2.6.1) |         version: 3.15.0(@parcel/watcher@2.5.0)(@types/node@22.10.2)(db0@0.2.1)(eslint@9.17.0(jiti@2.4.2))(ioredis@5.4.2)(magicast@0.3.5)(optionator@0.9.4)(rollup@4.29.1)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(typescript@5.7.2)(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))(yaml@2.6.1) | ||||||
| @ -54,6 +60,9 @@ importers: | |||||||
|       bumpp: |       bumpp: | ||||||
|         specifier: ^9.9.2 |         specifier: ^9.9.2 | ||||||
|         version: 9.9.2(magicast@0.3.5) |         version: 9.9.2(magicast@0.3.5) | ||||||
|  |       cross-env: | ||||||
|  |         specifier: ^7.0.3 | ||||||
|  |         version: 7.0.3 | ||||||
|       postcss-mobile-forever: |       postcss-mobile-forever: | ||||||
|         specifier: ^4.3.1 |         specifier: ^4.3.1 | ||||||
|         version: 4.3.1(postcss@8.4.49) |         version: 4.3.1(postcss@8.4.49) | ||||||
| @ -1657,6 +1666,9 @@ packages: | |||||||
|   async@3.2.6: |   async@3.2.6: | ||||||
|     resolution: {integrity: sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==} |     resolution: {integrity: sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==} | ||||||
| 
 | 
 | ||||||
|  |   asynckit@0.4.0: | ||||||
|  |     resolution: {integrity: sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==} | ||||||
|  | 
 | ||||||
|   autoprefixer@10.4.20: |   autoprefixer@10.4.20: | ||||||
|     resolution: {integrity: sha512-XY25y5xSv/wEoqzDyXXME4AFfkZI0P23z6Fs3YgymDnKJkCGOnkL0iTxCa85UTqaSgfcqyf3UA6+c7wUvx/16g==} |     resolution: {integrity: sha512-XY25y5xSv/wEoqzDyXXME4AFfkZI0P23z6Fs3YgymDnKJkCGOnkL0iTxCa85UTqaSgfcqyf3UA6+c7wUvx/16g==} | ||||||
|     engines: {node: ^10 || ^12 || >=14} |     engines: {node: ^10 || ^12 || >=14} | ||||||
| @ -1664,6 +1676,9 @@ packages: | |||||||
|     peerDependencies: |     peerDependencies: | ||||||
|       postcss: ^8.1.0 |       postcss: ^8.1.0 | ||||||
| 
 | 
 | ||||||
|  |   axios@1.7.9: | ||||||
|  |     resolution: {integrity: sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw==} | ||||||
|  | 
 | ||||||
|   b4a@1.6.7: |   b4a@1.6.7: | ||||||
|     resolution: {integrity: sha512-OnAYlL5b7LEkALw87fUVafQw5rVR9RjwGd4KUwNQ6DrrNmaVaUCgLipfVlzrPQ4tWOR9P0IXGNOx50jYCCdSJg==} |     resolution: {integrity: sha512-OnAYlL5b7LEkALw87fUVafQw5rVR9RjwGd4KUwNQ6DrrNmaVaUCgLipfVlzrPQ4tWOR9P0IXGNOx50jYCCdSJg==} | ||||||
| 
 | 
 | ||||||
| @ -1816,6 +1831,10 @@ packages: | |||||||
|   colorette@2.0.20: |   colorette@2.0.20: | ||||||
|     resolution: {integrity: sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==} |     resolution: {integrity: sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==} | ||||||
| 
 | 
 | ||||||
|  |   combined-stream@1.0.8: | ||||||
|  |     resolution: {integrity: sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==} | ||||||
|  |     engines: {node: '>= 0.8'} | ||||||
|  | 
 | ||||||
|   commander@1.1.1: |   commander@1.1.1: | ||||||
|     resolution: {integrity: sha512-71Rod2AhcH3JhkBikVpNd0pA+fWsmAaVoti6OR38T76chA7vE3pSerS0Jor4wDw+tOueD2zLVvFOw5H0Rcj7rA==} |     resolution: {integrity: sha512-71Rod2AhcH3JhkBikVpNd0pA+fWsmAaVoti6OR38T76chA7vE3pSerS0Jor4wDw+tOueD2zLVvFOw5H0Rcj7rA==} | ||||||
|     engines: {node: '>= 0.6.x'} |     engines: {node: '>= 0.6.x'} | ||||||
| @ -1889,6 +1908,11 @@ packages: | |||||||
|     resolution: {integrity: sha512-NKgHbWkSZXJUcaBHSsyzC8eegD6bBd4O0oCI6XMIJ+y4Bq3v4w7sY3wfWoKPuVlq9pQHRB6od0lmKpIqi8TlKA==} |     resolution: {integrity: sha512-NKgHbWkSZXJUcaBHSsyzC8eegD6bBd4O0oCI6XMIJ+y4Bq3v4w7sY3wfWoKPuVlq9pQHRB6od0lmKpIqi8TlKA==} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| 
 | 
 | ||||||
|  |   cross-env@7.0.3: | ||||||
|  |     resolution: {integrity: sha512-+/HKd6EgcQCJGh2PSjZuUitQBQynKor4wrFbRg4DtAgS1aWO+gU52xpH7M9ScGgXSYmAVS9bIJ8EzuaGw0oNAw==} | ||||||
|  |     engines: {node: '>=10.14', npm: '>=6', yarn: '>=1'} | ||||||
|  |     hasBin: true | ||||||
|  | 
 | ||||||
|   cross-spawn@7.0.6: |   cross-spawn@7.0.6: | ||||||
|     resolution: {integrity: sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==} |     resolution: {integrity: sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==} | ||||||
|     engines: {node: '>= 8'} |     engines: {node: '>= 8'} | ||||||
| @ -2017,6 +2041,10 @@ packages: | |||||||
|   defu@6.1.4: |   defu@6.1.4: | ||||||
|     resolution: {integrity: sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg==} |     resolution: {integrity: sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg==} | ||||||
| 
 | 
 | ||||||
|  |   delayed-stream@1.0.0: | ||||||
|  |     resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==} | ||||||
|  |     engines: {node: '>=0.4.0'} | ||||||
|  | 
 | ||||||
|   denque@2.1.0: |   denque@2.1.0: | ||||||
|     resolution: {integrity: sha512-HVQE3AAb/pxF8fQAoiqpvg9i3evqug3hoiwakOyZAwJm+6vZehbkYXZ0l4JxS+I3QxM97v5aaRNhj8v5oBhekw==} |     resolution: {integrity: sha512-HVQE3AAb/pxF8fQAoiqpvg9i3evqug3hoiwakOyZAwJm+6vZehbkYXZ0l4JxS+I3QxM97v5aaRNhj8v5oBhekw==} | ||||||
|     engines: {node: '>=0.10'} |     engines: {node: '>=0.10'} | ||||||
| @ -2293,10 +2321,23 @@ packages: | |||||||
|   flatted@3.3.2: |   flatted@3.3.2: | ||||||
|     resolution: {integrity: sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==} |     resolution: {integrity: sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==} | ||||||
| 
 | 
 | ||||||
|  |   follow-redirects@1.15.9: | ||||||
|  |     resolution: {integrity: sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==} | ||||||
|  |     engines: {node: '>=4.0'} | ||||||
|  |     peerDependencies: | ||||||
|  |       debug: '*' | ||||||
|  |     peerDependenciesMeta: | ||||||
|  |       debug: | ||||||
|  |         optional: true | ||||||
|  | 
 | ||||||
|   foreground-child@3.3.0: |   foreground-child@3.3.0: | ||||||
|     resolution: {integrity: sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==} |     resolution: {integrity: sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==} | ||||||
|     engines: {node: '>=14'} |     engines: {node: '>=14'} | ||||||
| 
 | 
 | ||||||
|  |   form-data@4.0.1: | ||||||
|  |     resolution: {integrity: sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==} | ||||||
|  |     engines: {node: '>= 6'} | ||||||
|  | 
 | ||||||
|   fraction.js@4.3.7: |   fraction.js@4.3.7: | ||||||
|     resolution: {integrity: sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==} |     resolution: {integrity: sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==} | ||||||
| 
 | 
 | ||||||
| @ -3326,6 +3367,9 @@ packages: | |||||||
|   protocols@2.0.1: |   protocols@2.0.1: | ||||||
|     resolution: {integrity: sha512-/XJ368cyBJ7fzLMwLKv1e4vLxOju2MNAIokcr7meSaNcVbWz/CPcW22cP04mwxOErdA5mwjA8Q6w/cdAQxVn7Q==} |     resolution: {integrity: sha512-/XJ368cyBJ7fzLMwLKv1e4vLxOju2MNAIokcr7meSaNcVbWz/CPcW22cP04mwxOErdA5mwjA8Q6w/cdAQxVn7Q==} | ||||||
| 
 | 
 | ||||||
|  |   proxy-from-env@1.1.0: | ||||||
|  |     resolution: {integrity: sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==} | ||||||
|  | 
 | ||||||
|   punycode@2.3.1: |   punycode@2.3.1: | ||||||
|     resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==} |     resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==} | ||||||
|     engines: {node: '>=6'} |     engines: {node: '>=6'} | ||||||
| @ -5994,6 +6038,8 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   async@3.2.6: {} |   async@3.2.6: {} | ||||||
| 
 | 
 | ||||||
|  |   asynckit@0.4.0: {} | ||||||
|  | 
 | ||||||
|   autoprefixer@10.4.20(postcss@8.4.49): |   autoprefixer@10.4.20(postcss@8.4.49): | ||||||
|     dependencies: |     dependencies: | ||||||
|       browserslist: 4.24.3 |       browserslist: 4.24.3 | ||||||
| @ -6004,6 +6050,14 @@ snapshots: | |||||||
|       postcss: 8.4.49 |       postcss: 8.4.49 | ||||||
|       postcss-value-parser: 4.2.0 |       postcss-value-parser: 4.2.0 | ||||||
| 
 | 
 | ||||||
|  |   axios@1.7.9: | ||||||
|  |     dependencies: | ||||||
|  |       follow-redirects: 1.15.9 | ||||||
|  |       form-data: 4.0.1 | ||||||
|  |       proxy-from-env: 1.1.0 | ||||||
|  |     transitivePeerDependencies: | ||||||
|  |       - debug | ||||||
|  | 
 | ||||||
|   b4a@1.6.7: {} |   b4a@1.6.7: {} | ||||||
| 
 | 
 | ||||||
|   babel-plugin-macros@2.8.0: |   babel-plugin-macros@2.8.0: | ||||||
| @ -6176,6 +6230,10 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   colorette@2.0.20: {} |   colorette@2.0.20: {} | ||||||
| 
 | 
 | ||||||
|  |   combined-stream@1.0.8: | ||||||
|  |     dependencies: | ||||||
|  |       delayed-stream: 1.0.0 | ||||||
|  | 
 | ||||||
|   commander@1.1.1: |   commander@1.1.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       keypress: 0.1.0 |       keypress: 0.1.0 | ||||||
| @ -6235,6 +6293,10 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   cronstrue@2.52.0: {} |   cronstrue@2.52.0: {} | ||||||
| 
 | 
 | ||||||
|  |   cross-env@7.0.3: | ||||||
|  |     dependencies: | ||||||
|  |       cross-spawn: 7.0.6 | ||||||
|  | 
 | ||||||
|   cross-spawn@7.0.6: |   cross-spawn@7.0.6: | ||||||
|     dependencies: |     dependencies: | ||||||
|       path-key: 3.1.1 |       path-key: 3.1.1 | ||||||
| @ -6357,6 +6419,8 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   defu@6.1.4: {} |   defu@6.1.4: {} | ||||||
| 
 | 
 | ||||||
|  |   delayed-stream@1.0.0: {} | ||||||
|  | 
 | ||||||
|   denque@2.1.0: {} |   denque@2.1.0: {} | ||||||
| 
 | 
 | ||||||
|   depd@2.0.0: {} |   depd@2.0.0: {} | ||||||
| @ -6704,11 +6768,19 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   flatted@3.3.2: {} |   flatted@3.3.2: {} | ||||||
| 
 | 
 | ||||||
|  |   follow-redirects@1.15.9: {} | ||||||
|  | 
 | ||||||
|   foreground-child@3.3.0: |   foreground-child@3.3.0: | ||||||
|     dependencies: |     dependencies: | ||||||
|       cross-spawn: 7.0.6 |       cross-spawn: 7.0.6 | ||||||
|       signal-exit: 4.1.0 |       signal-exit: 4.1.0 | ||||||
| 
 | 
 | ||||||
|  |   form-data@4.0.1: | ||||||
|  |     dependencies: | ||||||
|  |       asynckit: 0.4.0 | ||||||
|  |       combined-stream: 1.0.8 | ||||||
|  |       mime-types: 2.1.35 | ||||||
|  | 
 | ||||||
|   fraction.js@4.3.7: {} |   fraction.js@4.3.7: {} | ||||||
| 
 | 
 | ||||||
|   fresh@0.5.2: {} |   fresh@0.5.2: {} | ||||||
| @ -7855,6 +7927,8 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   protocols@2.0.1: {} |   protocols@2.0.1: {} | ||||||
| 
 | 
 | ||||||
|  |   proxy-from-env@1.1.0: {} | ||||||
|  | 
 | ||||||
|   punycode@2.3.1: {} |   punycode@2.3.1: {} | ||||||
| 
 | 
 | ||||||
|   queue-microtask@1.2.3: {} |   queue-microtask@1.2.3: {} | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user