@sparkle-learning/core 0.0.57 → 0.0.58

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 (1100) hide show
  1. package/dist/cjs/PrivateRoute-f97245ce.js +217 -0
  2. package/dist/cjs/active-router-f9e18bd8.js +75 -0
  3. package/dist/cjs/animation-ee586546.js +986 -0
  4. package/dist/cjs/app-globals-33c9f31b.js +9 -0
  5. package/dist/cjs/appdata.service-c8d71e05.js +73 -0
  6. package/dist/cjs/assets.service-bfa75092.js +50 -0
  7. package/dist/cjs/assignment.service-690fb59c.js +19 -0
  8. package/dist/cjs/auth.store-1e630a7d.js +3392 -0
  9. package/dist/cjs/compass-svg.cjs.entry.js +132 -0
  10. package/dist/cjs/context-consumer.cjs.entry.js +29 -0
  11. package/dist/cjs/course-select.cjs.entry.js +30 -0
  12. package/dist/cjs/cubic-bezier-53d26d05.js +93 -0
  13. package/dist/cjs/dir-5af5259a.js +20 -0
  14. package/dist/cjs/environment-config.service-c8ff1f3d.js +28 -0
  15. package/dist/cjs/facilitator.service-ff0e1659.js +95 -0
  16. package/dist/cjs/feed.service-8eca4de6.js +57 -0
  17. package/dist/cjs/focus-visible-b0b07ba6.js +76 -0
  18. package/dist/cjs/framework-delegate-59a98abd.js +111 -0
  19. package/dist/cjs/gesture-controller-0eb5579e.js +196 -0
  20. package/dist/cjs/haptic-780f33c4.js +116 -0
  21. package/dist/cjs/hardware-back-button-92d97ff8.js +76 -0
  22. package/dist/cjs/header-mobile-collapse_61.cjs.entry.js +15124 -0
  23. package/dist/cjs/helpers-c2496722.js +425 -0
  24. package/dist/cjs/httpService-d2e7bf8f.js +687 -0
  25. package/dist/cjs/icons-fda820af.js +26 -0
  26. package/dist/cjs/index-12082cba.js +465 -0
  27. package/dist/cjs/index-15ea05f5.js +314 -0
  28. package/dist/cjs/index-51e8292e.js +1928 -0
  29. package/dist/cjs/index-787d4498.js +232 -0
  30. package/dist/cjs/index-8b5629a6.js +186 -0
  31. package/dist/cjs/index-975586fd.js +48 -0
  32. package/dist/cjs/index-9c7b27e4.js +140 -0
  33. package/dist/cjs/index-af080b50.js +139 -0
  34. package/dist/cjs/index-e56e09b8.js +38 -0
  35. package/dist/cjs/index.cjs.js +26 -0
  36. package/dist/cjs/index.es-38cbcdbe.js +10666 -0
  37. package/dist/cjs/input-shims-eff63b88.js +418 -0
  38. package/dist/cjs/ion-accordion-group.cjs.entry.js +205 -0
  39. package/dist/cjs/ion-accordion.cjs.entry.js +336 -0
  40. package/dist/cjs/ion-action-sheet_7.cjs.entry.js +2935 -0
  41. package/dist/cjs/ion-app.cjs.entry.js +79 -0
  42. package/dist/cjs/ion-back-button.cjs.entry.js +94 -0
  43. package/dist/cjs/ion-backdrop.cjs.entry.js +67 -0
  44. package/dist/cjs/ion-badge.cjs.entry.js +29 -0
  45. package/dist/cjs/ion-breadcrumb.cjs.entry.js +95 -0
  46. package/dist/cjs/ion-breadcrumbs.cjs.entry.js +133 -0
  47. package/dist/cjs/ion-buttons_3.cjs.entry.js +153 -0
  48. package/dist/cjs/ion-card-header.cjs.entry.js +37 -0
  49. package/dist/cjs/ion-card-subtitle.cjs.entry.js +30 -0
  50. package/dist/cjs/ion-card-title.cjs.entry.js +30 -0
  51. package/dist/cjs/ion-chip.cjs.entry.js +40 -0
  52. package/dist/cjs/ion-content_2.cjs.entry.js +659 -0
  53. package/dist/cjs/ion-datetime-button.cjs.entry.js +312 -0
  54. package/dist/cjs/ion-datetime.cjs.entry.js +1623 -0
  55. package/dist/cjs/ion-fab-button.cjs.entry.js +108 -0
  56. package/dist/cjs/ion-fab-list.cjs.entry.js +45 -0
  57. package/dist/cjs/ion-fab.cjs.entry.js +76 -0
  58. package/dist/cjs/ion-footer.cjs.entry.js +120 -0
  59. package/dist/cjs/ion-img.cjs.entry.js +101 -0
  60. package/dist/cjs/ion-infinite-scroll-content.cjs.entry.js +37 -0
  61. package/dist/cjs/ion-infinite-scroll.cjs.entry.js +206 -0
  62. package/dist/cjs/ion-item-divider.cjs.entry.js +40 -0
  63. package/dist/cjs/ion-item-group.cjs.entry.js +31 -0
  64. package/dist/cjs/ion-item-option.cjs.entry.js +60 -0
  65. package/dist/cjs/ion-item-options.cjs.entry.js +47 -0
  66. package/dist/cjs/ion-item-sliding.cjs.entry.js +398 -0
  67. package/dist/cjs/ion-loading.cjs.entry.js +215 -0
  68. package/dist/cjs/ion-menu-button.cjs.entry.js +76 -0
  69. package/dist/cjs/ion-menu-toggle.cjs.entry.js +47 -0
  70. package/dist/cjs/ion-menu.cjs.entry.js +575 -0
  71. package/dist/cjs/ion-modal.cjs.entry.js +1711 -0
  72. package/dist/cjs/ion-nav-link.cjs.entry.js +47 -0
  73. package/dist/cjs/ion-nav.cjs.entry.js +872 -0
  74. package/dist/cjs/ion-picker-column-internal_2.cjs.entry.js +808 -0
  75. package/dist/cjs/ion-picker-column.cjs.entry.js +331 -0
  76. package/dist/cjs/ion-picker.cjs.entry.js +221 -0
  77. package/dist/cjs/ion-progress-bar.cjs.entry.js +74 -0
  78. package/dist/cjs/ion-refresher-content.cjs.entry.js +35 -0
  79. package/dist/cjs/ion-refresher.cjs.entry.js +802 -0
  80. package/dist/cjs/ion-reorder-group.cjs.entry.js +281 -0
  81. package/dist/cjs/ion-reorder.cjs.entry.js +38 -0
  82. package/dist/cjs/ion-route-redirect.cjs.entry.js +24 -0
  83. package/dist/cjs/ion-route.cjs.entry.js +49 -0
  84. package/dist/cjs/ion-router-link.cjs.entry.js +38 -0
  85. package/dist/cjs/ion-router-outlet.cjs.entry.js +200 -0
  86. package/dist/cjs/ion-router.cjs.entry.js +831 -0
  87. package/dist/cjs/ion-searchbar.cjs.entry.js +370 -0
  88. package/dist/cjs/ion-segment-button.cjs.entry.js +102 -0
  89. package/dist/cjs/ion-segment.cjs.entry.js +417 -0
  90. package/dist/cjs/ion-skeleton-text.cjs.entry.js +33 -0
  91. package/dist/cjs/ion-slide.cjs.entry.js +25 -0
  92. package/dist/cjs/ion-slides.cjs.entry.js +391 -0
  93. package/dist/cjs/ion-split-pane.cjs.entry.js +154 -0
  94. package/dist/cjs/ion-tab-bar.cjs.entry.js +75 -0
  95. package/dist/cjs/ion-tab-button.cjs.entry.js +103 -0
  96. package/dist/cjs/ion-tab.cjs.entry.js +59 -0
  97. package/dist/cjs/ion-tabs.cjs.entry.js +154 -0
  98. package/dist/cjs/ion-thumbnail.cjs.entry.js +20 -0
  99. package/dist/cjs/ion-toast.cjs.entry.js +272 -0
  100. package/dist/cjs/ion-toggle.cjs.entry.js +177 -0
  101. package/dist/cjs/ion-virtual-scroll.cjs.entry.js +555 -0
  102. package/dist/cjs/ionic-global-2cde9d3a.js +231 -0
  103. package/dist/cjs/ios.transition-da235483.js +482 -0
  104. package/dist/cjs/keyboard-91096619.js +140 -0
  105. package/dist/cjs/loader.cjs.js +24 -0
  106. package/dist/cjs/localstorage.service-6346a41d.js +40 -0
  107. package/dist/cjs/md.transition-be429e07.js +57 -0
  108. package/dist/cjs/media.service-8a1b9bc5.js +40 -0
  109. package/dist/cjs/menu-toggle-util-7a01448c.js +14 -0
  110. package/dist/cjs/overlays-32df265a.js +507 -0
  111. package/dist/cjs/parse-d0071120.js +1237 -0
  112. package/dist/cjs/purify-fb9c107e.js +1468 -0
  113. package/dist/cjs/signalR.service-bd6b42f9.js +2985 -0
  114. package/dist/cjs/sparkle-animation-player.cjs.entry.js +515 -0
  115. package/dist/cjs/sparkle-assignment.cjs.entry.js +110 -0
  116. package/dist/cjs/sparkle-character-intro.cjs.entry.js +26 -0
  117. package/dist/cjs/sparkle-code.cjs.entry.js +43 -0
  118. package/dist/cjs/sparkle-compass-post.cjs.entry.js +133 -0
  119. package/dist/cjs/sparkle-compass.cjs.entry.js +126 -0
  120. package/dist/cjs/sparkle-core.cjs.js +22 -0
  121. package/dist/cjs/sparkle-discussion-questions_2.cjs.entry.js +281 -0
  122. package/dist/cjs/sparkle-discussion.cjs.entry.js +42 -0
  123. package/dist/cjs/sparkle-emoji.cjs.entry.js +80 -0
  124. package/dist/cjs/sparkle-facilitator-notes-form.cjs.entry.js +121 -0
  125. package/dist/cjs/sparkle-feed-post.cjs.entry.js +122 -0
  126. package/dist/cjs/sparkle-feedback.cjs.entry.js +101 -0
  127. package/dist/cjs/sparkle-file-upload.cjs.entry.js +53 -0
  128. package/dist/cjs/sparkle-goal-form.cjs.entry.js +179 -0
  129. package/dist/cjs/sparkle-gww-comment-list.cjs.entry.js +26 -0
  130. package/dist/cjs/sparkle-gww-graph.cjs.entry.js +19 -0
  131. package/dist/cjs/sparkle-input.cjs.entry.js +56 -0
  132. package/dist/cjs/sparkle-intro.cjs.entry.js +26 -0
  133. package/dist/cjs/sparkle-lower-content-nav.cjs.entry.js +22 -0
  134. package/dist/cjs/sparkle-menu-collapsible.cjs.entry.js +46 -0
  135. package/dist/cjs/sparkle-modal-image.cjs.entry.js +34 -0
  136. package/dist/cjs/sparkle-notfound-page.cjs.entry.js +25 -0
  137. package/dist/cjs/sparkle-overlay.cjs.entry.js +92 -0
  138. package/dist/cjs/sparkle-poll.cjs.entry.js +19 -0
  139. package/dist/cjs/sparkle-quiz-container.cjs.entry.js +47 -0
  140. package/dist/cjs/sparkle-quiz-feedback_5.cjs.entry.js +117 -0
  141. package/dist/cjs/sparkle-quiz-old.cjs.entry.js +120 -0
  142. package/dist/cjs/sparkle-quiz.cjs.entry.js +103 -0
  143. package/dist/cjs/sparkle-select.cjs.entry.js +61 -0
  144. package/dist/cjs/sparkle-sidebar.cjs.entry.js +43 -0
  145. package/dist/cjs/sparkle-tab.cjs.entry.js +26 -0
  146. package/dist/cjs/sparkle-table-of-contents.cjs.entry.js +71 -0
  147. package/dist/cjs/sparkle-tabs.cjs.entry.js +66 -0
  148. package/dist/cjs/sparkle-video-player.cjs.entry.js +22 -0
  149. package/dist/cjs/sparkle-youtube.cjs.entry.js +39 -0
  150. package/dist/cjs/spinner-configs-0ac05f2d.js +147 -0
  151. package/dist/cjs/status-tap-033befa2.js +42 -0
  152. package/dist/cjs/stencil-async-content.cjs.entry.js +32 -0
  153. package/dist/cjs/stencil-route-title.cjs.entry.js +32 -0
  154. package/dist/cjs/stencil-router-prompt.cjs.entry.js +59 -0
  155. package/dist/cjs/student.service-7e5385be.js +78 -0
  156. package/dist/cjs/swipe-back-4a826f9b.js +76 -0
  157. package/dist/cjs/swiper.bundle-8c897c07.js +6420 -0
  158. package/dist/cjs/theme-b0b295c1.js +48 -0
  159. package/dist/cjs/token.service-7a41953d.js +97 -0
  160. package/dist/cjs/util-47e320b2.js +2462 -0
  161. package/dist/collection/PrivateRoute.js +27 -0
  162. package/dist/collection/appconst.js +13 -0
  163. package/dist/collection/assets/img/forward.svg +5 -0
  164. package/dist/collection/assets/img/help/fitt-logo.svg +1 -0
  165. package/dist/collection/assets/img/home/big-white-wall.svg +15 -0
  166. package/dist/collection/assets/img/home/find-help.svg +23 -0
  167. package/dist/collection/assets/img/home/lessons.svg +26 -0
  168. package/dist/collection/assets/img/home/my-goals.svg +19 -0
  169. package/dist/collection/assets/img/home/my-health.svg +17 -0
  170. package/dist/collection/assets/img/home/my-mood.svg +26 -0
  171. package/dist/collection/assets/img/pause.svg +5 -0
  172. package/dist/collection/assets/img/play-symbol.svg +8 -0
  173. package/dist/collection/assets/img/play.svg +4 -0
  174. package/dist/collection/assets/img/rewind.svg +5 -0
  175. package/dist/collection/assets/lib/SignalRAspNetCoreHelper.js +17 -0
  176. package/dist/collection/assets/lib/sparkleUtility.js +8 -0
  177. package/dist/collection/assets/svg/profile.svg +2 -0
  178. package/dist/collection/collection-manifest.json +219 -0
  179. package/dist/collection/components/compass-svg/compass-svg.css +15 -0
  180. package/dist/collection/components/compass-svg/compass-svg.js +156 -0
  181. package/dist/collection/components/layout/facilitator/export-lessons/export-lessons.css +7 -0
  182. package/dist/collection/components/layout/facilitator/export-lessons/export-lessons.js +110 -0
  183. package/dist/collection/components/layout/facilitator/facilitator-dashboard/facilitator-dashboard.css +3 -0
  184. package/dist/collection/components/layout/facilitator/facilitator-dashboard/facilitator-dashboard.js +214 -0
  185. package/dist/collection/components/layout/facilitator/facilitator-header/facilitator-header-mobile-collapse/facilitator-header-mobile-collapse.js +0 -0
  186. package/dist/collection/components/layout/facilitator/facilitator-header/facilitator-header.css +172 -0
  187. package/dist/collection/components/layout/facilitator/facilitator-header/facilitator-header.js +104 -0
  188. package/dist/collection/components/layout/facilitator/facilitator-notes/facilitator-notes-form/facilitator-notes-form.css +3 -0
  189. package/dist/collection/components/layout/facilitator/facilitator-notes/facilitator-notes-form/facilitator-notes-form.js +144 -0
  190. package/dist/collection/components/layout/facilitator/facilitator-notes/facilitator-notes.css +14 -0
  191. package/dist/collection/components/layout/facilitator/facilitator-notes/facilitator-notes.js +64 -0
  192. package/dist/collection/components/layout/facilitator/facilitator-page.css +196 -0
  193. package/dist/collection/components/layout/facilitator/facilitator-page.js +281 -0
  194. package/dist/collection/components/layout/facilitator/online-students/online-students.css +0 -0
  195. package/dist/collection/components/layout/facilitator/online-students/online-students.js +70 -0
  196. package/dist/collection/components/layout/page/page.css +183 -0
  197. package/dist/collection/components/layout/page/page.js +321 -0
  198. package/dist/collection/components/layout/page/templates/default.js +9 -0
  199. package/dist/collection/components/layout/page/templates/error.js +33 -0
  200. package/dist/collection/components/layout/page/templates/index.js +8 -0
  201. package/dist/collection/components/layout/page/templates/pdf.js +8 -0
  202. package/dist/collection/components/layout/page/to-hypertext.js +27 -0
  203. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goal-form/sparkle-goal-form.css +3 -0
  204. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goal-form/sparkle-goal-form.js +252 -0
  205. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goal-item/sparkle-goal-item.css +12 -0
  206. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goal-item/sparkle-goal-item.js +59 -0
  207. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goal-progress/sparkle-goal-progress.css +33 -0
  208. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goal-progress/sparkle-goal-progress.js +37 -0
  209. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goals.css +8 -0
  210. package/dist/collection/components/mini-apps/sparkle-goals/sparkle-goals.js +40 -0
  211. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww-comment-list/sparkle-gww-comment-list.css +7 -0
  212. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww-comment-list/sparkle-gww-comment-list.js +52 -0
  213. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww-graph/sparkle-gww-graph.css +3 -0
  214. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww-graph/sparkle-gww-graph.js +14 -0
  215. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww-item/sparkle-gww-item.css +30 -0
  216. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww-item/sparkle-gww-item.js +187 -0
  217. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww.css +3 -0
  218. package/dist/collection/components/mini-apps/sparkle-gww/sparkle-gww.js +43 -0
  219. package/dist/collection/components/mini-apps/sparkle-health/sparkle-health.css +10 -0
  220. package/dist/collection/components/mini-apps/sparkle-health/sparkle-health.js +111 -0
  221. package/dist/collection/components/mini-apps/sparkle-mood/sparkle-mood.css +11 -0
  222. package/dist/collection/components/mini-apps/sparkle-mood/sparkle-mood.js +127 -0
  223. package/dist/collection/components/modal-image/modal-image.css +61 -0
  224. package/dist/collection/components/modal-image/modal-image.js +159 -0
  225. package/dist/collection/components/sparkle-animation-player/assets/play-button-disabled-overlay.png +0 -0
  226. package/dist/collection/components/sparkle-animation-player/assets/play-button-overlay.png +0 -0
  227. package/dist/collection/components/sparkle-animation-player/caption-parser.js +94 -0
  228. package/dist/collection/components/sparkle-animation-player/sparkle-animation-player.css +157 -0
  229. package/dist/collection/components/sparkle-animation-player/sparkle-animation-player.js +598 -0
  230. package/dist/collection/components/sparkle-assignment/sparkle-assignment.css +30 -0
  231. package/dist/collection/components/sparkle-assignment/sparkle-assignment.js +159 -0
  232. package/dist/collection/components/sparkle-character-intro/assets/characters/character-img.jpg +0 -0
  233. package/dist/collection/components/sparkle-character-intro/assets/characters/jen.png +0 -0
  234. package/dist/collection/components/sparkle-character-intro/assets/characters/kimberly.png +0 -0
  235. package/dist/collection/components/sparkle-character-intro/assets/characters/valeria.png +0 -0
  236. package/dist/collection/components/sparkle-character-intro/assets/characters/yuna.png +0 -0
  237. package/dist/collection/components/sparkle-character-intro/assets/characters/zynab.png +0 -0
  238. package/dist/collection/components/sparkle-character-intro/sparkle-character-intro.css +74 -0
  239. package/dist/collection/components/sparkle-character-intro/sparkle-character-intro.js +68 -0
  240. package/dist/collection/components/sparkle-compass/sparkle-compass-post/sparkle-compass-post.css +35 -0
  241. package/dist/collection/components/sparkle-compass/sparkle-compass-post/sparkle-compass-post.js +171 -0
  242. package/dist/collection/components/sparkle-compass/sparkle-compass.css +25 -0
  243. package/dist/collection/components/sparkle-compass/sparkle-compass.js +283 -0
  244. package/dist/collection/components/sparkle-course-root/sparkle-course-root.css +3 -0
  245. package/dist/collection/components/sparkle-course-root/sparkle-course-root.js +196 -0
  246. package/dist/collection/components/sparkle-discussion/sparkle-discussion-questions/sparkle-discussion-questions.css +157 -0
  247. package/dist/collection/components/sparkle-discussion/sparkle-discussion-questions/sparkle-discussion-questions.js +232 -0
  248. package/dist/collection/components/sparkle-discussion/sparkle-discussion-results/sparkle-discussion-results.css +158 -0
  249. package/dist/collection/components/sparkle-discussion/sparkle-discussion-results/sparkle-discussion-results.js +274 -0
  250. package/dist/collection/components/sparkle-discussion/sparkle-discussion.css +5 -0
  251. package/dist/collection/components/sparkle-discussion/sparkle-discussion.js +112 -0
  252. package/dist/collection/components/sparkle-emoji/sparkle-emoji.css +16 -0
  253. package/dist/collection/components/sparkle-emoji/sparkle-emoji.js +116 -0
  254. package/dist/collection/components/sparkle-feed-post/sparkle-feed-post.css +35 -0
  255. package/dist/collection/components/sparkle-feed-post/sparkle-feed-post.js +199 -0
  256. package/dist/collection/components/sparkle-feedback/sparkle-feedback.css +3 -0
  257. package/dist/collection/components/sparkle-feedback/sparkle-feedback.js +118 -0
  258. package/dist/collection/components/sparkle-file-upload/sparkle-file-upload.css +0 -0
  259. package/dist/collection/components/sparkle-file-upload/sparkle-file-upload.js +105 -0
  260. package/dist/collection/components/sparkle-forgot-password/sparkle-forgot-password.css +4 -0
  261. package/dist/collection/components/sparkle-forgot-password/sparkle-forgot-password.js +107 -0
  262. package/dist/collection/components/sparkle-input/sparkle-input.css +0 -0
  263. package/dist/collection/components/sparkle-input/sparkle-input.js +212 -0
  264. package/dist/collection/components/sparkle-intro/sparkle-intro.css +15 -0
  265. package/dist/collection/components/sparkle-intro/sparkle-intro.js +35 -0
  266. package/dist/collection/components/sparkle-login/sparkle-login.css +4 -0
  267. package/dist/collection/components/sparkle-login/sparkle-login.js +173 -0
  268. package/dist/collection/components/sparkle-poll/sparkle-poll.css +3 -0
  269. package/dist/collection/components/sparkle-poll/sparkle-poll.js +15 -0
  270. package/dist/collection/components/sparkle-quiz/sparkle-quiz-feedback/sparkle-quiz-feedback.css +3 -0
  271. package/dist/collection/components/sparkle-quiz/sparkle-quiz-feedback/sparkle-quiz-feedback.js +69 -0
  272. package/dist/collection/components/sparkle-quiz/sparkle-quiz-input/sparkle-quiz-input.css +3 -0
  273. package/dist/collection/components/sparkle-quiz/sparkle-quiz-input/sparkle-quiz-input.js +59 -0
  274. package/dist/collection/components/sparkle-quiz/sparkle-quiz-old/sparkle-quiz-old.css +48 -0
  275. package/dist/collection/components/sparkle-quiz/sparkle-quiz-old/sparkle-quiz-old.js +327 -0
  276. package/dist/collection/components/sparkle-quiz/sparkle-quiz-opinion/sparkle-quiz-opinion.css +18 -0
  277. package/dist/collection/components/sparkle-quiz/sparkle-quiz-opinion/sparkle-quiz-opinion.js +106 -0
  278. package/dist/collection/components/sparkle-quiz/sparkle-quiz-poll/sparkle-quiz-poll.css +3 -0
  279. package/dist/collection/components/sparkle-quiz/sparkle-quiz-poll/sparkle-quiz-poll.js +59 -0
  280. package/dist/collection/components/sparkle-quiz/sparkle-quiz-select/sparkle-quiz-select.css +3 -0
  281. package/dist/collection/components/sparkle-quiz/sparkle-quiz-select/sparkle-quiz-select.js +100 -0
  282. package/dist/collection/components/sparkle-quiz/sparkle-quiz.css +48 -0
  283. package/dist/collection/components/sparkle-quiz/sparkle-quiz.js +221 -0
  284. package/dist/collection/components/sparkle-quiz-container/sparkle-quiz-container.css +3 -0
  285. package/dist/collection/components/sparkle-quiz-container/sparkle-quiz-container.js +98 -0
  286. package/dist/collection/components/sparkle-reset-password/sparkle-reset-password.css +3 -0
  287. package/dist/collection/components/sparkle-reset-password/sparkle-reset-password.js +126 -0
  288. package/dist/collection/components/sparkle-root/sparkle-root.css +61 -0
  289. package/dist/collection/components/sparkle-root/sparkle-root.js +86 -0
  290. package/dist/collection/components/sparkle-signup/sparkle-signup.css +6 -0
  291. package/dist/collection/components/sparkle-signup/sparkle-signup.js +197 -0
  292. package/dist/collection/components/sparkle-unauthorized/sparkle-unauthorized.css +13 -0
  293. package/dist/collection/components/sparkle-unauthorized/sparkle-unauthorized.js +18 -0
  294. package/dist/collection/components/sparkle-user-enrollment/sparkle-user-enrollment.css +3 -0
  295. package/dist/collection/components/sparkle-user-enrollment/sparkle-user-enrollment.js +93 -0
  296. package/dist/collection/components/sparkle-user-profile/sparkle-user-profile.css +54 -0
  297. package/dist/collection/components/sparkle-user-profile/sparkle-user-profile.js +151 -0
  298. package/dist/collection/components/sparkle-validation-error/sparkle-validation-error.css +11 -0
  299. package/dist/collection/components/sparkle-validation-error/sparkle-validation-error.js +44 -0
  300. package/dist/collection/components/sparkle-video-player/sparkle-video-player.css +0 -0
  301. package/dist/collection/components/sparkle-video-player/sparkle-video-player.js +92 -0
  302. package/dist/collection/components/sparkle-youtube/sparkle-youtube.css +24 -0
  303. package/dist/collection/components/sparkle-youtube/sparkle-youtube.js +99 -0
  304. package/dist/collection/global/app.js +4 -0
  305. package/dist/collection/helpers/utils.js +3 -0
  306. package/dist/collection/icons.js +36 -0
  307. package/dist/collection/index.js +3 -0
  308. package/dist/collection/l10n.js +18 -0
  309. package/dist/collection/models/api.model.js +7 -0
  310. package/dist/collection/models/assets.model.js +1 -0
  311. package/dist/collection/models/auth/auth.user.js +1 -0
  312. package/dist/collection/models/class.model.js +5 -0
  313. package/dist/collection/models/course.model.js +10 -0
  314. package/dist/collection/models/definitions.js +1 -0
  315. package/dist/collection/models/facilitator-dashboard.model.js +5 -0
  316. package/dist/collection/models/goal.model.js +1 -0
  317. package/dist/collection/models/index.js +1 -0
  318. package/dist/collection/models/markdown.model.js +1 -0
  319. package/dist/collection/models/page.model.js +1 -0
  320. package/dist/collection/models/quiz.model.js +3 -0
  321. package/dist/collection/models/user.model.js +1 -0
  322. package/dist/collection/pages/course/welcome-to-mind-body/introduction/animation/m4l1p1_part1.js +2727 -0
  323. package/dist/collection/pages/course/welcome-to-mind-body/introduction/animation/m4l1p1_part2.js +2042 -0
  324. package/dist/collection/services/account.service.js +61 -0
  325. package/dist/collection/services/appdata.service.js +60 -0
  326. package/dist/collection/services/assignment.service.js +14 -0
  327. package/dist/collection/services/auth/auth.service.js +64 -0
  328. package/dist/collection/services/core/assets.service.js +45 -0
  329. package/dist/collection/services/core/localstorage.service.js +34 -0
  330. package/dist/collection/services/environment/environment-config.js +24 -0
  331. package/dist/collection/services/environment/environment-config.service.js +24 -0
  332. package/dist/collection/services/facilitator.service.js +76 -0
  333. package/dist/collection/services/feed.service.js +43 -0
  334. package/dist/collection/services/httpService.js +103 -0
  335. package/dist/collection/services/index.js +4 -0
  336. package/dist/collection/services/media.service.js +29 -0
  337. package/dist/collection/services/signalR.service.js +83 -0
  338. package/dist/collection/services/store.service.js +13 -0
  339. package/dist/collection/services/student.service.js +56 -0
  340. package/dist/collection/services/token.service.js +79 -0
  341. package/dist/collection/stores/auth.store.js +12 -0
  342. package/dist/collection/stores/class.store.js +5 -0
  343. package/dist/collection/stores/error.store.js +5 -0
  344. package/dist/collection/stores/facilitator.store.js +15 -0
  345. package/dist/collection/stores/feed.store.js +8 -0
  346. package/dist/collection/stores/goal.store.js +7 -0
  347. package/dist/collection/stores/index.js +1 -0
  348. package/dist/collection/stores/media.store.js +5 -0
  349. package/dist/collection/stores/mood.store.js +5 -0
  350. package/dist/collection/stores/nav.store.js +11 -0
  351. package/dist/collection/stores/signalR.store.js +6 -0
  352. package/dist/collection/stores/theme.store.js +9 -0
  353. package/dist/collection/stores/toc.store.js +5 -0
  354. package/dist/collection/stores/user.store.js +16 -0
  355. package/dist/collection/util.js +55 -0
  356. package/dist/collection/utils.js +92 -0
  357. package/dist/esm/PrivateRoute-90ac95b8.js +212 -0
  358. package/dist/esm/active-router-fc9e4e06.js +73 -0
  359. package/dist/esm/animation-12377cb3.js +984 -0
  360. package/dist/esm/app-globals-3f0347b0.js +7 -0
  361. package/dist/esm/appdata.service-2e84e167.js +70 -0
  362. package/dist/esm/assets.service-def1d63c.js +48 -0
  363. package/dist/esm/assignment.service-8d31f141.js +17 -0
  364. package/dist/esm/auth.store-dba2c2da.js +3381 -0
  365. package/dist/esm/compass-svg.entry.js +128 -0
  366. package/dist/esm/context-consumer.entry.js +25 -0
  367. package/dist/esm/course-select.entry.js +26 -0
  368. package/dist/esm/dir-03012648.js +18 -0
  369. package/dist/esm/environment-config.service-b191f276.js +26 -0
  370. package/dist/esm/facilitator.service-18c47bdf.js +92 -0
  371. package/dist/esm/feed.service-b4f3cae4.js +54 -0
  372. package/dist/esm/framework-delegate-3e634a5c.js +107 -0
  373. package/dist/esm/gesture-controller-7be18351.js +194 -0
  374. package/dist/esm/haptic-522f76f2.js +110 -0
  375. package/dist/esm/header-mobile-collapse_61.entry.js +15060 -0
  376. package/dist/esm/helpers-bf0e23d6.js +403 -0
  377. package/dist/esm/httpService-7986aeed.js +685 -0
  378. package/dist/esm/icons-1c794c74.js +18 -0
  379. package/dist/esm/index-21661af2.js +463 -0
  380. package/dist/esm/index-2b84cad2.js +223 -0
  381. package/dist/esm/index-4044fde9.js +25 -0
  382. package/dist/esm/index-45fec1e7.js +184 -0
  383. package/dist/esm/index-5e8971ae.js +128 -0
  384. package/dist/esm/index-c04b9ed5.js +1888 -0
  385. package/dist/esm/index-cded2d87.js +312 -0
  386. package/dist/esm/index-dad75b83.js +34 -0
  387. package/dist/esm/index.es-e0c0f891.js +10580 -0
  388. package/dist/esm/index.js +12 -0
  389. package/dist/esm/input-shims-671d8d9f.js +416 -0
  390. package/dist/esm/ion-accordion-group.entry.js +201 -0
  391. package/dist/esm/ion-accordion.entry.js +332 -0
  392. package/dist/esm/ion-action-sheet_7.entry.js +2925 -0
  393. package/dist/esm/ion-app.entry.js +75 -0
  394. package/dist/esm/ion-back-button.entry.js +90 -0
  395. package/dist/esm/ion-backdrop.entry.js +63 -0
  396. package/dist/esm/ion-badge.entry.js +25 -0
  397. package/dist/esm/ion-breadcrumb.entry.js +91 -0
  398. package/dist/esm/ion-breadcrumbs.entry.js +129 -0
  399. package/dist/esm/ion-buttons_3.entry.js +147 -0
  400. package/dist/esm/ion-card-header.entry.js +33 -0
  401. package/dist/esm/ion-card-subtitle.entry.js +26 -0
  402. package/dist/esm/ion-card-title.entry.js +26 -0
  403. package/dist/esm/ion-chip.entry.js +36 -0
  404. package/dist/esm/ion-content_2.entry.js +654 -0
  405. package/dist/esm/ion-datetime-button.entry.js +308 -0
  406. package/dist/esm/ion-datetime.entry.js +1619 -0
  407. package/dist/esm/ion-fab-button.entry.js +104 -0
  408. package/dist/esm/ion-fab-list.entry.js +41 -0
  409. package/dist/esm/ion-fab.entry.js +72 -0
  410. package/dist/esm/ion-footer.entry.js +116 -0
  411. package/dist/esm/ion-img.entry.js +97 -0
  412. package/dist/esm/ion-infinite-scroll-content.entry.js +33 -0
  413. package/dist/esm/ion-infinite-scroll.entry.js +202 -0
  414. package/dist/esm/ion-item-divider.entry.js +36 -0
  415. package/dist/esm/ion-item-group.entry.js +27 -0
  416. package/dist/esm/ion-item-option.entry.js +56 -0
  417. package/dist/esm/ion-item-options.entry.js +43 -0
  418. package/dist/esm/ion-item-sliding.entry.js +394 -0
  419. package/dist/esm/ion-loading.entry.js +211 -0
  420. package/dist/esm/ion-menu-button.entry.js +72 -0
  421. package/dist/esm/ion-menu-toggle.entry.js +43 -0
  422. package/dist/esm/ion-menu.entry.js +571 -0
  423. package/dist/esm/ion-modal.entry.js +1707 -0
  424. package/dist/esm/ion-nav-link.entry.js +43 -0
  425. package/dist/esm/ion-nav.entry.js +868 -0
  426. package/dist/esm/ion-picker-column-internal_2.entry.js +803 -0
  427. package/dist/esm/ion-picker-column.entry.js +327 -0
  428. package/dist/esm/ion-picker.entry.js +217 -0
  429. package/dist/esm/ion-progress-bar.entry.js +70 -0
  430. package/dist/esm/ion-refresher-content.entry.js +31 -0
  431. package/dist/esm/ion-refresher.entry.js +798 -0
  432. package/dist/esm/ion-reorder-group.entry.js +277 -0
  433. package/dist/esm/ion-reorder.entry.js +34 -0
  434. package/dist/esm/ion-route-redirect.entry.js +20 -0
  435. package/dist/esm/ion-route.entry.js +45 -0
  436. package/dist/esm/ion-router-link.entry.js +34 -0
  437. package/dist/esm/ion-router-outlet.entry.js +196 -0
  438. package/dist/esm/ion-router.entry.js +827 -0
  439. package/dist/esm/ion-searchbar.entry.js +366 -0
  440. package/dist/esm/ion-segment-button.entry.js +98 -0
  441. package/dist/esm/ion-segment.entry.js +413 -0
  442. package/dist/esm/ion-skeleton-text.entry.js +29 -0
  443. package/dist/esm/ion-slide.entry.js +21 -0
  444. package/dist/esm/ion-slides.entry.js +387 -0
  445. package/dist/esm/ion-split-pane.entry.js +150 -0
  446. package/dist/esm/ion-tab-bar.entry.js +71 -0
  447. package/dist/esm/ion-tab-button.entry.js +99 -0
  448. package/dist/esm/ion-tab.entry.js +55 -0
  449. package/dist/esm/ion-tabs.entry.js +150 -0
  450. package/dist/esm/ion-thumbnail.entry.js +16 -0
  451. package/dist/esm/ion-toast.entry.js +268 -0
  452. package/dist/esm/ion-toggle.entry.js +173 -0
  453. package/dist/esm/ion-virtual-scroll.entry.js +551 -0
  454. package/dist/esm/ionic-global-4903e23e.js +226 -0
  455. package/dist/esm/ios.transition-131d64fe.js +479 -0
  456. package/dist/esm/loader.js +20 -0
  457. package/dist/esm/md.transition-f6126011.js +55 -0
  458. package/dist/esm/media.service-6e90bc41.js +37 -0
  459. package/dist/esm/menu-toggle-util-bace8ae6.js +12 -0
  460. package/dist/esm/overlays-4233a39d.js +491 -0
  461. package/dist/esm/parse-1ae3a9bb.js +1196 -0
  462. package/dist/esm/polyfills/core-js.js +11 -0
  463. package/dist/esm/polyfills/css-shim.js +1 -0
  464. package/dist/esm/polyfills/dom.js +79 -0
  465. package/dist/esm/polyfills/es5-html-element.js +1 -0
  466. package/dist/esm/polyfills/index.js +34 -0
  467. package/dist/esm/polyfills/system.js +6 -0
  468. package/dist/esm/purify-85bfcc69.js +1466 -0
  469. package/dist/esm/signalR.service-c33fba50.js +2982 -0
  470. package/dist/esm/sparkle-animation-player.entry.js +511 -0
  471. package/dist/esm/sparkle-assignment.entry.js +106 -0
  472. package/dist/esm/sparkle-character-intro.entry.js +22 -0
  473. package/dist/esm/sparkle-code.entry.js +39 -0
  474. package/dist/esm/sparkle-compass-post.entry.js +129 -0
  475. package/dist/esm/sparkle-compass.entry.js +122 -0
  476. package/dist/esm/sparkle-core.js +20 -0
  477. package/dist/esm/sparkle-discussion-questions_2.entry.js +276 -0
  478. package/dist/esm/sparkle-discussion.entry.js +38 -0
  479. package/dist/esm/sparkle-emoji.entry.js +76 -0
  480. package/dist/esm/sparkle-facilitator-notes-form.entry.js +117 -0
  481. package/dist/esm/sparkle-feed-post.entry.js +118 -0
  482. package/dist/esm/sparkle-feedback.entry.js +97 -0
  483. package/dist/esm/sparkle-file-upload.entry.js +49 -0
  484. package/dist/esm/sparkle-goal-form.entry.js +175 -0
  485. package/dist/esm/sparkle-gww-comment-list.entry.js +22 -0
  486. package/dist/esm/sparkle-gww-graph.entry.js +15 -0
  487. package/dist/esm/sparkle-input.entry.js +52 -0
  488. package/dist/esm/sparkle-intro.entry.js +22 -0
  489. package/dist/esm/sparkle-lower-content-nav.entry.js +18 -0
  490. package/dist/esm/sparkle-menu-collapsible.entry.js +42 -0
  491. package/dist/esm/sparkle-modal-image.entry.js +30 -0
  492. package/dist/esm/sparkle-notfound-page.entry.js +21 -0
  493. package/dist/esm/sparkle-overlay.entry.js +88 -0
  494. package/dist/esm/sparkle-poll.entry.js +15 -0
  495. package/dist/esm/sparkle-quiz-container.entry.js +43 -0
  496. package/dist/esm/sparkle-quiz-feedback_5.entry.js +109 -0
  497. package/dist/esm/sparkle-quiz-old.entry.js +116 -0
  498. package/dist/esm/sparkle-quiz.entry.js +99 -0
  499. package/dist/esm/sparkle-select.entry.js +57 -0
  500. package/dist/esm/sparkle-sidebar.entry.js +39 -0
  501. package/dist/esm/sparkle-tab.entry.js +22 -0
  502. package/dist/esm/sparkle-table-of-contents.entry.js +67 -0
  503. package/dist/esm/sparkle-tabs.entry.js +62 -0
  504. package/dist/esm/sparkle-video-player.entry.js +18 -0
  505. package/dist/esm/sparkle-youtube.entry.js +35 -0
  506. package/dist/esm/status-tap-dde52787.js +40 -0
  507. package/dist/esm/stencil-async-content.entry.js +28 -0
  508. package/dist/esm/stencil-route-title.entry.js +28 -0
  509. package/dist/esm/stencil-router-prompt.entry.js +55 -0
  510. package/dist/esm/student.service-08af124f.js +75 -0
  511. package/dist/esm/swipe-back-7847a0c1.js +74 -0
  512. package/dist/esm/swiper.bundle-b6a959de.js +6418 -0
  513. package/dist/esm/token.service-71a5d33f.js +94 -0
  514. package/dist/esm/util-57cc8006.js +2451 -0
  515. package/dist/index.cjs.js +1 -0
  516. package/dist/index.js +1 -0
  517. package/dist/loader/cdn.js +3 -0
  518. package/dist/loader/index.cjs.js +3 -0
  519. package/dist/loader/index.d.ts +12 -0
  520. package/dist/loader/index.es2017.js +3 -0
  521. package/dist/loader/index.js +4 -0
  522. package/dist/loader/package.json +10 -0
  523. package/dist/node_modules/@ionic/core/dist/collection/components/accordion/accordion.ios.css +75 -0
  524. package/dist/node_modules/@ionic/core/dist/collection/components/accordion/accordion.md.css +72 -0
  525. package/dist/node_modules/@ionic/core/dist/collection/components/accordion-group/accordion-group.ios.css +25 -0
  526. package/dist/node_modules/@ionic/core/dist/collection/components/accordion-group/accordion-group.md.css +59 -0
  527. package/dist/node_modules/@ionic/core/dist/collection/components/action-sheet/action-sheet.ios.css +357 -0
  528. package/dist/node_modules/@ionic/core/dist/collection/components/action-sheet/action-sheet.md.css +290 -0
  529. package/dist/node_modules/@ionic/core/dist/collection/components/alert/alert.ios.css +494 -0
  530. package/dist/node_modules/@ionic/core/dist/collection/components/alert/alert.md.css +502 -0
  531. package/dist/node_modules/@ionic/core/dist/collection/components/app/app.css +17 -0
  532. package/dist/node_modules/@ionic/core/dist/collection/components/avatar/avatar.ios.css +22 -0
  533. package/dist/node_modules/@ionic/core/dist/collection/components/avatar/avatar.md.css +22 -0
  534. package/dist/node_modules/@ionic/core/dist/collection/components/back-button/back-button.ios.css +281 -0
  535. package/dist/node_modules/@ionic/core/dist/collection/components/back-button/back-button.md.css +309 -0
  536. package/dist/node_modules/@ionic/core/dist/collection/components/backdrop/backdrop.ios.css +26 -0
  537. package/dist/node_modules/@ionic/core/dist/collection/components/backdrop/backdrop.md.css +26 -0
  538. package/dist/node_modules/@ionic/core/dist/collection/components/badge/badge.ios.css +58 -0
  539. package/dist/node_modules/@ionic/core/dist/collection/components/badge/badge.md.css +62 -0
  540. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumb/breadcrumb.ios.css +234 -0
  541. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumb/breadcrumb.md.css +237 -0
  542. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +38 -0
  543. package/dist/node_modules/@ionic/core/dist/collection/components/breadcrumbs/breadcrumbs.md.css +37 -0
  544. package/dist/node_modules/@ionic/core/dist/collection/components/button/button.ios.css +439 -0
  545. package/dist/node_modules/@ionic/core/dist/collection/components/button/button.md.css +428 -0
  546. package/dist/node_modules/@ionic/core/dist/collection/components/buttons/buttons.ios.css +128 -0
  547. package/dist/node_modules/@ionic/core/dist/collection/components/buttons/buttons.md.css +151 -0
  548. package/dist/node_modules/@ionic/core/dist/collection/components/card/card.ios.css +101 -0
  549. package/dist/node_modules/@ionic/core/dist/collection/components/card/card.md.css +95 -0
  550. package/dist/node_modules/@ionic/core/dist/collection/components/card-content/card-content.ios.css +61 -0
  551. package/dist/node_modules/@ionic/core/dist/collection/components/card-content/card-content.md.css +63 -0
  552. package/dist/node_modules/@ionic/core/dist/collection/components/card-header/card-header.ios.css +37 -0
  553. package/dist/node_modules/@ionic/core/dist/collection/components/card-header/card-header.md.css +35 -0
  554. package/dist/node_modules/@ionic/core/dist/collection/components/card-subtitle/card-subtitle.ios.css +28 -0
  555. package/dist/node_modules/@ionic/core/dist/collection/components/card-subtitle/card-subtitle.md.css +26 -0
  556. package/dist/node_modules/@ionic/core/dist/collection/components/card-title/card-title.ios.css +27 -0
  557. package/dist/node_modules/@ionic/core/dist/collection/components/card-title/card-title.md.css +27 -0
  558. package/dist/node_modules/@ionic/core/dist/collection/components/checkbox/checkbox.ios.css +169 -0
  559. package/dist/node_modules/@ionic/core/dist/collection/components/checkbox/checkbox.md.css +172 -0
  560. package/dist/node_modules/@ionic/core/dist/collection/components/chip/chip.ios.css +200 -0
  561. package/dist/node_modules/@ionic/core/dist/collection/components/chip/chip.md.css +200 -0
  562. package/dist/node_modules/@ionic/core/dist/collection/components/col/col.css +108 -0
  563. package/dist/node_modules/@ionic/core/dist/collection/components/content/content.css +237 -0
  564. package/dist/node_modules/@ionic/core/dist/collection/components/datetime/datetime.ios.css +648 -0
  565. package/dist/node_modules/@ionic/core/dist/collection/components/datetime/datetime.md.css +637 -0
  566. package/dist/node_modules/@ionic/core/dist/collection/components/datetime-button/datetime-button.css +60 -0
  567. package/dist/node_modules/@ionic/core/dist/collection/components/fab/fab.css +61 -0
  568. package/dist/node_modules/@ionic/core/dist/collection/components/fab-button/fab-button.ios.css +338 -0
  569. package/dist/node_modules/@ionic/core/dist/collection/components/fab-button/fab-button.md.css +307 -0
  570. package/dist/node_modules/@ionic/core/dist/collection/components/fab-list/fab-list.css +116 -0
  571. package/dist/node_modules/@ionic/core/dist/collection/components/footer/footer.ios.css +37 -0
  572. package/dist/node_modules/@ionic/core/dist/collection/components/footer/footer.md.css +37 -0
  573. package/dist/node_modules/@ionic/core/dist/collection/components/grid/grid.css +151 -0
  574. package/dist/node_modules/@ionic/core/dist/collection/components/header/header.ios.css +108 -0
  575. package/dist/node_modules/@ionic/core/dist/collection/components/header/header.md.css +40 -0
  576. package/dist/node_modules/@ionic/core/dist/collection/components/img/img.css +12 -0
  577. package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll/infinite-scroll.css +8 -0
  578. package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +54 -0
  579. package/dist/node_modules/@ionic/core/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +54 -0
  580. package/dist/node_modules/@ionic/core/dist/collection/components/input/input.ios.css +185 -0
  581. package/dist/node_modules/@ionic/core/dist/collection/components/input/input.md.css +185 -0
  582. package/dist/node_modules/@ionic/core/dist/collection/components/item/item.ios.css +669 -0
  583. package/dist/node_modules/@ionic/core/dist/collection/components/item/item.md.css +928 -0
  584. package/dist/node_modules/@ionic/core/dist/collection/components/item-divider/item-divider.ios.css +204 -0
  585. package/dist/node_modules/@ionic/core/dist/collection/components/item-divider/item-divider.md.css +297 -0
  586. package/dist/node_modules/@ionic/core/dist/collection/components/item-group/item-group.ios.css +3 -0
  587. package/dist/node_modules/@ionic/core/dist/collection/components/item-group/item-group.md.css +3 -0
  588. package/dist/node_modules/@ionic/core/dist/collection/components/item-option/item-option.ios.css +186 -0
  589. package/dist/node_modules/@ionic/core/dist/collection/components/item-option/item-option.md.css +180 -0
  590. package/dist/node_modules/@ionic/core/dist/collection/components/item-options/item-options.ios.css +88 -0
  591. package/dist/node_modules/@ionic/core/dist/collection/components/item-options/item-options.md.css +85 -0
  592. package/dist/node_modules/@ionic/core/dist/collection/components/item-sliding/item-sliding.css +42 -0
  593. package/dist/node_modules/@ionic/core/dist/collection/components/label/label.ios.css +156 -0
  594. package/dist/node_modules/@ionic/core/dist/collection/components/label/label.md.css +250 -0
  595. package/dist/node_modules/@ionic/core/dist/collection/components/list/list.ios.css +91 -0
  596. package/dist/node_modules/@ionic/core/dist/collection/components/list/list.md.css +114 -0
  597. package/dist/node_modules/@ionic/core/dist/collection/components/list-header/list-header.ios.css +118 -0
  598. package/dist/node_modules/@ionic/core/dist/collection/components/list-header/list-header.md.css +94 -0
  599. package/dist/node_modules/@ionic/core/dist/collection/components/loading/loading.ios.css +109 -0
  600. package/dist/node_modules/@ionic/core/dist/collection/components/loading/loading.md.css +100 -0
  601. package/dist/node_modules/@ionic/core/dist/collection/components/menu/menu.ios.css +127 -0
  602. package/dist/node_modules/@ionic/core/dist/collection/components/menu/menu.md.css +123 -0
  603. package/dist/node_modules/@ionic/core/dist/collection/components/menu-button/menu-button.ios.css +175 -0
  604. package/dist/node_modules/@ionic/core/dist/collection/components/menu-button/menu-button.md.css +178 -0
  605. package/dist/node_modules/@ionic/core/dist/collection/components/menu-toggle/menu-toggle.css +3 -0
  606. package/dist/node_modules/@ionic/core/dist/collection/components/modal/modal.ios.css +250 -0
  607. package/dist/node_modules/@ionic/core/dist/collection/components/modal/modal.md.css +177 -0
  608. package/dist/node_modules/@ionic/core/dist/collection/components/nav/nav.css +10 -0
  609. package/dist/node_modules/@ionic/core/dist/collection/components/note/note.ios.css +16 -0
  610. package/dist/node_modules/@ionic/core/dist/collection/components/note/note.md.css +17 -0
  611. package/dist/node_modules/@ionic/core/dist/collection/components/picker/picker.ios.css +217 -0
  612. package/dist/node_modules/@ionic/core/dist/collection/components/picker/picker.md.css +204 -0
  613. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column/picker-column.ios.css +122 -0
  614. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column/picker-column.md.css +123 -0
  615. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +82 -0
  616. package/dist/node_modules/@ionic/core/dist/collection/components/picker-column-internal/picker-column-internal.md.css +85 -0
  617. package/dist/node_modules/@ionic/core/dist/collection/components/picker-internal/picker-internal.ios.css +126 -0
  618. package/dist/node_modules/@ionic/core/dist/collection/components/picker-internal/picker-internal.md.css +122 -0
  619. package/dist/node_modules/@ionic/core/dist/collection/components/popover/popover.ios.css +201 -0
  620. package/dist/node_modules/@ionic/core/dist/collection/components/popover/popover.md.css +132 -0
  621. package/dist/node_modules/@ionic/core/dist/collection/components/progress-bar/progress-bar.ios.css +206 -0
  622. package/dist/node_modules/@ionic/core/dist/collection/components/progress-bar/progress-bar.md.css +206 -0
  623. package/dist/node_modules/@ionic/core/dist/collection/components/radio/radio.ios.css +177 -0
  624. package/dist/node_modules/@ionic/core/dist/collection/components/radio/radio.md.css +178 -0
  625. package/dist/node_modules/@ionic/core/dist/collection/components/range/range.ios.css +275 -0
  626. package/dist/node_modules/@ionic/core/dist/collection/components/range/range.md.css +320 -0
  627. package/dist/node_modules/@ionic/core/dist/collection/components/refresher/refresher.ios.css +189 -0
  628. package/dist/node_modules/@ionic/core/dist/collection/components/refresher/refresher.md.css +210 -0
  629. package/dist/node_modules/@ionic/core/dist/collection/components/reorder/reorder.ios.css +15 -0
  630. package/dist/node_modules/@ionic/core/dist/collection/components/reorder/reorder.md.css +15 -0
  631. package/dist/node_modules/@ionic/core/dist/collection/components/reorder-group/reorder-group.css +33 -0
  632. package/dist/node_modules/@ionic/core/dist/collection/components/ripple-effect/ripple-effect.css +58 -0
  633. package/dist/node_modules/@ionic/core/dist/collection/components/router-link/router-link.css +29 -0
  634. package/dist/node_modules/@ionic/core/dist/collection/components/router-outlet/route-outlet.css +10 -0
  635. package/dist/node_modules/@ionic/core/dist/collection/components/row/row.css +4 -0
  636. package/dist/node_modules/@ionic/core/dist/collection/components/searchbar/searchbar.ios.css +348 -0
  637. package/dist/node_modules/@ionic/core/dist/collection/components/searchbar/searchbar.md.css +279 -0
  638. package/dist/node_modules/@ionic/core/dist/collection/components/segment/segment.ios.css +65 -0
  639. package/dist/node_modules/@ionic/core/dist/collection/components/segment/segment.md.css +36 -0
  640. package/dist/node_modules/@ionic/core/dist/collection/components/segment-button/segment-button.ios.css +446 -0
  641. package/dist/node_modules/@ionic/core/dist/collection/components/segment-button/segment-button.md.css +424 -0
  642. package/dist/node_modules/@ionic/core/dist/collection/components/select/select.ios.css +145 -0
  643. package/dist/node_modules/@ionic/core/dist/collection/components/select/select.md.css +177 -0
  644. package/dist/node_modules/@ionic/core/dist/collection/components/select-option/select-option.css +3 -0
  645. package/dist/node_modules/@ionic/core/dist/collection/components/select-popover/select-popover.ios.css +14 -0
  646. package/dist/node_modules/@ionic/core/dist/collection/components/select-popover/select-popover.md.css +37 -0
  647. package/dist/node_modules/@ionic/core/dist/collection/components/skeleton-text/skeleton-text.css +53 -0
  648. package/dist/node_modules/@ionic/core/dist/collection/components/slide/slide.css +31 -0
  649. package/dist/node_modules/@ionic/core/dist/collection/components/slides/slides.ios.css +764 -0
  650. package/dist/node_modules/@ionic/core/dist/collection/components/slides/slides.md.css +764 -0
  651. package/dist/node_modules/@ionic/core/dist/collection/components/spinner/spinner.css +167 -0
  652. package/dist/node_modules/@ionic/core/dist/collection/components/split-pane/split-pane.ios.css +108 -0
  653. package/dist/node_modules/@ionic/core/dist/collection/components/split-pane/split-pane.md.css +108 -0
  654. package/dist/node_modules/@ionic/core/dist/collection/components/tab/tab.css +4 -0
  655. package/dist/node_modules/@ionic/core/dist/collection/components/tab-bar/tab-bar.ios.css +97 -0
  656. package/dist/node_modules/@ionic/core/dist/collection/components/tab-bar/tab-bar.md.css +82 -0
  657. package/dist/node_modules/@ionic/core/dist/collection/components/tab-button/tab-button.ios.css +308 -0
  658. package/dist/node_modules/@ionic/core/dist/collection/components/tab-button/tab-button.md.css +331 -0
  659. package/dist/node_modules/@ionic/core/dist/collection/components/tabs/tabs.css +19 -0
  660. package/dist/node_modules/@ionic/core/dist/collection/components/text/text.css +3 -0
  661. package/dist/node_modules/@ionic/core/dist/collection/components/textarea/textarea.ios.css +175 -0
  662. package/dist/node_modules/@ionic/core/dist/collection/components/textarea/textarea.md.css +179 -0
  663. package/dist/node_modules/@ionic/core/dist/collection/components/thumbnail/thumbnail.css +21 -0
  664. package/dist/node_modules/@ionic/core/dist/collection/components/title/title.ios.css +122 -0
  665. package/dist/node_modules/@ionic/core/dist/collection/components/title/title.md.css +55 -0
  666. package/dist/node_modules/@ionic/core/dist/collection/components/toast/toast.ios.css +262 -0
  667. package/dist/node_modules/@ionic/core/dist/collection/components/toast/toast.md.css +295 -0
  668. package/dist/node_modules/@ionic/core/dist/collection/components/toggle/toggle.ios.css +286 -0
  669. package/dist/node_modules/@ionic/core/dist/collection/components/toggle/toggle.md.css +261 -0
  670. package/dist/node_modules/@ionic/core/dist/collection/components/toolbar/toolbar.ios.css +175 -0
  671. package/dist/node_modules/@ionic/core/dist/collection/components/toolbar/toolbar.md.css +168 -0
  672. package/dist/node_modules/@ionic/core/dist/collection/components/virtual-scroll/virtual-scroll.css +21 -0
  673. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/button/button.css +49 -0
  674. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/cards/card/card.css +208 -0
  675. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/cards/cards.css +31 -0
  676. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/code/code.css +245 -0
  677. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/dropdown/dropdown.css +115 -0
  678. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/header/header-mobile-collapse/header-mobile-collapse.css +255 -0
  679. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/header/header.css +232 -0
  680. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/menu/collapsible/collapsible.css +3 -0
  681. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/menu/menu-toggle/menu-toggle.css +25 -0
  682. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/menu/menu.css +71 -0
  683. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/nav/nav.css +194 -0
  684. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/notfound-page/notfound-page.css +4 -0
  685. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/overlay/overlay.css +67 -0
  686. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/page-footer/page-footer.css +25 -0
  687. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/pagination/pagination.css +93 -0
  688. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/select/select.css +52 -0
  689. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/sidebar/sidebar.css +98 -0
  690. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/sparkle-lower-content-nav/sparkle-lower-content-nav.css +8 -0
  691. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/table-of-contents/table-of-contents.css +37 -0
  692. package/dist/node_modules/@sparkle-learning/components/dist/collection/components/tabs/tabs.css +64 -0
  693. package/dist/node_modules/@stencil/router/dist/collection/components/route/route.css +3 -0
  694. package/dist/node_modules/ionicons/dist/collection/components/icon/icon.css +101 -0
  695. package/dist/sparkle-core/index.esm.js +1 -19
  696. package/dist/sparkle-core/p-00d10dc9.js +4 -0
  697. package/dist/sparkle-core/p-0147266a.js +1 -0
  698. package/dist/sparkle-core/p-04c7b276.entry.js +1 -0
  699. package/dist/sparkle-core/p-05c032dd.js +4 -0
  700. package/dist/sparkle-core/p-06642405.entry.js +1 -0
  701. package/dist/sparkle-core/p-0664370b.entry.js +1 -0
  702. package/dist/sparkle-core/p-06c7d0f2.entry.js +1 -0
  703. package/dist/sparkle-core/p-076f0239.js +4 -0
  704. package/dist/sparkle-core/p-077c732b.js +4 -0
  705. package/dist/sparkle-core/p-08420531.entry.js +1 -0
  706. package/dist/sparkle-core/p-0ad5c123.entry.js +1 -0
  707. package/dist/sparkle-core/p-0afa3a4d.entry.js +1 -0
  708. package/dist/sparkle-core/p-0c3f3ea6.entry.js +1 -0
  709. package/dist/sparkle-core/p-0e4de1d0.js +4 -0
  710. package/dist/sparkle-core/p-0e8e539f.entry.js +1 -0
  711. package/dist/sparkle-core/p-11356b03.entry.js +1 -0
  712. package/dist/sparkle-core/p-11a6c175.entry.js +1 -0
  713. package/dist/sparkle-core/p-12dd96d7.js +4 -0
  714. package/dist/sparkle-core/p-13ec39db.entry.js +1 -0
  715. package/dist/sparkle-core/p-1adc98f6.js +1 -0
  716. package/dist/sparkle-core/p-1b1ba156.entry.js +1 -0
  717. package/dist/sparkle-core/p-1e125ca5.entry.js +1 -0
  718. package/dist/sparkle-core/p-1e4782af.entry.js +1 -0
  719. package/dist/sparkle-core/p-2033cd86.js +7 -0
  720. package/dist/sparkle-core/p-214d1229.entry.js +1 -0
  721. package/dist/sparkle-core/p-23aca7ca.js +4 -0
  722. package/dist/sparkle-core/p-24cb9a33.entry.js +1 -0
  723. package/dist/sparkle-core/p-27fbabc3.entry.js +1 -0
  724. package/dist/sparkle-core/p-2ba70507.entry.js +1 -0
  725. package/dist/sparkle-core/p-2c1ca854.entry.js +1 -0
  726. package/dist/sparkle-core/p-2caed39f.entry.js +1 -0
  727. package/dist/sparkle-core/p-2d9659e2.entry.js +1 -0
  728. package/dist/sparkle-core/p-2f569553.js +1 -0
  729. package/dist/sparkle-core/p-30b810d1.entry.js +4 -0
  730. package/dist/sparkle-core/p-32f4e565.entry.js +1 -0
  731. package/dist/sparkle-core/p-352677e6.entry.js +1 -0
  732. package/dist/sparkle-core/p-38b7cf68.entry.js +1 -0
  733. package/dist/sparkle-core/p-38c842d5.entry.js +1 -0
  734. package/dist/sparkle-core/p-3963e02b.entry.js +1 -0
  735. package/dist/sparkle-core/p-39712c56.entry.js +4 -0
  736. package/dist/sparkle-core/p-39a31e43.js +1 -0
  737. package/dist/sparkle-core/p-3daf2915.entry.js +352 -0
  738. package/dist/sparkle-core/p-3de0e00c.js +4 -0
  739. package/dist/sparkle-core/p-4053ecdb.entry.js +1 -0
  740. package/dist/sparkle-core/p-408176ba.js +1 -0
  741. package/dist/sparkle-core/p-42ed7d5f.entry.js +1 -0
  742. package/dist/sparkle-core/p-48f72e63.js +4 -0
  743. package/dist/sparkle-core/p-4b4a8703.js +1 -0
  744. package/dist/sparkle-core/p-4c6a7e52.js +1 -0
  745. package/dist/sparkle-core/p-4d1cfcbe.entry.js +1 -0
  746. package/dist/sparkle-core/p-4d4077ea.js +4 -0
  747. package/dist/sparkle-core/p-4fba3e4c.js +1 -0
  748. package/dist/sparkle-core/p-506221fe.js +4 -0
  749. package/dist/sparkle-core/p-5096739e.entry.js +1 -0
  750. package/dist/sparkle-core/p-5322c920.entry.js +1 -0
  751. package/dist/sparkle-core/p-5893bbe5.entry.js +1 -0
  752. package/dist/sparkle-core/p-594a6982.entry.js +1 -0
  753. package/dist/sparkle-core/p-5c435d5a.entry.js +1 -0
  754. package/dist/sparkle-core/p-5cad23f1.js +3 -0
  755. package/dist/sparkle-core/p-5d409601.js +1 -0
  756. package/dist/sparkle-core/p-601397df.entry.js +1 -0
  757. package/dist/sparkle-core/p-604a7987.js +4 -0
  758. package/dist/sparkle-core/p-616941c6.entry.js +1 -0
  759. package/dist/sparkle-core/p-6316d124.entry.js +1 -0
  760. package/dist/sparkle-core/p-63f71ada.entry.js +1 -0
  761. package/dist/sparkle-core/p-69487d90.entry.js +1 -0
  762. package/dist/sparkle-core/p-6bde0192.entry.js +7 -0
  763. package/dist/sparkle-core/p-6d2f4093.entry.js +7 -0
  764. package/dist/sparkle-core/p-6ffd2420.entry.js +1 -0
  765. package/dist/sparkle-core/p-72053ae0.entry.js +1 -0
  766. package/dist/sparkle-core/p-73721c84.js +4 -0
  767. package/dist/sparkle-core/p-74864276.entry.js +1 -0
  768. package/dist/sparkle-core/p-7d8427eb.js +4 -0
  769. package/dist/sparkle-core/p-7dae0f0e.js +1 -0
  770. package/dist/sparkle-core/p-7dbfc316.js +1 -0
  771. package/dist/sparkle-core/p-7e7ce516.js +4 -0
  772. package/dist/sparkle-core/p-81714d94.entry.js +1 -0
  773. package/dist/sparkle-core/p-8492a765.entry.js +1 -0
  774. package/dist/sparkle-core/p-859563db.entry.js +1 -0
  775. package/dist/sparkle-core/p-85d4cd5c.entry.js +1 -0
  776. package/dist/sparkle-core/p-865f36a8.entry.js +1 -0
  777. package/dist/sparkle-core/p-86ed13f0.js +5 -0
  778. package/dist/sparkle-core/p-871106e0.js +4 -0
  779. package/dist/sparkle-core/p-894ff7e6.entry.js +1 -0
  780. package/dist/sparkle-core/p-8a41b502.entry.js +1 -0
  781. package/dist/sparkle-core/p-8b56f734.js +1 -0
  782. package/dist/sparkle-core/p-8c74cbb6.entry.js +1 -0
  783. package/dist/sparkle-core/p-924b2917.js +4 -0
  784. package/dist/sparkle-core/p-9289cdbc.entry.js +1 -0
  785. package/dist/sparkle-core/p-957715c5.entry.js +1 -0
  786. package/dist/sparkle-core/p-973fe404.entry.js +22 -0
  787. package/dist/sparkle-core/p-975b99ee.entry.js +1 -0
  788. package/dist/sparkle-core/p-98daeddb.entry.js +1 -0
  789. package/dist/sparkle-core/p-99ee9919.js +1 -0
  790. package/dist/sparkle-core/p-9abbd715.entry.js +1 -0
  791. package/dist/sparkle-core/p-9d894ed4.js +4 -0
  792. package/dist/sparkle-core/p-9e309b3e.entry.js +1 -0
  793. package/dist/sparkle-core/p-9e7fee8f.entry.js +1 -0
  794. package/dist/sparkle-core/p-9ebf0537.entry.js +1 -0
  795. package/dist/sparkle-core/p-a208ab2d.js +4 -0
  796. package/dist/sparkle-core/p-a2638250.entry.js +1 -0
  797. package/dist/sparkle-core/p-a2ebcf0a.entry.js +1 -0
  798. package/dist/sparkle-core/p-a98d7ebe.entry.js +1 -0
  799. package/dist/sparkle-core/p-add30d46.js +4 -0
  800. package/dist/sparkle-core/p-b0603d19.js +16 -0
  801. package/dist/sparkle-core/p-b06e2bef.js +1 -0
  802. package/dist/sparkle-core/p-b3f375fb.entry.js +1 -0
  803. package/dist/sparkle-core/p-b5f3e1bf.entry.js +1 -0
  804. package/dist/sparkle-core/p-b6fec622.entry.js +1 -0
  805. package/dist/sparkle-core/p-b8d71ff4.js +1 -0
  806. package/dist/sparkle-core/p-b96f3c84.entry.js +7 -0
  807. package/dist/sparkle-core/p-bd80ff43.js +4 -0
  808. package/dist/sparkle-core/p-bd90903e.js +1 -0
  809. package/dist/sparkle-core/p-be64105c.entry.js +1 -0
  810. package/dist/sparkle-core/p-c0533c23.entry.js +1 -0
  811. package/dist/sparkle-core/p-c2990b24.entry.js +1 -0
  812. package/dist/sparkle-core/p-c3cadfc6.entry.js +1 -0
  813. package/dist/sparkle-core/p-c60b29bd.entry.js +4 -0
  814. package/dist/sparkle-core/p-c64a34cd.entry.js +1 -0
  815. package/dist/sparkle-core/p-c7e21070.entry.js +1 -0
  816. package/dist/sparkle-core/p-c9f753a4.js +1 -0
  817. package/dist/sparkle-core/p-cabe9139.js +1 -0
  818. package/dist/sparkle-core/p-cabfbf22.entry.js +1 -0
  819. package/dist/sparkle-core/p-cc518c36.entry.js +1 -0
  820. package/dist/sparkle-core/p-cffd4817.entry.js +1 -0
  821. package/dist/sparkle-core/p-d0adf726.entry.js +1 -0
  822. package/dist/sparkle-core/p-d20e4fcf.entry.js +1 -0
  823. package/dist/sparkle-core/p-d24e53ab.entry.js +1 -0
  824. package/dist/sparkle-core/p-d288e6c1.entry.js +1 -0
  825. package/dist/sparkle-core/p-d601810e.entry.js +1 -0
  826. package/dist/sparkle-core/p-d68092b7.js +4 -0
  827. package/dist/sparkle-core/p-da391f3f.js +1 -0
  828. package/dist/sparkle-core/p-de4deb61.entry.js +1 -0
  829. package/dist/sparkle-core/p-e0cad1bb.js +1 -0
  830. package/dist/sparkle-core/p-e249aebf.entry.js +1 -0
  831. package/dist/sparkle-core/p-e3e36ce9.entry.js +1 -0
  832. package/dist/sparkle-core/p-e421d638.entry.js +1 -0
  833. package/dist/sparkle-core/p-e686d8b5.entry.js +4 -0
  834. package/dist/sparkle-core/p-e8988989.entry.js +1 -0
  835. package/dist/sparkle-core/p-e9431eeb.js +7 -0
  836. package/dist/sparkle-core/p-ea962e1b.entry.js +1 -0
  837. package/dist/sparkle-core/p-eaa8bbee.js +4 -0
  838. package/dist/sparkle-core/p-ebd4354b.entry.js +1 -0
  839. package/dist/sparkle-core/p-ee1e0eb4.js +2 -0
  840. package/dist/sparkle-core/p-ef4edc48.entry.js +4 -0
  841. package/dist/sparkle-core/p-f196c124.entry.js +7 -0
  842. package/dist/sparkle-core/p-f3cba72a.js +4 -0
  843. package/dist/sparkle-core/p-f47fe1fe.entry.js +1 -0
  844. package/dist/sparkle-core/p-f714f77a.entry.js +1 -0
  845. package/dist/sparkle-core/p-f891c79a.entry.js +1 -0
  846. package/dist/sparkle-core/p-fb0ca75e.entry.js +5 -0
  847. package/dist/sparkle-core/p-fb757951.entry.js +1 -0
  848. package/dist/sparkle-core/p-fd8d0738.entry.js +4 -0
  849. package/dist/sparkle-core/p-fda95b6e.entry.js +1 -0
  850. package/dist/sparkle-core/p-fe6dc976.entry.js +1 -0
  851. package/dist/sparkle-core/p-ff080f82.entry.js +10 -0
  852. package/dist/sparkle-core/p-ff7a8a71.js +4 -0
  853. package/dist/sparkle-core/sparkle-core.css +1 -2660
  854. package/dist/sparkle-core/sparkle-core.esm.js +1 -130
  855. package/package.json +1 -1
  856. package/dist/sparkle-core/PrivateRoute-a12e7ee5.js +0 -37
  857. package/dist/sparkle-core/account.service-e711795d.js +0 -63
  858. package/dist/sparkle-core/active-router-af86c9b4.js +0 -73
  859. package/dist/sparkle-core/animation-676a644d.js +0 -984
  860. package/dist/sparkle-core/app-globals-9ffa9ec3.js +0 -10
  861. package/dist/sparkle-core/appdata.service-703dff70.js +0 -69
  862. package/dist/sparkle-core/assets/user.png +0 -0
  863. package/dist/sparkle-core/assets.service-6508aae6.js +0 -71
  864. package/dist/sparkle-core/assignment.service-e42e9368.js +0 -17
  865. package/dist/sparkle-core/button-active-d68c5eb7.js +0 -67
  866. package/dist/sparkle-core/compass-svg.entry.js +0 -128
  867. package/dist/sparkle-core/context-consumer.entry.js +0 -25
  868. package/dist/sparkle-core/course-select.entry.js +0 -26
  869. package/dist/sparkle-core/css-shim-04165e59.js +0 -4
  870. package/dist/sparkle-core/dom-26e7cb2c.js +0 -73
  871. package/dist/sparkle-core/dom-utils-8e73e88b.js +0 -55
  872. package/dist/sparkle-core/facilitator.service-00a88935.js +0 -79
  873. package/dist/sparkle-core/facilitator.store-01be0386.js +0 -18
  874. package/dist/sparkle-core/feed.service-d495f3e1.js +0 -53
  875. package/dist/sparkle-core/framework-delegate-d3fa493f.js +0 -107
  876. package/dist/sparkle-core/haptic-a9e94599.js +0 -124
  877. package/dist/sparkle-core/header-mobile-collapse.entry.js +0 -86
  878. package/dist/sparkle-core/helpers-f11f0674.js +0 -406
  879. package/dist/sparkle-core/icons-758d1417.js +0 -41
  880. package/dist/sparkle-core/index-05b398c2.js +0 -34
  881. package/dist/sparkle-core/index-0af0deac.js +0 -312
  882. package/dist/sparkle-core/index-0df264ee.js +0 -4518
  883. package/dist/sparkle-core/index-183cda39.js +0 -223
  884. package/dist/sparkle-core/index-18a69883.js +0 -1336
  885. package/dist/sparkle-core/index-1d7a6fa0.js +0 -269
  886. package/dist/sparkle-core/index-1dec9544.js +0 -3064
  887. package/dist/sparkle-core/index-81dab78f.js +0 -85
  888. package/dist/sparkle-core/index-9b5bcea1.js +0 -22
  889. package/dist/sparkle-core/index-bb469fe3.js +0 -128
  890. package/dist/sparkle-core/index-d2990a48.js +0 -184
  891. package/dist/sparkle-core/index-dd414b33.js +0 -653
  892. package/dist/sparkle-core/index-faeec85a.js +0 -8
  893. package/dist/sparkle-core/index.es-1f6eedc5.js +0 -11066
  894. package/dist/sparkle-core/input-shims-0b2f5522.js +0 -418
  895. package/dist/sparkle-core/ion-accordion-group.entry.js +0 -201
  896. package/dist/sparkle-core/ion-accordion.entry.js +0 -332
  897. package/dist/sparkle-core/ion-action-sheet.entry.js +0 -263
  898. package/dist/sparkle-core/ion-alert.entry.js +0 -448
  899. package/dist/sparkle-core/ion-app.entry.js +0 -75
  900. package/dist/sparkle-core/ion-avatar.entry.js +0 -21
  901. package/dist/sparkle-core/ion-back-button.entry.js +0 -90
  902. package/dist/sparkle-core/ion-backdrop.entry.js +0 -63
  903. package/dist/sparkle-core/ion-badge.entry.js +0 -25
  904. package/dist/sparkle-core/ion-breadcrumb.entry.js +0 -91
  905. package/dist/sparkle-core/ion-breadcrumbs.entry.js +0 -129
  906. package/dist/sparkle-core/ion-button.entry.js +0 -125
  907. package/dist/sparkle-core/ion-buttons.entry.js +0 -38
  908. package/dist/sparkle-core/ion-card-content.entry.js +0 -26
  909. package/dist/sparkle-core/ion-card-header.entry.js +0 -33
  910. package/dist/sparkle-core/ion-card-subtitle.entry.js +0 -26
  911. package/dist/sparkle-core/ion-card-title.entry.js +0 -26
  912. package/dist/sparkle-core/ion-card.entry.js +0 -64
  913. package/dist/sparkle-core/ion-checkbox.entry.js +0 -109
  914. package/dist/sparkle-core/ion-chip.entry.js +0 -36
  915. package/dist/sparkle-core/ion-col.entry.js +0 -121
  916. package/dist/sparkle-core/ion-content.entry.js +0 -319
  917. package/dist/sparkle-core/ion-datetime-button.entry.js +0 -308
  918. package/dist/sparkle-core/ion-datetime.entry.js +0 -1619
  919. package/dist/sparkle-core/ion-fab-button.entry.js +0 -104
  920. package/dist/sparkle-core/ion-fab-list.entry.js +0 -41
  921. package/dist/sparkle-core/ion-fab.entry.js +0 -72
  922. package/dist/sparkle-core/ion-footer.entry.js +0 -116
  923. package/dist/sparkle-core/ion-grid.entry.js +0 -24
  924. package/dist/sparkle-core/ion-header.entry.js +0 -341
  925. package/dist/sparkle-core/ion-icon.entry.js +0 -200
  926. package/dist/sparkle-core/ion-img.entry.js +0 -97
  927. package/dist/sparkle-core/ion-infinite-scroll-content.entry.js +0 -33
  928. package/dist/sparkle-core/ion-infinite-scroll.entry.js +0 -202
  929. package/dist/sparkle-core/ion-input.entry.js +0 -293
  930. package/dist/sparkle-core/ion-item-divider.entry.js +0 -36
  931. package/dist/sparkle-core/ion-item-group.entry.js +0 -27
  932. package/dist/sparkle-core/ion-item-option.entry.js +0 -56
  933. package/dist/sparkle-core/ion-item-options.entry.js +0 -43
  934. package/dist/sparkle-core/ion-item-sliding.entry.js +0 -394
  935. package/dist/sparkle-core/ion-item.entry.js +0 -267
  936. package/dist/sparkle-core/ion-label.entry.js +0 -77
  937. package/dist/sparkle-core/ion-list-header.entry.js +0 -27
  938. package/dist/sparkle-core/ion-list.entry.js +0 -48
  939. package/dist/sparkle-core/ion-loading.entry.js +0 -211
  940. package/dist/sparkle-core/ion-menu-button.entry.js +0 -72
  941. package/dist/sparkle-core/ion-menu-toggle.entry.js +0 -43
  942. package/dist/sparkle-core/ion-menu.entry.js +0 -575
  943. package/dist/sparkle-core/ion-modal.entry.js +0 -1706
  944. package/dist/sparkle-core/ion-nav-link.entry.js +0 -43
  945. package/dist/sparkle-core/ion-nav.entry.js +0 -872
  946. package/dist/sparkle-core/ion-note.entry.js +0 -25
  947. package/dist/sparkle-core/ion-picker-column-internal.entry.js +0 -363
  948. package/dist/sparkle-core/ion-picker-column.entry.js +0 -327
  949. package/dist/sparkle-core/ion-picker-internal.entry.js +0 -454
  950. package/dist/sparkle-core/ion-picker.entry.js +0 -217
  951. package/dist/sparkle-core/ion-popover.entry.js +0 -1362
  952. package/dist/sparkle-core/ion-progress-bar.entry.js +0 -70
  953. package/dist/sparkle-core/ion-radio-group.entry.js +0 -121
  954. package/dist/sparkle-core/ion-radio.entry.js +0 -111
  955. package/dist/sparkle-core/ion-range.entry.js +0 -511
  956. package/dist/sparkle-core/ion-refresher-content.entry.js +0 -31
  957. package/dist/sparkle-core/ion-refresher.entry.js +0 -798
  958. package/dist/sparkle-core/ion-reorder-group.entry.js +0 -277
  959. package/dist/sparkle-core/ion-reorder.entry.js +0 -34
  960. package/dist/sparkle-core/ion-ripple-effect.entry.js +0 -89
  961. package/dist/sparkle-core/ion-route-redirect.entry.js +0 -20
  962. package/dist/sparkle-core/ion-route.entry.js +0 -45
  963. package/dist/sparkle-core/ion-router-link.entry.js +0 -34
  964. package/dist/sparkle-core/ion-router-outlet.entry.js +0 -196
  965. package/dist/sparkle-core/ion-router.entry.js +0 -827
  966. package/dist/sparkle-core/ion-row.entry.js +0 -16
  967. package/dist/sparkle-core/ion-searchbar.entry.js +0 -366
  968. package/dist/sparkle-core/ion-segment-button.entry.js +0 -98
  969. package/dist/sparkle-core/ion-segment.entry.js +0 -415
  970. package/dist/sparkle-core/ion-select-option.entry.js +0 -23
  971. package/dist/sparkle-core/ion-select-popover.entry.js +0 -96
  972. package/dist/sparkle-core/ion-select.entry.js +0 -510
  973. package/dist/sparkle-core/ion-skeleton-text.entry.js +0 -29
  974. package/dist/sparkle-core/ion-slide.entry.js +0 -21
  975. package/dist/sparkle-core/ion-slides.entry.js +0 -387
  976. package/dist/sparkle-core/ion-spinner.entry.js +0 -60
  977. package/dist/sparkle-core/ion-split-pane.entry.js +0 -156
  978. package/dist/sparkle-core/ion-tab-bar.entry.js +0 -71
  979. package/dist/sparkle-core/ion-tab-button.entry.js +0 -99
  980. package/dist/sparkle-core/ion-tab.entry.js +0 -63
  981. package/dist/sparkle-core/ion-tabs.entry.js +0 -150
  982. package/dist/sparkle-core/ion-text.entry.js +0 -20
  983. package/dist/sparkle-core/ion-textarea.entry.js +0 -244
  984. package/dist/sparkle-core/ion-thumbnail.entry.js +0 -16
  985. package/dist/sparkle-core/ion-title.entry.js +0 -48
  986. package/dist/sparkle-core/ion-toast.entry.js +0 -268
  987. package/dist/sparkle-core/ion-toggle.entry.js +0 -173
  988. package/dist/sparkle-core/ion-toolbar.entry.js +0 -70
  989. package/dist/sparkle-core/ion-virtual-scroll.entry.js +0 -551
  990. package/dist/sparkle-core/ionic-global-127576f6.js +0 -226
  991. package/dist/sparkle-core/ios.transition-02531dda.js +0 -479
  992. package/dist/sparkle-core/location-utils-fea12957.js +0 -229
  993. package/dist/sparkle-core/match-path-760e1797.js +0 -343
  994. package/dist/sparkle-core/md.transition-f8765467.js +0 -55
  995. package/dist/sparkle-core/media.service-2609406e.js +0 -36
  996. package/dist/sparkle-core/menu-toggle-util-6cc13cbd.js +0 -12
  997. package/dist/sparkle-core/overlays-fd3cfa13.js +0 -493
  998. package/dist/sparkle-core/parse-60474840.js +0 -1196
  999. package/dist/sparkle-core/purify-d9093094.js +0 -1469
  1000. package/dist/sparkle-core/quiz.model-1cff62e4.js +0 -5
  1001. package/dist/sparkle-core/shadow-css-1257b266.js +0 -387
  1002. package/dist/sparkle-core/signalR.service-2b7645c1.js +0 -2983
  1003. package/dist/sparkle-core/sparkle-animation-player.entry.js +0 -513
  1004. package/dist/sparkle-core/sparkle-assignment.entry.js +0 -114
  1005. package/dist/sparkle-core/sparkle-button.entry.js +0 -24
  1006. package/dist/sparkle-core/sparkle-card.entry.js +0 -61
  1007. package/dist/sparkle-core/sparkle-cards.entry.js +0 -15
  1008. package/dist/sparkle-core/sparkle-character-intro.entry.js +0 -22
  1009. package/dist/sparkle-core/sparkle-code.entry.js +0 -39
  1010. package/dist/sparkle-core/sparkle-compass-post.entry.js +0 -129
  1011. package/dist/sparkle-core/sparkle-compass.entry.js +0 -122
  1012. package/dist/sparkle-core/sparkle-course-root.entry.js +0 -155
  1013. package/dist/sparkle-core/sparkle-discussion-questions.entry.js +0 -122
  1014. package/dist/sparkle-core/sparkle-discussion-results.entry.js +0 -189
  1015. package/dist/sparkle-core/sparkle-discussion.entry.js +0 -52
  1016. package/dist/sparkle-core/sparkle-dropdown.entry.js +0 -57
  1017. package/dist/sparkle-core/sparkle-emoji.entry.js +0 -77
  1018. package/dist/sparkle-core/sparkle-export-lessons.entry.js +0 -10081
  1019. package/dist/sparkle-core/sparkle-facilitator-dashboard.entry.js +0 -93
  1020. package/dist/sparkle-core/sparkle-facilitator-header.entry.js +0 -60
  1021. package/dist/sparkle-core/sparkle-facilitator-notes-form.entry.js +0 -160
  1022. package/dist/sparkle-core/sparkle-facilitator-notes.entry.js +0 -65
  1023. package/dist/sparkle-core/sparkle-facilitator-page.entry.js +0 -198
  1024. package/dist/sparkle-core/sparkle-feed-post.entry.js +0 -131
  1025. package/dist/sparkle-core/sparkle-feedback.entry.js +0 -106
  1026. package/dist/sparkle-core/sparkle-file-upload.entry.js +0 -57
  1027. package/dist/sparkle-core/sparkle-forgot-password.entry.js +0 -80
  1028. package/dist/sparkle-core/sparkle-goal-form.entry.js +0 -182
  1029. package/dist/sparkle-core/sparkle-goal-item.entry.js +0 -15
  1030. package/dist/sparkle-core/sparkle-goal-progress.entry.js +0 -15
  1031. package/dist/sparkle-core/sparkle-goals.entry.js +0 -47
  1032. package/dist/sparkle-core/sparkle-gww-comment-list.entry.js +0 -22
  1033. package/dist/sparkle-core/sparkle-gww-graph.entry.js +0 -15
  1034. package/dist/sparkle-core/sparkle-gww-item.entry.js +0 -80
  1035. package/dist/sparkle-core/sparkle-gww.entry.js +0 -44
  1036. package/dist/sparkle-core/sparkle-header.entry.js +0 -97
  1037. package/dist/sparkle-core/sparkle-health.entry.js +0 -70
  1038. package/dist/sparkle-core/sparkle-input.entry.js +0 -52
  1039. package/dist/sparkle-core/sparkle-intro.entry.js +0 -22
  1040. package/dist/sparkle-core/sparkle-login.entry.js +0 -116
  1041. package/dist/sparkle-core/sparkle-lower-content-nav.entry.js +0 -18
  1042. package/dist/sparkle-core/sparkle-menu-collapsible.entry.js +0 -42
  1043. package/dist/sparkle-core/sparkle-menu-toggle.entry.js +0 -24
  1044. package/dist/sparkle-core/sparkle-menu.entry.js +0 -26
  1045. package/dist/sparkle-core/sparkle-modal-image.entry.js +0 -33
  1046. package/dist/sparkle-core/sparkle-mood.entry.js +0 -76
  1047. package/dist/sparkle-core/sparkle-nav.entry.js +0 -113
  1048. package/dist/sparkle-core/sparkle-notfound-page.entry.js +0 -25
  1049. package/dist/sparkle-core/sparkle-online-students.entry.js +0 -55
  1050. package/dist/sparkle-core/sparkle-overlay.entry.js +0 -90
  1051. package/dist/sparkle-core/sparkle-page-footer.entry.js +0 -24
  1052. package/dist/sparkle-core/sparkle-page.entry.js +0 -245
  1053. package/dist/sparkle-core/sparkle-pagination.entry.js +0 -67
  1054. package/dist/sparkle-core/sparkle-poll.entry.js +0 -15
  1055. package/dist/sparkle-core/sparkle-quiz-container.entry.js +0 -43
  1056. package/dist/sparkle-core/sparkle-quiz-feedback.entry.js +0 -18
  1057. package/dist/sparkle-core/sparkle-quiz-input.entry.js +0 -16
  1058. package/dist/sparkle-core/sparkle-quiz-old.entry.js +0 -116
  1059. package/dist/sparkle-core/sparkle-quiz-opinion.entry.js +0 -41
  1060. package/dist/sparkle-core/sparkle-quiz-poll.entry.js +0 -16
  1061. package/dist/sparkle-core/sparkle-quiz-select.entry.js +0 -29
  1062. package/dist/sparkle-core/sparkle-quiz.entry.js +0 -98
  1063. package/dist/sparkle-core/sparkle-reset-password.entry.js +0 -96
  1064. package/dist/sparkle-core/sparkle-root.entry.js +0 -79
  1065. package/dist/sparkle-core/sparkle-select.entry.js +0 -57
  1066. package/dist/sparkle-core/sparkle-sidebar.entry.js +0 -39
  1067. package/dist/sparkle-core/sparkle-signup.entry.js +0 -144
  1068. package/dist/sparkle-core/sparkle-tab.entry.js +0 -22
  1069. package/dist/sparkle-core/sparkle-table-of-contents.entry.js +0 -67
  1070. package/dist/sparkle-core/sparkle-tabs.entry.js +0 -62
  1071. package/dist/sparkle-core/sparkle-unauthorized.entry.js +0 -17
  1072. package/dist/sparkle-core/sparkle-user-enrollment.entry.js +0 -85
  1073. package/dist/sparkle-core/sparkle-user-profile.entry.js +0 -129
  1074. package/dist/sparkle-core/sparkle-validation-error.entry.js +0 -17
  1075. package/dist/sparkle-core/sparkle-video-player.entry.js +0 -18
  1076. package/dist/sparkle-core/sparkle-youtube.entry.js +0 -35
  1077. package/dist/sparkle-core/status-tap-52feb1b1.js +0 -40
  1078. package/dist/sparkle-core/stencil-async-content.entry.js +0 -28
  1079. package/dist/sparkle-core/stencil-route-link.entry.js +0 -74
  1080. package/dist/sparkle-core/stencil-route-switch.entry.js +0 -100
  1081. package/dist/sparkle-core/stencil-route-title.entry.js +0 -28
  1082. package/dist/sparkle-core/stencil-route.entry.js +0 -93
  1083. package/dist/sparkle-core/stencil-router-prompt.entry.js +0 -55
  1084. package/dist/sparkle-core/stencil-router-redirect.entry.js +0 -28
  1085. package/dist/sparkle-core/stencil-router.entry.js +0 -636
  1086. package/dist/sparkle-core/store.service-0f7d998b.js +0 -16
  1087. package/dist/sparkle-core/student.service-f0375229.js +0 -59
  1088. package/dist/sparkle-core/swipe-back-9a614189.js +0 -73
  1089. package/dist/sparkle-core/swiper.bundle-4274e115.js +0 -6418
  1090. package/dist/sparkle-core/user.store-3d052406.js +0 -19
  1091. package/dist/sparkle-core/util-ba470e54.js +0 -14683
  1092. package/dist/sparkle-core/utils-cae23bce.js +0 -114
  1093. /package/dist/{sparkle-core → esm}/cubic-bezier-4c0db14f.js +0 -0
  1094. /package/dist/{sparkle-core → esm}/focus-visible-4e9a0764.js +0 -0
  1095. /package/dist/{sparkle-core → esm}/hardware-back-button-fa04d6e9.js +0 -0
  1096. /package/dist/{sparkle-core → esm}/index-be6112f8.js +0 -0
  1097. /package/dist/{sparkle-core → esm}/keyboard-7e8329b3.js +0 -0
  1098. /package/dist/{sparkle-core → esm}/localstorage.service-4bf408c8.js +0 -0
  1099. /package/dist/{sparkle-core → esm}/spinner-configs-a37e628a.js +0 -0
  1100. /package/dist/{sparkle-core → esm}/theme-7ef00c83.js +0 -0
@@ -1,1619 +0,0 @@
1
- import { r as registerInstance, q as createEvent, l as writeTask, k as h, n as Host, o as getElement } from './index-1dec9544.js';
2
- import { c as chevronDown, b as caretUpSharp, d as chevronForward, f as caretDownSharp, g as chevronBack } from './index-18a69883.js';
3
- import { g as getIonMode } from './ionic-global-127576f6.js';
4
- import { startFocusVisible } from './focus-visible-4e9a0764.js';
5
- import { r as raf, g as getElementRoot, d as renderHiddenInput } from './helpers-f11f0674.js';
6
- import { p as printIonWarning, a as printIonError } from './index-05b398c2.js';
7
- import { i as isRTL } from './index-9b5bcea1.js';
8
- import { c as createColorClasses } from './theme-7ef00c83.js';
9
- import { i as isBefore, a as isAfter, b as isSameDay, g as generateDayAriaLabel, c as getPreviousMonth, d as getNextMonth, p as parseDate, e as getToday, f as getPartsFromCalendarDay, h as getNextYear, j as getPreviousYear, k as getEndOfWeek, l as getStartOfWeek, m as getPreviousDay, n as getNextDay, o as getPreviousWeek, q as getNextWeek, w as warnIfValueOutOfBounds, r as clampDate, s as parseAmPm, t as convertToArrayOfNumbers, u as convertDataToISO, v as generateMonths, x as getCombinedDateColumnData, y as getMonthColumnData, z as getDayColumnData, A as getYearColumnData, B as isMonthFirstLocale, C as getTimeColumnsData, D as isLocaleDayPeriodRTL, E as calculateHourFromAMPM, F as getMonthAndYear, G as getDaysOfWeek, H as getDaysOfMonth, I as is24Hour, J as getLocalizedTime, K as getMonthAndDay, L as formatValue } from './parse-60474840.js';
10
-
11
- /*!
12
- * (C) Ionic http://ionicframework.com - MIT License
13
- */
14
- const isYearDisabled = (refYear, minParts, maxParts) => {
15
- if (minParts && minParts.year > refYear) {
16
- return true;
17
- }
18
- if (maxParts && maxParts.year < refYear) {
19
- return true;
20
- }
21
- return false;
22
- };
23
- /**
24
- * Returns true if a given day should
25
- * not be interactive according to its value,
26
- * or the max/min dates.
27
- */
28
- const isDayDisabled = (refParts, minParts, maxParts, dayValues) => {
29
- /**
30
- * If this is a filler date (i.e. padding)
31
- * then the date is disabled.
32
- */
33
- if (refParts.day === null) {
34
- return true;
35
- }
36
- /**
37
- * If user passed in a list of acceptable day values
38
- * check to make sure that the date we are looking
39
- * at is in this array.
40
- */
41
- if (dayValues !== undefined && !dayValues.includes(refParts.day)) {
42
- return true;
43
- }
44
- /**
45
- * Given a min date, perform the following
46
- * checks. If any of them are true, then the
47
- * day should be disabled:
48
- * 1. Is the current year < the min allowed year?
49
- * 2. Is the current year === min allowed year,
50
- * but the current month < the min allowed month?
51
- * 3. Is the current year === min allowed year, the
52
- * current month === min allow month, but the current
53
- * day < the min allowed day?
54
- */
55
- if (minParts && isBefore(refParts, minParts)) {
56
- return true;
57
- }
58
- /**
59
- * Given a max date, perform the following
60
- * checks. If any of them are true, then the
61
- * day should be disabled:
62
- * 1. Is the current year > the max allowed year?
63
- * 2. Is the current year === max allowed year,
64
- * but the current month > the max allowed month?
65
- * 3. Is the current year === max allowed year, the
66
- * current month === max allow month, but the current
67
- * day > the max allowed day?
68
- */
69
- if (maxParts && isAfter(refParts, maxParts)) {
70
- return true;
71
- }
72
- /**
73
- * If none of these checks
74
- * passed then the date should
75
- * be interactive.
76
- */
77
- return false;
78
- };
79
- /**
80
- * Given a locale, a date, the selected date(s), and today's date,
81
- * generate the state for a given calendar day button.
82
- */
83
- const getCalendarDayState = (locale, refParts, activeParts, todayParts, minParts, maxParts, dayValues) => {
84
- /**
85
- * activeParts signals what day(s) are currently selected in the datetime.
86
- * If multiple="true", this will be an array, but the logic in this util
87
- * is the same whether we have one selected day or many because we're only
88
- * calculating the state for one button. So, we treat a single activeParts value
89
- * the same as an array of length one.
90
- */
91
- const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
92
- /**
93
- * The day button is active if it is selected, or in other words, if refParts
94
- * matches at least one selected date.
95
- */
96
- const isActive = activePartsArray.find((parts) => isSameDay(refParts, parts)) !== undefined;
97
- const isToday = isSameDay(refParts, todayParts);
98
- const disabled = isDayDisabled(refParts, minParts, maxParts, dayValues);
99
- /**
100
- * Note that we always return one object regardless of whether activeParts
101
- * was an array, since we pare down to one value for isActive.
102
- */
103
- return {
104
- disabled,
105
- isActive,
106
- isToday,
107
- ariaSelected: isActive ? 'true' : null,
108
- ariaLabel: generateDayAriaLabel(locale, isToday, refParts),
109
- };
110
- };
111
- /**
112
- * Returns `true` if the month is disabled given the
113
- * current date value and min/max date constraints.
114
- */
115
- const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
116
- // If the year is disabled then the month is disabled.
117
- if (isYearDisabled(refParts.year, minParts, maxParts)) {
118
- return true;
119
- }
120
- // If the date value is before the min date, then the month is disabled.
121
- // If the date value is after the max date, then the month is disabled.
122
- if ((minParts && isBefore(refParts, minParts)) || (maxParts && isAfter(refParts, maxParts))) {
123
- return true;
124
- }
125
- return false;
126
- };
127
- /**
128
- * Given a working date, an optional minimum date range,
129
- * and an optional maximum date range; determine if the
130
- * previous navigation button is disabled.
131
- */
132
- const isPrevMonthDisabled = (refParts, minParts, maxParts) => {
133
- const prevMonth = Object.assign(Object.assign({}, getPreviousMonth(refParts)), { day: null });
134
- return isMonthDisabled(prevMonth, {
135
- minParts,
136
- maxParts,
137
- });
138
- };
139
- /**
140
- * Given a working date and a maximum date range,
141
- * determine if the next navigation button is disabled.
142
- */
143
- const isNextMonthDisabled = (refParts, maxParts) => {
144
- const nextMonth = Object.assign(Object.assign({}, getNextMonth(refParts)), { day: null });
145
- return isMonthDisabled(nextMonth, {
146
- maxParts,
147
- });
148
- };
149
-
150
- const datetimeIosCss = ":host{display:flex;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{order:3;text-align:end}:host .wheel-order-year-first .month-column{order:2;text-align:end}:host .wheel-order-year-first .year-column{order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:flex;flex:1 1 auto;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px;position:absolute;visibility:hidden;pointer-events:none}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-readonly),:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled){opacity:0.4}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:flex;justify-content:space-between}:host .calendar-action-buttons{display:flex;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:flex;align-items:center}:host .calendar-action-buttons ion-item ion-icon{padding-left:4px;padding-right:0;padding-top:0;padding-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-action-buttons ion-item ion-icon{padding-left:unset;padding-right:unset;-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0}}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}:host .calendar-body{display:flex;flex-grow:1;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{scroll-snap-align:start;scroll-snap-stop:always;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr);height:100%}:host .calendar-day{padding-left:0px;padding-right:0px;padding-top:0px;padding-bottom:0px;margin-left:0px;margin-right:0px;margin-top:0px;margin-bottom:0px;display:flex;position:relative;align-items:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;cursor:pointer;appearance:none;z-index:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day{padding-left:unset;padding-right:unset;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px}}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day{margin-left:unset;margin-right:unset;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px}}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}:host .calendar-day:after{border-radius:32px;padding-left:4px;padding-right:4px;padding-top:4px;padding-bottom:4px;position:absolute;top:50%;left:50%;width:32px;height:32px;transform:translate(-50%, -50%);content:\" \";z-index:-1}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day:after{padding-left:unset;padding-right:unset;-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px}}:host .datetime-time{display:flex;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:flex;align-items:center}:host .time-body{border-radius:8px;padding-left:12px;padding-right:12px;padding-top:6px;padding-bottom:6px;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;appearance:none}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .time-body{padding-left:unset;padding-right:unset;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px}}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-light, #ffffff);--background-rgb:var(--ion-color-light-rgb);--title-color:var(--ion-color-step-600, #666666)}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{padding-left:16px;padding-right:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, #cccccc)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .datetime-header{padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}:host .datetime-header .datetime-title{color:var(--title-color);font-size:14px}:host .calendar-action-buttons ion-item{--padding-start:16px;--background-hover:transparent;--background-activated:transparent;font-size:16px;font-weight:600}:host .calendar-action-buttons ion-item ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{padding-left:0;padding-right:0;padding-top:8px;padding-bottom:0}:host .calendar-action-buttons ion-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-days-of-week{padding-left:8px;padding-right:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, #b3b3b3);font-size:12px;font-weight:600;line-height:24px;text-transform:uppercase}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-days-of-week{padding-left:unset;padding-right:unset;-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px}}:host .calendar-body .calendar-month .calendar-month-grid{padding-left:8px;padding-right:8px;padding-top:8px;padding-bottom:8px;height:calc(100% - 16px)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-body .calendar-month .calendar-month-grid{padding-left:unset;padding-right:unset;-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px}}:host .calendar-day{font-size:20px}:host .calendar-day:after{opacity:0.2}:host .calendar-day:focus:after{background:var(--ion-color-base)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-active:after{background:var(--ion-color-base)}:host .calendar-day.calendar-day-today.calendar-day-active{color:var(--ion-color-contrast)}:host .calendar-day.calendar-day-today.calendar-day-active:after{background:var(--ion-color-base);opacity:1}:host .datetime-time{padding-left:16px;padding-right:16px;padding-top:8px;padding-bottom:16px;font-size:16px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .datetime-time{padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{padding-left:8px;padding-right:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, #cccccc)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .datetime-buttons{padding-left:unset;padding-right:unset;-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px}}:host .datetime-buttons ::slotted(ion-buttons),:host .datetime-buttons ion-buttons{display:flex;align-items:center;justify-content:space-between}:host .datetime-action-buttons{width:100%}";
151
-
152
- const datetimeMdCss = ":host{display:flex;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{order:3;text-align:end}:host .wheel-order-year-first .month-column{order:2;text-align:end}:host .wheel-order-year-first .year-column{order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:flex;flex:1 1 auto;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px;position:absolute;visibility:hidden;pointer-events:none}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-readonly),:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled){opacity:0.4}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:flex;justify-content:space-between}:host .calendar-action-buttons{display:flex;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:flex;align-items:center}:host .calendar-action-buttons ion-item ion-icon{padding-left:4px;padding-right:0;padding-top:0;padding-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-action-buttons ion-item ion-icon{padding-left:unset;padding-right:unset;-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0}}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}:host .calendar-body{display:flex;flex-grow:1;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{scroll-snap-align:start;scroll-snap-stop:always;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr);height:100%}:host .calendar-day{padding-left:0px;padding-right:0px;padding-top:0px;padding-bottom:0px;margin-left:0px;margin-right:0px;margin-top:0px;margin-bottom:0px;display:flex;position:relative;align-items:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;cursor:pointer;appearance:none;z-index:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day{padding-left:unset;padding-right:unset;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px}}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day{margin-left:unset;margin-right:unset;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px}}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}:host .calendar-day:after{border-radius:32px;padding-left:4px;padding-right:4px;padding-top:4px;padding-bottom:4px;position:absolute;top:50%;left:50%;width:32px;height:32px;transform:translate(-50%, -50%);content:\" \";z-index:-1}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day:after{padding-left:unset;padding-right:unset;-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px}}:host .datetime-time{display:flex;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:flex;align-items:center}:host .time-body{border-radius:8px;padding-left:12px;padding-right:12px;padding-top:6px;padding-bottom:6px;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;appearance:none}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .time-body{padding-left:unset;padding-right:unset;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px}}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-step-100, #ffffff);--title-color:var(--ion-color-contrast)}:host .datetime-header{padding-left:20px;padding-right:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .datetime-header{padding-left:unset;padding-right:unset;-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px}}:host .datetime-header .datetime-title{font-size:12px;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:34px}:host .datetime-calendar .calendar-action-buttons ion-item{--padding-start:20px}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{color:var(--ion-color-step-650, #595959)}:host .calendar-days-of-week{padding-left:10px;padding-right:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, gray);font-size:14px;line-height:36px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-days-of-week{padding-left:unset;padding-right:unset;-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px}}:host .calendar-body .calendar-month .calendar-month-grid{padding-left:10px;padding-right:10px;padding-top:3px;padding-bottom:0px;grid-template-rows:repeat(6, 1fr)}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-body .calendar-month .calendar-month-grid{padding-left:unset;padding-right:unset;-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px}}:host .calendar-day{padding-left:0px;padding-right:0;padding-top:13px;padding-bottom:13px;font-size:14px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .calendar-day{padding-left:unset;padding-right:unset;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0;padding-inline-end:0}}:host .calendar-day:focus:after{background:rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-today:after{border:1px solid var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-contrast)}:host .calendar-day.calendar-day-active:after{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .datetime-time{padding-left:16px;padding-right:16px;padding-top:8px;padding-bottom:8px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .datetime-time{padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}:host .time-header{color:var(--ion-color-step-650, #595959)}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{padding-left:10px;padding-right:10px;padding-top:10px;padding-bottom:10px;display:flex;align-items:center;justify-content:flex-end}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host .datetime-buttons{padding-left:unset;padding-right:unset;-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px}}:host .datetime-view-buttons ion-button{color:var(--ion-color-step-800, #333333)}";
153
-
154
- const Datetime = class {
155
- constructor(hostRef) {
156
- registerInstance(this, hostRef);
157
- this.ionCancel = createEvent(this, "ionCancel", 7);
158
- this.ionChange = createEvent(this, "ionChange", 7);
159
- this.ionFocus = createEvent(this, "ionFocus", 7);
160
- this.ionBlur = createEvent(this, "ionBlur", 7);
161
- this.ionStyle = createEvent(this, "ionStyle", 7);
162
- this.ionRender = createEvent(this, "ionRender", 7);
163
- this.inputId = `ion-dt-${datetimeIds++}`;
164
- /**
165
- * Whether to highlight the active day with a solid circle (as opposed
166
- * to the outline circle around today). If you don't specify an initial
167
- * value for the datetime, it doesn't automatically init to a default to
168
- * avoid unwanted change events firing. If the solid circle were still
169
- * shown then, it would look like a date had already been selected, which
170
- * is misleading UX.
171
- */
172
- this.highlightActiveParts = false;
173
- this.todayParts = parseDate(getToday());
174
- this.prevPresentation = null;
175
- this.showMonthAndYear = false;
176
- this.activeParts = {
177
- month: 5,
178
- day: 28,
179
- year: 2021,
180
- hour: 13,
181
- minute: 52,
182
- ampm: 'pm',
183
- };
184
- this.workingParts = {
185
- month: 5,
186
- day: 28,
187
- year: 2021,
188
- hour: 13,
189
- minute: 52,
190
- ampm: 'pm',
191
- };
192
- this.isPresented = false;
193
- this.isTimePopoverOpen = false;
194
- /**
195
- * The color to use from your application's color palette.
196
- * Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`.
197
- * For more information on colors, see [theming](/docs/theming/basics).
198
- */
199
- this.color = 'primary';
200
- /**
201
- * The name of the control, which is submitted with the form data.
202
- */
203
- this.name = this.inputId;
204
- /**
205
- * If `true`, the user cannot interact with the datetime.
206
- */
207
- this.disabled = false;
208
- /**
209
- * If `true`, the datetime appears normal but is not interactive.
210
- */
211
- this.readonly = false;
212
- /**
213
- * Which values you want to select. `'date'` will show
214
- * a calendar picker to select the month, day, and year. `'time'`
215
- * will show a time picker to select the hour, minute, and (optionally)
216
- * AM/PM. `'date-time'` will show the date picker first and time picker second.
217
- * `'time-date'` will show the time picker first and date picker second.
218
- */
219
- this.presentation = 'date-time';
220
- /**
221
- * The text to display on the picker's cancel button.
222
- */
223
- this.cancelText = 'Cancel';
224
- /**
225
- * The text to display on the picker's "Done" button.
226
- */
227
- this.doneText = 'Done';
228
- /**
229
- * The text to display on the picker's "Clear" button.
230
- */
231
- this.clearText = 'Clear';
232
- /**
233
- * The locale to use for `ion-datetime`. This
234
- * impacts month and day name formatting.
235
- * The `'default'` value refers to the default
236
- * locale set by your device.
237
- */
238
- this.locale = 'default';
239
- /**
240
- * The first day of the week to use for `ion-datetime`. The
241
- * default value is `0` and represents Sunday.
242
- */
243
- this.firstDayOfWeek = 0;
244
- /**
245
- * If `true`, multiple dates can be selected at once. Only
246
- * applies to `presentation="date"` and `preferWheel="false"`.
247
- */
248
- this.multiple = false;
249
- /**
250
- * If `true`, a header will be shown above the calendar
251
- * picker. On `ios` mode this will include the
252
- * slotted title, and on `md` mode this will include
253
- * the slotted title and the selected date.
254
- */
255
- this.showDefaultTitle = false;
256
- /**
257
- * If `true`, the default "Cancel" and "OK" buttons
258
- * will be rendered at the bottom of the `ion-datetime`
259
- * component. Developers can also use the `button` slot
260
- * if they want to customize these buttons. If custom
261
- * buttons are set in the `button` slot then the
262
- * default buttons will not be rendered.
263
- */
264
- this.showDefaultButtons = false;
265
- /**
266
- * If `true`, a "Clear" button will be rendered alongside
267
- * the default "Cancel" and "OK" buttons at the bottom of the `ion-datetime`
268
- * component. Developers can also use the `button` slot
269
- * if they want to customize these buttons. If custom
270
- * buttons are set in the `button` slot then the
271
- * default buttons will not be rendered.
272
- */
273
- this.showClearButton = false;
274
- /**
275
- * If `true`, the default "Time" label will be rendered
276
- * for the time selector of the `ion-datetime` component.
277
- * Developers can also use the `time-label` slot
278
- * if they want to customize this label. If a custom
279
- * label is set in the `time-label` slot then the
280
- * default label will not be rendered.
281
- */
282
- this.showDefaultTimeLabel = true;
283
- /**
284
- * If `cover`, the `ion-datetime` will expand to cover the full width of its container.
285
- * If `fixed`, the `ion-datetime` will have a fixed width.
286
- */
287
- this.size = 'fixed';
288
- /**
289
- * If `true`, a wheel picker will be rendered instead of a calendar grid
290
- * where possible. If `false`, a calendar grid will be rendered instead of
291
- * a wheel picker where possible.
292
- *
293
- * A wheel picker can be rendered instead of a grid when `presentation` is
294
- * one of the following values: `'date'`, `'date-time'`, or `'time-date'`.
295
- *
296
- * A wheel picker will always be rendered regardless of
297
- * the `preferWheel` value when `presentation` is one of the following values:
298
- * `'time'`, `'month'`, `'month-year'`, or `'year'`.
299
- */
300
- this.preferWheel = false;
301
- this.closeParentOverlay = () => {
302
- const popoverOrModal = this.el.closest('ion-modal, ion-popover');
303
- if (popoverOrModal) {
304
- popoverOrModal.dismiss();
305
- }
306
- };
307
- this.setWorkingParts = (parts) => {
308
- this.workingParts = Object.assign({}, parts);
309
- };
310
- this.setActiveParts = (parts, removeDate = false) => {
311
- const { multiple, activePartsClone, highlightActiveParts } = this;
312
- if (multiple) {
313
- /**
314
- * We read from activePartsClone here because valueChanged() only updates that,
315
- * so it's the more reliable source of truth. If we read from activeParts, then
316
- * if you click July 1, manually set the value to July 2, and then click July 3,
317
- * the new value would be [July 1, July 3], ignoring the value set.
318
- *
319
- * We can then pass the new value to activeParts (rather than activePartsClone)
320
- * since the clone will be updated automatically by activePartsChanged().
321
- */
322
- const activePartsArray = Array.isArray(activePartsClone) ? activePartsClone : [activePartsClone];
323
- if (removeDate) {
324
- this.activeParts = activePartsArray.filter((p) => !isSameDay(p, parts));
325
- }
326
- else if (highlightActiveParts) {
327
- this.activeParts = [...activePartsArray, parts];
328
- }
329
- else {
330
- /**
331
- * If highlightActiveParts is false, that means we just have a
332
- * default value of today in activeParts; we need to replace that
333
- * rather than adding to it since it's just a placeholder.
334
- */
335
- this.activeParts = [parts];
336
- }
337
- }
338
- else {
339
- this.activeParts = Object.assign({}, parts);
340
- }
341
- /**
342
- * Now that the user has interacted somehow to select something, we can
343
- * show the solid highlight. This needs to be done after checking it above,
344
- * but before the confirm call below.
345
- *
346
- * Note that for datetimes with confirm/cancel buttons, the value
347
- * isn't updated until you call confirm(). We need to bring the
348
- * solid circle back on day click for UX reasons, rather than only
349
- * show the circle if `value` is truthy.
350
- */
351
- this.highlightActiveParts = true;
352
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
353
- if (hasSlottedButtons || this.showDefaultButtons) {
354
- return;
355
- }
356
- this.confirm();
357
- };
358
- /**
359
- * Stencil sometimes sets calendarBodyRef to null on rerender, even though
360
- * the element is present. Query for it manually as a fallback.
361
- *
362
- * TODO(FW-901) Remove when issue is resolved: https://github.com/ionic-team/stencil/issues/3253
363
- */
364
- this.getCalendarBodyEl = () => {
365
- var _a;
366
- return this.calendarBodyRef || ((_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.calendar-body'));
367
- };
368
- this.initializeKeyboardListeners = () => {
369
- const calendarBodyRef = this.getCalendarBodyEl();
370
- if (!calendarBodyRef) {
371
- return;
372
- }
373
- const root = this.el.shadowRoot;
374
- /**
375
- * Get a reference to the month
376
- * element we are currently viewing.
377
- */
378
- const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
379
- /**
380
- * When focusing the calendar body, we want to pass focus
381
- * to the working day, but other days should
382
- * only be accessible using the arrow keys. Pressing
383
- * Tab should jump between bodies of selectable content.
384
- */
385
- const checkCalendarBodyFocus = (ev) => {
386
- var _a;
387
- const record = ev[0];
388
- /**
389
- * If calendar body was already focused
390
- * when this fired or if the calendar body
391
- * if not currently focused, we should not re-focus
392
- * the inner day.
393
- */
394
- if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
395
- return;
396
- }
397
- this.focusWorkingDay(currentMonth);
398
- };
399
- const mo = new MutationObserver(checkCalendarBodyFocus);
400
- mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
401
- this.destroyKeyboardMO = () => {
402
- mo === null || mo === void 0 ? void 0 : mo.disconnect();
403
- };
404
- /**
405
- * We must use keydown not keyup as we want
406
- * to prevent scrolling when using the arrow keys.
407
- */
408
- calendarBodyRef.addEventListener('keydown', (ev) => {
409
- const activeElement = root.activeElement;
410
- if (!activeElement || !activeElement.classList.contains('calendar-day')) {
411
- return;
412
- }
413
- const parts = getPartsFromCalendarDay(activeElement);
414
- let partsToFocus;
415
- switch (ev.key) {
416
- case 'ArrowDown':
417
- ev.preventDefault();
418
- partsToFocus = getNextWeek(parts);
419
- break;
420
- case 'ArrowUp':
421
- ev.preventDefault();
422
- partsToFocus = getPreviousWeek(parts);
423
- break;
424
- case 'ArrowRight':
425
- ev.preventDefault();
426
- partsToFocus = getNextDay(parts);
427
- break;
428
- case 'ArrowLeft':
429
- ev.preventDefault();
430
- partsToFocus = getPreviousDay(parts);
431
- break;
432
- case 'Home':
433
- ev.preventDefault();
434
- partsToFocus = getStartOfWeek(parts);
435
- break;
436
- case 'End':
437
- ev.preventDefault();
438
- partsToFocus = getEndOfWeek(parts);
439
- break;
440
- case 'PageUp':
441
- ev.preventDefault();
442
- partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
443
- break;
444
- case 'PageDown':
445
- ev.preventDefault();
446
- partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
447
- break;
448
- /**
449
- * Do not preventDefault here
450
- * as we do not want to override other
451
- * browser defaults such as pressing Enter/Space
452
- * to select a day.
453
- */
454
- default:
455
- return;
456
- }
457
- /**
458
- * If the day we want to move focus to is
459
- * disabled, do not do anything.
460
- */
461
- if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
462
- return;
463
- }
464
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
465
- /**
466
- * Give view a chance to re-render
467
- * then move focus to the new working day
468
- */
469
- requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
470
- });
471
- };
472
- this.focusWorkingDay = (currentMonth) => {
473
- /**
474
- * Get the number of padding days so
475
- * we know how much to offset our next selector by
476
- * to grab the correct calenday-day element.
477
- */
478
- const padding = currentMonth.querySelectorAll('.calendar-day-padding');
479
- const { day } = this.workingParts;
480
- if (day === null) {
481
- return;
482
- }
483
- /**
484
- * Get the calendar day element
485
- * and focus it.
486
- */
487
- const dayEl = currentMonth.querySelector(`.calendar-day:nth-of-type(${padding.length + day})`);
488
- if (dayEl) {
489
- dayEl.focus();
490
- }
491
- };
492
- this.processMinParts = () => {
493
- if (this.min === undefined) {
494
- this.minParts = undefined;
495
- return;
496
- }
497
- const { month, day, year, hour, minute } = parseDate(this.min);
498
- this.minParts = {
499
- month,
500
- day,
501
- year,
502
- hour,
503
- minute,
504
- };
505
- };
506
- this.processMaxParts = () => {
507
- if (this.max === undefined) {
508
- this.maxParts = undefined;
509
- return;
510
- }
511
- const { month, day, year, hour, minute } = parseDate(this.max);
512
- this.maxParts = {
513
- month,
514
- day,
515
- year,
516
- hour,
517
- minute,
518
- };
519
- };
520
- this.initializeCalendarListener = () => {
521
- const calendarBodyRef = this.getCalendarBodyEl();
522
- if (!calendarBodyRef) {
523
- return;
524
- }
525
- /**
526
- * For performance reasons, we only render 3
527
- * months at a time: The current month, the previous
528
- * month, and the next month. We have a scroll listener
529
- * on the calendar body to append/prepend new months.
530
- *
531
- * We can do this because Stencil is smart enough to not
532
- * re-create the .calendar-month containers, but rather
533
- * update the content within those containers.
534
- *
535
- * As an added bonus, WebKit has some troubles with
536
- * scroll-snap-stop: always, so not rendering all of
537
- * the months in a row allows us to mostly sidestep
538
- * that issue.
539
- */
540
- const months = calendarBodyRef.querySelectorAll('.calendar-month');
541
- const startMonth = months[0];
542
- const workingMonth = months[1];
543
- const endMonth = months[2];
544
- const mode = getIonMode(this);
545
- const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
546
- /**
547
- * Before setting up the scroll listener,
548
- * scroll the middle month into view.
549
- * scrollIntoView() will scroll entire page
550
- * if element is not in viewport. Use scrollLeft instead.
551
- */
552
- writeTask(() => {
553
- calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
554
- const getChangedMonth = (parts) => {
555
- const box = calendarBodyRef.getBoundingClientRect();
556
- const root = this.el.shadowRoot;
557
- /**
558
- * Get the element that is in the center of the calendar body.
559
- * This will be an element inside of the active month.
560
- */
561
- const elementAtCenter = root.elementFromPoint(box.x + box.width / 2, box.y + box.height / 2);
562
- /**
563
- * If there is no element then the
564
- * component may be re-rendering on a slow device.
565
- */
566
- if (!elementAtCenter)
567
- return;
568
- const month = elementAtCenter.closest('.calendar-month');
569
- if (!month)
570
- return;
571
- /**
572
- * The edge of the month must be lined up with
573
- * the edge of the calendar body in order for
574
- * the component to update. Otherwise, it
575
- * may be the case that the user has paused their
576
- * swipe or the browser has not finished snapping yet.
577
- * Rather than check if the x values are equal,
578
- * we give it a tolerance of 2px to account for
579
- * sub pixel rendering.
580
- */
581
- const monthBox = month.getBoundingClientRect();
582
- if (Math.abs(monthBox.x - box.x) > 2)
583
- return;
584
- /**
585
- * From here, we can determine if the start
586
- * month or the end month was scrolled into view.
587
- * If no month was changed, then we can return from
588
- * the scroll callback early.
589
- */
590
- if (month === startMonth) {
591
- return getPreviousMonth(parts);
592
- }
593
- else if (month === endMonth) {
594
- return getNextMonth(parts);
595
- }
596
- else {
597
- return;
598
- }
599
- };
600
- const updateActiveMonth = () => {
601
- if (needsiOSRubberBandFix) {
602
- calendarBodyRef.style.removeProperty('pointer-events');
603
- appliediOSRubberBandFix = false;
604
- }
605
- /**
606
- * If the month did not change
607
- * then we can return early.
608
- */
609
- const newDate = getChangedMonth(this.workingParts);
610
- if (!newDate)
611
- return;
612
- const { month, day, year } = newDate;
613
- if (isMonthDisabled({ month, year, day: null }, {
614
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
615
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
616
- })) {
617
- return;
618
- }
619
- /**
620
- * Prevent scrolling for other browsers
621
- * to give the DOM time to update and the container
622
- * time to properly snap.
623
- */
624
- calendarBodyRef.style.setProperty('overflow', 'hidden');
625
- /**
626
- * Use a writeTask here to ensure
627
- * that the state is updated and the
628
- * correct month is scrolled into view
629
- * in the same frame. This is not
630
- * typically a problem on newer devices
631
- * but older/slower device may have a flicker
632
- * if we did not do this.
633
- */
634
- writeTask(() => {
635
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
636
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
637
- calendarBodyRef.style.removeProperty('overflow');
638
- });
639
- };
640
- /**
641
- * When the container finishes scrolling we
642
- * need to update the DOM with the selected month.
643
- */
644
- let scrollTimeout;
645
- /**
646
- * We do not want to attempt to set pointer-events
647
- * multiple times within a single swipe gesture as
648
- * that adds unnecessary work to the main thread.
649
- */
650
- let appliediOSRubberBandFix = false;
651
- const scrollCallback = () => {
652
- if (scrollTimeout) {
653
- clearTimeout(scrollTimeout);
654
- }
655
- /**
656
- * On iOS it is possible to quickly rubber band
657
- * the scroll area before the scroll timeout has fired.
658
- * This results in users reaching the end of the scrollable
659
- * container before the DOM has updated.
660
- * By setting `pointer-events: none` we can ensure that
661
- * subsequent swipes do not happen while the container
662
- * is snapping.
663
- */
664
- if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
665
- calendarBodyRef.style.setProperty('pointer-events', 'none');
666
- appliediOSRubberBandFix = true;
667
- }
668
- // Wait ~3 frames
669
- scrollTimeout = setTimeout(updateActiveMonth, 50);
670
- };
671
- calendarBodyRef.addEventListener('scroll', scrollCallback);
672
- this.destroyCalendarListener = () => {
673
- calendarBodyRef.removeEventListener('scroll', scrollCallback);
674
- };
675
- });
676
- };
677
- /**
678
- * Clean up all listeners except for the overlay
679
- * listener. This is so that we can re-create the listeners
680
- * if the datetime has been hidden/presented by a modal or popover.
681
- */
682
- this.destroyInteractionListeners = () => {
683
- const { destroyCalendarListener, destroyKeyboardMO } = this;
684
- if (destroyCalendarListener !== undefined) {
685
- destroyCalendarListener();
686
- }
687
- if (destroyKeyboardMO !== undefined) {
688
- destroyKeyboardMO();
689
- }
690
- };
691
- this.processValue = (value) => {
692
- this.highlightActiveParts = !!value;
693
- let valueToProcess = parseDate(value || getToday());
694
- const { minParts, maxParts, multiple } = this;
695
- if (!multiple && Array.isArray(value)) {
696
- this.value = value[0];
697
- valueToProcess = valueToProcess[0];
698
- }
699
- warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
700
- /**
701
- * If there are multiple values, pick an arbitrary one to clamp to. This way,
702
- * if the values are across months, we always show at least one of them. Note
703
- * that the values don't necessarily have to be in order.
704
- */
705
- const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
706
- const { month, day, year, hour, minute, tzOffset } = clampDate(singleValue, minParts, maxParts);
707
- const ampm = parseAmPm(hour);
708
- this.setWorkingParts({
709
- month,
710
- day,
711
- year,
712
- hour,
713
- minute,
714
- tzOffset,
715
- ampm,
716
- });
717
- if (Array.isArray(valueToProcess)) {
718
- this.activeParts = [...valueToProcess];
719
- }
720
- else {
721
- this.activeParts = {
722
- month,
723
- day,
724
- year,
725
- hour,
726
- minute,
727
- tzOffset,
728
- ampm,
729
- };
730
- }
731
- };
732
- this.onFocus = () => {
733
- this.ionFocus.emit();
734
- };
735
- this.onBlur = () => {
736
- this.ionBlur.emit();
737
- };
738
- this.hasValue = () => {
739
- return this.value != null && this.value !== '';
740
- };
741
- this.nextMonth = () => {
742
- const calendarBodyRef = this.getCalendarBodyEl();
743
- if (!calendarBodyRef) {
744
- return;
745
- }
746
- const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
747
- if (!nextMonth) {
748
- return;
749
- }
750
- const left = nextMonth.offsetWidth * 2;
751
- calendarBodyRef.scrollTo({
752
- top: 0,
753
- left: left * (isRTL(this.el) ? -1 : 1),
754
- behavior: 'smooth',
755
- });
756
- };
757
- this.prevMonth = () => {
758
- const calendarBodyRef = this.getCalendarBodyEl();
759
- if (!calendarBodyRef) {
760
- return;
761
- }
762
- const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
763
- if (!prevMonth) {
764
- return;
765
- }
766
- calendarBodyRef.scrollTo({
767
- top: 0,
768
- left: 0,
769
- behavior: 'smooth',
770
- });
771
- };
772
- this.toggleMonthAndYearView = () => {
773
- this.showMonthAndYear = !this.showMonthAndYear;
774
- };
775
- }
776
- disabledChanged() {
777
- this.emitStyle();
778
- }
779
- minChanged() {
780
- this.processMinParts();
781
- }
782
- maxChanged() {
783
- this.processMaxParts();
784
- }
785
- yearValuesChanged() {
786
- this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
787
- }
788
- monthValuesChanged() {
789
- this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
790
- }
791
- dayValuesChanged() {
792
- this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
793
- }
794
- hourValuesChanged() {
795
- this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
796
- }
797
- minuteValuesChanged() {
798
- this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
799
- }
800
- activePartsChanged() {
801
- this.activePartsClone = this.activeParts;
802
- }
803
- /**
804
- * Update the datetime value when the value changes
805
- */
806
- valueChanged() {
807
- const { value, minParts, maxParts, workingParts, multiple } = this;
808
- if (this.hasValue()) {
809
- if (!multiple && Array.isArray(value)) {
810
- this.value = value[0];
811
- return; // setting this.value will trigger re-run of this function
812
- }
813
- /**
814
- * Clones the value of the `activeParts` to the private clone, to update
815
- * the date display on the current render cycle without causing another render.
816
- *
817
- * This allows us to update the current value's date/time display without
818
- * refocusing or shifting the user's display (leaves the user in place).
819
- */
820
- const valueDateParts = parseDate(value);
821
- if (valueDateParts) {
822
- warnIfValueOutOfBounds(valueDateParts, minParts, maxParts);
823
- if (Array.isArray(valueDateParts)) {
824
- this.activePartsClone = [...valueDateParts];
825
- }
826
- else {
827
- const { month, day, year, hour, minute } = valueDateParts;
828
- const ampm = hour != null ? (hour >= 12 ? 'pm' : 'am') : undefined;
829
- this.activePartsClone = Object.assign(Object.assign({}, this.activeParts), { month,
830
- day,
831
- year,
832
- hour,
833
- minute,
834
- ampm });
835
- /**
836
- * The working parts am/pm value must be updated when the value changes, to
837
- * ensure the time picker hour column values are generated correctly.
838
- *
839
- * Note that we don't need to do this if valueDateParts is an array, since
840
- * multiple="true" does not apply to time pickers.
841
- */
842
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm }));
843
- }
844
- }
845
- else {
846
- printIonWarning(`Unable to parse date string: ${value}. Please provide a valid ISO 8601 datetime string.`);
847
- }
848
- }
849
- this.emitStyle();
850
- this.ionChange.emit({ value });
851
- }
852
- /**
853
- * Confirms the selected datetime value, updates the
854
- * `value` property, and optionally closes the popover
855
- * or modal that the datetime was presented in.
856
- */
857
- async confirm(closeOverlay = false) {
858
- const { highlightActiveParts, isCalendarPicker, activeParts } = this;
859
- /**
860
- * We only update the value if the presentation is not a calendar picker,
861
- * or if `highlightActiveParts` is true; indicating that the user
862
- * has selected a date from the calendar picker.
863
- *
864
- * Otherwise "today" would accidentally be set as the value.
865
- */
866
- if (highlightActiveParts || !isCalendarPicker) {
867
- const activePartsIsArray = Array.isArray(activeParts);
868
- if (activePartsIsArray && activeParts.length === 0) {
869
- this.value = undefined;
870
- }
871
- else {
872
- /**
873
- * Prevent convertDataToISO from doing any
874
- * kind of transformation based on timezone
875
- * This cancels out any change it attempts to make
876
- *
877
- * Important: Take the timezone offset based on
878
- * the date that is currently selected, otherwise
879
- * there can be 1 hr difference when dealing w/ DST
880
- */
881
- if (activePartsIsArray) {
882
- const dates = convertDataToISO(activeParts).map((str) => new Date(str));
883
- for (let i = 0; i < dates.length; i++) {
884
- activeParts[i].tzOffset = dates[i].getTimezoneOffset() * -1;
885
- }
886
- }
887
- else {
888
- const date = new Date(convertDataToISO(activeParts));
889
- activeParts.tzOffset = date.getTimezoneOffset() * -1;
890
- }
891
- this.value = convertDataToISO(activeParts);
892
- }
893
- }
894
- if (closeOverlay) {
895
- this.closeParentOverlay();
896
- }
897
- }
898
- /**
899
- * Resets the internal state of the datetime but does not update the value.
900
- * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
901
- * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
902
- */
903
- async reset(startDate) {
904
- this.processValue(startDate);
905
- }
906
- /**
907
- * Emits the ionCancel event and
908
- * optionally closes the popover
909
- * or modal that the datetime was
910
- * presented in.
911
- */
912
- async cancel(closeOverlay = false) {
913
- this.ionCancel.emit();
914
- if (closeOverlay) {
915
- this.closeParentOverlay();
916
- }
917
- }
918
- get isCalendarPicker() {
919
- const { presentation } = this;
920
- return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
921
- }
922
- connectedCallback() {
923
- this.clearFocusVisible = startFocusVisible(this.el).destroy;
924
- }
925
- disconnectedCallback() {
926
- if (this.clearFocusVisible) {
927
- this.clearFocusVisible();
928
- this.clearFocusVisible = undefined;
929
- }
930
- }
931
- initializeListeners() {
932
- this.initializeCalendarListener();
933
- this.initializeKeyboardListeners();
934
- }
935
- componentDidLoad() {
936
- /**
937
- * If a scrollable element is hidden using `display: none`,
938
- * it will not have a scroll height meaning we cannot scroll elements
939
- * into view. As a result, we will need to wait for the datetime to become
940
- * visible if used inside of a modal or a popover otherwise the scrollable
941
- * areas will not have the correct values snapped into place.
942
- */
943
- const visibleCallback = (entries) => {
944
- const ev = entries[0];
945
- if (!ev.isIntersecting) {
946
- return;
947
- }
948
- this.initializeListeners();
949
- /**
950
- * TODO: Datetime needs a frame to ensure that it
951
- * can properly scroll contents into view. As a result
952
- * we hide the scrollable content until after that frame
953
- * so users do not see the content quickly shifting. The downside
954
- * is that the content will pop into view a frame after. Maybe there
955
- * is a better way to handle this?
956
- */
957
- writeTask(() => {
958
- this.el.classList.add('datetime-ready');
959
- });
960
- };
961
- const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
962
- /**
963
- * Use raf to avoid a race condition between the component loading and
964
- * its display animation starting (such as when shown in a modal). This
965
- * could cause the datetime to start at a visibility of 0, erroneously
966
- * triggering the `hiddenIO` observer below.
967
- */
968
- raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
969
- /**
970
- * We need to clean up listeners when the datetime is hidden
971
- * in a popover/modal so that we can properly scroll containers
972
- * back into view if they are re-presented. When the datetime is hidden
973
- * the scroll areas have scroll widths/heights of 0px, so any snapping
974
- * we did originally has been lost.
975
- */
976
- const hiddenCallback = (entries) => {
977
- const ev = entries[0];
978
- if (ev.isIntersecting) {
979
- return;
980
- }
981
- this.destroyInteractionListeners();
982
- writeTask(() => {
983
- this.el.classList.remove('datetime-ready');
984
- });
985
- };
986
- const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
987
- raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
988
- /**
989
- * Datetime uses Ionic components that emit
990
- * ionFocus and ionBlur. These events are
991
- * composed meaning they will cross
992
- * the shadow dom boundary. We need to
993
- * stop propagation on these events otherwise
994
- * developers will see 2 ionFocus or 2 ionBlur
995
- * events at a time.
996
- */
997
- const root = getElementRoot(this.el);
998
- root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
999
- root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
1000
- }
1001
- /**
1002
- * When the presentation is changed, all calendar content is recreated,
1003
- * so we need to re-init behavior with the new elements.
1004
- */
1005
- componentDidRender() {
1006
- const { presentation, prevPresentation } = this;
1007
- if (prevPresentation === null) {
1008
- this.prevPresentation = presentation;
1009
- return;
1010
- }
1011
- if (presentation === prevPresentation) {
1012
- return;
1013
- }
1014
- this.prevPresentation = presentation;
1015
- this.destroyInteractionListeners();
1016
- this.initializeListeners();
1017
- /**
1018
- * The month/year picker from the date interface
1019
- * should be closed as it is not available in non-date
1020
- * interfaces.
1021
- */
1022
- this.showMonthAndYear = false;
1023
- raf(() => {
1024
- this.ionRender.emit();
1025
- });
1026
- }
1027
- componentWillLoad() {
1028
- const { el, multiple, presentation, preferWheel } = this;
1029
- if (multiple) {
1030
- if (presentation !== 'date') {
1031
- printIonWarning('Multiple date selection is only supported for presentation="date".', el);
1032
- }
1033
- if (preferWheel) {
1034
- printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
1035
- }
1036
- }
1037
- this.processMinParts();
1038
- this.processMaxParts();
1039
- this.processValue(this.value);
1040
- this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
1041
- this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
1042
- this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
1043
- this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
1044
- this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
1045
- this.emitStyle();
1046
- }
1047
- emitStyle() {
1048
- this.ionStyle.emit({
1049
- interactive: true,
1050
- datetime: true,
1051
- 'interactive-disabled': this.disabled,
1052
- });
1053
- }
1054
- /**
1055
- * Universal render methods
1056
- * These are pieces of datetime that
1057
- * are rendered independently of presentation.
1058
- */
1059
- renderFooter() {
1060
- const { showDefaultButtons, showClearButton } = this;
1061
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
1062
- if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
1063
- return;
1064
- }
1065
- const clearButtonClick = () => {
1066
- this.reset();
1067
- this.value = undefined;
1068
- };
1069
- /**
1070
- * By default we render two buttons:
1071
- * Cancel - Dismisses the datetime and
1072
- * does not update the `value` prop.
1073
- * OK - Dismisses the datetime and
1074
- * updates the `value` prop.
1075
- */
1076
- return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
1077
- ['datetime-action-buttons']: true,
1078
- ['has-clear-button']: this.showClearButton,
1079
- } }, h("slot", { name: "buttons" }, h("ion-buttons", null, showDefaultButtons && (h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true) }, this.cancelText)), h("div", null, showClearButton && (h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick() }, this.clearText)), showDefaultButtons && (h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true) }, this.doneText)))))))));
1080
- }
1081
- /**
1082
- * Wheel picker render methods
1083
- */
1084
- renderWheelPicker(forcePresentation = this.presentation) {
1085
- /**
1086
- * If presentation="time-date" we switch the
1087
- * order of the render array here instead of
1088
- * manually reordering each date/time picker
1089
- * column with CSS. This allows for additional
1090
- * flexibility if we need to render subsets
1091
- * of the date/time data or do additional ordering
1092
- * within the child render functions.
1093
- */
1094
- const renderArray = forcePresentation === 'time-date'
1095
- ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
1096
- : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
1097
- return h("ion-picker-internal", null, renderArray);
1098
- }
1099
- renderDatePickerColumns(forcePresentation) {
1100
- return forcePresentation === 'date-time' || forcePresentation === 'time-date'
1101
- ? this.renderCombinedDatePickerColumn()
1102
- : this.renderIndividualDatePickerColumns(forcePresentation);
1103
- }
1104
- renderCombinedDatePickerColumn() {
1105
- const { activeParts, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
1106
- /**
1107
- * By default, generate a range of 3 months:
1108
- * Previous month, current month, and next month
1109
- */
1110
- const monthsToRender = generateMonths(workingParts);
1111
- /**
1112
- * generateMonths returns the day data as well,
1113
- * but we do not want the day value to act as a max/min
1114
- * on the data we are going to generate.
1115
- */
1116
- for (let i = 0; i <= monthsToRender.length - 1; i++) {
1117
- monthsToRender[i].day = null;
1118
- }
1119
- /**
1120
- * If developers have provided their own
1121
- * min/max values, use that instead. Otherwise,
1122
- * fallback to the default range of 3 months.
1123
- */
1124
- const min = minParts || monthsToRender[0];
1125
- const max = maxParts || monthsToRender[monthsToRender.length - 1];
1126
- const result = getCombinedDateColumnData(locale, workingParts, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
1127
- let items = result.items;
1128
- const parts = result.parts;
1129
- if (isDateEnabled) {
1130
- items = items.map((itemObject, index) => {
1131
- const referenceParts = parts[index];
1132
- let disabled;
1133
- try {
1134
- /**
1135
- * The `isDateEnabled` implementation is try-catch wrapped
1136
- * to prevent exceptions in the user's function from
1137
- * interrupting the calendar rendering.
1138
- */
1139
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1140
- }
1141
- catch (e) {
1142
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1143
- }
1144
- return Object.assign(Object.assign({}, itemObject), { disabled });
1145
- });
1146
- }
1147
- /**
1148
- * If we have selected a day already, then default the column
1149
- * to that value. Otherwise, default it to today.
1150
- */
1151
- const todayString = workingParts.day
1152
- ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1153
- : `${todayParts.year}-${todayParts.month}-${todayParts.day}`;
1154
- return (h("ion-picker-column-internal", { class: "date-column", color: this.color, items: items, value: todayString, onIonChange: (ev) => {
1155
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1156
- // Due to a Safari 14 issue we need to destroy
1157
- // the scroll listener before we update state
1158
- // and trigger a re-render.
1159
- if (this.destroyCalendarListener) {
1160
- this.destroyCalendarListener();
1161
- }
1162
- const { value } = ev.detail;
1163
- const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1164
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1165
- if (!Array.isArray(activeParts)) {
1166
- this.setActiveParts(Object.assign(Object.assign({}, activeParts), findPart));
1167
- }
1168
- // We can re-attach the scroll listener after
1169
- // the working parts have been updated.
1170
- this.initializeCalendarListener();
1171
- ev.stopPropagation();
1172
- } }));
1173
- }
1174
- renderIndividualDatePickerColumns(forcePresentation) {
1175
- const { workingParts, isDateEnabled } = this;
1176
- const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1177
- const months = shouldRenderMonths
1178
- ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1179
- : [];
1180
- const shouldRenderDays = forcePresentation === 'date';
1181
- let days = shouldRenderDays
1182
- ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1183
- : [];
1184
- if (isDateEnabled) {
1185
- days = days.map((dayObject) => {
1186
- const { value } = dayObject;
1187
- const valueNum = typeof value === 'string' ? parseInt(value) : value;
1188
- const referenceParts = {
1189
- month: workingParts.month,
1190
- day: valueNum,
1191
- year: workingParts.year,
1192
- };
1193
- let disabled;
1194
- try {
1195
- /**
1196
- * The `isDateEnabled` implementation is try-catch wrapped
1197
- * to prevent exceptions in the user's function from
1198
- * interrupting the calendar rendering.
1199
- */
1200
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1201
- }
1202
- catch (e) {
1203
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1204
- }
1205
- return Object.assign(Object.assign({}, dayObject), { disabled });
1206
- });
1207
- }
1208
- const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1209
- const years = shouldRenderYears
1210
- ? getYearColumnData(this.todayParts, this.minParts, this.maxParts, this.parsedYearValues)
1211
- : [];
1212
- /**
1213
- * Certain locales show the day before the month.
1214
- */
1215
- const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1216
- let renderArray = [];
1217
- if (showMonthFirst) {
1218
- renderArray = [
1219
- this.renderMonthPickerColumn(months),
1220
- this.renderDayPickerColumn(days),
1221
- this.renderYearPickerColumn(years),
1222
- ];
1223
- }
1224
- else {
1225
- renderArray = [
1226
- this.renderDayPickerColumn(days),
1227
- this.renderMonthPickerColumn(months),
1228
- this.renderYearPickerColumn(years),
1229
- ];
1230
- }
1231
- return renderArray;
1232
- }
1233
- renderDayPickerColumn(days) {
1234
- var _a;
1235
- if (days.length === 0) {
1236
- return [];
1237
- }
1238
- const { activeParts, workingParts } = this;
1239
- return (h("ion-picker-column-internal", { class: "day-column", color: this.color, items: days, value: (_a = (workingParts.day || this.todayParts.day)) !== null && _a !== void 0 ? _a : undefined, onIonChange: (ev) => {
1240
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1241
- // Due to a Safari 14 issue we need to destroy
1242
- // the scroll listener before we update state
1243
- // and trigger a re-render.
1244
- if (this.destroyCalendarListener) {
1245
- this.destroyCalendarListener();
1246
- }
1247
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1248
- if (!Array.isArray(activeParts)) {
1249
- this.setActiveParts(Object.assign(Object.assign({}, activeParts), { day: ev.detail.value }));
1250
- }
1251
- // We can re-attach the scroll listener after
1252
- // the working parts have been updated.
1253
- this.initializeCalendarListener();
1254
- ev.stopPropagation();
1255
- } }));
1256
- }
1257
- renderMonthPickerColumn(months) {
1258
- if (months.length === 0) {
1259
- return [];
1260
- }
1261
- const { activeParts, workingParts } = this;
1262
- return (h("ion-picker-column-internal", { class: "month-column", color: this.color, items: months, value: workingParts.month, onIonChange: (ev) => {
1263
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1264
- // Due to a Safari 14 issue we need to destroy
1265
- // the scroll listener before we update state
1266
- // and trigger a re-render.
1267
- if (this.destroyCalendarListener) {
1268
- this.destroyCalendarListener();
1269
- }
1270
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1271
- if (!Array.isArray(activeParts)) {
1272
- this.setActiveParts(Object.assign(Object.assign({}, activeParts), { month: ev.detail.value }));
1273
- }
1274
- // We can re-attach the scroll listener after
1275
- // the working parts have been updated.
1276
- this.initializeCalendarListener();
1277
- ev.stopPropagation();
1278
- } }));
1279
- }
1280
- renderYearPickerColumn(years) {
1281
- if (years.length === 0) {
1282
- return [];
1283
- }
1284
- const { activeParts, workingParts } = this;
1285
- return (h("ion-picker-column-internal", { class: "year-column", color: this.color, items: years, value: workingParts.year, onIonChange: (ev) => {
1286
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1287
- // Due to a Safari 14 issue we need to destroy
1288
- // the scroll listener before we update state
1289
- // and trigger a re-render.
1290
- if (this.destroyCalendarListener) {
1291
- this.destroyCalendarListener();
1292
- }
1293
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1294
- if (!Array.isArray(activeParts)) {
1295
- this.setActiveParts(Object.assign(Object.assign({}, activeParts), { year: ev.detail.value }));
1296
- }
1297
- // We can re-attach the scroll listener after
1298
- // the working parts have been updated.
1299
- this.initializeCalendarListener();
1300
- ev.stopPropagation();
1301
- } }));
1302
- }
1303
- renderTimePickerColumns(forcePresentation) {
1304
- if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1305
- return [];
1306
- }
1307
- const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, this.value ? this.minParts : undefined, this.value ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1308
- return [
1309
- this.renderHourPickerColumn(hoursData),
1310
- this.renderMinutePickerColumn(minutesData),
1311
- this.renderDayPeriodPickerColumn(dayPeriodData),
1312
- ];
1313
- }
1314
- renderHourPickerColumn(hoursData) {
1315
- const { workingParts, activePartsClone } = this;
1316
- if (hoursData.length === 0)
1317
- return [];
1318
- return (h("ion-picker-column-internal", { color: this.color, value: activePartsClone.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1319
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1320
- if (!Array.isArray(activePartsClone)) {
1321
- this.setActiveParts(Object.assign(Object.assign({}, activePartsClone), { hour: ev.detail.value }));
1322
- }
1323
- ev.stopPropagation();
1324
- } }));
1325
- }
1326
- renderMinutePickerColumn(minutesData) {
1327
- const { workingParts, activePartsClone } = this;
1328
- if (minutesData.length === 0)
1329
- return [];
1330
- return (h("ion-picker-column-internal", { color: this.color, value: activePartsClone.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1331
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1332
- if (!Array.isArray(activePartsClone)) {
1333
- this.setActiveParts(Object.assign(Object.assign({}, activePartsClone), { minute: ev.detail.value }));
1334
- }
1335
- ev.stopPropagation();
1336
- } }));
1337
- }
1338
- renderDayPeriodPickerColumn(dayPeriodData) {
1339
- const { workingParts, activePartsClone } = this;
1340
- if (dayPeriodData.length === 0) {
1341
- return [];
1342
- }
1343
- const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1344
- return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, value: activePartsClone.ampm, items: dayPeriodData, onIonChange: (ev) => {
1345
- const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1346
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1347
- if (!Array.isArray(activePartsClone)) {
1348
- this.setActiveParts(Object.assign(Object.assign({}, activePartsClone), { ampm: ev.detail.value, hour }));
1349
- }
1350
- ev.stopPropagation();
1351
- } }));
1352
- }
1353
- renderWheelView(forcePresentation) {
1354
- const { locale } = this;
1355
- const showMonthFirst = isMonthFirstLocale(locale);
1356
- const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1357
- return (h("div", { class: {
1358
- [`wheel-order-${columnOrder}`]: true,
1359
- } }, this.renderWheelPicker(forcePresentation)));
1360
- }
1361
- /**
1362
- * Grid Render Methods
1363
- */
1364
- renderCalendarHeader(mode) {
1365
- const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1366
- const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1367
- const prevMonthDisabled = isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1368
- const nextMonthDisabled = isNextMonthDisabled(this.workingParts, this.maxParts);
1369
- return (h("div", { class: "calendar-header" }, h("div", { class: "calendar-action-buttons" }, h("div", { class: "calendar-month-year" }, h("ion-item", { button: true, detail: false, lines: "none", onClick: () => this.toggleMonthAndYearView() }, h("ion-label", null, getMonthAndYear(this.locale, this.workingParts), ' ', h("ion-icon", { icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false })))), h("div", { class: "calendar-next-prev" }, h("ion-buttons", null, h("ion-button", { disabled: prevMonthDisabled, onClick: () => this.prevMonth() }, h("ion-icon", { slot: "icon-only", icon: chevronBack, lazy: false, flipRtl: true })), h("ion-button", { disabled: nextMonthDisabled, onClick: () => this.nextMonth() }, h("ion-icon", { slot: "icon-only", icon: chevronForward, lazy: false, flipRtl: true }))))), h("div", { class: "calendar-days-of-week" }, getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
1370
- return h("div", { class: "day-of-week" }, d);
1371
- }))));
1372
- }
1373
- renderMonth(month, year) {
1374
- const { highlightActiveParts } = this;
1375
- const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1376
- const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1377
- const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1378
- const swipeDisabled = isMonthDisabled({
1379
- month,
1380
- year,
1381
- day: null,
1382
- }, {
1383
- // The day is not used when checking if a month is disabled.
1384
- // Users should be able to access the min or max month, even if the
1385
- // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1386
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1387
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1388
- });
1389
- // The working month should never have swipe disabled.
1390
- // Otherwise the CSS scroll snap will not work and the user
1391
- // can free-scroll the calendar.
1392
- const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1393
- return (h("div", { class: {
1394
- 'calendar-month': true,
1395
- // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1396
- 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1397
- } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1398
- const { day, dayOfWeek } = dateObject;
1399
- const { isDateEnabled, multiple } = this;
1400
- const referenceParts = { month, day, year };
1401
- const { isActive, isToday, ariaLabel, ariaSelected, disabled } = getCalendarDayState(this.locale, referenceParts, this.activePartsClone, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1402
- let isCalDayDisabled = isCalMonthDisabled || disabled;
1403
- if (!isCalDayDisabled && isDateEnabled !== undefined) {
1404
- try {
1405
- /**
1406
- * The `isDateEnabled` implementation is try-catch wrapped
1407
- * to prevent exceptions in the user's function from
1408
- * interrupting the calendar rendering.
1409
- */
1410
- isCalDayDisabled = !isDateEnabled(convertDataToISO(referenceParts));
1411
- }
1412
- catch (e) {
1413
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1414
- }
1415
- }
1416
- return (h("button", { tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isCalDayDisabled, class: {
1417
- 'calendar-day-padding': day === null,
1418
- 'calendar-day': true,
1419
- 'calendar-day-active': isActive && highlightActiveParts,
1420
- 'calendar-day-today': isToday,
1421
- }, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1422
- if (day === null) {
1423
- return;
1424
- }
1425
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1426
- day,
1427
- year }));
1428
- // multiple only needs date info, so we can wipe out other fields like time
1429
- if (multiple) {
1430
- this.setActiveParts({
1431
- month,
1432
- day,
1433
- year,
1434
- }, isActive && highlightActiveParts);
1435
- }
1436
- else {
1437
- this.setActiveParts(Object.assign(Object.assign({}, this.activeParts), { month,
1438
- day,
1439
- year }));
1440
- }
1441
- } }, day));
1442
- }))));
1443
- }
1444
- renderCalendarBody() {
1445
- return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts).map(({ month, year }) => {
1446
- return this.renderMonth(month, year);
1447
- })));
1448
- }
1449
- renderCalendar(mode) {
1450
- return (h("div", { class: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1451
- }
1452
- renderTimeLabel() {
1453
- const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1454
- if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1455
- return;
1456
- }
1457
- return h("slot", { name: "time-label" }, "Time");
1458
- }
1459
- renderTimeOverlay() {
1460
- const use24Hour = is24Hour(this.locale, this.hourCycle);
1461
- return [
1462
- h("div", { class: "time-header" }, this.renderTimeLabel()),
1463
- h("button", { class: {
1464
- 'time-body': true,
1465
- 'time-body-active': this.isTimePopoverOpen,
1466
- }, "aria-expanded": "false", "aria-haspopup": "true", onClick: async (ev) => {
1467
- const { popoverRef } = this;
1468
- if (popoverRef) {
1469
- this.isTimePopoverOpen = true;
1470
- popoverRef.present(new CustomEvent('ionShadowTarget', {
1471
- detail: {
1472
- ionShadowTarget: ev.target,
1473
- },
1474
- }));
1475
- await popoverRef.onWillDismiss();
1476
- this.isTimePopoverOpen = false;
1477
- }
1478
- } }, getLocalizedTime(this.locale, this.activePartsClone, use24Hour)),
1479
- h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1480
- /**
1481
- * Intersection Observers do not consistently fire between Blink and Webkit
1482
- * when toggling the visibility of the popover and trying to scroll the picker
1483
- * column to the correct time value.
1484
- *
1485
- * This will correctly scroll the element position to the correct time value,
1486
- * before the popover is fully presented.
1487
- */
1488
- const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1489
- // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1490
- cols.forEach((col) => col.scrollActiveItemIntoView());
1491
- }, style: {
1492
- '--offset-y': '-10px',
1493
- '--min-width': 'fit-content',
1494
- },
1495
- // Allow native browser keyboard events to support up/down/home/end key
1496
- // navigation within the time picker.
1497
- keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1498
- ];
1499
- }
1500
- renderCalendarViewHeader(mode) {
1501
- const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1502
- if (!hasSlottedTitle && !this.showDefaultTitle) {
1503
- return;
1504
- }
1505
- return (h("div", { class: "datetime-header" }, h("div", { class: "datetime-title" }, h("slot", { name: "title" }, "Select Date")), mode === 'md' && !this.multiple && (h("div", { class: "datetime-selected-date" }, getMonthAndDay(this.locale, this.activeParts)))));
1506
- }
1507
- /**
1508
- * Render time picker inside of datetime.
1509
- * Do not pass color prop to segment on
1510
- * iOS mode. MD segment has been customized and
1511
- * should take on the color prop, but iOS
1512
- * should just be the default segment.
1513
- */
1514
- renderTime() {
1515
- const { presentation } = this;
1516
- const timeOnlyPresentation = presentation === 'time';
1517
- return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1518
- }
1519
- /**
1520
- * Renders the month/year picker that is
1521
- * displayed on the calendar grid.
1522
- * The .datetime-year class has additional
1523
- * styles that let us show/hide the
1524
- * picker when the user clicks on the
1525
- * toggle in the calendar header.
1526
- */
1527
- renderCalendarViewMonthYearPicker() {
1528
- return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1529
- }
1530
- /**
1531
- * Render entry point
1532
- * All presentation types are rendered from here.
1533
- */
1534
- renderDatetime(mode) {
1535
- const { presentation, preferWheel } = this;
1536
- /**
1537
- * Certain presentation types have separate grid and wheel displays.
1538
- * If preferWheel is true then we should show a wheel picker instead.
1539
- */
1540
- const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1541
- if (preferWheel && hasWheelVariant) {
1542
- return [this.renderWheelView(), this.renderFooter()];
1543
- }
1544
- switch (presentation) {
1545
- case 'date-time':
1546
- return [
1547
- this.renderCalendarViewHeader(mode),
1548
- this.renderCalendar(mode),
1549
- this.renderCalendarViewMonthYearPicker(),
1550
- this.renderTime(),
1551
- this.renderFooter(),
1552
- ];
1553
- case 'time-date':
1554
- return [
1555
- this.renderCalendarViewHeader(mode),
1556
- this.renderTime(),
1557
- this.renderCalendar(mode),
1558
- this.renderCalendarViewMonthYearPicker(),
1559
- this.renderFooter(),
1560
- ];
1561
- case 'time':
1562
- return [this.renderTime(), this.renderFooter()];
1563
- case 'month':
1564
- case 'month-year':
1565
- case 'year':
1566
- return [this.renderWheelView(), this.renderFooter()];
1567
- default:
1568
- return [
1569
- this.renderCalendarViewHeader(mode),
1570
- this.renderCalendar(mode),
1571
- this.renderCalendarViewMonthYearPicker(),
1572
- this.renderFooter(),
1573
- ];
1574
- }
1575
- }
1576
- render() {
1577
- const { name, value, disabled, el, color, isPresented, readonly, showMonthAndYear, preferWheel, presentation, size, } = this;
1578
- const mode = getIonMode(this);
1579
- const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1580
- const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1581
- const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1582
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1583
- const hasWheelVariant = hasDatePresentation && preferWheel;
1584
- const hasGrid = hasDatePresentation && !preferWheel;
1585
- renderHiddenInput(true, el, name, formatValue(value), disabled);
1586
- return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1587
- [mode]: true,
1588
- ['datetime-presented']: isPresented,
1589
- ['datetime-readonly']: readonly,
1590
- ['datetime-disabled']: disabled,
1591
- 'show-month-and-year': shouldShowMonthAndYear,
1592
- 'month-year-picker-open': monthYearPickerOpen,
1593
- [`datetime-presentation-${presentation}`]: true,
1594
- [`datetime-size-${size}`]: true,
1595
- [`datetime-prefer-wheel`]: hasWheelVariant,
1596
- [`datetime-grid`]: hasGrid,
1597
- })) }, this.renderDatetime(mode)));
1598
- }
1599
- get el() { return getElement(this); }
1600
- static get watchers() { return {
1601
- "disabled": ["disabledChanged"],
1602
- "min": ["minChanged"],
1603
- "max": ["maxChanged"],
1604
- "yearValues": ["yearValuesChanged"],
1605
- "monthValues": ["monthValuesChanged"],
1606
- "dayValues": ["dayValuesChanged"],
1607
- "hourValues": ["hourValuesChanged"],
1608
- "minuteValues": ["minuteValuesChanged"],
1609
- "activeParts": ["activePartsChanged"],
1610
- "value": ["valueChanged"]
1611
- }; }
1612
- };
1613
- let datetimeIds = 0;
1614
- Datetime.style = {
1615
- ios: datetimeIosCss,
1616
- md: datetimeMdCss
1617
- };
1618
-
1619
- export { Datetime as ion_datetime };