classcard-ui 0.2.1475 → 0.2.1476

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 (209) hide show
  1. package/README.md +24 -24
  2. package/dist/classcard-ui.common.js +86 -85
  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 +86 -85
  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 +83 -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 +263 -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/CModalHeading/CModalHeading.vue +22 -22
  83. package/src/components/CModalHeading/index.js +2 -2
  84. package/src/components/CModuleHelpLinks/CModuleHelpLinks.vue +88 -88
  85. package/src/components/CModuleHelpLinks/index.js +3 -3
  86. package/src/components/CMultiselect/CMultiselect.vue +1170 -1170
  87. package/src/components/CMultiselect/index.js +2 -2
  88. package/src/components/CMultiselectr/CMultiselectr.vue +44 -44
  89. package/src/components/CMultiselectr/index.js +2 -2
  90. package/src/components/CPageHeading/CPageHeading.vue +83 -83
  91. package/src/components/CPageHeading/index.js +2 -2
  92. package/src/components/CPagination/CPagination.vue +239 -239
  93. package/src/components/CPagination/index.js +2 -2
  94. package/src/components/CPhoneNumber/CPhoneNumber.vue +213 -213
  95. package/src/components/CPhoneNumber/index.js +2 -2
  96. package/src/components/CProgress/CProgress.vue +91 -91
  97. package/src/components/CProgress/index.js +2 -2
  98. package/src/components/CRadio/CRadio.vue +197 -197
  99. package/src/components/CRadio/index.js +2 -2
  100. package/src/components/CRadioGroup/CRadioGroup.vue +96 -96
  101. package/src/components/CRadioGroup/index.js +2 -2
  102. package/src/components/CRangeSlider/CRangeSlider.vue +55 -55
  103. package/src/components/CRangeSlider/index.js +2 -2
  104. package/src/components/CReorderableStackedList/CReorderableStackedList.vue +94 -94
  105. package/src/components/CReorderableStackedList/index.js +2 -2
  106. package/src/components/CSelect/CSelect.vue +1210 -1210
  107. package/src/components/CSelect/index.js +2 -2
  108. package/src/components/CSmallTimeline/CSmallTimeline.vue +40 -40
  109. package/src/components/CSmallTimeline/index.js +2 -2
  110. package/src/components/CStackedList/CStackedList.vue +162 -162
  111. package/src/components/CStackedList/index.js +2 -2
  112. package/src/components/CStats/CStats.vue +157 -157
  113. package/src/components/CStats/index.js +2 -2
  114. package/src/components/CSwitch/CSwitch.vue +200 -200
  115. package/src/components/CSwitch/index.js +2 -2
  116. package/src/components/CTabLazy/CTabLazy.vue +83 -83
  117. package/src/components/CTabLazy/index.js +2 -2
  118. package/src/components/CTable/CTable.vue +1114 -1114
  119. package/src/components/CTable/index.js +2 -2
  120. package/src/components/CTabs/CTabs.vue +250 -250
  121. package/src/components/CTabs/index.js +2 -2
  122. package/src/components/CTag/CTag.vue +109 -109
  123. package/src/components/CTag/index.js +2 -2
  124. package/src/components/CTextarea/CTextarea.vue +118 -118
  125. package/src/components/CTextarea/index.js +2 -2
  126. package/src/components/CTimeline/CTimeline.vue +237 -237
  127. package/src/components/CTimeline/index.js +2 -2
  128. package/src/components/CToolTip/CToolTip.vue +108 -108
  129. package/src/components/CToolTip/index.js +3 -3
  130. package/src/components/CUpload/CUpload.vue +331 -331
  131. package/src/components/CUpload/index.js +2 -2
  132. package/src/components/NumberAnimator.vue +112 -112
  133. package/src/components/index.js +57 -57
  134. package/src/helper.js +8 -8
  135. package/src/icons.js +831 -830
  136. package/src/main.js +22 -22
  137. package/src/stories/CAlertModal.stories.js +30 -30
  138. package/src/stories/CAlerts.stories.js +39 -39
  139. package/src/stories/CAnchorTabs.stories.js +29 -29
  140. package/src/stories/CAnchorTag.stories.js +38 -38
  141. package/src/stories/CAvatar.stories.js +38 -38
  142. package/src/stories/CAvatarGroup.stories.js +136 -136
  143. package/src/stories/CBasicTable.stories.js +316 -316
  144. package/src/stories/CBreadcrumbs.stories.js +24 -24
  145. package/src/stories/CButton.stories.js +49 -49
  146. package/src/stories/CButtonGroup.stories.js +43 -43
  147. package/src/stories/CButtonIcon.stories.js +27 -27
  148. package/src/stories/CButtonLink.stories.js +24 -24
  149. package/src/stories/CButtonSelect.stories.js +44 -44
  150. package/src/stories/CButtonSelectBorder.stories.js +56 -56
  151. package/src/stories/CButtonWithDropdown.stories.js +41 -41
  152. package/src/stories/CCalendar.stories.js +16 -16
  153. package/src/stories/CCard.stories.js +30 -30
  154. package/src/stories/CCheckbox.stories.js +38 -38
  155. package/src/stories/CCircularButton.stories.js +29 -29
  156. package/src/stories/CCollapsibleSection.stories.js +29 -29
  157. package/src/stories/CColorDots.stories.js +37 -37
  158. package/src/stories/CConfirmActionModal.stories.js +60 -60
  159. package/src/stories/CDatepicker.stories.js +31 -31
  160. package/src/stories/CDualSelect.stories.js +29 -29
  161. package/src/stories/CEditor.stories.js +30 -30
  162. package/src/stories/CFormSectionHeading.stories.js +37 -37
  163. package/src/stories/CGroupedFilterDropdown.stories.js +176 -176
  164. package/src/stories/CGroupedSelect.stories.js +103 -103
  165. package/src/stories/CIcon.stories.js +31 -31
  166. package/src/stories/CIconDropdown.stories.js +52 -52
  167. package/src/stories/CIconSelect.stories.js +45 -45
  168. package/src/stories/CInput.stories.js +36 -36
  169. package/src/stories/CInputAddon.stories.js +37 -37
  170. package/src/stories/CInputEmail.stories.js +27 -27
  171. package/src/stories/CInsetTabs.stories.js +48 -48
  172. package/src/stories/CModalHeading.stories.js +25 -25
  173. package/src/stories/CModuleHelpLinks.stories.js +25 -25
  174. package/src/stories/CMultiselect.stories.js +136 -136
  175. package/src/stories/CMultiselectr.stories.js +23 -23
  176. package/src/stories/CPageHeading.stories.js +32 -32
  177. package/src/stories/CPagination.stories.js +30 -30
  178. package/src/stories/CPhoneNumber.stories.js +37 -37
  179. package/src/stories/CProgress.stories.js +23 -23
  180. package/src/stories/CRadio.stories.js +44 -44
  181. package/src/stories/CRadioGroup.stories.js +51 -51
  182. package/src/stories/CRangeSlider.stories.js +23 -23
  183. package/src/stories/CReorderableStackedList.stories.js +23 -23
  184. package/src/stories/CSelect.stories.js +157 -157
  185. package/src/stories/CSmallTimeline.stories.js +26 -26
  186. package/src/stories/CStackedList.stories.js +37 -37
  187. package/src/stories/CStats.stories.js +53 -53
  188. package/src/stories/CSwitch.stories.js +28 -28
  189. package/src/stories/CTabLazy.stories.js +42 -42
  190. package/src/stories/CTable.stories.js +203 -203
  191. package/src/stories/CTabs.stories.js +36 -36
  192. package/src/stories/CTag.stories.js +37 -37
  193. package/src/stories/CTextarea.stories.js +32 -32
  194. package/src/stories/CTimeline.stories.js +26 -26
  195. package/src/stories/CToolTip.stories.js +27 -27
  196. package/src/stories/CUpload.stories.js +36 -36
  197. package/src/stories/Introduction.stories.mdx +207 -207
  198. package/src/stories/Page.vue +88 -88
  199. package/src/stories/assets/code-brackets.svg +0 -0
  200. package/src/stories/assets/colors.svg +0 -0
  201. package/src/stories/assets/comments.svg +0 -0
  202. package/src/stories/assets/direction.svg +0 -0
  203. package/src/stories/assets/flow.svg +0 -0
  204. package/src/stories/assets/plugin.svg +0 -0
  205. package/src/stories/assets/repo.svg +0 -0
  206. package/src/stories/assets/stackalt.svg +0 -0
  207. package/src/stories/header.css +26 -26
  208. package/src/stories/page.css +69 -69
  209. 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>