tab2.page.html 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. <ion-header>
  2. <ion-toolbar color="light">
  3. <ion-title>装修</ion-title>
  4. </ion-toolbar>
  5. </ion-header>
  6. <ion-content>
  7. <!-- 搜索框 -->
  8. <ion-searchbar placeholder="输入关键字搜索"></ion-searchbar>
  9. <!-- 导航栏 -->
  10. <ion-segment (ionChange)="segmentChanged($event)">
  11. <ion-segment-button value="company">
  12. <ion-icon name="business"></ion-icon>
  13. 装修公司
  14. </ion-segment-button>
  15. <ion-segment-button value="design">
  16. <ion-icon name="brush"></ion-icon>
  17. 设计机构
  18. </ion-segment-button>
  19. <ion-segment-button value="designer">
  20. <ion-icon name="person"></ion-icon>
  21. 独立设计师
  22. </ion-segment-button>
  23. </ion-segment>
  24. <!-- 区域用来展示详情页 -->
  25. <div class="details-container">
  26. <!-- 装修公司详情页 -->
  27. <div *ngIf="selectedSegment === 'company'">
  28. <div *ngFor="let company of companies">
  29. <ion-card class="Company-card">
  30. <ion-card-header><ion-card-title> {{ company.name }}</ion-card-title>
  31. </ion-card-header>
  32. <ion-card-content>
  33. <ion-label>星级评分:</ion-label>
  34. <ion-text>{{ company.starRating }}</ion-text>
  35. <ion-label>评价数量:</ion-label>
  36. <ion-text>{{ company.reviewCount }}</ion-text>
  37. <!-- 公司简介 -->
  38. <ion-card class="company-card">
  39. <ion-card-header>
  40. 公司简介:
  41. </ion-card-header>
  42. <ion-card-content>
  43. <ion-text [innerHTML]="formatHtmlContent(company.description)"></ion-text>
  44. </ion-card-content>
  45. </ion-card>
  46. <!-- 公司服务 -->
  47. <ion-card class="company-card">
  48. <ion-card-header>
  49. 公司服务:
  50. </ion-card-header>
  51. <ion-card-content>
  52. <ion-text [innerHTML]="formatHtmlContent(company.services)"></ion-text>
  53. </ion-card-content>
  54. </ion-card>
  55. <!-- 公司优势 -->
  56. <ion-card class="company-card">
  57. <ion-card-header>
  58. 公司优势:
  59. </ion-card-header>
  60. <ion-card-content>
  61. <ion-text [innerHTML]="formatHtmlContent(company.advantages)"></ion-text>
  62. </ion-card-content>
  63. </ion-card>
  64. <!-- 公司案例 -->
  65. <ion-card class="company-card">
  66. <ion-card-header>
  67. 公司案例:
  68. </ion-card-header>
  69. <ion-card-content>
  70. <ion-text [innerHTML]="formatHtmlContent(company.cases)"></ion-text>
  71. </ion-card-content>
  72. </ion-card>
  73. <!-- 底部按钮 -->
  74. <ion-button expand="full" fill="clear">电话</ion-button>
  75. <ion-button expand="full" fill="clear">预约</ion-button>
  76. <ion-button expand="full" fill="clear">咨询</ion-button>
  77. <ion-button expand="full" fill="clear">查看案例</ion-button>
  78. </ion-card-content>
  79. </ion-card>
  80. </div>
  81. </div>
  82. <!-- 设计机构详情页 -->
  83. <div *ngIf="selectedSegment === 'design'">
  84. <div *ngFor="let designCompany of designCompanies">
  85. <ion-card class="Angency-card">
  86. <ion-card-header>
  87. <ion-card-title>{{ designCompany.name }}</ion-card-title>
  88. <ion-card-subtitle>星级评分: {{ designCompany.starRating }} | 评价数量: {{ designCompany.reviewCount }}</ion-card-subtitle>
  89. </ion-card-header>
  90. <ion-card-content>
  91. <!-- 机构简介 -->
  92. <ion-card class="ant-card">
  93. <ion-card-header class="ant-card">
  94. 机构简介:
  95. </ion-card-header>
  96. <ion-card-content>
  97. <ion-text [innerHTML]="formatHtmlContent(designCompany.description )"></ion-text>
  98. </ion-card-content>
  99. </ion-card>
  100. <!-- 机构介绍 -->
  101. <ion-card class="ant-card">
  102. <ion-card-header class="ant-card">
  103. 机构服务:
  104. </ion-card-header>
  105. <ion-card-content>
  106. <ion-text [innerHTML]="formatHtmlContent(designCompany.services )"></ion-text>
  107. </ion-card-content>
  108. </ion-card>
  109. <!-- 机构介绍 -->
  110. <ion-card class="ant-card">
  111. <ion-card-header class="ant-card">
  112. 机构优势:
  113. </ion-card-header>
  114. <ion-card-content>
  115. <ion-text [innerHTML]="formatHtmlContent(designCompany.advantages )"></ion-text>
  116. </ion-card-content>
  117. </ion-card>
  118. <!-- 设计师团队 -->
  119. <ion-card class="ant-card">
  120. <ion-card-header class="ant-card">
  121. 设计师团队:
  122. </ion-card-header>
  123. <ion-card-content>
  124. <ion-item *ngFor="let designer of designCompany.designers" lines="none">
  125. <ion-avatar slot="start">
  126. <img [src]="designer.avatar" alt="设计师头像">
  127. </ion-avatar>
  128. <ion-label>{{ designer.name }}</ion-label>
  129. <ion-label>{{ designer.style }}</ion-label>
  130. <ion-label>{{ designer.serviceArea }}</ion-label>
  131. <ion-label>{{ designer.price }}</ion-label>
  132. </ion-item>
  133. </ion-card-content>
  134. </ion-card>
  135. <!-- 案例展示 -->
  136. <ion-card class="ant-card">
  137. <ion-card-header class="ant-card">
  138. 案例展示:
  139. </ion-card-header>
  140. <ion-card-content>
  141. <ion-item *ngFor="let case of designCompany.cases" lines="none">
  142. <div class="case-container">
  143. <img [src]="case.image" alt="案例图片" class="case-image">
  144. <div class="case-details">
  145. <ion-label>{{ case.description }}</ion-label>
  146. <ion-text>设计风格:{{ case.style }}</ion-text>
  147. </div>
  148. </div>
  149. </ion-item>
  150. </ion-card-content>
  151. </ion-card>
  152. <!-- 设计理念 -->
  153. <ion-card class="ant-card">
  154. <ion-card-header class="ant-card">
  155. 设计理念:
  156. </ion-card-header>
  157. <ion-card-content>
  158. <ion-text>{{ designCompany.designConcept }}</ion-text>
  159. </ion-card-content>
  160. </ion-card>
  161. <!-- 服务流程 -->
  162. <ion-card class="ant-card">
  163. <ion-card-header class="ant-card">
  164. 服务流程:
  165. </ion-card-header>
  166. <ion-card-content>
  167. <ion-text [innerHTML]="formatHtmlContent(designCompany.serviceProcess)"></ion-text>
  168. </ion-card-content>
  169. </ion-card>
  170. <!-- 用户评价 -->
  171. <ion-card class="ant-card">
  172. <ion-card-header class="ant-card">
  173. 用户评价:
  174. </ion-card-header>
  175. <ion-card-content>
  176. <ion-item *ngFor="let review of designCompany.userReviews" lines="none">
  177. <div class="review-container">
  178. <img [src]="review.image" alt="用户评价图片">
  179. <div class="review-details">
  180. <ion-text>星级评分: {{ review.starRating }}</ion-text>
  181. <ion-label>{{ review.text }}</ion-label>
  182. </div>
  183. </div>
  184. </ion-item>
  185. </ion-card-content>
  186. </ion-card>
  187. <!-- 底部按钮 -->
  188. <ion-button expand="full" fill="clear">电话</ion-button>
  189. <ion-button expand="full" fill="clear">预约</ion-button>
  190. <ion-button expand="full" fill="clear">咨询</ion-button>
  191. <ion-button expand="full" fill="clear">查看案例</ion-button>
  192. </ion-card-content>
  193. </ion-card>
  194. </div>
  195. </div>
  196. <div *ngIf="selectedSegment === 'designer'">
  197. <ion-card *ngFor="let designer of designers" class="Designer-card">
  198. <!-- 头部 -->
  199. <ion-card-header class="header">
  200. <div class="avatar-container">
  201. <ion-avatar class="avatar">
  202. <img [src]="designer.avatar" alt="Designer Avatar">
  203. </ion-avatar>
  204. </div>
  205. <div class="name-container">
  206. <ion-card-title class="title">{{ designer.username }}</ion-card-title>
  207. <ion-button fill="clear" slot="end" class="custom-button" (click)="toggleFollow()">
  208. {{ isFollowing ? '已关注' : '关注' }}
  209. </ion-button>
  210. </div>
  211. </ion-card-header>
  212. <ion-card-content>
  213. <p>{{ designer.bio }}</p>
  214. </ion-card-content>
  215. <!-- 内容 -->
  216. <ion-card-content class="content">
  217. <ion-img [src]="designer.portfolioImage" alt="Designer Portfolio"></ion-img>
  218. <ion-item>
  219. <ion-label>作品数量:</ion-label>
  220. <ion-text>{{ designer.portfolioCount }}</ion-text>
  221. </ion-item>
  222. <ion-item>
  223. <ion-label>擅长风格:</ion-label>
  224. <ion-text>{{ designer.style }}</ion-text>
  225. </ion-item>
  226. <ion-item>
  227. <ion-label>服务地区:</ion-label>
  228. <ion-text>{{ designer.serviceArea }}</ion-text>
  229. </ion-item>
  230. <ion-item>
  231. <ion-label>价格:</ion-label>
  232. <ion-text>{{ designer.price }}</ion-text>
  233. </ion-item>
  234. <ion-item>
  235. <ion-label>用户评价:</ion-label>
  236. <ion-text>{{ designer.rating }}</ion-text>
  237. </ion-item>
  238. </ion-card-content>
  239. <!-- 底部 -->
  240. <ion-button expand="full" fill="clear">咨询</ion-button>
  241. <ion-button expand="full" fill="clear">电话</ion-button>
  242. <ion-button expand="full" fill="clear">在线预约</ion-button>
  243. <ion-button expand="full" fill="clear">查看案例</ion-button>
  244. </ion-card>
  245. </div>
  246. </div>
  247. </ion-content>