classcard-ui 0.2.1477 → 0.2.1480

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 (212) hide show
  1. package/README.md +24 -24
  2. package/dist/classcard-ui.common.js +558 -435
  3. package/dist/classcard-ui.common.js.map +1 -1
  4. package/dist/classcard-ui.css +2 -2
  5. package/dist/classcard-ui.umd.js +558 -435
  6. package/dist/classcard-ui.umd.js.map +1 -1
  7. package/dist/classcard-ui.umd.min.js +2 -2
  8. package/dist/classcard-ui.umd.min.js.map +1 -1
  9. package/package.json +84 -83
  10. package/src/App.vue +16 -16
  11. package/src/colorConfig.js +52 -52
  12. package/src/components/CAlertModal/CAlertModal.vue +179 -179
  13. package/src/components/CAlertModal/index.js +3 -3
  14. package/src/components/CAlerts/CAlerts.vue +114 -114
  15. package/src/components/CAlerts/index.js +2 -2
  16. package/src/components/CAnchorTabs/CAnchorTabs.vue +100 -100
  17. package/src/components/CAnchorTabs/index.js +2 -2
  18. package/src/components/CAnchorTag/CAnchorTag.vue +84 -84
  19. package/src/components/CAnchorTag/index.js +2 -2
  20. package/src/components/CAvatar/CAvatar.vue +230 -230
  21. package/src/components/CAvatar/index.js +2 -2
  22. package/src/components/CAvatarGroup/CAvatarGroup.vue +213 -213
  23. package/src/components/CAvatarGroup/index.js +2 -2
  24. package/src/components/CBasicTable/CBasicTable.vue +184 -184
  25. package/src/components/CBasicTable/index.js +2 -2
  26. package/src/components/CBreadcrumbs/CBreadcrumbs.vue +38 -38
  27. package/src/components/CBreadcrumbs/index.js +2 -2
  28. package/src/components/CButton/CButton.vue +239 -239
  29. package/src/components/CButton/index.js +2 -2
  30. package/src/components/CButtonGroup/CButtonGroup.vue +155 -155
  31. package/src/components/CButtonGroup/index.js +2 -2
  32. package/src/components/CButtonIcon/CButtonIcon.vue +166 -166
  33. package/src/components/CButtonIcon/index.js +2 -2
  34. package/src/components/CButtonLink/CButtonLink.vue +43 -43
  35. package/src/components/CButtonLink/index.js +2 -2
  36. package/src/components/CButtonSelect/CButtonSelect.vue +186 -186
  37. package/src/components/CButtonSelect/index.js +2 -2
  38. package/src/components/CButtonSelectBorder/CButtonSelectBorder.vue +265 -265
  39. package/src/components/CButtonSelectBorder/index.js +3 -3
  40. package/src/components/CButtonWithDropdown/CButtonWithDropdown.vue +152 -152
  41. package/src/components/CButtonWithDropdown/index.js +2 -2
  42. package/src/components/CCalendar/CCalendar.vue +443 -443
  43. package/src/components/CCalendar/index.js +3 -3
  44. package/src/components/CCard/CCard.vue +53 -53
  45. package/src/components/CCard/index.js +2 -2
  46. package/src/components/CCheckbox/CCheckbox.vue +200 -200
  47. package/src/components/CCheckbox/index.js +2 -2
  48. package/src/components/CCircularButton/CCircularButton.vue +57 -57
  49. package/src/components/CCircularButton/index.js +2 -2
  50. package/src/components/CCollapsibleSection/CCollapsibleSection.vue +121 -121
  51. package/src/components/CCollapsibleSection/index.js +2 -2
  52. package/src/components/CColorDots/CColorDots.vue +52 -52
  53. package/src/components/CColorDots/index.js +3 -3
  54. package/src/components/CConfirmActionModal/CConfirmActionModal.vue +221 -221
  55. package/src/components/CConfirmActionModal/index.js +3 -3
  56. package/src/components/CDatepicker/CDatepicker.vue +235 -235
  57. package/src/components/CDatepicker/index.js +2 -2
  58. package/src/components/CDualSelect/CDualSelect.vue +193 -193
  59. package/src/components/CDualSelect/index.js +2 -2
  60. package/src/components/CEditor/CEditor.vue +114 -114
  61. package/src/components/CEditor/index.js +2 -2
  62. package/src/components/CFormSectionHeading/CFormSectionHeading.vue +76 -76
  63. package/src/components/CFormSectionHeading/index.js +2 -2
  64. package/src/components/CGroupedFilterDropdown/CGroupedFilterDropdown.vue +331 -263
  65. package/src/components/CGroupedFilterDropdown/index.js +2 -2
  66. package/src/components/CGroupedSelect/CGroupedSelect.vue +366 -366
  67. package/src/components/CGroupedSelect/index.js +3 -3
  68. package/src/components/CIcon/CIcon.vue +112 -112
  69. package/src/components/CIcon/index.js +2 -2
  70. package/src/components/CIconDropdown/CIconDropdown.vue +206 -206
  71. package/src/components/CIconDropdown/index.js +2 -2
  72. package/src/components/CIconSelect/CIconSelect.vue +182 -182
  73. package/src/components/CIconSelect/index.js +3 -3
  74. package/src/components/CInput/CInput.vue +173 -173
  75. package/src/components/CInput/index.js +2 -2
  76. package/src/components/CInputAddon/CInputAddon.vue +297 -297
  77. package/src/components/CInputAddon/index.js +2 -2
  78. package/src/components/CInputEmail/CInputEmail.vue +107 -107
  79. package/src/components/CInputEmail/index.js +2 -2
  80. package/src/components/CInsetTabs/CInsetTabs.vue +134 -134
  81. package/src/components/CInsetTabs/index.js +3 -3
  82. package/src/components/CLinearProgressBar/CLinearProgressBar.vue +35 -35
  83. package/src/components/CLinearProgressBar/index.js +2 -2
  84. package/src/components/CModalHeading/CModalHeading.vue +22 -22
  85. package/src/components/CModalHeading/index.js +2 -2
  86. package/src/components/CModuleHelpLinks/CModuleHelpLinks.vue +88 -88
  87. package/src/components/CModuleHelpLinks/index.js +3 -3
  88. package/src/components/CMultiselect/CMultiselect.vue +1286 -1170
  89. package/src/components/CMultiselect/index.js +2 -2
  90. package/src/components/CMultiselectr/CMultiselectr.vue +44 -44
  91. package/src/components/CMultiselectr/index.js +2 -2
  92. package/src/components/CPageHeading/CPageHeading.vue +83 -83
  93. package/src/components/CPageHeading/index.js +2 -2
  94. package/src/components/CPagination/CPagination.vue +239 -239
  95. package/src/components/CPagination/index.js +2 -2
  96. package/src/components/CPhoneNumber/CPhoneNumber.vue +213 -213
  97. package/src/components/CPhoneNumber/index.js +2 -2
  98. package/src/components/CProgress/CProgress.vue +91 -91
  99. package/src/components/CProgress/index.js +2 -2
  100. package/src/components/CRadio/CRadio.vue +197 -197
  101. package/src/components/CRadio/index.js +2 -2
  102. package/src/components/CRadioGroup/CRadioGroup.vue +96 -96
  103. package/src/components/CRadioGroup/index.js +2 -2
  104. package/src/components/CRangeSlider/CRangeSlider.vue +55 -55
  105. package/src/components/CRangeSlider/index.js +2 -2
  106. package/src/components/CReorderableStackedList/CReorderableStackedList.vue +94 -94
  107. package/src/components/CReorderableStackedList/index.js +2 -2
  108. package/src/components/CSelect/CSelect.vue +1219 -1210
  109. package/src/components/CSelect/index.js +2 -2
  110. package/src/components/CSmallTimeline/CSmallTimeline.vue +40 -40
  111. package/src/components/CSmallTimeline/index.js +2 -2
  112. package/src/components/CStackedList/CStackedList.vue +162 -162
  113. package/src/components/CStackedList/index.js +2 -2
  114. package/src/components/CStats/CStats.vue +157 -157
  115. package/src/components/CStats/index.js +2 -2
  116. package/src/components/CSwitch/CSwitch.vue +200 -200
  117. package/src/components/CSwitch/index.js +2 -2
  118. package/src/components/CTabLazy/CTabLazy.vue +83 -83
  119. package/src/components/CTabLazy/index.js +2 -2
  120. package/src/components/CTable/CTable.vue +1114 -1114
  121. package/src/components/CTable/index.js +2 -2
  122. package/src/components/CTabs/CTabs.vue +250 -250
  123. package/src/components/CTabs/index.js +2 -2
  124. package/src/components/CTag/CTag.vue +109 -109
  125. package/src/components/CTag/index.js +2 -2
  126. package/src/components/CTextarea/CTextarea.vue +118 -118
  127. package/src/components/CTextarea/index.js +2 -2
  128. package/src/components/CTimeline/CTimeline.vue +237 -237
  129. package/src/components/CTimeline/index.js +2 -2
  130. package/src/components/CToolTip/CToolTip.vue +108 -108
  131. package/src/components/CToolTip/index.js +3 -3
  132. package/src/components/CUpload/CUpload.vue +331 -331
  133. package/src/components/CUpload/index.js +2 -2
  134. package/src/components/NumberAnimator.vue +112 -112
  135. package/src/components/index.js +58 -58
  136. package/src/helper.js +8 -8
  137. package/src/icons.js +831 -831
  138. package/src/main.js +22 -22
  139. package/src/stories/CAlertModal.stories.js +30 -30
  140. package/src/stories/CAlerts.stories.js +39 -39
  141. package/src/stories/CAnchorTabs.stories.js +29 -29
  142. package/src/stories/CAnchorTag.stories.js +38 -38
  143. package/src/stories/CAvatar.stories.js +38 -38
  144. package/src/stories/CAvatarGroup.stories.js +136 -136
  145. package/src/stories/CBasicTable.stories.js +316 -316
  146. package/src/stories/CBreadcrumbs.stories.js +24 -24
  147. package/src/stories/CButton.stories.js +49 -49
  148. package/src/stories/CButtonGroup.stories.js +43 -43
  149. package/src/stories/CButtonIcon.stories.js +27 -27
  150. package/src/stories/CButtonLink.stories.js +24 -24
  151. package/src/stories/CButtonSelect.stories.js +44 -44
  152. package/src/stories/CButtonSelectBorder.stories.js +56 -56
  153. package/src/stories/CButtonWithDropdown.stories.js +41 -41
  154. package/src/stories/CCalendar.stories.js +16 -16
  155. package/src/stories/CCard.stories.js +30 -30
  156. package/src/stories/CCheckbox.stories.js +38 -38
  157. package/src/stories/CCircularButton.stories.js +29 -29
  158. package/src/stories/CCollapsibleSection.stories.js +29 -29
  159. package/src/stories/CColorDots.stories.js +37 -37
  160. package/src/stories/CConfirmActionModal.stories.js +60 -60
  161. package/src/stories/CDatepicker.stories.js +31 -31
  162. package/src/stories/CDualSelect.stories.js +29 -29
  163. package/src/stories/CEditor.stories.js +30 -30
  164. package/src/stories/CFormSectionHeading.stories.js +37 -37
  165. package/src/stories/CGroupedFilterDropdown.stories.js +131 -176
  166. package/src/stories/CGroupedSelect.stories.js +103 -103
  167. package/src/stories/CIcon.stories.js +31 -31
  168. package/src/stories/CIconDropdown.stories.js +52 -52
  169. package/src/stories/CIconSelect.stories.js +45 -45
  170. package/src/stories/CInput.stories.js +36 -36
  171. package/src/stories/CInputAddon.stories.js +37 -37
  172. package/src/stories/CInputEmail.stories.js +27 -27
  173. package/src/stories/CInsetTabs.stories.js +48 -48
  174. package/src/stories/CLinearProgressBar.stories.js +22 -22
  175. package/src/stories/CModalHeading.stories.js +25 -25
  176. package/src/stories/CModuleHelpLinks.stories.js +25 -25
  177. package/src/stories/CMultiselect.stories.js +146 -136
  178. package/src/stories/CMultiselectr.stories.js +23 -23
  179. package/src/stories/CPageHeading.stories.js +32 -32
  180. package/src/stories/CPagination.stories.js +30 -30
  181. package/src/stories/CPhoneNumber.stories.js +37 -37
  182. package/src/stories/CProgress.stories.js +23 -23
  183. package/src/stories/CRadio.stories.js +44 -44
  184. package/src/stories/CRadioGroup.stories.js +51 -51
  185. package/src/stories/CRangeSlider.stories.js +23 -23
  186. package/src/stories/CReorderableStackedList.stories.js +23 -23
  187. package/src/stories/CSelect.stories.js +157 -157
  188. package/src/stories/CSmallTimeline.stories.js +26 -26
  189. package/src/stories/CStackedList.stories.js +37 -37
  190. package/src/stories/CStats.stories.js +53 -53
  191. package/src/stories/CSwitch.stories.js +28 -28
  192. package/src/stories/CTabLazy.stories.js +42 -42
  193. package/src/stories/CTable.stories.js +203 -203
  194. package/src/stories/CTabs.stories.js +36 -36
  195. package/src/stories/CTag.stories.js +37 -37
  196. package/src/stories/CTextarea.stories.js +32 -32
  197. package/src/stories/CTimeline.stories.js +26 -26
  198. package/src/stories/CToolTip.stories.js +27 -27
  199. package/src/stories/CUpload.stories.js +36 -36
  200. package/src/stories/Introduction.stories.mdx +207 -207
  201. package/src/stories/Page.vue +88 -88
  202. package/src/stories/assets/code-brackets.svg +0 -0
  203. package/src/stories/assets/colors.svg +0 -0
  204. package/src/stories/assets/comments.svg +0 -0
  205. package/src/stories/assets/direction.svg +0 -0
  206. package/src/stories/assets/flow.svg +0 -0
  207. package/src/stories/assets/plugin.svg +0 -0
  208. package/src/stories/assets/repo.svg +0 -0
  209. package/src/stories/assets/stackalt.svg +0 -0
  210. package/src/stories/header.css +26 -26
  211. package/src/stories/page.css +69 -69
  212. package/src/stories/utils.css +32 -32
@@ -1,443 +1,443 @@
1
- <template>
2
- <!-- This example requires Tailwind CSS v2.0+ -->
3
- <div>
4
- <div class="grid grid-cols-1 md:grid-cols-2 md:gap-8">
5
- <div :class="`sticky top-0 md:block ${calendarClasses}`">
6
- <div
7
- class="relative z-20 flex items-center justify-between border-b border-gray-200 py-4 px-4 sm:px-0"
8
- >
9
- <h2 class="flex-auto font-semibold text-gray-900">
10
- {{ currentMonthAndYear }}
11
- </h2>
12
- <div class="flex items-center">
13
- <div class="flex items-center rounded-md shadow-sm">
14
- <button
15
- @click="handlePreviousMonthClick"
16
- type="button"
17
- class="flex items-center justify-center rounded-l-md border border-r-0 border-gray-300 bg-white py-2 pl-3 pr-4 text-gray-400 hover:text-gray-500 focus:relative"
18
- :id="id + '_button_previous_month'"
19
- >
20
- <span class="sr-only">Previous month</span>
21
- <!-- Heroicon name: solid/chevron-left -->
22
- <svg
23
- class="h-5 w-5"
24
- xmlns="http://www.w3.org/2000/svg"
25
- viewBox="0 0 20 20"
26
- fill="currentColor"
27
- aria-hidden="true"
28
- >
29
- <path
30
- fill-rule="evenodd"
31
- d="M12.707 5.293a1 1 0 010 1.414L9.414 10l3.293 3.293a1 1 0 01-1.414 1.414l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 0z"
32
- clip-rule="evenodd"
33
- />
34
- </svg>
35
- </button>
36
- <span class="relative -mx-px h-5 w-px bg-gray-300"></span>
37
- <button
38
- @click="handleNextMonthClick"
39
- type="button"
40
- class="flex items-center justify-center rounded-r-md border border-l-0 border-gray-300 bg-white py-2 pl-4 pr-3 text-gray-400 hover:text-gray-500 focus:relative"
41
- :id="id + '_button_next_month'"
42
- >
43
- <span class="sr-only">Next month</span>
44
- <!-- Heroicon name: solid/chevron-right -->
45
- <svg
46
- class="h-5 w-5"
47
- xmlns="http://www.w3.org/2000/svg"
48
- viewBox="0 0 20 20"
49
- fill="currentColor"
50
- aria-hidden="true"
51
- >
52
- <path
53
- fill-rule="evenodd"
54
- d="M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z"
55
- clip-rule="evenodd"
56
- />
57
- </svg>
58
- </button>
59
- </div>
60
- </div>
61
- </div>
62
-
63
- <div
64
- class="col-span-1 overflow-hidden rounded shadow ring-1 ring-gray-200"
65
- >
66
- <div
67
- class="grid grid-cols-7 gap-px border-b border-gray-300 bg-gray-200 text-center text-xs font-semibold leading-6 text-gray-700"
68
- >
69
- <div class="bg-white py-2">Mo<span class="sr-only">on</span></div>
70
- <div class="bg-white py-2">Tu<span class="sr-only">ue</span></div>
71
- <div class="bg-white py-2">We<span class="sr-only">ed</span></div>
72
- <div class="bg-white py-2">Th<span class="sr-only">hu</span></div>
73
- <div class="bg-white py-2">Fr<span class="sr-only">ri</span></div>
74
- <div class="bg-white py-2">Sa<span class="sr-only">at</span></div>
75
- <div class="bg-white py-2">Su<span class="sr-only">un</span></div>
76
- </div>
77
- <div class="flex bg-gray-200 text-xs leading-6 text-gray-700">
78
- <div class="isolate grid w-full grid-cols-7 grid-rows-6 gap-px">
79
- <button
80
- v-for="date in daysArray"
81
- :key="getDateKey(date)"
82
- type="button"
83
- :class="{
84
- 'flex h-14 flex-col py-2 px-3 hover:bg-gray-100 focus:z-10': true,
85
- 'bg-white': isCurrentMonth(date),
86
- 'bg-gray-50': !isCurrentMonth(date),
87
- 'font-semibold': isSelected(date) || isToday(date),
88
- 'text-white': isSelected(date),
89
- 'text-indigo-600': !isSelected(date) && isToday(date),
90
- 'text-gray-900':
91
- !isSelected(date) && isCurrentMonth(date) && !isToday(date),
92
- 'text-gray-500':
93
- !isSelected(date) &&
94
- !isCurrentMonth(date) &&
95
- !isToday(date),
96
- }"
97
- @click="handleDateClick(date)"
98
- >
99
- <time
100
- :datetime="formatForDateTime(date)"
101
- :class="{
102
- 'ml-auto': true,
103
- 'flex h-6 w-6 items-center justify-center rounded-full':
104
- isSelected(date),
105
- 'bg-indigo-600': isSelected(date) && isToday(date),
106
- 'bg-gray-900': isSelected(date) && !isToday(date),
107
- }"
108
- >{{ getDayFromDate(date) }}</time
109
- >
110
- <span v-if="eventsCount" class="sr-only"
111
- >{{ getEventsCountForDate(date) }} events</span
112
- >
113
- <span
114
- v-if="eventsCount && getEventsCountForDate(date) > 0"
115
- class="-mx-0.5 mt-auto flex flex-wrap-reverse"
116
- >
117
- <span
118
- class="mx-0.5 mb-1 h-1.5 w-1.5 rounded-full bg-gray-400"
119
- ></span>
120
- </span>
121
- </button>
122
- </div>
123
- </div>
124
- </div>
125
- </div>
126
- <slot name="customCardsRender"></slot>
127
- <section
128
- v-if="eventsData && validSelectedDate && showDefaultCardUi"
129
- class="col-span-1 my-10 mx-4 md:mx-0 md:my-0"
130
- >
131
- <h2
132
- v-if="showSelectedDate"
133
- class="hidden py-4 font-semibold text-gray-900 md:block"
134
- >
135
- Schedule for
136
- <time :datetime="selectedDateForDateTime">{{
137
- formattedSelectedDate
138
- }}</time>
139
- </h2>
140
- <p
141
- v-if="getEventsForDate(value).length === 0"
142
- class="mt-3 text-center text-sm text-gray-400"
143
- >
144
- Sorry, no events found for this date.
145
- </p>
146
- <ol
147
- v-if="getEventsForDate(value).length !== 0"
148
- class="mt-3 divide-y divide-gray-100 overflow-hidden rounded-lg bg-white text-sm shadow ring-1 ring-indigo-700 ring-opacity-5"
149
- >
150
- <li
151
- class="cursor-pointer p-4 focus-within:bg-gray-50 hover:bg-gray-50"
152
- v-for="event in getEventsForDate(value)"
153
- :key="event.id"
154
- @click="handleEventClick(event)"
155
- >
156
- <div class="text-sm text-gray-900">
157
- {{ formatTimeFromDate(event.start) }} -
158
- {{ formatTimeFromDate(event.end) }}
159
- </div>
160
- <div
161
- class="mt-1 flex text-sm font-semibold"
162
- :style="{ color: event.color }"
163
- :class="event.status === 7 ? 'line-through' : ''"
164
- >
165
- <c-icon
166
- v-if="event.attendance"
167
- name="check"
168
- type="solid"
169
- class="mt-0.5 h-4 w-4 shrink-0"
170
- :style="`color:${event.color}`"
171
- ></c-icon>
172
- {{ event.title }}
173
- </div>
174
- <div class="-mx-1 -my-0.5 flex flex-wrap items-center">
175
- <div class="mx-1 my-0.5 flex items-center space-x-0.5">
176
- <svg
177
- xmlns="http://www.w3.org/2000/svg"
178
- class="h-4 w-4 flex-none text-gray-400"
179
- fill="none"
180
- viewBox="0 0 24 24"
181
- stroke="currentColor"
182
- stroke-width="2"
183
- >
184
- <path
185
- stroke-linecap="round"
186
- stroke-linejoin="round"
187
- d="M12 8v4l3 3m6-3a9 9 0 11-18 0 9 9 0 0118 0z"
188
- />
189
- </svg>
190
- <span class="min-w-0 flex-1 text-sm text-gray-500"
191
- >{{ event.duration }} mins</span
192
- >
193
- </div>
194
- <div
195
- v-if="event.subject && event.subject.length"
196
- class="mx-1 my-0.5 flex items-center space-x-0.5"
197
- >
198
- <svg
199
- xmlns="http://www.w3.org/2000/svg"
200
- class="h-4 w-4 flex-none text-gray-400"
201
- fill="none"
202
- viewBox="0 0 24 24"
203
- stroke="currentColor"
204
- stroke-width="2"
205
- >
206
- <path
207
- stroke-linecap="round"
208
- stroke-linejoin="round"
209
- d="M5 5a2 2 0 012-2h10a2 2 0 012 2v16l-7-3.5L5 21V5z"
210
- />
211
- </svg>
212
- <span class="min-w-0 flex-1 text-sm text-gray-500">{{
213
- event.subject
214
- }}</span>
215
- </div>
216
- <div
217
- v-if="event.location && event.location.length"
218
- class="mx-1 my-0.5 flex items-center space-x-0.5"
219
- >
220
- <svg
221
- xmlns="http://www.w3.org/2000/svg"
222
- class="h-4 w-4 flex-none text-gray-400"
223
- fill="none"
224
- viewBox="0 0 24 24"
225
- stroke="currentColor"
226
- stroke-width="2"
227
- >
228
- <path
229
- stroke-linecap="round"
230
- stroke-linejoin="round"
231
- d="M9 20l-5.447-2.724A1 1 0 013 16.382V5.618a1 1 0 011.447-.894L9 7m0 13l6-3m-6 3V7m6 10l4.553 2.276A1 1 0 0021 18.382V7.618a1 1 0 00-.553-.894L15 4m0 13V4m0 0L9 7"
232
- />
233
- </svg>
234
- <span class="min-w-0 flex-1 text-sm text-gray-500">{{
235
- event.location
236
- }}</span>
237
- </div>
238
- <div
239
- v-if="
240
- event.video_call_type == 1 ||
241
- event.video_call_type == 2 ||
242
- event.video_call_type == 3
243
- "
244
- class="mx-1 my-0.5 flex items-center space-x-0.5"
245
- >
246
- <c-icon
247
- name="video-camera-outline"
248
- type="outline"
249
- class="h-4 w-4 flex-shrink-0 text-gray-400"
250
- ></c-icon>
251
- <p class="min-w-0 flex-1 text-sm text-gray-500">
252
- {{
253
- event.video_call_type == 1
254
- ? "Lessonspace link"
255
- : event.video_call_type == 2
256
- ? "Meeting link"
257
- : "Zoom link"
258
- }}
259
- </p>
260
- </div>
261
- <div
262
- v-if="event.staff && event.staff.length"
263
- class="mx-1 my-0.5 flex items-center space-x-0.5"
264
- >
265
- <svg
266
- xmlns="http://www.w3.org/2000/svg"
267
- class="h-4 w-4 flex-none text-gray-400"
268
- fill="none"
269
- viewBox="0 0 24 24"
270
- stroke="currentColor"
271
- stroke-width="2"
272
- >
273
- <path
274
- stroke-linecap="round"
275
- stroke-linejoin="round"
276
- d="M21 13.255A23.931 23.931 0 0112 15c-3.183 0-6.22-.62-9-1.745M16 6V4a2 2 0 00-2-2h-4a2 2 0 00-2 2v2m4 6h.01M5 20h14a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"
277
- />
278
- </svg>
279
- <span class="min-w-0 flex-1 text-sm text-gray-500">{{
280
- event.staff
281
- }}</span>
282
- </div>
283
- </div>
284
- </li>
285
- </ol>
286
- </section>
287
- </div>
288
- </div>
289
- </template>
290
-
291
- <script>
292
- import * as dayjs from "dayjs";
293
- import CIcon from "../CIcon/CIcon.vue";
294
-
295
- export default {
296
- name: "CCalendar",
297
- components: { CIcon },
298
- props: {
299
- value: {
300
- type: [String, Date, Object],
301
- default: () => dayjs(),
302
- },
303
- id: {
304
- type: String,
305
- },
306
- eventsCount: {
307
- type: Array,
308
- default: () => null,
309
- },
310
- eventsData: {
311
- type: Array,
312
- default: () => null,
313
- },
314
- calendarClasses: {
315
- type: String,
316
- default: "",
317
- },
318
- showSelectedDate: {
319
- type: Boolean,
320
- default: true,
321
- },
322
- showDefaultCardUi: {
323
- type: Boolean,
324
- default: true,
325
- },
326
- },
327
- data() {
328
- return {
329
- activeDate: dayjs(),
330
- };
331
- },
332
- methods: {
333
- handlePreviousMonthClick() {
334
- this.activeDate = this.activeDate.subtract(1, "month");
335
- this.$emit("prev-month", this.getActiveStartAndEndDates());
336
- },
337
- handleNextMonthClick() {
338
- this.activeDate = this.activeDate.add(1, "month");
339
- this.$emit("next-month", this.getActiveStartAndEndDates());
340
- },
341
- handleDateClick(date) {
342
- this.$emit("input", date);
343
- },
344
- getDayFromDate(date) {
345
- return dayjs(date).format("D");
346
- },
347
- isSelected(date) {
348
- return dayjs(date).isSame(this.value, "day");
349
- },
350
- isToday(date) {
351
- return dayjs(date).isSame(dayjs(), "day");
352
- },
353
- isCurrentMonth(date) {
354
- return dayjs(date).isSame(this.activeDate, "month");
355
- },
356
- getDateKey(date) {
357
- return dayjs(date).format();
358
- },
359
- formatForDateTime(date) {
360
- return dayjs(date).format("YYYY-MM-DD");
361
- },
362
- formatTimeFromDate(date) {
363
- return dayjs(date).format("hh:mma");
364
- },
365
- getEventsCountForDate(date) {
366
- let eventsCountObj = this.eventsCount.find((event) =>
367
- dayjs(date).isSame(dayjs(event.date), "day")
368
- );
369
- if (eventsCountObj) {
370
- return eventsCountObj.eventsCount;
371
- } else {
372
- return 0;
373
- }
374
- },
375
- getActiveStartAndEndDates() {
376
- return {
377
- startDate: this.daysArray[0],
378
- endDate: this.daysArray[this.daysArray.length - 1],
379
- };
380
- },
381
- getEventsForDate(date) {
382
- return this.eventsData.filter((event) =>
383
- dayjs(date).isSame(dayjs(event.start), "day")
384
- );
385
- },
386
- handleEventClick(event) {
387
- this.$emit("event-click", event);
388
- },
389
- },
390
- computed: {
391
- currentMonthAndYear() {
392
- return dayjs(this.activeDate).format("MMMM YYYY");
393
- },
394
- daysArray() {
395
- let dates = [];
396
- let firstDayOfmonth = dayjs(this.activeDate).startOf("month");
397
- let lastDayOfmonth = dayjs(this.activeDate).endOf("month");
398
- let firstDayOfMonthInWeek = firstDayOfmonth.day();
399
- let lastDayOfMonthInWeek = lastDayOfmonth.day();
400
- if (firstDayOfMonthInWeek === 0) {
401
- firstDayOfMonthInWeek = 7;
402
- }
403
- if (lastDayOfMonthInWeek === 0) {
404
- lastDayOfMonthInWeek = 7;
405
- }
406
- for (let i = 0; i < firstDayOfMonthInWeek - 1; i++) {
407
- dates.unshift(firstDayOfmonth.subtract(i + 1, "day"));
408
- }
409
- for (let i = 0; i < dayjs(this.activeDate).daysInMonth(); i++) {
410
- dates.push(firstDayOfmonth.add(i, "day"));
411
- }
412
- let cursor = 1;
413
- for (let i = lastDayOfMonthInWeek; i < 7; i++) {
414
- dates.push(lastDayOfmonth.add(cursor, "day"));
415
- cursor++;
416
- }
417
- if (dates.length !== 42) {
418
- let lastDayOfDates = dates[dates.length - 1];
419
- for (let i = 1; i <= 7; i++) {
420
- dates.push(lastDayOfDates.add(i, "day"));
421
- }
422
- }
423
- return dates;
424
- },
425
- formattedSelectedDate() {
426
- return dayjs(this.value ? this.value : dayjs()).format("MMMM D, YYYY");
427
- },
428
- selectedDateForDateTime() {
429
- return dayjs(this.value ? this.value : dayjs()).format("YYYY-MM-DD");
430
- },
431
- validSelectedDate() {
432
- return this.value && dayjs(this.value).isValid();
433
- },
434
- },
435
- mounted() {
436
- if (this.value) {
437
- this.activeDate = dayjs(this.value);
438
- }
439
- },
440
- };
441
- </script>
442
-
443
- <style></style>
1
+ <template>
2
+ <!-- This example requires Tailwind CSS v2.0+ -->
3
+ <div>
4
+ <div class="grid grid-cols-1 md:grid-cols-2 md:gap-8">
5
+ <div :class="`sticky top-0 md:block ${calendarClasses}`">
6
+ <div
7
+ class="relative z-20 flex items-center justify-between border-b border-gray-200 py-4 px-4 sm:px-0"
8
+ >
9
+ <h2 class="flex-auto font-semibold text-gray-900">
10
+ {{ currentMonthAndYear }}
11
+ </h2>
12
+ <div class="flex items-center">
13
+ <div class="flex items-center rounded-md shadow-sm">
14
+ <button
15
+ @click="handlePreviousMonthClick"
16
+ type="button"
17
+ class="flex items-center justify-center rounded-l-md border border-r-0 border-gray-300 bg-white py-2 pl-3 pr-4 text-gray-400 hover:text-gray-500 focus:relative"
18
+ :id="id + '_button_previous_month'"
19
+ >
20
+ <span class="sr-only">Previous month</span>
21
+ <!-- Heroicon name: solid/chevron-left -->
22
+ <svg
23
+ class="h-5 w-5"
24
+ xmlns="http://www.w3.org/2000/svg"
25
+ viewBox="0 0 20 20"
26
+ fill="currentColor"
27
+ aria-hidden="true"
28
+ >
29
+ <path
30
+ fill-rule="evenodd"
31
+ d="M12.707 5.293a1 1 0 010 1.414L9.414 10l3.293 3.293a1 1 0 01-1.414 1.414l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 0z"
32
+ clip-rule="evenodd"
33
+ />
34
+ </svg>
35
+ </button>
36
+ <span class="relative -mx-px h-5 w-px bg-gray-300"></span>
37
+ <button
38
+ @click="handleNextMonthClick"
39
+ type="button"
40
+ class="flex items-center justify-center rounded-r-md border border-l-0 border-gray-300 bg-white py-2 pl-4 pr-3 text-gray-400 hover:text-gray-500 focus:relative"
41
+ :id="id + '_button_next_month'"
42
+ >
43
+ <span class="sr-only">Next month</span>
44
+ <!-- Heroicon name: solid/chevron-right -->
45
+ <svg
46
+ class="h-5 w-5"
47
+ xmlns="http://www.w3.org/2000/svg"
48
+ viewBox="0 0 20 20"
49
+ fill="currentColor"
50
+ aria-hidden="true"
51
+ >
52
+ <path
53
+ fill-rule="evenodd"
54
+ d="M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z"
55
+ clip-rule="evenodd"
56
+ />
57
+ </svg>
58
+ </button>
59
+ </div>
60
+ </div>
61
+ </div>
62
+
63
+ <div
64
+ class="col-span-1 overflow-hidden rounded shadow ring-1 ring-gray-200"
65
+ >
66
+ <div
67
+ class="grid grid-cols-7 gap-px border-b border-gray-300 bg-gray-200 text-center text-xs font-semibold leading-6 text-gray-700"
68
+ >
69
+ <div class="bg-white py-2">Mo<span class="sr-only">on</span></div>
70
+ <div class="bg-white py-2">Tu<span class="sr-only">ue</span></div>
71
+ <div class="bg-white py-2">We<span class="sr-only">ed</span></div>
72
+ <div class="bg-white py-2">Th<span class="sr-only">hu</span></div>
73
+ <div class="bg-white py-2">Fr<span class="sr-only">ri</span></div>
74
+ <div class="bg-white py-2">Sa<span class="sr-only">at</span></div>
75
+ <div class="bg-white py-2">Su<span class="sr-only">un</span></div>
76
+ </div>
77
+ <div class="flex bg-gray-200 text-xs leading-6 text-gray-700">
78
+ <div class="isolate grid w-full grid-cols-7 grid-rows-6 gap-px">
79
+ <button
80
+ v-for="date in daysArray"
81
+ :key="getDateKey(date)"
82
+ type="button"
83
+ :class="{
84
+ 'flex h-14 flex-col py-2 px-3 hover:bg-gray-100 focus:z-10': true,
85
+ 'bg-white': isCurrentMonth(date),
86
+ 'bg-gray-50': !isCurrentMonth(date),
87
+ 'font-semibold': isSelected(date) || isToday(date),
88
+ 'text-white': isSelected(date),
89
+ 'text-indigo-600': !isSelected(date) && isToday(date),
90
+ 'text-gray-900':
91
+ !isSelected(date) && isCurrentMonth(date) && !isToday(date),
92
+ 'text-gray-500':
93
+ !isSelected(date) &&
94
+ !isCurrentMonth(date) &&
95
+ !isToday(date),
96
+ }"
97
+ @click="handleDateClick(date)"
98
+ >
99
+ <time
100
+ :datetime="formatForDateTime(date)"
101
+ :class="{
102
+ 'ml-auto': true,
103
+ 'flex h-6 w-6 items-center justify-center rounded-full':
104
+ isSelected(date),
105
+ 'bg-indigo-600': isSelected(date) && isToday(date),
106
+ 'bg-gray-900': isSelected(date) && !isToday(date),
107
+ }"
108
+ >{{ getDayFromDate(date) }}</time
109
+ >
110
+ <span v-if="eventsCount" class="sr-only"
111
+ >{{ getEventsCountForDate(date) }} events</span
112
+ >
113
+ <span
114
+ v-if="eventsCount && getEventsCountForDate(date) > 0"
115
+ class="-mx-0.5 mt-auto flex flex-wrap-reverse"
116
+ >
117
+ <span
118
+ class="mx-0.5 mb-1 h-1.5 w-1.5 rounded-full bg-gray-400"
119
+ ></span>
120
+ </span>
121
+ </button>
122
+ </div>
123
+ </div>
124
+ </div>
125
+ </div>
126
+ <slot name="customCardsRender"></slot>
127
+ <section
128
+ v-if="eventsData && validSelectedDate && showDefaultCardUi"
129
+ class="col-span-1 my-10 mx-4 md:mx-0 md:my-0"
130
+ >
131
+ <h2
132
+ v-if="showSelectedDate"
133
+ class="hidden py-4 font-semibold text-gray-900 md:block"
134
+ >
135
+ Schedule for
136
+ <time :datetime="selectedDateForDateTime">{{
137
+ formattedSelectedDate
138
+ }}</time>
139
+ </h2>
140
+ <p
141
+ v-if="getEventsForDate(value).length === 0"
142
+ class="mt-3 text-center text-sm text-gray-400"
143
+ >
144
+ Sorry, no events found for this date.
145
+ </p>
146
+ <ol
147
+ v-if="getEventsForDate(value).length !== 0"
148
+ class="mt-3 divide-y divide-gray-100 overflow-hidden rounded-lg bg-white text-sm shadow ring-1 ring-indigo-700 ring-opacity-5"
149
+ >
150
+ <li
151
+ class="cursor-pointer p-4 focus-within:bg-gray-50 hover:bg-gray-50"
152
+ v-for="event in getEventsForDate(value)"
153
+ :key="event.id"
154
+ @click="handleEventClick(event)"
155
+ >
156
+ <div class="text-sm text-gray-900">
157
+ {{ formatTimeFromDate(event.start) }} -
158
+ {{ formatTimeFromDate(event.end) }}
159
+ </div>
160
+ <div
161
+ class="mt-1 flex text-sm font-semibold"
162
+ :style="{ color: event.color }"
163
+ :class="event.status === 7 ? 'line-through' : ''"
164
+ >
165
+ <c-icon
166
+ v-if="event.attendance"
167
+ name="check"
168
+ type="solid"
169
+ class="mt-0.5 h-4 w-4 shrink-0"
170
+ :style="`color:${event.color}`"
171
+ ></c-icon>
172
+ {{ event.title }}
173
+ </div>
174
+ <div class="-mx-1 -my-0.5 flex flex-wrap items-center">
175
+ <div class="mx-1 my-0.5 flex items-center space-x-0.5">
176
+ <svg
177
+ xmlns="http://www.w3.org/2000/svg"
178
+ class="h-4 w-4 flex-none text-gray-400"
179
+ fill="none"
180
+ viewBox="0 0 24 24"
181
+ stroke="currentColor"
182
+ stroke-width="2"
183
+ >
184
+ <path
185
+ stroke-linecap="round"
186
+ stroke-linejoin="round"
187
+ d="M12 8v4l3 3m6-3a9 9 0 11-18 0 9 9 0 0118 0z"
188
+ />
189
+ </svg>
190
+ <span class="min-w-0 flex-1 text-sm text-gray-500"
191
+ >{{ event.duration }} mins</span
192
+ >
193
+ </div>
194
+ <div
195
+ v-if="event.subject && event.subject.length"
196
+ class="mx-1 my-0.5 flex items-center space-x-0.5"
197
+ >
198
+ <svg
199
+ xmlns="http://www.w3.org/2000/svg"
200
+ class="h-4 w-4 flex-none text-gray-400"
201
+ fill="none"
202
+ viewBox="0 0 24 24"
203
+ stroke="currentColor"
204
+ stroke-width="2"
205
+ >
206
+ <path
207
+ stroke-linecap="round"
208
+ stroke-linejoin="round"
209
+ d="M5 5a2 2 0 012-2h10a2 2 0 012 2v16l-7-3.5L5 21V5z"
210
+ />
211
+ </svg>
212
+ <span class="min-w-0 flex-1 text-sm text-gray-500">{{
213
+ event.subject
214
+ }}</span>
215
+ </div>
216
+ <div
217
+ v-if="event.location && event.location.length"
218
+ class="mx-1 my-0.5 flex items-center space-x-0.5"
219
+ >
220
+ <svg
221
+ xmlns="http://www.w3.org/2000/svg"
222
+ class="h-4 w-4 flex-none text-gray-400"
223
+ fill="none"
224
+ viewBox="0 0 24 24"
225
+ stroke="currentColor"
226
+ stroke-width="2"
227
+ >
228
+ <path
229
+ stroke-linecap="round"
230
+ stroke-linejoin="round"
231
+ d="M9 20l-5.447-2.724A1 1 0 013 16.382V5.618a1 1 0 011.447-.894L9 7m0 13l6-3m-6 3V7m6 10l4.553 2.276A1 1 0 0021 18.382V7.618a1 1 0 00-.553-.894L15 4m0 13V4m0 0L9 7"
232
+ />
233
+ </svg>
234
+ <span class="min-w-0 flex-1 text-sm text-gray-500">{{
235
+ event.location
236
+ }}</span>
237
+ </div>
238
+ <div
239
+ v-if="
240
+ event.video_call_type == 1 ||
241
+ event.video_call_type == 2 ||
242
+ event.video_call_type == 3
243
+ "
244
+ class="mx-1 my-0.5 flex items-center space-x-0.5"
245
+ >
246
+ <c-icon
247
+ name="video-camera-outline"
248
+ type="outline"
249
+ class="h-4 w-4 flex-shrink-0 text-gray-400"
250
+ ></c-icon>
251
+ <p class="min-w-0 flex-1 text-sm text-gray-500">
252
+ {{
253
+ event.video_call_type == 1
254
+ ? "Lessonspace link"
255
+ : event.video_call_type == 2
256
+ ? "Meeting link"
257
+ : "Zoom link"
258
+ }}
259
+ </p>
260
+ </div>
261
+ <div
262
+ v-if="event.staff && event.staff.length"
263
+ class="mx-1 my-0.5 flex items-center space-x-0.5"
264
+ >
265
+ <svg
266
+ xmlns="http://www.w3.org/2000/svg"
267
+ class="h-4 w-4 flex-none text-gray-400"
268
+ fill="none"
269
+ viewBox="0 0 24 24"
270
+ stroke="currentColor"
271
+ stroke-width="2"
272
+ >
273
+ <path
274
+ stroke-linecap="round"
275
+ stroke-linejoin="round"
276
+ d="M21 13.255A23.931 23.931 0 0112 15c-3.183 0-6.22-.62-9-1.745M16 6V4a2 2 0 00-2-2h-4a2 2 0 00-2 2v2m4 6h.01M5 20h14a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"
277
+ />
278
+ </svg>
279
+ <span class="min-w-0 flex-1 text-sm text-gray-500">{{
280
+ event.staff
281
+ }}</span>
282
+ </div>
283
+ </div>
284
+ </li>
285
+ </ol>
286
+ </section>
287
+ </div>
288
+ </div>
289
+ </template>
290
+
291
+ <script>
292
+ import * as dayjs from "dayjs";
293
+ import CIcon from "../CIcon/CIcon.vue";
294
+
295
+ export default {
296
+ name: "CCalendar",
297
+ components: { CIcon },
298
+ props: {
299
+ value: {
300
+ type: [String, Date, Object],
301
+ default: () => dayjs(),
302
+ },
303
+ id: {
304
+ type: String,
305
+ },
306
+ eventsCount: {
307
+ type: Array,
308
+ default: () => null,
309
+ },
310
+ eventsData: {
311
+ type: Array,
312
+ default: () => null,
313
+ },
314
+ calendarClasses: {
315
+ type: String,
316
+ default: "",
317
+ },
318
+ showSelectedDate: {
319
+ type: Boolean,
320
+ default: true,
321
+ },
322
+ showDefaultCardUi: {
323
+ type: Boolean,
324
+ default: true,
325
+ },
326
+ },
327
+ data() {
328
+ return {
329
+ activeDate: dayjs(),
330
+ };
331
+ },
332
+ methods: {
333
+ handlePreviousMonthClick() {
334
+ this.activeDate = this.activeDate.subtract(1, "month");
335
+ this.$emit("prev-month", this.getActiveStartAndEndDates());
336
+ },
337
+ handleNextMonthClick() {
338
+ this.activeDate = this.activeDate.add(1, "month");
339
+ this.$emit("next-month", this.getActiveStartAndEndDates());
340
+ },
341
+ handleDateClick(date) {
342
+ this.$emit("input", date);
343
+ },
344
+ getDayFromDate(date) {
345
+ return dayjs(date).format("D");
346
+ },
347
+ isSelected(date) {
348
+ return dayjs(date).isSame(this.value, "day");
349
+ },
350
+ isToday(date) {
351
+ return dayjs(date).isSame(dayjs(), "day");
352
+ },
353
+ isCurrentMonth(date) {
354
+ return dayjs(date).isSame(this.activeDate, "month");
355
+ },
356
+ getDateKey(date) {
357
+ return dayjs(date).format();
358
+ },
359
+ formatForDateTime(date) {
360
+ return dayjs(date).format("YYYY-MM-DD");
361
+ },
362
+ formatTimeFromDate(date) {
363
+ return dayjs(date).format("hh:mma");
364
+ },
365
+ getEventsCountForDate(date) {
366
+ let eventsCountObj = this.eventsCount.find((event) =>
367
+ dayjs(date).isSame(dayjs(event.date), "day")
368
+ );
369
+ if (eventsCountObj) {
370
+ return eventsCountObj.eventsCount;
371
+ } else {
372
+ return 0;
373
+ }
374
+ },
375
+ getActiveStartAndEndDates() {
376
+ return {
377
+ startDate: this.daysArray[0],
378
+ endDate: this.daysArray[this.daysArray.length - 1],
379
+ };
380
+ },
381
+ getEventsForDate(date) {
382
+ return this.eventsData.filter((event) =>
383
+ dayjs(date).isSame(dayjs(event.start), "day")
384
+ );
385
+ },
386
+ handleEventClick(event) {
387
+ this.$emit("event-click", event);
388
+ },
389
+ },
390
+ computed: {
391
+ currentMonthAndYear() {
392
+ return dayjs(this.activeDate).format("MMMM YYYY");
393
+ },
394
+ daysArray() {
395
+ let dates = [];
396
+ let firstDayOfmonth = dayjs(this.activeDate).startOf("month");
397
+ let lastDayOfmonth = dayjs(this.activeDate).endOf("month");
398
+ let firstDayOfMonthInWeek = firstDayOfmonth.day();
399
+ let lastDayOfMonthInWeek = lastDayOfmonth.day();
400
+ if (firstDayOfMonthInWeek === 0) {
401
+ firstDayOfMonthInWeek = 7;
402
+ }
403
+ if (lastDayOfMonthInWeek === 0) {
404
+ lastDayOfMonthInWeek = 7;
405
+ }
406
+ for (let i = 0; i < firstDayOfMonthInWeek - 1; i++) {
407
+ dates.unshift(firstDayOfmonth.subtract(i + 1, "day"));
408
+ }
409
+ for (let i = 0; i < dayjs(this.activeDate).daysInMonth(); i++) {
410
+ dates.push(firstDayOfmonth.add(i, "day"));
411
+ }
412
+ let cursor = 1;
413
+ for (let i = lastDayOfMonthInWeek; i < 7; i++) {
414
+ dates.push(lastDayOfmonth.add(cursor, "day"));
415
+ cursor++;
416
+ }
417
+ if (dates.length !== 42) {
418
+ let lastDayOfDates = dates[dates.length - 1];
419
+ for (let i = 1; i <= 7; i++) {
420
+ dates.push(lastDayOfDates.add(i, "day"));
421
+ }
422
+ }
423
+ return dates;
424
+ },
425
+ formattedSelectedDate() {
426
+ return dayjs(this.value ? this.value : dayjs()).format("MMMM D, YYYY");
427
+ },
428
+ selectedDateForDateTime() {
429
+ return dayjs(this.value ? this.value : dayjs()).format("YYYY-MM-DD");
430
+ },
431
+ validSelectedDate() {
432
+ return this.value && dayjs(this.value).isValid();
433
+ },
434
+ },
435
+ mounted() {
436
+ if (this.value) {
437
+ this.activeDate = dayjs(this.value);
438
+ }
439
+ },
440
+ };
441
+ </script>
442
+
443
+ <style></style>