|  | @@ -0,0 +1,153 @@
 | 
	
		
			
				|  |  | +<div class="case-detail-panel">
 | 
	
		
			
				|  |  | +  <!-- 头部 -->
 | 
	
		
			
				|  |  | +  <div class="panel-header">
 | 
	
		
			
				|  |  | +    <h2 class="panel-title">案例详情</h2>
 | 
	
		
			
				|  |  | +    <button class="close-btn" (click)="closePanel()">
 | 
	
		
			
				|  |  | +      <svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor">
 | 
	
		
			
				|  |  | +        <line x1="18" y1="6" x2="6" y2="18"></line>
 | 
	
		
			
				|  |  | +        <line x1="6" y1="6" x2="18" y2="18"></line>
 | 
	
		
			
				|  |  | +      </svg>
 | 
	
		
			
				|  |  | +    </button>
 | 
	
		
			
				|  |  | +  </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  <!-- 内容区域 -->
 | 
	
		
			
				|  |  | +  <div class="panel-content">
 | 
	
		
			
				|  |  | +    <!-- 封面图片 -->
 | 
	
		
			
				|  |  | +    <div class="cover-image">
 | 
	
		
			
				|  |  | +      <img [src]="case.coverImage" [alt]="case.name" class="cover-img">
 | 
	
		
			
				|  |  | +      <div class="image-overlay">
 | 
	
		
			
				|  |  | +        <div class="case-badges">
 | 
	
		
			
				|  |  | +          <span class="badge project-type">{{ case.projectType }}</span>
 | 
	
		
			
				|  |  | +          <span class="badge space-type">{{ case.spaceType }}</span>
 | 
	
		
			
				|  |  | +          <span class="badge rendering-level">{{ case.renderingLevel }}</span>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +      </div>
 | 
	
		
			
				|  |  | +    </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    <!-- 基本信息 -->
 | 
	
		
			
				|  |  | +    <div class="basic-info">
 | 
	
		
			
				|  |  | +      <h1 class="case-name">{{ case.name }}</h1>
 | 
	
		
			
				|  |  | +      
 | 
	
		
			
				|  |  | +      <div class="meta-grid">
 | 
	
		
			
				|  |  | +        <div class="meta-item">
 | 
	
		
			
				|  |  | +          <svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor">
 | 
	
		
			
				|  |  | +            <path d="M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2"></path>
 | 
	
		
			
				|  |  | +            <circle cx="12" cy="7" r="4"></circle>
 | 
	
		
			
				|  |  | +          </svg>
 | 
	
		
			
				|  |  | +          <div class="meta-content">
 | 
	
		
			
				|  |  | +            <span class="meta-label">设计师</span>
 | 
	
		
			
				|  |  | +            <span class="meta-value">{{ case.designer }}</span>
 | 
	
		
			
				|  |  | +            @if (isInternalUser) {
 | 
	
		
			
				|  |  | +              <span class="team-badge">{{ case.team }}</span>
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        <div class="meta-item">
 | 
	
		
			
				|  |  | +          <svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor">
 | 
	
		
			
				|  |  | +            <rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect>
 | 
	
		
			
				|  |  | +            <line x1="3" y1="9" x2="21" y2="9"></line>
 | 
	
		
			
				|  |  | +          </svg>
 | 
	
		
			
				|  |  | +          <div class="meta-content">
 | 
	
		
			
				|  |  | +            <span class="meta-label">面积</span>
 | 
	
		
			
				|  |  | +            <span class="meta-value">{{ case.area }}㎡</span>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        <div class="meta-item">
 | 
	
		
			
				|  |  | +          <svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor">
 | 
	
		
			
				|  |  | +            <path d="M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z"></path>
 | 
	
		
			
				|  |  | +            <path d="M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z"></path>
 | 
	
		
			
				|  |  | +          </svg>
 | 
	
		
			
				|  |  | +          <div class="meta-content">
 | 
	
		
			
				|  |  | +            <span class="meta-label">浏览量</span>
 | 
	
		
			
				|  |  | +            <span class="meta-value">{{ case.viewCount }}</span>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        <div class="meta-item">
 | 
	
		
			
				|  |  | +          <svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor">
 | 
	
		
			
				|  |  | +            <circle cx="12" cy="12" r="10"></circle>
 | 
	
		
			
				|  |  | +            <polyline points="12 6 12 12 16 14"></polyline>
 | 
	
		
			
				|  |  | +          </svg>
 | 
	
		
			
				|  |  | +          <div class="meta-content">
 | 
	
		
			
				|  |  | +            <span class="meta-label">创建时间</span>
 | 
	
		
			
				|  |  | +            <span class="meta-value">{{ getFormattedDate(case.createdAt) }}</span>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +      </div>
 | 
	
		
			
				|  |  | +    </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    <!-- 风格标签 -->
 | 
	
		
			
				|  |  | +    <div class="style-section">
 | 
	
		
			
				|  |  | +      <h3 class="section-title">设计风格</h3>
 | 
	
		
			
				|  |  | +      <div class="style-tags">
 | 
	
		
			
				|  |  | +        @for (tag of case.styleTags; track $index) {
 | 
	
		
			
				|  |  | +          <span class="style-tag">{{ tag }}</span>
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +      </div>
 | 
	
		
			
				|  |  | +    </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    <!-- 客户评价 -->
 | 
	
		
			
				|  |  | +    @if (case.customerReview) {
 | 
	
		
			
				|  |  | +      <div class="review-section">
 | 
	
		
			
				|  |  | +        <h3 class="section-title">客户评价</h3>
 | 
	
		
			
				|  |  | +        <div class="review-content">
 | 
	
		
			
				|  |  | +          <div class="quote-icon">"</div>
 | 
	
		
			
				|  |  | +          <p class="review-text">{{ case.customerReview }}</p>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +      </div>
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    <!-- 设计师内部信息 -->
 | 
	
		
			
				|  |  | +    @if (isInternalUser) {
 | 
	
		
			
				|  |  | +      <div class="internal-section">
 | 
	
		
			
				|  |  | +        <h3 class="section-title">内部信息</h3>
 | 
	
		
			
				|  |  | +        <div class="internal-grid">
 | 
	
		
			
				|  |  | +          <div class="internal-item">
 | 
	
		
			
				|  |  | +            <span class="internal-label">案例等级</span>
 | 
	
		
			
				|  |  | +            <span class="internal-badge" [class.excellent]="case.isExcellent">
 | 
	
		
			
				|  |  | +              {{ case.isExcellent ? '优秀案例' : '普通案例' }}
 | 
	
		
			
				|  |  | +            </span>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +          <div class="internal-item">
 | 
	
		
			
				|  |  | +            <span class="internal-label">分享次数</span>
 | 
	
		
			
				|  |  | +            <span class="internal-value">{{ case.shareCount }}</span>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +          <div class="internal-item">
 | 
	
		
			
				|  |  | +            <span class="internal-label">收藏次数</span>
 | 
	
		
			
				|  |  | +            <span class="internal-value">{{ case.favoriteCount }}</span>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +      </div>
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  <!-- 底部操作栏 -->
 | 
	
		
			
				|  |  | +  <div class="panel-footer">
 | 
	
		
			
				|  |  | +    <button 
 | 
	
		
			
				|  |  | +      class="btn btn-secondary" 
 | 
	
		
			
				|  |  | +      (click)="onShare()"
 | 
	
		
			
				|  |  | +    >
 | 
	
		
			
				|  |  | +      <svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor">
 | 
	
		
			
				|  |  | +        <circle cx="18" cy="5" r="3"></circle>
 | 
	
		
			
				|  |  | +        <circle cx="6" cy="12" r="3"></circle>
 | 
	
		
			
				|  |  | +        <circle cx="18" cy="19" r="3"></circle>
 | 
	
		
			
				|  |  | +        <line x1="8.59" y1="13.51" x2="15.42" y2="17.49"></line>
 | 
	
		
			
				|  |  | +        <line x1="15.41" y1="6.51" x2="8.59" y2="10.49"></line>
 | 
	
		
			
				|  |  | +      </svg>
 | 
	
		
			
				|  |  | +      分享案例
 | 
	
		
			
				|  |  | +    </button>
 | 
	
		
			
				|  |  | +    
 | 
	
		
			
				|  |  | +    <button 
 | 
	
		
			
				|  |  | +      class="btn btn-primary" 
 | 
	
		
			
				|  |  | +      [class.active]="case.isFavorite"
 | 
	
		
			
				|  |  | +      (click)="onToggleFavorite()"
 | 
	
		
			
				|  |  | +    >
 | 
	
		
			
				|  |  | +      <svg width="18" height="18" viewBox="0 0 24 24" fill="currentColor">
 | 
	
		
			
				|  |  | +        <path d="M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z"></path>
 | 
	
		
			
				|  |  | +      </svg>
 | 
	
		
			
				|  |  | +      {{ case.isFavorite ? '已收藏' : '收藏案例' }}
 | 
	
		
			
				|  |  | +    </button>
 | 
	
		
			
				|  |  | +  </div>
 | 
	
		
			
				|  |  | +</div>
 |