@zap-wunschlachen/wl-shared-components 1.0.0

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 (254) hide show
  1. package/.github/workflows/playwright.yml +215 -0
  2. package/.github/workflows/static.yml +62 -0
  3. package/.prettierrc +5 -0
  4. package/.storybook/main.ts +18 -0
  5. package/.storybook/preview.ts +37 -0
  6. package/.storybook/storyWrapper.vue +18 -0
  7. package/.storybook/withVuetifyTheme.decorator.ts +21 -0
  8. package/App.vue +95 -0
  9. package/README.md +56 -0
  10. package/heroicons.ts +75 -0
  11. package/index.html +19 -0
  12. package/package.json +66 -0
  13. package/playwright.config.ts +35 -0
  14. package/public/audio/dummy_pink_noise.wav +0 -0
  15. package/public/background.svg +60 -0
  16. package/public/javascript.svg +1 -0
  17. package/public/style.css +187 -0
  18. package/public/technologies.svg +22 -0
  19. package/src/assets/css/base.css +235 -0
  20. package/src/assets/css/variables.css +96 -0
  21. package/src/assets/fonts/Outfit-Black.ttf +0 -0
  22. package/src/assets/fonts/Outfit-Bold.ttf +0 -0
  23. package/src/assets/fonts/Outfit-ExtraBold.ttf +0 -0
  24. package/src/assets/fonts/Outfit-ExtraLight.ttf +0 -0
  25. package/src/assets/fonts/Outfit-Light.ttf +0 -0
  26. package/src/assets/fonts/Outfit-Medium.ttf +0 -0
  27. package/src/assets/fonts/Outfit-Regular.ttf +0 -0
  28. package/src/assets/fonts/Outfit-SemiBold.ttf +0 -0
  29. package/src/assets/fonts/Outfit-Thin.ttf +0 -0
  30. package/src/components/Accordion/Accordion.css +59 -0
  31. package/src/components/Accordion/AccordionGroup.vue +51 -0
  32. package/src/components/Accordion/AccordionItem.vue +66 -0
  33. package/src/components/Appointment/Card/Actions.css +30 -0
  34. package/src/components/Appointment/Card/Actions.vue +66 -0
  35. package/src/components/Appointment/Card/Card.css +49 -0
  36. package/src/components/Appointment/Card/Card.vue +55 -0
  37. package/src/components/Appointment/Card/Details.css +51 -0
  38. package/src/components/Appointment/Card/Details.vue +44 -0
  39. package/src/components/Audio/Audio.vue +188 -0
  40. package/src/components/Audio/Waveform.vue +118 -0
  41. package/src/components/Button/Button.vue +119 -0
  42. package/src/components/CheckBox/CheckBox.css +185 -0
  43. package/src/components/CheckBox/Checkbox.vue +130 -0
  44. package/src/components/DateInput/DateInput.css +3 -0
  45. package/src/components/DateInput/DateInput.vue +263 -0
  46. package/src/components/Dialog/Dialog.css +6 -0
  47. package/src/components/Dialog/Dialog.vue +29 -0
  48. package/src/components/EditField/EditField.css +20 -0
  49. package/src/components/EditField/EditField.vue +202 -0
  50. package/src/components/IconBullet/IconBullet.vue +86 -0
  51. package/src/components/IconBullet/IconBulletList.vue +41 -0
  52. package/src/components/Icons/Audio/CloudFailed.vue +21 -0
  53. package/src/components/Icons/Audio/CloudSaved.vue +22 -0
  54. package/src/components/Icons/Audio/Delete.vue +16 -0
  55. package/src/components/Icons/Audio/Pause.vue +19 -0
  56. package/src/components/Icons/Audio/Play.vue +16 -0
  57. package/src/components/Icons/CalendarNotification.vue +126 -0
  58. package/src/components/Icons/Chair.vue +32 -0
  59. package/src/components/Icons/ChairNotification.vue +35 -0
  60. package/src/components/Icons/Circle.vue +66 -0
  61. package/src/components/Icons/FavIcon.vue +22 -0
  62. package/src/components/Icons/FilledCircle.vue +11 -0
  63. package/src/components/Icons/Group3.vue +46 -0
  64. package/src/components/Icons/RingNotification.vue +54 -0
  65. package/src/components/Icons/SolidArrowRight.vue +14 -0
  66. package/src/components/Icons/calendar.vue +17 -0
  67. package/src/components/Icons/checkbox.vue +19 -0
  68. package/src/components/Icons/outlineChecked.vue +27 -0
  69. package/src/components/Icons/play.vue +6 -0
  70. package/src/components/Input/Input.css +187 -0
  71. package/src/components/Input/Input.vue +247 -0
  72. package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -0
  73. package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -0
  74. package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -0
  75. package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -0
  76. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -0
  77. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -0
  78. package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -0
  79. package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -0
  80. package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -0
  81. package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -0
  82. package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -0
  83. package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -0
  84. package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -0
  85. package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -0
  86. package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -0
  87. package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -0
  88. package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -0
  89. package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -0
  90. package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -0
  91. package/src/components/Laboratory/TicketCard/TicketCard.css +3 -0
  92. package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -0
  93. package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -0
  94. package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -0
  95. package/src/components/Laboratory/TimeLine/Timeline.css +4 -0
  96. package/src/components/Laboratory/TimeLine/Timeline.vue +30 -0
  97. package/src/components/Modal/Modal.css +6 -0
  98. package/src/components/Modal/Modal.vue +23 -0
  99. package/src/components/NotificationBubble/NotificationBubble.css +4 -0
  100. package/src/components/NotificationBubble/NotificationBubble.vue +90 -0
  101. package/src/components/OtpInput/OtpInput.css +39 -0
  102. package/src/components/OtpInput/OtpInput.vue +144 -0
  103. package/src/components/PhoneInput/PhoneInput.css +32 -0
  104. package/src/components/PhoneInput/PhoneInput.vue +114 -0
  105. package/src/components/Select/Select.css +150 -0
  106. package/src/components/Select/Select.vue +304 -0
  107. package/src/components/TextArea/TextArea.css +3 -0
  108. package/src/components/TextArea/TextArea.vue +126 -0
  109. package/src/components/TickBox/TickBox.css +49 -0
  110. package/src/components/TickBox/TickBox.vue +126 -0
  111. package/src/components/index.ts +20 -0
  112. package/src/constants/buttonEnums.ts +0 -0
  113. package/src/constants/iconEnums.ts +4 -0
  114. package/src/i18n/i18n.ts +16 -0
  115. package/src/i18n/locales/de.json +19 -0
  116. package/src/i18n/locales/en.json +19 -0
  117. package/src/index.ts +31 -0
  118. package/src/main.ts +11 -0
  119. package/src/plugins/vuetify.ts +131 -0
  120. package/src/shims-vue.d.ts +10 -0
  121. package/src/stories/Accordion.stories.ts +650 -0
  122. package/src/stories/Audio.stories.ts +29 -0
  123. package/src/stories/Button.stories.ts +263 -0
  124. package/src/stories/CheckBox.stories.ts +348 -0
  125. package/src/stories/DateInput.stories.ts +54 -0
  126. package/src/stories/Dialog.stories.ts +147 -0
  127. package/src/stories/EditField.stories.ts +79 -0
  128. package/src/stories/IconBullet/IconBullet.stories.ts +201 -0
  129. package/src/stories/IconBullet/IconBulletList.stories.ts +275 -0
  130. package/src/stories/Input.stories.ts +351 -0
  131. package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -0
  132. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -0
  133. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -0
  134. package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -0
  135. package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -0
  136. package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -0
  137. package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -0
  138. package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -0
  139. package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -0
  140. package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -0
  141. package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -0
  142. package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -0
  143. package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -0
  144. package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -0
  145. package/src/stories/Laboratory/TagLabel.stories.ts +418 -0
  146. package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -0
  147. package/src/stories/Laboratory/Timeline.stories.ts +403 -0
  148. package/src/stories/NotificationBubble.stories.ts +194 -0
  149. package/src/stories/OtpInput.stories.ts +101 -0
  150. package/src/stories/PhoneInput.stories.ts +53 -0
  151. package/src/stories/Select.stories.ts +419 -0
  152. package/src/stories/TextArea.stories.ts +112 -0
  153. package/src/stories/TickBox.stories.ts +294 -0
  154. package/src/stories/assets/accessibility.png +0 -0
  155. package/src/stories/assets/accessibility.svg +1 -0
  156. package/src/stories/assets/addon-library.png +0 -0
  157. package/src/stories/assets/assets.png +0 -0
  158. package/src/stories/assets/avif-test-image.avif +0 -0
  159. package/src/stories/assets/context.png +0 -0
  160. package/src/stories/assets/discord.svg +1 -0
  161. package/src/stories/assets/docs.png +0 -0
  162. package/src/stories/assets/figma-plugin.png +0 -0
  163. package/src/stories/assets/github.svg +1 -0
  164. package/src/stories/assets/share.png +0 -0
  165. package/src/stories/assets/styling.png +0 -0
  166. package/src/stories/assets/testing.png +0 -0
  167. package/src/stories/assets/theming.png +0 -0
  168. package/src/stories/assets/tutorials.svg +1 -0
  169. package/src/stories/assets/youtube.svg +1 -0
  170. package/src/stories/v-icon.stories.ts +91 -0
  171. package/src/types/index.ts +21 -0
  172. package/src/vite-env.d.ts +1 -0
  173. package/tests/e2e/README.md +221 -0
  174. package/tests/e2e/accessibility.spec.ts +639 -0
  175. package/tests/e2e/accordion.spec.ts +42 -0
  176. package/tests/e2e/additional-components.spec.ts +438 -0
  177. package/tests/e2e/all-components.spec.ts +135 -0
  178. package/tests/e2e/button-fixed.spec.ts +59 -0
  179. package/tests/e2e/button.spec.ts +76 -0
  180. package/tests/e2e/checkbox.spec.ts +50 -0
  181. package/tests/e2e/date-input.spec.ts +46 -0
  182. package/tests/e2e/debug.spec.ts +52 -0
  183. package/tests/e2e/dialog.spec.ts +58 -0
  184. package/tests/e2e/input.spec.ts +55 -0
  185. package/tests/e2e/laboratory-components.spec.ts +321 -0
  186. package/tests/e2e/otp-input.spec.ts +50 -0
  187. package/tests/e2e/select.spec.ts +52 -0
  188. package/tests/e2e/storybook-utils.ts +59 -0
  189. package/tests/e2e/test-basic.spec.ts +34 -0
  190. package/tests/e2e/visual-regression.spec.ts +351 -0
  191. package/tests/unit/components/Accordion/AccordionGroup.spec.ts +343 -0
  192. package/tests/unit/components/Accordion/AccordionItem.spec.ts +384 -0
  193. package/tests/unit/components/Audio/Audio.spec.ts +404 -0
  194. package/tests/unit/components/Audio/Waveform.spec.ts +484 -0
  195. package/tests/unit/components/Core/Button.spec.ts +337 -0
  196. package/tests/unit/components/Core/Checkbox.spec.ts +545 -0
  197. package/tests/unit/components/Core/DateInput.spec.ts +691 -0
  198. package/tests/unit/components/Core/Dialog.spec.ts +486 -0
  199. package/tests/unit/components/Core/EditField.spec.ts +783 -0
  200. package/tests/unit/components/Core/Input.spec.ts +513 -0
  201. package/tests/unit/components/Core/Modal.spec.ts +519 -0
  202. package/tests/unit/components/Core/NotificationBubble.spec.ts +607 -0
  203. package/tests/unit/components/Core/OtpInput.spec.ts +709 -0
  204. package/tests/unit/components/Core/PhoneInput.spec.ts +620 -0
  205. package/tests/unit/components/Core/Select.spec.ts +713 -0
  206. package/tests/unit/components/Core/TextArea.spec.ts +566 -0
  207. package/tests/unit/components/Core/TickBox.spec.ts +780 -0
  208. package/tests/unit/components/IconBullet/IconBullet.spec.ts +357 -0
  209. package/tests/unit/components/IconBullet/IconBulletList.spec.ts +372 -0
  210. package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +109 -0
  211. package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +150 -0
  212. package/tests/unit/components/Icons/Audio/Delete.spec.ts +159 -0
  213. package/tests/unit/components/Icons/Audio/Pause.spec.ts +209 -0
  214. package/tests/unit/components/Icons/Audio/Play.spec.ts +218 -0
  215. package/tests/unit/components/Icons/CalendarNotification.spec.ts +187 -0
  216. package/tests/unit/components/Icons/Chair.spec.ts +235 -0
  217. package/tests/unit/components/Icons/ChairNotification.spec.ts +312 -0
  218. package/tests/unit/components/Icons/Circle.spec.ts +256 -0
  219. package/tests/unit/components/Icons/FavIcon.spec.ts +252 -0
  220. package/tests/unit/components/Icons/FilledCircle.spec.ts +275 -0
  221. package/tests/unit/components/Icons/Group3.spec.ts +356 -0
  222. package/tests/unit/components/Icons/RingNotification.spec.ts +394 -0
  223. package/tests/unit/components/Icons/calendar.spec.ts +287 -0
  224. package/tests/unit/components/Icons/checkbox.spec.ts +316 -0
  225. package/tests/unit/components/Icons/outlineChecked.spec.ts +435 -0
  226. package/tests/unit/components/Icons/play.spec.ts +309 -0
  227. package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +168 -0
  228. package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +180 -0
  229. package/tests/unit/components/Laboratory/ChatMessage.spec.ts +264 -0
  230. package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +283 -0
  231. package/tests/unit/components/Laboratory/ChatNotification.spec.ts +257 -0
  232. package/tests/unit/components/Laboratory/DocumentCard.spec.ts +229 -0
  233. package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +237 -0
  234. package/tests/unit/components/Laboratory/InfoCard.spec.ts +309 -0
  235. package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +252 -0
  236. package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +291 -0
  237. package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +276 -0
  238. package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +289 -0
  239. package/tests/unit/components/Laboratory/StatusNotification.spec.ts +297 -0
  240. package/tests/unit/components/Laboratory/TagLabel.spec.ts +354 -0
  241. package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +378 -0
  242. package/tests/unit/components/Laboratory/TicketCard.spec.ts +352 -0
  243. package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +382 -0
  244. package/tests/unit/components/Laboratory/Timeline.spec.ts +420 -0
  245. package/tests/unit/constants/iconEnums.spec.ts +40 -0
  246. package/tests/unit/i18n/i18n.spec.ts +89 -0
  247. package/tests/unit/plugins/vuetify.spec.ts +221 -0
  248. package/tests/unit/setup.ts +190 -0
  249. package/tests/unit/src/components/index.spec.ts +193 -0
  250. package/tests/unit/src/index.spec.ts +183 -0
  251. package/tests/unit/src/main.spec.ts +152 -0
  252. package/tsconfig.json +26 -0
  253. package/vite.config.ts +29 -0
  254. package/vitest.config.ts +84 -0
@@ -0,0 +1,337 @@
1
+ import { describe, it, expect, vi } from 'vitest';
2
+ import { mount } from '@vue/test-utils';
3
+ import Button from '@components/Button/Button.vue';
4
+
5
+ describe('Button', () => {
6
+ // Test default props and rendering
7
+ describe('Default Behavior', () => {
8
+ it('renders with default props', () => {
9
+ const wrapper = mount(Button);
10
+
11
+ expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
12
+ expect(wrapper.text()).toBe('Button');
13
+ expect(wrapper.vm.color).toBe('#172774');
14
+ expect(wrapper.vm.variant).toBe('flat');
15
+ expect(wrapper.vm.size).toBe('default');
16
+ expect(wrapper.vm.density).toBe('default');
17
+ expect(wrapper.vm.disabled).toBe(false);
18
+ expect(wrapper.vm.loading).toBe(false);
19
+ expect(wrapper.vm.readonly).toBe(false);
20
+ });
21
+
22
+ it('renders with custom label', () => {
23
+ const wrapper = mount(Button, {
24
+ props: {
25
+ label: 'Custom Button Text'
26
+ }
27
+ });
28
+
29
+ expect(wrapper.text()).toBe('Custom Button Text');
30
+ });
31
+
32
+ it('applies the wl-button class', () => {
33
+ const wrapper = mount(Button);
34
+ expect(wrapper.find('.wl-button').exists()).toBe(true);
35
+ });
36
+ });
37
+
38
+ // Test prop validation and customization
39
+ describe('Props', () => {
40
+ it('accepts and applies color prop', () => {
41
+ const wrapper = mount(Button, {
42
+ props: {
43
+ color: '#FF5722'
44
+ }
45
+ });
46
+
47
+ expect(wrapper.vm.color).toBe('#FF5722');
48
+ });
49
+
50
+ it('accepts and applies variant prop', () => {
51
+ const variants = ['flat', 'outlined', 'contained', 'tonal', 'text', 'plain'];
52
+
53
+ variants.forEach(variant => {
54
+ const wrapper = mount(Button, {
55
+ props: { variant }
56
+ });
57
+
58
+ expect(wrapper.vm.variant).toBe(variant);
59
+ });
60
+ });
61
+
62
+ it('accepts and applies size prop', () => {
63
+ const sizes = ['small', 'default', 'large', 'x-large'];
64
+
65
+ sizes.forEach(size => {
66
+ const wrapper = mount(Button, {
67
+ props: { size }
68
+ });
69
+
70
+ expect(wrapper.vm.size).toBe(size);
71
+ });
72
+ });
73
+
74
+ it('accepts and applies density prop', () => {
75
+ const densities = ['default', 'comfortable', 'compact'];
76
+
77
+ densities.forEach(density => {
78
+ const wrapper = mount(Button, {
79
+ props: { density }
80
+ });
81
+
82
+ expect(wrapper.vm.density).toBe(density);
83
+ });
84
+ });
85
+
86
+ it('handles disabled state', () => {
87
+ const wrapper = mount(Button, {
88
+ props: {
89
+ disabled: true
90
+ }
91
+ });
92
+
93
+ expect(wrapper.vm.disabled).toBe(true);
94
+ });
95
+
96
+ it('handles loading state', () => {
97
+ const wrapper = mount(Button, {
98
+ props: {
99
+ loading: true
100
+ }
101
+ });
102
+
103
+ expect(wrapper.vm.loading).toBe(true);
104
+ });
105
+
106
+ it('handles readonly state', () => {
107
+ const wrapper = mount(Button, {
108
+ props: {
109
+ readonly: true
110
+ }
111
+ });
112
+
113
+ expect(wrapper.vm.readonly).toBe(true);
114
+ });
115
+ });
116
+
117
+ // Test icons
118
+ describe('Icons', () => {
119
+ it('renders with prepend icon', () => {
120
+ const wrapper = mount(Button, {
121
+ props: {
122
+ prependIcon: 'mdi-home'
123
+ }
124
+ });
125
+
126
+ expect(wrapper.vm.prependIcon).toBe('mdi-home');
127
+ });
128
+
129
+ it('renders with append icon', () => {
130
+ const wrapper = mount(Button, {
131
+ props: {
132
+ appendIcon: 'mdi-arrow-right'
133
+ }
134
+ });
135
+
136
+ expect(wrapper.vm.appendIcon).toBe('mdi-arrow-right');
137
+ });
138
+
139
+ it('renders with both prepend and append icons', () => {
140
+ const wrapper = mount(Button, {
141
+ props: {
142
+ prependIcon: 'mdi-home',
143
+ appendIcon: 'mdi-arrow-right'
144
+ }
145
+ });
146
+
147
+ expect(wrapper.vm.prependIcon).toBe('mdi-home');
148
+ expect(wrapper.vm.appendIcon).toBe('mdi-arrow-right');
149
+ });
150
+
151
+ it('handles flexible appendIcon prop type', () => {
152
+ const wrapper = mount(Button, {
153
+ props: {
154
+ appendIcon: 'mdi-test'
155
+ }
156
+ });
157
+
158
+ expect(wrapper.vm.appendIcon).toBe('mdi-test');
159
+
160
+ // Test with different types since appendIcon has no type constraint
161
+ const wrapperWithObject = mount(Button, {
162
+ props: {
163
+ appendIcon: { icon: 'custom' }
164
+ }
165
+ });
166
+
167
+ expect(wrapperWithObject.vm.appendIcon).toEqual({ icon: 'custom' });
168
+ });
169
+ });
170
+
171
+ // Test accessibility
172
+ describe('Accessibility', () => {
173
+ it('has data-testid for testing', () => {
174
+ const wrapper = mount(Button);
175
+ expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
176
+ });
177
+
178
+ it('is accessible when disabled', () => {
179
+ const wrapper = mount(Button, {
180
+ props: {
181
+ disabled: true,
182
+ label: 'Disabled Button'
183
+ }
184
+ });
185
+
186
+ expect(wrapper.vm.disabled).toBe(true);
187
+ expect(wrapper.text()).toBe('Disabled Button');
188
+ });
189
+
190
+ it('is accessible when loading', () => {
191
+ const wrapper = mount(Button, {
192
+ props: {
193
+ loading: true,
194
+ label: 'Loading Button'
195
+ }
196
+ });
197
+
198
+ expect(wrapper.vm.loading).toBe(true);
199
+ expect(wrapper.text()).toBe('Loading Button');
200
+ });
201
+ });
202
+
203
+ // Test edge cases and error conditions
204
+ describe('Edge Cases', () => {
205
+ it('handles empty label', () => {
206
+ const wrapper = mount(Button, {
207
+ props: {
208
+ label: ''
209
+ }
210
+ });
211
+
212
+ expect(wrapper.text()).toBe('');
213
+ });
214
+
215
+ it('handles undefined/null props gracefully', () => {
216
+ const wrapper = mount(Button, {
217
+ props: {
218
+ prependIcon: undefined,
219
+ appendIcon: null,
220
+ label: null
221
+ }
222
+ });
223
+
224
+ expect(wrapper.vm.prependIcon).toBeUndefined();
225
+ expect(wrapper.vm.appendIcon).toBeNull();
226
+ expect(wrapper.vm.label).toBeNull();
227
+ });
228
+
229
+ it('handles very long label text', () => {
230
+ const longLabel = 'This is a very long button label that might cause layout issues if not handled properly';
231
+ const wrapper = mount(Button, {
232
+ props: {
233
+ label: longLabel
234
+ }
235
+ });
236
+
237
+ expect(wrapper.text()).toBe(longLabel);
238
+ });
239
+ });
240
+
241
+ // Test component behavior with different states
242
+ describe('State Combinations', () => {
243
+ it('handles loading and disabled states together', () => {
244
+ const wrapper = mount(Button, {
245
+ props: {
246
+ loading: true,
247
+ disabled: true
248
+ }
249
+ });
250
+
251
+ expect(wrapper.vm.loading).toBe(true);
252
+ expect(wrapper.vm.disabled).toBe(true);
253
+ });
254
+
255
+ it('handles readonly and disabled states together', () => {
256
+ const wrapper = mount(Button, {
257
+ props: {
258
+ readonly: true,
259
+ disabled: true
260
+ }
261
+ });
262
+
263
+ expect(wrapper.vm.readonly).toBe(true);
264
+ expect(wrapper.vm.disabled).toBe(true);
265
+ });
266
+
267
+ it('handles all states together', () => {
268
+ const wrapper = mount(Button, {
269
+ props: {
270
+ loading: true,
271
+ disabled: true,
272
+ readonly: true,
273
+ variant: 'outlined',
274
+ size: 'large',
275
+ color: '#FF5722',
276
+ label: 'Complex Button'
277
+ }
278
+ });
279
+
280
+ expect(wrapper.vm.loading).toBe(true);
281
+ expect(wrapper.vm.disabled).toBe(true);
282
+ expect(wrapper.vm.readonly).toBe(true);
283
+ expect(wrapper.vm.variant).toBe('outlined');
284
+ expect(wrapper.vm.size).toBe('large');
285
+ expect(wrapper.vm.color).toBe('#FF5722');
286
+ expect(wrapper.text()).toBe('Complex Button');
287
+ });
288
+ });
289
+
290
+ // Test Vuetify integration
291
+ describe('Vuetify Integration', () => {
292
+ it('passes all props to v-btn correctly', () => {
293
+ const wrapper = mount(Button, {
294
+ props: {
295
+ color: '#FF5722',
296
+ variant: 'outlined',
297
+ size: 'large',
298
+ density: 'comfortable',
299
+ disabled: true,
300
+ loading: true,
301
+ readonly: true,
302
+ prependIcon: 'mdi-home',
303
+ appendIcon: 'mdi-arrow-right'
304
+ }
305
+ });
306
+
307
+ const vBtn = wrapper.find('[data-testid="root"]');
308
+ expect(vBtn.exists()).toBe(true);
309
+ });
310
+
311
+ it('applies rounded="lg" attribute', () => {
312
+ const wrapper = mount(Button);
313
+ // Since we're using stubs, we can't directly test Vuetify props
314
+ // but we can verify the component renders correctly
315
+ expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
316
+ });
317
+
318
+ it('applies text-none class for Vuetify text transformation', () => {
319
+ const wrapper = mount(Button);
320
+ expect(wrapper.find('.text-none').exists()).toBe(true);
321
+ });
322
+ });
323
+
324
+ // Test CSS styling
325
+ describe('Styling', () => {
326
+ it('applies custom CSS for outlined variant border', () => {
327
+ const wrapper = mount(Button, {
328
+ props: {
329
+ variant: 'outlined'
330
+ }
331
+ });
332
+
333
+ // Check if the component has the necessary classes
334
+ expect(wrapper.find('.wl-button').exists()).toBe(true);
335
+ });
336
+ });
337
+ });