classcard-ui 0.2.749 → 0.2.751

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 +64 -65
  3. package/dist/classcard-ui.common.js.map +1 -1
  4. package/dist/classcard-ui.umd.js +64 -65
  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 +118 -118
  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 +410 -410
  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 +131 -131
  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 +218 -218
  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 +118 -118
  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 +361 -361
  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 +204 -204
  79. package/src/components/CPagination/index.js +2 -2
  80. package/src/components/CPhoneNumber/CPhoneNumber.vue +89 -89
  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 +340 -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 +537 -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 +291 -291
  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 +45 -45
  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 +103 -103
  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,131 +1,131 @@
1
- <template>
2
- <focus-trap :active="true" :escapeDeactivates="false">
3
- <div
4
- v-scroll-lock="true"
5
- id="confirmModal"
6
- class="z-100 fixed inset-0 overflow-y-auto"
7
- >
8
- <div
9
- class="flex min-h-screen items-end justify-center px-4 pt-4 pb-20 text-center sm:block sm:p-0"
10
- @click="$emit('close')"
11
- >
12
- <transition
13
- enter-active-class="ease-out duration-300"
14
- enter-class="opacity-0"
15
- enter-to-class="opacity-100"
16
- leave-active-class="ease-in duration-200"
17
- leave-class="opacity-100"
18
- leave-to-class="opacity-0"
19
- >
20
- <div class="fixed inset-0 transition-opacity" aria-hidden="true">
21
- <div class="absolute inset-0 bg-gray-500 opacity-75"></div>
22
- </div>
23
- </transition>
24
-
25
- <!-- This element is to trick the browser into centering the modal contents. -->
26
- <span
27
- class="hidden sm:inline-block sm:h-screen sm:align-middle"
28
- aria-hidden="true"
29
- >&#8203;</span
30
- >
31
- <transition
32
- enter-active-class="ease-out duration-300"
33
- enter-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
34
- enter-to-class="opacity-100 translate-y-0 sm:scale-100"
35
- leave-active-class="ease-in duration-200"
36
- leave-class="opacity-100 translate-y-0 sm:scale-100"
37
- leave-to-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
38
- >
39
- <div
40
- class="inline-block transform overflow-y-visible rounded-lg bg-white text-left align-bottom shadow-xl transition-all sm:my-8 sm:w-full sm:max-w-sm sm:align-middle md:max-w-2xl"
41
- role="dialog"
42
- aria-modal="true"
43
- aria-labelledby="modal-headline"
44
- @click.stop
45
- >
46
- <div class="bg-white shadow sm:rounded-lg">
47
- <div class="px-4 py-5 sm:p-6">
48
- <h3 class="text-lg font-medium leading-6 text-gray-900">
49
- {{ title }}
50
- </h3>
51
- <div class="mt-2 max-w-xl text-sm text-gray-500">
52
- <p>{{ message }}</p>
53
- <p v-if="description" class="mt-1 text-gray-500">
54
- {{ description }}
55
- </p>
56
- </div>
57
- <div class="mt-5 flex justify-end space-x-2">
58
- <c-button
59
- @action="$emit('action-one')"
60
- :type="actionOneType"
61
- :label="actionOneLabel"
62
- ></c-button>
63
- <c-button
64
- @action="$emit('action-two')"
65
- :type="actionTwoType"
66
- :label="actionTwoLabel"
67
- :isLoading="loadButton"
68
- :disabled="loadButton"
69
- ></c-button>
70
- </div>
71
- </div>
72
- </div>
73
- </div>
74
- </transition>
75
- </div>
76
- </div>
77
- </focus-trap>
78
- </template>
79
-
80
- <script>
81
- import CButton from "../CButton";
82
-
83
- export default {
84
- name: "CConfirmActionModal",
85
- components: {
86
- CButton,
87
- },
88
- props: {
89
- title: {
90
- type: String,
91
- default: "Are you sure?",
92
- },
93
- message: {
94
- type: String,
95
- default: "",
96
- },
97
- description: {
98
- type: String,
99
- },
100
- actionOneLabel: {
101
- type: String,
102
- default: "Cancel",
103
- },
104
- actionTwoLabel: {
105
- type: String,
106
- default: "Ok",
107
- },
108
- actionOneType: {
109
- type: String,
110
- default: "secondary-gray",
111
- },
112
- actionTwoType: {
113
- type: String,
114
- default: "secondary-gray",
115
- },
116
- loadButton: {
117
- type: Boolean,
118
- default: false,
119
- },
120
- },
121
- };
122
- </script>
123
-
124
- <style>
125
- .form-content {
126
- max-height: calc(100vh - 200px);
127
- }
128
- /* #confirmModal {
129
- -webkit-transform: translate3d(0, 0, 0);
130
- } */
131
- </style>
1
+ <template>
2
+ <focus-trap :active="true" :escapeDeactivates="false">
3
+ <div
4
+ v-scroll-lock="true"
5
+ id="confirmModal"
6
+ class="z-100 fixed inset-0 overflow-y-auto"
7
+ >
8
+ <div
9
+ class="flex min-h-screen items-end justify-center px-4 pt-4 pb-20 text-center sm:block sm:p-0"
10
+ @click="$emit('close')"
11
+ >
12
+ <transition
13
+ enter-active-class="ease-out duration-300"
14
+ enter-class="opacity-0"
15
+ enter-to-class="opacity-100"
16
+ leave-active-class="ease-in duration-200"
17
+ leave-class="opacity-100"
18
+ leave-to-class="opacity-0"
19
+ >
20
+ <div class="fixed inset-0 transition-opacity" aria-hidden="true">
21
+ <div class="absolute inset-0 bg-gray-500 opacity-75"></div>
22
+ </div>
23
+ </transition>
24
+
25
+ <!-- This element is to trick the browser into centering the modal contents. -->
26
+ <span
27
+ class="hidden sm:inline-block sm:h-screen sm:align-middle"
28
+ aria-hidden="true"
29
+ >&#8203;</span
30
+ >
31
+ <transition
32
+ enter-active-class="ease-out duration-300"
33
+ enter-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
34
+ enter-to-class="opacity-100 translate-y-0 sm:scale-100"
35
+ leave-active-class="ease-in duration-200"
36
+ leave-class="opacity-100 translate-y-0 sm:scale-100"
37
+ leave-to-class="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
38
+ >
39
+ <div
40
+ class="inline-block transform overflow-y-visible rounded-lg bg-white text-left align-bottom shadow-xl transition-all sm:my-8 sm:w-full sm:max-w-sm sm:align-middle md:max-w-2xl"
41
+ role="dialog"
42
+ aria-modal="true"
43
+ aria-labelledby="modal-headline"
44
+ @click.stop
45
+ >
46
+ <div class="bg-white shadow sm:rounded-lg">
47
+ <div class="px-4 py-5 sm:p-6">
48
+ <h3 class="text-lg font-medium leading-6 text-gray-900">
49
+ {{ title }}
50
+ </h3>
51
+ <div class="mt-2 max-w-xl text-sm text-gray-500">
52
+ <p>{{ message }}</p>
53
+ <p v-if="description" class="mt-1 text-gray-500">
54
+ {{ description }}
55
+ </p>
56
+ </div>
57
+ <div class="mt-5 flex justify-end space-x-2">
58
+ <c-button
59
+ @action="$emit('action-one')"
60
+ :type="actionOneType"
61
+ :label="actionOneLabel"
62
+ ></c-button>
63
+ <c-button
64
+ @action="$emit('action-two')"
65
+ :type="actionTwoType"
66
+ :label="actionTwoLabel"
67
+ :isLoading="loadButton"
68
+ :disabled="loadButton"
69
+ ></c-button>
70
+ </div>
71
+ </div>
72
+ </div>
73
+ </div>
74
+ </transition>
75
+ </div>
76
+ </div>
77
+ </focus-trap>
78
+ </template>
79
+
80
+ <script>
81
+ import CButton from "../CButton";
82
+
83
+ export default {
84
+ name: "CConfirmActionModal",
85
+ components: {
86
+ CButton,
87
+ },
88
+ props: {
89
+ title: {
90
+ type: String,
91
+ default: "Are you sure?",
92
+ },
93
+ message: {
94
+ type: String,
95
+ default: "",
96
+ },
97
+ description: {
98
+ type: String,
99
+ },
100
+ actionOneLabel: {
101
+ type: String,
102
+ default: "Cancel",
103
+ },
104
+ actionTwoLabel: {
105
+ type: String,
106
+ default: "Ok",
107
+ },
108
+ actionOneType: {
109
+ type: String,
110
+ default: "secondary-gray",
111
+ },
112
+ actionTwoType: {
113
+ type: String,
114
+ default: "secondary-gray",
115
+ },
116
+ loadButton: {
117
+ type: Boolean,
118
+ default: false,
119
+ },
120
+ },
121
+ };
122
+ </script>
123
+
124
+ <style>
125
+ .form-content {
126
+ max-height: calc(100vh - 200px);
127
+ }
128
+ /* #confirmModal {
129
+ -webkit-transform: translate3d(0, 0, 0);
130
+ } */
131
+ </style>
@@ -1,3 +1,3 @@
1
- import CConfirmActionModal from "./CConfirmActionModal.vue";
2
-
3
- export default CConfirmActionModal;
1
+ import CConfirmActionModal from "./CConfirmActionModal.vue";
2
+
3
+ export default CConfirmActionModal;
@@ -1,139 +1,139 @@
1
- <template>
2
- <div>
3
- <div class="flex items-center">
4
- <div v-if="label">
5
- <label class="block text-sm font-medium text-gray-900">
6
- {{ label }}
7
- </label>
8
- </div>
9
- <!-- asterisk sign to render if field is required -->
10
- <p v-if="isRequired" class="ml-1 text-red-600">*</p>
11
- </div>
12
- <v-date-picker
13
- :class="{
14
- 'inline-block h-full': true,
15
- 'w-full': isExpanded,
16
- }"
17
- :masks="masks"
18
- @input="onDayClick"
19
- :value="value"
20
- :min-date="minDate"
21
- :max-date="maxDate"
22
- :attributes="attrs"
23
- firstDayOfWeek="2"
24
- :is-required="true"
25
- >
26
- <template v-slot="{ inputValue, togglePopover }">
27
- <div class="mt-1 flex items-center">
28
- <button
29
- type="button"
30
- :class="[
31
- disabled ? 'pointer-events-none border-gray-100' : 'border-gray-300',
32
- 'text-blue-600 focus:outline-none rounded-l-md border bg-white p-2 shadow-sm focus:text-white',
33
- ]"
34
- @click="togglePopover()"
35
- >
36
- <c-icon
37
- name="calendar-solid"
38
- :class="[disabled ? 'text-gray-200' : 'text-gray-400', 'h-5 w-5 ']"
39
- type="solid"
40
- ></c-icon>
41
- </button>
42
- <input
43
- :value="inputValue"
44
- :class="[
45
- disabled
46
- ? 'pointer-events-none border-l-0 border-gray-100 text-gray-400'
47
- : 'border-l-0 border-gray-300 text-gray-900',
48
- 'focus:outline-none focus:border-blue-500 w-full appearance-none rounded-r-md border bg-white p-2 text-sm shadow-sm',
49
- ]"
50
- :readonly="disabled"
51
- @click="togglePopover()"
52
- />
53
- </div>
54
- </template>
55
- </v-date-picker>
56
- <!-- validation error message -->
57
- <p v-if="!isValidate" class="mt-2 text-sm text-red-600">
58
- {{ errorMessage }}
59
- </p>
60
- <p v-if="helpText && isValidate == true" class="mt-1 text-sm text-gray-500">
61
- {{ helpText }}
62
- </p>
63
- </div>
64
- </template>
65
- <script>
66
- import CIcon from "../CIcon/CIcon.vue";
67
- // import Calendar from "v-calendar/lib/components/calendar.umd";
68
- import VDatePicker from "v-calendar/lib/components/date-picker.umd";
69
- export default {
70
- name: "CDatepicker",
71
- components: {
72
- // Calendar,
73
- VDatePicker,
74
- CIcon,
75
- },
76
- props: {
77
- classes: {
78
- type: String,
79
- },
80
- isRequired: {
81
- type: Boolean,
82
- },
83
- label: {
84
- type: String,
85
- },
86
- helpText: {
87
- type: String,
88
- },
89
- value: {
90
- type: [String, Date, Array],
91
- },
92
- disabled: {
93
- type: Boolean,
94
- default: false,
95
- },
96
- minDate: {
97
- type: [String, Date],
98
- default: null,
99
- },
100
- maxDate:{
101
- type: [String, Date],
102
- default: null,
103
- },
104
- isExpanded: {
105
- type: Boolean,
106
- default: false,
107
- },
108
- isValidate: {
109
- type: Boolean,
110
- default: true,
111
- },
112
- errorMessage: {
113
- type: String,
114
- },
115
- },
116
- data() {
117
- const masks = {
118
- input: ["MMM DD, YYYY", "YYYY/MM/DD", "DD-MM-YYYY", "DD/MM/YYYY", "YYYY-MM-DD", "L"],
119
- };
120
- return {
121
- masks,
122
- attrs: [
123
- {
124
- highlight: {
125
- color: "blue",
126
- fillMode: "outline",
127
- },
128
- dates: new Date(),
129
- },
130
- ],
131
- };
132
- },
133
- methods: {
134
- onDayClick(date) {
135
- this.$emit("input", date);
136
- },
137
- },
138
- };
139
- </script>
1
+ <template>
2
+ <div>
3
+ <div class="flex items-center">
4
+ <div v-if="label">
5
+ <label class="block text-sm font-medium text-gray-900">
6
+ {{ label }}
7
+ </label>
8
+ </div>
9
+ <!-- asterisk sign to render if field is required -->
10
+ <p v-if="isRequired" class="ml-1 text-red-600">*</p>
11
+ </div>
12
+ <v-date-picker
13
+ :class="{
14
+ 'inline-block h-full': true,
15
+ 'w-full': isExpanded,
16
+ }"
17
+ :masks="masks"
18
+ @input="onDayClick"
19
+ :value="value"
20
+ :min-date="minDate"
21
+ :max-date="maxDate"
22
+ :attributes="attrs"
23
+ firstDayOfWeek="2"
24
+ :is-required="true"
25
+ >
26
+ <template v-slot="{ inputValue, togglePopover }">
27
+ <div class="mt-1 flex items-center">
28
+ <button
29
+ type="button"
30
+ :class="[
31
+ disabled ? 'pointer-events-none border-gray-100' : 'border-gray-300',
32
+ 'text-blue-600 focus:outline-none rounded-l-md border bg-white p-2 shadow-sm focus:text-white',
33
+ ]"
34
+ @click="togglePopover()"
35
+ >
36
+ <c-icon
37
+ name="calendar-solid"
38
+ :class="[disabled ? 'text-gray-200' : 'text-gray-400', 'h-5 w-5 ']"
39
+ type="solid"
40
+ ></c-icon>
41
+ </button>
42
+ <input
43
+ :value="inputValue"
44
+ :class="[
45
+ disabled
46
+ ? 'pointer-events-none border-l-0 border-gray-100 text-gray-400'
47
+ : 'border-l-0 border-gray-300 text-gray-900',
48
+ 'focus:outline-none focus:border-blue-500 w-full appearance-none rounded-r-md border bg-white p-2 text-sm shadow-sm',
49
+ ]"
50
+ :readonly="disabled"
51
+ @click="togglePopover()"
52
+ />
53
+ </div>
54
+ </template>
55
+ </v-date-picker>
56
+ <!-- validation error message -->
57
+ <p v-if="!isValidate" class="mt-2 text-sm text-red-600">
58
+ {{ errorMessage }}
59
+ </p>
60
+ <p v-if="helpText && isValidate == true" class="mt-1 text-sm text-gray-500">
61
+ {{ helpText }}
62
+ </p>
63
+ </div>
64
+ </template>
65
+ <script>
66
+ import CIcon from "../CIcon/CIcon.vue";
67
+ // import Calendar from "v-calendar/lib/components/calendar.umd";
68
+ import VDatePicker from "v-calendar/lib/components/date-picker.umd";
69
+ export default {
70
+ name: "CDatepicker",
71
+ components: {
72
+ // Calendar,
73
+ VDatePicker,
74
+ CIcon,
75
+ },
76
+ props: {
77
+ classes: {
78
+ type: String,
79
+ },
80
+ isRequired: {
81
+ type: Boolean,
82
+ },
83
+ label: {
84
+ type: String,
85
+ },
86
+ helpText: {
87
+ type: String,
88
+ },
89
+ value: {
90
+ type: [String, Date, Array],
91
+ },
92
+ disabled: {
93
+ type: Boolean,
94
+ default: false,
95
+ },
96
+ minDate: {
97
+ type: [String, Date],
98
+ default: null,
99
+ },
100
+ maxDate:{
101
+ type: [String, Date],
102
+ default: null,
103
+ },
104
+ isExpanded: {
105
+ type: Boolean,
106
+ default: false,
107
+ },
108
+ isValidate: {
109
+ type: Boolean,
110
+ default: true,
111
+ },
112
+ errorMessage: {
113
+ type: String,
114
+ },
115
+ },
116
+ data() {
117
+ const masks = {
118
+ input: ["MMM DD, YYYY", "YYYY/MM/DD", "DD-MM-YYYY", "DD/MM/YYYY", "YYYY-MM-DD", "L"],
119
+ };
120
+ return {
121
+ masks,
122
+ attrs: [
123
+ {
124
+ highlight: {
125
+ color: "blue",
126
+ fillMode: "outline",
127
+ },
128
+ dates: new Date(),
129
+ },
130
+ ],
131
+ };
132
+ },
133
+ methods: {
134
+ onDayClick(date) {
135
+ this.$emit("input", date);
136
+ },
137
+ },
138
+ };
139
+ </script>
@@ -1,3 +1,3 @@
1
- import CDatepicker from './CDatepicker.vue'
2
-
1
+ import CDatepicker from './CDatepicker.vue'
2
+
3
3
  export default CDatepicker