@zap-wunschlachen/wl-shared-components 1.0.3 → 1.0.5

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 (231) hide show
  1. package/.github/workflows/playwright.yml +205 -205
  2. package/.github/workflows/static.yml +61 -61
  3. package/.github/workflows/update-snapshots.yml +37 -37
  4. package/.prettierrc +5 -5
  5. package/.storybook/main.ts +18 -18
  6. package/.storybook/preview.ts +37 -37
  7. package/.storybook/storyWrapper.vue +18 -18
  8. package/.storybook/withVuetifyTheme.decorator.ts +21 -21
  9. package/App.vue +190 -147
  10. package/README.md +56 -56
  11. package/heroicons.ts +75 -75
  12. package/index.html +19 -19
  13. package/package.json +67 -67
  14. package/playwright.config.ts +48 -48
  15. package/public/background.svg +60 -60
  16. package/public/style.css +187 -187
  17. package/public/technologies.svg +22 -22
  18. package/src/assets/css/base.css +235 -235
  19. package/src/assets/css/variables.css +96 -96
  20. package/src/components/Accordion/Accordion.css +59 -59
  21. package/src/components/Accordion/AccordionGroup.vue +51 -51
  22. package/src/components/Accordion/AccordionItem.vue +66 -66
  23. package/src/components/Appointment/Card/Actions.css +28 -28
  24. package/src/components/Appointment/Card/Actions.vue +72 -69
  25. package/src/components/Appointment/Card/Card.css +81 -61
  26. package/src/components/Appointment/Card/Card.vue +88 -74
  27. package/src/components/Appointment/Card/Details.css +50 -50
  28. package/src/components/Appointment/Card/Details.vue +43 -43
  29. package/src/components/Audio/Audio.vue +187 -187
  30. package/src/components/Audio/Waveform.vue +117 -117
  31. package/src/components/Button/Button.vue +119 -119
  32. package/src/components/CheckBox/CheckBox.css +185 -185
  33. package/src/components/CheckBox/Checkbox.vue +130 -130
  34. package/src/components/DateInput/DateInput.css +2 -2
  35. package/src/components/DateInput/DateInput.vue +262 -262
  36. package/src/components/Dialog/Dialog.css +6 -6
  37. package/src/components/Dialog/Dialog.vue +29 -29
  38. package/src/components/EditField/EditField.css +19 -19
  39. package/src/components/EditField/EditField.vue +202 -202
  40. package/src/components/IconBullet/IconBullet.vue +86 -86
  41. package/src/components/IconBullet/IconBulletList.vue +41 -41
  42. package/src/components/Icons/AdvanceAppointments.vue +112 -0
  43. package/src/components/Icons/Audio/CloudFailed.vue +20 -20
  44. package/src/components/Icons/Audio/CloudSaved.vue +21 -21
  45. package/src/components/Icons/Audio/Delete.vue +15 -15
  46. package/src/components/Icons/Audio/Pause.vue +18 -18
  47. package/src/components/Icons/Audio/Play.vue +15 -15
  48. package/src/components/Icons/CalendarNotification.vue +126 -126
  49. package/src/components/Icons/Chair.vue +32 -32
  50. package/src/components/Icons/ChairNotification.vue +35 -35
  51. package/src/components/Icons/Circle.vue +66 -66
  52. package/src/components/Icons/FavIcon.vue +22 -22
  53. package/src/components/Icons/FilledCircle.vue +11 -11
  54. package/src/components/Icons/Group3.vue +46 -46
  55. package/src/components/Icons/RingNotification.vue +54 -54
  56. package/src/components/Icons/SolidArrowRight.vue +14 -14
  57. package/src/components/Icons/calendar.vue +17 -17
  58. package/src/components/Icons/checkbox.vue +19 -19
  59. package/src/components/Icons/outlineChecked.vue +27 -27
  60. package/src/components/Icons/play.vue +5 -5
  61. package/src/components/Input/Input.css +187 -187
  62. package/src/components/Input/Input.vue +247 -247
  63. package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -7
  64. package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -116
  65. package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -81
  66. package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -113
  67. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -4
  68. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -99
  69. package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -130
  70. package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -3
  71. package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -50
  72. package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -53
  73. package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -162
  74. package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -102
  75. package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -152
  76. package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -33
  77. package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -75
  78. package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -92
  79. package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -49
  80. package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -126
  81. package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -97
  82. package/src/components/Laboratory/TicketCard/TicketCard.css +3 -3
  83. package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -143
  84. package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -18
  85. package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -119
  86. package/src/components/Laboratory/TimeLine/Timeline.css +4 -4
  87. package/src/components/Laboratory/TimeLine/Timeline.vue +30 -30
  88. package/src/components/Modal/Modal.css +5 -5
  89. package/src/components/Modal/Modal.vue +22 -22
  90. package/src/components/NotificationBubble/NotificationBubble.css +4 -4
  91. package/src/components/NotificationBubble/NotificationBubble.vue +90 -90
  92. package/src/components/OtpInput/OtpInput.css +39 -39
  93. package/src/components/OtpInput/OtpInput.vue +143 -143
  94. package/src/components/PhoneInput/PhoneInput.css +31 -31
  95. package/src/components/PhoneInput/PhoneInput.vue +113 -113
  96. package/src/components/Select/Select.css +150 -150
  97. package/src/components/Select/Select.vue +304 -304
  98. package/src/components/TextArea/TextArea.css +3 -3
  99. package/src/components/TextArea/TextArea.vue +126 -126
  100. package/src/components/TickBox/TickBox.css +49 -49
  101. package/src/components/TickBox/TickBox.vue +126 -126
  102. package/src/components/index.ts +21 -21
  103. package/src/constants/iconEnums.ts +3 -3
  104. package/src/i18n/i18n.ts +15 -15
  105. package/src/i18n/locales/de.json +27 -27
  106. package/src/i18n/locales/en.json +27 -27
  107. package/src/index.ts +31 -31
  108. package/src/main.ts +11 -11
  109. package/src/plugins/vuetify.ts +131 -131
  110. package/src/shims-vue.d.ts +10 -10
  111. package/src/stories/Accordion.stories.ts +650 -650
  112. package/src/stories/Audio.stories.ts +28 -28
  113. package/src/stories/Button.stories.ts +263 -263
  114. package/src/stories/CheckBox.stories.ts +348 -348
  115. package/src/stories/DateInput.stories.ts +53 -53
  116. package/src/stories/Dialog.stories.ts +147 -147
  117. package/src/stories/EditField.stories.ts +78 -78
  118. package/src/stories/IconBullet/IconBullet.stories.ts +201 -201
  119. package/src/stories/IconBullet/IconBulletList.stories.ts +275 -275
  120. package/src/stories/Input.stories.ts +351 -351
  121. package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -260
  122. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -176
  123. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -119
  124. package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -320
  125. package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -335
  126. package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -82
  127. package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -198
  128. package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -204
  129. package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -144
  130. package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -186
  131. package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -111
  132. package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -48
  133. package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -261
  134. package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -234
  135. package/src/stories/Laboratory/TagLabel.stories.ts +418 -418
  136. package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -234
  137. package/src/stories/Laboratory/Timeline.stories.ts +403 -403
  138. package/src/stories/NotificationBubble.stories.ts +194 -194
  139. package/src/stories/OtpInput.stories.ts +100 -100
  140. package/src/stories/PhoneInput.stories.ts +52 -52
  141. package/src/stories/Select.stories.ts +419 -419
  142. package/src/stories/TextArea.stories.ts +112 -112
  143. package/src/stories/TickBox.stories.ts +294 -294
  144. package/src/stories/v-icon.stories.ts +91 -91
  145. package/src/vite-env.d.ts +1 -1
  146. package/tests/e2e/README.md +220 -220
  147. package/tests/e2e/accessibility.spec.ts +638 -638
  148. package/tests/e2e/accordion.spec.ts +42 -42
  149. package/tests/e2e/additional-components.spec.ts +437 -437
  150. package/tests/e2e/all-components.spec.ts +135 -135
  151. package/tests/e2e/appointment-card.spec.ts +816 -816
  152. package/tests/e2e/button-fixed.spec.ts +58 -58
  153. package/tests/e2e/button.spec.ts +76 -76
  154. package/tests/e2e/checkbox.spec.ts +50 -50
  155. package/tests/e2e/date-input.spec.ts +46 -46
  156. package/tests/e2e/debug.spec.ts +51 -51
  157. package/tests/e2e/dialog.spec.ts +58 -58
  158. package/tests/e2e/input.spec.ts +55 -55
  159. package/tests/e2e/laboratory-components.spec.ts +320 -320
  160. package/tests/e2e/otp-input.spec.ts +50 -50
  161. package/tests/e2e/select.spec.ts +52 -52
  162. package/tests/e2e/storybook-utils.ts +59 -59
  163. package/tests/e2e/test-basic.spec.ts +33 -33
  164. package/tests/e2e/visual-regression.spec.ts +350 -350
  165. package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
  166. package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
  167. package/tests/unit/components/Appointment/Card/Actions.spec.ts +407 -407
  168. package/tests/unit/components/Appointment/Card/Card.spec.ts +485 -485
  169. package/tests/unit/components/Appointment/Card/Details.spec.ts +397 -397
  170. package/tests/unit/components/Audio/Audio.spec.ts +403 -403
  171. package/tests/unit/components/Audio/Waveform.spec.ts +483 -483
  172. package/tests/unit/components/Core/Button.spec.ts +336 -336
  173. package/tests/unit/components/Core/Checkbox.spec.ts +544 -544
  174. package/tests/unit/components/Core/DateInput.spec.ts +690 -690
  175. package/tests/unit/components/Core/Dialog.spec.ts +485 -485
  176. package/tests/unit/components/Core/EditField.spec.ts +782 -782
  177. package/tests/unit/components/Core/Input.spec.ts +512 -512
  178. package/tests/unit/components/Core/Modal.spec.ts +518 -518
  179. package/tests/unit/components/Core/NotificationBubble.spec.ts +606 -606
  180. package/tests/unit/components/Core/OtpInput.spec.ts +708 -708
  181. package/tests/unit/components/Core/PhoneInput.spec.ts +619 -619
  182. package/tests/unit/components/Core/Select.spec.ts +712 -712
  183. package/tests/unit/components/Core/TextArea.spec.ts +565 -565
  184. package/tests/unit/components/Core/TickBox.spec.ts +779 -779
  185. package/tests/unit/components/IconBullet/IconBullet.spec.ts +356 -356
  186. package/tests/unit/components/IconBullet/IconBulletList.spec.ts +371 -371
  187. package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +108 -108
  188. package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +149 -149
  189. package/tests/unit/components/Icons/Audio/Delete.spec.ts +158 -158
  190. package/tests/unit/components/Icons/Audio/Pause.spec.ts +208 -208
  191. package/tests/unit/components/Icons/Audio/Play.spec.ts +217 -217
  192. package/tests/unit/components/Icons/CalendarNotification.spec.ts +186 -186
  193. package/tests/unit/components/Icons/Chair.spec.ts +234 -234
  194. package/tests/unit/components/Icons/ChairNotification.spec.ts +311 -311
  195. package/tests/unit/components/Icons/Circle.spec.ts +255 -255
  196. package/tests/unit/components/Icons/FavIcon.spec.ts +251 -251
  197. package/tests/unit/components/Icons/FilledCircle.spec.ts +274 -274
  198. package/tests/unit/components/Icons/Group3.spec.ts +355 -355
  199. package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
  200. package/tests/unit/components/Icons/calendar.spec.ts +286 -286
  201. package/tests/unit/components/Icons/checkbox.spec.ts +315 -315
  202. package/tests/unit/components/Icons/outlineChecked.spec.ts +434 -434
  203. package/tests/unit/components/Icons/play.spec.ts +308 -308
  204. package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +167 -167
  205. package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +179 -179
  206. package/tests/unit/components/Laboratory/ChatMessage.spec.ts +263 -263
  207. package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +282 -282
  208. package/tests/unit/components/Laboratory/ChatNotification.spec.ts +256 -256
  209. package/tests/unit/components/Laboratory/DocumentCard.spec.ts +228 -228
  210. package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +236 -236
  211. package/tests/unit/components/Laboratory/InfoCard.spec.ts +308 -308
  212. package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +251 -251
  213. package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +290 -290
  214. package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +275 -275
  215. package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +288 -288
  216. package/tests/unit/components/Laboratory/StatusNotification.spec.ts +296 -296
  217. package/tests/unit/components/Laboratory/TagLabel.spec.ts +353 -353
  218. package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +377 -377
  219. package/tests/unit/components/Laboratory/TicketCard.spec.ts +351 -351
  220. package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +381 -381
  221. package/tests/unit/components/Laboratory/Timeline.spec.ts +419 -419
  222. package/tests/unit/constants/iconEnums.spec.ts +39 -39
  223. package/tests/unit/i18n/i18n.spec.ts +88 -88
  224. package/tests/unit/plugins/vuetify.spec.ts +220 -220
  225. package/tests/unit/setup.ts +189 -189
  226. package/tests/unit/src/components/index.spec.ts.skip +192 -192
  227. package/tests/unit/src/index.spec.ts.skip +182 -182
  228. package/tests/unit/src/main.spec.ts +151 -151
  229. package/tsconfig.json +26 -26
  230. package/vite.config.ts +29 -29
  231. package/vitest.config.ts +83 -83
@@ -1,190 +1,190 @@
1
- import { config } from '@vue/test-utils';
2
- import { vi } from 'vitest';
3
-
4
- // Mock specific problematic CSS imports
5
- vi.mock('vuetify/lib/components/VCode/VCode.css', () => ({}));
6
- vi.mock('vuetify/styles', () => ({}));
7
- vi.mock('vuetify/lib/styles', () => ({}));
8
-
9
- // Mock Vuetify
10
- vi.mock('vuetify', () => ({
11
- createVuetify: () => ({
12
- install: () => {},
13
- }),
14
- }));
15
-
16
- // Global test configuration
17
- config.global.stubs = {
18
- // Stub Vuetify components that are commonly used
19
- 'v-btn': {
20
- template: '<button class="v-btn" :disabled="disabled" :readonly="readonly" @click="handleClick" data-testid="root" v-bind="$attrs"><span v-if="prependIcon" class="prepend-icon"></span><slot /><span v-if="appendIcon" class="append-icon"></span></button>',
21
- props: ['disabled', 'loading', 'variant', 'color', 'size', 'density', 'rounded', 'elevation', 'flat', 'readonly', 'prependIcon', 'appendIcon'],
22
- emits: ['click'],
23
- inheritAttrs: false,
24
- methods: {
25
- handleClick(event) {
26
- if (!this.disabled) {
27
- this.$emit('click', event);
28
- }
29
- }
30
- }
31
- },
32
- 'v-text-field': {
33
- template: '<div data-testid="root" class="v-text-field" :class="classes"><input :id="id" :type="type || \'text\'" :value="modelValue" @input="$emit(\'update:modelValue\', $event.target.value)" /><slot name="prepend"></slot><slot name="prepend-inner"></slot><slot name="append"></slot><slot name="append-inner"></slot><slot name="details"></slot></div>',
34
- props: ['modelValue', 'disabled', 'error', 'label', 'placeholder', 'variant', 'density', 'hideDetails', 'persistentHint', 'prependIcon', 'prependInnerIcon', 'appendIcon', 'appendInnerIcon', 'success', 'warning', 'borderOnHover', 'class', 'type', 'id'],
35
- emits: ['update:modelValue', 'click:prepend', 'click:prepend-inner', 'click:append', 'click:append-inner'],
36
- computed: {
37
- classes() {
38
- return this.$props.class || '';
39
- }
40
- }
41
- },
42
- 'v-icon': {
43
- template: '<i class="v-icon" data-testid="v-icon" :icon="icon" :size="size" :color="color" v-bind="$attrs"></i>',
44
- props: ['icon', 'color', 'size'],
45
- inheritAttrs: false
46
- },
47
- 'v-card': {
48
- template: '<div class="v-card" data-testid="v-card" :elevation="elevation" :rounded="rounded" :color="color" :variant="variant" :style="style"><div class="v-card-item"><slot name="title" /></div><div class="v-card-text"><slot name="text" /></div><slot /></div>',
49
- props: ['elevation', 'rounded', 'color', 'variant', 'style'],
50
- },
51
- 'v-dialog': {
52
- template: '<div data-testid="v-dialog" class="v-dialog"><slot /></div>',
53
- props: ['modelValue', 'width'],
54
- },
55
- 'v-checkbox': {
56
- template: '<div data-testid="root" class="v-checkbox tick-box" :class="$props.class"><input type="checkbox" /><slot name="label"></slot></div>',
57
- props: ['modelValue', 'disabled', 'label', 'value', 'density', 'color', 'baseColor', 'trueIcon', 'falseIcon', 'class'],
58
- },
59
- 'v-select': {
60
- template: '<select data-testid="v-select"></select>',
61
- props: ['modelValue', 'items', 'disabled'],
62
- },
63
- 'v-combobox': {
64
- template: '<div data-testid="root" class="v-combobox"><input /><select><option v-for="item in items" :key="item.value" :value="item.value">{{ item.title }}</option></select><slot name="menu"></slot><slot name="prepend"></slot><slot name="prepend-inner"></slot><slot name="append"></slot><slot name="append-inner"></slot></div>',
65
- props: ['modelValue', 'items', 'disabled', 'multiple', 'chips', 'clearable', 'variant', 'density', 'label', 'appendIcon', 'appendInnerIcon', 'prependIcon', 'prependInnerIcon', 'menuIcon', 'clearIcon', 'closableChips', 'hideDetails', 'error', 'itemTitle', 'itemValue', 'returnObject'],
66
- emits: ['update:modelValue', 'click:append', 'click:appendInner', 'click:clear', 'click:prepend', 'click:prependInner', 'update:search']
67
- },
68
- 'v-textarea': {
69
- template: '<textarea data-testid="root" class="text-area v-textarea"></textarea>',
70
- props: ['modelValue', 'disabled', 'clearable', 'clearIcon', 'label', 'prependIcon', 'prependInnerIcon', 'appendIcon', 'appendInnerIcon', 'baseColor', 'bgColor', 'variant', 'color', 'rounded'],
71
- emits: ['update:modelValue', 'click:append', 'click:appendInner', 'click:clear', 'click:control', 'click:prepend', 'click:prependInner']
72
- },
73
- 'v-expansion-panels': {
74
- template: '<div data-testid="root" class="wl-accordion"><slot /></div>',
75
- props: ['modelValue', 'multiple', 'variant', 'rounded', 'expandIcon', 'collapseIcon'],
76
- emits: ['update:modelValue'],
77
- },
78
- 'v-expansion-panel': {
79
- template: '<div data-testid="root"><slot /></div>',
80
- props: ['value', 'bgColor'],
81
- },
82
- 'v-expansion-panel-title': {
83
- template: '<div data-testid="v-expansion-panel-title"><slot /></div>',
84
- },
85
- 'v-expansion-panel-text': {
86
- template: '<div data-testid="v-expansion-panel-text"><slot /></div>',
87
- },
88
- 'v-alert': {
89
- template: '<div class="v-alert" data-testid="v-alert" :color="color" :rounded="rounded"><div class="v-alert__content"><slot name="title" /><slot name="text" /></div><slot /></div>',
90
- props: ['type', 'color', 'rounded'],
91
- },
92
- 'v-progress-circular': {
93
- template: '<div data-testid="v-progress-circular"></div>',
94
- props: ['value', 'size'],
95
- },
96
- 'v-timeline': {
97
- template: '<div class="v-timeline" data-testid="v-timeline" data-testid="root"><slot /></div>',
98
- props: ['density', 'align']
99
- },
100
- 'v-timeline-item': {
101
- template: '<div class="v-timeline-item" data-testid="v-timeline-item"><template #icon><slot name="icon" /></template><slot /></div>',
102
- props: ['size']
103
- },
104
- 'v-list': {
105
- template: '<div data-testid="v-list"><slot /></div>',
106
- },
107
- 'v-list-item': {
108
- template: '<div data-testid="v-list-item"><slot /></div>',
109
- },
110
- 'v-hover': {
111
- template: '<div data-testid="v-hover"><slot /></div>',
112
- },
113
- 'v-sheet': {
114
- template: '<div class="v-sheet" data-testid="v-sheet" :style="style" :elevation="elevation" :border="border" :rounded="rounded" v-bind="$attrs"><slot /></div>',
115
- props: ['border', 'rounded', 'elevation', 'style'],
116
- inheritAttrs: false
117
- },
118
- 'v-divider': {
119
- template: '<hr class="v-divider" data-testid="v-divider" v-bind="$attrs" />',
120
- props: ['vertical', 'thickness'],
121
- inheritAttrs: false
122
- },
123
- 'v-fab': {
124
- template: '<button class="v-fab" data-testid="v-fab"><slot /></button>',
125
- props: ['baseColor', 'color', 'readonly', 'icon', 'size']
126
- },
127
- 'v-badge': {
128
- template: '<div class="v-badge" data-testid="v-badge"><slot /><template #badge><slot name="badge" /></template></div>',
129
- props: ['color']
130
- },
131
- 'v-img': {
132
- template: '<img class="v-img" data-testid="v-img" :src="src" :aspect-ratio="aspectRatio" :rounded="rounded" :cover="cover" />',
133
- props: ['src', 'aspectRatio', 'rounded', 'cover']
134
- },
135
- 'v-card-actions': {
136
- template: '<div class="v-card-actions" data-testid="v-card-actions"><slot /></div>',
137
- },
138
- 'v-progress-linear': {
139
- template: '<div class="v-progress-linear custom-progress-linear" data-testid="v-progress-linear" v-bind="$attrs"></div>',
140
- props: ['modelValue', 'height', 'color', 'bgColor', 'bgOpacity'],
141
- inheritAttrs: false
142
- },
143
- 'teleport': {
144
- template: '<div data-testid="teleport"><slot /></div>',
145
- props: ['to']
146
- },
147
- 'VPhoneInput': {
148
- template: '<div data-testid="root" class="wl-phone-input"><input /></div>',
149
- props: ['modelValue', 'placeholder', 'label', 'variant', 'density', 'countryLabel', 'countryAriaLabel', 'phoneAriaLabel', 'preferredCountries', 'ignoredCountries', 'includedCountries', 'includeCountries', 'ariaLabel', 'appendInnerIcon', 'placeHolder', 'displayFormat', 'defaultCountry', 'hideDetails', 'ariaInvalid', 'countryIconMode', 'id', 'class'],
150
- emits: ['update:modelValue', 'update:phone']
151
- },
152
- 'v-otp-input': {
153
- template: '<div data-testid="v-otp-input"></div>',
154
- props: ['modelValue', 'autofocus', 'rounded', 'loading', 'error', 'focus-all', 'focused', 'type'],
155
- emits: ['update:modelValue']
156
- },
157
- 'i18n-t': {
158
- template: '<p data-testid="i18n-t"><slot></slot><slot name="phoneNumber"></slot></p>',
159
- props: ['keypath', 'tag'],
160
- },
161
- };
162
-
163
- // Mock window.matchMedia
164
- Object.defineProperty(window, 'matchMedia', {
165
- writable: true,
166
- value: vi.fn().mockImplementation(query => ({
167
- matches: false,
168
- media: query,
169
- onchange: null,
170
- addListener: vi.fn(),
171
- removeListener: vi.fn(),
172
- addEventListener: vi.fn(),
173
- removeEventListener: vi.fn(),
174
- dispatchEvent: vi.fn(),
175
- })),
176
- });
177
-
178
- // Mock IntersectionObserver
179
- global.IntersectionObserver = vi.fn().mockImplementation(() => ({
180
- observe: vi.fn(),
181
- unobserve: vi.fn(),
182
- disconnect: vi.fn(),
183
- }));
184
-
185
- // Mock ResizeObserver
186
- global.ResizeObserver = vi.fn().mockImplementation(() => ({
187
- observe: vi.fn(),
188
- unobserve: vi.fn(),
189
- disconnect: vi.fn(),
1
+ import { config } from '@vue/test-utils';
2
+ import { vi } from 'vitest';
3
+
4
+ // Mock specific problematic CSS imports
5
+ vi.mock('vuetify/lib/components/VCode/VCode.css', () => ({}));
6
+ vi.mock('vuetify/styles', () => ({}));
7
+ vi.mock('vuetify/lib/styles', () => ({}));
8
+
9
+ // Mock Vuetify
10
+ vi.mock('vuetify', () => ({
11
+ createVuetify: () => ({
12
+ install: () => {},
13
+ }),
14
+ }));
15
+
16
+ // Global test configuration
17
+ config.global.stubs = {
18
+ // Stub Vuetify components that are commonly used
19
+ 'v-btn': {
20
+ template: '<button class="v-btn" :disabled="disabled" :readonly="readonly" @click="handleClick" data-testid="root" v-bind="$attrs"><span v-if="prependIcon" class="prepend-icon"></span><slot /><span v-if="appendIcon" class="append-icon"></span></button>',
21
+ props: ['disabled', 'loading', 'variant', 'color', 'size', 'density', 'rounded', 'elevation', 'flat', 'readonly', 'prependIcon', 'appendIcon'],
22
+ emits: ['click'],
23
+ inheritAttrs: false,
24
+ methods: {
25
+ handleClick(event) {
26
+ if (!this.disabled) {
27
+ this.$emit('click', event);
28
+ }
29
+ }
30
+ }
31
+ },
32
+ 'v-text-field': {
33
+ template: '<div data-testid="root" class="v-text-field" :class="classes"><input :id="id" :type="type || \'text\'" :value="modelValue" @input="$emit(\'update:modelValue\', $event.target.value)" /><slot name="prepend"></slot><slot name="prepend-inner"></slot><slot name="append"></slot><slot name="append-inner"></slot><slot name="details"></slot></div>',
34
+ props: ['modelValue', 'disabled', 'error', 'label', 'placeholder', 'variant', 'density', 'hideDetails', 'persistentHint', 'prependIcon', 'prependInnerIcon', 'appendIcon', 'appendInnerIcon', 'success', 'warning', 'borderOnHover', 'class', 'type', 'id'],
35
+ emits: ['update:modelValue', 'click:prepend', 'click:prepend-inner', 'click:append', 'click:append-inner'],
36
+ computed: {
37
+ classes() {
38
+ return this.$props.class || '';
39
+ }
40
+ }
41
+ },
42
+ 'v-icon': {
43
+ template: '<i class="v-icon" data-testid="v-icon" :icon="icon" :size="size" :color="color" v-bind="$attrs"></i>',
44
+ props: ['icon', 'color', 'size'],
45
+ inheritAttrs: false
46
+ },
47
+ 'v-card': {
48
+ template: '<div class="v-card" data-testid="v-card" :elevation="elevation" :rounded="rounded" :color="color" :variant="variant" :style="style"><div class="v-card-item"><slot name="title" /></div><div class="v-card-text"><slot name="text" /></div><slot /></div>',
49
+ props: ['elevation', 'rounded', 'color', 'variant', 'style'],
50
+ },
51
+ 'v-dialog': {
52
+ template: '<div data-testid="v-dialog" class="v-dialog"><slot /></div>',
53
+ props: ['modelValue', 'width'],
54
+ },
55
+ 'v-checkbox': {
56
+ template: '<div data-testid="root" class="v-checkbox tick-box" :class="$props.class"><input type="checkbox" /><slot name="label"></slot></div>',
57
+ props: ['modelValue', 'disabled', 'label', 'value', 'density', 'color', 'baseColor', 'trueIcon', 'falseIcon', 'class'],
58
+ },
59
+ 'v-select': {
60
+ template: '<select data-testid="v-select"></select>',
61
+ props: ['modelValue', 'items', 'disabled'],
62
+ },
63
+ 'v-combobox': {
64
+ template: '<div data-testid="root" class="v-combobox"><input /><select><option v-for="item in items" :key="item.value" :value="item.value">{{ item.title }}</option></select><slot name="menu"></slot><slot name="prepend"></slot><slot name="prepend-inner"></slot><slot name="append"></slot><slot name="append-inner"></slot></div>',
65
+ props: ['modelValue', 'items', 'disabled', 'multiple', 'chips', 'clearable', 'variant', 'density', 'label', 'appendIcon', 'appendInnerIcon', 'prependIcon', 'prependInnerIcon', 'menuIcon', 'clearIcon', 'closableChips', 'hideDetails', 'error', 'itemTitle', 'itemValue', 'returnObject'],
66
+ emits: ['update:modelValue', 'click:append', 'click:appendInner', 'click:clear', 'click:prepend', 'click:prependInner', 'update:search']
67
+ },
68
+ 'v-textarea': {
69
+ template: '<textarea data-testid="root" class="text-area v-textarea"></textarea>',
70
+ props: ['modelValue', 'disabled', 'clearable', 'clearIcon', 'label', 'prependIcon', 'prependInnerIcon', 'appendIcon', 'appendInnerIcon', 'baseColor', 'bgColor', 'variant', 'color', 'rounded'],
71
+ emits: ['update:modelValue', 'click:append', 'click:appendInner', 'click:clear', 'click:control', 'click:prepend', 'click:prependInner']
72
+ },
73
+ 'v-expansion-panels': {
74
+ template: '<div data-testid="root" class="wl-accordion"><slot /></div>',
75
+ props: ['modelValue', 'multiple', 'variant', 'rounded', 'expandIcon', 'collapseIcon'],
76
+ emits: ['update:modelValue'],
77
+ },
78
+ 'v-expansion-panel': {
79
+ template: '<div data-testid="root"><slot /></div>',
80
+ props: ['value', 'bgColor'],
81
+ },
82
+ 'v-expansion-panel-title': {
83
+ template: '<div data-testid="v-expansion-panel-title"><slot /></div>',
84
+ },
85
+ 'v-expansion-panel-text': {
86
+ template: '<div data-testid="v-expansion-panel-text"><slot /></div>',
87
+ },
88
+ 'v-alert': {
89
+ template: '<div class="v-alert" data-testid="v-alert" :color="color" :rounded="rounded"><div class="v-alert__content"><slot name="title" /><slot name="text" /></div><slot /></div>',
90
+ props: ['type', 'color', 'rounded'],
91
+ },
92
+ 'v-progress-circular': {
93
+ template: '<div data-testid="v-progress-circular"></div>',
94
+ props: ['value', 'size'],
95
+ },
96
+ 'v-timeline': {
97
+ template: '<div class="v-timeline" data-testid="v-timeline" data-testid="root"><slot /></div>',
98
+ props: ['density', 'align']
99
+ },
100
+ 'v-timeline-item': {
101
+ template: '<div class="v-timeline-item" data-testid="v-timeline-item"><template #icon><slot name="icon" /></template><slot /></div>',
102
+ props: ['size']
103
+ },
104
+ 'v-list': {
105
+ template: '<div data-testid="v-list"><slot /></div>',
106
+ },
107
+ 'v-list-item': {
108
+ template: '<div data-testid="v-list-item"><slot /></div>',
109
+ },
110
+ 'v-hover': {
111
+ template: '<div data-testid="v-hover"><slot /></div>',
112
+ },
113
+ 'v-sheet': {
114
+ template: '<div class="v-sheet" data-testid="v-sheet" :style="style" :elevation="elevation" :border="border" :rounded="rounded" v-bind="$attrs"><slot /></div>',
115
+ props: ['border', 'rounded', 'elevation', 'style'],
116
+ inheritAttrs: false
117
+ },
118
+ 'v-divider': {
119
+ template: '<hr class="v-divider" data-testid="v-divider" v-bind="$attrs" />',
120
+ props: ['vertical', 'thickness'],
121
+ inheritAttrs: false
122
+ },
123
+ 'v-fab': {
124
+ template: '<button class="v-fab" data-testid="v-fab"><slot /></button>',
125
+ props: ['baseColor', 'color', 'readonly', 'icon', 'size']
126
+ },
127
+ 'v-badge': {
128
+ template: '<div class="v-badge" data-testid="v-badge"><slot /><template #badge><slot name="badge" /></template></div>',
129
+ props: ['color']
130
+ },
131
+ 'v-img': {
132
+ template: '<img class="v-img" data-testid="v-img" :src="src" :aspect-ratio="aspectRatio" :rounded="rounded" :cover="cover" />',
133
+ props: ['src', 'aspectRatio', 'rounded', 'cover']
134
+ },
135
+ 'v-card-actions': {
136
+ template: '<div class="v-card-actions" data-testid="v-card-actions"><slot /></div>',
137
+ },
138
+ 'v-progress-linear': {
139
+ template: '<div class="v-progress-linear custom-progress-linear" data-testid="v-progress-linear" v-bind="$attrs"></div>',
140
+ props: ['modelValue', 'height', 'color', 'bgColor', 'bgOpacity'],
141
+ inheritAttrs: false
142
+ },
143
+ 'teleport': {
144
+ template: '<div data-testid="teleport"><slot /></div>',
145
+ props: ['to']
146
+ },
147
+ 'VPhoneInput': {
148
+ template: '<div data-testid="root" class="wl-phone-input"><input /></div>',
149
+ props: ['modelValue', 'placeholder', 'label', 'variant', 'density', 'countryLabel', 'countryAriaLabel', 'phoneAriaLabel', 'preferredCountries', 'ignoredCountries', 'includedCountries', 'includeCountries', 'ariaLabel', 'appendInnerIcon', 'placeHolder', 'displayFormat', 'defaultCountry', 'hideDetails', 'ariaInvalid', 'countryIconMode', 'id', 'class'],
150
+ emits: ['update:modelValue', 'update:phone']
151
+ },
152
+ 'v-otp-input': {
153
+ template: '<div data-testid="v-otp-input"></div>',
154
+ props: ['modelValue', 'autofocus', 'rounded', 'loading', 'error', 'focus-all', 'focused', 'type'],
155
+ emits: ['update:modelValue']
156
+ },
157
+ 'i18n-t': {
158
+ template: '<p data-testid="i18n-t"><slot></slot><slot name="phoneNumber"></slot></p>',
159
+ props: ['keypath', 'tag'],
160
+ },
161
+ };
162
+
163
+ // Mock window.matchMedia
164
+ Object.defineProperty(window, 'matchMedia', {
165
+ writable: true,
166
+ value: vi.fn().mockImplementation(query => ({
167
+ matches: false,
168
+ media: query,
169
+ onchange: null,
170
+ addListener: vi.fn(),
171
+ removeListener: vi.fn(),
172
+ addEventListener: vi.fn(),
173
+ removeEventListener: vi.fn(),
174
+ dispatchEvent: vi.fn(),
175
+ })),
176
+ });
177
+
178
+ // Mock IntersectionObserver
179
+ global.IntersectionObserver = vi.fn().mockImplementation(() => ({
180
+ observe: vi.fn(),
181
+ unobserve: vi.fn(),
182
+ disconnect: vi.fn(),
183
+ }));
184
+
185
+ // Mock ResizeObserver
186
+ global.ResizeObserver = vi.fn().mockImplementation(() => ({
187
+ observe: vi.fn(),
188
+ unobserve: vi.fn(),
189
+ disconnect: vi.fn(),
190
190
  }));