dashboard.html 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <div class="dashboard-container">
  2. <header class="dashboard-header">
  3. <h1>设计师工作台</h1>
  4. <!-- 顶部导航 -->
  5. <nav class="dashboard-nav">
  6. <button class="nav-btn active" (click)="switchDashboard('main')">工作台</button>
  7. <button class="nav-btn" (click)="switchDashboard('skills')">能力雷达</button>
  8. <button class="nav-btn" (click)="switchDashboard('personal')">个人看板</button>
  9. </nav>
  10. </header>
  11. <!-- 主要内容区域 - 工作台 -->
  12. <div *ngIf="activeDashboard === 'main'" class="dashboard-main">
  13. <!-- 核心信息卡片区域 - 每行列3张卡片 -->
  14. <section class="core-cards-section">
  15. <div class="cards-grid">
  16. <!-- 紧急任务卡片 -->
  17. <div *ngFor="let task of urgentTasks" class="core-card urgent-card">
  18. <div class="card-header">
  19. <span class="card-badge urgent">紧急</span>
  20. <h3>{{ task.title }}</h3>
  21. </div>
  22. <div class="card-content">
  23. <p class="project-name">项目: {{ task.projectName }}</p>
  24. <p class="countdown">剩余: {{ getTaskCountdown(task.id) }}</p>
  25. </div>
  26. <div class="card-actions">
  27. <button [routerLink]="['/designer/project-detail', task.projectId]" class="btn-primary">
  28. 立即处理
  29. </button>
  30. </div>
  31. </div>
  32. <!-- 待办任务卡片 -->
  33. <div *ngFor="let task of getTopTasks(6 - urgentTasks.length)" class="core-card task-card">
  34. <div class="card-header">
  35. <span class="card-badge" [class.overdue]="task.isOverdue">
  36. {{ task.stage }}
  37. <span *ngIf="task.isOverdue">/超期</span>
  38. </span>
  39. <h3>{{ task.title }}</h3>
  40. </div>
  41. <div class="card-content">
  42. <p class="project-name">项目: {{ task.projectName }}</p>
  43. <p class="deadline" [class.overdue]="task.isOverdue">
  44. 截止: {{ task.deadline | date:'yyyy-MM-dd HH:mm' }}
  45. </p>
  46. <!-- 进度条 -->
  47. <div class="task-progress" *ngIf="task.stage !== '完成'">
  48. <div class="progress-bar">
  49. <div class="progress-fill" [style.width]="getTaskStageProgress(task.id) + '%'">
  50. </div>
  51. </div>
  52. <p class="progress-text">{{ getTaskStageProgress(task.id) }}%</p>
  53. </div>
  54. </div>
  55. <div class="card-actions">
  56. <button *ngIf="!task.isCompleted" (click)="markTaskAsCompleted(task.id)" class="btn-secondary">
  57. 标记完成
  58. </button>
  59. <button [routerLink]="['/designer/project-detail', task.projectId]" class="btn-primary">
  60. 查看详情
  61. </button>
  62. </div>
  63. </div>
  64. <!-- 项目饱和度卡片 -->
  65. <div class="core-card workload-card" *ngIf="(urgentTasks.length + tasks.length) < 6">
  66. <div class="card-header">
  67. <span class="card-badge workload">饱和度</span>
  68. <h3>当前工作量</h3>
  69. </div>
  70. <div class="card-content">
  71. <div class="workload-indicator">
  72. <div class="workload-circle" [style.background]="getWorkloadColor()">
  73. <span class="workload-percentage">{{ workloadPercentage }}%</span>
  74. </div>
  75. </div>
  76. <p class="workload-status">{{ getWorkloadStatus() }}</p>
  77. </div>
  78. <div class="card-actions">
  79. <button class="btn-secondary" (click)="switchDashboard('personal')">
  80. 查看详情
  81. </button>
  82. </div>
  83. </div>
  84. </div>
  85. </section>
  86. <!-- 附加信息区域 -->
  87. <section class="additional-info-section">
  88. <!-- 待处理反馈区域 -->
  89. <div class="info-column" *ngIf="pendingFeedbacks.length > 0">
  90. <div class="section-header">
  91. <h2>待处理反馈</h2>
  92. </div>
  93. <div class="feedback-list">
  94. <div *ngFor="let item of pendingFeedbacks" class="feedback-item">
  95. <div class="feedback-content">
  96. <p class="feedback-title">⚠️ {{ item.task.title }} - 客户反馈</p>
  97. <p class="feedback-project">项目: {{ item.task.projectName }}</p>
  98. <p class="feedback-summary">反馈: {{ !item.feedback.isSatisfied ? '不满意' : '满意' }}</p>
  99. </div>
  100. <div class="feedback-actions">
  101. <button (click)="handleFeedback(item.task.id)" class="btn-handle-feedback">
  102. 处理反馈
  103. </button>
  104. </div>
  105. </div>
  106. </div>
  107. </div>
  108. <!-- 代班信息区域 -->
  109. <div class="info-column" *ngIf="shiftTasks.length > 0">
  110. <div class="section-header">
  111. <h2>👥 代班信息</h2>
  112. <button class="add-shift-btn" (click)="openShiftModal()">
  113. 添加代班任务
  114. </button>
  115. </div>
  116. <div class="shift-list">
  117. <div class="shift-item" *ngFor="let shift of shiftTasks">
  118. <div class="shift-header">
  119. <div class="shift-project">{{ shift.projectName }}</div>
  120. <div class="shift-priority" [class.priority-high]="shift.priority === '高'" [class.priority-medium]="shift.priority === '中'" [class.priority-low]="shift.priority === '低'">
  121. {{ shift.priority }}级
  122. </div>
  123. </div>
  124. <div class="shift-details">
  125. <div class="shift-task">{{ shift.taskDescription }}</div>
  126. <div class="shift-time">代班时间: {{ shift.shiftDate }}</div>
  127. </div>
  128. </div>
  129. </div>
  130. </div>
  131. <!-- 时间预警区域 -->
  132. <div class="info-column" *ngIf="overdueTasks.length > 0">
  133. <div class="section-header">
  134. <h2>⏰ 时间预警</h2>
  135. </div>
  136. <div class="warning-list">
  137. <div *ngFor="let task of overdueTasks" class="warning-item">
  138. <div class="warning-content">
  139. <p class="warning-title">{{ task.title }} - 已超期</p>
  140. <p class="warning-detail">项目: {{ task.projectName }}</p>
  141. </div>
  142. </div>
  143. </div>
  144. </div>
  145. </section>
  146. <!-- 底部信息分层展示 -->
  147. <div class="bottom-sections">
  148. <!-- 能力雷达区域 -->
  149. <section class="bottom-section">
  150. <app-skill-radar></app-skill-radar>
  151. </section>
  152. </div>
  153. </div>
  154. <!-- 能力雷达单独视图 -->
  155. <div *ngIf="activeDashboard === 'skills'" class="skills-view">
  156. <app-skill-radar></app-skill-radar>
  157. </div>
  158. <!-- 个人看板单独视图 -->
  159. <div *ngIf="activeDashboard === 'personal'" class="personal-view">
  160. <app-personal-board></app-personal-board>
  161. </div>
  162. <!-- 提醒话术弹窗 -->
  163. <div *ngIf="reminderMessage" class="reminder-modal">
  164. <div class="modal-content">
  165. <h3>提醒话术</h3>
  166. <p>{{ reminderMessage }}</p>
  167. <button (click)="clearReminder()" class="btn-close">关闭</button>
  168. </div>
  169. </div>
  170. </div>