@getmicdrop/svelte-components 1.0.2 → 1.0.3

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 (517) hide show
  1. package/README.md +98 -98
  2. package/dist/components/Alert/Alert.spec.d.ts +2 -0
  3. package/dist/components/Alert/Alert.spec.d.ts.map +1 -0
  4. package/dist/components/Alert/Alert.spec.js +170 -0
  5. package/dist/components/Alert/Alert.svelte +54 -0
  6. package/dist/components/Alert/Alert.svelte.d.ts +40 -0
  7. package/dist/components/Alert/Alert.svelte.d.ts.map +1 -0
  8. package/dist/components/Alert/AlertAudit.stories.svelte +241 -0
  9. package/dist/components/Alert/AlertAudit.stories.svelte.d.ts +31 -0
  10. package/dist/components/Alert/AlertAudit.stories.svelte.d.ts.map +1 -0
  11. package/dist/components/Badges/Badge.spec.d.ts +2 -0
  12. package/dist/components/Badges/Badge.spec.d.ts.map +1 -0
  13. package/dist/components/Badges/Badge.spec.js +103 -0
  14. package/dist/components/Badges/Badge.stories.svelte +87 -0
  15. package/dist/components/Badges/Badge.stories.svelte.d.ts +47 -0
  16. package/dist/components/Badges/Badge.stories.svelte.d.ts.map +1 -0
  17. package/dist/components/Badges/Badge.svelte +182 -0
  18. package/dist/components/Badges/Badge.svelte.d.ts +38 -0
  19. package/dist/components/Badges/Badge.svelte.d.ts.map +1 -0
  20. package/dist/components/Badges/BadgeAudit.stories.svelte +238 -0
  21. package/dist/components/Badges/BadgeAudit.stories.svelte.d.ts +31 -0
  22. package/dist/components/Badges/BadgeAudit.stories.svelte.d.ts.map +1 -0
  23. package/dist/components/BottomSheet/BottomSheet.spec.d.ts +2 -0
  24. package/dist/components/BottomSheet/BottomSheet.spec.d.ts.map +1 -0
  25. package/dist/components/BottomSheet/BottomSheet.spec.js +127 -0
  26. package/dist/components/BottomSheet/BottomSheet.stories.svelte +91 -0
  27. package/dist/components/BottomSheet/BottomSheet.stories.svelte.d.ts +45 -0
  28. package/dist/components/BottomSheet/BottomSheet.stories.svelte.d.ts.map +1 -0
  29. package/dist/components/BottomSheet/BottomSheet.svelte +171 -0
  30. package/dist/components/BottomSheet/BottomSheet.svelte.d.ts +40 -0
  31. package/dist/components/BottomSheet/BottomSheet.svelte.d.ts.map +1 -0
  32. package/dist/components/Breadcrumb/Breadcrumb.spec.d.ts +2 -0
  33. package/dist/components/Breadcrumb/Breadcrumb.spec.d.ts.map +1 -0
  34. package/dist/components/Breadcrumb/Breadcrumb.spec.js +120 -0
  35. package/dist/components/Breadcrumb/Breadcrumb.stories.svelte +24 -0
  36. package/dist/components/Breadcrumb/Breadcrumb.stories.svelte.d.ts +36 -0
  37. package/dist/components/Breadcrumb/Breadcrumb.stories.svelte.d.ts.map +1 -0
  38. package/dist/components/Breadcrumb/Breadcrumb.svelte +50 -0
  39. package/dist/components/Breadcrumb/Breadcrumb.svelte.d.ts +30 -0
  40. package/dist/components/Breadcrumb/Breadcrumb.svelte.d.ts.map +1 -0
  41. package/dist/components/Button/Button.spec.d.ts +2 -0
  42. package/dist/components/Button/Button.spec.d.ts.map +1 -0
  43. package/dist/components/Button/Button.spec.js +211 -0
  44. package/dist/components/Button/Button.stories.svelte +111 -0
  45. package/dist/components/Button/Button.stories.svelte.d.ts +59 -0
  46. package/dist/components/Button/Button.stories.svelte.d.ts.map +1 -0
  47. package/dist/components/Button/Button.svelte +642 -0
  48. package/dist/components/Button/Button.svelte.d.ts +68 -0
  49. package/dist/components/Button/Button.svelte.d.ts.map +1 -0
  50. package/dist/components/Button/ButtonAudit.stories.svelte +333 -0
  51. package/dist/components/Button/ButtonAudit.stories.svelte.d.ts +33 -0
  52. package/dist/components/Button/ButtonAudit.stories.svelte.d.ts.map +1 -0
  53. package/dist/components/Button/ButtonSaveDemo.spec.d.ts +2 -0
  54. package/dist/components/Button/ButtonSaveDemo.spec.d.ts.map +1 -0
  55. package/dist/components/Button/ButtonSaveDemo.spec.js +48 -0
  56. package/dist/components/Button/ButtonSaveDemo.svelte +24 -0
  57. package/dist/components/Button/ButtonSaveDemo.svelte.d.ts +26 -0
  58. package/dist/components/Button/ButtonSaveDemo.svelte.d.ts.map +1 -0
  59. package/dist/components/Calendar/Calendar.spec.d.ts +2 -0
  60. package/dist/components/Calendar/Calendar.spec.d.ts.map +1 -0
  61. package/dist/components/Calendar/Calendar.spec.js +131 -0
  62. package/dist/components/Calendar/Calendar.svelte +1115 -0
  63. package/dist/components/Calendar/Calendar.svelte.d.ts +52 -0
  64. package/dist/components/Calendar/Calendar.svelte.d.ts.map +1 -0
  65. package/dist/components/Calendar/QuarterView.spec.d.ts +2 -0
  66. package/dist/components/Calendar/QuarterView.spec.d.ts.map +1 -0
  67. package/dist/components/Calendar/QuarterView.spec.js +394 -0
  68. package/dist/components/Calendar/QuarterView.stories.svelte +134 -0
  69. package/dist/components/Calendar/QuarterView.stories.svelte.d.ts +40 -0
  70. package/dist/components/Calendar/QuarterView.stories.svelte.d.ts.map +1 -0
  71. package/dist/components/Calendar/QuarterView.svelte +736 -0
  72. package/dist/components/Calendar/QuarterView.svelte.d.ts +30 -0
  73. package/dist/components/Calendar/QuarterView.svelte.d.ts.map +1 -0
  74. package/dist/components/Card.spec.d.ts +2 -0
  75. package/dist/components/Card.spec.d.ts.map +1 -0
  76. package/dist/components/Card.spec.js +47 -0
  77. package/dist/components/Card.stories.svelte +26 -0
  78. package/dist/components/Card.stories.svelte.d.ts +36 -0
  79. package/dist/components/Card.stories.svelte.d.ts.map +1 -0
  80. package/dist/components/Card.svelte +9 -0
  81. package/dist/components/Card.svelte.d.ts +30 -0
  82. package/dist/components/Card.svelte.d.ts.map +1 -0
  83. package/dist/components/CardAudit.stories.svelte +175 -0
  84. package/dist/components/CardAudit.stories.svelte.d.ts +31 -0
  85. package/dist/components/CardAudit.stories.svelte.d.ts.map +1 -0
  86. package/dist/components/CropImage/CropImage.spec.d.ts +2 -0
  87. package/dist/components/CropImage/CropImage.spec.d.ts.map +1 -0
  88. package/dist/components/CropImage/CropImage.spec.js +216 -0
  89. package/dist/components/CropImage/CropImage.stories.svelte +133 -0
  90. package/dist/components/CropImage/CropImage.stories.svelte.d.ts +40 -0
  91. package/dist/components/CropImage/CropImage.stories.svelte.d.ts.map +1 -0
  92. package/dist/components/CropImage/CropImage.svelte +311 -0
  93. package/dist/components/CropImage/CropImage.svelte.d.ts +34 -0
  94. package/dist/components/CropImage/CropImage.svelte.d.ts.map +1 -0
  95. package/dist/components/DarkModeToggle.spec.d.ts +2 -0
  96. package/dist/components/DarkModeToggle.spec.d.ts.map +1 -0
  97. package/dist/components/DarkModeToggle.spec.js +357 -0
  98. package/dist/components/DarkModeToggle.stories.svelte +55 -0
  99. package/dist/components/DarkModeToggle.stories.svelte.d.ts +32 -0
  100. package/dist/components/DarkModeToggle.stories.svelte.d.ts.map +1 -0
  101. package/dist/components/DarkModeToggle.svelte +245 -0
  102. package/dist/components/DarkModeToggle.svelte.d.ts +26 -0
  103. package/dist/components/DarkModeToggle.svelte.d.ts.map +1 -0
  104. package/dist/components/ErrorDisplay.spec.d.ts +2 -0
  105. package/dist/components/ErrorDisplay.spec.d.ts.map +1 -0
  106. package/dist/components/ErrorDisplay.spec.js +69 -0
  107. package/dist/components/ErrorDisplay.stories.svelte +115 -0
  108. package/dist/components/ErrorDisplay.stories.svelte.d.ts +62 -0
  109. package/dist/components/ErrorDisplay.stories.svelte.d.ts.map +1 -0
  110. package/dist/components/ErrorDisplay.svelte +58 -0
  111. package/dist/components/ErrorDisplay.svelte.d.ts +36 -0
  112. package/dist/components/ErrorDisplay.svelte.d.ts.map +1 -0
  113. package/dist/components/FormActions.spec.d.ts +2 -0
  114. package/dist/components/FormActions.spec.d.ts.map +1 -0
  115. package/dist/components/FormActions.spec.js +88 -0
  116. package/dist/components/FormActions.stories.svelte +98 -0
  117. package/dist/components/FormActions.stories.svelte.d.ts +57 -0
  118. package/dist/components/FormActions.stories.svelte.d.ts.map +1 -0
  119. package/dist/components/FormActions.svelte +67 -0
  120. package/dist/components/FormActions.svelte.d.ts +48 -0
  121. package/dist/components/FormActions.svelte.d.ts.map +1 -0
  122. package/dist/components/FormValidationSummary.spec.d.ts +2 -0
  123. package/dist/components/FormValidationSummary.spec.d.ts.map +1 -0
  124. package/dist/components/FormValidationSummary.spec.js +203 -0
  125. package/dist/components/FormValidationSummary.stories.svelte +95 -0
  126. package/dist/components/FormValidationSummary.stories.svelte.d.ts +32 -0
  127. package/dist/components/FormValidationSummary.stories.svelte.d.ts.map +1 -0
  128. package/dist/components/FormValidationSummary.svelte +83 -0
  129. package/dist/components/FormValidationSummary.svelte.d.ts +32 -0
  130. package/dist/components/FormValidationSummary.svelte.d.ts.map +1 -0
  131. package/dist/components/Icons/ArrowLeft.svelte +21 -0
  132. package/dist/components/Icons/ArrowLeft.svelte.d.ts +28 -0
  133. package/dist/components/Icons/ArrowLeft.svelte.d.ts.map +1 -0
  134. package/dist/components/Icons/ArrowRight.svelte +21 -0
  135. package/dist/components/Icons/ArrowRight.svelte.d.ts +28 -0
  136. package/dist/components/Icons/ArrowRight.svelte.d.ts.map +1 -0
  137. package/dist/components/Icons/Availability.svelte +28 -0
  138. package/dist/components/Icons/Availability.svelte.d.ts +28 -0
  139. package/dist/components/Icons/Availability.svelte.d.ts.map +1 -0
  140. package/dist/components/Icons/Back.svelte +28 -0
  141. package/dist/components/Icons/Back.svelte.d.ts +28 -0
  142. package/dist/components/Icons/Back.svelte.d.ts.map +1 -0
  143. package/dist/components/Icons/CheckCircle.svelte +20 -0
  144. package/dist/components/Icons/CheckCircle.svelte.d.ts +28 -0
  145. package/dist/components/Icons/CheckCircle.svelte.d.ts.map +1 -0
  146. package/dist/components/Icons/CheckCircleOutline.svelte +28 -0
  147. package/dist/components/Icons/CheckCircleOutline.svelte.d.ts +28 -0
  148. package/dist/components/Icons/CheckCircleOutline.svelte.d.ts.map +1 -0
  149. package/dist/components/Icons/ChevronLeft.svelte +18 -0
  150. package/dist/components/Icons/ChevronLeft.svelte.d.ts +28 -0
  151. package/dist/components/Icons/ChevronLeft.svelte.d.ts.map +1 -0
  152. package/dist/components/Icons/ChevronRight.svelte +18 -0
  153. package/dist/components/Icons/ChevronRight.svelte.d.ts +28 -0
  154. package/dist/components/Icons/ChevronRight.svelte.d.ts.map +1 -0
  155. package/dist/components/Icons/Copy.svelte +28 -0
  156. package/dist/components/Icons/Copy.svelte.d.ts +28 -0
  157. package/dist/components/Icons/Copy.svelte.d.ts.map +1 -0
  158. package/dist/components/Icons/Cross.svelte +18 -0
  159. package/dist/components/Icons/Cross.svelte.d.ts +28 -0
  160. package/dist/components/Icons/Cross.svelte.d.ts.map +1 -0
  161. package/dist/components/Icons/DownArrow.svelte +21 -0
  162. package/dist/components/Icons/DownArrow.svelte.d.ts +28 -0
  163. package/dist/components/Icons/DownArrow.svelte.d.ts.map +1 -0
  164. package/dist/components/Icons/ErrorCircle.svelte +20 -0
  165. package/dist/components/Icons/ErrorCircle.svelte.d.ts +28 -0
  166. package/dist/components/Icons/ErrorCircle.svelte.d.ts.map +1 -0
  167. package/dist/components/Icons/FacebookIcon.svelte +14 -0
  168. package/dist/components/Icons/FacebookIcon.svelte.d.ts +28 -0
  169. package/dist/components/Icons/FacebookIcon.svelte.d.ts.map +1 -0
  170. package/dist/components/Icons/Home.svelte +29 -0
  171. package/dist/components/Icons/Home.svelte.d.ts +28 -0
  172. package/dist/components/Icons/Home.svelte.d.ts.map +1 -0
  173. package/dist/components/Icons/Icon.spec.d.ts +2 -0
  174. package/dist/components/Icons/Icon.spec.d.ts.map +1 -0
  175. package/dist/components/Icons/Icon.spec.js +175 -0
  176. package/dist/components/Icons/Icon.stories.svelte +101 -0
  177. package/dist/components/Icons/Icon.stories.svelte.d.ts +44 -0
  178. package/dist/components/Icons/Icon.stories.svelte.d.ts.map +1 -0
  179. package/dist/components/Icons/Icon.svelte +66 -0
  180. package/dist/components/Icons/Icon.svelte.d.ts +30 -0
  181. package/dist/components/Icons/Icon.svelte.d.ts.map +1 -0
  182. package/dist/components/Icons/IconGallery.stories.svelte +233 -0
  183. package/dist/components/Icons/IconGallery.stories.svelte.d.ts +30 -0
  184. package/dist/components/Icons/IconGallery.stories.svelte.d.ts.map +1 -0
  185. package/dist/components/Icons/Info.svelte +20 -0
  186. package/dist/components/Icons/Info.svelte.d.ts +28 -0
  187. package/dist/components/Icons/Info.svelte.d.ts.map +1 -0
  188. package/dist/components/Icons/InstagramIcon.svelte +20 -0
  189. package/dist/components/Icons/InstagramIcon.svelte.d.ts +28 -0
  190. package/dist/components/Icons/InstagramIcon.svelte.d.ts.map +1 -0
  191. package/dist/components/Icons/Message.svelte +28 -0
  192. package/dist/components/Icons/Message.svelte.d.ts +28 -0
  193. package/dist/components/Icons/Message.svelte.d.ts.map +1 -0
  194. package/dist/components/Icons/MoonIcon.svelte +17 -0
  195. package/dist/components/Icons/MoonIcon.svelte.d.ts +28 -0
  196. package/dist/components/Icons/MoonIcon.svelte.d.ts.map +1 -0
  197. package/dist/components/Icons/More.svelte +35 -0
  198. package/dist/components/Icons/More.svelte.d.ts +28 -0
  199. package/dist/components/Icons/More.svelte.d.ts.map +1 -0
  200. package/dist/components/Icons/MoreHori.spec.d.ts +2 -0
  201. package/dist/components/Icons/MoreHori.spec.d.ts.map +1 -0
  202. package/dist/components/Icons/MoreHori.spec.js +67 -0
  203. package/dist/components/Icons/MoreHori.svelte +35 -0
  204. package/dist/components/Icons/MoreHori.svelte.d.ts +28 -0
  205. package/dist/components/Icons/MoreHori.svelte.d.ts.map +1 -0
  206. package/dist/components/Icons/Notification.svelte +28 -0
  207. package/dist/components/Icons/Notification.svelte.d.ts +28 -0
  208. package/dist/components/Icons/Notification.svelte.d.ts.map +1 -0
  209. package/dist/components/Icons/Payment.svelte +28 -0
  210. package/dist/components/Icons/Payment.svelte.d.ts +28 -0
  211. package/dist/components/Icons/Payment.svelte.d.ts.map +1 -0
  212. package/dist/components/Icons/Profile.svelte +35 -0
  213. package/dist/components/Icons/Profile.svelte.d.ts +28 -0
  214. package/dist/components/Icons/Profile.svelte.d.ts.map +1 -0
  215. package/dist/components/Icons/Reload.svelte +42 -0
  216. package/dist/components/Icons/Reload.svelte.d.ts +28 -0
  217. package/dist/components/Icons/Reload.svelte.d.ts.map +1 -0
  218. package/dist/components/Icons/Shows.svelte +35 -0
  219. package/dist/components/Icons/Shows.svelte.d.ts +28 -0
  220. package/dist/components/Icons/Shows.svelte.d.ts.map +1 -0
  221. package/dist/components/Icons/Signout.svelte +35 -0
  222. package/dist/components/Icons/Signout.svelte.d.ts +28 -0
  223. package/dist/components/Icons/Signout.svelte.d.ts.map +1 -0
  224. package/dist/components/Icons/SunIcon.svelte +20 -0
  225. package/dist/components/Icons/SunIcon.svelte.d.ts +28 -0
  226. package/dist/components/Icons/SunIcon.svelte.d.ts.map +1 -0
  227. package/dist/components/Icons/TiktokIcon.svelte +14 -0
  228. package/dist/components/Icons/TiktokIcon.svelte.d.ts +28 -0
  229. package/dist/components/Icons/TiktokIcon.svelte.d.ts.map +1 -0
  230. package/dist/components/Icons/TwitterIcon.svelte +14 -0
  231. package/dist/components/Icons/TwitterIcon.svelte.d.ts +28 -0
  232. package/dist/components/Icons/TwitterIcon.svelte.d.ts.map +1 -0
  233. package/dist/components/Icons/WarningIcon.spec.d.ts +2 -0
  234. package/dist/components/Icons/WarningIcon.spec.d.ts.map +1 -0
  235. package/dist/components/Icons/WarningIcon.spec.js +30 -0
  236. package/dist/components/Icons/WarningIcon.svelte +24 -0
  237. package/dist/components/Icons/WarningIcon.svelte.d.ts +26 -0
  238. package/dist/components/Icons/WarningIcon.svelte.d.ts.map +1 -0
  239. package/dist/components/Input/Input.spec.d.ts +2 -0
  240. package/dist/components/Input/Input.spec.d.ts.map +1 -0
  241. package/dist/components/Input/Input.spec.js +573 -0
  242. package/dist/components/Input/Input.stories.svelte +140 -0
  243. package/dist/components/Input/Input.stories.svelte.d.ts +80 -0
  244. package/dist/components/Input/Input.stories.svelte.d.ts.map +1 -0
  245. package/dist/components/Input/Input.svelte +721 -0
  246. package/dist/components/Input/Input.svelte.d.ts +96 -0
  247. package/dist/components/Input/Input.svelte.d.ts.map +1 -0
  248. package/dist/components/Input/InputAudit.stories.svelte +483 -0
  249. package/dist/components/Input/InputAudit.stories.svelte.d.ts +31 -0
  250. package/dist/components/Input/InputAudit.stories.svelte.d.ts.map +1 -0
  251. package/dist/components/Input/MultiSelect.spec.d.ts +2 -0
  252. package/dist/components/Input/MultiSelect.spec.d.ts.map +1 -0
  253. package/dist/components/Input/MultiSelect.spec.js +257 -0
  254. package/dist/components/Input/MultiSelect.stories.svelte +138 -0
  255. package/dist/components/Input/MultiSelect.stories.svelte.d.ts +32 -0
  256. package/dist/components/Input/MultiSelect.stories.svelte.d.ts.map +1 -0
  257. package/dist/components/Input/MultiSelect.svelte +557 -0
  258. package/dist/components/Input/MultiSelect.svelte.d.ts +50 -0
  259. package/dist/components/Input/MultiSelect.svelte.d.ts.map +1 -0
  260. package/dist/components/Input/OTPInput.spec.d.ts +2 -0
  261. package/dist/components/Input/OTPInput.spec.d.ts.map +1 -0
  262. package/dist/components/Input/OTPInput.spec.js +238 -0
  263. package/dist/components/Input/OTPInput.stories.svelte +167 -0
  264. package/dist/components/Input/OTPInput.stories.svelte.d.ts +48 -0
  265. package/dist/components/Input/OTPInput.stories.svelte.d.ts.map +1 -0
  266. package/dist/components/Input/OTPInput.svelte +117 -0
  267. package/dist/components/Input/OTPInput.svelte.d.ts +42 -0
  268. package/dist/components/Input/OTPInput.svelte.d.ts.map +1 -0
  269. package/dist/components/Input/Select.spec.d.ts +2 -0
  270. package/dist/components/Input/Select.spec.d.ts.map +1 -0
  271. package/dist/components/Input/Select.spec.js +218 -0
  272. package/dist/components/Input/Select.svelte +385 -0
  273. package/dist/components/Input/Select.svelte.d.ts +48 -0
  274. package/dist/components/Input/Select.svelte.d.ts.map +1 -0
  275. package/dist/components/Input/SelectAudit.stories.svelte +364 -0
  276. package/dist/components/Input/SelectAudit.stories.svelte.d.ts +31 -0
  277. package/dist/components/Input/SelectAudit.stories.svelte.d.ts.map +1 -0
  278. package/dist/components/Layout/BottomNav.spec.d.ts +2 -0
  279. package/dist/components/Layout/BottomNav.spec.d.ts.map +1 -0
  280. package/dist/components/Layout/BottomNav.spec.js +130 -0
  281. package/dist/components/Layout/BottomNav.stories.svelte +115 -0
  282. package/dist/components/Layout/BottomNav.stories.svelte.d.ts +32 -0
  283. package/dist/components/Layout/BottomNav.stories.svelte.d.ts.map +1 -0
  284. package/dist/components/Layout/BottomNav.svelte +120 -0
  285. package/dist/components/Layout/BottomNav.svelte.d.ts +26 -0
  286. package/dist/components/Layout/BottomNav.svelte.d.ts.map +1 -0
  287. package/dist/components/Layout/Header.spec.d.ts +2 -0
  288. package/dist/components/Layout/Header.spec.d.ts.map +1 -0
  289. package/dist/components/Layout/Header.spec.js +203 -0
  290. package/dist/components/Layout/Header.stories.svelte +78 -0
  291. package/dist/components/Layout/Header.stories.svelte.d.ts +47 -0
  292. package/dist/components/Layout/Header.stories.svelte.d.ts.map +1 -0
  293. package/dist/components/Layout/Header.svelte +528 -0
  294. package/dist/components/Layout/Header.svelte.d.ts +42 -0
  295. package/dist/components/Layout/Header.svelte.d.ts.map +1 -0
  296. package/dist/components/Modal/ConfirmationModal.spec.d.ts +2 -0
  297. package/dist/components/Modal/ConfirmationModal.spec.d.ts.map +1 -0
  298. package/dist/components/Modal/ConfirmationModal.spec.js +191 -0
  299. package/dist/components/Modal/ConfirmationModal.stories.svelte +124 -0
  300. package/dist/components/Modal/ConfirmationModal.stories.svelte.d.ts +45 -0
  301. package/dist/components/Modal/ConfirmationModal.stories.svelte.d.ts.map +1 -0
  302. package/dist/components/Modal/ConfirmationModal.svelte +105 -0
  303. package/dist/components/Modal/ConfirmationModal.svelte.d.ts +38 -0
  304. package/dist/components/Modal/ConfirmationModal.svelte.d.ts.map +1 -0
  305. package/dist/components/Modal/Modal.spec.d.ts +2 -0
  306. package/dist/components/Modal/Modal.spec.d.ts.map +1 -0
  307. package/dist/components/Modal/Modal.spec.js +95 -0
  308. package/dist/components/Modal/Modal.stories.svelte +83 -0
  309. package/dist/components/Modal/Modal.stories.svelte.d.ts +31 -0
  310. package/dist/components/Modal/Modal.stories.svelte.d.ts.map +1 -0
  311. package/dist/components/Modal/Modal.svelte +234 -0
  312. package/dist/components/Modal/Modal.svelte.d.ts +46 -0
  313. package/dist/components/Modal/Modal.svelte.d.ts.map +1 -0
  314. package/dist/components/Modal/ModalAudit.stories.svelte +329 -0
  315. package/dist/components/Modal/ModalAudit.stories.svelte.d.ts +31 -0
  316. package/dist/components/Modal/ModalAudit.stories.svelte.d.ts.map +1 -0
  317. package/dist/components/Modal/ModalStateManager.spec.d.ts +2 -0
  318. package/dist/components/Modal/ModalStateManager.spec.d.ts.map +1 -0
  319. package/dist/components/Modal/ModalStateManager.spec.js +100 -0
  320. package/dist/components/Modal/ModalStateManager.svelte +67 -0
  321. package/dist/components/Modal/ModalStateManager.svelte.d.ts +48 -0
  322. package/dist/components/Modal/ModalStateManager.svelte.d.ts.map +1 -0
  323. package/dist/components/Modal/ModalTestWrapper.svelte +21 -0
  324. package/dist/components/Modal/ModalTestWrapper.svelte.d.ts +36 -0
  325. package/dist/components/Modal/ModalTestWrapper.svelte.d.ts.map +1 -0
  326. package/dist/components/PageLoader.spec.d.ts +2 -0
  327. package/dist/components/PageLoader.spec.d.ts.map +1 -0
  328. package/dist/components/PageLoader.spec.js +54 -0
  329. package/dist/components/PageLoader.stories.svelte +145 -0
  330. package/dist/components/PageLoader.stories.svelte.d.ts +53 -0
  331. package/dist/components/PageLoader.stories.svelte.d.ts.map +1 -0
  332. package/dist/components/PageLoader.svelte +52 -0
  333. package/dist/components/PageLoader.svelte.d.ts +42 -0
  334. package/dist/components/PageLoader.svelte.d.ts.map +1 -0
  335. package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.d.ts +2 -0
  336. package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.d.ts.map +1 -0
  337. package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +173 -0
  338. package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +101 -0
  339. package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte.d.ts +36 -0
  340. package/dist/components/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte.d.ts.map +1 -0
  341. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.spec.d.ts +2 -0
  342. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.spec.d.ts.map +1 -0
  343. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.spec.js +300 -0
  344. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +168 -0
  345. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.stories.svelte.d.ts +60 -0
  346. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.stories.svelte.d.ts.map +1 -0
  347. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.svelte +431 -0
  348. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts +29 -0
  349. package/dist/components/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -0
  350. package/dist/components/Spinner/Spinner.spec.d.ts +2 -0
  351. package/dist/components/Spinner/Spinner.spec.d.ts.map +1 -0
  352. package/dist/components/Spinner/Spinner.spec.js +75 -0
  353. package/dist/components/Spinner/Spinner.stories.svelte +30 -0
  354. package/dist/components/Spinner/Spinner.stories.svelte.d.ts +31 -0
  355. package/dist/components/Spinner/Spinner.stories.svelte.d.ts.map +1 -0
  356. package/dist/components/Spinner/Spinner.svelte +19 -0
  357. package/dist/components/Spinner/Spinner.svelte.d.ts +26 -0
  358. package/dist/components/Spinner/Spinner.svelte.d.ts.map +1 -0
  359. package/dist/components/StatusIndicator/StatusIndicator.spec.d.ts +2 -0
  360. package/dist/components/StatusIndicator/StatusIndicator.spec.d.ts.map +1 -0
  361. package/dist/components/StatusIndicator/StatusIndicator.spec.js +129 -0
  362. package/dist/components/StatusIndicator/StatusIndicator.svelte +206 -0
  363. package/dist/components/StatusIndicator/StatusIndicator.svelte.d.ts +28 -0
  364. package/dist/components/StatusIndicator/StatusIndicator.svelte.d.ts.map +1 -0
  365. package/dist/components/Toaster/Toaster.stories.svelte +61 -0
  366. package/dist/components/Toaster/Toaster.stories.svelte.d.ts +29 -0
  367. package/dist/components/Toaster/Toaster.stories.svelte.d.ts.map +1 -0
  368. package/dist/components/Toggle.spec.d.ts +2 -0
  369. package/dist/components/Toggle.spec.d.ts.map +1 -0
  370. package/dist/components/Toggle.spec.js +158 -0
  371. package/dist/components/Toggle.stories.svelte +93 -0
  372. package/dist/components/Toggle.stories.svelte.d.ts +41 -0
  373. package/dist/components/Toggle.stories.svelte.d.ts.map +1 -0
  374. package/dist/components/Toggle.svelte +79 -0
  375. package/dist/components/Toggle.svelte.d.ts +32 -0
  376. package/dist/components/Toggle.svelte.d.ts.map +1 -0
  377. package/dist/components/ValidationError.spec.d.ts +2 -0
  378. package/dist/components/ValidationError.spec.d.ts.map +1 -0
  379. package/dist/components/ValidationError.spec.js +79 -0
  380. package/dist/components/ValidationError.stories.svelte +88 -0
  381. package/dist/components/ValidationError.stories.svelte.d.ts +41 -0
  382. package/dist/components/ValidationError.stories.svelte.d.ts.map +1 -0
  383. package/dist/components/ValidationError.svelte +19 -0
  384. package/dist/components/ValidationError.svelte.d.ts +28 -0
  385. package/dist/components/ValidationError.svelte.d.ts.map +1 -0
  386. package/dist/components/pages/performers/AvailabilityCalendarModal.spec.d.ts +2 -0
  387. package/dist/components/pages/performers/AvailabilityCalendarModal.spec.d.ts.map +1 -0
  388. package/dist/components/pages/performers/AvailabilityCalendarModal.spec.js +606 -0
  389. package/dist/components/pages/performers/AvailabilityCalendarModal.svelte +632 -0
  390. package/dist/components/pages/performers/AvailabilityCalendarModal.svelte.d.ts +36 -0
  391. package/dist/components/pages/performers/AvailabilityCalendarModal.svelte.d.ts.map +1 -0
  392. package/dist/components/pages/performers/ModalShowInfo.spec.d.ts +2 -0
  393. package/dist/components/pages/performers/ModalShowInfo.spec.d.ts.map +1 -0
  394. package/dist/components/pages/performers/ModalShowInfo.spec.js +124 -0
  395. package/dist/components/pages/performers/ModalShowInfo.svelte +88 -0
  396. package/dist/components/pages/performers/ModalShowInfo.svelte.d.ts +34 -0
  397. package/dist/components/pages/performers/ModalShowInfo.svelte.d.ts.map +1 -0
  398. package/dist/components/pages/performers/PageBackButton.spec.d.ts +2 -0
  399. package/dist/components/pages/performers/PageBackButton.spec.d.ts.map +1 -0
  400. package/dist/components/pages/performers/PageBackButton.spec.js +89 -0
  401. package/dist/components/pages/performers/PageBackButton.stories.svelte +72 -0
  402. package/dist/components/pages/performers/PageBackButton.stories.svelte.d.ts +36 -0
  403. package/dist/components/pages/performers/PageBackButton.stories.svelte.d.ts.map +1 -0
  404. package/dist/components/pages/performers/PageBackButton.svelte +13 -0
  405. package/dist/components/pages/performers/PageBackButton.svelte.d.ts +26 -0
  406. package/dist/components/pages/performers/PageBackButton.svelte.d.ts.map +1 -0
  407. package/dist/components/pages/performers/SectionHeader.spec.d.ts +2 -0
  408. package/dist/components/pages/performers/SectionHeader.spec.d.ts.map +1 -0
  409. package/dist/components/pages/performers/SectionHeader.spec.js +75 -0
  410. package/dist/components/pages/performers/SectionHeader.stories.svelte +100 -0
  411. package/dist/components/pages/performers/SectionHeader.stories.svelte.d.ts +41 -0
  412. package/dist/components/pages/performers/SectionHeader.stories.svelte.d.ts.map +1 -0
  413. package/dist/components/pages/performers/SectionHeader.svelte +9 -0
  414. package/dist/components/pages/performers/SectionHeader.svelte.d.ts +28 -0
  415. package/dist/components/pages/performers/SectionHeader.svelte.d.ts.map +1 -0
  416. package/dist/components/pages/performers/ShowDetails.spec.d.ts +2 -0
  417. package/dist/components/pages/performers/ShowDetails.spec.d.ts.map +1 -0
  418. package/dist/components/pages/performers/ShowDetails.spec.js +166 -0
  419. package/dist/components/pages/performers/ShowDetails.stories.svelte +140 -0
  420. package/dist/components/pages/performers/ShowDetails.stories.svelte.d.ts +37 -0
  421. package/dist/components/pages/performers/ShowDetails.stories.svelte.d.ts.map +1 -0
  422. package/dist/components/pages/performers/ShowDetails.svelte +73 -0
  423. package/dist/components/pages/performers/ShowDetails.svelte.d.ts +44 -0
  424. package/dist/components/pages/performers/ShowDetails.svelte.d.ts.map +1 -0
  425. package/dist/components/pages/performers/ShowItemCard.spec.d.ts +2 -0
  426. package/dist/components/pages/performers/ShowItemCard.spec.d.ts.map +1 -0
  427. package/dist/components/pages/performers/ShowItemCard.spec.js +793 -0
  428. package/dist/components/pages/performers/ShowItemCard.stories.svelte +250 -0
  429. package/dist/components/pages/performers/ShowItemCard.stories.svelte.d.ts +43 -0
  430. package/dist/components/pages/performers/ShowItemCard.stories.svelte.d.ts.map +1 -0
  431. package/dist/components/pages/performers/ShowItemCard.svelte +886 -0
  432. package/dist/components/pages/performers/ShowItemCard.svelte.d.ts +54 -0
  433. package/dist/components/pages/performers/ShowItemCard.svelte.d.ts.map +1 -0
  434. package/dist/components/pages/performers/SwitchOption.spec.d.ts +2 -0
  435. package/dist/components/pages/performers/SwitchOption.spec.d.ts.map +1 -0
  436. package/dist/components/pages/performers/SwitchOption.spec.js +127 -0
  437. package/dist/components/pages/performers/SwitchOption.stories.svelte +211 -0
  438. package/dist/components/pages/performers/SwitchOption.stories.svelte.d.ts +40 -0
  439. package/dist/components/pages/performers/SwitchOption.stories.svelte.d.ts.map +1 -0
  440. package/dist/components/pages/performers/SwitchOption.svelte +24 -0
  441. package/dist/components/pages/performers/SwitchOption.svelte.d.ts +30 -0
  442. package/dist/components/pages/performers/SwitchOption.svelte.d.ts.map +1 -0
  443. package/dist/components/pages/performers/VenueInfo.spec.d.ts +2 -0
  444. package/dist/components/pages/performers/VenueInfo.spec.d.ts.map +1 -0
  445. package/dist/components/pages/performers/VenueInfo.spec.js +167 -0
  446. package/dist/components/pages/performers/VenueInfo.svelte +90 -0
  447. package/dist/components/pages/performers/VenueInfo.svelte.d.ts +32 -0
  448. package/dist/components/pages/performers/VenueInfo.svelte.d.ts.map +1 -0
  449. package/dist/components/pages/performers/VenueItemCard.spec.d.ts +2 -0
  450. package/dist/components/pages/performers/VenueItemCard.spec.d.ts.map +1 -0
  451. package/dist/components/pages/performers/VenueItemCard.spec.js +763 -0
  452. package/dist/components/pages/performers/VenueItemCard.stories.svelte +301 -0
  453. package/dist/components/pages/performers/VenueItemCard.stories.svelte.d.ts +37 -0
  454. package/dist/components/pages/performers/VenueItemCard.stories.svelte.d.ts.map +1 -0
  455. package/dist/components/pages/performers/VenueItemCard.svelte +192 -0
  456. package/dist/components/pages/performers/VenueItemCard.svelte.d.ts +66 -0
  457. package/dist/components/pages/performers/VenueItemCard.svelte.d.ts.map +1 -0
  458. package/dist/components/pages/profile/profile-form.spec.d.ts +2 -0
  459. package/dist/components/pages/profile/profile-form.spec.d.ts.map +1 -0
  460. package/dist/components/pages/profile/profile-form.spec.js +9 -0
  461. package/dist/components/pages/profile/profile-form.stories.svelte +279 -0
  462. package/dist/components/pages/profile/profile-form.stories.svelte.d.ts +48 -0
  463. package/dist/components/pages/profile/profile-form.stories.svelte.d.ts.map +1 -0
  464. package/dist/components/pages/profile/profile-form.svelte +445 -0
  465. package/dist/components/pages/profile/profile-form.svelte.d.ts +36 -0
  466. package/dist/components/pages/profile/profile-form.svelte.d.ts.map +1 -0
  467. package/dist/components/pages/profile/profile-photos.stories.svelte +69 -0
  468. package/dist/components/pages/profile/profile-photos.stories.svelte.d.ts +31 -0
  469. package/dist/components/pages/profile/profile-photos.stories.svelte.d.ts.map +1 -0
  470. package/dist/components/pages/profile/profile-photos.svelte +26 -0
  471. package/dist/components/pages/profile/profile-photos.svelte.d.ts +26 -0
  472. package/dist/components/pages/profile/profile-photos.svelte.d.ts.map +1 -0
  473. package/dist/components/pages/settings/tabs/CustomImageDropzone.stories.svelte +166 -0
  474. package/dist/components/pages/settings/tabs/CustomImageDropzone.stories.svelte.d.ts +49 -0
  475. package/dist/components/pages/settings/tabs/CustomImageDropzone.stories.svelte.d.ts.map +1 -0
  476. package/dist/components/pages/settings/tabs/CustomImageDropzone.svelte +241 -0
  477. package/dist/components/pages/settings/tabs/CustomImageDropzone.svelte.d.ts +38 -0
  478. package/dist/components/pages/settings/tabs/CustomImageDropzone.svelte.d.ts.map +1 -0
  479. package/dist/components/pages/shows/ShowList.spec.d.ts +2 -0
  480. package/dist/components/pages/shows/ShowList.spec.d.ts.map +1 -0
  481. package/dist/components/pages/shows/ShowList.spec.js +33 -0
  482. package/dist/components/pages/shows/ShowList.stories.svelte +258 -0
  483. package/dist/components/pages/shows/ShowList.stories.svelte.d.ts +41 -0
  484. package/dist/components/pages/shows/ShowList.stories.svelte.d.ts.map +1 -0
  485. package/dist/components/pages/shows/ShowList.svelte +12 -0
  486. package/dist/components/pages/shows/ShowList.svelte.d.ts +28 -0
  487. package/dist/components/pages/shows/ShowList.svelte.d.ts.map +1 -0
  488. package/dist/components/pages/shows/TabContent.spec.d.ts +2 -0
  489. package/dist/components/pages/shows/TabContent.spec.d.ts.map +1 -0
  490. package/dist/components/pages/shows/TabContent.spec.js +90 -0
  491. package/dist/components/pages/shows/TabContent.stories.svelte +254 -0
  492. package/dist/components/pages/shows/TabContent.stories.svelte.d.ts +45 -0
  493. package/dist/components/pages/shows/TabContent.stories.svelte.d.ts.map +1 -0
  494. package/dist/components/pages/shows/TabContent.svelte +94 -0
  495. package/dist/components/pages/shows/TabContent.svelte.d.ts +32 -0
  496. package/dist/components/pages/shows/TabContent.svelte.d.ts.map +1 -0
  497. package/dist/components/pages/shows/TabNavigation.spec.d.ts +2 -0
  498. package/dist/components/pages/shows/TabNavigation.spec.d.ts.map +1 -0
  499. package/dist/components/pages/shows/TabNavigation.spec.js +143 -0
  500. package/dist/components/pages/shows/TabNavigation.stories.svelte +177 -0
  501. package/dist/components/pages/shows/TabNavigation.stories.svelte.d.ts +41 -0
  502. package/dist/components/pages/shows/TabNavigation.stories.svelte.d.ts.map +1 -0
  503. package/dist/components/pages/shows/TabNavigation.svelte +64 -0
  504. package/dist/components/pages/shows/TabNavigation.svelte.d.ts +32 -0
  505. package/dist/components/pages/shows/TabNavigation.svelte.d.ts.map +1 -0
  506. package/dist/config.js +5 -5
  507. package/dist/config.spec.js +29 -29
  508. package/dist/constants/formOptions.js +25 -25
  509. package/dist/constants/formOptions.spec.js +88 -88
  510. package/dist/index.d.ts +80 -0
  511. package/dist/index.d.ts.map +1 -0
  512. package/dist/index.js +111 -0
  513. package/dist/telemetry.js +357 -357
  514. package/dist/telemetry.server.js +211 -211
  515. package/dist/telemetry.server.spec.js +434 -434
  516. package/dist/telemetry.spec.js +660 -660
  517. package/package.json +155 -152
@@ -0,0 +1,763 @@
1
+ import { describe, it, expect, vi, beforeEach, beforeAll, afterEach } from 'vitest';
2
+ import { render, fireEvent, waitFor, cleanup } from '@testing-library/svelte';
3
+
4
+ // Mock IntersectionObserver
5
+ vi.stubGlobal('IntersectionObserver', vi.fn().mockImplementation(() => ({
6
+ observe: vi.fn(),
7
+ disconnect: vi.fn(),
8
+ unobserve: vi.fn(),
9
+ })));
10
+
11
+ // Mock $app modules
12
+ vi.mock('$app/navigation', () => ({
13
+ goto: vi.fn(),
14
+ }));
15
+
16
+ vi.mock('$app/stores', () => ({
17
+ page: {
18
+ subscribe: vi.fn((callback) => {
19
+ callback({ url: new URL('http://localhost:3000/availability') });
20
+ return () => {};
21
+ }),
22
+ },
23
+ }));
24
+
25
+ vi.mock('$app/environment', () => ({
26
+ browser: true,
27
+ }));
28
+
29
+ // Mock stores
30
+ vi.mock('@/stores/toaster', () => ({
31
+ showToast: vi.fn(),
32
+ }));
33
+
34
+ // Mock utils
35
+ vi.mock('@/utils/utils', () => ({
36
+ getPerformerToken: vi.fn(() => 'mock-token'),
37
+ microphonePlaceholder: '/placeholder.jpg',
38
+ parseLocation: vi.fn((location) => ({
39
+ street: location ? '123 Test St' : '',
40
+ cityStateZip: location ? 'City, ST 12345' : '',
41
+ })),
42
+ getUserDetails: vi.fn(() => ({ firstName: 'Test', lastName: 'User' })),
43
+ classNames: vi.fn((...args) => args.filter(Boolean).join(' ')),
44
+ }));
45
+
46
+ // Mock Modal to always render its slots (for testing modal content)
47
+ // This is scoped to this test file only
48
+ vi.mock('@/components/Modal/Modal.svelte', async () => {
49
+ const MockModal = await import('../../../__mocks__/Modal.svelte');
50
+ return { default: MockModal.default };
51
+ });
52
+
53
+
54
+ vi.mock('@/utils/utils/utils', () => ({
55
+ timeAgo: vi.fn(() => '2 hours ago'),
56
+ }));
57
+
58
+ vi.mock('@/utils/apiConfig', () => ({
59
+ buildApiUrl: vi.fn((endpoint) => `http://localhost:8080${endpoint}`),
60
+ API_ENDPOINTS: {
61
+ REMOVE_VENUE_FROM_ROSTER: '/api/performer/removeVenueFromRoster',
62
+ },
63
+ }));
64
+
65
+ // Mock fetch globally
66
+ global.fetch = vi.fn();
67
+
68
+ // Mock window.location.reload
69
+ const mockReload = vi.fn();
70
+ Object.defineProperty(window, 'location', {
71
+ value: { reload: mockReload },
72
+ writable: true,
73
+ });
74
+
75
+ describe('VenueItemCard', () => {
76
+ let VenueItemCard;
77
+ let showToast;
78
+
79
+ const defaultProps = {
80
+ venueId: 1,
81
+ name: 'Test Venue',
82
+ image: '/test-image.jpg',
83
+ location: '123 Test St, City',
84
+ start: '2025-01-01',
85
+ end: '2025-12-31',
86
+ doorOpen: '6:00 PM',
87
+ email: 'test@venue.com',
88
+ phone: '555-1234',
89
+ description: 'A great venue',
90
+ instagram: '@testvenue',
91
+ facebook: 'testvenue',
92
+ twitter: '@testvenue',
93
+ inviteID: 123,
94
+ lastUpdated: '2025-06-01T12:00:00Z',
95
+ timeRange: '6:00 PM - 2:00 AM',
96
+ dateRange: 'Jan 1 - Dec 31',
97
+ status: 'upcoming',
98
+ invitationAccepted: true,
99
+ hasAvailability: true,
100
+ onUpdateClick: vi.fn(),
101
+ };
102
+
103
+ beforeAll(async () => {
104
+ vi.resetModules();
105
+ const toasterModule = await import('../../../../stores/toaster');
106
+ showToast = toasterModule.showToast;
107
+ VenueItemCard = (await import('./VenueItemCard.svelte')).default;
108
+ }, 60000);
109
+
110
+ beforeEach(() => {
111
+ vi.clearAllMocks();
112
+ global.fetch.mockReset();
113
+ mockReload.mockReset();
114
+ });
115
+
116
+ afterEach(() => {
117
+ cleanup();
118
+ });
119
+
120
+ describe('Basic Rendering', () => {
121
+ it('renders the venue card with basic info', async () => {
122
+ const { container } = render(VenueItemCard, { props: defaultProps });
123
+ expect(container.querySelector('.rounded-lg')).toBeDefined();
124
+ });
125
+
126
+ it('displays venue name through VenueInfo component', async () => {
127
+ const { container } = render(VenueItemCard, { props: defaultProps });
128
+ expect(container).toBeDefined();
129
+ });
130
+
131
+ it('renders with all props', async () => {
132
+ const { container } = render(VenueItemCard, { props: defaultProps });
133
+ expect(container.innerHTML).toBeDefined();
134
+ });
135
+ });
136
+
137
+ describe('Status: Upcoming with Availability', () => {
138
+ it('shows Update button when status is upcoming and has availability', async () => {
139
+ const { container } = render(VenueItemCard, {
140
+ props: {
141
+ ...defaultProps,
142
+ status: 'upcoming',
143
+ hasAvailability: true,
144
+ invitationAccepted: true,
145
+ },
146
+ });
147
+
148
+ await waitFor(() => {
149
+ const updateButton = container.querySelector('button');
150
+ expect(updateButton).toBeDefined();
151
+ });
152
+ });
153
+
154
+ it('shows last updated text', async () => {
155
+ const { container } = render(VenueItemCard, {
156
+ props: {
157
+ ...defaultProps,
158
+ status: 'upcoming',
159
+ hasAvailability: true,
160
+ invitationAccepted: true,
161
+ },
162
+ });
163
+
164
+ await waitFor(() => {
165
+ expect(container.innerHTML).toContain('Last updated');
166
+ });
167
+ });
168
+
169
+ it('calls onUpdateClick when Update button is clicked', async () => {
170
+ const mockUpdateClick = vi.fn();
171
+ const { container } = render(VenueItemCard, {
172
+ props: {
173
+ ...defaultProps,
174
+ status: 'upcoming',
175
+ hasAvailability: true,
176
+ invitationAccepted: true,
177
+ onUpdateClick: mockUpdateClick,
178
+ },
179
+ });
180
+
181
+ await waitFor(() => {
182
+ const buttons = container.querySelectorAll('button');
183
+ const updateButton = Array.from(buttons).find(
184
+ (btn) => btn.textContent?.includes('Update')
185
+ );
186
+ if (updateButton) {
187
+ fireEvent.click(updateButton);
188
+ }
189
+ });
190
+
191
+ // The onUpdateClick should have been called
192
+ expect(mockUpdateClick).toBeDefined();
193
+ });
194
+ });
195
+
196
+ describe('Status: Upcoming without Availability', () => {
197
+ it('shows Set up button when invitation accepted but no availability', async () => {
198
+ const { container } = render(VenueItemCard, {
199
+ props: {
200
+ ...defaultProps,
201
+ status: 'upcoming',
202
+ hasAvailability: false,
203
+ invitationAccepted: true,
204
+ },
205
+ });
206
+
207
+ await waitFor(() => {
208
+ expect(container.innerHTML).toContain('Set up');
209
+ });
210
+ });
211
+
212
+ it('shows warning message when needs availability update', async () => {
213
+ const { container } = render(VenueItemCard, {
214
+ props: {
215
+ ...defaultProps,
216
+ status: 'upcoming',
217
+ hasAvailability: false,
218
+ invitationAccepted: true,
219
+ },
220
+ });
221
+
222
+ await waitFor(() => {
223
+ expect(container.innerHTML).toContain('Please update your availability');
224
+ });
225
+ });
226
+
227
+ it('calls onUpdateClick when Set up button is clicked', async () => {
228
+ const mockUpdateClick = vi.fn();
229
+ const { container } = render(VenueItemCard, {
230
+ props: {
231
+ ...defaultProps,
232
+ status: 'upcoming',
233
+ hasAvailability: false,
234
+ invitationAccepted: true,
235
+ onUpdateClick: mockUpdateClick,
236
+ },
237
+ });
238
+
239
+ await waitFor(() => {
240
+ const buttons = container.querySelectorAll('button');
241
+ const setupButton = Array.from(buttons).find(
242
+ (btn) => btn.textContent?.includes('Set up')
243
+ );
244
+ if (setupButton) {
245
+ fireEvent.click(setupButton);
246
+ }
247
+ });
248
+ });
249
+ });
250
+
251
+ describe('Status: Other States', () => {
252
+ it('does not show buttons when status is not upcoming', async () => {
253
+ const { container } = render(VenueItemCard, {
254
+ props: {
255
+ ...defaultProps,
256
+ status: 'past',
257
+ hasAvailability: true,
258
+ invitationAccepted: true,
259
+ },
260
+ });
261
+
262
+ await waitFor(() => {
263
+ // Should not show the Update or Set up sections
264
+ expect(container.innerHTML).not.toContain('Last updated');
265
+ });
266
+ });
267
+
268
+ it('does not show buttons when invitation not accepted', async () => {
269
+ const { container } = render(VenueItemCard, {
270
+ props: {
271
+ ...defaultProps,
272
+ status: 'upcoming',
273
+ hasAvailability: false,
274
+ invitationAccepted: false,
275
+ },
276
+ });
277
+
278
+ await waitFor(() => {
279
+ // Should not show the availability sections
280
+ expect(container.innerHTML).not.toContain('Please update your availability');
281
+ });
282
+ });
283
+ });
284
+
285
+ describe('Leave Venue Modal', () => {
286
+ it('renders the dropdown trigger icon', async () => {
287
+ const { container } = render(VenueItemCard, {
288
+ props: {
289
+ ...defaultProps,
290
+ status: 'upcoming',
291
+ hasAvailability: true,
292
+ invitationAccepted: true,
293
+ },
294
+ });
295
+
296
+ // The dropdown trigger is present
297
+ expect(container.querySelector('[data-testid="dropdown-menu"]')).toBeDefined();
298
+ });
299
+
300
+ it('has Update button visible', async () => {
301
+ const { container } = render(VenueItemCard, {
302
+ props: {
303
+ ...defaultProps,
304
+ status: 'upcoming',
305
+ hasAvailability: true,
306
+ invitationAccepted: true,
307
+ },
308
+ });
309
+
310
+ expect(container.innerHTML).toContain('Update');
311
+ });
312
+
313
+ it('has more-menu class on dropdown trigger', async () => {
314
+ const { container } = render(VenueItemCard, {
315
+ props: {
316
+ ...defaultProps,
317
+ status: 'upcoming',
318
+ hasAvailability: true,
319
+ invitationAccepted: true,
320
+ },
321
+ });
322
+
323
+ const menuTrigger = container.querySelector('.more-menu');
324
+ expect(menuTrigger).toBeDefined();
325
+ });
326
+ });
327
+
328
+ describe('Leave Venue API', () => {
329
+ it('calls API when leave is confirmed - success', async () => {
330
+ global.fetch.mockResolvedValueOnce({
331
+ ok: true,
332
+ json: async () => ({ success: true }),
333
+ });
334
+
335
+ const { container } = render(VenueItemCard, {
336
+ props: {
337
+ ...defaultProps,
338
+ status: 'upcoming',
339
+ hasAvailability: true,
340
+ invitationAccepted: true,
341
+ },
342
+ });
343
+
344
+ // Find and click Leave button (the one in the modal footer)
345
+ const buttons = container.querySelectorAll('button');
346
+ const leaveButton = Array.from(buttons).find(
347
+ (btn) => btn.textContent?.trim() === 'Leave'
348
+ );
349
+
350
+ if (leaveButton) {
351
+ await fireEvent.click(leaveButton);
352
+
353
+ await waitFor(() => {
354
+ expect(global.fetch).toHaveBeenCalledWith(
355
+ expect.stringContaining('/api/performer/removeVenueFromRoster'),
356
+ expect.objectContaining({
357
+ method: 'DELETE',
358
+ headers: expect.objectContaining({
359
+ 'Content-Type': 'application/json',
360
+ }),
361
+ })
362
+ );
363
+ });
364
+ }
365
+ });
366
+
367
+ it('shows success toast on successful leave', async () => {
368
+ global.fetch.mockResolvedValueOnce({
369
+ ok: true,
370
+ json: async () => ({ success: true }),
371
+ });
372
+
373
+ const { container } = render(VenueItemCard, {
374
+ props: {
375
+ ...defaultProps,
376
+ status: 'upcoming',
377
+ hasAvailability: true,
378
+ invitationAccepted: true,
379
+ },
380
+ });
381
+
382
+ const buttons = container.querySelectorAll('button');
383
+ const leaveButton = Array.from(buttons).find(
384
+ (btn) => btn.textContent?.trim() === 'Leave'
385
+ );
386
+
387
+ if (leaveButton) {
388
+ await fireEvent.click(leaveButton);
389
+
390
+ await waitFor(() => {
391
+ expect(showToast).toHaveBeenCalledWith(
392
+ expect.stringContaining('You have left'),
393
+ 'success'
394
+ );
395
+ });
396
+ }
397
+ });
398
+
399
+ it('shows error toast on failed leave', async () => {
400
+ global.fetch.mockResolvedValueOnce({
401
+ ok: false,
402
+ json: async () => ({ error: 'Failed' }),
403
+ });
404
+
405
+ const { container } = render(VenueItemCard, {
406
+ props: {
407
+ ...defaultProps,
408
+ status: 'upcoming',
409
+ hasAvailability: true,
410
+ invitationAccepted: true,
411
+ },
412
+ });
413
+
414
+ const buttons = container.querySelectorAll('button');
415
+ const leaveButton = Array.from(buttons).find(
416
+ (btn) => btn.textContent?.trim() === 'Leave'
417
+ );
418
+
419
+ if (leaveButton) {
420
+ await fireEvent.click(leaveButton);
421
+
422
+ await waitFor(() => {
423
+ expect(showToast).toHaveBeenCalledWith(
424
+ expect.stringContaining('Failed to leave'),
425
+ 'error'
426
+ );
427
+ });
428
+ }
429
+ });
430
+
431
+ it('reloads page after successful leave', async () => {
432
+ global.fetch.mockResolvedValueOnce({
433
+ ok: true,
434
+ json: async () => ({ success: true }),
435
+ });
436
+
437
+ const { container } = render(VenueItemCard, {
438
+ props: {
439
+ ...defaultProps,
440
+ status: 'upcoming',
441
+ hasAvailability: true,
442
+ invitationAccepted: true,
443
+ },
444
+ });
445
+
446
+ const buttons = container.querySelectorAll('button');
447
+ const leaveButton = Array.from(buttons).find(
448
+ (btn) => btn.textContent?.trim() === 'Leave'
449
+ );
450
+
451
+ if (leaveButton) {
452
+ await fireEvent.click(leaveButton);
453
+
454
+ await waitFor(() => {
455
+ expect(mockReload).toHaveBeenCalled();
456
+ });
457
+ }
458
+ });
459
+ });
460
+
461
+ describe('Card Structure', () => {
462
+ it('has main container with border and rounded corners', async () => {
463
+ const { container } = render(VenueItemCard, {
464
+ props: {
465
+ ...defaultProps,
466
+ status: 'upcoming',
467
+ hasAvailability: true,
468
+ invitationAccepted: true,
469
+ },
470
+ });
471
+
472
+ const mainDiv = container.querySelector('.rounded-lg');
473
+ expect(mainDiv).toBeDefined();
474
+ });
475
+ });
476
+
477
+ describe('Props Handling', () => {
478
+ it('renders with minimal required props', async () => {
479
+ const minimalProps = {
480
+ venueId: 1,
481
+ name: 'Minimal Venue',
482
+ status: 'upcoming',
483
+ invitationAccepted: false,
484
+ hasAvailability: false,
485
+ };
486
+
487
+ const { container } = render(VenueItemCard, { props: minimalProps });
488
+ expect(container).toBeDefined();
489
+ });
490
+
491
+ it('handles undefined optional props', async () => {
492
+ const propsWithUndefined = {
493
+ venueId: 1,
494
+ name: 'Test Venue',
495
+ image: undefined,
496
+ location: undefined,
497
+ status: 'upcoming',
498
+ invitationAccepted: true,
499
+ hasAvailability: true,
500
+ };
501
+
502
+ const { container } = render(VenueItemCard, { props: propsWithUndefined });
503
+ expect(container).toBeDefined();
504
+ });
505
+
506
+ it('handles null optional props', async () => {
507
+ const propsWithNull = {
508
+ venueId: 1,
509
+ name: 'Test Venue',
510
+ image: null,
511
+ location: null,
512
+ email: null,
513
+ phone: null,
514
+ status: 'upcoming',
515
+ invitationAccepted: true,
516
+ hasAvailability: true,
517
+ };
518
+
519
+ const { container } = render(VenueItemCard, { props: propsWithNull });
520
+ expect(container).toBeDefined();
521
+ });
522
+
523
+ it('handles empty string props', async () => {
524
+ const propsWithEmpty = {
525
+ venueId: 1,
526
+ name: '',
527
+ image: '',
528
+ location: '',
529
+ description: '',
530
+ status: 'upcoming',
531
+ invitationAccepted: true,
532
+ hasAvailability: true,
533
+ };
534
+
535
+ const { container } = render(VenueItemCard, { props: propsWithEmpty });
536
+ expect(container).toBeDefined();
537
+ });
538
+ });
539
+
540
+ describe('Dropdown Menu', () => {
541
+ it('renders dropdown trigger icon', async () => {
542
+ const { container } = render(VenueItemCard, {
543
+ props: {
544
+ ...defaultProps,
545
+ status: 'upcoming',
546
+ hasAvailability: true,
547
+ invitationAccepted: true,
548
+ },
549
+ });
550
+
551
+ const dropdownTrigger = container.querySelector('[data-testid="dropdown-menu"]');
552
+ expect(dropdownTrigger).toBeDefined();
553
+ });
554
+
555
+ it('renders dropdown icon with correct classes', async () => {
556
+ const { container } = render(VenueItemCard, {
557
+ props: {
558
+ ...defaultProps,
559
+ status: 'upcoming',
560
+ hasAvailability: true,
561
+ invitationAccepted: true,
562
+ },
563
+ });
564
+
565
+ const menuTrigger = container.querySelector('.more-menu');
566
+ expect(menuTrigger).not.toBeNull();
567
+ });
568
+ });
569
+
570
+ describe('Without Token', () => {
571
+ it('handles API call without token', async () => {
572
+ const { getPerformerToken } = await import('../../../../utils/utils');
573
+ getPerformerToken.mockReturnValueOnce(null);
574
+
575
+ global.fetch.mockResolvedValueOnce({
576
+ ok: true,
577
+ json: async () => ({ success: true }),
578
+ });
579
+
580
+ const { container } = render(VenueItemCard, {
581
+ props: {
582
+ ...defaultProps,
583
+ status: 'upcoming',
584
+ hasAvailability: true,
585
+ invitationAccepted: true,
586
+ },
587
+ });
588
+
589
+ const buttons = container.querySelectorAll('button');
590
+ const leaveButton = Array.from(buttons).find(
591
+ (btn) => btn.textContent?.trim() === 'Leave'
592
+ );
593
+
594
+ // With the Modal mock, the Leave button is rendered
595
+ expect(leaveButton).toBeDefined();
596
+
597
+ if (leaveButton) {
598
+ await fireEvent.click(leaveButton);
599
+ // Give time for async operations
600
+ await new Promise(resolve => setTimeout(resolve, 100));
601
+ }
602
+ });
603
+ });
604
+
605
+ describe('Modal Interactions', () => {
606
+ it('Cancel button closes the modal', async () => {
607
+ const { container } = render(VenueItemCard, {
608
+ props: {
609
+ ...defaultProps,
610
+ status: 'upcoming',
611
+ hasAvailability: true,
612
+ invitationAccepted: true,
613
+ },
614
+ });
615
+
616
+ // Find Cancel button in the modal footer
617
+ const buttons = container.querySelectorAll('button');
618
+ const cancelButton = Array.from(buttons).find(
619
+ (btn) => btn.textContent?.trim() === 'Cancel'
620
+ );
621
+
622
+ if (cancelButton) {
623
+ await fireEvent.click(cancelButton);
624
+ // Modal should close after cancel
625
+ expect(container).toBeDefined();
626
+ }
627
+ });
628
+
629
+ it('handles note input in leave venue modal', async () => {
630
+ const { container } = render(VenueItemCard, {
631
+ props: {
632
+ ...defaultProps,
633
+ status: 'upcoming',
634
+ hasAvailability: true,
635
+ invitationAccepted: true,
636
+ },
637
+ });
638
+
639
+ // Find textarea for notes
640
+ const textarea = container.querySelector('textarea');
641
+ if (textarea) {
642
+ await fireEvent.input(textarea, { target: { value: 'Test note for leaving' } });
643
+ expect(textarea.value).toBe('Test note for leaving');
644
+ }
645
+ });
646
+
647
+ it('Leave button triggers API call from modal', async () => {
648
+ global.fetch.mockResolvedValueOnce({
649
+ ok: true,
650
+ json: async () => ({ success: true }),
651
+ });
652
+
653
+ const { container } = render(VenueItemCard, {
654
+ props: {
655
+ ...defaultProps,
656
+ status: 'upcoming',
657
+ hasAvailability: true,
658
+ invitationAccepted: true,
659
+ },
660
+ });
661
+
662
+ // Modal only shows Leave button when showLeaveVenue is true
663
+ // Look for modal buttons that might be in the DOM
664
+ await waitFor(() => {
665
+ const buttons = container.querySelectorAll('button');
666
+ const leaveButton = Array.from(buttons).find(
667
+ (btn) => btn.textContent?.trim() === 'Leave'
668
+ );
669
+
670
+ if (leaveButton) {
671
+ fireEvent.click(leaveButton);
672
+ }
673
+ });
674
+ });
675
+ });
676
+
677
+ describe('Dropdown Menu Interactions', () => {
678
+ it('dropdown icon is clickable', async () => {
679
+ const { container } = render(VenueItemCard, {
680
+ props: {
681
+ ...defaultProps,
682
+ status: 'upcoming',
683
+ hasAvailability: true,
684
+ invitationAccepted: true,
685
+ },
686
+ });
687
+
688
+ const dropdownIcon = container.querySelector('[data-testid="dropdown-menu"]');
689
+ expect(dropdownIcon).toBeDefined();
690
+ if (dropdownIcon) {
691
+ await fireEvent.click(dropdownIcon);
692
+ // Dropdown should be rendered
693
+ expect(container).toBeDefined();
694
+ }
695
+ });
696
+
697
+ it('shows dropdown for red warning state', async () => {
698
+ const { container } = render(VenueItemCard, {
699
+ props: {
700
+ ...defaultProps,
701
+ status: 'upcoming',
702
+ hasAvailability: false,
703
+ invitationAccepted: true,
704
+ },
705
+ });
706
+
707
+ const dropdownIcon = container.querySelector('[data-testid="dropdown-menu"]');
708
+ expect(dropdownIcon).toBeDefined();
709
+ });
710
+
711
+ it('shows dropdown for normal update state', async () => {
712
+ const { container } = render(VenueItemCard, {
713
+ props: {
714
+ ...defaultProps,
715
+ status: 'upcoming',
716
+ hasAvailability: true,
717
+ invitationAccepted: true,
718
+ },
719
+ });
720
+
721
+ const dropdownIcon = container.querySelector('[data-testid="dropdown-menu"]');
722
+ expect(dropdownIcon).toBeDefined();
723
+ });
724
+ });
725
+
726
+ describe('Toggle Modal Function', () => {
727
+ it('handles non-leave modal name', async () => {
728
+ const { container } = render(VenueItemCard, {
729
+ props: {
730
+ ...defaultProps,
731
+ status: 'upcoming',
732
+ hasAvailability: true,
733
+ invitationAccepted: true,
734
+ },
735
+ });
736
+
737
+ // The toggleModal function should handle unknown modal names gracefully
738
+ expect(container).toBeDefined();
739
+ });
740
+ });
741
+
742
+ describe('Styling', () => {
743
+ it('has correct card container classes', async () => {
744
+ const { container } = render(VenueItemCard, { props: defaultProps });
745
+
746
+ const card = container.querySelector('.rounded-lg');
747
+ expect(card).toBeDefined();
748
+ });
749
+
750
+ it('applies red styling when needs availability update', async () => {
751
+ const { container } = render(VenueItemCard, {
752
+ props: {
753
+ ...defaultProps,
754
+ status: 'upcoming',
755
+ hasAvailability: false,
756
+ invitationAccepted: true,
757
+ },
758
+ });
759
+
760
+ expect(container.innerHTML).toContain('red-50');
761
+ });
762
+ });
763
+ });