classcard-ui 0.2.396 → 0.2.399

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 (172) hide show
  1. package/README.md +24 -24
  2. package/dist/classcard-ui.common.js +111 -71
  3. package/dist/classcard-ui.common.js.map +1 -1
  4. package/dist/classcard-ui.umd.js +111 -71
  5. package/dist/classcard-ui.umd.js.map +1 -1
  6. package/dist/classcard-ui.umd.min.js +1 -1
  7. package/dist/classcard-ui.umd.min.js.map +1 -1
  8. package/package.json +79 -79
  9. package/src/App.vue +16 -16
  10. package/src/components/CAlerts/CAlerts.vue +70 -70
  11. package/src/components/CAlerts/index.js +2 -2
  12. package/src/components/CAnchorTabs/CAnchorTabs.vue +98 -98
  13. package/src/components/CAnchorTabs/index.js +2 -2
  14. package/src/components/CAnchorTag/CAnchorTag.vue +62 -62
  15. package/src/components/CAnchorTag/index.js +2 -2
  16. package/src/components/CAvatar/CAvatar.vue +89 -89
  17. package/src/components/CAvatar/index.js +2 -2
  18. package/src/components/CAvatarGroup/CAvatarGroup.vue +145 -145
  19. package/src/components/CAvatarGroup/index.js +2 -2
  20. package/src/components/CBasicTable/CBasicTable.vue +184 -184
  21. package/src/components/CBasicTable/index.js +2 -2
  22. package/src/components/CBreadcrumbs/CBreadcrumbs.vue +38 -38
  23. package/src/components/CBreadcrumbs/index.js +2 -2
  24. package/src/components/CButton/CButton.vue +121 -121
  25. package/src/components/CButton/index.js +2 -2
  26. package/src/components/CButtonGroup/CButtonGroup.vue +100 -100
  27. package/src/components/CButtonGroup/index.js +2 -2
  28. package/src/components/CButtonIcon/CButtonIcon.vue +108 -82
  29. package/src/components/CButtonIcon/index.js +2 -2
  30. package/src/components/CButtonLink/CButtonLink.vue +39 -39
  31. package/src/components/CButtonLink/index.js +2 -2
  32. package/src/components/CButtonSelect/CButtonSelect.vue +103 -103
  33. package/src/components/CButtonSelect/index.js +2 -2
  34. package/src/components/CButtonWithDropdown/CButtonWithDropdown.vue +168 -168
  35. package/src/components/CButtonWithDropdown/index.js +2 -2
  36. package/src/components/CCard/CCard.vue +49 -49
  37. package/src/components/CCard/index.js +2 -2
  38. package/src/components/CCheckbox/CCheckbox.vue +61 -61
  39. package/src/components/CCheckbox/index.js +2 -2
  40. package/src/components/CCollapsibleSection/CCollapsibleSection.vue +99 -99
  41. package/src/components/CCollapsibleSection/index.js +2 -2
  42. package/src/components/CColorDots/CColorDots.vue +35 -35
  43. package/src/components/CColorDots/index.js +3 -3
  44. package/src/components/CConfirmActionModal/CConfirmActionModal.vue +116 -116
  45. package/src/components/CConfirmActionModal/index.js +3 -3
  46. package/src/components/CDatepicker/CDatepicker.vue +134 -134
  47. package/src/components/CDatepicker/index.js +2 -2
  48. package/src/components/CDualSelect/CDualSelect.vue +193 -193
  49. package/src/components/CDualSelect/index.js +2 -2
  50. package/src/components/CEditor/CEditor.vue +91 -91
  51. package/src/components/CEditor/index.js +2 -2
  52. package/src/components/CFormSectionHeading/CFormSectionHeading.vue +52 -52
  53. package/src/components/CFormSectionHeading/index.js +2 -2
  54. package/src/components/CGroupedSelect/CGroupedSelect.vue +212 -212
  55. package/src/components/CGroupedSelect/index.js +3 -3
  56. package/src/components/CIcon/CIcon.vue +72 -72
  57. package/src/components/CIcon/index.js +2 -2
  58. package/src/components/CIconDropdown/CIconDropdown.vue +90 -90
  59. package/src/components/CIconDropdown/index.js +2 -2
  60. package/src/components/CInput/CInput.vue +110 -110
  61. package/src/components/CInput/index.js +2 -2
  62. package/src/components/CInputAddon/CInputAddon.vue +199 -199
  63. package/src/components/CInputAddon/index.js +2 -2
  64. package/src/components/CInputEmail/CInputEmail.vue +84 -84
  65. package/src/components/CInputEmail/index.js +2 -2
  66. package/src/components/CModalHeading/CModalHeading.vue +22 -22
  67. package/src/components/CModalHeading/index.js +2 -2
  68. package/src/components/CModuleHelpLinks/CModuleHelpLinks.vue +39 -39
  69. package/src/components/CModuleHelpLinks/index.js +3 -3
  70. package/src/components/CMultiselect/CMultiselect.vue +318 -318
  71. package/src/components/CMultiselect/index.js +2 -2
  72. package/src/components/CMultiselectr/CMultiselectr.vue +44 -44
  73. package/src/components/CMultiselectr/index.js +2 -2
  74. package/src/components/CPageHeading/CPageHeading.vue +52 -52
  75. package/src/components/CPageHeading/index.js +2 -2
  76. package/src/components/CPagination/CPagination.vue +202 -202
  77. package/src/components/CPagination/index.js +2 -2
  78. package/src/components/CPhoneNumber/CPhoneNumber.vue +62 -62
  79. package/src/components/CPhoneNumber/index.js +2 -2
  80. package/src/components/CRadio/CRadio.vue +70 -70
  81. package/src/components/CRadio/index.js +2 -2
  82. package/src/components/CRangeSlider/CRangeSlider.vue +55 -55
  83. package/src/components/CRangeSlider/index.js +2 -2
  84. package/src/components/CReorderableStackedList/CReorderableStackedList.vue +89 -89
  85. package/src/components/CReorderableStackedList/index.js +2 -2
  86. package/src/components/CSelect/CSelect.vue +271 -271
  87. package/src/components/CSelect/index.js +2 -2
  88. package/src/components/CSmallTimeline/CSmallTimeline.vue +40 -40
  89. package/src/components/CSmallTimeline/index.js +2 -2
  90. package/src/components/CStackedList/CStackedList.vue +87 -86
  91. package/src/components/CStackedList/index.js +2 -2
  92. package/src/components/CStats/CStats.vue +88 -88
  93. package/src/components/CStats/index.js +2 -2
  94. package/src/components/CSwitch/CSwitch.vue +132 -132
  95. package/src/components/CSwitch/index.js +2 -2
  96. package/src/components/CTable/CTable.vue +486 -473
  97. package/src/components/CTable/index.js +2 -2
  98. package/src/components/CTabs/CTabs.vue +109 -109
  99. package/src/components/CTabs/index.js +2 -2
  100. package/src/components/CTag/CTag.vue +36 -36
  101. package/src/components/CTag/index.js +2 -2
  102. package/src/components/CTextarea/CTextarea.vue +85 -85
  103. package/src/components/CTextarea/index.js +2 -2
  104. package/src/components/CTimeline/CTimeline.vue +237 -237
  105. package/src/components/CTimeline/index.js +2 -2
  106. package/src/components/CUpload/CUpload.vue +122 -122
  107. package/src/components/CUpload/index.js +2 -2
  108. package/src/components/index.js +47 -47
  109. package/src/icons.js +231 -231
  110. package/src/main.js +17 -17
  111. package/src/stories/CAlerts.stories.js +37 -37
  112. package/src/stories/CAnchorTabs.stories.js +29 -29
  113. package/src/stories/CAnchorTag.stories.js +36 -36
  114. package/src/stories/CAvatar.stories.js +38 -38
  115. package/src/stories/CAvatarGroup.stories.js +100 -100
  116. package/src/stories/CBasicTable.stories.js +316 -316
  117. package/src/stories/CBreadcrumbs.stories.js +24 -24
  118. package/src/stories/CButton.stories.js +46 -46
  119. package/src/stories/CButtonGroup.stories.js +33 -33
  120. package/src/stories/CButtonIcon.stories.js +27 -27
  121. package/src/stories/CButtonLink.stories.js +24 -24
  122. package/src/stories/CButtonSelect.stories.js +32 -32
  123. package/src/stories/CButtonWithDropdown.stories.js +41 -41
  124. package/src/stories/CCard.stories.js +30 -30
  125. package/src/stories/CCheckbox.stories.js +29 -29
  126. package/src/stories/CCollapsibleSection.stories.js +28 -28
  127. package/src/stories/CColorDots.stories.js +28 -28
  128. package/src/stories/CConfirmActionModal.stories.js +59 -59
  129. package/src/stories/CDatepicker.stories.js +30 -30
  130. package/src/stories/CDualSelect.stories.js +29 -29
  131. package/src/stories/CEditor.stories.js +30 -30
  132. package/src/stories/CFormSectionHeading.stories.js +34 -34
  133. package/src/stories/CGroupedSelect.stories.js +69 -69
  134. package/src/stories/CIcon.stories.js +26 -26
  135. package/src/stories/CIconDropdown.stories.js +39 -39
  136. package/src/stories/CInput.stories.js +36 -36
  137. package/src/stories/CInputAddon.stories.js +37 -37
  138. package/src/stories/CInputEmail.stories.js +27 -27
  139. package/src/stories/CModalHeading.stories.js +25 -25
  140. package/src/stories/CModuleHelpLinks.stories.js +25 -25
  141. package/src/stories/CMultiselect.stories.js +97 -97
  142. package/src/stories/CMultiselectr.stories.js +23 -23
  143. package/src/stories/CPageHeading.stories.js +32 -32
  144. package/src/stories/CPagination.stories.js +30 -30
  145. package/src/stories/CPhoneNumber.stories.js +29 -29
  146. package/src/stories/CRadio.stories.js +36 -36
  147. package/src/stories/CRangeSlider.stories.js +23 -23
  148. package/src/stories/CReorderableStackedList.stories.js +23 -23
  149. package/src/stories/CSelect.stories.js +50 -50
  150. package/src/stories/CSmallTimeline.stories.js +26 -26
  151. package/src/stories/CStackedList.stories.js +37 -36
  152. package/src/stories/CStats.stories.js +33 -33
  153. package/src/stories/CSwitch.stories.js +28 -28
  154. package/src/stories/CTable.stories.js +77 -77
  155. package/src/stories/CTabs.stories.js +29 -29
  156. package/src/stories/CTag.stories.js +23 -23
  157. package/src/stories/CTextarea.stories.js +32 -32
  158. package/src/stories/CTimeline.stories.js +26 -26
  159. package/src/stories/CUpload.stories.js +36 -36
  160. package/src/stories/Introduction.stories.mdx +207 -207
  161. package/src/stories/Page.vue +88 -88
  162. package/src/stories/assets/code-brackets.svg +0 -0
  163. package/src/stories/assets/colors.svg +0 -0
  164. package/src/stories/assets/comments.svg +0 -0
  165. package/src/stories/assets/direction.svg +0 -0
  166. package/src/stories/assets/flow.svg +0 -0
  167. package/src/stories/assets/plugin.svg +0 -0
  168. package/src/stories/assets/repo.svg +0 -0
  169. package/src/stories/assets/stackalt.svg +0 -0
  170. package/src/stories/header.css +26 -26
  171. package/src/stories/page.css +69 -69
  172. 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