@zap-wunschlachen/wl-shared-components 1.0.38 → 1.0.40

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 +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 +33 -33
  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 +234 -232
  19. package/src/assets/css/variables.css +112 -109
  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 +54 -54
  24. package/src/components/Appointment/Card/Actions.vue +99 -99
  25. package/src/components/Appointment/Card/AnamneseNotification.css +15 -15
  26. package/src/components/Appointment/Card/AnamneseNotification.vue +23 -23
  27. package/src/components/Appointment/Card/Card.css +80 -80
  28. package/src/components/Appointment/Card/Card.vue +93 -93
  29. package/src/components/Appointment/Card/Details.css +50 -50
  30. package/src/components/Appointment/Card/Details.vue +43 -43
  31. package/src/components/Audio/Audio.vue +187 -187
  32. package/src/components/Audio/Waveform.vue +118 -118
  33. package/src/components/Button/Button.vue +174 -174
  34. package/src/components/CheckBox/CheckBox.css +214 -214
  35. package/src/components/CheckBox/Checkbox.vue +138 -138
  36. package/src/components/DateInput/DateInput.css +2 -2
  37. package/src/components/DateInput/DateInput.vue +262 -262
  38. package/src/components/Dialog/Dialog.css +6 -6
  39. package/src/components/Dialog/Dialog.vue +38 -38
  40. package/src/components/EditField/EditField.css +19 -19
  41. package/src/components/EditField/EditField.vue +202 -202
  42. package/src/components/ErrorPage/ErrorPage.css +172 -172
  43. package/src/components/IconBullet/IconBullet.vue +86 -86
  44. package/src/components/IconBullet/IconBulletList.vue +41 -41
  45. package/src/components/Icons/AdvanceAppointments.vue +153 -153
  46. package/src/components/Icons/Audio/CloudFailed.vue +20 -20
  47. package/src/components/Icons/Audio/CloudSaved.vue +21 -21
  48. package/src/components/Icons/Audio/Delete.vue +15 -15
  49. package/src/components/Icons/Audio/Pause.vue +18 -18
  50. package/src/components/Icons/Audio/Play.vue +15 -15
  51. package/src/components/Icons/{calendar.vue → Calendar.vue} +17 -17
  52. package/src/components/Icons/CalendarNotification.vue +126 -126
  53. package/src/components/Icons/Chair.vue +32 -32
  54. package/src/components/Icons/ChairNotification.vue +35 -35
  55. package/src/components/Icons/Circle.vue +66 -66
  56. package/src/components/Icons/FavIcon.vue +22 -22
  57. package/src/components/Icons/FilledCircle.vue +11 -11
  58. package/src/components/Icons/Group3.vue +46 -46
  59. package/src/components/Icons/RingNotification.vue +54 -54
  60. package/src/components/Icons/SolidArrowRight.vue +14 -14
  61. package/src/components/Icons/checkbox.vue +19 -19
  62. package/src/components/Icons/outlineChecked.vue +27 -27
  63. package/src/components/Icons/play.vue +5 -5
  64. package/src/components/Input/Input.css +187 -187
  65. package/src/components/Input/Input.vue +253 -253
  66. package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -7
  67. package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -116
  68. package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -81
  69. package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -113
  70. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -4
  71. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -99
  72. package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -130
  73. package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -3
  74. package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -50
  75. package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -53
  76. package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -162
  77. package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -102
  78. package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -152
  79. package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -33
  80. package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -75
  81. package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -92
  82. package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -49
  83. package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -126
  84. package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -97
  85. package/src/components/Laboratory/TicketCard/TicketCard.css +3 -3
  86. package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -143
  87. package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -18
  88. package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -119
  89. package/src/components/Laboratory/TimeLine/Timeline.css +4 -4
  90. package/src/components/Laboratory/TimeLine/Timeline.vue +30 -30
  91. package/src/components/Loader/Loader.css +71 -71
  92. package/src/components/MaintenanceBanner/MaintenanceBanner.css +353 -353
  93. package/src/components/MaintenanceBanner/MaintenanceBanner.vue +127 -127
  94. package/src/components/MaintenanceBanner/MaintenanceIllustration.vue +54 -54
  95. package/src/components/Modal/Modal.css +5 -5
  96. package/src/components/Modal/Modal.vue +22 -22
  97. package/src/components/NotificationBubble/NotificationBubble.css +4 -4
  98. package/src/components/NotificationBubble/NotificationBubble.vue +90 -90
  99. package/src/components/OtpInput/OtpInput.css +39 -39
  100. package/src/components/OtpInput/OtpInput.vue +151 -151
  101. package/src/components/PhoneInput/PhoneInput.css +31 -31
  102. package/src/components/PhoneInput/PhoneInput.vue +113 -113
  103. package/src/components/Select/Select.css +150 -150
  104. package/src/components/Select/Select.vue +316 -316
  105. package/src/components/TextArea/TextArea.css +3 -3
  106. package/src/components/TextArea/TextArea.vue +126 -126
  107. package/src/components/TickBox/TickBox.css +49 -49
  108. package/src/components/TickBox/TickBox.vue +126 -126
  109. package/src/components/accessibility.css +218 -218
  110. package/src/components/index.ts +29 -29
  111. package/src/constants/iconEnums.ts +3 -3
  112. package/src/i18n/i18n.ts +15 -15
  113. package/src/i18n/locales/de.json +30 -30
  114. package/src/i18n/locales/en.json +30 -30
  115. package/src/index.ts +34 -34
  116. package/src/main.ts +11 -11
  117. package/src/plugins/vuetify.ts +141 -141
  118. package/src/shims-vue.d.ts +10 -10
  119. package/src/stories/Accordion.stories.ts +650 -650
  120. package/src/stories/Audio.stories.ts +28 -28
  121. package/src/stories/Button.stories.ts +263 -263
  122. package/src/stories/CheckBox.stories.ts +348 -348
  123. package/src/stories/DateInput.stories.ts +53 -53
  124. package/src/stories/Dialog.stories.ts +147 -147
  125. package/src/stories/EditField.stories.ts +78 -78
  126. package/src/stories/IconBullet/IconBullet.stories.ts +201 -201
  127. package/src/stories/IconBullet/IconBulletList.stories.ts +275 -275
  128. package/src/stories/Input.stories.ts +351 -351
  129. package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -260
  130. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -176
  131. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -119
  132. package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -320
  133. package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -335
  134. package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -82
  135. package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -198
  136. package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -204
  137. package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -144
  138. package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -186
  139. package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -111
  140. package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -48
  141. package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -261
  142. package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -234
  143. package/src/stories/Laboratory/TagLabel.stories.ts +418 -418
  144. package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -234
  145. package/src/stories/Laboratory/Timeline.stories.ts +403 -403
  146. package/src/stories/NotificationBubble.stories.ts +194 -194
  147. package/src/stories/OtpInput.stories.ts +100 -100
  148. package/src/stories/PhoneInput.stories.ts +52 -52
  149. package/src/stories/Select.stories.ts +419 -419
  150. package/src/stories/TextArea.stories.ts +112 -112
  151. package/src/stories/TickBox.stories.ts +294 -294
  152. package/src/stories/v-icon.stories.ts +91 -91
  153. package/src/utils/index.ts +116 -109
  154. package/src/vite-env.d.ts +1 -1
  155. package/tests/e2e/README.md +220 -220
  156. package/tests/e2e/accessibility.spec.ts +638 -638
  157. package/tests/e2e/accordion.spec.ts +42 -42
  158. package/tests/e2e/additional-components.spec.ts +437 -437
  159. package/tests/e2e/all-components.spec.ts +135 -135
  160. package/tests/e2e/appointment-card.spec.ts +816 -816
  161. package/tests/e2e/button-fixed.spec.ts +58 -58
  162. package/tests/e2e/button.spec.ts +76 -76
  163. package/tests/e2e/checkbox.spec.ts +50 -50
  164. package/tests/e2e/date-input.spec.ts +46 -46
  165. package/tests/e2e/debug.spec.ts +51 -51
  166. package/tests/e2e/dialog.spec.ts +58 -58
  167. package/tests/e2e/input.spec.ts +55 -55
  168. package/tests/e2e/laboratory-components.spec.ts +320 -320
  169. package/tests/e2e/otp-input.spec.ts +50 -50
  170. package/tests/e2e/select.spec.ts +52 -52
  171. package/tests/e2e/storybook-utils.ts +59 -59
  172. package/tests/e2e/test-basic.spec.ts +33 -33
  173. package/tests/e2e/visual-regression.spec.ts +350 -350
  174. package/tests/unit/accessibility/component-a11y.spec.ts +469 -469
  175. package/tests/unit/components/Accordion/AccordionGroup.spec.ts +228 -228
  176. package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
  177. package/tests/unit/components/Accordion/AccordionItem.spec.ts +292 -292
  178. package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
  179. package/tests/unit/components/Appointment/AnamneseNotification.spec.ts +176 -176
  180. package/tests/unit/components/Appointment/Card/Actions.spec.ts +407 -407
  181. package/tests/unit/components/Appointment/Card/Card.spec.ts +485 -485
  182. package/tests/unit/components/Appointment/Card/Details.spec.ts +397 -397
  183. package/tests/unit/components/Audio/Audio.spec.ts +403 -403
  184. package/tests/unit/components/Audio/Waveform.spec.ts +483 -483
  185. package/tests/unit/components/Background/Background.spec.ts +177 -177
  186. package/tests/unit/components/Core/Button.spec.ts +336 -336
  187. package/tests/unit/components/Core/Checkbox.spec.ts +544 -544
  188. package/tests/unit/components/Core/DateInput.spec.ts +690 -690
  189. package/tests/unit/components/Core/Dialog.spec.ts +485 -485
  190. package/tests/unit/components/Core/EditField.spec.ts +782 -782
  191. package/tests/unit/components/Core/Input.spec.ts +512 -512
  192. package/tests/unit/components/Core/Modal.spec.ts +518 -518
  193. package/tests/unit/components/Core/NotificationBubble.spec.ts +606 -606
  194. package/tests/unit/components/Core/OtpInput.spec.ts +708 -708
  195. package/tests/unit/components/Core/PhoneInput.spec.ts +619 -619
  196. package/tests/unit/components/Core/Select.spec.ts +712 -712
  197. package/tests/unit/components/Core/TextArea.spec.ts +565 -565
  198. package/tests/unit/components/Core/TickBox.spec.ts +779 -779
  199. package/tests/unit/components/ErrorPage/ErrorPage.spec.ts +313 -313
  200. package/tests/unit/components/ErrorPage/ErrorPageLogo.spec.ts +153 -153
  201. package/tests/unit/components/IconBullet/IconBullet.spec.ts +356 -356
  202. package/tests/unit/components/IconBullet/IconBulletList.spec.ts +371 -371
  203. package/tests/unit/components/Icons/AdvanceAppointments.spec.ts +61 -61
  204. package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +108 -108
  205. package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +149 -149
  206. package/tests/unit/components/Icons/Audio/Delete.spec.ts +158 -158
  207. package/tests/unit/components/Icons/Audio/Pause.spec.ts +208 -208
  208. package/tests/unit/components/Icons/Audio/Play.spec.ts +217 -217
  209. package/tests/unit/components/Icons/CalendarNotification.spec.ts +186 -186
  210. package/tests/unit/components/Icons/Chair.spec.ts +234 -234
  211. package/tests/unit/components/Icons/ChairNotification.spec.ts +311 -311
  212. package/tests/unit/components/Icons/Circle.spec.ts +255 -255
  213. package/tests/unit/components/Icons/FavIcon.spec.ts +251 -251
  214. package/tests/unit/components/Icons/FilledCircle.spec.ts +274 -274
  215. package/tests/unit/components/Icons/Group3.spec.ts +355 -355
  216. package/tests/unit/components/Icons/Logo.spec.ts +228 -228
  217. package/tests/unit/components/Icons/MiniLogo.spec.ts +38 -38
  218. package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
  219. package/tests/unit/components/Icons/SolidArrowRight.spec.ts +49 -49
  220. package/tests/unit/components/Icons/calendar.spec.ts +286 -286
  221. package/tests/unit/components/Icons/checkbox.spec.ts +315 -315
  222. package/tests/unit/components/Icons/outlineChecked.spec.ts +434 -434
  223. package/tests/unit/components/Icons/play.spec.ts +308 -308
  224. package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +167 -167
  225. package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +179 -179
  226. package/tests/unit/components/Laboratory/ChatMessage.spec.ts +263 -263
  227. package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +282 -282
  228. package/tests/unit/components/Laboratory/ChatNotification.spec.ts +256 -256
  229. package/tests/unit/components/Laboratory/DocumentCard.spec.ts +228 -228
  230. package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +236 -236
  231. package/tests/unit/components/Laboratory/InfoCard.spec.ts +308 -308
  232. package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +251 -251
  233. package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +290 -290
  234. package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +275 -275
  235. package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +288 -288
  236. package/tests/unit/components/Laboratory/StatusNotification.spec.ts +296 -296
  237. package/tests/unit/components/Laboratory/TagLabel.spec.ts +353 -353
  238. package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +377 -377
  239. package/tests/unit/components/Laboratory/TicketCard.spec.ts +351 -351
  240. package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +381 -381
  241. package/tests/unit/components/Laboratory/Timeline.spec.ts +419 -419
  242. package/tests/unit/components/Loader/Loader.spec.ts +197 -197
  243. package/tests/unit/components/MaintenanceBanner/MaintenanceBanner.spec.ts +302 -302
  244. package/tests/unit/constants/iconEnums.spec.ts +39 -39
  245. package/tests/unit/i18n/i18n.spec.ts +88 -88
  246. package/tests/unit/plugins/vuetify.spec.ts +220 -220
  247. package/tests/unit/setup.ts +189 -189
  248. package/tests/unit/src/components/index.spec.ts.skip +192 -192
  249. package/tests/unit/src/index.spec.ts.skip +182 -182
  250. package/tests/unit/src/main.spec.ts +151 -151
  251. package/tests/unit/utils/accessibility.spec.ts +318 -318
  252. package/tsconfig.json +26 -26
  253. package/vite.config.ts +29 -29
  254. package/vitest.config.ts +83 -83
@@ -1,214 +1,214 @@
1
- /* Normal State */
2
-
3
- /* Label */
4
- .label {
5
- display: flex;
6
- align-items: center;
7
- gap: 12px;
8
- font-size: 0.875rem;
9
- line-height: 15.6px;
10
- letter-spacing: -0.13px;
11
- color: var(--Dental-Blue-0);
12
- cursor: pointer;
13
- }
14
-
15
- /* Checkbox Container */
16
- .checkbox-container {
17
- display: flex;
18
- align-items: center;
19
- justify-content: center;
20
- }
21
-
22
- /* Checkbox (Normal) */
23
- .input-checkbox {
24
- appearance: none;
25
- background-color: white;
26
- margin: 0;
27
- padding: 0;
28
- /* Width and height will be set by density classes */
29
- border: 1px solid;
30
- border-radius: 4px;
31
- display: grid;
32
- place-content: center;
33
- transform: translateY(-0.075em);
34
- border-color: var(--Soft-Concrete-2);
35
- cursor: pointer;
36
- }
37
-
38
- .input-checkbox:hover {
39
- border-width: 2px;
40
- background-color: var(--Dental-Light-Blue--2);
41
- border-color: var(--Dental-Blue-0);
42
- }
43
-
44
- .input-checkbox::before {
45
- content: '';
46
- /* Width and height will be set by density classes */
47
- transform: scale(0);
48
- transition: 120ms transform ease-in-out;
49
- box-shadow: inset 1em 1em var(--Dental-Blue-0);
50
- background-color: var(--Dental-Blue-0);
51
- border-radius: 2px;
52
- }
53
-
54
- .input-checkbox:checked::before {
55
- transform: scale(1);
56
- background-color: var(--Dental-Blue-0);
57
- }
58
-
59
- .input-checkbox:checked {
60
- border-width: 2px;
61
- border-color: var(--Dental-Blue-0);
62
- }
63
-
64
- .input-checkbox:hover::before {
65
- border-color: var(--Dental-Blue-0);
66
- }
67
-
68
- /* Density Levels */
69
-
70
- /* Comfortable */
71
- .density-comfortable.input-checkbox {
72
- width: 32px;
73
- height: 32px;
74
- }
75
-
76
- .density-comfortable.input-checkbox::before {
77
- width: 20px;
78
- height: 20px;
79
- }
80
-
81
- /* Default */
82
- .density-default.input-checkbox {
83
- width: 28px;
84
- height: 28px;
85
- }
86
-
87
- .density-default.input-checkbox::before {
88
- width: 16px;
89
- height: 16px;
90
- }
91
-
92
- /* Compact */
93
- .density-compact.input-checkbox {
94
- width: 24px;
95
- height: 24px;
96
- }
97
-
98
- .density-compact.input-checkbox::before {
99
- width: 12px;
100
- height: 12px;
101
- }
102
-
103
- /* Success State */
104
-
105
- /* Success Label */
106
- .label-success {
107
- color: var(--Success-Green-1);
108
- }
109
-
110
- /* Success Checkbox */
111
- .input-success {
112
- border-color: var(--Success-Green-0);
113
- color: var(--Success-Green-0);
114
- }
115
-
116
- .input-success:hover {
117
- border-color: var(--Success-Green-0);
118
- background-color: var(--Success-Green--1);
119
- }
120
-
121
- .input-success.input-checkbox:checked {
122
- border-color: var(--Success-Green-0);
123
- }
124
-
125
- .input-success.input-checkbox::before {
126
- box-shadow: inset 1em 1em var(--Success-Green-0);
127
- background-color: var(--Success-Green-0);
128
- }
129
-
130
- /* Error State */
131
-
132
- /* Error Label */
133
- .label-error {
134
- color: var(--Error-Red-0);
135
- }
136
-
137
- /* Error Checkbox */
138
- .input-error {
139
- border-color: var(--Error-Red-0);
140
- color: var(--Error-Red-0);
141
- }
142
-
143
- .input-error:hover {
144
- border-color: var(--Error-Red-0);
145
- background-color: var(--Light-Gum--3);
146
- }
147
-
148
- .input-error.input-checkbox:checked {
149
- border-color: var(--Error-Red-0);
150
- }
151
-
152
- .input-error.input-checkbox::before {
153
- box-shadow: inset 1em 1em var(--Error-Red-0);
154
- background-color: var(--Error-Red-0);
155
- }
156
-
157
- /* Disabled State */
158
-
159
- /* Disabled Label */
160
- .label-disabled {
161
- color: var(--Soft-Concrete-2);
162
- opacity: 0.5;
163
- cursor: not-allowed;
164
- }
165
-
166
- /* Disabled Checkbox */
167
- .input-disabled {
168
- opacity: 0.5;
169
- cursor: not-allowed;
170
- }
171
-
172
- .input-checkbox:disabled::before {
173
- border-color: var(--Dental-Blue-0);
174
- }
175
-
176
- .input-disabled.input-checkbox:hover {
177
- border-width: 0.5px;
178
- background-color: white;
179
- border-color: var(--Soft-Concrete-2);
180
- }
181
-
182
- /* Label Text */
183
- .label-text {
184
- font-weight: 300;
185
- }
186
-
187
- /* =====================================================
188
- ACCESSIBILITY: Focus Indicators
189
- WCAG 2.4.7: Focus Visible (Level AA)
190
- ===================================================== */
191
-
192
- .input-checkbox:focus-visible {
193
- outline: 2px solid var(--Dental-Blue-0);
194
- outline-offset: 2px;
195
- }
196
-
197
- .input-success:focus-visible {
198
- outline-color: var(--Success-Green-0);
199
- }
200
-
201
- .input-error:focus-visible {
202
- outline-color: var(--Error-Red-0);
203
- }
204
-
205
- /* High contrast mode support */
206
- @media (forced-colors: active) {
207
- .input-checkbox {
208
- border: 2px solid currentColor;
209
- }
210
-
211
- .input-checkbox:checked::before {
212
- background-color: currentColor;
213
- }
214
- }
1
+ /* Normal State */
2
+
3
+ /* Label */
4
+ .label {
5
+ display: flex;
6
+ align-items: center;
7
+ gap: 12px;
8
+ font-size: 0.875rem;
9
+ line-height: 15.6px;
10
+ letter-spacing: -0.13px;
11
+ color: var(--Dental-Blue-0);
12
+ cursor: pointer;
13
+ }
14
+
15
+ /* Checkbox Container */
16
+ .checkbox-container {
17
+ display: flex;
18
+ align-items: center;
19
+ justify-content: center;
20
+ }
21
+
22
+ /* Checkbox (Normal) */
23
+ .input-checkbox {
24
+ appearance: none;
25
+ background-color: white;
26
+ margin: 0;
27
+ padding: 0;
28
+ /* Width and height will be set by density classes */
29
+ border: 1px solid;
30
+ border-radius: 4px;
31
+ display: grid;
32
+ place-content: center;
33
+ transform: translateY(-0.075em);
34
+ border-color: var(--Soft-Concrete-2);
35
+ cursor: pointer;
36
+ }
37
+
38
+ .input-checkbox:hover {
39
+ border-width: 2px;
40
+ background-color: var(--Dental-Light-Blue--2);
41
+ border-color: var(--Dental-Blue-0);
42
+ }
43
+
44
+ .input-checkbox::before {
45
+ content: '';
46
+ /* Width and height will be set by density classes */
47
+ transform: scale(0);
48
+ transition: 120ms transform ease-in-out;
49
+ box-shadow: inset 1em 1em var(--Dental-Blue-0);
50
+ background-color: var(--Dental-Blue-0);
51
+ border-radius: 2px;
52
+ }
53
+
54
+ .input-checkbox:checked::before {
55
+ transform: scale(1);
56
+ background-color: var(--Dental-Blue-0);
57
+ }
58
+
59
+ .input-checkbox:checked {
60
+ border-width: 2px;
61
+ border-color: var(--Dental-Blue-0);
62
+ }
63
+
64
+ .input-checkbox:hover::before {
65
+ border-color: var(--Dental-Blue-0);
66
+ }
67
+
68
+ /* Density Levels */
69
+
70
+ /* Comfortable */
71
+ .density-comfortable.input-checkbox {
72
+ width: 32px;
73
+ height: 32px;
74
+ }
75
+
76
+ .density-comfortable.input-checkbox::before {
77
+ width: 20px;
78
+ height: 20px;
79
+ }
80
+
81
+ /* Default */
82
+ .density-default.input-checkbox {
83
+ width: 28px;
84
+ height: 28px;
85
+ }
86
+
87
+ .density-default.input-checkbox::before {
88
+ width: 16px;
89
+ height: 16px;
90
+ }
91
+
92
+ /* Compact */
93
+ .density-compact.input-checkbox {
94
+ width: 24px;
95
+ height: 24px;
96
+ }
97
+
98
+ .density-compact.input-checkbox::before {
99
+ width: 12px;
100
+ height: 12px;
101
+ }
102
+
103
+ /* Success State */
104
+
105
+ /* Success Label */
106
+ .label-success {
107
+ color: var(--Success-Green-1);
108
+ }
109
+
110
+ /* Success Checkbox */
111
+ .input-success {
112
+ border-color: var(--Success-Green-0);
113
+ color: var(--Success-Green-0);
114
+ }
115
+
116
+ .input-success:hover {
117
+ border-color: var(--Success-Green-0);
118
+ background-color: var(--Success-Green--1);
119
+ }
120
+
121
+ .input-success.input-checkbox:checked {
122
+ border-color: var(--Success-Green-0);
123
+ }
124
+
125
+ .input-success.input-checkbox::before {
126
+ box-shadow: inset 1em 1em var(--Success-Green-0);
127
+ background-color: var(--Success-Green-0);
128
+ }
129
+
130
+ /* Error State */
131
+
132
+ /* Error Label */
133
+ .label-error {
134
+ color: var(--Error-Red-0);
135
+ }
136
+
137
+ /* Error Checkbox */
138
+ .input-error {
139
+ border-color: var(--Error-Red-0);
140
+ color: var(--Error-Red-0);
141
+ }
142
+
143
+ .input-error:hover {
144
+ border-color: var(--Error-Red-0);
145
+ background-color: var(--Light-Gum--3);
146
+ }
147
+
148
+ .input-error.input-checkbox:checked {
149
+ border-color: var(--Error-Red-0);
150
+ }
151
+
152
+ .input-error.input-checkbox::before {
153
+ box-shadow: inset 1em 1em var(--Error-Red-0);
154
+ background-color: var(--Error-Red-0);
155
+ }
156
+
157
+ /* Disabled State */
158
+
159
+ /* Disabled Label */
160
+ .label-disabled {
161
+ color: var(--Soft-Concrete-2);
162
+ opacity: 0.5;
163
+ cursor: not-allowed;
164
+ }
165
+
166
+ /* Disabled Checkbox */
167
+ .input-disabled {
168
+ opacity: 0.5;
169
+ cursor: not-allowed;
170
+ }
171
+
172
+ .input-checkbox:disabled::before {
173
+ border-color: var(--Dental-Blue-0);
174
+ }
175
+
176
+ .input-disabled.input-checkbox:hover {
177
+ border-width: 0.5px;
178
+ background-color: white;
179
+ border-color: var(--Soft-Concrete-2);
180
+ }
181
+
182
+ /* Label Text */
183
+ .label-text {
184
+ font-weight: 300;
185
+ }
186
+
187
+ /* =====================================================
188
+ ACCESSIBILITY: Focus Indicators
189
+ WCAG 2.4.7: Focus Visible (Level AA)
190
+ ===================================================== */
191
+
192
+ .input-checkbox:focus-visible {
193
+ outline: 2px solid var(--Dental-Blue-0);
194
+ outline-offset: 2px;
195
+ }
196
+
197
+ .input-success:focus-visible {
198
+ outline-color: var(--Success-Green-0);
199
+ }
200
+
201
+ .input-error:focus-visible {
202
+ outline-color: var(--Error-Red-0);
203
+ }
204
+
205
+ /* High contrast mode support */
206
+ @media (forced-colors: active) {
207
+ .input-checkbox {
208
+ border: 2px solid currentColor;
209
+ }
210
+
211
+ .input-checkbox:checked::before {
212
+ background-color: currentColor;
213
+ }
214
+ }