This commit is contained in:
2025-07-29 00:38:01 +08:00
parent 1745a54eb6
commit d885ad84e2
7 changed files with 20 additions and 22 deletions

View File

@@ -4,22 +4,28 @@ FROM node:20-alpine AS base
# 1. 如项目有原生包better-sqlite3、sharp等启用下面两行 # 1. 如项目有原生包better-sqlite3、sharp等启用下面两行
# RUN apk add --no-cache build-base python3 sqlite-dev # RUN apk add --no-cache build-base python3 sqlite-dev
# 安装pnpm
RUN npm install -g pnpm
WORKDIR /app WORKDIR /app
# 2. 用 npm 锁文件 # 2. 用 pnpm 锁文件
COPY package.json package-lock.json ./ COPY package.json pnpm-lock.yaml ./
RUN npm ci --omit=dev # devDependencies 会用于编译阶段,保留即可 RUN pnpm install --frozen-lockfile
# 3. 源码 + 打补丁 # 3. 源码 + 打补丁
COPY . . COPY . .
RUN chmod +x patch-ui-pro.zsh && ./patch-ui-pro.zsh RUN chmod +x patch-ui-pro.zsh && ./patch-ui-pro.zsh
# 4. 构建产物 # 4. 构建产物
RUN npm run build RUN pnpm build
########## 阶段 2生产运行时 ########## ########## 阶段 2生产运行时 ##########
FROM node:20-alpine AS production FROM node:20-alpine AS production
# 安装pnpm
RUN npm install -g pnpm
# 输出里有 .outputNuxt3 的默认路径 # 输出里有 .outputNuxt3 的默认路径
WORKDIR /app WORKDIR /app
@@ -27,8 +33,8 @@ WORKDIR /app
# RUN apk add --no-cache sqlite-libs # RUN apk add --no-cache sqlite-libs
# 2. 只拷贝生产运行时 # 2. 只拷贝生产运行时
COPY package.json package-lock.json ./ COPY package.json pnpm-lock.yaml ./
RUN npm ci --omit=dev --only=production RUN pnpm install --frozen-lockfile --prod
COPY --from=base /app/.output /app/.output COPY --from=base /app/.output /app/.output

View File

@@ -7,7 +7,7 @@ const { data: files } = useLazyAsyncData('search', () => queryCollectionSearchSe
}) })
// 获取主题系统 // 获取主题系统
const { selectedTheme, selectedFont, selectedFontSize } = useTheme() const { selectedTheme, selectedFont } = useTheme()
// 计算根元素的 CSS 类 // 计算根元素的 CSS 类
const rootClasses = computed(() => { const rootClasses = computed(() => {
@@ -50,7 +50,6 @@ provide('navigation', navigation)
<template> <template>
<UApp> <UApp>
<NuxtLoadingIndicator /> <NuxtLoadingIndicator />
<UMain> <UMain>
<NuxtLayout> <NuxtLayout>
<NuxtPage /> <NuxtPage />

View File

@@ -96,14 +96,6 @@ const getChildrenWithIcons = (item: ContentNavigationItem) => {
return item.children.filter(child => child.title) return item.children.filter(child => child.title)
} }
// 获取描述信息
const getDescription = (item: ContentNavigationItem) => {
if (item.children && item.children.length > 0) {
return `${item.children.length} 个子页面`
}
return '文档页面'
}
// 导航方法 // 导航方法
const navigateTo = (path: string) => { const navigateTo = (path: string) => {
if (path) { if (path) {

View File

@@ -7,6 +7,7 @@
> >
<template <template
v-for="item in tabItems" v-for="item in tabItems"
:key="item.slot"
#[item.slot]="{ item: slotItem }" #[item.slot]="{ item: slotItem }"
> >
<div class="mt-4"> <div class="mt-4">
@@ -21,7 +22,7 @@ import type { TabsItem } from '@nuxt/ui'
const slots = useSlots() const slots = useSlots()
const slotContents = ref<Record<string, any>>({}) const slotContents = ref<Record<string, unknown>>({})
const tabItems = computed(() => { const tabItems = computed(() => {
const defaultSlots = slots.default?.() || [] const defaultSlots = slots.default?.() || []

View File

@@ -1,7 +1,6 @@
<script setup lang="ts"> <script setup lang="ts">
import type { NavigationMenuItem } from '@nuxt/ui' import type { NavigationMenuItem } from '@nuxt/ui'
const route = useRoute()
const items = ref<NavigationMenuItem[][]>([ const items = ref<NavigationMenuItem[][]>([
[ [
{ {

View File

@@ -35,8 +35,7 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { ref, watch } from 'vue' import { ref } from 'vue'
import { useRoute } from 'vue-router'
const isSidebarOpen = ref(false) const isSidebarOpen = ref(false)

View File

@@ -18,6 +18,8 @@ useSeoMeta({
</script> </script>
<template> <template>
<IndexHero /> <div>
<IndexCard /> <IndexHero />
<IndexCard />
</div>
</template> </template>