classcard-ui 0.2.607 → 0.2.608

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 +53 -55
  3. package/dist/classcard-ui.common.js.map +1 -1
  4. package/dist/classcard-ui.umd.js +53 -55
  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 +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 +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 +400 -400
  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 +134 -134
  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 +91 -91
  53. package/src/components/CEditor/index.js +2 -2
  54. package/src/components/CFormSectionHeading/CFormSectionHeading.vue +52 -52
  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 +105 -105
  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 +84 -84
  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 +323 -323
  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 +71 -71
  81. package/src/components/CPhoneNumber/index.js +2 -2
  82. package/src/components/CRadio/CRadio.vue +114 -114
  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 +314 -314
  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 +100 -102
  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 +488 -488
  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 +85 -85
  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 +201 -201
  109. package/src/components/CUpload/index.js +2 -2
  110. package/src/components/index.js +48 -48
  111. package/src/icons.js +259 -259
  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,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
- 'text-blue-600 focus:outline-none rounded-l-md border bg-white 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
+ 'text-blue-600 focus:outline-none rounded-l-md border bg-white 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