@zap-wunschlachen/wl-shared-components 1.0.37 → 1.0.38
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 +33 -43
- 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 +232 -232
- package/src/assets/css/variables.css +109 -109
- 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 +118 -118
- package/src/components/Button/Button.vue +174 -174
- package/src/components/CheckBox/CheckBox.css +214 -214
- package/src/components/CheckBox/Checkbox.vue +138 -138
- 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 +38 -38
- package/src/components/EditField/EditField.css +19 -19
- package/src/components/EditField/EditField.vue +202 -202
- package/src/components/ErrorPage/ErrorPage.css +172 -172
- 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/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 +253 -253
- 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 +71 -71
- package/src/components/MaintenanceBanner/MaintenanceBanner.css +353 -353
- package/src/components/MaintenanceBanner/MaintenanceBanner.vue +127 -127
- package/src/components/MaintenanceBanner/MaintenanceIllustration.vue +54 -54
- 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 +151 -151
- 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 +316 -316
- package/src/components/StagingBanner/StagingBanner.css +19 -0
- package/src/components/StagingBanner/StagingBanner.vue +82 -0
- 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/accessibility.css +218 -218
- package/src/components/index.ts +29 -28
- 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 +141 -141
- 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 +109 -109
- 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/accessibility/component-a11y.spec.ts +469 -469
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts +228 -228
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
- package/tests/unit/components/Accordion/AccordionItem.spec.ts +292 -292
- package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
- package/tests/unit/components/Appointment/AnamneseNotification.spec.ts +176 -176
- 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/Background/Background.spec.ts +177 -177
- 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/ErrorPage/ErrorPage.spec.ts +313 -313
- package/tests/unit/components/ErrorPage/ErrorPageLogo.spec.ts +153 -153
- 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/AdvanceAppointments.spec.ts +61 -61
- 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/Logo.spec.ts +228 -228
- package/tests/unit/components/Icons/MiniLogo.spec.ts +38 -38
- package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
- package/tests/unit/components/Icons/SolidArrowRight.spec.ts +49 -49
- 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/components/Loader/Loader.spec.ts +197 -197
- package/tests/unit/components/MaintenanceBanner/MaintenanceBanner.spec.ts +302 -302
- 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/tests/unit/utils/accessibility.spec.ts +318 -318
- package/tsconfig.json +26 -26
- package/vite.config.ts +29 -29
- package/vitest.config.ts +83 -83
- package/public/audio/test.aac +0 -0
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div v-if="isVisible" class="staging-banner">
|
|
3
|
+
{{ displayText }}
|
|
4
|
+
</div>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { computed, onMounted, ref } from 'vue';
|
|
9
|
+
import './StagingBanner.css';
|
|
10
|
+
|
|
11
|
+
const props = defineProps({
|
|
12
|
+
/**
|
|
13
|
+
* Custom text to display in the banner.
|
|
14
|
+
* Default: "⚠️ STAGING - Testumgebung (keine echten Daten)"
|
|
15
|
+
*/
|
|
16
|
+
text: {
|
|
17
|
+
type: String,
|
|
18
|
+
default: ''
|
|
19
|
+
},
|
|
20
|
+
/**
|
|
21
|
+
* Force the banner to show regardless of hostname.
|
|
22
|
+
* Useful for testing or manual control.
|
|
23
|
+
*/
|
|
24
|
+
show: {
|
|
25
|
+
type: Boolean,
|
|
26
|
+
default: undefined
|
|
27
|
+
},
|
|
28
|
+
/**
|
|
29
|
+
* Whether to auto-detect staging based on hostname.
|
|
30
|
+
* Looks for "staging." or "staging-" in the hostname.
|
|
31
|
+
* Default: true
|
|
32
|
+
*/
|
|
33
|
+
autoDetect: {
|
|
34
|
+
type: Boolean,
|
|
35
|
+
default: true
|
|
36
|
+
},
|
|
37
|
+
/**
|
|
38
|
+
* Whether to add padding to the body to account for the banner.
|
|
39
|
+
* Default: true
|
|
40
|
+
*/
|
|
41
|
+
addBodyPadding: {
|
|
42
|
+
type: Boolean,
|
|
43
|
+
default: true
|
|
44
|
+
},
|
|
45
|
+
/**
|
|
46
|
+
* Custom padding value for the body (in pixels).
|
|
47
|
+
* Default: 40
|
|
48
|
+
*/
|
|
49
|
+
bodyPaddingPx: {
|
|
50
|
+
type: Number,
|
|
51
|
+
default: 40
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
const isStaging = ref(false);
|
|
56
|
+
|
|
57
|
+
const displayText = computed(() => {
|
|
58
|
+
return props.text || '⚠️ STAGING - Testumgebung (keine echten Daten)';
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
const isVisible = computed(() => {
|
|
62
|
+
// If show prop is explicitly set, use that
|
|
63
|
+
if (props.show !== undefined) {
|
|
64
|
+
return props.show;
|
|
65
|
+
}
|
|
66
|
+
// Otherwise use auto-detection result
|
|
67
|
+
return props.autoDetect && isStaging.value;
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
onMounted(() => {
|
|
71
|
+
// Check if running in browser
|
|
72
|
+
if (typeof window !== 'undefined') {
|
|
73
|
+
const hostname = window.location.hostname;
|
|
74
|
+
isStaging.value = hostname.includes('staging.') || hostname.includes('staging-');
|
|
75
|
+
|
|
76
|
+
// Add body padding if visible and option is enabled
|
|
77
|
+
if (isVisible.value && props.addBodyPadding) {
|
|
78
|
+
document.body.style.paddingTop = `${props.bodyPaddingPx}px`;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
</script>
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
.v-icon {
|
|
2
|
-
opacity: 1 !important;
|
|
3
|
-
}
|
|
1
|
+
.v-icon {
|
|
2
|
+
opacity: 1 !important;
|
|
3
|
+
}
|
|
@@ -1,126 +1,126 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<v-textarea
|
|
3
|
-
class="text-area"
|
|
4
|
-
v-model="internalValue"
|
|
5
|
-
clearable
|
|
6
|
-
:clear-icon="clearIcon"
|
|
7
|
-
:label="label"
|
|
8
|
-
:prepend-icon="prependIcon"
|
|
9
|
-
:prepend-inner-icon="prependInnerIcon"
|
|
10
|
-
:append-icon="appendIcon"
|
|
11
|
-
:append-inner-icon="appendInnerIcon"
|
|
12
|
-
base-color="var(--Soft-Concrete-1)"
|
|
13
|
-
bg-color="white"
|
|
14
|
-
variant="outlined"
|
|
15
|
-
color="var(--Dental-Light-Blue-1)"
|
|
16
|
-
rounded="lg"
|
|
17
|
-
@click:append="emit('click:append', $event)"
|
|
18
|
-
@click:appendInner="emit('click:appendInner', $event)"
|
|
19
|
-
@click:clear="emit('click:clear', $event)"
|
|
20
|
-
@click:control="emit('click:control', $event)"
|
|
21
|
-
@click:prepend="emit('click:prepend', $event)"
|
|
22
|
-
@click:prependInner="emit('click:prependInner', $event)"
|
|
23
|
-
data-testid="root"
|
|
24
|
-
>
|
|
25
|
-
<!-- You can include slots if needed -->
|
|
26
|
-
</v-textarea>
|
|
27
|
-
</template>
|
|
28
|
-
<script setup>
|
|
29
|
-
import './TextArea.css';
|
|
30
|
-
import { computed } from 'vue';
|
|
31
|
-
|
|
32
|
-
// Define props for the TextArea component
|
|
33
|
-
const props = defineProps({
|
|
34
|
-
/**
|
|
35
|
-
* The value bound to the textarea, supporting both String and Number types.
|
|
36
|
-
* Default is an empty string.
|
|
37
|
-
*/
|
|
38
|
-
modelValue: {
|
|
39
|
-
type: [String, Number],
|
|
40
|
-
default: '',
|
|
41
|
-
},
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Icon for clearing the textarea content.
|
|
45
|
-
* Default is 'text-area'.
|
|
46
|
-
*/
|
|
47
|
-
clearIcon: {
|
|
48
|
-
type: String,
|
|
49
|
-
default: 'text-area',
|
|
50
|
-
},
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Label for the textarea field.
|
|
54
|
-
* Default is 'Label'.
|
|
55
|
-
*/
|
|
56
|
-
label: {
|
|
57
|
-
type: String,
|
|
58
|
-
default: 'Label',
|
|
59
|
-
},
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Icon displayed before the textarea.
|
|
63
|
-
* Default is null, meaning no icon is displayed by default.
|
|
64
|
-
*/
|
|
65
|
-
prependIcon: {
|
|
66
|
-
type: String,
|
|
67
|
-
default: null,
|
|
68
|
-
},
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Inner icon displayed before the textarea, inside the input field.
|
|
72
|
-
* Default is null.
|
|
73
|
-
*/
|
|
74
|
-
prependInnerIcon: {
|
|
75
|
-
type: String,
|
|
76
|
-
default: null,
|
|
77
|
-
},
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Icon displayed after the textarea.
|
|
81
|
-
* Default is null.
|
|
82
|
-
*/
|
|
83
|
-
appendIcon: {
|
|
84
|
-
type: String,
|
|
85
|
-
default: null,
|
|
86
|
-
},
|
|
87
|
-
|
|
88
|
-
/**
|
|
89
|
-
* Inner icon displayed after the textarea, inside the input field.
|
|
90
|
-
* Default is null.
|
|
91
|
-
*/
|
|
92
|
-
appendInnerIcon: {
|
|
93
|
-
type: String,
|
|
94
|
-
default: null,
|
|
95
|
-
},
|
|
96
|
-
|
|
97
|
-
// Add more props as needed to customize the textarea
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
// Define emits for event handling
|
|
101
|
-
const emit = defineEmits([
|
|
102
|
-
'update:modelValue', // Emitted when the model value is updated
|
|
103
|
-
'click:append', // Emitted when the append icon is clicked
|
|
104
|
-
'click:appendInner', // Emitted when the append inner icon is clicked
|
|
105
|
-
'click:clear', // Emitted when the clear button is clicked
|
|
106
|
-
'click:control', // Emitted when the main textarea control is clicked
|
|
107
|
-
'click:prepend', // Emitted when the prepend icon is clicked
|
|
108
|
-
'click:prependInner', // Emitted when the prepend inner icon is clicked
|
|
109
|
-
]);
|
|
110
|
-
|
|
111
|
-
// Computed property to create two-way binding for v-model
|
|
112
|
-
const internalValue = computed({
|
|
113
|
-
get() {
|
|
114
|
-
return props.modelValue; // Getter returns the current modelValue prop
|
|
115
|
-
},
|
|
116
|
-
set(val) {
|
|
117
|
-
emit('update:modelValue', val); // Setter emits the updated value to parent component
|
|
118
|
-
},
|
|
119
|
-
});
|
|
120
|
-
</script>
|
|
121
|
-
|
|
122
|
-
<style>
|
|
123
|
-
.text-area .v-icon {
|
|
124
|
-
color: var(--Dental-Blue-0);
|
|
125
|
-
}
|
|
126
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<v-textarea
|
|
3
|
+
class="text-area"
|
|
4
|
+
v-model="internalValue"
|
|
5
|
+
clearable
|
|
6
|
+
:clear-icon="clearIcon"
|
|
7
|
+
:label="label"
|
|
8
|
+
:prepend-icon="prependIcon"
|
|
9
|
+
:prepend-inner-icon="prependInnerIcon"
|
|
10
|
+
:append-icon="appendIcon"
|
|
11
|
+
:append-inner-icon="appendInnerIcon"
|
|
12
|
+
base-color="var(--Soft-Concrete-1)"
|
|
13
|
+
bg-color="white"
|
|
14
|
+
variant="outlined"
|
|
15
|
+
color="var(--Dental-Light-Blue-1)"
|
|
16
|
+
rounded="lg"
|
|
17
|
+
@click:append="emit('click:append', $event)"
|
|
18
|
+
@click:appendInner="emit('click:appendInner', $event)"
|
|
19
|
+
@click:clear="emit('click:clear', $event)"
|
|
20
|
+
@click:control="emit('click:control', $event)"
|
|
21
|
+
@click:prepend="emit('click:prepend', $event)"
|
|
22
|
+
@click:prependInner="emit('click:prependInner', $event)"
|
|
23
|
+
data-testid="root"
|
|
24
|
+
>
|
|
25
|
+
<!-- You can include slots if needed -->
|
|
26
|
+
</v-textarea>
|
|
27
|
+
</template>
|
|
28
|
+
<script setup>
|
|
29
|
+
import './TextArea.css';
|
|
30
|
+
import { computed } from 'vue';
|
|
31
|
+
|
|
32
|
+
// Define props for the TextArea component
|
|
33
|
+
const props = defineProps({
|
|
34
|
+
/**
|
|
35
|
+
* The value bound to the textarea, supporting both String and Number types.
|
|
36
|
+
* Default is an empty string.
|
|
37
|
+
*/
|
|
38
|
+
modelValue: {
|
|
39
|
+
type: [String, Number],
|
|
40
|
+
default: '',
|
|
41
|
+
},
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Icon for clearing the textarea content.
|
|
45
|
+
* Default is 'text-area'.
|
|
46
|
+
*/
|
|
47
|
+
clearIcon: {
|
|
48
|
+
type: String,
|
|
49
|
+
default: 'text-area',
|
|
50
|
+
},
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Label for the textarea field.
|
|
54
|
+
* Default is 'Label'.
|
|
55
|
+
*/
|
|
56
|
+
label: {
|
|
57
|
+
type: String,
|
|
58
|
+
default: 'Label',
|
|
59
|
+
},
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Icon displayed before the textarea.
|
|
63
|
+
* Default is null, meaning no icon is displayed by default.
|
|
64
|
+
*/
|
|
65
|
+
prependIcon: {
|
|
66
|
+
type: String,
|
|
67
|
+
default: null,
|
|
68
|
+
},
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Inner icon displayed before the textarea, inside the input field.
|
|
72
|
+
* Default is null.
|
|
73
|
+
*/
|
|
74
|
+
prependInnerIcon: {
|
|
75
|
+
type: String,
|
|
76
|
+
default: null,
|
|
77
|
+
},
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* Icon displayed after the textarea.
|
|
81
|
+
* Default is null.
|
|
82
|
+
*/
|
|
83
|
+
appendIcon: {
|
|
84
|
+
type: String,
|
|
85
|
+
default: null,
|
|
86
|
+
},
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Inner icon displayed after the textarea, inside the input field.
|
|
90
|
+
* Default is null.
|
|
91
|
+
*/
|
|
92
|
+
appendInnerIcon: {
|
|
93
|
+
type: String,
|
|
94
|
+
default: null,
|
|
95
|
+
},
|
|
96
|
+
|
|
97
|
+
// Add more props as needed to customize the textarea
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
// Define emits for event handling
|
|
101
|
+
const emit = defineEmits([
|
|
102
|
+
'update:modelValue', // Emitted when the model value is updated
|
|
103
|
+
'click:append', // Emitted when the append icon is clicked
|
|
104
|
+
'click:appendInner', // Emitted when the append inner icon is clicked
|
|
105
|
+
'click:clear', // Emitted when the clear button is clicked
|
|
106
|
+
'click:control', // Emitted when the main textarea control is clicked
|
|
107
|
+
'click:prepend', // Emitted when the prepend icon is clicked
|
|
108
|
+
'click:prependInner', // Emitted when the prepend inner icon is clicked
|
|
109
|
+
]);
|
|
110
|
+
|
|
111
|
+
// Computed property to create two-way binding for v-model
|
|
112
|
+
const internalValue = computed({
|
|
113
|
+
get() {
|
|
114
|
+
return props.modelValue; // Getter returns the current modelValue prop
|
|
115
|
+
},
|
|
116
|
+
set(val) {
|
|
117
|
+
emit('update:modelValue', val); // Setter emits the updated value to parent component
|
|
118
|
+
},
|
|
119
|
+
});
|
|
120
|
+
</script>
|
|
121
|
+
|
|
122
|
+
<style>
|
|
123
|
+
.text-area .v-icon {
|
|
124
|
+
color: var(--Dental-Blue-0);
|
|
125
|
+
}
|
|
126
|
+
</style>
|
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
/* Default state */
|
|
2
|
-
.tick-box.default-state .v-icon {
|
|
3
|
-
color: var(--Dental-Blue-0) !important;
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
/* Success state */
|
|
7
|
-
.tick-box.success-state .v-icon {
|
|
8
|
-
color: var(--Success-Green-0) !important;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/* Error state */
|
|
12
|
-
.tick-box.error-state .svg {
|
|
13
|
-
color: var(--Error-Red-0) !important;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
/* Common styles for the checkbox label */
|
|
17
|
-
.tick-box .v-label {
|
|
18
|
-
opacity: 1 !important;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
.tick-box svg path {
|
|
22
|
-
stroke: var(--Dental-Blue-0);
|
|
23
|
-
fill: white;
|
|
24
|
-
stroke-width: 3px;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
.tick-box.success-state svg rect {
|
|
28
|
-
stroke: var(--Success-Green-0);
|
|
29
|
-
fill: white;
|
|
30
|
-
stroke-width: 1px;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
.tick-box.success-state svg path {
|
|
34
|
-
stroke: var(--Success-Green-0);
|
|
35
|
-
fill: white;
|
|
36
|
-
stroke-width: 3px;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
.tick-box.error-state svg path {
|
|
40
|
-
stroke: var(--Error-Red-0);
|
|
41
|
-
fill: white;
|
|
42
|
-
stroke-width: 3px;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
.tick-box.error-state svg rect {
|
|
46
|
-
stroke: var(--Error-Red-0);
|
|
47
|
-
fill: white;
|
|
48
|
-
stroke-width: 1px;
|
|
49
|
-
}
|
|
1
|
+
/* Default state */
|
|
2
|
+
.tick-box.default-state .v-icon {
|
|
3
|
+
color: var(--Dental-Blue-0) !important;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
/* Success state */
|
|
7
|
+
.tick-box.success-state .v-icon {
|
|
8
|
+
color: var(--Success-Green-0) !important;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
/* Error state */
|
|
12
|
+
.tick-box.error-state .svg {
|
|
13
|
+
color: var(--Error-Red-0) !important;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/* Common styles for the checkbox label */
|
|
17
|
+
.tick-box .v-label {
|
|
18
|
+
opacity: 1 !important;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.tick-box svg path {
|
|
22
|
+
stroke: var(--Dental-Blue-0);
|
|
23
|
+
fill: white;
|
|
24
|
+
stroke-width: 3px;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.tick-box.success-state svg rect {
|
|
28
|
+
stroke: var(--Success-Green-0);
|
|
29
|
+
fill: white;
|
|
30
|
+
stroke-width: 1px;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.tick-box.success-state svg path {
|
|
34
|
+
stroke: var(--Success-Green-0);
|
|
35
|
+
fill: white;
|
|
36
|
+
stroke-width: 3px;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
.tick-box.error-state svg path {
|
|
40
|
+
stroke: var(--Error-Red-0);
|
|
41
|
+
fill: white;
|
|
42
|
+
stroke-width: 3px;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
.tick-box.error-state svg rect {
|
|
46
|
+
stroke: var(--Error-Red-0);
|
|
47
|
+
fill: white;
|
|
48
|
+
stroke-width: 1px;
|
|
49
|
+
}
|