classcard-ui 0.2.705 → 0.2.708

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