@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.
Files changed (246) 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 +34 -176
  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 +107 -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 +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 +117 -117
  33. package/src/components/Background/Background.css +39 -0
  34. package/src/components/Background/Background.vue +19 -0
  35. package/src/components/Background/WhiteCocoonBackground.vue +9 -0
  36. package/src/components/Background/WunschlachenBackground.vue +11 -0
  37. package/src/components/Button/Button.vue +119 -119
  38. package/src/components/CheckBox/CheckBox.css +185 -185
  39. package/src/components/CheckBox/Checkbox.vue +130 -130
  40. package/src/components/DateInput/DateInput.css +2 -2
  41. package/src/components/DateInput/DateInput.vue +262 -262
  42. package/src/components/Dialog/Dialog.css +6 -6
  43. package/src/components/Dialog/Dialog.vue +29 -29
  44. package/src/components/EditField/EditField.css +19 -19
  45. package/src/components/EditField/EditField.vue +202 -202
  46. package/src/components/ErrorPage/ErrorPage.css +124 -0
  47. package/src/components/ErrorPage/ErrorPage.vue +45 -0
  48. package/src/components/ErrorPage/ErrorPageLogo.vue +26 -0
  49. package/src/components/IconBullet/IconBullet.vue +86 -86
  50. package/src/components/IconBullet/IconBulletList.vue +41 -41
  51. package/src/components/Icons/AdvanceAppointments.vue +153 -153
  52. package/src/components/Icons/Audio/CloudFailed.vue +20 -20
  53. package/src/components/Icons/Audio/CloudSaved.vue +21 -21
  54. package/src/components/Icons/Audio/Delete.vue +15 -15
  55. package/src/components/Icons/Audio/Pause.vue +18 -18
  56. package/src/components/Icons/Audio/Play.vue +15 -15
  57. package/src/components/Icons/CalendarNotification.vue +126 -126
  58. package/src/components/Icons/Chair.vue +32 -32
  59. package/src/components/Icons/ChairNotification.vue +35 -35
  60. package/src/components/Icons/Circle.vue +66 -66
  61. package/src/components/Icons/FavIcon.vue +22 -22
  62. package/src/components/Icons/FilledCircle.vue +11 -11
  63. package/src/components/Icons/Group3.vue +46 -46
  64. package/src/components/Icons/Logo.vue +108 -0
  65. package/src/components/Icons/RingNotification.vue +54 -54
  66. package/src/components/Icons/SolidArrowRight.vue +14 -14
  67. package/src/components/Icons/calendar.vue +17 -17
  68. package/src/components/Icons/checkbox.vue +19 -19
  69. package/src/components/Icons/outlineChecked.vue +27 -27
  70. package/src/components/Icons/play.vue +5 -5
  71. package/src/components/Input/Input.css +187 -187
  72. package/src/components/Input/Input.vue +247 -247
  73. package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -7
  74. package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -116
  75. package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -81
  76. package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -113
  77. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -4
  78. package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -99
  79. package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -130
  80. package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -3
  81. package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -50
  82. package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -53
  83. package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -162
  84. package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -102
  85. package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -152
  86. package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -33
  87. package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -75
  88. package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -92
  89. package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -49
  90. package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -126
  91. package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -97
  92. package/src/components/Laboratory/TicketCard/TicketCard.css +3 -3
  93. package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -143
  94. package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -18
  95. package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -119
  96. package/src/components/Laboratory/TimeLine/Timeline.css +4 -4
  97. package/src/components/Laboratory/TimeLine/Timeline.vue +30 -30
  98. package/src/components/Loader/Loader.css +51 -51
  99. package/src/components/MaintenanceBanner/MaintenanceBanner.css +289 -0
  100. package/src/components/MaintenanceBanner/MaintenanceBanner.vue +127 -0
  101. package/src/components/MaintenanceBanner/MaintenanceIllustration.vue +54 -0
  102. package/src/components/Modal/Modal.css +5 -5
  103. package/src/components/Modal/Modal.vue +22 -22
  104. package/src/components/NotificationBubble/NotificationBubble.css +4 -4
  105. package/src/components/NotificationBubble/NotificationBubble.vue +90 -90
  106. package/src/components/OtpInput/OtpInput.css +39 -39
  107. package/src/components/OtpInput/OtpInput.vue +143 -143
  108. package/src/components/PhoneInput/PhoneInput.css +31 -31
  109. package/src/components/PhoneInput/PhoneInput.vue +113 -113
  110. package/src/components/Select/Select.css +150 -150
  111. package/src/components/Select/Select.vue +315 -304
  112. package/src/components/TextArea/TextArea.css +3 -3
  113. package/src/components/TextArea/TextArea.vue +126 -126
  114. package/src/components/TickBox/TickBox.css +49 -49
  115. package/src/components/TickBox/TickBox.vue +126 -126
  116. package/src/components/index.ts +26 -24
  117. package/src/constants/iconEnums.ts +3 -3
  118. package/src/i18n/i18n.ts +15 -15
  119. package/src/i18n/locales/de.json +30 -30
  120. package/src/i18n/locales/en.json +30 -30
  121. package/src/index.ts +34 -34
  122. package/src/main.ts +11 -11
  123. package/src/plugins/vuetify.ts +139 -131
  124. package/src/shims-vue.d.ts +10 -10
  125. package/src/stories/Accordion.stories.ts +650 -650
  126. package/src/stories/Audio.stories.ts +28 -28
  127. package/src/stories/Button.stories.ts +263 -263
  128. package/src/stories/CheckBox.stories.ts +348 -348
  129. package/src/stories/DateInput.stories.ts +53 -53
  130. package/src/stories/Dialog.stories.ts +147 -147
  131. package/src/stories/EditField.stories.ts +78 -78
  132. package/src/stories/IconBullet/IconBullet.stories.ts +201 -201
  133. package/src/stories/IconBullet/IconBulletList.stories.ts +275 -275
  134. package/src/stories/Input.stories.ts +351 -351
  135. package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -260
  136. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -176
  137. package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -119
  138. package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -320
  139. package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -335
  140. package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -82
  141. package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -198
  142. package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -204
  143. package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -144
  144. package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -186
  145. package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -111
  146. package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -48
  147. package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -261
  148. package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -234
  149. package/src/stories/Laboratory/TagLabel.stories.ts +418 -418
  150. package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -234
  151. package/src/stories/Laboratory/Timeline.stories.ts +403 -403
  152. package/src/stories/NotificationBubble.stories.ts +194 -194
  153. package/src/stories/OtpInput.stories.ts +100 -100
  154. package/src/stories/PhoneInput.stories.ts +52 -52
  155. package/src/stories/Select.stories.ts +419 -419
  156. package/src/stories/TextArea.stories.ts +112 -112
  157. package/src/stories/TickBox.stories.ts +294 -294
  158. package/src/stories/v-icon.stories.ts +91 -91
  159. package/src/utils/index.ts +106 -100
  160. package/src/vite-env.d.ts +1 -1
  161. package/tests/e2e/README.md +220 -220
  162. package/tests/e2e/accessibility.spec.ts +638 -638
  163. package/tests/e2e/accordion.spec.ts +42 -42
  164. package/tests/e2e/additional-components.spec.ts +437 -437
  165. package/tests/e2e/all-components.spec.ts +135 -135
  166. package/tests/e2e/appointment-card.spec.ts +816 -816
  167. package/tests/e2e/button-fixed.spec.ts +58 -58
  168. package/tests/e2e/button.spec.ts +76 -76
  169. package/tests/e2e/checkbox.spec.ts +50 -50
  170. package/tests/e2e/date-input.spec.ts +46 -46
  171. package/tests/e2e/debug.spec.ts +51 -51
  172. package/tests/e2e/dialog.spec.ts +58 -58
  173. package/tests/e2e/input.spec.ts +55 -55
  174. package/tests/e2e/laboratory-components.spec.ts +320 -320
  175. package/tests/e2e/otp-input.spec.ts +50 -50
  176. package/tests/e2e/select.spec.ts +52 -52
  177. package/tests/e2e/storybook-utils.ts +59 -59
  178. package/tests/e2e/test-basic.spec.ts +33 -33
  179. package/tests/e2e/visual-regression.spec.ts +350 -350
  180. package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
  181. package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
  182. package/tests/unit/components/Appointment/Card/Actions.spec.ts +407 -407
  183. package/tests/unit/components/Appointment/Card/Card.spec.ts +485 -485
  184. package/tests/unit/components/Appointment/Card/Details.spec.ts +397 -397
  185. package/tests/unit/components/Audio/Audio.spec.ts +403 -403
  186. package/tests/unit/components/Audio/Waveform.spec.ts +483 -483
  187. package/tests/unit/components/Core/Button.spec.ts +336 -336
  188. package/tests/unit/components/Core/Checkbox.spec.ts +544 -544
  189. package/tests/unit/components/Core/DateInput.spec.ts +690 -690
  190. package/tests/unit/components/Core/Dialog.spec.ts +485 -485
  191. package/tests/unit/components/Core/EditField.spec.ts +782 -782
  192. package/tests/unit/components/Core/Input.spec.ts +512 -512
  193. package/tests/unit/components/Core/Modal.spec.ts +518 -518
  194. package/tests/unit/components/Core/NotificationBubble.spec.ts +606 -606
  195. package/tests/unit/components/Core/OtpInput.spec.ts +708 -708
  196. package/tests/unit/components/Core/PhoneInput.spec.ts +619 -619
  197. package/tests/unit/components/Core/Select.spec.ts +712 -712
  198. package/tests/unit/components/Core/TextArea.spec.ts +565 -565
  199. package/tests/unit/components/Core/TickBox.spec.ts +779 -779
  200. package/tests/unit/components/IconBullet/IconBullet.spec.ts +356 -356
  201. package/tests/unit/components/IconBullet/IconBulletList.spec.ts +371 -371
  202. package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +108 -108
  203. package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +149 -149
  204. package/tests/unit/components/Icons/Audio/Delete.spec.ts +158 -158
  205. package/tests/unit/components/Icons/Audio/Pause.spec.ts +208 -208
  206. package/tests/unit/components/Icons/Audio/Play.spec.ts +217 -217
  207. package/tests/unit/components/Icons/CalendarNotification.spec.ts +186 -186
  208. package/tests/unit/components/Icons/Chair.spec.ts +234 -234
  209. package/tests/unit/components/Icons/ChairNotification.spec.ts +311 -311
  210. package/tests/unit/components/Icons/Circle.spec.ts +255 -255
  211. package/tests/unit/components/Icons/FavIcon.spec.ts +251 -251
  212. package/tests/unit/components/Icons/FilledCircle.spec.ts +274 -274
  213. package/tests/unit/components/Icons/Group3.spec.ts +355 -355
  214. package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
  215. package/tests/unit/components/Icons/calendar.spec.ts +286 -286
  216. package/tests/unit/components/Icons/checkbox.spec.ts +315 -315
  217. package/tests/unit/components/Icons/outlineChecked.spec.ts +434 -434
  218. package/tests/unit/components/Icons/play.spec.ts +308 -308
  219. package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +167 -167
  220. package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +179 -179
  221. package/tests/unit/components/Laboratory/ChatMessage.spec.ts +263 -263
  222. package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +282 -282
  223. package/tests/unit/components/Laboratory/ChatNotification.spec.ts +256 -256
  224. package/tests/unit/components/Laboratory/DocumentCard.spec.ts +228 -228
  225. package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +236 -236
  226. package/tests/unit/components/Laboratory/InfoCard.spec.ts +308 -308
  227. package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +251 -251
  228. package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +290 -290
  229. package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +275 -275
  230. package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +288 -288
  231. package/tests/unit/components/Laboratory/StatusNotification.spec.ts +296 -296
  232. package/tests/unit/components/Laboratory/TagLabel.spec.ts +353 -353
  233. package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +377 -377
  234. package/tests/unit/components/Laboratory/TicketCard.spec.ts +351 -351
  235. package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +381 -381
  236. package/tests/unit/components/Laboratory/Timeline.spec.ts +419 -419
  237. package/tests/unit/constants/iconEnums.spec.ts +39 -39
  238. package/tests/unit/i18n/i18n.spec.ts +88 -88
  239. package/tests/unit/plugins/vuetify.spec.ts +220 -220
  240. package/tests/unit/setup.ts +189 -189
  241. package/tests/unit/src/components/index.spec.ts.skip +192 -192
  242. package/tests/unit/src/index.spec.ts.skip +182 -182
  243. package/tests/unit/src/main.spec.ts +151 -151
  244. package/tsconfig.json +26 -26
  245. package/vite.config.ts +29 -29
  246. package/vitest.config.ts +83 -83
@@ -1,144 +1,144 @@
1
- <template>
2
- <form class="wl-otp-input" @submit.prevent="props.submitFn" aria-labelledby="page-heading"
3
- :aria-describedby="error ? 'form-error' : undefined" data-testid="root">
4
- <div class="title-container">
5
- <h2 id="page-heading" ref="heading">{{ t('wl.otp_input.enter_sms_code') }}</h2>
6
- <p>{{ t('wl.otp_input.code_was_sent', { phoneNumber }) }}</p>
7
- </div>
8
-
9
- <div class="input-container">
10
- <v-otp-input
11
- v-model="internalValue"
12
- autofocus
13
- rounded="lg"
14
- :loading="loading"
15
- :error="error"
16
- :focus-all="error"
17
- :focused="error"
18
- @update:model-value="onResetError"
19
- type="number"
20
- />
21
- </div>
22
-
23
- <div class="message-container">
24
- <p :id="error ? 'form-error' : 'form-success'" :style="statusMessageStyle"
25
- :role="error ? 'alert' : 'status'"
26
- :aria-live="error ? 'assertive' : 'polite'" aria-atomic="true">
27
- {{ message }}
28
- </p>
29
- </div>
30
-
31
- <div class="button-container">
32
- <slot name="buttons">
33
- <Button :label="t('wl.otp_input.confirm')" :disabled="disableSubmitBtn" width="226" @click="onSubmit" type="submit" />
34
- <Button :label="t('wl.otp_input.resend')" variant='outlined' :disabled="disableResendBtn" width="226" @click="onResend" />
35
- </slot>
36
- </div>
37
- </form>
38
- </template>
39
-
40
- <script setup lang="ts">
41
- import { ref, computed, watch, type CSSProperties, PropType } from 'vue';
42
- import './OtpInput.css';
43
- import Button from '../Button/Button.vue';
44
- import { useI18n } from 'vue-i18n';
45
-
46
- const { t } = useI18n();
47
-
48
- const props = defineProps({
49
- phoneNumber: {
50
- type: String,
51
- required: true
52
- },
53
-
54
- message: {
55
- type: String,
56
- default: ''
57
- },
58
-
59
- otpState: {
60
- type: String,
61
- default: 'default'
62
- },
63
-
64
- submitFn: {
65
- type: Function,
66
- required: true
67
- },
68
-
69
- resendFn: {
70
- type: Function,
71
- required: true
72
- },
73
-
74
- loading: {
75
- type: Boolean,
76
- default: false
77
- },
78
-
79
- colors: {
80
- type: Object as PropType<{
81
- error?: string;
82
- success?: string;
83
- }>,
84
- default: () => ({
85
- error: 'var(--Error-Red-0)',
86
- success: 'var(--Success-Green-0)'
87
- })
88
- },
89
- disableSubmitBtn: {
90
- type: Boolean,
91
- default: false
92
- },
93
- disableResendBtn: {
94
- type: Boolean,
95
- default: false
96
- }
97
- });
98
-
99
- enum ValidationState {
100
- DEFAULT = "default",
101
- ERROR = "error",
102
- SUCCESS = "success",
103
- }
104
-
105
- const emit = defineEmits([
106
- 'update:modelValue'
107
- ]);
108
-
109
- const state = computed(() => localOtpState.value as ValidationState);
110
- const error = computed(() => state.value === ValidationState.ERROR);
111
- const loading = computed(() => props.loading);
112
- const internalValue = ref('')
113
- const localOtpState = ref(props.otpState)
114
-
115
- const statusMessageStyle = computed<CSSProperties>(() => ({
116
- visibility: state.value === ValidationState.DEFAULT ? 'hidden' : 'visible',
117
- color: state.value === ValidationState.ERROR
118
- ? `${props.colors.error} !important`
119
- : `${props.colors.success} !important`,
120
- minHeight: '1.5em'
121
- }));
122
-
123
- watch(() => props.otpState, (newVal) => {
124
- localOtpState.value = newVal;
125
- });
126
-
127
- watch(internalValue, () => {
128
- emit('update:modelValue', internalValue.value)
129
- }, { immediate: true })
130
-
131
- function onSubmit() {
132
- props.submitFn();
133
- }
134
-
135
- function onResend() {
136
- internalValue.value = '';
137
- props.resendFn();
138
- }
139
-
140
- function onResetError(){
141
- localOtpState.value = ValidationState.DEFAULT;
142
- }
143
-
1
+ <template>
2
+ <form class="wl-otp-input" @submit.prevent="props.submitFn" aria-labelledby="page-heading"
3
+ :aria-describedby="error ? 'form-error' : undefined" data-testid="root">
4
+ <div class="title-container">
5
+ <h2 id="page-heading" ref="heading">{{ t('wl.otp_input.enter_sms_code') }}</h2>
6
+ <p>{{ t('wl.otp_input.code_was_sent', { phoneNumber }) }}</p>
7
+ </div>
8
+
9
+ <div class="input-container">
10
+ <v-otp-input
11
+ v-model="internalValue"
12
+ autofocus
13
+ rounded="lg"
14
+ :loading="loading"
15
+ :error="error"
16
+ :focus-all="error"
17
+ :focused="error"
18
+ @update:model-value="onResetError"
19
+ type="number"
20
+ />
21
+ </div>
22
+
23
+ <div class="message-container">
24
+ <p :id="error ? 'form-error' : 'form-success'" :style="statusMessageStyle"
25
+ :role="error ? 'alert' : 'status'"
26
+ :aria-live="error ? 'assertive' : 'polite'" aria-atomic="true">
27
+ {{ message }}
28
+ </p>
29
+ </div>
30
+
31
+ <div class="button-container">
32
+ <slot name="buttons">
33
+ <Button :label="t('wl.otp_input.confirm')" :disabled="disableSubmitBtn" width="226" @click="onSubmit" type="submit" />
34
+ <Button :label="t('wl.otp_input.resend')" variant='outlined' :disabled="disableResendBtn" width="226" @click="onResend" />
35
+ </slot>
36
+ </div>
37
+ </form>
38
+ </template>
39
+
40
+ <script setup lang="ts">
41
+ import { ref, computed, watch, type CSSProperties, PropType } from 'vue';
42
+ import './OtpInput.css';
43
+ import Button from '../Button/Button.vue';
44
+ import { useI18n } from 'vue-i18n';
45
+
46
+ const { t } = useI18n();
47
+
48
+ const props = defineProps({
49
+ phoneNumber: {
50
+ type: String,
51
+ required: true
52
+ },
53
+
54
+ message: {
55
+ type: String,
56
+ default: ''
57
+ },
58
+
59
+ otpState: {
60
+ type: String,
61
+ default: 'default'
62
+ },
63
+
64
+ submitFn: {
65
+ type: Function,
66
+ required: true
67
+ },
68
+
69
+ resendFn: {
70
+ type: Function,
71
+ required: true
72
+ },
73
+
74
+ loading: {
75
+ type: Boolean,
76
+ default: false
77
+ },
78
+
79
+ colors: {
80
+ type: Object as PropType<{
81
+ error?: string;
82
+ success?: string;
83
+ }>,
84
+ default: () => ({
85
+ error: 'var(--Error-Red-0)',
86
+ success: 'var(--Success-Green-0)'
87
+ })
88
+ },
89
+ disableSubmitBtn: {
90
+ type: Boolean,
91
+ default: false
92
+ },
93
+ disableResendBtn: {
94
+ type: Boolean,
95
+ default: false
96
+ }
97
+ });
98
+
99
+ enum ValidationState {
100
+ DEFAULT = "default",
101
+ ERROR = "error",
102
+ SUCCESS = "success",
103
+ }
104
+
105
+ const emit = defineEmits([
106
+ 'update:modelValue'
107
+ ]);
108
+
109
+ const state = computed(() => localOtpState.value as ValidationState);
110
+ const error = computed(() => state.value === ValidationState.ERROR);
111
+ const loading = computed(() => props.loading);
112
+ const internalValue = ref('')
113
+ const localOtpState = ref(props.otpState)
114
+
115
+ const statusMessageStyle = computed<CSSProperties>(() => ({
116
+ visibility: state.value === ValidationState.DEFAULT ? 'hidden' : 'visible',
117
+ color: state.value === ValidationState.ERROR
118
+ ? `${props.colors.error} !important`
119
+ : `${props.colors.success} !important`,
120
+ minHeight: '1.5em'
121
+ }));
122
+
123
+ watch(() => props.otpState, (newVal) => {
124
+ localOtpState.value = newVal;
125
+ });
126
+
127
+ watch(internalValue, () => {
128
+ emit('update:modelValue', internalValue.value)
129
+ }, { immediate: true })
130
+
131
+ function onSubmit() {
132
+ props.submitFn();
133
+ }
134
+
135
+ function onResend() {
136
+ internalValue.value = '';
137
+ props.resendFn();
138
+ }
139
+
140
+ function onResetError(){
141
+ localOtpState.value = ValidationState.DEFAULT;
142
+ }
143
+
144
144
  </script>
@@ -1,32 +1,32 @@
1
- .wl-phone-input {
2
- width: 100%;
3
- }
4
-
5
- .wl-phone-input.border-on-hover .v-phone-input__country__input .v-field__outline__end {
6
- border-top-right-radius: 0 !important;
7
- border-bottom-right-radius: 0 !important;
8
- border-top-left-radius: 8px !important;
9
- border-bottom-left-radius: 8px !important;
10
- }
11
-
12
- .wl-phone-input.border-on-hover .v-phone-input__phone__input .v-field__outline__start {
13
- border-top-right-radius: 8px !important;
14
- border-bottom-right-radius: 8px !important;
15
- border-top-left-radius: 0 !important;
16
- border-bottom-left-radius: 0 !important;
17
- }
18
-
19
- .wl-phone-input.border-on-hover :deep(.v-field__outline) {
20
- opacity: 0;
21
- --v-field-border-opacity: 0;
22
- }
23
-
24
- .wl-phone-input.border-on-hover:hover :deep(.v-field__outline) {
25
- opacity: 1;
26
- --v-field-border-opacity: 1;
27
- }
28
-
29
- .wl-phone-input.border-on-hover.v-field--focused :deep(.v-field__outline) {
30
- opacity: 1;
31
- --v-field-border-opacity: 1;
1
+ .wl-phone-input {
2
+ width: 100%;
3
+ }
4
+
5
+ .wl-phone-input.border-on-hover .v-phone-input__country__input .v-field__outline__end {
6
+ border-top-right-radius: 0 !important;
7
+ border-bottom-right-radius: 0 !important;
8
+ border-top-left-radius: 8px !important;
9
+ border-bottom-left-radius: 8px !important;
10
+ }
11
+
12
+ .wl-phone-input.border-on-hover .v-phone-input__phone__input .v-field__outline__start {
13
+ border-top-right-radius: 8px !important;
14
+ border-bottom-right-radius: 8px !important;
15
+ border-top-left-radius: 0 !important;
16
+ border-bottom-left-radius: 0 !important;
17
+ }
18
+
19
+ .wl-phone-input.border-on-hover :deep(.v-field__outline) {
20
+ opacity: 0;
21
+ --v-field-border-opacity: 0;
22
+ }
23
+
24
+ .wl-phone-input.border-on-hover:hover :deep(.v-field__outline) {
25
+ opacity: 1;
26
+ --v-field-border-opacity: 1;
27
+ }
28
+
29
+ .wl-phone-input.border-on-hover.v-field--focused :deep(.v-field__outline) {
30
+ opacity: 1;
31
+ --v-field-border-opacity: 1;
32
32
  }
@@ -1,114 +1,114 @@
1
- <template>
2
- <VPhoneInput
3
- v-bind="$attrs"
4
- ref="inputRef"
5
- id="phone"
6
- class="wl-phone-input"
7
- :class="{
8
- 'border-on-hover': borderOnHover
9
- }"
10
- :include-countries="countriesCodes"
11
- :aria-label="placeholder"
12
- :variant="variant"
13
- label=""
14
- :appendInnerIcon="appendInnerIcon"
15
- :placeHolder="placeholder"
16
- display-format="international"
17
- :default-country="defaultCountryCode"
18
- hide-details
19
- :aria-invalid="state === ValidationState.ERROR"
20
- :countryIconMode="'svg'"
21
- @update:model-value="(value) => emit('update:phone', value)"
22
- data-testid="root"
23
- />
24
- </template>
25
-
26
- <script setup lang="ts">
27
- import { defineProps, PropType, ref, nextTick } from 'vue';
28
- import { VPhoneInput } from 'v-phone-input';
29
- import './PhoneInput.css'
30
-
31
- import "flag-icons/css/flag-icons.min.css";
32
- import "v-phone-input/dist/v-phone-input.css";
33
-
34
- enum ValidationState {
35
- DEFAULT = "default",
36
- ERROR = "error",
37
- SUCCESS = "success",
38
- }
39
-
40
- const props = defineProps({
41
- state: {
42
- type: String as PropType<ValidationState>,
43
- default: ValidationState.DEFAULT
44
- },
45
-
46
- placeholder: {
47
- type: String,
48
- default: ''
49
- },
50
-
51
- countriesCodes: {
52
- type: Array as PropType<string[]>,
53
- default: []
54
- },
55
-
56
- defaultCountryCode: {
57
- type: String,
58
- default: 'DE'
59
- },
60
-
61
- appendInnerIcon: {
62
- type: String,
63
- default: 'heroicons:phone'
64
- },
65
-
66
- variant: {
67
- type: String,
68
- default: 'outlined'
69
- },
70
-
71
- borderOnHover: {
72
- type: Boolean,
73
- default: false
74
- }
75
- });
76
-
77
- const emit = defineEmits<{
78
- (e: 'update:phone', value: string): void
79
- }>();
80
-
81
- const inputRef = ref(null)
82
-
83
- const getNativeInput = () => {
84
- return inputRef.value?.phoneInputRef?.$el?.querySelector('input');
85
- }
86
-
87
- const blur = () => {
88
- nextTick(() => {
89
- getNativeInput()?.blur();
90
- });
91
- };
92
-
93
- const select = () => {
94
- nextTick(() => {
95
- getNativeInput()?.select();
96
- });
97
- };
98
-
99
- const focus = () => {
100
- nextTick(() => {
101
- getNativeInput()?.focus();
102
- });
103
- };
104
-
105
- defineExpose({
106
- blur,
107
- select,
108
- focus
109
- });
110
-
111
- </script>
112
-
113
- <style scoped>
1
+ <template>
2
+ <VPhoneInput
3
+ v-bind="$attrs"
4
+ ref="inputRef"
5
+ id="phone"
6
+ class="wl-phone-input"
7
+ :class="{
8
+ 'border-on-hover': borderOnHover
9
+ }"
10
+ :include-countries="countriesCodes"
11
+ :aria-label="placeholder"
12
+ :variant="variant"
13
+ label=""
14
+ :appendInnerIcon="appendInnerIcon"
15
+ :placeHolder="placeholder"
16
+ display-format="international"
17
+ :default-country="defaultCountryCode"
18
+ hide-details
19
+ :aria-invalid="state === ValidationState.ERROR"
20
+ :countryIconMode="'svg'"
21
+ @update:model-value="(value) => emit('update:phone', value)"
22
+ data-testid="root"
23
+ />
24
+ </template>
25
+
26
+ <script setup lang="ts">
27
+ import { defineProps, PropType, ref, nextTick } from 'vue';
28
+ import { VPhoneInput } from 'v-phone-input';
29
+ import './PhoneInput.css'
30
+
31
+ import "flag-icons/css/flag-icons.min.css";
32
+ import "v-phone-input/dist/v-phone-input.css";
33
+
34
+ enum ValidationState {
35
+ DEFAULT = "default",
36
+ ERROR = "error",
37
+ SUCCESS = "success",
38
+ }
39
+
40
+ const props = defineProps({
41
+ state: {
42
+ type: String as PropType<ValidationState>,
43
+ default: ValidationState.DEFAULT
44
+ },
45
+
46
+ placeholder: {
47
+ type: String,
48
+ default: ''
49
+ },
50
+
51
+ countriesCodes: {
52
+ type: Array as PropType<string[]>,
53
+ default: []
54
+ },
55
+
56
+ defaultCountryCode: {
57
+ type: String,
58
+ default: 'DE'
59
+ },
60
+
61
+ appendInnerIcon: {
62
+ type: String,
63
+ default: 'heroicons:phone'
64
+ },
65
+
66
+ variant: {
67
+ type: String,
68
+ default: 'outlined'
69
+ },
70
+
71
+ borderOnHover: {
72
+ type: Boolean,
73
+ default: false
74
+ }
75
+ });
76
+
77
+ const emit = defineEmits<{
78
+ (e: 'update:phone', value: string): void
79
+ }>();
80
+
81
+ const inputRef = ref(null)
82
+
83
+ const getNativeInput = () => {
84
+ return inputRef.value?.phoneInputRef?.$el?.querySelector('input');
85
+ }
86
+
87
+ const blur = () => {
88
+ nextTick(() => {
89
+ getNativeInput()?.blur();
90
+ });
91
+ };
92
+
93
+ const select = () => {
94
+ nextTick(() => {
95
+ getNativeInput()?.select();
96
+ });
97
+ };
98
+
99
+ const focus = () => {
100
+ nextTick(() => {
101
+ getNativeInput()?.focus();
102
+ });
103
+ };
104
+
105
+ defineExpose({
106
+ blur,
107
+ select,
108
+ focus
109
+ });
110
+
111
+ </script>
112
+
113
+ <style scoped>
114
114
  </style>