@zap-wunschlachen/wl-shared-components 1.0.25 → 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 -315
- 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,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
|
+
}
|
|
@@ -1,126 +1,126 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<v-checkbox
|
|
3
|
-
class="tick-box"
|
|
4
|
-
:class="checkboxClass"
|
|
5
|
-
true-icon="heroicons:outline-checked"
|
|
6
|
-
false-icon="heroicons:outline"
|
|
7
|
-
:disabled="disabled"
|
|
8
|
-
:value="value"
|
|
9
|
-
:density="density"
|
|
10
|
-
v-model="internalValue"
|
|
11
|
-
:color="hoverColor"
|
|
12
|
-
:base-color="hoverColor"
|
|
13
|
-
data-testid="root"
|
|
14
|
-
>
|
|
15
|
-
<!-- Custom label slot with dynamic style -->
|
|
16
|
-
<template #label>
|
|
17
|
-
<span :style="labelStyles">{{ label }}</span>
|
|
18
|
-
</template>
|
|
19
|
-
</v-checkbox>
|
|
20
|
-
</template>
|
|
21
|
-
|
|
22
|
-
<script setup>
|
|
23
|
-
import { computed } from 'vue';
|
|
24
|
-
import './TickBox.css';
|
|
25
|
-
|
|
26
|
-
// Define props for the TickBox component
|
|
27
|
-
const props = defineProps({
|
|
28
|
-
/**
|
|
29
|
-
* The label text displayed next to the tick box.
|
|
30
|
-
* This prop is required.
|
|
31
|
-
*/
|
|
32
|
-
label: {
|
|
33
|
-
type: String,
|
|
34
|
-
required: true,
|
|
35
|
-
},
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Indicates if the tick box is in a success state.
|
|
39
|
-
* When true, the success styling will be applied.
|
|
40
|
-
*/
|
|
41
|
-
success: {
|
|
42
|
-
type: Boolean,
|
|
43
|
-
default: false,
|
|
44
|
-
},
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Indicates if the tick box is in an error state.
|
|
48
|
-
* When true, the error styling will be applied.
|
|
49
|
-
*/
|
|
50
|
-
error: {
|
|
51
|
-
type: Boolean,
|
|
52
|
-
default: false,
|
|
53
|
-
},
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Disables the tick box when true, making it non-interactive.
|
|
57
|
-
*/
|
|
58
|
-
disabled: {
|
|
59
|
-
type: Boolean,
|
|
60
|
-
default: false,
|
|
61
|
-
},
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* The value that the tick box represents when checked.
|
|
65
|
-
* Can be a string, number, or boolean. Default is `true`.
|
|
66
|
-
*/
|
|
67
|
-
value: {
|
|
68
|
-
type: [String, Number, Boolean],
|
|
69
|
-
default: true,
|
|
70
|
-
},
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* The current value bound to the tick box for v-model.
|
|
74
|
-
* Can be an array for multiple selection or boolean for single selection.
|
|
75
|
-
* This prop is required.
|
|
76
|
-
*/
|
|
77
|
-
modelValue: {
|
|
78
|
-
type: [Array, Boolean],
|
|
79
|
-
required: true,
|
|
80
|
-
},
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Controls the density of the tick box, such as padding and size.
|
|
84
|
-
* Default is 'comfortable'.
|
|
85
|
-
*/
|
|
86
|
-
density: {
|
|
87
|
-
type: String,
|
|
88
|
-
required: false,
|
|
89
|
-
default: 'comfortable',
|
|
90
|
-
},
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
// Emit event for v-model binding
|
|
94
|
-
const emit = defineEmits(['update:modelValue']);
|
|
95
|
-
|
|
96
|
-
// Computed property for v-model binding (two-way binding)
|
|
97
|
-
const internalValue = computed({
|
|
98
|
-
get() {
|
|
99
|
-
return props.modelValue; // Get the current modelValue from the parent
|
|
100
|
-
},
|
|
101
|
-
set(newValue) {
|
|
102
|
-
emit('update:modelValue', newValue); // Emit the updated value to the parent
|
|
103
|
-
},
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
// Computed property for dynamic class based on error or success state
|
|
107
|
-
const checkboxClass = computed(() => {
|
|
108
|
-
if (props.error) return 'error-state'; // Return error class if in error state
|
|
109
|
-
if (props.success) return 'success-state'; // Return success class if in success state
|
|
110
|
-
return 'default-state'; // Default class when no error or success
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
// Computed property for dynamic label styles based on state
|
|
114
|
-
const labelStyles = computed(() => {
|
|
115
|
-
if (props.error) return { color: 'var(--Error-Red-0)' }; // Error styling for label
|
|
116
|
-
if (props.success) return { color: 'var(--Success-Green-1)' }; // Success styling for label
|
|
117
|
-
return { color: 'var(--Dental-Blue-0)' }; // Default label styling
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
// Computed property for dynamic color based on error or success state
|
|
121
|
-
const hoverColor = computed(() => {
|
|
122
|
-
if (props.error) return 'var(--Error-Red-0)';
|
|
123
|
-
if (props.success) return 'var(--Success-Green-1)';
|
|
124
|
-
return 'var(--Dental-Blue-0)';
|
|
125
|
-
});
|
|
126
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<v-checkbox
|
|
3
|
+
class="tick-box"
|
|
4
|
+
:class="checkboxClass"
|
|
5
|
+
true-icon="heroicons:outline-checked"
|
|
6
|
+
false-icon="heroicons:outline"
|
|
7
|
+
:disabled="disabled"
|
|
8
|
+
:value="value"
|
|
9
|
+
:density="density"
|
|
10
|
+
v-model="internalValue"
|
|
11
|
+
:color="hoverColor"
|
|
12
|
+
:base-color="hoverColor"
|
|
13
|
+
data-testid="root"
|
|
14
|
+
>
|
|
15
|
+
<!-- Custom label slot with dynamic style -->
|
|
16
|
+
<template #label>
|
|
17
|
+
<span :style="labelStyles">{{ label }}</span>
|
|
18
|
+
</template>
|
|
19
|
+
</v-checkbox>
|
|
20
|
+
</template>
|
|
21
|
+
|
|
22
|
+
<script setup>
|
|
23
|
+
import { computed } from 'vue';
|
|
24
|
+
import './TickBox.css';
|
|
25
|
+
|
|
26
|
+
// Define props for the TickBox component
|
|
27
|
+
const props = defineProps({
|
|
28
|
+
/**
|
|
29
|
+
* The label text displayed next to the tick box.
|
|
30
|
+
* This prop is required.
|
|
31
|
+
*/
|
|
32
|
+
label: {
|
|
33
|
+
type: String,
|
|
34
|
+
required: true,
|
|
35
|
+
},
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Indicates if the tick box is in a success state.
|
|
39
|
+
* When true, the success styling will be applied.
|
|
40
|
+
*/
|
|
41
|
+
success: {
|
|
42
|
+
type: Boolean,
|
|
43
|
+
default: false,
|
|
44
|
+
},
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Indicates if the tick box is in an error state.
|
|
48
|
+
* When true, the error styling will be applied.
|
|
49
|
+
*/
|
|
50
|
+
error: {
|
|
51
|
+
type: Boolean,
|
|
52
|
+
default: false,
|
|
53
|
+
},
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Disables the tick box when true, making it non-interactive.
|
|
57
|
+
*/
|
|
58
|
+
disabled: {
|
|
59
|
+
type: Boolean,
|
|
60
|
+
default: false,
|
|
61
|
+
},
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* The value that the tick box represents when checked.
|
|
65
|
+
* Can be a string, number, or boolean. Default is `true`.
|
|
66
|
+
*/
|
|
67
|
+
value: {
|
|
68
|
+
type: [String, Number, Boolean],
|
|
69
|
+
default: true,
|
|
70
|
+
},
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* The current value bound to the tick box for v-model.
|
|
74
|
+
* Can be an array for multiple selection or boolean for single selection.
|
|
75
|
+
* This prop is required.
|
|
76
|
+
*/
|
|
77
|
+
modelValue: {
|
|
78
|
+
type: [Array, Boolean],
|
|
79
|
+
required: true,
|
|
80
|
+
},
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Controls the density of the tick box, such as padding and size.
|
|
84
|
+
* Default is 'comfortable'.
|
|
85
|
+
*/
|
|
86
|
+
density: {
|
|
87
|
+
type: String,
|
|
88
|
+
required: false,
|
|
89
|
+
default: 'comfortable',
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
// Emit event for v-model binding
|
|
94
|
+
const emit = defineEmits(['update:modelValue']);
|
|
95
|
+
|
|
96
|
+
// Computed property for v-model binding (two-way binding)
|
|
97
|
+
const internalValue = computed({
|
|
98
|
+
get() {
|
|
99
|
+
return props.modelValue; // Get the current modelValue from the parent
|
|
100
|
+
},
|
|
101
|
+
set(newValue) {
|
|
102
|
+
emit('update:modelValue', newValue); // Emit the updated value to the parent
|
|
103
|
+
},
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
// Computed property for dynamic class based on error or success state
|
|
107
|
+
const checkboxClass = computed(() => {
|
|
108
|
+
if (props.error) return 'error-state'; // Return error class if in error state
|
|
109
|
+
if (props.success) return 'success-state'; // Return success class if in success state
|
|
110
|
+
return 'default-state'; // Default class when no error or success
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
// Computed property for dynamic label styles based on state
|
|
114
|
+
const labelStyles = computed(() => {
|
|
115
|
+
if (props.error) return { color: 'var(--Error-Red-0)' }; // Error styling for label
|
|
116
|
+
if (props.success) return { color: 'var(--Success-Green-1)' }; // Success styling for label
|
|
117
|
+
return { color: 'var(--Dental-Blue-0)' }; // Default label styling
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
// Computed property for dynamic color based on error or success state
|
|
121
|
+
const hoverColor = computed(() => {
|
|
122
|
+
if (props.error) return 'var(--Error-Red-0)';
|
|
123
|
+
if (props.success) return 'var(--Success-Green-1)';
|
|
124
|
+
return 'var(--Dental-Blue-0)';
|
|
125
|
+
});
|
|
126
|
+
</script>
|
package/src/components/index.ts
CHANGED
|
@@ -1,24 +1,26 @@
|
|
|
1
|
-
// Components index file
|
|
2
|
-
|
|
3
|
-
export { default as AccordionItem } from './Accordion/AccordionItem.vue';
|
|
4
|
-
export { default as AccordionGroup } from './Accordion/AccordionGroup.vue';
|
|
5
|
-
export { default as Audio } from './Audio/Audio.vue';
|
|
6
|
-
export { default as Button } from './Button/Button.vue';
|
|
7
|
-
export { default as Checkbox } from './CheckBox/Checkbox.vue';
|
|
8
|
-
export { default as DateInput } from './DateInput/DateInput.vue';
|
|
9
|
-
export { default as Dialog } from './Dialog/Dialog.vue';
|
|
10
|
-
export { default as IconBulletList } from './IconBullet/IconBulletList.vue';
|
|
11
|
-
export { default as IconBullet } from './IconBullet/IconBullet.vue';
|
|
12
|
-
export { default as Input } from './Input/Input.vue';
|
|
13
|
-
export { default as NotificationBubble } from './NotificationBubble/NotificationBubble.vue';
|
|
14
|
-
export { default as Select } from './Select/Select.vue';
|
|
15
|
-
export { default as TickBox } from './TickBox/TickBox.vue';
|
|
16
|
-
export { default as TextArea } from './TextArea/TextArea.vue';
|
|
17
|
-
export { default as OtpInput } from './OtpInput/OtpInput.vue';
|
|
18
|
-
export { default as PhoneInput } from './PhoneInput/PhoneInput.vue';
|
|
19
|
-
export { default as EditField } from './EditField/EditField.vue';
|
|
20
|
-
export { default as Modal } from './Modal/Modal.vue';
|
|
21
|
-
export { default as AppointmentCard } from './Appointment/Card/Card.vue';
|
|
22
|
-
export { default as AdvanceAppointmentIcons } from './Icons/AdvanceAppointments.vue';
|
|
23
|
-
export { default as Loader } from './Loader/Loader.vue';
|
|
24
|
-
export { default as AnamneseNotification } from './Appointment/Card/AnamneseNotification.vue';
|
|
1
|
+
// Components index file
|
|
2
|
+
|
|
3
|
+
export { default as AccordionItem } from './Accordion/AccordionItem.vue';
|
|
4
|
+
export { default as AccordionGroup } from './Accordion/AccordionGroup.vue';
|
|
5
|
+
export { default as Audio } from './Audio/Audio.vue';
|
|
6
|
+
export { default as Button } from './Button/Button.vue';
|
|
7
|
+
export { default as Checkbox } from './CheckBox/Checkbox.vue';
|
|
8
|
+
export { default as DateInput } from './DateInput/DateInput.vue';
|
|
9
|
+
export { default as Dialog } from './Dialog/Dialog.vue';
|
|
10
|
+
export { default as IconBulletList } from './IconBullet/IconBulletList.vue';
|
|
11
|
+
export { default as IconBullet } from './IconBullet/IconBullet.vue';
|
|
12
|
+
export { default as Input } from './Input/Input.vue';
|
|
13
|
+
export { default as NotificationBubble } from './NotificationBubble/NotificationBubble.vue';
|
|
14
|
+
export { default as Select } from './Select/Select.vue';
|
|
15
|
+
export { default as TickBox } from './TickBox/TickBox.vue';
|
|
16
|
+
export { default as TextArea } from './TextArea/TextArea.vue';
|
|
17
|
+
export { default as OtpInput } from './OtpInput/OtpInput.vue';
|
|
18
|
+
export { default as PhoneInput } from './PhoneInput/PhoneInput.vue';
|
|
19
|
+
export { default as EditField } from './EditField/EditField.vue';
|
|
20
|
+
export { default as Modal } from './Modal/Modal.vue';
|
|
21
|
+
export { default as AppointmentCard } from './Appointment/Card/Card.vue';
|
|
22
|
+
export { default as AdvanceAppointmentIcons } from './Icons/AdvanceAppointments.vue';
|
|
23
|
+
export { default as Loader } from './Loader/Loader.vue';
|
|
24
|
+
export { default as AnamneseNotification } from './Appointment/Card/AnamneseNotification.vue';
|
|
25
|
+
export { default as ErrorPage } from './ErrorPage/ErrorPage.vue';
|
|
26
|
+
export { default as MaintenanceBanner } from './MaintenanceBanner/MaintenanceBanner.vue';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export enum IconEnum {
|
|
2
|
-
CALENDAR = 'calendar',
|
|
3
|
-
PLAY = 'play',
|
|
1
|
+
export enum IconEnum {
|
|
2
|
+
CALENDAR = 'calendar',
|
|
3
|
+
PLAY = 'play',
|
|
4
4
|
}
|