classcard-ui 0.2.660 → 0.2.664

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 +94 -94
  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 +94 -94
  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 +116 -116
  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 +401 -401
  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 +120 -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 +217 -217
  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 +111 -111
  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 +340 -340
  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 +202 -202
  80. package/src/components/CPagination/index.js +2 -2
  81. package/src/components/CPhoneNumber/CPhoneNumber.vue +81 -71
  82. package/src/components/CPhoneNumber/index.js +2 -2
  83. package/src/components/CRadio/CRadio.vue +120 -116
  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 +275 -275
  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 +39 -39
  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,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