@zap-wunschlachen/wl-shared-components 1.0.0 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (487) hide show
  1. package/.github/workflows/playwright.yml +12 -21
  2. package/.github/workflows/update-snapshots.yml +38 -0
  3. package/App.vue +62 -10
  4. package/package.json +3 -2
  5. package/playwright.config.ts +15 -2
  6. package/src/components/Appointment/Card/Actions.css +1 -2
  7. package/src/components/Appointment/Card/Actions.vue +17 -13
  8. package/src/components/Appointment/Card/Card.vue +10 -5
  9. package/src/components/Appointment/Card/Details.vue +1 -1
  10. package/src/components/index.ts +1 -0
  11. package/tests/e2e/all-components.spec.ts +3 -2
  12. package/tests/e2e/appointment-card.spec.ts +817 -0
  13. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/accordion-default.png +0 -0
  14. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-default.png +0 -0
  15. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-disabled.png +0 -0
  16. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-focus-state.png +0 -0
  17. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-hover-state.png +0 -0
  18. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-loading.png +0 -0
  19. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-normal-state.png +0 -0
  20. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-outlined.png +0 -0
  21. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/button-states-composite.png +0 -0
  22. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/checkbox-default.png +0 -0
  23. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/dark-mode-component-1.png +0 -0
  24. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/dark-mode-component-2.png +0 -0
  25. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/dark-mode-component-3.png +0 -0
  26. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/dateinput-default.png +0 -0
  27. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/dialog-default.png +0 -0
  28. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/editfield-default.png +0 -0
  29. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-default.png +0 -0
  30. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-error.png +0 -0
  31. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-filled-state.png +0 -0
  32. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-focus-state.png +0 -0
  33. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-normal-state.png +0 -0
  34. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-state-default.png +0 -0
  35. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-state-error.png +0 -0
  36. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-state-success.png +0 -0
  37. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-state-warning.png +0 -0
  38. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-success.png +0 -0
  39. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/input-warning.png +0 -0
  40. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-appointmentcard.png +0 -0
  41. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-chatmessage.png +0 -0
  42. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-chatnotification.png +0 -0
  43. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-documentcard.png +0 -0
  44. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-infocard.png +0 -0
  45. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-progresscircle.png +0 -0
  46. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-taglabel.png +0 -0
  47. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/lab-ticketcard.png +0 -0
  48. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/notificationbubble-default.png +0 -0
  49. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/otpinput-default.png +0 -0
  50. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/phoneinput-default.png +0 -0
  51. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/responsive-desktop-component-1.png +0 -0
  52. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/responsive-desktop-component-2.png +0 -0
  53. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/responsive-mobile-component-1.png +0 -0
  54. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/responsive-mobile-component-2.png +0 -0
  55. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/responsive-tablet-component-1.png +0 -0
  56. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/responsive-tablet-component-2.png +0 -0
  57. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/select-default.png +0 -0
  58. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/textarea-default.png +0 -0
  59. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Chrome/tickbox-default.png +0 -0
  60. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/accordion-default.png +0 -0
  61. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-default.png +0 -0
  62. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-disabled.png +0 -0
  63. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-focus-state.png +0 -0
  64. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-hover-state.png +0 -0
  65. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-loading.png +0 -0
  66. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-normal-state.png +0 -0
  67. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-outlined.png +0 -0
  68. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/button-states-composite.png +0 -0
  69. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/checkbox-default.png +0 -0
  70. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/dark-mode-component-1.png +0 -0
  71. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/dark-mode-component-2.png +0 -0
  72. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/dark-mode-component-3.png +0 -0
  73. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/dateinput-default.png +0 -0
  74. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/dialog-default.png +0 -0
  75. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/editfield-default.png +0 -0
  76. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-default.png +0 -0
  77. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-error.png +0 -0
  78. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-filled-state.png +0 -0
  79. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-focus-state.png +0 -0
  80. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-normal-state.png +0 -0
  81. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-state-default.png +0 -0
  82. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-state-error.png +0 -0
  83. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-state-success.png +0 -0
  84. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-state-warning.png +0 -0
  85. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-success.png +0 -0
  86. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/input-warning.png +0 -0
  87. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-appointmentcard.png +0 -0
  88. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-chatmessage.png +0 -0
  89. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-chatnotification.png +0 -0
  90. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-documentcard.png +0 -0
  91. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-infocard.png +0 -0
  92. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-progresscircle.png +0 -0
  93. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-taglabel.png +0 -0
  94. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/lab-ticketcard.png +0 -0
  95. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/notificationbubble-default.png +0 -0
  96. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/otpinput-default.png +0 -0
  97. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/phoneinput-default.png +0 -0
  98. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/responsive-desktop-component-1.png +0 -0
  99. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/responsive-desktop-component-2.png +0 -0
  100. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/responsive-mobile-component-1.png +0 -0
  101. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/responsive-mobile-component-2.png +0 -0
  102. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/responsive-tablet-component-1.png +0 -0
  103. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/responsive-tablet-component-2.png +0 -0
  104. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/select-default.png +0 -0
  105. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/textarea-default.png +0 -0
  106. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/Mobile-Safari/tickbox-default.png +0 -0
  107. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/accordion-default.png +0 -0
  108. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-default.png +0 -0
  109. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-disabled.png +0 -0
  110. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-focus-state.png +0 -0
  111. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-hover-state.png +0 -0
  112. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-loading.png +0 -0
  113. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-normal-state.png +0 -0
  114. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-outlined.png +0 -0
  115. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/button-states-composite.png +0 -0
  116. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/checkbox-default.png +0 -0
  117. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/dark-mode-component-1.png +0 -0
  118. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/dark-mode-component-2.png +0 -0
  119. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/dark-mode-component-3.png +0 -0
  120. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/dateinput-default.png +0 -0
  121. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/dialog-default.png +0 -0
  122. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/editfield-default.png +0 -0
  123. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-default.png +0 -0
  124. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-error.png +0 -0
  125. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-filled-state.png +0 -0
  126. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-focus-state.png +0 -0
  127. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-normal-state.png +0 -0
  128. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-state-default.png +0 -0
  129. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-state-error.png +0 -0
  130. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-state-success.png +0 -0
  131. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-state-warning.png +0 -0
  132. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-success.png +0 -0
  133. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/input-warning.png +0 -0
  134. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-appointmentcard.png +0 -0
  135. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-chatmessage.png +0 -0
  136. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-chatnotification.png +0 -0
  137. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-documentcard.png +0 -0
  138. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-infocard.png +0 -0
  139. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-progresscircle.png +0 -0
  140. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-taglabel.png +0 -0
  141. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/lab-ticketcard.png +0 -0
  142. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/notificationbubble-default.png +0 -0
  143. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/otpinput-default.png +0 -0
  144. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/phoneinput-default.png +0 -0
  145. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/responsive-desktop-component-1.png +0 -0
  146. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/responsive-desktop-component-2.png +0 -0
  147. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/responsive-mobile-component-1.png +0 -0
  148. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/responsive-mobile-component-2.png +0 -0
  149. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/responsive-tablet-component-1.png +0 -0
  150. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/responsive-tablet-component-2.png +0 -0
  151. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/select-default.png +0 -0
  152. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/textarea-default.png +0 -0
  153. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/chromium/tickbox-default.png +0 -0
  154. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/accordion-default.png +0 -0
  155. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-default.png +0 -0
  156. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-disabled.png +0 -0
  157. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-focus-state.png +0 -0
  158. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-hover-state.png +0 -0
  159. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-loading.png +0 -0
  160. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-normal-state.png +0 -0
  161. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-outlined.png +0 -0
  162. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/button-states-composite.png +0 -0
  163. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/checkbox-default.png +0 -0
  164. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/dark-mode-component-1.png +0 -0
  165. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/dark-mode-component-2.png +0 -0
  166. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/dark-mode-component-3.png +0 -0
  167. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/dateinput-default.png +0 -0
  168. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/dialog-default.png +0 -0
  169. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/editfield-default.png +0 -0
  170. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-default.png +0 -0
  171. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-error.png +0 -0
  172. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-filled-state.png +0 -0
  173. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-focus-state.png +0 -0
  174. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-normal-state.png +0 -0
  175. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-state-default.png +0 -0
  176. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-state-error.png +0 -0
  177. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-state-success.png +0 -0
  178. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-state-warning.png +0 -0
  179. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-success.png +0 -0
  180. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/input-warning.png +0 -0
  181. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-appointmentcard.png +0 -0
  182. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-chatmessage.png +0 -0
  183. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-chatnotification.png +0 -0
  184. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-documentcard.png +0 -0
  185. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-infocard.png +0 -0
  186. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-progresscircle.png +0 -0
  187. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-taglabel.png +0 -0
  188. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/lab-ticketcard.png +0 -0
  189. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/notificationbubble-default.png +0 -0
  190. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/otpinput-default.png +0 -0
  191. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/phoneinput-default.png +0 -0
  192. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/responsive-desktop-component-1.png +0 -0
  193. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/responsive-desktop-component-2.png +0 -0
  194. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/responsive-mobile-component-1.png +0 -0
  195. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/responsive-mobile-component-2.png +0 -0
  196. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/responsive-tablet-component-1.png +0 -0
  197. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/responsive-tablet-component-2.png +0 -0
  198. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/select-default.png +0 -0
  199. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/textarea-default.png +0 -0
  200. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/firefox/tickbox-default.png +0 -0
  201. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/accordion-default.png +0 -0
  202. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-default.png +0 -0
  203. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-disabled.png +0 -0
  204. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-focus-state.png +0 -0
  205. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-hover-state.png +0 -0
  206. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-loading.png +0 -0
  207. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-normal-state.png +0 -0
  208. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-outlined.png +0 -0
  209. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/button-states-composite.png +0 -0
  210. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/checkbox-default.png +0 -0
  211. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/dark-mode-component-1.png +0 -0
  212. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/dark-mode-component-2.png +0 -0
  213. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/dark-mode-component-3.png +0 -0
  214. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/dateinput-default.png +0 -0
  215. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/dialog-default.png +0 -0
  216. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/editfield-default.png +0 -0
  217. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-default.png +0 -0
  218. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-error.png +0 -0
  219. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-filled-state.png +0 -0
  220. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-focus-state.png +0 -0
  221. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-normal-state.png +0 -0
  222. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-state-default.png +0 -0
  223. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-state-error.png +0 -0
  224. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-state-success.png +0 -0
  225. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-state-warning.png +0 -0
  226. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-success.png +0 -0
  227. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/input-warning.png +0 -0
  228. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-appointmentcard.png +0 -0
  229. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-chatmessage.png +0 -0
  230. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-chatnotification.png +0 -0
  231. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-documentcard.png +0 -0
  232. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-infocard.png +0 -0
  233. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-progresscircle.png +0 -0
  234. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-taglabel.png +0 -0
  235. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/lab-ticketcard.png +0 -0
  236. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/notificationbubble-default.png +0 -0
  237. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/otpinput-default.png +0 -0
  238. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/phoneinput-default.png +0 -0
  239. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/responsive-desktop-component-1.png +0 -0
  240. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/responsive-desktop-component-2.png +0 -0
  241. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/responsive-mobile-component-1.png +0 -0
  242. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/responsive-mobile-component-2.png +0 -0
  243. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/responsive-tablet-component-1.png +0 -0
  244. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/responsive-tablet-component-2.png +0 -0
  245. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/select-default.png +0 -0
  246. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/textarea-default.png +0 -0
  247. package/tests/e2e/snapshots/visual-regression.spec.ts/linux/webkit/tickbox-default.png +0 -0
  248. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/accordion-default.png +0 -0
  249. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-default.png +0 -0
  250. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-disabled.png +0 -0
  251. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-focus-state.png +0 -0
  252. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-hover-state.png +0 -0
  253. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-loading.png +0 -0
  254. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-normal-state.png +0 -0
  255. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-outlined.png +0 -0
  256. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/button-states-composite.png +0 -0
  257. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/checkbox-default.png +0 -0
  258. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/dark-mode-component-1.png +0 -0
  259. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/dark-mode-component-2.png +0 -0
  260. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/dark-mode-component-3.png +0 -0
  261. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/dateinput-default.png +0 -0
  262. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/dialog-default.png +0 -0
  263. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/editfield-default.png +0 -0
  264. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-default.png +0 -0
  265. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-error.png +0 -0
  266. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-filled-state.png +0 -0
  267. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-focus-state.png +0 -0
  268. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-normal-state.png +0 -0
  269. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-state-default.png +0 -0
  270. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-state-error.png +0 -0
  271. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-state-success.png +0 -0
  272. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-state-warning.png +0 -0
  273. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-success.png +0 -0
  274. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/input-warning.png +0 -0
  275. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-appointmentcard.png +0 -0
  276. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-chatmessage.png +0 -0
  277. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-chatnotification.png +0 -0
  278. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-documentcard.png +0 -0
  279. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-infocard.png +0 -0
  280. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-progresscircle.png +0 -0
  281. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-taglabel.png +0 -0
  282. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/lab-ticketcard.png +0 -0
  283. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/notificationbubble-default.png +0 -0
  284. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/otpinput-default.png +0 -0
  285. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/phoneinput-default.png +0 -0
  286. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/responsive-desktop-component-1.png +0 -0
  287. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/responsive-desktop-component-2.png +0 -0
  288. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/responsive-mobile-component-1.png +0 -0
  289. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/responsive-mobile-component-2.png +0 -0
  290. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/responsive-tablet-component-1.png +0 -0
  291. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/responsive-tablet-component-2.png +0 -0
  292. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/select-default.png +0 -0
  293. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/textarea-default.png +0 -0
  294. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Chrome/tickbox-default.png +0 -0
  295. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/accordion-default.png +0 -0
  296. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-default.png +0 -0
  297. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-disabled.png +0 -0
  298. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-focus-state.png +0 -0
  299. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-hover-state.png +0 -0
  300. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-loading.png +0 -0
  301. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-normal-state.png +0 -0
  302. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-outlined.png +0 -0
  303. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/button-states-composite.png +0 -0
  304. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/checkbox-default.png +0 -0
  305. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/dark-mode-component-1.png +0 -0
  306. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/dark-mode-component-2.png +0 -0
  307. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/dark-mode-component-3.png +0 -0
  308. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/dateinput-default.png +0 -0
  309. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/dialog-default.png +0 -0
  310. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/editfield-default.png +0 -0
  311. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-default.png +0 -0
  312. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-error.png +0 -0
  313. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-filled-state.png +0 -0
  314. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-focus-state.png +0 -0
  315. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-normal-state.png +0 -0
  316. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-state-default.png +0 -0
  317. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-state-error.png +0 -0
  318. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-state-success.png +0 -0
  319. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-state-warning.png +0 -0
  320. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-success.png +0 -0
  321. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/input-warning.png +0 -0
  322. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-appointmentcard.png +0 -0
  323. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-chatmessage.png +0 -0
  324. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-chatnotification.png +0 -0
  325. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-documentcard.png +0 -0
  326. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-infocard.png +0 -0
  327. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-progresscircle.png +0 -0
  328. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-taglabel.png +0 -0
  329. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/lab-ticketcard.png +0 -0
  330. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/notificationbubble-default.png +0 -0
  331. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/otpinput-default.png +0 -0
  332. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/phoneinput-default.png +0 -0
  333. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/responsive-desktop-component-1.png +0 -0
  334. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/responsive-desktop-component-2.png +0 -0
  335. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/responsive-mobile-component-1.png +0 -0
  336. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/responsive-mobile-component-2.png +0 -0
  337. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/responsive-tablet-component-1.png +0 -0
  338. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/responsive-tablet-component-2.png +0 -0
  339. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/select-default.png +0 -0
  340. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/textarea-default.png +0 -0
  341. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/Mobile-Safari/tickbox-default.png +0 -0
  342. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/accordion-default.png +0 -0
  343. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-default.png +0 -0
  344. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-disabled.png +0 -0
  345. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-focus-state.png +0 -0
  346. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-hover-state.png +0 -0
  347. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-loading.png +0 -0
  348. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-normal-state.png +0 -0
  349. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-outlined.png +0 -0
  350. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/button-states-composite.png +0 -0
  351. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/checkbox-default.png +0 -0
  352. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/dark-mode-component-1.png +0 -0
  353. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/dark-mode-component-2.png +0 -0
  354. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/dark-mode-component-3.png +0 -0
  355. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/dateinput-default.png +0 -0
  356. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/dialog-default.png +0 -0
  357. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/editfield-default.png +0 -0
  358. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-default.png +0 -0
  359. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-error.png +0 -0
  360. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-filled-state.png +0 -0
  361. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-focus-state.png +0 -0
  362. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-normal-state.png +0 -0
  363. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-state-default.png +0 -0
  364. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-state-error.png +0 -0
  365. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-state-success.png +0 -0
  366. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-state-warning.png +0 -0
  367. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-success.png +0 -0
  368. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/input-warning.png +0 -0
  369. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-appointmentcard.png +0 -0
  370. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-chatmessage.png +0 -0
  371. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-chatnotification.png +0 -0
  372. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-documentcard.png +0 -0
  373. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-infocard.png +0 -0
  374. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-progresscircle.png +0 -0
  375. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-taglabel.png +0 -0
  376. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/lab-ticketcard.png +0 -0
  377. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/notificationbubble-default.png +0 -0
  378. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/otpinput-default.png +0 -0
  379. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/phoneinput-default.png +0 -0
  380. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/responsive-desktop-component-1.png +0 -0
  381. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/responsive-desktop-component-2.png +0 -0
  382. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/responsive-mobile-component-1.png +0 -0
  383. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/responsive-mobile-component-2.png +0 -0
  384. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/responsive-tablet-component-1.png +0 -0
  385. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/responsive-tablet-component-2.png +0 -0
  386. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/select-default.png +0 -0
  387. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/textarea-default.png +0 -0
  388. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/chromium/tickbox-default.png +0 -0
  389. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/accordion-default.png +0 -0
  390. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-default.png +0 -0
  391. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-disabled.png +0 -0
  392. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-focus-state.png +0 -0
  393. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-hover-state.png +0 -0
  394. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-loading.png +0 -0
  395. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-normal-state.png +0 -0
  396. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-outlined.png +0 -0
  397. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/button-states-composite.png +0 -0
  398. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/checkbox-default.png +0 -0
  399. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/dark-mode-component-1.png +0 -0
  400. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/dark-mode-component-2.png +0 -0
  401. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/dark-mode-component-3.png +0 -0
  402. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/dateinput-default.png +0 -0
  403. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/dialog-default.png +0 -0
  404. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/editfield-default.png +0 -0
  405. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-default.png +0 -0
  406. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-error.png +0 -0
  407. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-filled-state.png +0 -0
  408. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-focus-state.png +0 -0
  409. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-normal-state.png +0 -0
  410. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-state-default.png +0 -0
  411. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-state-error.png +0 -0
  412. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-state-success.png +0 -0
  413. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-state-warning.png +0 -0
  414. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-success.png +0 -0
  415. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/input-warning.png +0 -0
  416. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-appointmentcard.png +0 -0
  417. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-chatmessage.png +0 -0
  418. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-chatnotification.png +0 -0
  419. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-documentcard.png +0 -0
  420. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-infocard.png +0 -0
  421. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-progresscircle.png +0 -0
  422. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-taglabel.png +0 -0
  423. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/lab-ticketcard.png +0 -0
  424. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/notificationbubble-default.png +0 -0
  425. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/otpinput-default.png +0 -0
  426. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/phoneinput-default.png +0 -0
  427. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/responsive-desktop-component-1.png +0 -0
  428. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/responsive-desktop-component-2.png +0 -0
  429. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/responsive-mobile-component-1.png +0 -0
  430. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/responsive-mobile-component-2.png +0 -0
  431. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/responsive-tablet-component-1.png +0 -0
  432. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/responsive-tablet-component-2.png +0 -0
  433. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/select-default.png +0 -0
  434. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/textarea-default.png +0 -0
  435. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/firefox/tickbox-default.png +0 -0
  436. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/accordion-default.png +0 -0
  437. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-default.png +0 -0
  438. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-disabled.png +0 -0
  439. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-focus-state.png +0 -0
  440. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-hover-state.png +0 -0
  441. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-loading.png +0 -0
  442. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-normal-state.png +0 -0
  443. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-outlined.png +0 -0
  444. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/button-states-composite.png +0 -0
  445. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/checkbox-default.png +0 -0
  446. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/dark-mode-component-1.png +0 -0
  447. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/dark-mode-component-2.png +0 -0
  448. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/dark-mode-component-3.png +0 -0
  449. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/dateinput-default.png +0 -0
  450. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/dialog-default.png +0 -0
  451. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/editfield-default.png +0 -0
  452. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-default.png +0 -0
  453. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-error.png +0 -0
  454. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-filled-state.png +0 -0
  455. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-focus-state.png +0 -0
  456. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-normal-state.png +0 -0
  457. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-state-default.png +0 -0
  458. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-state-error.png +0 -0
  459. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-state-success.png +0 -0
  460. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-state-warning.png +0 -0
  461. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-success.png +0 -0
  462. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/input-warning.png +0 -0
  463. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/lab-appointmentcard.png +0 -0
  464. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/lab-chatmessage.png +0 -0
  465. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/lab-chatnotification.png +0 -0
  466. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/lab-documentcard.png +0 -0
  467. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/lab-progresscircle.png +0 -0
  468. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/lab-ticketcard.png +0 -0
  469. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/notificationbubble-default.png +0 -0
  470. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/otpinput-default.png +0 -0
  471. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/phoneinput-default.png +0 -0
  472. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/responsive-desktop-component-1.png +0 -0
  473. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/responsive-desktop-component-2.png +0 -0
  474. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/responsive-mobile-component-1.png +0 -0
  475. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/responsive-mobile-component-2.png +0 -0
  476. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/responsive-tablet-component-1.png +0 -0
  477. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/responsive-tablet-component-2.png +0 -0
  478. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/select-default.png +0 -0
  479. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/textarea-default.png +0 -0
  480. package/tests/e2e/snapshots/visual-regression.spec.ts/win32/webkit/tickbox-default.png +0 -0
  481. package/tests/unit/components/Accordion/{AccordionGroup.spec.ts → AccordionGroup.spec.ts.skip} +1 -1
  482. package/tests/unit/components/Accordion/{AccordionItem.spec.ts → AccordionItem.spec.ts.skip} +1 -1
  483. package/tests/unit/components/Appointment/Card/Actions.spec.ts +408 -0
  484. package/tests/unit/components/Appointment/Card/Card.spec.ts +486 -0
  485. package/tests/unit/components/Appointment/Card/Details.spec.ts +398 -0
  486. package/tests/unit/src/components/{index.spec.ts → index.spec.ts.skip} +1 -1
  487. package/tests/unit/src/{index.spec.ts → index.spec.ts.skip} +1 -1
@@ -0,0 +1,486 @@
1
+ import { describe, it, expect, beforeEach, vi } from 'vitest';
2
+ import { mount, VueWrapper } from '@vue/test-utils';
3
+ import { format } from 'date-fns';
4
+ import { de } from 'date-fns/locale';
5
+ import Card from '../../../../../src/components/Appointment/Card/Card.vue';
6
+ import type { AppointmentData, Dentist } from '../../../../../src/types';
7
+
8
+ describe('Appointment Card', () => {
9
+ let wrapper: VueWrapper;
10
+
11
+ const createMockDentist = (overrides: Partial<Dentist> = {}): Dentist => ({
12
+ name: 'Dr. Test Dentist',
13
+ gender: 'Male',
14
+ imageSrc: 'https://example.com/dentist.jpg',
15
+ ...overrides
16
+ });
17
+
18
+ const createMockAppointment = (overrides: Partial<AppointmentData> = {}): AppointmentData => ({
19
+ id: '123',
20
+ template_name: 'Test Treatment',
21
+ description: 'Test Description',
22
+ dentist: createMockDentist(),
23
+ start: '2024-01-15T10:30:00.000Z',
24
+ type: 1,
25
+ status: 'upcoming',
26
+ patientName: 'John Doe',
27
+ address: 'Test Address 123',
28
+ district: 'Test District',
29
+ is_confirmed: false,
30
+ ...overrides
31
+ });
32
+
33
+ beforeEach(() => {
34
+ const appointment = createMockAppointment();
35
+ wrapper = mount(Card, {
36
+ props: { appointment },
37
+ global: {
38
+ stubs: {
39
+ Icon: {
40
+ template: '<div class="icon-stub" :name="name" :size="size"></div>',
41
+ props: ['name', 'size']
42
+ },
43
+ Details: {
44
+ template: '<div class="details-stub">Details Component</div>',
45
+ props: ['appointment', 'dentistImageSrc']
46
+ },
47
+ Actions: {
48
+ template: '<div class="actions-stub" @confirmed="$emit(\'confirmed\', $event)" @cancelled="$emit(\'cancelled\', $event)" @rescheduled="$emit(\'rescheduled\', $event)">Actions Component</div>',
49
+ props: ['appointment'],
50
+ emits: ['confirmed', 'cancelled', 'rescheduled']
51
+ }
52
+ }
53
+ }
54
+ });
55
+ });
56
+
57
+ describe('Component Rendering', () => {
58
+ it('should render the component with correct test id', () => {
59
+ expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
60
+ });
61
+
62
+ it('should render the appointment card structure', () => {
63
+ expect(wrapper.find('.appointment-card').exists()).toBe(true);
64
+ expect(wrapper.find('.card-header').exists()).toBe(true);
65
+ expect(wrapper.find('.card-body').exists()).toBe(true);
66
+ expect(wrapper.find('.card-footer').exists()).toBe(true);
67
+ });
68
+
69
+ it('should render Details and Actions components', () => {
70
+ expect(wrapper.find('.details-stub').exists()).toBe(true);
71
+ expect(wrapper.find('.actions-stub').exists()).toBe(true);
72
+ });
73
+ });
74
+
75
+ describe('Header Information', () => {
76
+ it('should display patient name', () => {
77
+ expect(wrapper.text()).toContain('John Doe');
78
+ });
79
+
80
+ it('should display default patient name when not provided', async () => {
81
+ const appointmentWithoutPatient = createMockAppointment({ patientName: undefined });
82
+ await wrapper.setProps({ appointment: appointmentWithoutPatient });
83
+
84
+ expect(wrapper.text()).toContain('Unbekannter Patient');
85
+ });
86
+
87
+ it('should display formatted date', () => {
88
+ const expectedDate = format(new Date('2024-01-15T10:30:00Z'), 'EEE, d MMM yyyy', { locale: de });
89
+ expect(wrapper.text()).toContain(expectedDate);
90
+ });
91
+
92
+ it('should display formatted time', () => {
93
+ const expectedTime = format(new Date('2024-01-15T10:30:00Z'), 'HH:mm');
94
+ expect(wrapper.text()).toContain(expectedTime);
95
+ });
96
+
97
+ it('should render header icons', () => {
98
+ const icons = wrapper.findAll('.icon-stub');
99
+ expect(icons.length).toBeGreaterThanOrEqual(3);
100
+
101
+ const iconNames = icons.map(icon => icon.attributes('name'));
102
+ expect(iconNames).toContain('heroicons:user-circle');
103
+ expect(iconNames).toContain('heroicons:map-pin');
104
+ expect(iconNames).toContain('heroicons:clock');
105
+ });
106
+
107
+ it('should have correct header items structure', () => {
108
+ const headerItems = wrapper.findAll('.header-item');
109
+ expect(headerItems).toHaveLength(3);
110
+ });
111
+ });
112
+
113
+ describe('Appointment Status Styling', () => {
114
+ it('should apply normal header background for upcoming appointments', () => {
115
+ const header = wrapper.find('.card-header');
116
+ expect(header.classes()).toContain('header-bg-normal');
117
+ expect(header.classes()).not.toContain('header-bg-cancelled');
118
+ });
119
+
120
+ it('should apply cancelled header background for cancelled appointments', async () => {
121
+ const cancelledAppointment = createMockAppointment({ status: 'cancelled' });
122
+ await wrapper.setProps({ appointment: cancelledAppointment });
123
+
124
+ const header = wrapper.find('.card-header');
125
+ expect(header.classes()).toContain('header-bg-cancelled');
126
+ expect(header.classes()).not.toContain('header-bg-normal');
127
+ });
128
+
129
+ it('should apply card opacity for past appointments', async () => {
130
+ const pastAppointment = createMockAppointment({ status: 'past' });
131
+ await wrapper.setProps({ appointment: pastAppointment });
132
+
133
+ expect(wrapper.find('.card-opacity').exists()).toBe(true);
134
+ });
135
+
136
+ it('should not apply card opacity for non-past appointments', () => {
137
+ expect(wrapper.find('.card-opacity').exists()).toBe(false);
138
+ });
139
+ });
140
+
141
+ describe('Template Name Display', () => {
142
+ it('should display single template name', () => {
143
+ expect(wrapper.text()).toContain('Test Treatment');
144
+ });
145
+
146
+ it('should display multiple template names as comma-separated string', async () => {
147
+ const appointmentWithMultipleTemplates = createMockAppointment({
148
+ template_name: ['Treatment A', 'Treatment B', 'Treatment C']
149
+ });
150
+ await wrapper.setProps({ appointment: appointmentWithMultipleTemplates });
151
+
152
+ expect(wrapper.text()).toContain('Treatment A, Treatment B, Treatment C');
153
+ });
154
+
155
+ it('should handle empty template name array', async () => {
156
+ const appointmentWithEmptyTemplates = createMockAppointment({
157
+ template_name: []
158
+ });
159
+ await wrapper.setProps({ appointment: appointmentWithEmptyTemplates });
160
+
161
+ expect(wrapper.find('h2').text()).toBe('');
162
+ });
163
+ });
164
+
165
+ describe('Link Functionality', () => {
166
+ it('should render appointment link when provided', async () => {
167
+ await wrapper.setProps({ appointmentLink: 'https://example.com/appointment/123' });
168
+
169
+ const link = wrapper.find('.appointment-card');
170
+ expect(link.attributes('href')).toBe('https://example.com/appointment/123');
171
+ expect(link.attributes('rel')).toBe('noopener noreferrer');
172
+ });
173
+
174
+ it('should render default hash link when no appointment link provided', () => {
175
+ const link = wrapper.find('.appointment-card');
176
+ expect(link.attributes('href')).toBe('#');
177
+ });
178
+ });
179
+
180
+ describe('Event Handling', () => {
181
+ it('should emit confirm event when Actions emits confirmed', async () => {
182
+ const actionsComponent = wrapper.find('.actions-stub');
183
+ await actionsComponent.trigger('confirmed', '123');
184
+
185
+ expect(wrapper.emitted('confirm')).toBeTruthy();
186
+ expect(wrapper.emitted('confirm')?.[0]).toEqual(['123']);
187
+ });
188
+
189
+ it('should emit cancel event when Actions emits cancelled', async () => {
190
+ const actionsComponent = wrapper.find('.actions-stub');
191
+ await actionsComponent.trigger('cancelled', '123');
192
+
193
+ expect(wrapper.emitted('cancel')).toBeTruthy();
194
+ expect(wrapper.emitted('cancel')?.[0]).toEqual(['123']);
195
+ });
196
+
197
+ it('should emit reschedule event when Actions emits rescheduled', async () => {
198
+ const actionsComponent = wrapper.find('.actions-stub');
199
+ await actionsComponent.trigger('rescheduled', '123');
200
+
201
+ expect(wrapper.emitted('reschedule')).toBeTruthy();
202
+ expect(wrapper.emitted('reschedule')?.[0]).toEqual(['123']);
203
+ });
204
+ });
205
+
206
+ describe('Props Passing', () => {
207
+ it('should pass appointment prop to Details component', () => {
208
+ const detailsStub = wrapper.find('.details-stub');
209
+ expect(detailsStub.exists()).toBe(true);
210
+ });
211
+
212
+ it('should pass appointment prop to Actions component', () => {
213
+ const actionsStub = wrapper.find('.actions-stub');
214
+ expect(actionsStub.exists()).toBe(true);
215
+ });
216
+
217
+ it('should pass dentistImageSrc prop to Details component', async () => {
218
+ await wrapper.setProps({ dentistImageSrc: 'https://example.com/custom-dentist.jpg' });
219
+ expect(wrapper.props('dentistImageSrc')).toBe('https://example.com/custom-dentist.jpg');
220
+ });
221
+ });
222
+
223
+ describe('Date Formatting Edge Cases', () => {
224
+ it('should handle current date when appointment date is null', async () => {
225
+ const appointmentWithNullDate = createMockAppointment({ start: null as any });
226
+ await wrapper.setProps({ appointment: appointmentWithNullDate });
227
+
228
+ // Should not throw an error and should display current date
229
+ expect(wrapper.find('.card-header').exists()).toBe(true);
230
+ });
231
+
232
+ it('should format different date correctly', async () => {
233
+ const appointmentWithDifferentDate = createMockAppointment({
234
+ start: '2024-12-25T15:45:00Z'
235
+ });
236
+ await wrapper.setProps({ appointment: appointmentWithDifferentDate });
237
+
238
+ const expectedDate = format(new Date('2024-12-25T15:45:00Z'), 'EEE, d MMM yyyy', { locale: de });
239
+ const expectedTime = format(new Date('2024-12-25T15:45:00Z'), 'HH:mm');
240
+
241
+ expect(wrapper.text()).toContain(expectedDate);
242
+ expect(wrapper.text()).toContain(expectedTime);
243
+ });
244
+ });
245
+
246
+ describe('Layout Structure', () => {
247
+ it('should have proper layout structure', () => {
248
+ const root = wrapper.find('[data-testid="root"]');
249
+ expect(root.exists()).toBe(true);
250
+
251
+ const appointmentCard = root.find('.appointment-card');
252
+ expect(appointmentCard.exists()).toBe(true);
253
+
254
+ const cardFooter = root.find('.card-footer');
255
+ expect(cardFooter.exists()).toBe(true);
256
+ });
257
+
258
+ it('should contain horizontal rule separator', () => {
259
+ expect(wrapper.find('hr').exists()).toBe(true);
260
+ });
261
+ });
262
+
263
+ describe('Accessibility', () => {
264
+ it('should have proper link attributes for accessibility', async () => {
265
+ await wrapper.setProps({ appointmentLink: 'https://example.com/appointment/123' });
266
+
267
+ const link = wrapper.find('.appointment-card');
268
+ expect(link.attributes('rel')).toBe('noopener noreferrer');
269
+ });
270
+
271
+ it('should have descriptive data-testid', () => {
272
+ expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
273
+ });
274
+ });
275
+
276
+ describe('Component Props Validation', () => {
277
+ it('should accept all required props', () => {
278
+ expect(wrapper.props('appointment')).toBeDefined();
279
+ });
280
+
281
+ it('should accept optional props', async () => {
282
+ await wrapper.setProps({
283
+ appointmentLink: 'https://example.com/test',
284
+ dentistImageSrc: 'https://example.com/dentist.jpg'
285
+ });
286
+
287
+ expect(wrapper.props('appointmentLink')).toBe('https://example.com/test');
288
+ expect(wrapper.props('dentistImageSrc')).toBe('https://example.com/dentist.jpg');
289
+ });
290
+ });
291
+
292
+ describe('Accessibility', () => {
293
+ beforeEach(() => {
294
+ const appointment = createMockAppointment();
295
+ wrapper = mount(Card, {
296
+ props: { appointment },
297
+ global: {
298
+ stubs: {
299
+ Icon: {
300
+ template: '<div class="icon-stub" :aria-hidden="true" :name="name" :size="size" role="img" :aria-label="name"></div>',
301
+ props: ['name', 'size']
302
+ },
303
+ Details: {
304
+ template: '<div class="details-stub" role="region" aria-label="Appointment details">Details Component</div>',
305
+ props: ['appointment', 'dentistImageSrc']
306
+ },
307
+ Actions: {
308
+ template: '<div class="actions-stub" role="group" aria-label="Appointment actions">Actions Component</div>',
309
+ props: ['appointment']
310
+ }
311
+ }
312
+ }
313
+ });
314
+ });
315
+
316
+ it('should have proper semantic HTML structure', () => {
317
+ const root = wrapper.find('[data-testid="root"]');
318
+ expect(root.exists()).toBe(true);
319
+
320
+ const appointmentCard = wrapper.find('.appointment-card');
321
+ expect(appointmentCard.exists()).toBe(true);
322
+
323
+ // Should have proper sectioning
324
+ expect(wrapper.find('.card-header').exists()).toBe(true);
325
+ expect(wrapper.find('.card-body').exists()).toBe(true);
326
+ expect(wrapper.find('.card-footer').exists()).toBe(true);
327
+ });
328
+
329
+ it('should use proper heading hierarchy', () => {
330
+ const heading = wrapper.find('h2');
331
+ expect(heading.exists()).toBe(true);
332
+ expect(heading.text()).toBe('Test Treatment');
333
+ });
334
+
335
+ it('should have accessible link attributes', async () => {
336
+ await wrapper.setProps({ appointmentLink: 'https://example.com/appointment/123' });
337
+
338
+ const link = wrapper.find('.appointment-card');
339
+ expect(link.attributes('href')).toBe('https://example.com/appointment/123');
340
+ expect(link.attributes('rel')).toBe('noopener noreferrer');
341
+ });
342
+
343
+ it('should provide meaningful content for screen readers', () => {
344
+ // Patient name should be visible
345
+ expect(wrapper.text()).toContain('John Doe');
346
+
347
+ // Date and time should be accessible
348
+ const appointmentDate = new Date('2024-01-15T10:30:00.000Z');
349
+ const expectedDate = format(appointmentDate, 'EEE, d MMM yyyy', { locale: de });
350
+
351
+ expect(wrapper.text()).toContain(expectedDate);
352
+ // Time will be displayed based on local timezone, check for any valid time format
353
+ expect(wrapper.text()).toMatch(/\d{1,2}:\d{2}/);
354
+
355
+ // Treatment name should be in heading
356
+ const h2 = wrapper.find('h2');
357
+ expect(h2.text()).toBe('Test Treatment');
358
+ });
359
+
360
+ it('should have proper icon accessibility attributes', () => {
361
+ const icons = wrapper.findAll('.icon-stub');
362
+ expect(icons.length).toBeGreaterThanOrEqual(3);
363
+
364
+ icons.forEach(icon => {
365
+ expect(icon.attributes('aria-hidden')).toBe('true');
366
+ expect(icon.attributes('role')).toBe('img');
367
+ expect(icon.attributes('aria-label')).toBeTruthy();
368
+ });
369
+ });
370
+
371
+ it('should provide semantic roles for sub-components', () => {
372
+ const detailsStub = wrapper.find('.details-stub');
373
+ expect(detailsStub.attributes('role')).toBe('region');
374
+ expect(detailsStub.attributes('aria-label')).toBe('Appointment details');
375
+
376
+ const actionsStub = wrapper.find('.actions-stub');
377
+ expect(actionsStub.attributes('role')).toBe('group');
378
+ expect(actionsStub.attributes('aria-label')).toBe('Appointment actions');
379
+ });
380
+
381
+ it('should handle different appointment statuses accessibly', async () => {
382
+ // Test normal status
383
+ let header = wrapper.find('.card-header');
384
+ expect(header.classes()).toContain('header-bg-normal');
385
+
386
+ // Test cancelled status
387
+ const cancelledAppointment = createMockAppointment({ status: 'cancelled' });
388
+ await wrapper.setProps({ appointment: cancelledAppointment });
389
+
390
+ header = wrapper.find('.card-header');
391
+ expect(header.classes()).toContain('header-bg-cancelled');
392
+
393
+ // Test past status with opacity
394
+ const pastAppointment = createMockAppointment({ status: 'past' });
395
+ await wrapper.setProps({ appointment: pastAppointment });
396
+
397
+ expect(wrapper.find('.card-opacity').exists()).toBe(true);
398
+ });
399
+
400
+ it('should provide informative default values', async () => {
401
+ const appointmentWithoutPatient = createMockAppointment({ patientName: undefined });
402
+ await wrapper.setProps({ appointment: appointmentWithoutPatient });
403
+
404
+ expect(wrapper.text()).toContain('Unbekannter Patient');
405
+ });
406
+
407
+ it('should have logical reading order', () => {
408
+ // Header items should be in logical order
409
+ const headerItems = wrapper.findAll('.header-item');
410
+ expect(headerItems).toHaveLength(3);
411
+
412
+ // Patient, Date, Time order
413
+ expect(headerItems[0].text()).toContain('John Doe');
414
+ // Time will be displayed based on local timezone, check for any valid time format
415
+ expect(headerItems[2].text()).toMatch(/\d{1,2}:\d{2}/);
416
+ });
417
+
418
+ it('should handle multiple template names accessibly', async () => {
419
+ const appointmentWithMultipleTemplates = createMockAppointment({
420
+ template_name: ['Treatment A', 'Treatment B', 'Treatment C']
421
+ });
422
+ await wrapper.setProps({ appointment: appointmentWithMultipleTemplates });
423
+
424
+ const heading = wrapper.find('h2');
425
+ expect(heading.text()).toBe('Treatment A, Treatment B, Treatment C');
426
+ });
427
+
428
+ it('should use proper HTML5 semantic elements', () => {
429
+ // Should have proper sectioning
430
+ const header = wrapper.find('.card-header');
431
+ const body = wrapper.find('.card-body');
432
+ const footer = wrapper.find('.card-footer');
433
+
434
+ expect(header.exists()).toBe(true);
435
+ expect(body.exists()).toBe(true);
436
+ expect(footer.exists()).toBe(true);
437
+
438
+ // Should have horizontal rule for separation
439
+ expect(wrapper.find('hr').exists()).toBe(true);
440
+ });
441
+
442
+ it('should maintain focus management for interactive elements', async () => {
443
+ await wrapper.setProps({ appointmentLink: 'https://example.com/appointment/123' });
444
+
445
+ const link = wrapper.find('.appointment-card');
446
+ expect(link.attributes('href')).toBeTruthy();
447
+
448
+ // Link should be focusable
449
+ expect(link.element.tagName.toLowerCase()).toBe('a');
450
+ });
451
+
452
+ it('should provide context for visual styling changes', () => {
453
+ // Visual changes should have semantic meaning
454
+ const header = wrapper.find('.card-header');
455
+ expect(header.classes()).toContain('header-bg-normal');
456
+
457
+ // Check that there are no accessibility violations in basic structure
458
+ expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
459
+ });
460
+
461
+ it('should handle date formatting for screen readers', async () => {
462
+ const appointmentWithDifferentDate = createMockAppointment({
463
+ start: '2024-12-25T15:45:00Z'
464
+ });
465
+ await wrapper.setProps({ appointment: appointmentWithDifferentDate });
466
+
467
+ const expectedDate = format(new Date('2024-12-25T15:45:00Z'), 'EEE, d MMM yyyy', { locale: de });
468
+ const expectedTime = format(new Date('2024-12-25T15:45:00Z'), 'HH:mm');
469
+
470
+ expect(wrapper.text()).toContain(expectedDate);
471
+ expect(wrapper.text()).toContain(expectedTime);
472
+ });
473
+
474
+ it('should provide comprehensive information structure', () => {
475
+ // Card should contain all necessary information
476
+ expect(wrapper.text()).toContain('John Doe'); // Patient
477
+ expect(wrapper.text()).toContain('Test Treatment'); // Treatment
478
+ // Time will be displayed based on local timezone, check for any valid time format
479
+ expect(wrapper.text()).toMatch(/\d{1,2}:\d{2}/); // Time
480
+
481
+ // Should have proper component structure
482
+ expect(wrapper.find('.details-stub').exists()).toBe(true);
483
+ expect(wrapper.find('.actions-stub').exists()).toBe(true);
484
+ });
485
+ });
486
+ });