classcard-ui 0.2.742 → 0.2.744

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 (176) hide show
  1. package/README.md +24 -24
  2. package/dist/classcard-ui.common.js +79 -66
  3. package/dist/classcard-ui.common.js.map +1 -1
  4. package/dist/classcard-ui.css +1 -1
  5. package/dist/classcard-ui.umd.js +79 -66
  6. package/dist/classcard-ui.umd.js.map +1 -1
  7. package/dist/classcard-ui.umd.min.js +1 -1
  8. package/dist/classcard-ui.umd.min.js.map +1 -1
  9. package/package.json +81 -81
  10. package/src/App.vue +16 -16
  11. package/src/components/CAlerts/CAlerts.vue +70 -70
  12. package/src/components/CAlerts/index.js +2 -2
  13. package/src/components/CAnchorTabs/CAnchorTabs.vue +96 -96
  14. package/src/components/CAnchorTabs/index.js +2 -2
  15. package/src/components/CAnchorTag/CAnchorTag.vue +62 -62
  16. package/src/components/CAnchorTag/index.js +2 -2
  17. package/src/components/CAvatar/CAvatar.vue +112 -112
  18. package/src/components/CAvatar/index.js +2 -2
  19. package/src/components/CAvatarGroup/CAvatarGroup.vue +145 -145
  20. package/src/components/CAvatarGroup/index.js +2 -2
  21. package/src/components/CBasicTable/CBasicTable.vue +184 -184
  22. package/src/components/CBasicTable/index.js +2 -2
  23. package/src/components/CBreadcrumbs/CBreadcrumbs.vue +38 -38
  24. package/src/components/CBreadcrumbs/index.js +2 -2
  25. package/src/components/CButton/CButton.vue +147 -147
  26. package/src/components/CButton/index.js +2 -2
  27. package/src/components/CButtonGroup/CButtonGroup.vue +118 -121
  28. package/src/components/CButtonGroup/index.js +2 -2
  29. package/src/components/CButtonIcon/CButtonIcon.vue +91 -91
  30. package/src/components/CButtonIcon/index.js +2 -2
  31. package/src/components/CButtonLink/CButtonLink.vue +39 -39
  32. package/src/components/CButtonLink/index.js +2 -2
  33. package/src/components/CButtonSelect/CButtonSelect.vue +103 -103
  34. package/src/components/CButtonSelect/index.js +2 -2
  35. package/src/components/CButtonWithDropdown/CButtonWithDropdown.vue +168 -168
  36. package/src/components/CButtonWithDropdown/index.js +2 -2
  37. package/src/components/CCalendar/CCalendar.vue +410 -410
  38. package/src/components/CCalendar/index.js +3 -3
  39. package/src/components/CCard/CCard.vue +49 -49
  40. package/src/components/CCard/index.js +2 -2
  41. package/src/components/CCheckbox/CCheckbox.vue +70 -70
  42. package/src/components/CCheckbox/index.js +2 -2
  43. package/src/components/CCollapsibleSection/CCollapsibleSection.vue +99 -99
  44. package/src/components/CCollapsibleSection/index.js +2 -2
  45. package/src/components/CColorDots/CColorDots.vue +35 -35
  46. package/src/components/CColorDots/index.js +3 -3
  47. package/src/components/CConfirmActionModal/CConfirmActionModal.vue +131 -120
  48. package/src/components/CConfirmActionModal/index.js +3 -3
  49. package/src/components/CDatepicker/CDatepicker.vue +139 -139
  50. package/src/components/CDatepicker/index.js +2 -2
  51. package/src/components/CDualSelect/CDualSelect.vue +193 -193
  52. package/src/components/CDualSelect/index.js +2 -2
  53. package/src/components/CEditor/CEditor.vue +96 -96
  54. package/src/components/CEditor/index.js +2 -2
  55. package/src/components/CFormSectionHeading/CFormSectionHeading.vue +53 -53
  56. package/src/components/CFormSectionHeading/index.js +2 -2
  57. package/src/components/CGroupedSelect/CGroupedSelect.vue +218 -218
  58. package/src/components/CGroupedSelect/index.js +3 -3
  59. package/src/components/CIcon/CIcon.vue +77 -77
  60. package/src/components/CIcon/index.js +2 -2
  61. package/src/components/CIconDropdown/CIconDropdown.vue +118 -118
  62. package/src/components/CIconDropdown/index.js +2 -2
  63. package/src/components/CInput/CInput.vue +120 -120
  64. package/src/components/CInput/index.js +2 -2
  65. package/src/components/CInputAddon/CInputAddon.vue +202 -202
  66. package/src/components/CInputAddon/index.js +2 -2
  67. package/src/components/CInputEmail/CInputEmail.vue +93 -93
  68. package/src/components/CInputEmail/index.js +2 -2
  69. package/src/components/CModalHeading/CModalHeading.vue +22 -22
  70. package/src/components/CModalHeading/index.js +2 -2
  71. package/src/components/CModuleHelpLinks/CModuleHelpLinks.vue +39 -39
  72. package/src/components/CModuleHelpLinks/index.js +3 -3
  73. package/src/components/CMultiselect/CMultiselect.vue +352 -352
  74. package/src/components/CMultiselect/index.js +2 -2
  75. package/src/components/CMultiselectr/CMultiselectr.vue +44 -44
  76. package/src/components/CMultiselectr/index.js +2 -2
  77. package/src/components/CPageHeading/CPageHeading.vue +56 -56
  78. package/src/components/CPageHeading/index.js +2 -2
  79. package/src/components/CPagination/CPagination.vue +204 -204
  80. package/src/components/CPagination/index.js +2 -2
  81. package/src/components/CPhoneNumber/CPhoneNumber.vue +89 -81
  82. package/src/components/CPhoneNumber/index.js +2 -2
  83. package/src/components/CRadio/CRadio.vue +106 -106
  84. package/src/components/CRadio/index.js +2 -2
  85. package/src/components/CRangeSlider/CRangeSlider.vue +55 -55
  86. package/src/components/CRangeSlider/index.js +2 -2
  87. package/src/components/CReorderableStackedList/CReorderableStackedList.vue +94 -94
  88. package/src/components/CReorderableStackedList/index.js +2 -2
  89. package/src/components/CSelect/CSelect.vue +343 -343
  90. package/src/components/CSelect/index.js +2 -2
  91. package/src/components/CSmallTimeline/CSmallTimeline.vue +40 -40
  92. package/src/components/CSmallTimeline/index.js +2 -2
  93. package/src/components/CStackedList/CStackedList.vue +132 -132
  94. package/src/components/CStackedList/index.js +2 -2
  95. package/src/components/CStats/CStats.vue +111 -111
  96. package/src/components/CStats/index.js +2 -2
  97. package/src/components/CSwitch/CSwitch.vue +140 -140
  98. package/src/components/CSwitch/index.js +2 -2
  99. package/src/components/CTable/CTable.vue +536 -536
  100. package/src/components/CTable/index.js +2 -2
  101. package/src/components/CTabs/CTabs.vue +111 -111
  102. package/src/components/CTabs/index.js +2 -2
  103. package/src/components/CTag/CTag.vue +36 -36
  104. package/src/components/CTag/index.js +2 -2
  105. package/src/components/CTextarea/CTextarea.vue +95 -95
  106. package/src/components/CTextarea/index.js +2 -2
  107. package/src/components/CTimeline/CTimeline.vue +237 -237
  108. package/src/components/CTimeline/index.js +2 -2
  109. package/src/components/CUpload/CUpload.vue +231 -231
  110. package/src/components/CUpload/index.js +2 -2
  111. package/src/components/index.js +48 -48
  112. package/src/icons.js +291 -291
  113. package/src/main.js +22 -22
  114. package/src/stories/CAlerts.stories.js +37 -37
  115. package/src/stories/CAnchorTabs.stories.js +29 -29
  116. package/src/stories/CAnchorTag.stories.js +36 -36
  117. package/src/stories/CAvatar.stories.js +38 -38
  118. package/src/stories/CAvatarGroup.stories.js +100 -100
  119. package/src/stories/CBasicTable.stories.js +316 -316
  120. package/src/stories/CBreadcrumbs.stories.js +24 -24
  121. package/src/stories/CButton.stories.js +46 -46
  122. package/src/stories/CButtonGroup.stories.js +33 -33
  123. package/src/stories/CButtonIcon.stories.js +27 -27
  124. package/src/stories/CButtonLink.stories.js +24 -24
  125. package/src/stories/CButtonSelect.stories.js +32 -32
  126. package/src/stories/CButtonWithDropdown.stories.js +41 -41
  127. package/src/stories/CCalendar.stories.js +16 -16
  128. package/src/stories/CCard.stories.js +30 -30
  129. package/src/stories/CCheckbox.stories.js +29 -29
  130. package/src/stories/CCollapsibleSection.stories.js +28 -28
  131. package/src/stories/CColorDots.stories.js +28 -28
  132. package/src/stories/CConfirmActionModal.stories.js +59 -59
  133. package/src/stories/CDatepicker.stories.js +30 -30
  134. package/src/stories/CDualSelect.stories.js +29 -29
  135. package/src/stories/CEditor.stories.js +30 -30
  136. package/src/stories/CFormSectionHeading.stories.js +34 -34
  137. package/src/stories/CGroupedSelect.stories.js +69 -69
  138. package/src/stories/CIcon.stories.js +26 -26
  139. package/src/stories/CIconDropdown.stories.js +45 -45
  140. package/src/stories/CInput.stories.js +36 -36
  141. package/src/stories/CInputAddon.stories.js +37 -37
  142. package/src/stories/CInputEmail.stories.js +27 -27
  143. package/src/stories/CModalHeading.stories.js +25 -25
  144. package/src/stories/CModuleHelpLinks.stories.js +25 -25
  145. package/src/stories/CMultiselect.stories.js +97 -97
  146. package/src/stories/CMultiselectr.stories.js +23 -23
  147. package/src/stories/CPageHeading.stories.js +32 -32
  148. package/src/stories/CPagination.stories.js +30 -30
  149. package/src/stories/CPhoneNumber.stories.js +29 -29
  150. package/src/stories/CRadio.stories.js +36 -36
  151. package/src/stories/CRangeSlider.stories.js +23 -23
  152. package/src/stories/CReorderableStackedList.stories.js +23 -23
  153. package/src/stories/CSelect.stories.js +50 -50
  154. package/src/stories/CSmallTimeline.stories.js +26 -26
  155. package/src/stories/CStackedList.stories.js +37 -37
  156. package/src/stories/CStats.stories.js +33 -33
  157. package/src/stories/CSwitch.stories.js +28 -28
  158. package/src/stories/CTable.stories.js +77 -77
  159. package/src/stories/CTabs.stories.js +33 -33
  160. package/src/stories/CTag.stories.js +23 -23
  161. package/src/stories/CTextarea.stories.js +32 -32
  162. package/src/stories/CTimeline.stories.js +26 -26
  163. package/src/stories/CUpload.stories.js +36 -36
  164. package/src/stories/Introduction.stories.mdx +207 -207
  165. package/src/stories/Page.vue +88 -88
  166. package/src/stories/assets/code-brackets.svg +0 -0
  167. package/src/stories/assets/colors.svg +0 -0
  168. package/src/stories/assets/comments.svg +0 -0
  169. package/src/stories/assets/direction.svg +0 -0
  170. package/src/stories/assets/flow.svg +0 -0
  171. package/src/stories/assets/plugin.svg +0 -0
  172. package/src/stories/assets/repo.svg +0 -0
  173. package/src/stories/assets/stackalt.svg +0 -0
  174. package/src/stories/header.css +26 -26
  175. package/src/stories/page.css +69 -69
  176. package/src/stories/utils.css +17 -17
@@ -1,120 +1,131 @@
1
- <template>
2
- <focus-trap :active="true" :escapeDeactivates="false">
3
- <div v-scroll-lock="true" class="fixed inset-0 z-100 overflow-y-auto">
4
- <div
5
- class="flex min-h-screen items-end justify-center px-4 pt-4 pb-20 text-center sm:block sm:p-0"
6
- @click="$emit('close')"
7
- >
8
- <transition
9
- enter-active-class="ease-out duration-300"
10
- enter-class="opacity-0"
11
- enter-to-class="opacity-100"
12
- leave-active-class="ease-in duration-200"
13
- leave-class="opacity-100"
14
- leave-to-class="opacity-0"
15
- >
16
- <div class="fixed inset-0 transition-opacity" aria-hidden="true">
17
- <div class="absolute inset-0 bg-gray-500 opacity-75"></div>
18
- </div>
19
- </transition>
20
-
21
- <!-- This element is to trick the browser into centering the modal contents. -->
22
- <span class="hidden sm:inline-block sm:h-screen sm:align-middle" aria-hidden="true"
23
- >&#8203;</span
24
- >
25
- <transition
26
- enter-active-class="ease-out duration-300"
27
- enter-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
28
- enter-to-class="opacity-100 translate-y-0 sm:scale-100"
29
- leave-active-class="ease-in duration-200"
30
- leave-class="opacity-100 translate-y-0 sm:scale-100"
31
- leave-to-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
32
- >
33
- <div
34
- class="inline-block transform overflow-y-visible rounded-lg bg-white text-left align-bottom shadow-xl transition-all sm:my-8 sm:w-full sm:max-w-sm sm:align-middle md:max-w-2xl"
35
- role="dialog"
36
- aria-modal="true"
37
- aria-labelledby="modal-headline"
38
- @click.stop
39
- >
40
- <div class="bg-white shadow sm:rounded-lg">
41
- <div class="px-4 py-5 sm:p-6">
42
- <h3 class="text-lg font-medium leading-6 text-gray-900">
43
- {{ title }}
44
- </h3>
45
- <div class="mt-2 max-w-xl text-sm text-gray-500">
46
- <p>{{ message }}</p>
47
- <p v-if="description" class="mt-1 text-gray-500">{{ description }}</p>
48
- </div>
49
- <div class="mt-5 flex justify-end space-x-2">
50
- <c-button
51
- @action="$emit('action-one')"
52
- :type="actionOneType"
53
- :label="actionOneLabel"
54
- ></c-button>
55
- <c-button
56
- @action="$emit('action-two')"
57
- :type="actionTwoType"
58
- :label="actionTwoLabel"
59
- :isLoading="loadButton"
60
- :disabled="loadButton"
61
- ></c-button>
62
- </div>
63
- </div>
64
- </div>
65
- </div>
66
- </transition>
67
- </div>
68
- </div>
69
- </focus-trap>
70
- </template>
71
-
72
- <script>
73
- import CButton from "../CButton";
74
-
75
- export default {
76
- name: "CConfirmActionModal",
77
- components: {
78
- CButton,
79
- },
80
- props: {
81
- title: {
82
- type: String,
83
- default: "Are you sure?",
84
- },
85
- message: {
86
- type: String,
87
- default: "",
88
- },
89
- description: {
90
- type: String,
91
- },
92
- actionOneLabel: {
93
- type: String,
94
- default: "Cancel",
95
- },
96
- actionTwoLabel: {
97
- type: String,
98
- default: "Ok",
99
- },
100
- actionOneType: {
101
- type: String,
102
- default: "secondary-gray",
103
- },
104
- actionTwoType: {
105
- type: String,
106
- default: "secondary-gray",
107
- },
108
- loadButton: {
109
- type: Boolean,
110
- default: false,
111
- },
112
- },
113
- };
114
- </script>
115
-
116
- <style>
117
- .form-content {
118
- max-height: calc(100vh - 200px);
119
- }
120
- </style>
1
+ <template>
2
+ <focus-trap :active="true" :escapeDeactivates="false">
3
+ <div
4
+ v-scroll-lock="true"
5
+ id="confirmModal"
6
+ class="z-100 fixed inset-0 overflow-y-auto"
7
+ >
8
+ <div
9
+ class="flex min-h-screen items-end justify-center px-4 pt-4 pb-20 text-center sm:block sm:p-0"
10
+ @click="$emit('close')"
11
+ >
12
+ <transition
13
+ enter-active-class="ease-out duration-300"
14
+ enter-class="opacity-0"
15
+ enter-to-class="opacity-100"
16
+ leave-active-class="ease-in duration-200"
17
+ leave-class="opacity-100"
18
+ leave-to-class="opacity-0"
19
+ >
20
+ <div class="fixed inset-0 transition-opacity" aria-hidden="true">
21
+ <div class="absolute inset-0 bg-gray-500 opacity-75"></div>
22
+ </div>
23
+ </transition>
24
+
25
+ <!-- This element is to trick the browser into centering the modal contents. -->
26
+ <span
27
+ class="hidden sm:inline-block sm:h-screen sm:align-middle"
28
+ aria-hidden="true"
29
+ >&#8203;</span
30
+ >
31
+ <transition
32
+ enter-active-class="ease-out duration-300"
33
+ enter-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
34
+ enter-to-class="opacity-100 translate-y-0 sm:scale-100"
35
+ leave-active-class="ease-in duration-200"
36
+ leave-class="opacity-100 translate-y-0 sm:scale-100"
37
+ leave-to-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
38
+ >
39
+ <div
40
+ class="inline-block transform overflow-y-visible rounded-lg bg-white text-left align-bottom shadow-xl transition-all sm:my-8 sm:w-full sm:max-w-sm sm:align-middle md:max-w-2xl"
41
+ role="dialog"
42
+ aria-modal="true"
43
+ aria-labelledby="modal-headline"
44
+ @click.stop
45
+ >
46
+ <div class="bg-white shadow sm:rounded-lg">
47
+ <div class="px-4 py-5 sm:p-6">
48
+ <h3 class="text-lg font-medium leading-6 text-gray-900">
49
+ {{ title }}
50
+ </h3>
51
+ <div class="mt-2 max-w-xl text-sm text-gray-500">
52
+ <p>{{ message }}</p>
53
+ <p v-if="description" class="mt-1 text-gray-500">
54
+ {{ description }}
55
+ </p>
56
+ </div>
57
+ <div class="mt-5 flex justify-end space-x-2">
58
+ <c-button
59
+ @action="$emit('action-one')"
60
+ :type="actionOneType"
61
+ :label="actionOneLabel"
62
+ ></c-button>
63
+ <c-button
64
+ @action="$emit('action-two')"
65
+ :type="actionTwoType"
66
+ :label="actionTwoLabel"
67
+ :isLoading="loadButton"
68
+ :disabled="loadButton"
69
+ ></c-button>
70
+ </div>
71
+ </div>
72
+ </div>
73
+ </div>
74
+ </transition>
75
+ </div>
76
+ </div>
77
+ </focus-trap>
78
+ </template>
79
+
80
+ <script>
81
+ import CButton from "../CButton";
82
+
83
+ export default {
84
+ name: "CConfirmActionModal",
85
+ components: {
86
+ CButton,
87
+ },
88
+ props: {
89
+ title: {
90
+ type: String,
91
+ default: "Are you sure?",
92
+ },
93
+ message: {
94
+ type: String,
95
+ default: "",
96
+ },
97
+ description: {
98
+ type: String,
99
+ },
100
+ actionOneLabel: {
101
+ type: String,
102
+ default: "Cancel",
103
+ },
104
+ actionTwoLabel: {
105
+ type: String,
106
+ default: "Ok",
107
+ },
108
+ actionOneType: {
109
+ type: String,
110
+ default: "secondary-gray",
111
+ },
112
+ actionTwoType: {
113
+ type: String,
114
+ default: "secondary-gray",
115
+ },
116
+ loadButton: {
117
+ type: Boolean,
118
+ default: false,
119
+ },
120
+ },
121
+ };
122
+ </script>
123
+
124
+ <style>
125
+ .form-content {
126
+ max-height: calc(100vh - 200px);
127
+ }
128
+ #confirmModal {
129
+ -webkit-transform: translate3d(0, 0, 0);
130
+ }
131
+ </style>
@@ -1,3 +1,3 @@
1
- import CConfirmActionModal from "./CConfirmActionModal.vue";
2
-
3
- export default CConfirmActionModal;
1
+ import CConfirmActionModal from "./CConfirmActionModal.vue";
2
+
3
+ export default CConfirmActionModal;
@@ -1,139 +1,139 @@
1
- <template>
2
- <div>
3
- <div class="flex items-center">
4
- <div v-if="label">
5
- <label class="block text-sm font-medium text-gray-900">
6
- {{ label }}
7
- </label>
8
- </div>
9
- <!-- asterisk sign to render if field is required -->
10
- <p v-if="isRequired" class="ml-1 text-red-600">*</p>
11
- </div>
12
- <v-date-picker
13
- :class="{
14
- 'inline-block h-full': true,
15
- 'w-full': isExpanded,
16
- }"
17
- :masks="masks"
18
- @input="onDayClick"
19
- :value="value"
20
- :min-date="minDate"
21
- :max-date="maxDate"
22
- :attributes="attrs"
23
- firstDayOfWeek="2"
24
- :is-required="true"
25
- >
26
- <template v-slot="{ inputValue, togglePopover }">
27
- <div class="mt-1 flex items-center">
28
- <button
29
- type="button"
30
- :class="[
31
- disabled ? 'pointer-events-none border-gray-100' : 'border-gray-300',
32
- 'text-blue-600 focus:outline-none rounded-l-md border bg-white p-2 shadow-sm focus:text-white',
33
- ]"
34
- @click="togglePopover()"
35
- >
36
- <c-icon
37
- name="calendar-solid"
38
- :class="[disabled ? 'text-gray-200' : 'text-gray-400', 'h-5 w-5 ']"
39
- type="solid"
40
- ></c-icon>
41
- </button>
42
- <input
43
- :value="inputValue"
44
- :class="[
45
- disabled
46
- ? 'pointer-events-none border-l-0 border-gray-100 text-gray-400'
47
- : 'border-l-0 border-gray-300 text-gray-900',
48
- 'focus:outline-none focus:border-blue-500 w-full appearance-none rounded-r-md border bg-white p-2 text-sm shadow-sm',
49
- ]"
50
- :readonly="disabled"
51
- @click="togglePopover()"
52
- />
53
- </div>
54
- </template>
55
- </v-date-picker>
56
- <!-- validation error message -->
57
- <p v-if="!isValidate" class="mt-2 text-sm text-red-600">
58
- {{ errorMessage }}
59
- </p>
60
- <p v-if="helpText && isValidate == true" class="mt-1 text-sm text-gray-500">
61
- {{ helpText }}
62
- </p>
63
- </div>
64
- </template>
65
- <script>
66
- import CIcon from "../CIcon/CIcon.vue";
67
- // import Calendar from "v-calendar/lib/components/calendar.umd";
68
- import VDatePicker from "v-calendar/lib/components/date-picker.umd";
69
- export default {
70
- name: "CDatepicker",
71
- components: {
72
- // Calendar,
73
- VDatePicker,
74
- CIcon,
75
- },
76
- props: {
77
- classes: {
78
- type: String,
79
- },
80
- isRequired: {
81
- type: Boolean,
82
- },
83
- label: {
84
- type: String,
85
- },
86
- helpText: {
87
- type: String,
88
- },
89
- value: {
90
- type: [String, Date, Array],
91
- },
92
- disabled: {
93
- type: Boolean,
94
- default: false,
95
- },
96
- minDate: {
97
- type: [String, Date],
98
- default: null,
99
- },
100
- maxDate:{
101
- type: [String, Date],
102
- default: null,
103
- },
104
- isExpanded: {
105
- type: Boolean,
106
- default: false,
107
- },
108
- isValidate: {
109
- type: Boolean,
110
- default: true,
111
- },
112
- errorMessage: {
113
- type: String,
114
- },
115
- },
116
- data() {
117
- const masks = {
118
- input: ["MMM DD, YYYY", "YYYY/MM/DD", "DD-MM-YYYY", "DD/MM/YYYY", "YYYY-MM-DD", "L"],
119
- };
120
- return {
121
- masks,
122
- attrs: [
123
- {
124
- highlight: {
125
- color: "blue",
126
- fillMode: "outline",
127
- },
128
- dates: new Date(),
129
- },
130
- ],
131
- };
132
- },
133
- methods: {
134
- onDayClick(date) {
135
- this.$emit("input", date);
136
- },
137
- },
138
- };
139
- </script>
1
+ <template>
2
+ <div>
3
+ <div class="flex items-center">
4
+ <div v-if="label">
5
+ <label class="block text-sm font-medium text-gray-900">
6
+ {{ label }}
7
+ </label>
8
+ </div>
9
+ <!-- asterisk sign to render if field is required -->
10
+ <p v-if="isRequired" class="ml-1 text-red-600">*</p>
11
+ </div>
12
+ <v-date-picker
13
+ :class="{
14
+ 'inline-block h-full': true,
15
+ 'w-full': isExpanded,
16
+ }"
17
+ :masks="masks"
18
+ @input="onDayClick"
19
+ :value="value"
20
+ :min-date="minDate"
21
+ :max-date="maxDate"
22
+ :attributes="attrs"
23
+ firstDayOfWeek="2"
24
+ :is-required="true"
25
+ >
26
+ <template v-slot="{ inputValue, togglePopover }">
27
+ <div class="mt-1 flex items-center">
28
+ <button
29
+ type="button"
30
+ :class="[
31
+ disabled ? 'pointer-events-none border-gray-100' : 'border-gray-300',
32
+ 'text-blue-600 focus:outline-none rounded-l-md border bg-white p-2 shadow-sm focus:text-white',
33
+ ]"
34
+ @click="togglePopover()"
35
+ >
36
+ <c-icon
37
+ name="calendar-solid"
38
+ :class="[disabled ? 'text-gray-200' : 'text-gray-400', 'h-5 w-5 ']"
39
+ type="solid"
40
+ ></c-icon>
41
+ </button>
42
+ <input
43
+ :value="inputValue"
44
+ :class="[
45
+ disabled
46
+ ? 'pointer-events-none border-l-0 border-gray-100 text-gray-400'
47
+ : 'border-l-0 border-gray-300 text-gray-900',
48
+ 'focus:outline-none focus:border-blue-500 w-full appearance-none rounded-r-md border bg-white p-2 text-sm shadow-sm',
49
+ ]"
50
+ :readonly="disabled"
51
+ @click="togglePopover()"
52
+ />
53
+ </div>
54
+ </template>
55
+ </v-date-picker>
56
+ <!-- validation error message -->
57
+ <p v-if="!isValidate" class="mt-2 text-sm text-red-600">
58
+ {{ errorMessage }}
59
+ </p>
60
+ <p v-if="helpText && isValidate == true" class="mt-1 text-sm text-gray-500">
61
+ {{ helpText }}
62
+ </p>
63
+ </div>
64
+ </template>
65
+ <script>
66
+ import CIcon from "../CIcon/CIcon.vue";
67
+ // import Calendar from "v-calendar/lib/components/calendar.umd";
68
+ import VDatePicker from "v-calendar/lib/components/date-picker.umd";
69
+ export default {
70
+ name: "CDatepicker",
71
+ components: {
72
+ // Calendar,
73
+ VDatePicker,
74
+ CIcon,
75
+ },
76
+ props: {
77
+ classes: {
78
+ type: String,
79
+ },
80
+ isRequired: {
81
+ type: Boolean,
82
+ },
83
+ label: {
84
+ type: String,
85
+ },
86
+ helpText: {
87
+ type: String,
88
+ },
89
+ value: {
90
+ type: [String, Date, Array],
91
+ },
92
+ disabled: {
93
+ type: Boolean,
94
+ default: false,
95
+ },
96
+ minDate: {
97
+ type: [String, Date],
98
+ default: null,
99
+ },
100
+ maxDate:{
101
+ type: [String, Date],
102
+ default: null,
103
+ },
104
+ isExpanded: {
105
+ type: Boolean,
106
+ default: false,
107
+ },
108
+ isValidate: {
109
+ type: Boolean,
110
+ default: true,
111
+ },
112
+ errorMessage: {
113
+ type: String,
114
+ },
115
+ },
116
+ data() {
117
+ const masks = {
118
+ input: ["MMM DD, YYYY", "YYYY/MM/DD", "DD-MM-YYYY", "DD/MM/YYYY", "YYYY-MM-DD", "L"],
119
+ };
120
+ return {
121
+ masks,
122
+ attrs: [
123
+ {
124
+ highlight: {
125
+ color: "blue",
126
+ fillMode: "outline",
127
+ },
128
+ dates: new Date(),
129
+ },
130
+ ],
131
+ };
132
+ },
133
+ methods: {
134
+ onDayClick(date) {
135
+ this.$emit("input", date);
136
+ },
137
+ },
138
+ };
139
+ </script>
@@ -1,3 +1,3 @@
1
- import CDatepicker from './CDatepicker.vue'
2
-
1
+ import CDatepicker from './CDatepicker.vue'
2
+
3
3
  export default CDatepicker