@zap-wunschlachen/wl-shared-components 1.0.24 → 1.0.26
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.
- package/.github/workflows/playwright.yml +205 -205
- package/.github/workflows/static.yml +61 -61
- package/.github/workflows/update-snapshots.yml +37 -37
- package/.prettierrc +5 -5
- package/.storybook/main.ts +18 -18
- package/.storybook/preview.ts +37 -37
- package/.storybook/storyWrapper.vue +18 -18
- package/.storybook/withVuetifyTheme.decorator.ts +21 -21
- package/App.vue +34 -176
- package/README.md +56 -56
- package/heroicons.ts +75 -75
- package/index.html +19 -19
- package/package.json +67 -67
- package/playwright.config.ts +48 -48
- package/public/background.svg +60 -60
- package/public/style.css +187 -187
- package/public/technologies.svg +22 -22
- package/src/assets/css/base.css +235 -235
- package/src/assets/css/variables.css +107 -96
- package/src/components/Accordion/Accordion.css +59 -59
- package/src/components/Accordion/AccordionGroup.vue +51 -51
- package/src/components/Accordion/AccordionItem.vue +66 -66
- package/src/components/Appointment/Card/Actions.css +54 -54
- package/src/components/Appointment/Card/Actions.vue +99 -99
- package/src/components/Appointment/Card/AnamneseNotification.css +15 -15
- package/src/components/Appointment/Card/AnamneseNotification.vue +23 -23
- package/src/components/Appointment/Card/Card.css +80 -80
- package/src/components/Appointment/Card/Card.vue +93 -93
- package/src/components/Appointment/Card/Details.css +50 -50
- package/src/components/Appointment/Card/Details.vue +43 -43
- package/src/components/Audio/Audio.vue +187 -187
- package/src/components/Audio/Waveform.vue +117 -117
- package/src/components/Background/Background.css +39 -0
- package/src/components/Background/Background.vue +19 -0
- package/src/components/Background/WhiteCocoonBackground.vue +9 -0
- package/src/components/Background/WunschlachenBackground.vue +11 -0
- package/src/components/Button/Button.vue +119 -119
- package/src/components/CheckBox/CheckBox.css +185 -185
- package/src/components/CheckBox/Checkbox.vue +130 -130
- package/src/components/DateInput/DateInput.css +2 -2
- package/src/components/DateInput/DateInput.vue +262 -262
- package/src/components/Dialog/Dialog.css +6 -6
- package/src/components/Dialog/Dialog.vue +29 -29
- package/src/components/EditField/EditField.css +19 -19
- package/src/components/EditField/EditField.vue +202 -202
- package/src/components/ErrorPage/ErrorPage.css +124 -0
- package/src/components/ErrorPage/ErrorPage.vue +45 -0
- package/src/components/ErrorPage/ErrorPageLogo.vue +26 -0
- package/src/components/IconBullet/IconBullet.vue +86 -86
- package/src/components/IconBullet/IconBulletList.vue +41 -41
- package/src/components/Icons/AdvanceAppointments.vue +153 -153
- package/src/components/Icons/Audio/CloudFailed.vue +20 -20
- package/src/components/Icons/Audio/CloudSaved.vue +21 -21
- package/src/components/Icons/Audio/Delete.vue +15 -15
- package/src/components/Icons/Audio/Pause.vue +18 -18
- package/src/components/Icons/Audio/Play.vue +15 -15
- package/src/components/Icons/CalendarNotification.vue +126 -126
- package/src/components/Icons/Chair.vue +32 -32
- package/src/components/Icons/ChairNotification.vue +35 -35
- package/src/components/Icons/Circle.vue +66 -66
- package/src/components/Icons/FavIcon.vue +22 -22
- package/src/components/Icons/FilledCircle.vue +11 -11
- package/src/components/Icons/Group3.vue +46 -46
- package/src/components/Icons/Logo.vue +108 -0
- package/src/components/Icons/RingNotification.vue +54 -54
- package/src/components/Icons/SolidArrowRight.vue +14 -14
- package/src/components/Icons/calendar.vue +17 -17
- package/src/components/Icons/checkbox.vue +19 -19
- package/src/components/Icons/outlineChecked.vue +27 -27
- package/src/components/Icons/play.vue +5 -5
- package/src/components/Input/Input.css +187 -187
- package/src/components/Input/Input.vue +247 -247
- package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -7
- package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -116
- package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -81
- package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -113
- package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -4
- package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -99
- package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -130
- package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -3
- package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -50
- package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -53
- package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -162
- package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -102
- package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -152
- package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -33
- package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -75
- package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -92
- package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -49
- package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -126
- package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -97
- package/src/components/Laboratory/TicketCard/TicketCard.css +3 -3
- package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -143
- package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -18
- package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -119
- package/src/components/Laboratory/TimeLine/Timeline.css +4 -4
- package/src/components/Laboratory/TimeLine/Timeline.vue +30 -30
- package/src/components/Loader/Loader.css +51 -51
- package/src/components/MaintenanceBanner/MaintenanceBanner.css +289 -0
- package/src/components/MaintenanceBanner/MaintenanceBanner.vue +127 -0
- package/src/components/MaintenanceBanner/MaintenanceIllustration.vue +54 -0
- package/src/components/Modal/Modal.css +5 -5
- package/src/components/Modal/Modal.vue +22 -22
- package/src/components/NotificationBubble/NotificationBubble.css +4 -4
- package/src/components/NotificationBubble/NotificationBubble.vue +90 -90
- package/src/components/OtpInput/OtpInput.css +39 -39
- package/src/components/OtpInput/OtpInput.vue +143 -143
- package/src/components/PhoneInput/PhoneInput.css +31 -31
- package/src/components/PhoneInput/PhoneInput.vue +113 -113
- package/src/components/Select/Select.css +150 -150
- package/src/components/Select/Select.vue +315 -304
- package/src/components/TextArea/TextArea.css +3 -3
- package/src/components/TextArea/TextArea.vue +126 -126
- package/src/components/TickBox/TickBox.css +49 -49
- package/src/components/TickBox/TickBox.vue +126 -126
- package/src/components/index.ts +26 -24
- package/src/constants/iconEnums.ts +3 -3
- package/src/i18n/i18n.ts +15 -15
- package/src/i18n/locales/de.json +30 -30
- package/src/i18n/locales/en.json +30 -30
- package/src/index.ts +34 -34
- package/src/main.ts +11 -11
- package/src/plugins/vuetify.ts +139 -131
- package/src/shims-vue.d.ts +10 -10
- package/src/stories/Accordion.stories.ts +650 -650
- package/src/stories/Audio.stories.ts +28 -28
- package/src/stories/Button.stories.ts +263 -263
- package/src/stories/CheckBox.stories.ts +348 -348
- package/src/stories/DateInput.stories.ts +53 -53
- package/src/stories/Dialog.stories.ts +147 -147
- package/src/stories/EditField.stories.ts +78 -78
- package/src/stories/IconBullet/IconBullet.stories.ts +201 -201
- package/src/stories/IconBullet/IconBulletList.stories.ts +275 -275
- package/src/stories/Input.stories.ts +351 -351
- package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -260
- package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -176
- package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -119
- package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -320
- package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -335
- package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -82
- package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -198
- package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -204
- package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -144
- package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -186
- package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -111
- package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -48
- package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -261
- package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -234
- package/src/stories/Laboratory/TagLabel.stories.ts +418 -418
- package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -234
- package/src/stories/Laboratory/Timeline.stories.ts +403 -403
- package/src/stories/NotificationBubble.stories.ts +194 -194
- package/src/stories/OtpInput.stories.ts +100 -100
- package/src/stories/PhoneInput.stories.ts +52 -52
- package/src/stories/Select.stories.ts +419 -419
- package/src/stories/TextArea.stories.ts +112 -112
- package/src/stories/TickBox.stories.ts +294 -294
- package/src/stories/v-icon.stories.ts +91 -91
- package/src/utils/index.ts +106 -100
- package/src/vite-env.d.ts +1 -1
- package/tests/e2e/README.md +220 -220
- package/tests/e2e/accessibility.spec.ts +638 -638
- package/tests/e2e/accordion.spec.ts +42 -42
- package/tests/e2e/additional-components.spec.ts +437 -437
- package/tests/e2e/all-components.spec.ts +135 -135
- package/tests/e2e/appointment-card.spec.ts +816 -816
- package/tests/e2e/button-fixed.spec.ts +58 -58
- package/tests/e2e/button.spec.ts +76 -76
- package/tests/e2e/checkbox.spec.ts +50 -50
- package/tests/e2e/date-input.spec.ts +46 -46
- package/tests/e2e/debug.spec.ts +51 -51
- package/tests/e2e/dialog.spec.ts +58 -58
- package/tests/e2e/input.spec.ts +55 -55
- package/tests/e2e/laboratory-components.spec.ts +320 -320
- package/tests/e2e/otp-input.spec.ts +50 -50
- package/tests/e2e/select.spec.ts +52 -52
- package/tests/e2e/storybook-utils.ts +59 -59
- package/tests/e2e/test-basic.spec.ts +33 -33
- package/tests/e2e/visual-regression.spec.ts +350 -350
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
- package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
- package/tests/unit/components/Appointment/Card/Actions.spec.ts +407 -407
- package/tests/unit/components/Appointment/Card/Card.spec.ts +485 -485
- package/tests/unit/components/Appointment/Card/Details.spec.ts +397 -397
- package/tests/unit/components/Audio/Audio.spec.ts +403 -403
- package/tests/unit/components/Audio/Waveform.spec.ts +483 -483
- package/tests/unit/components/Core/Button.spec.ts +336 -336
- package/tests/unit/components/Core/Checkbox.spec.ts +544 -544
- package/tests/unit/components/Core/DateInput.spec.ts +690 -690
- package/tests/unit/components/Core/Dialog.spec.ts +485 -485
- package/tests/unit/components/Core/EditField.spec.ts +782 -782
- package/tests/unit/components/Core/Input.spec.ts +512 -512
- package/tests/unit/components/Core/Modal.spec.ts +518 -518
- package/tests/unit/components/Core/NotificationBubble.spec.ts +606 -606
- package/tests/unit/components/Core/OtpInput.spec.ts +708 -708
- package/tests/unit/components/Core/PhoneInput.spec.ts +619 -619
- package/tests/unit/components/Core/Select.spec.ts +712 -712
- package/tests/unit/components/Core/TextArea.spec.ts +565 -565
- package/tests/unit/components/Core/TickBox.spec.ts +779 -779
- package/tests/unit/components/IconBullet/IconBullet.spec.ts +356 -356
- package/tests/unit/components/IconBullet/IconBulletList.spec.ts +371 -371
- package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +108 -108
- package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +149 -149
- package/tests/unit/components/Icons/Audio/Delete.spec.ts +158 -158
- package/tests/unit/components/Icons/Audio/Pause.spec.ts +208 -208
- package/tests/unit/components/Icons/Audio/Play.spec.ts +217 -217
- package/tests/unit/components/Icons/CalendarNotification.spec.ts +186 -186
- package/tests/unit/components/Icons/Chair.spec.ts +234 -234
- package/tests/unit/components/Icons/ChairNotification.spec.ts +311 -311
- package/tests/unit/components/Icons/Circle.spec.ts +255 -255
- package/tests/unit/components/Icons/FavIcon.spec.ts +251 -251
- package/tests/unit/components/Icons/FilledCircle.spec.ts +274 -274
- package/tests/unit/components/Icons/Group3.spec.ts +355 -355
- package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
- package/tests/unit/components/Icons/calendar.spec.ts +286 -286
- package/tests/unit/components/Icons/checkbox.spec.ts +315 -315
- package/tests/unit/components/Icons/outlineChecked.spec.ts +434 -434
- package/tests/unit/components/Icons/play.spec.ts +308 -308
- package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +167 -167
- package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +179 -179
- package/tests/unit/components/Laboratory/ChatMessage.spec.ts +263 -263
- package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +282 -282
- package/tests/unit/components/Laboratory/ChatNotification.spec.ts +256 -256
- package/tests/unit/components/Laboratory/DocumentCard.spec.ts +228 -228
- package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +236 -236
- package/tests/unit/components/Laboratory/InfoCard.spec.ts +308 -308
- package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +251 -251
- package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +290 -290
- package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +275 -275
- package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +288 -288
- package/tests/unit/components/Laboratory/StatusNotification.spec.ts +296 -296
- package/tests/unit/components/Laboratory/TagLabel.spec.ts +353 -353
- package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +377 -377
- package/tests/unit/components/Laboratory/TicketCard.spec.ts +351 -351
- package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +381 -381
- package/tests/unit/components/Laboratory/Timeline.spec.ts +419 -419
- package/tests/unit/constants/iconEnums.spec.ts +39 -39
- package/tests/unit/i18n/i18n.spec.ts +88 -88
- package/tests/unit/plugins/vuetify.spec.ts +220 -220
- package/tests/unit/setup.ts +189 -189
- package/tests/unit/src/components/index.spec.ts.skip +192 -192
- package/tests/unit/src/index.spec.ts.skip +182 -182
- package/tests/unit/src/main.spec.ts +151 -151
- package/tsconfig.json +26 -26
- package/vite.config.ts +29 -29
- package/vitest.config.ts +83 -83
|
@@ -1,287 +1,287 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { mount } from '@vue/test-utils';
|
|
3
|
-
import Calendar from '@components/Icons/calendar.vue';
|
|
4
|
-
|
|
5
|
-
describe('Calendar Icon', () => {
|
|
6
|
-
describe('Rendering', () => {
|
|
7
|
-
it('renders as SVG element', () => {
|
|
8
|
-
const wrapper = mount(Calendar);
|
|
9
|
-
expect(wrapper.find('svg').exists()).toBe(true);
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
it('has correct SVG attributes', () => {
|
|
13
|
-
const wrapper = mount(Calendar);
|
|
14
|
-
const svg = wrapper.find('svg');
|
|
15
|
-
|
|
16
|
-
expect(svg.attributes('width')).toBe('21');
|
|
17
|
-
expect(svg.attributes('height')).toBe('20');
|
|
18
|
-
expect(svg.attributes('viewBox')).toBe('0 0 21 20');
|
|
19
|
-
expect(svg.attributes('fill')).toBe('none');
|
|
20
|
-
expect(svg.attributes('xmlns')).toBe('http://www.w3.org/2000/svg');
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
it('contains exactly 1 path element', () => {
|
|
24
|
-
const wrapper = mount(Calendar);
|
|
25
|
-
const paths = wrapper.findAll('path');
|
|
26
|
-
expect(paths).toHaveLength(1);
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
describe('Path Structure', () => {
|
|
31
|
-
it('path represents complete calendar structure', () => {
|
|
32
|
-
const wrapper = mount(Calendar);
|
|
33
|
-
const path = wrapper.find('path');
|
|
34
|
-
|
|
35
|
-
const pathData = path.attributes('d');
|
|
36
|
-
expect(pathData).toContain('M5.07568 1V3.25'); // Top left binding ring
|
|
37
|
-
expect(pathData).toContain('M15.5757 1V3.25'); // Top right binding ring
|
|
38
|
-
expect(pathData).toContain('M1.32568 16.75V5.5'); // Calendar body
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
it('path has correct stroke properties', () => {
|
|
42
|
-
const wrapper = mount(Calendar);
|
|
43
|
-
const path = wrapper.find('path');
|
|
44
|
-
|
|
45
|
-
expect(path.attributes('stroke')).toBe('#172774');
|
|
46
|
-
expect(path.attributes('stroke-width')).toBe('1.5');
|
|
47
|
-
expect(path.attributes('stroke-linecap')).toBe('round');
|
|
48
|
-
expect(path.attributes('stroke-linejoin')).toBe('round');
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it('includes binding rings at top', () => {
|
|
52
|
-
const wrapper = mount(Calendar);
|
|
53
|
-
const path = wrapper.find('path');
|
|
54
|
-
|
|
55
|
-
const pathData = path.attributes('d');
|
|
56
|
-
// Binding rings that extend above the calendar body
|
|
57
|
-
expect(pathData).toContain('M5.07568 1V3.25'); // Left ring
|
|
58
|
-
expect(pathData).toContain('M15.5757 1V3.25'); // Right ring
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it('includes calendar body structure', () => {
|
|
62
|
-
const wrapper = mount(Calendar);
|
|
63
|
-
const path = wrapper.find('path');
|
|
64
|
-
|
|
65
|
-
const pathData = path.attributes('d');
|
|
66
|
-
// Calendar body with rounded corners
|
|
67
|
-
expect(pathData).toContain('C1.32568 4.25736 2.33304 3.25'); // Top body
|
|
68
|
-
expect(pathData).toContain('C1.32568 17.9926 2.33304 19'); // Bottom body
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
it('includes date grid dots', () => {
|
|
72
|
-
const wrapper = mount(Calendar);
|
|
73
|
-
const path = wrapper.find('path');
|
|
74
|
-
|
|
75
|
-
const pathData = path.attributes('d');
|
|
76
|
-
// Multiple small rectangles representing dates
|
|
77
|
-
expect(pathData).toContain('H10.3332V10.7575'); // Date dots
|
|
78
|
-
expect(pathData).toContain('H12.5832V13.0075'); // More date dots
|
|
79
|
-
expect(pathData).toContain('H14.8332V10.7575'); // Even more date dots
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
describe('Visual Properties', () => {
|
|
84
|
-
it('uses correct brand color for stroke', () => {
|
|
85
|
-
const wrapper = mount(Calendar);
|
|
86
|
-
const path = wrapper.find('path');
|
|
87
|
-
|
|
88
|
-
expect(path.attributes('stroke')).toBe('#172774');
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
it('has appropriate stroke width for icon size', () => {
|
|
92
|
-
const wrapper = mount(Calendar);
|
|
93
|
-
const path = wrapper.find('path');
|
|
94
|
-
|
|
95
|
-
expect(path.attributes('stroke-width')).toBe('1.5');
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
it('uses rounded line caps and joins', () => {
|
|
99
|
-
const wrapper = mount(Calendar);
|
|
100
|
-
const path = wrapper.find('path');
|
|
101
|
-
|
|
102
|
-
expect(path.attributes('stroke-linecap')).toBe('round');
|
|
103
|
-
expect(path.attributes('stroke-linejoin')).toBe('round');
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
it('path has no fill (outline style)', () => {
|
|
107
|
-
const wrapper = mount(Calendar);
|
|
108
|
-
const svg = wrapper.find('svg');
|
|
109
|
-
|
|
110
|
-
expect(svg.attributes('fill')).toBe('none');
|
|
111
|
-
});
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
describe('Calendar Geometry', () => {
|
|
115
|
-
it('binding rings positioned at top', () => {
|
|
116
|
-
const wrapper = mount(Calendar);
|
|
117
|
-
const path = wrapper.find('path');
|
|
118
|
-
|
|
119
|
-
const pathData = path.attributes('d');
|
|
120
|
-
// Rings extend from y=1 to y=3.25
|
|
121
|
-
expect(pathData).toContain('1V3.25');
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it('calendar body spans most of viewBox', () => {
|
|
125
|
-
const wrapper = mount(Calendar);
|
|
126
|
-
const path = wrapper.find('path');
|
|
127
|
-
|
|
128
|
-
const pathData = path.attributes('d');
|
|
129
|
-
// Body from y=3.25 to y=19, x=1.32568 to x=19.3257
|
|
130
|
-
expect(pathData).toContain('1.32568');
|
|
131
|
-
expect(pathData).toContain('19.3257');
|
|
132
|
-
expect(pathData).toContain('3.25');
|
|
133
|
-
expect(pathData).toContain('19');
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
it('includes header section separation', () => {
|
|
137
|
-
const wrapper = mount(Calendar);
|
|
138
|
-
const path = wrapper.find('path');
|
|
139
|
-
|
|
140
|
-
const pathData = path.attributes('d');
|
|
141
|
-
// Separator line at y=7 between header and dates
|
|
142
|
-
expect(pathData).toContain('7H17.0757');
|
|
143
|
-
expect(pathData).toContain('9.25V16.75');
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
it('date dots arranged in grid pattern', () => {
|
|
147
|
-
const wrapper = mount(Calendar);
|
|
148
|
-
const path = wrapper.find('path');
|
|
149
|
-
|
|
150
|
-
const pathData = path.attributes('d');
|
|
151
|
-
// Multiple columns and rows
|
|
152
|
-
expect(pathData).toContain('10.3257'); // Center column
|
|
153
|
-
expect(pathData).toContain('8.07568'); // Left column
|
|
154
|
-
expect(pathData).toContain('12.5757'); // Right column
|
|
155
|
-
expect(pathData).toContain('10.75'); // First row
|
|
156
|
-
expect(pathData).toContain('13H'); // Second row
|
|
157
|
-
expect(pathData).toContain('15.25'); // Third row
|
|
158
|
-
});
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
describe('Component Structure', () => {
|
|
162
|
-
it('uses appropriate dimensions for calendar icon', () => {
|
|
163
|
-
const wrapper = mount(Calendar);
|
|
164
|
-
const svg = wrapper.find('svg');
|
|
165
|
-
|
|
166
|
-
// Slightly wider than tall to accommodate calendar proportions
|
|
167
|
-
expect(svg.attributes('width')).toBe('21');
|
|
168
|
-
expect(svg.attributes('height')).toBe('20');
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
it('suitable for UI calendar representations', () => {
|
|
172
|
-
const wrapper = mount(Calendar);
|
|
173
|
-
const path = wrapper.find('path');
|
|
174
|
-
|
|
175
|
-
// Includes key calendar elements
|
|
176
|
-
const pathData = path.attributes('d');
|
|
177
|
-
expect(pathData).toContain('1V3.25'); // Binding rings
|
|
178
|
-
expect(pathData).toMatch(/H\d+\.\d+V\d+\.\d+/); // Grid structure
|
|
179
|
-
});
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
describe('Accessibility', () => {
|
|
183
|
-
it('svg is properly structured for screen readers', () => {
|
|
184
|
-
const wrapper = mount(Calendar);
|
|
185
|
-
const svg = wrapper.find('svg');
|
|
186
|
-
|
|
187
|
-
expect(svg.element.tagName.toLowerCase()).toBe('svg');
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
it('uses outline style for better contrast', () => {
|
|
191
|
-
const wrapper = mount(Calendar);
|
|
192
|
-
const path = wrapper.find('path');
|
|
193
|
-
|
|
194
|
-
// Outline style is more universally accessible
|
|
195
|
-
expect(path.attributes('stroke')).toBeTruthy();
|
|
196
|
-
expect(path.attributes('fill')).toBeFalsy();
|
|
197
|
-
});
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
describe('Component Integration', () => {
|
|
201
|
-
it('can be mounted without props', () => {
|
|
202
|
-
expect(() => {
|
|
203
|
-
mount(Calendar);
|
|
204
|
-
}).not.toThrow();
|
|
205
|
-
});
|
|
206
|
-
|
|
207
|
-
it('renders consistently on multiple mounts', () => {
|
|
208
|
-
const wrapper1 = mount(Calendar);
|
|
209
|
-
const wrapper2 = mount(Calendar);
|
|
210
|
-
|
|
211
|
-
expect(wrapper1.html()).toBe(wrapper2.html());
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
it('maintains calendar structure integrity', () => {
|
|
215
|
-
const wrapper = mount(Calendar);
|
|
216
|
-
const path = wrapper.find('path');
|
|
217
|
-
|
|
218
|
-
expect(path.exists()).toBe(true);
|
|
219
|
-
expect(path.attributes('d')).toBeTruthy();
|
|
220
|
-
expect(path.attributes('stroke')).toBeTruthy();
|
|
221
|
-
expect(path.attributes('stroke-width')).toBeTruthy();
|
|
222
|
-
});
|
|
223
|
-
|
|
224
|
-
it('suitable for various calendar UI contexts', () => {
|
|
225
|
-
const wrapper = mount(Calendar);
|
|
226
|
-
|
|
227
|
-
// Good size for buttons, form fields, navigation
|
|
228
|
-
expect(wrapper.find('svg').attributes('width')).toBe('21');
|
|
229
|
-
expect(wrapper.find('svg').attributes('height')).toBe('20');
|
|
230
|
-
});
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
describe('Icon Semantics', () => {
|
|
234
|
-
it('represents calendar with recognizable elements', () => {
|
|
235
|
-
const wrapper = mount(Calendar);
|
|
236
|
-
const path = wrapper.find('path');
|
|
237
|
-
|
|
238
|
-
const pathData = path.attributes('d');
|
|
239
|
-
// Key calendar features
|
|
240
|
-
expect(pathData).toMatch(/1V3\.25/); // Binding rings
|
|
241
|
-
expect(pathData).toMatch(/H\d+\.\d+V\d+\.\d+/); // Date grid
|
|
242
|
-
expect(pathData).toMatch(/C\d+/); // Rounded corners
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
it('uses standard calendar proportions', () => {
|
|
246
|
-
const wrapper = mount(Calendar);
|
|
247
|
-
const svg = wrapper.find('svg');
|
|
248
|
-
|
|
249
|
-
// Typical calendar aspect ratio (slightly wider than tall)
|
|
250
|
-
const width = parseInt(svg.attributes('width'));
|
|
251
|
-
const height = parseInt(svg.attributes('height'));
|
|
252
|
-
expect(width).toBeGreaterThan(height);
|
|
253
|
-
expect(width / height).toBeCloseTo(1.05, 1);
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
it('includes visual date indicators', () => {
|
|
257
|
-
const wrapper = mount(Calendar);
|
|
258
|
-
const path = wrapper.find('path');
|
|
259
|
-
|
|
260
|
-
const pathData = path.attributes('d');
|
|
261
|
-
// Should have multiple small date markers
|
|
262
|
-
const dateMarkers = pathData.match(/H\d+\.\d+V\d+\.\d+/g);
|
|
263
|
-
expect(dateMarkers).toBeTruthy();
|
|
264
|
-
expect(dateMarkers.length).toBeGreaterThan(5);
|
|
265
|
-
});
|
|
266
|
-
});
|
|
267
|
-
|
|
268
|
-
describe('Visual Design', () => {
|
|
269
|
-
it('provides clear calendar recognition', () => {
|
|
270
|
-
const wrapper = mount(Calendar);
|
|
271
|
-
const path = wrapper.find('path');
|
|
272
|
-
|
|
273
|
-
const pathData = path.attributes('d');
|
|
274
|
-
// Distinctive calendar elements
|
|
275
|
-
expect(pathData).toContain('1V3.25'); // Top rings
|
|
276
|
-
expect(pathData).toMatch(/\d+\.\d+H\d+\.\d+V/); // Grid pattern
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
it('uses appropriate line weight for clarity', () => {
|
|
280
|
-
const wrapper = mount(Calendar);
|
|
281
|
-
const path = wrapper.find('path');
|
|
282
|
-
|
|
283
|
-
// 1.5px stroke provides good visibility without being too heavy
|
|
284
|
-
expect(path.attributes('stroke-width')).toBe('1.5');
|
|
285
|
-
});
|
|
286
|
-
});
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { mount } from '@vue/test-utils';
|
|
3
|
+
import Calendar from '@components/Icons/calendar.vue';
|
|
4
|
+
|
|
5
|
+
describe('Calendar Icon', () => {
|
|
6
|
+
describe('Rendering', () => {
|
|
7
|
+
it('renders as SVG element', () => {
|
|
8
|
+
const wrapper = mount(Calendar);
|
|
9
|
+
expect(wrapper.find('svg').exists()).toBe(true);
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it('has correct SVG attributes', () => {
|
|
13
|
+
const wrapper = mount(Calendar);
|
|
14
|
+
const svg = wrapper.find('svg');
|
|
15
|
+
|
|
16
|
+
expect(svg.attributes('width')).toBe('21');
|
|
17
|
+
expect(svg.attributes('height')).toBe('20');
|
|
18
|
+
expect(svg.attributes('viewBox')).toBe('0 0 21 20');
|
|
19
|
+
expect(svg.attributes('fill')).toBe('none');
|
|
20
|
+
expect(svg.attributes('xmlns')).toBe('http://www.w3.org/2000/svg');
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
it('contains exactly 1 path element', () => {
|
|
24
|
+
const wrapper = mount(Calendar);
|
|
25
|
+
const paths = wrapper.findAll('path');
|
|
26
|
+
expect(paths).toHaveLength(1);
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
describe('Path Structure', () => {
|
|
31
|
+
it('path represents complete calendar structure', () => {
|
|
32
|
+
const wrapper = mount(Calendar);
|
|
33
|
+
const path = wrapper.find('path');
|
|
34
|
+
|
|
35
|
+
const pathData = path.attributes('d');
|
|
36
|
+
expect(pathData).toContain('M5.07568 1V3.25'); // Top left binding ring
|
|
37
|
+
expect(pathData).toContain('M15.5757 1V3.25'); // Top right binding ring
|
|
38
|
+
expect(pathData).toContain('M1.32568 16.75V5.5'); // Calendar body
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
it('path has correct stroke properties', () => {
|
|
42
|
+
const wrapper = mount(Calendar);
|
|
43
|
+
const path = wrapper.find('path');
|
|
44
|
+
|
|
45
|
+
expect(path.attributes('stroke')).toBe('#172774');
|
|
46
|
+
expect(path.attributes('stroke-width')).toBe('1.5');
|
|
47
|
+
expect(path.attributes('stroke-linecap')).toBe('round');
|
|
48
|
+
expect(path.attributes('stroke-linejoin')).toBe('round');
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
it('includes binding rings at top', () => {
|
|
52
|
+
const wrapper = mount(Calendar);
|
|
53
|
+
const path = wrapper.find('path');
|
|
54
|
+
|
|
55
|
+
const pathData = path.attributes('d');
|
|
56
|
+
// Binding rings that extend above the calendar body
|
|
57
|
+
expect(pathData).toContain('M5.07568 1V3.25'); // Left ring
|
|
58
|
+
expect(pathData).toContain('M15.5757 1V3.25'); // Right ring
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
it('includes calendar body structure', () => {
|
|
62
|
+
const wrapper = mount(Calendar);
|
|
63
|
+
const path = wrapper.find('path');
|
|
64
|
+
|
|
65
|
+
const pathData = path.attributes('d');
|
|
66
|
+
// Calendar body with rounded corners
|
|
67
|
+
expect(pathData).toContain('C1.32568 4.25736 2.33304 3.25'); // Top body
|
|
68
|
+
expect(pathData).toContain('C1.32568 17.9926 2.33304 19'); // Bottom body
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it('includes date grid dots', () => {
|
|
72
|
+
const wrapper = mount(Calendar);
|
|
73
|
+
const path = wrapper.find('path');
|
|
74
|
+
|
|
75
|
+
const pathData = path.attributes('d');
|
|
76
|
+
// Multiple small rectangles representing dates
|
|
77
|
+
expect(pathData).toContain('H10.3332V10.7575'); // Date dots
|
|
78
|
+
expect(pathData).toContain('H12.5832V13.0075'); // More date dots
|
|
79
|
+
expect(pathData).toContain('H14.8332V10.7575'); // Even more date dots
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
describe('Visual Properties', () => {
|
|
84
|
+
it('uses correct brand color for stroke', () => {
|
|
85
|
+
const wrapper = mount(Calendar);
|
|
86
|
+
const path = wrapper.find('path');
|
|
87
|
+
|
|
88
|
+
expect(path.attributes('stroke')).toBe('#172774');
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it('has appropriate stroke width for icon size', () => {
|
|
92
|
+
const wrapper = mount(Calendar);
|
|
93
|
+
const path = wrapper.find('path');
|
|
94
|
+
|
|
95
|
+
expect(path.attributes('stroke-width')).toBe('1.5');
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
it('uses rounded line caps and joins', () => {
|
|
99
|
+
const wrapper = mount(Calendar);
|
|
100
|
+
const path = wrapper.find('path');
|
|
101
|
+
|
|
102
|
+
expect(path.attributes('stroke-linecap')).toBe('round');
|
|
103
|
+
expect(path.attributes('stroke-linejoin')).toBe('round');
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
it('path has no fill (outline style)', () => {
|
|
107
|
+
const wrapper = mount(Calendar);
|
|
108
|
+
const svg = wrapper.find('svg');
|
|
109
|
+
|
|
110
|
+
expect(svg.attributes('fill')).toBe('none');
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
describe('Calendar Geometry', () => {
|
|
115
|
+
it('binding rings positioned at top', () => {
|
|
116
|
+
const wrapper = mount(Calendar);
|
|
117
|
+
const path = wrapper.find('path');
|
|
118
|
+
|
|
119
|
+
const pathData = path.attributes('d');
|
|
120
|
+
// Rings extend from y=1 to y=3.25
|
|
121
|
+
expect(pathData).toContain('1V3.25');
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
it('calendar body spans most of viewBox', () => {
|
|
125
|
+
const wrapper = mount(Calendar);
|
|
126
|
+
const path = wrapper.find('path');
|
|
127
|
+
|
|
128
|
+
const pathData = path.attributes('d');
|
|
129
|
+
// Body from y=3.25 to y=19, x=1.32568 to x=19.3257
|
|
130
|
+
expect(pathData).toContain('1.32568');
|
|
131
|
+
expect(pathData).toContain('19.3257');
|
|
132
|
+
expect(pathData).toContain('3.25');
|
|
133
|
+
expect(pathData).toContain('19');
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
it('includes header section separation', () => {
|
|
137
|
+
const wrapper = mount(Calendar);
|
|
138
|
+
const path = wrapper.find('path');
|
|
139
|
+
|
|
140
|
+
const pathData = path.attributes('d');
|
|
141
|
+
// Separator line at y=7 between header and dates
|
|
142
|
+
expect(pathData).toContain('7H17.0757');
|
|
143
|
+
expect(pathData).toContain('9.25V16.75');
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
it('date dots arranged in grid pattern', () => {
|
|
147
|
+
const wrapper = mount(Calendar);
|
|
148
|
+
const path = wrapper.find('path');
|
|
149
|
+
|
|
150
|
+
const pathData = path.attributes('d');
|
|
151
|
+
// Multiple columns and rows
|
|
152
|
+
expect(pathData).toContain('10.3257'); // Center column
|
|
153
|
+
expect(pathData).toContain('8.07568'); // Left column
|
|
154
|
+
expect(pathData).toContain('12.5757'); // Right column
|
|
155
|
+
expect(pathData).toContain('10.75'); // First row
|
|
156
|
+
expect(pathData).toContain('13H'); // Second row
|
|
157
|
+
expect(pathData).toContain('15.25'); // Third row
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
describe('Component Structure', () => {
|
|
162
|
+
it('uses appropriate dimensions for calendar icon', () => {
|
|
163
|
+
const wrapper = mount(Calendar);
|
|
164
|
+
const svg = wrapper.find('svg');
|
|
165
|
+
|
|
166
|
+
// Slightly wider than tall to accommodate calendar proportions
|
|
167
|
+
expect(svg.attributes('width')).toBe('21');
|
|
168
|
+
expect(svg.attributes('height')).toBe('20');
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
it('suitable for UI calendar representations', () => {
|
|
172
|
+
const wrapper = mount(Calendar);
|
|
173
|
+
const path = wrapper.find('path');
|
|
174
|
+
|
|
175
|
+
// Includes key calendar elements
|
|
176
|
+
const pathData = path.attributes('d');
|
|
177
|
+
expect(pathData).toContain('1V3.25'); // Binding rings
|
|
178
|
+
expect(pathData).toMatch(/H\d+\.\d+V\d+\.\d+/); // Grid structure
|
|
179
|
+
});
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
describe('Accessibility', () => {
|
|
183
|
+
it('svg is properly structured for screen readers', () => {
|
|
184
|
+
const wrapper = mount(Calendar);
|
|
185
|
+
const svg = wrapper.find('svg');
|
|
186
|
+
|
|
187
|
+
expect(svg.element.tagName.toLowerCase()).toBe('svg');
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
it('uses outline style for better contrast', () => {
|
|
191
|
+
const wrapper = mount(Calendar);
|
|
192
|
+
const path = wrapper.find('path');
|
|
193
|
+
|
|
194
|
+
// Outline style is more universally accessible
|
|
195
|
+
expect(path.attributes('stroke')).toBeTruthy();
|
|
196
|
+
expect(path.attributes('fill')).toBeFalsy();
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
describe('Component Integration', () => {
|
|
201
|
+
it('can be mounted without props', () => {
|
|
202
|
+
expect(() => {
|
|
203
|
+
mount(Calendar);
|
|
204
|
+
}).not.toThrow();
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
it('renders consistently on multiple mounts', () => {
|
|
208
|
+
const wrapper1 = mount(Calendar);
|
|
209
|
+
const wrapper2 = mount(Calendar);
|
|
210
|
+
|
|
211
|
+
expect(wrapper1.html()).toBe(wrapper2.html());
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
it('maintains calendar structure integrity', () => {
|
|
215
|
+
const wrapper = mount(Calendar);
|
|
216
|
+
const path = wrapper.find('path');
|
|
217
|
+
|
|
218
|
+
expect(path.exists()).toBe(true);
|
|
219
|
+
expect(path.attributes('d')).toBeTruthy();
|
|
220
|
+
expect(path.attributes('stroke')).toBeTruthy();
|
|
221
|
+
expect(path.attributes('stroke-width')).toBeTruthy();
|
|
222
|
+
});
|
|
223
|
+
|
|
224
|
+
it('suitable for various calendar UI contexts', () => {
|
|
225
|
+
const wrapper = mount(Calendar);
|
|
226
|
+
|
|
227
|
+
// Good size for buttons, form fields, navigation
|
|
228
|
+
expect(wrapper.find('svg').attributes('width')).toBe('21');
|
|
229
|
+
expect(wrapper.find('svg').attributes('height')).toBe('20');
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
describe('Icon Semantics', () => {
|
|
234
|
+
it('represents calendar with recognizable elements', () => {
|
|
235
|
+
const wrapper = mount(Calendar);
|
|
236
|
+
const path = wrapper.find('path');
|
|
237
|
+
|
|
238
|
+
const pathData = path.attributes('d');
|
|
239
|
+
// Key calendar features
|
|
240
|
+
expect(pathData).toMatch(/1V3\.25/); // Binding rings
|
|
241
|
+
expect(pathData).toMatch(/H\d+\.\d+V\d+\.\d+/); // Date grid
|
|
242
|
+
expect(pathData).toMatch(/C\d+/); // Rounded corners
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
it('uses standard calendar proportions', () => {
|
|
246
|
+
const wrapper = mount(Calendar);
|
|
247
|
+
const svg = wrapper.find('svg');
|
|
248
|
+
|
|
249
|
+
// Typical calendar aspect ratio (slightly wider than tall)
|
|
250
|
+
const width = parseInt(svg.attributes('width'));
|
|
251
|
+
const height = parseInt(svg.attributes('height'));
|
|
252
|
+
expect(width).toBeGreaterThan(height);
|
|
253
|
+
expect(width / height).toBeCloseTo(1.05, 1);
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
it('includes visual date indicators', () => {
|
|
257
|
+
const wrapper = mount(Calendar);
|
|
258
|
+
const path = wrapper.find('path');
|
|
259
|
+
|
|
260
|
+
const pathData = path.attributes('d');
|
|
261
|
+
// Should have multiple small date markers
|
|
262
|
+
const dateMarkers = pathData.match(/H\d+\.\d+V\d+\.\d+/g);
|
|
263
|
+
expect(dateMarkers).toBeTruthy();
|
|
264
|
+
expect(dateMarkers.length).toBeGreaterThan(5);
|
|
265
|
+
});
|
|
266
|
+
});
|
|
267
|
+
|
|
268
|
+
describe('Visual Design', () => {
|
|
269
|
+
it('provides clear calendar recognition', () => {
|
|
270
|
+
const wrapper = mount(Calendar);
|
|
271
|
+
const path = wrapper.find('path');
|
|
272
|
+
|
|
273
|
+
const pathData = path.attributes('d');
|
|
274
|
+
// Distinctive calendar elements
|
|
275
|
+
expect(pathData).toContain('1V3.25'); // Top rings
|
|
276
|
+
expect(pathData).toMatch(/\d+\.\d+H\d+\.\d+V/); // Grid pattern
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
it('uses appropriate line weight for clarity', () => {
|
|
280
|
+
const wrapper = mount(Calendar);
|
|
281
|
+
const path = wrapper.find('path');
|
|
282
|
+
|
|
283
|
+
// 1.5px stroke provides good visibility without being too heavy
|
|
284
|
+
expect(path.attributes('stroke-width')).toBe('1.5');
|
|
285
|
+
});
|
|
286
|
+
});
|
|
287
287
|
});
|