classcard-ui 0.2.387 → 0.2.390

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