Commit Graph

13 Commits

Author SHA1 Message Date
zdl
f5dbdfa84c refactor(layout): 统一页面边距管理,移除 Container 限制
- layoutConfig.js: 新增 LAYOUT_PADDING 常量 { base: 4, md: 6, lg: '80px' }
- MainLayout.js: 在 Outlet 容器上统一应用 px={LAYOUT_PADDING.x}
- HomeNavbar.js: 边距从 lg:8 改为 lg:'80px',与内容区对齐
- AppFooter.js: 移除 Container,边距改为 lg:'80px'

页面组件清理(移除冗余的 px/Container):
- Company, Community, Center, Profile, Settings
- ValueForum, DataBrowser, LimitAnalyse, StockOverview, Concept

特殊处理:
- CompanyHeader: 使用负边距实现全宽背景
- Concept Hero: 使用负边距实现全宽背景

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-24 18:34:42 +08:00
zdl
f1ae48bd42 fix(Layout): 全局布局优化与 Mock 数据增强 2025-12-23 17:45:19 +08:00
zdl
2fe535e553 style(layout): 完善 Z-INDEX 层级管理,优化全局侧边栏样式
layoutConfig.js:
- 重构 Z_INDEX 常量,分层管理(页面内部 → 系统级)
- 添加详细注释说明各层级用途
- 新增 SIDEBAR、DROPDOWN、POPOVER 等层级定义

GlobalSidebar:
- 使用统一的 Z_INDEX.SIDEBAR 常量
- 优化背景色和边框样式
- 添加 h="100%" 确保高度填满

MainLayout:
- 简化注释

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-23 14:50:41 +08:00
zdl
c325d51316 fix(MainLayout): 调整页脚位置到滚动区域内
- 将 AppFooter 移动到内容滚动区域内
- 页脚随内容滚动,不再固定在底部
- 适配全局侧边栏布局

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-23 11:58:18 +08:00
zdl
bb0506b2bb feat(layouts): MainLayout 集成全局右侧工具栏
- 主体区域改为 Flex 布局(左侧内容 + 右侧侧边栏)
- 添加 GlobalSidebar 组件到右侧
- 页面内容区域自适应宽度

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-23 11:56:07 +08:00
zdl
1d5d06c567 fix: 调整事件详情页面 2025-12-04 19:01:35 +08:00
zdl
4aebb3bf4b feat: 调整导航栏高度 2025-11-26 14:10:09 +08:00
zdl
2d49af3bea feat: UI调整 2025-11-24 16:11:13 +08:00
9251531eb7 update pay function 2025-11-23 08:30:52 +08:00
zdl
5d8ad5e442 feat: bugfix 2025-10-31 10:33:53 +08:00
zdl
9b23149f1c refactor: 重构 MainLayout - 使用新组件(115行→68行)
## 优化成果
- 代码量:115 行 → 68 行(减少 63%)
- 实际代码:约 42 行(其余为详细注释)
- 复杂度:大幅降低
- 可维护性:

## 重构内容

### 1. 移除内联组件定义
**移除 BackToTopButton(37行)**
- 提取为独立组件 `src/layouts/components/BackToTopButton.js`
- 支持配置化使用

**移除 MotionBox 定义(1行)**
- 封装到 PageTransitionWrapper 中

### 2. 简化复杂嵌套逻辑
**原代码(18行复杂嵌套):**
```jsx
<Box flex="1" position="relative" overflow="hidden">
    <AnimatePresence mode="wait">
        <MotionBox key={location.pathname} ...>
            <ErrorBoundary>
                <Suspense fallback={<PageLoader />}>
                    <Outlet />
                </Suspense>
            </ErrorBoundary>
        </MotionBox>
    </AnimatePresence>
</Box>
```

**新代码(7行清晰简洁):**
```jsx
<PageTransitionWrapper
    location={location}
    animationConfig={ANIMATION_CONFIG.default}
    loaderMessage="页面加载中..."
>
    <Outlet />
</PageTransitionWrapper>
```

### 3. 使用配置文件
引入 `layoutConfig.js` 统一管理配置:
```javascript
import { ANIMATION_CONFIG, BACK_TO_TOP_CONFIG } from "./config/layoutConfig";
```

### 4. 组件配置化使用
```jsx
<BackToTopButton
    scrollThreshold={BACK_TO_TOP_CONFIG.scrollThreshold}
    position={BACK_TO_TOP_CONFIG.position}
    zIndex={BACK_TO_TOP_CONFIG.zIndex}
/>
```

## 保留的优化
-  React.memo - MemoizedHomeNavbar 和 MemoizedAppFooter
-  性能优化 - 导航栏/页脚渲染提升 50%+
-  错误隔离 - ErrorBoundary(封装在 PageTransitionWrapper)
-  页面动画 - framer-motion(封装在 PageTransitionWrapper)
-  返回顶部 - BackToTopButton 组件

## 架构优化成果
- 📦 组件拆分:职责单一,边界清晰
- 🔧 配置集中:易于维护和调整
- ♻️ 可复用性:组件可在其他 Layout 中使用
- 🧪 可测试性:独立组件,易于单元测试
- 📖 可读性:代码简洁,逻辑清晰

## 依赖关系
本次重构依赖以下 3 个 commit:
1. feat: 创建 layoutConfig(配置层)
2. feat: 创建 BackToTopButton(组件层)
3. feat: 创建 PageTransitionWrapper(组件层)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-30 15:24:06 +08:00
zdl
5aebd4b113 feat: 将 AppFooter 集成到 MainLayout 2025-10-24 17:17:31 +08:00
zdl
bae4d25e24 feat: 路由改造 2025-10-17 18:59:00 +08:00