@sparkle-learning/core 0.0.35 → 0.0.36

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 (407) hide show
  1. package/dist/cjs/{auth.service-4b584cd7.js → PrivateRoute-074c584e.js} +30 -0
  2. package/dist/cjs/{sparkle-export-lessons_6.cjs.entry.js → header-mobile-collapse_61.cjs.entry.js} +11600 -2714
  3. package/dist/cjs/index.cjs.js +5 -6
  4. package/dist/cjs/ion-card-title.cjs.entry.js +30 -0
  5. package/dist/cjs/ion-textarea.cjs.entry.js +248 -0
  6. package/dist/cjs/ion-toggle.cjs.entry.js +177 -0
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/cjs/sparkle-core.cjs.js +1 -1
  9. package/dist/cjs/sparkle-feed-post.cjs.entry.js +120 -0
  10. package/dist/cjs/sparkle-feedback.cjs.entry.js +1 -2
  11. package/dist/cjs/sparkle-quiz-v1.cjs.entry.js +105 -0
  12. package/dist/cjs/sparkle-quiz.cjs.entry.js +54 -40
  13. package/dist/cjs/student.service-2e58f237.js +78 -0
  14. package/dist/collection/collection-manifest.json +2 -1
  15. package/dist/collection/components/sparkle-quiz/{sparkle-quiz.css → sparkle-quiz/sparkle-quiz.css} +0 -0
  16. package/dist/collection/components/sparkle-quiz/sparkle-quiz/sparkle-quiz.js +326 -0
  17. package/dist/collection/components/sparkle-quiz/sparkle-quiz-v1.css +48 -0
  18. package/dist/collection/components/sparkle-quiz/{sparkle-quiz.js → sparkle-quiz-v1.js} +4 -4
  19. package/dist/esm/{auth.service-79389d86.js → PrivateRoute-c5441f35.js} +33 -4
  20. package/dist/esm/{active-router-9843e205.js → active-router-fc9e4e06.js} +1 -1
  21. package/dist/esm/{animation-d98d3e81.js → animation-12377cb3.js} +1 -1
  22. package/dist/esm/{app-globals-08edc964.js → app-globals-3f0347b0.js} +1 -1
  23. package/dist/esm/{auth.store-b812b34b.js → auth.store-dba2c2da.js} +2 -2
  24. package/dist/esm/compass-svg.entry.js +1 -1
  25. package/dist/esm/context-consumer.entry.js +1 -1
  26. package/dist/esm/course-select.entry.js +1 -1
  27. package/dist/esm/{facilitator.service-7babc526.js → facilitator.service-b0292f7f.js} +2 -2
  28. package/dist/esm/{feed.service-80fbe79d.js → feed.service-8fbe4ce3.js} +3 -3
  29. package/dist/esm/{framework-delegate-9b329182.js → framework-delegate-3e634a5c.js} +1 -1
  30. package/dist/esm/{haptic-3a76a65c.js → haptic-522f76f2.js} +1 -1
  31. package/dist/esm/{sparkle-export-lessons_6.entry.js → header-mobile-collapse_61.entry.js} +11501 -2670
  32. package/dist/esm/{helpers-94a5855b.js → helpers-bf0e23d6.js} +1 -1
  33. package/dist/esm/{httpService-b2b7a1ad.js → httpService-7b75b095.js} +2 -2
  34. package/dist/esm/{icons-16f1a80b.js → icons-9b62a1ec.js} +2 -2
  35. package/dist/esm/{index-478745be.js → index-2b84cad2.js} +4 -4
  36. package/dist/esm/{index-4ec6b9c2.js → index-4044fde9.js} +1 -1
  37. package/dist/esm/{index-230a26c9.js → index-45fec1e7.js} +1 -1
  38. package/dist/esm/{index-c23a1826.js → index-5e8971ae.js} +2 -2
  39. package/dist/esm/{index-9db08224.js → index-c04b9ed5.js} +1 -1
  40. package/dist/esm/{index-95307148.js → index-cded2d87.js} +3 -3
  41. package/dist/esm/{index.es-1c3b1ef3.js → index.es-e0c0f891.js} +2 -2
  42. package/dist/esm/index.js +7 -8
  43. package/dist/esm/{input-shims-ce5c01df.js → input-shims-671d8d9f.js} +2 -2
  44. package/dist/esm/ion-accordion-group.entry.js +2 -2
  45. package/dist/esm/ion-accordion.entry.js +4 -4
  46. package/dist/esm/ion-action-sheet_4.entry.js +8 -8
  47. package/dist/esm/ion-app.entry.js +5 -5
  48. package/dist/esm/ion-back-button.entry.js +4 -4
  49. package/dist/esm/ion-backdrop.entry.js +2 -2
  50. package/dist/esm/ion-badge.entry.js +2 -2
  51. package/dist/esm/ion-breadcrumb.entry.js +4 -4
  52. package/dist/esm/ion-breadcrumbs.entry.js +2 -2
  53. package/dist/esm/ion-buttons_3.entry.js +2 -2
  54. package/dist/esm/ion-card-header.entry.js +2 -2
  55. package/dist/esm/ion-card-subtitle.entry.js +2 -2
  56. package/dist/esm/ion-card-title.entry.js +26 -0
  57. package/dist/esm/ion-chip.entry.js +2 -2
  58. package/dist/esm/ion-content_2.entry.js +4 -4
  59. package/dist/esm/ion-datetime-button.entry.js +3 -3
  60. package/dist/esm/ion-datetime.entry.js +4 -4
  61. package/dist/esm/ion-fab-button.entry.js +4 -4
  62. package/dist/esm/ion-fab-list.entry.js +2 -2
  63. package/dist/esm/ion-fab.entry.js +2 -2
  64. package/dist/esm/ion-footer.entry.js +4 -4
  65. package/dist/esm/ion-img.entry.js +3 -3
  66. package/dist/esm/ion-infinite-scroll-content.entry.js +2 -2
  67. package/dist/esm/ion-infinite-scroll.entry.js +4 -4
  68. package/dist/esm/ion-item-divider.entry.js +2 -2
  69. package/dist/esm/ion-item-group.entry.js +2 -2
  70. package/dist/esm/ion-item-option.entry.js +2 -2
  71. package/dist/esm/ion-item-options.entry.js +3 -3
  72. package/dist/esm/ion-item-sliding.entry.js +4 -4
  73. package/dist/esm/ion-loading.entry.js +5 -5
  74. package/dist/esm/ion-menu-button.entry.js +7 -7
  75. package/dist/esm/ion-menu-toggle.entry.js +6 -6
  76. package/dist/esm/ion-menu.entry.js +6 -6
  77. package/dist/esm/ion-modal.entry.js +8 -8
  78. package/dist/esm/ion-nav-link.entry.js +1 -1
  79. package/dist/esm/ion-nav.entry.js +6 -6
  80. package/dist/esm/ion-picker-column-internal_2.entry.js +4 -4
  81. package/dist/esm/ion-picker-column.entry.js +4 -4
  82. package/dist/esm/ion-picker.entry.js +5 -5
  83. package/dist/esm/ion-progress-bar.entry.js +3 -3
  84. package/dist/esm/ion-refresher-content.entry.js +3 -3
  85. package/dist/esm/ion-refresher.entry.js +6 -6
  86. package/dist/esm/ion-reorder-group.entry.js +5 -5
  87. package/dist/esm/ion-reorder.entry.js +3 -3
  88. package/dist/esm/ion-route-redirect.entry.js +1 -1
  89. package/dist/esm/ion-route.entry.js +1 -1
  90. package/dist/esm/ion-router-link.entry.js +2 -2
  91. package/dist/esm/ion-router-outlet.entry.js +6 -6
  92. package/dist/esm/ion-router.entry.js +2 -2
  93. package/dist/esm/ion-searchbar.entry.js +4 -4
  94. package/dist/esm/ion-segment-button.entry.js +3 -3
  95. package/dist/esm/ion-segment.entry.js +3 -3
  96. package/dist/esm/ion-select_2.entry.js +4 -4
  97. package/dist/esm/ion-skeleton-text.entry.js +2 -2
  98. package/dist/esm/ion-slide.entry.js +2 -2
  99. package/dist/esm/ion-slides.entry.js +3 -3
  100. package/dist/esm/ion-split-pane.entry.js +2 -2
  101. package/dist/esm/ion-tab-bar.entry.js +2 -2
  102. package/dist/esm/ion-tab-button.entry.js +2 -2
  103. package/dist/esm/ion-tab.entry.js +3 -3
  104. package/dist/esm/ion-tabs.entry.js +1 -1
  105. package/dist/esm/ion-textarea.entry.js +244 -0
  106. package/dist/esm/ion-thumbnail.entry.js +2 -2
  107. package/dist/esm/ion-toast.entry.js +5 -5
  108. package/dist/esm/ion-toggle.entry.js +173 -0
  109. package/dist/esm/ion-virtual-scroll.entry.js +2 -2
  110. package/dist/esm/{ionic-global-293e882b.js → ionic-global-4903e23e.js} +1 -1
  111. package/dist/esm/{ios.transition-7cd34deb.js → ios.transition-131d64fe.js} +4 -4
  112. package/dist/esm/loader.js +4 -4
  113. package/dist/esm/{md.transition-2589a5b1.js → md.transition-f6126011.js} +4 -4
  114. package/dist/esm/{menu-toggle-util-f92ba2f0.js → menu-toggle-util-bace8ae6.js} +1 -1
  115. package/dist/esm/{overlays-dfa730c8.js → overlays-3b4dca92.js} +3 -3
  116. package/dist/esm/{purify-79af871f.js → purify-85bfcc69.js} +1 -1
  117. package/dist/esm/sparkle-animation-player.entry.js +2 -2
  118. package/dist/esm/sparkle-character-intro.entry.js +1 -1
  119. package/dist/esm/sparkle-code.entry.js +2 -2
  120. package/dist/esm/sparkle-compass-post.entry.js +1 -1
  121. package/dist/esm/sparkle-compass.entry.js +1 -1
  122. package/dist/esm/sparkle-core.js +4 -4
  123. package/dist/esm/sparkle-emoji.entry.js +1 -1
  124. package/dist/esm/sparkle-facilitator-notes-form.entry.js +7 -7
  125. package/dist/esm/sparkle-feed-post.entry.js +116 -0
  126. package/dist/esm/sparkle-feedback.entry.js +7 -8
  127. package/dist/esm/sparkle-goal-form.entry.js +8 -8
  128. package/dist/esm/sparkle-gww-comment-list.entry.js +1 -1
  129. package/dist/esm/sparkle-gww-graph.entry.js +1 -1
  130. package/dist/esm/sparkle-intro.entry.js +1 -1
  131. package/dist/esm/sparkle-lower-content-nav.entry.js +1 -1
  132. package/dist/esm/sparkle-menu-collapsible.entry.js +2 -2
  133. package/dist/esm/sparkle-modal-image.entry.js +1 -1
  134. package/dist/esm/sparkle-notfound-page.entry.js +1 -1
  135. package/dist/esm/sparkle-overlay.entry.js +1 -1
  136. package/dist/esm/sparkle-poll.entry.js +1 -1
  137. package/dist/esm/sparkle-quiz-container.entry.js +1 -1
  138. package/dist/esm/sparkle-quiz-feedback_5.entry.js +1 -1
  139. package/dist/esm/sparkle-quiz-v1.entry.js +101 -0
  140. package/dist/esm/sparkle-quiz.entry.js +55 -41
  141. package/dist/esm/sparkle-select.entry.js +1 -1
  142. package/dist/esm/sparkle-sidebar.entry.js +1 -1
  143. package/dist/esm/sparkle-tab.entry.js +1 -1
  144. package/dist/esm/sparkle-table-of-contents.entry.js +1 -1
  145. package/dist/esm/sparkle-tabs.entry.js +1 -1
  146. package/dist/esm/sparkle-youtube.entry.js +1 -1
  147. package/dist/esm/{status-tap-79b6199d.js → status-tap-dde52787.js} +3 -3
  148. package/dist/esm/stencil-async-content.entry.js +1 -1
  149. package/dist/esm/stencil-route-title.entry.js +2 -2
  150. package/dist/esm/stencil-router-prompt.entry.js +2 -2
  151. package/dist/esm/{student.service-0caed0f4.js → student.service-0746418b.js} +19 -3
  152. package/dist/esm/{swipe-back-ad7a0361.js → swipe-back-7847a0c1.js} +1 -1
  153. package/dist/esm/{util-a831d09d.js → util-6ef753e9.js} +1 -1
  154. package/dist/sparkle-core/index.esm.js +1 -1
  155. package/dist/sparkle-core/p-00d10dc9.js +4 -0
  156. package/dist/sparkle-core/p-0147266a.js +1 -0
  157. package/dist/sparkle-core/{p-9ef14088.entry.js → p-04c7b276.entry.js} +1 -1
  158. package/dist/sparkle-core/{p-fde96f7c.js → p-05c032dd.js} +1 -1
  159. package/dist/sparkle-core/{p-4af496a8.entry.js → p-06642405.entry.js} +1 -1
  160. package/dist/sparkle-core/p-0664370b.entry.js +1 -0
  161. package/dist/sparkle-core/{p-0b92326d.entry.js → p-06c7d0f2.entry.js} +1 -1
  162. package/dist/sparkle-core/p-077c732b.js +4 -0
  163. package/dist/sparkle-core/{p-3c752205.entry.js → p-0ad5c123.entry.js} +1 -1
  164. package/dist/sparkle-core/p-0afa3a4d.entry.js +1 -0
  165. package/dist/sparkle-core/{p-e6d39f6e.entry.js → p-0c3f3ea6.entry.js} +1 -1
  166. package/dist/sparkle-core/{p-8cbe019a.entry.js → p-0f1c5899.entry.js} +1 -1
  167. package/dist/sparkle-core/{p-767c9db8.entry.js → p-0fa3fd63.entry.js} +1 -1
  168. package/dist/sparkle-core/p-11356b03.entry.js +1 -0
  169. package/dist/sparkle-core/{p-506f3c5f.js → p-12dd96d7.js} +2 -2
  170. package/dist/sparkle-core/p-162bff1a.entry.js +1 -0
  171. package/dist/sparkle-core/p-1b1ba156.entry.js +1 -0
  172. package/dist/sparkle-core/{p-966817ec.js → p-1d4c7c11.js} +1 -1
  173. package/dist/sparkle-core/p-1e125ca5.entry.js +1 -0
  174. package/dist/sparkle-core/{p-b00d0a47.entry.js → p-1e4782af.entry.js} +1 -1
  175. package/dist/sparkle-core/p-1e4f65ee.entry.js +1 -0
  176. package/dist/sparkle-core/{p-1394cbb8.js → p-2033cd86.js} +2 -2
  177. package/dist/sparkle-core/{p-3ef53ebf.entry.js → p-214d1229.entry.js} +1 -1
  178. package/dist/sparkle-core/p-23aca7ca.js +4 -0
  179. package/dist/sparkle-core/p-24cb9a33.entry.js +1 -0
  180. package/dist/sparkle-core/{p-bae8cd7d.entry.js → p-27fbabc3.entry.js} +1 -1
  181. package/dist/sparkle-core/{p-d220a642.entry.js → p-2ba70507.entry.js} +1 -1
  182. package/dist/sparkle-core/{p-4c9e010d.entry.js → p-2c1ca854.entry.js} +1 -1
  183. package/dist/sparkle-core/p-2d9659e2.entry.js +1 -0
  184. package/dist/sparkle-core/{p-23d713e2.js → p-2f569553.js} +1 -1
  185. package/dist/sparkle-core/{p-c9f474d0.js → p-2ff67662.js} +2 -2
  186. package/dist/sparkle-core/{p-136b93d5.entry.js → p-30b810d1.entry.js} +1 -1
  187. package/dist/sparkle-core/p-32f4e565.entry.js +1 -0
  188. package/dist/sparkle-core/{p-7b21bd70.entry.js → p-352677e6.entry.js} +1 -1
  189. package/dist/sparkle-core/p-370609ba.entry.js +1 -0
  190. package/dist/sparkle-core/{p-bd2c8e30.entry.js → p-377b04c2.entry.js} +2 -2
  191. package/dist/sparkle-core/{p-fea20ec2.entry.js → p-38b7cf68.entry.js} +1 -1
  192. package/dist/sparkle-core/{p-c5eb4404.entry.js → p-3963e02b.entry.js} +1 -1
  193. package/dist/sparkle-core/{p-9b4979b5.entry.js → p-39712c56.entry.js} +1 -1
  194. package/dist/sparkle-core/p-3a965828.entry.js +1 -0
  195. package/dist/sparkle-core/{p-3810777d.js → p-3de0e00c.js} +1 -1
  196. package/dist/sparkle-core/p-4053ecdb.entry.js +1 -0
  197. package/dist/sparkle-core/p-462bffba.js +1 -0
  198. package/dist/sparkle-core/{p-308517b3.js → p-48f72e63.js} +2 -2
  199. package/dist/sparkle-core/{p-a05871e6.js → p-4c6a7e52.js} +1 -1
  200. package/dist/sparkle-core/{p-d6637b48.entry.js → p-5096739e.entry.js} +1 -1
  201. package/dist/sparkle-core/p-5322c920.entry.js +1 -0
  202. package/dist/sparkle-core/{p-34d93a39.entry.js → p-54dd894f.entry.js} +1 -1
  203. package/dist/sparkle-core/{p-085eb951.entry.js → p-564e64fc.entry.js} +1 -1
  204. package/dist/sparkle-core/{p-d0d0e5e5.entry.js → p-5893bbe5.entry.js} +1 -1
  205. package/dist/sparkle-core/{p-351b82a8.entry.js → p-58e4bbe5.entry.js} +1 -1
  206. package/dist/sparkle-core/p-590266d6.entry.js +1 -0
  207. package/dist/sparkle-core/{p-b8ba8164.entry.js → p-594a6982.entry.js} +1 -1
  208. package/dist/sparkle-core/{p-34ebfc8a.entry.js → p-5c435d5a.entry.js} +1 -1
  209. package/dist/sparkle-core/{p-a19b42f0.js → p-5cad23f1.js} +1 -1
  210. package/dist/sparkle-core/p-5efc6566.js +1 -0
  211. package/dist/sparkle-core/{p-7b3d1457.js → p-600cf6a3.js} +1 -1
  212. package/dist/sparkle-core/{p-16b7974e.entry.js → p-601397df.entry.js} +1 -1
  213. package/dist/sparkle-core/{p-dff8325e.js → p-604a7987.js} +1 -1
  214. package/dist/sparkle-core/{p-58f74119.entry.js → p-616941c6.entry.js} +1 -1
  215. package/dist/sparkle-core/{p-fe214d79.entry.js → p-6316d124.entry.js} +1 -1
  216. package/dist/sparkle-core/p-63f71ada.entry.js +1 -0
  217. package/dist/sparkle-core/p-641bfc92.entry.js +1 -0
  218. package/dist/sparkle-core/{p-ea4a9f0d.entry.js → p-69487d90.entry.js} +1 -1
  219. package/dist/sparkle-core/{p-9a383065.entry.js → p-6faa194c.entry.js} +2 -2
  220. package/dist/sparkle-core/{p-df5efe0d.entry.js → p-6ffd2420.entry.js} +1 -1
  221. package/dist/sparkle-core/{p-c48352cf.js → p-73721c84.js} +1 -1
  222. package/dist/sparkle-core/p-74864276.entry.js +1 -0
  223. package/dist/sparkle-core/p-80d6b0e6.entry.js +1 -0
  224. package/dist/sparkle-core/p-81714d94.entry.js +1 -0
  225. package/dist/sparkle-core/p-8492a765.entry.js +1 -0
  226. package/dist/sparkle-core/p-859563db.entry.js +1 -0
  227. package/dist/sparkle-core/p-865f36a8.entry.js +1 -0
  228. package/dist/sparkle-core/{p-280e938d.js → p-86ed13f0.js} +1 -1
  229. package/dist/sparkle-core/{p-01743e3e.js → p-871106e0.js} +1 -1
  230. package/dist/sparkle-core/p-894ff7e6.entry.js +1 -0
  231. package/dist/sparkle-core/p-8a41b502.entry.js +1 -0
  232. package/dist/sparkle-core/p-8c74cbb6.entry.js +1 -0
  233. package/dist/sparkle-core/{p-5979f253.entry.js → p-9289cdbc.entry.js} +1 -1
  234. package/dist/sparkle-core/{p-4bd4dab2.js → p-935e7cfc.js} +1 -1
  235. package/dist/sparkle-core/{p-6ae9c743.entry.js → p-975b99ee.entry.js} +1 -1
  236. package/dist/sparkle-core/p-99ee9919.js +1 -0
  237. package/dist/sparkle-core/{p-0127a61a.entry.js → p-9abbd715.entry.js} +1 -1
  238. package/dist/sparkle-core/{p-4338e1e3.js → p-9d894ed4.js} +1 -1
  239. package/dist/sparkle-core/{p-3fd92216.entry.js → p-9e309b3e.entry.js} +1 -1
  240. package/dist/sparkle-core/p-9e7fee8f.entry.js +1 -0
  241. package/dist/sparkle-core/{p-d6a3a639.entry.js → p-9ebf0537.entry.js} +1 -1
  242. package/dist/sparkle-core/p-a102341e.entry.js +1 -0
  243. package/dist/sparkle-core/{p-06af1bc8.entry.js → p-a2638250.entry.js} +1 -1
  244. package/dist/sparkle-core/{p-e1743d82.entry.js → p-a2ebcf0a.entry.js} +1 -1
  245. package/dist/sparkle-core/{p-ba775d8e.entry.js → p-a98d7ebe.entry.js} +1 -1
  246. package/dist/sparkle-core/p-af3cc111.entry.js +1 -0
  247. package/dist/sparkle-core/{p-1c2aee9c.js → p-b0603d19.js} +1 -1
  248. package/dist/sparkle-core/p-b3f375fb.entry.js +1 -0
  249. package/dist/sparkle-core/p-b5f3e1bf.entry.js +1 -0
  250. package/dist/sparkle-core/{p-3d2c0e24.entry.js → p-b96f3c84.entry.js} +2 -2
  251. package/dist/sparkle-core/{p-ed3dfd89.js → p-bd80ff43.js} +2 -2
  252. package/dist/sparkle-core/p-be64105c.entry.js +1 -0
  253. package/dist/sparkle-core/{p-defeaa5c.entry.js → p-c0533c23.entry.js} +1 -1
  254. package/dist/sparkle-core/p-c2990b24.entry.js +1 -0
  255. package/dist/sparkle-core/p-c3cadfc6.entry.js +1 -0
  256. package/dist/sparkle-core/{p-5a3de051.entry.js → p-c60b29bd.entry.js} +2 -2
  257. package/dist/sparkle-core/p-cabfbf22.entry.js +1 -0
  258. package/dist/sparkle-core/p-cc518c36.entry.js +1 -0
  259. package/dist/sparkle-core/{p-0c603495.entry.js → p-ce4b22f7.entry.js} +1 -1
  260. package/dist/sparkle-core/p-cffd4817.entry.js +1 -0
  261. package/dist/sparkle-core/{p-9cd95e7e.entry.js → p-d0adf726.entry.js} +1 -1
  262. package/dist/sparkle-core/p-d20e4fcf.entry.js +1 -0
  263. package/dist/sparkle-core/p-d24e53ab.entry.js +1 -0
  264. package/dist/sparkle-core/p-d288e6c1.entry.js +1 -0
  265. package/dist/sparkle-core/{p-785f1879.entry.js → p-d601810e.entry.js} +1 -1
  266. package/dist/sparkle-core/{p-27075abe.js → p-d68092b7.js} +1 -1
  267. package/dist/sparkle-core/p-de4deb61.entry.js +1 -0
  268. package/dist/sparkle-core/{p-d5b8302f.entry.js → p-e249aebf.entry.js} +1 -1
  269. package/dist/sparkle-core/p-e3e36ce9.entry.js +1 -0
  270. package/dist/sparkle-core/{p-fdb9a613.entry.js → p-e421d638.entry.js} +1 -1
  271. package/dist/sparkle-core/{p-c8ad5a5b.entry.js → p-e686d8b5.entry.js} +2 -2
  272. package/dist/sparkle-core/{p-8d630960.js → p-e8073714.js} +1 -1
  273. package/dist/sparkle-core/p-e863bf1d.entry.js +1 -0
  274. package/dist/sparkle-core/{p-efe37368.entry.js → p-e8988989.entry.js} +1 -1
  275. package/dist/sparkle-core/{p-6a337ad1.entry.js → p-ea962e1b.entry.js} +1 -1
  276. package/dist/sparkle-core/p-eaf76d1d.entry.js +352 -0
  277. package/dist/sparkle-core/p-ebd4354b.entry.js +1 -0
  278. package/dist/sparkle-core/{p-6a5ace01.js → p-ee1e0eb4.js} +1 -1
  279. package/dist/sparkle-core/{p-1701723e.entry.js → p-ef4edc48.entry.js} +1 -1
  280. package/dist/sparkle-core/{p-a6c1a55a.entry.js → p-fb0ca75e.entry.js} +1 -1
  281. package/dist/sparkle-core/{p-0798d46a.entry.js → p-fb757951.entry.js} +1 -1
  282. package/dist/sparkle-core/{p-ea7d7a3b.js → p-fbccd30c.js} +1 -1
  283. package/dist/sparkle-core/p-fd8d0738.entry.js +4 -0
  284. package/dist/sparkle-core/{p-63d8a5b7.entry.js → p-fda95b6e.entry.js} +1 -1
  285. package/dist/sparkle-core/{p-3eb56165.entry.js → p-fe6dc976.entry.js} +1 -1
  286. package/dist/sparkle-core/{p-f63a13d8.entry.js → p-ff0e0d4e.entry.js} +1 -1
  287. package/dist/sparkle-core/sparkle-core.esm.js +1 -1
  288. package/dist/types/components/sparkle-quiz/sparkle-quiz/sparkle-quiz.d.ts +42 -0
  289. package/dist/types/components/sparkle-quiz/sparkle-quiz-v1.d.ts +41 -0
  290. package/dist/types/components/sparkle-quiz/sparkle-quiz.d.ts +36 -36
  291. package/dist/types/components.d.ts +37 -1
  292. package/package.json +1 -1
  293. package/dist/cjs/PrivateRoute-4abc9d29.js +0 -35
  294. package/dist/cjs/dom-utils-b8befdd5.js +0 -63
  295. package/dist/cjs/header-mobile-collapse_2.cjs.entry.js +0 -112
  296. package/dist/cjs/index-70e63f5b.js +0 -3071
  297. package/dist/cjs/injectHistory-7206bbb9.js +0 -9
  298. package/dist/cjs/ion-avatar_16.cjs.entry.js +0 -1907
  299. package/dist/cjs/ion-checkbox_4.cjs.entry.js +0 -360
  300. package/dist/cjs/ion-col_3.cjs.entry.js +0 -159
  301. package/dist/cjs/ion-range.cjs.entry.js +0 -515
  302. package/dist/cjs/ion-text.cjs.entry.js +0 -24
  303. package/dist/cjs/match-path-84c9f7ca.js +0 -511
  304. package/dist/cjs/sparkle-card_3.cjs.entry.js +0 -91
  305. package/dist/cjs/sparkle-course-root.cjs.entry.js +0 -146
  306. package/dist/cjs/sparkle-dropdown.cjs.entry.js +0 -61
  307. package/dist/cjs/sparkle-facilitator-header_19.cjs.entry.js +0 -2130
  308. package/dist/cjs/sparkle-goal-progress.cjs.entry.js +0 -19
  309. package/dist/cjs/sparkle-gww-item.cjs.entry.js +0 -74
  310. package/dist/cjs/sparkle-menu-toggle_3.cjs.entry.js +0 -236
  311. package/dist/cjs/sparkle-validation-error.cjs.entry.js +0 -21
  312. package/dist/cjs/stencil-route-link.cjs.entry.js +0 -77
  313. package/dist/cjs/stencil-router-redirect.cjs.entry.js +0 -32
  314. package/dist/cjs/student.service-d48f1c99.js +0 -61
  315. package/dist/cjs/user.store-8a049c4e.js +0 -21
  316. package/dist/esm/PrivateRoute-530ef873.js +0 -33
  317. package/dist/esm/dom-utils-8e73e88b.js +0 -55
  318. package/dist/esm/header-mobile-collapse_2.entry.js +0 -107
  319. package/dist/esm/index-ab1c6a9f.js +0 -3067
  320. package/dist/esm/injectHistory-4bfff188.js +0 -7
  321. package/dist/esm/ion-avatar_16.entry.js +0 -1888
  322. package/dist/esm/ion-checkbox_4.entry.js +0 -353
  323. package/dist/esm/ion-col_3.entry.js +0 -153
  324. package/dist/esm/ion-range.entry.js +0 -511
  325. package/dist/esm/ion-text.entry.js +0 -20
  326. package/dist/esm/match-path-36fdf5c7.js +0 -499
  327. package/dist/esm/sparkle-card_3.entry.js +0 -85
  328. package/dist/esm/sparkle-course-root.entry.js +0 -142
  329. package/dist/esm/sparkle-dropdown.entry.js +0 -57
  330. package/dist/esm/sparkle-facilitator-header_19.entry.js +0 -2108
  331. package/dist/esm/sparkle-goal-progress.entry.js +0 -15
  332. package/dist/esm/sparkle-gww-item.entry.js +0 -70
  333. package/dist/esm/sparkle-menu-toggle_3.entry.js +0 -230
  334. package/dist/esm/sparkle-validation-error.entry.js +0 -17
  335. package/dist/esm/stencil-route-link.entry.js +0 -73
  336. package/dist/esm/stencil-router-redirect.entry.js +0 -28
  337. package/dist/esm/user.store-8477642a.js +0 -19
  338. package/dist/sparkle-core/p-0d7cceaa.entry.js +0 -1
  339. package/dist/sparkle-core/p-0d813026.entry.js +0 -1
  340. package/dist/sparkle-core/p-11ed6b7f.entry.js +0 -1
  341. package/dist/sparkle-core/p-122427b7.entry.js +0 -1
  342. package/dist/sparkle-core/p-12c4f45c.entry.js +0 -1
  343. package/dist/sparkle-core/p-14340143.entry.js +0 -4
  344. package/dist/sparkle-core/p-14a06a91.entry.js +0 -1
  345. package/dist/sparkle-core/p-16c81890.entry.js +0 -1
  346. package/dist/sparkle-core/p-1728ead7.js +0 -1
  347. package/dist/sparkle-core/p-17aef6f9.js +0 -1
  348. package/dist/sparkle-core/p-180857a2.entry.js +0 -1
  349. package/dist/sparkle-core/p-1acc7870.entry.js +0 -1
  350. package/dist/sparkle-core/p-1cd4c3cc.entry.js +0 -1
  351. package/dist/sparkle-core/p-21d9833d.js +0 -1
  352. package/dist/sparkle-core/p-25c13612.entry.js +0 -1
  353. package/dist/sparkle-core/p-2699868a.entry.js +0 -1
  354. package/dist/sparkle-core/p-2bd4c60e.js +0 -1
  355. package/dist/sparkle-core/p-2c89a6c2.entry.js +0 -1
  356. package/dist/sparkle-core/p-3227afcb.entry.js +0 -1
  357. package/dist/sparkle-core/p-363a2d6d.js +0 -4
  358. package/dist/sparkle-core/p-36c48760.entry.js +0 -1
  359. package/dist/sparkle-core/p-384911d7.entry.js +0 -1
  360. package/dist/sparkle-core/p-3b618eda.entry.js +0 -1
  361. package/dist/sparkle-core/p-442eadcf.entry.js +0 -1
  362. package/dist/sparkle-core/p-4d0dfbc9.js +0 -1
  363. package/dist/sparkle-core/p-4e0502b8.entry.js +0 -4
  364. package/dist/sparkle-core/p-524a6174.entry.js +0 -1
  365. package/dist/sparkle-core/p-53aac9d7.entry.js +0 -1
  366. package/dist/sparkle-core/p-56700a40.entry.js +0 -1
  367. package/dist/sparkle-core/p-5722be24.entry.js +0 -1
  368. package/dist/sparkle-core/p-58389020.entry.js +0 -348
  369. package/dist/sparkle-core/p-5a850731.entry.js +0 -1
  370. package/dist/sparkle-core/p-5dcf33fb.entry.js +0 -1
  371. package/dist/sparkle-core/p-5e8fa1ac.entry.js +0 -1
  372. package/dist/sparkle-core/p-5ef50959.js +0 -1
  373. package/dist/sparkle-core/p-615b8f64.entry.js +0 -1
  374. package/dist/sparkle-core/p-76206f80.entry.js +0 -1
  375. package/dist/sparkle-core/p-76a6e202.entry.js +0 -1
  376. package/dist/sparkle-core/p-788735b9.entry.js +0 -1
  377. package/dist/sparkle-core/p-8e42e634.entry.js +0 -1
  378. package/dist/sparkle-core/p-8e56f9ee.entry.js +0 -1
  379. package/dist/sparkle-core/p-8ed0cefb.entry.js +0 -1
  380. package/dist/sparkle-core/p-9484e34b.entry.js +0 -1
  381. package/dist/sparkle-core/p-969e98e5.entry.js +0 -1
  382. package/dist/sparkle-core/p-98f3925b.js +0 -4
  383. package/dist/sparkle-core/p-99231c00.js +0 -4
  384. package/dist/sparkle-core/p-9dc42d70.entry.js +0 -1
  385. package/dist/sparkle-core/p-9eea81f2.js +0 -1
  386. package/dist/sparkle-core/p-a111c567.entry.js +0 -1
  387. package/dist/sparkle-core/p-a2f7c751.entry.js +0 -1
  388. package/dist/sparkle-core/p-a458b415.entry.js +0 -1
  389. package/dist/sparkle-core/p-ab3a8f5e.entry.js +0 -1
  390. package/dist/sparkle-core/p-ac0e4d8c.entry.js +0 -1
  391. package/dist/sparkle-core/p-b2827978.entry.js +0 -1
  392. package/dist/sparkle-core/p-bb3e3482.entry.js +0 -1
  393. package/dist/sparkle-core/p-bb575dba.entry.js +0 -1
  394. package/dist/sparkle-core/p-ca0edc9b.entry.js +0 -1
  395. package/dist/sparkle-core/p-cb04b18a.entry.js +0 -1
  396. package/dist/sparkle-core/p-d38a2511.entry.js +0 -1
  397. package/dist/sparkle-core/p-d5ba8e80.entry.js +0 -1
  398. package/dist/sparkle-core/p-d6788642.entry.js +0 -1
  399. package/dist/sparkle-core/p-d86f8633.entry.js +0 -1
  400. package/dist/sparkle-core/p-df5cfa7f.entry.js +0 -1
  401. package/dist/sparkle-core/p-e09de7ac.js +0 -1
  402. package/dist/sparkle-core/p-e28a106d.entry.js +0 -1
  403. package/dist/sparkle-core/p-e566c0b3.entry.js +0 -1
  404. package/dist/sparkle-core/p-f187d129.entry.js +0 -1
  405. package/dist/sparkle-core/p-f5e7bfa5.js +0 -1
  406. package/dist/sparkle-core/p-fe3a7bca.js +0 -1
  407. package/dist/sparkle-core/p-ff26d891.entry.js +0 -1
@@ -1,511 +0,0 @@
1
- import { r as registerInstance, e as createEvent, h, H as Host, i as getElement } from './index-9db08224.js';
2
- import { g as getIonMode } from './ionic-global-293e882b.js';
3
- import { a as findClosestIonContent, d as disableContentScrollY, r as resetContentScrollY } from './index-c23a1826.js';
4
- import { m as clamp, d as debounceEvent, i as inheritAriaAttributes, k as getAriaLabel, l as renderHiddenInput } from './helpers-94a5855b.js';
5
- import { a as printIonWarning } from './index-dad75b83.js';
6
- import { i as isRTL } from './dir-03012648.js';
7
- import { c as createColorClasses, h as hostContext } from './theme-7ef00c83.js';
8
-
9
- const rangeIosCss = ":host{--knob-handle-size:calc(var(--knob-size) * 2);display:flex;position:relative;flex:3;align-items:center;font-family:var(--ion-font-family, inherit);user-select:none;z-index:2}:host(.range-disabled){pointer-events:none}::slotted(ion-label){flex:initial}::slotted(ion-icon[slot]){font-size:24px}.range-slider{position:relative;flex:1;width:100%;height:var(--height);contain:size layout style;cursor:grab;touch-action:pan-y}:host(.range-pressed) .range-slider{cursor:grabbing}.range-pin{position:absolute;background:var(--ion-color-base);color:var(--ion-color-contrast);text-align:center;box-sizing:border-box}.range-knob-handle{left:0;top:calc((var(--height) - var(--knob-handle-size)) / 2);margin-left:calc(0px - var(--knob-handle-size) / 2);position:absolute;width:var(--knob-handle-size);height:var(--knob-handle-size);text-align:center}[dir=rtl] .range-knob-handle,:host-context([dir=rtl]) .range-knob-handle{left:unset;right:unset;right:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.range-knob-handle{margin-left:unset;-webkit-margin-start:calc(0px - var(--knob-handle-size) / 2);margin-inline-start:calc(0px - var(--knob-handle-size) / 2)}}[dir=rtl] .range-knob-handle,:host-context([dir=rtl]) .range-knob-handle{left:unset}.range-knob-handle:active,.range-knob-handle:focus{outline:none}.range-bar{border-radius:var(--bar-border-radius);left:0;top:calc((var(--height) - var(--bar-height)) / 2);position:absolute;width:100%;height:var(--bar-height);background:var(--bar-background);pointer-events:none}[dir=rtl] .range-bar,:host-context([dir=rtl]) .range-bar{left:unset;right:unset;right:0}[dir=rtl] .range-bar,:host-context([dir=rtl]) .range-bar{left:unset}.range-knob{border-radius:var(--knob-border-radius);left:calc(50% - var(--knob-size) / 2);top:calc(50% - var(--knob-size) / 2);position:absolute;width:var(--knob-size);height:var(--knob-size);background:var(--knob-background);box-shadow:var(--knob-box-shadow);z-index:2;pointer-events:none}[dir=rtl] .range-knob,:host-context([dir=rtl]) .range-knob{left:unset;right:unset;right:calc(50% - var(--knob-size) / 2)}[dir=rtl] .range-knob,:host-context([dir=rtl]) .range-knob{left:unset}:host(.range-pressed) .range-bar-active{will-change:left, right}:host(.in-item){width:100%}:host(.in-item) ::slotted(ion-label){align-self:center}:host{--knob-border-radius:50%;--knob-background:#ffffff;--knob-box-shadow:0 3px 1px rgba(0, 0, 0, 0.1), 0 4px 8px rgba(0, 0, 0, 0.13), 0 0 0 1px rgba(0, 0, 0, 0.02);--knob-size:28px;--bar-height:2px;--bar-background:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.1);--bar-background-active:var(--ion-color-primary, #3880ff);--bar-border-radius:0;--height:42px;padding-left:16px;padding-right:16px;padding-top:8px;padding-bottom:8px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px}}:host(.ion-color) .range-bar-active,:host(.ion-color) .range-tick-active{background:var(--ion-color-base)}::slotted([slot=start]){margin-left:0;margin-right:16px;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:16px;margin-inline-end:16px}}::slotted([slot=end]){margin-left:16px;margin-right:0;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:16px;margin-inline-start:16px;-webkit-margin-end:0;margin-inline-end:0}}:host(.range-has-pin){padding-top:20px}.range-bar-active{bottom:0;width:auto;background:var(--bar-background-active)}.range-tick{margin-left:-1px;border-radius:0;position:absolute;top:18px;width:2px;height:8px;background:rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.1);pointer-events:none}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.range-tick{margin-left:unset;-webkit-margin-start:-1px;margin-inline-start:-1px}}.range-tick-active{background:var(--bar-background-active)}.range-pin{transform:translate3d(0, 28px, 0) scale(0.01);padding-left:8px;padding-right:8px;padding-top:8px;padding-bottom:8px;display:inline-block;position:relative;top:-20px;min-width:28px;transition:transform 120ms ease;background:transparent;color:var(--ion-text-color, #000);font-size:12px;text-align:center}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.range-pin{padding-left:unset;padding-right:unset;-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px}}.range-knob-pressed .range-pin{transform:translate3d(0, 0, 0) scale(1)}:host(.range-disabled){opacity:0.5}";
10
-
11
- const rangeMdCss = ":host{--knob-handle-size:calc(var(--knob-size) * 2);display:flex;position:relative;flex:3;align-items:center;font-family:var(--ion-font-family, inherit);user-select:none;z-index:2}:host(.range-disabled){pointer-events:none}::slotted(ion-label){flex:initial}::slotted(ion-icon[slot]){font-size:24px}.range-slider{position:relative;flex:1;width:100%;height:var(--height);contain:size layout style;cursor:grab;touch-action:pan-y}:host(.range-pressed) .range-slider{cursor:grabbing}.range-pin{position:absolute;background:var(--ion-color-base);color:var(--ion-color-contrast);text-align:center;box-sizing:border-box}.range-knob-handle{left:0;top:calc((var(--height) - var(--knob-handle-size)) / 2);margin-left:calc(0px - var(--knob-handle-size) / 2);position:absolute;width:var(--knob-handle-size);height:var(--knob-handle-size);text-align:center}[dir=rtl] .range-knob-handle,:host-context([dir=rtl]) .range-knob-handle{left:unset;right:unset;right:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.range-knob-handle{margin-left:unset;-webkit-margin-start:calc(0px - var(--knob-handle-size) / 2);margin-inline-start:calc(0px - var(--knob-handle-size) / 2)}}[dir=rtl] .range-knob-handle,:host-context([dir=rtl]) .range-knob-handle{left:unset}.range-knob-handle:active,.range-knob-handle:focus{outline:none}.range-bar{border-radius:var(--bar-border-radius);left:0;top:calc((var(--height) - var(--bar-height)) / 2);position:absolute;width:100%;height:var(--bar-height);background:var(--bar-background);pointer-events:none}[dir=rtl] .range-bar,:host-context([dir=rtl]) .range-bar{left:unset;right:unset;right:0}[dir=rtl] .range-bar,:host-context([dir=rtl]) .range-bar{left:unset}.range-knob{border-radius:var(--knob-border-radius);left:calc(50% - var(--knob-size) / 2);top:calc(50% - var(--knob-size) / 2);position:absolute;width:var(--knob-size);height:var(--knob-size);background:var(--knob-background);box-shadow:var(--knob-box-shadow);z-index:2;pointer-events:none}[dir=rtl] .range-knob,:host-context([dir=rtl]) .range-knob{left:unset;right:unset;right:calc(50% - var(--knob-size) / 2)}[dir=rtl] .range-knob,:host-context([dir=rtl]) .range-knob{left:unset}:host(.range-pressed) .range-bar-active{will-change:left, right}:host(.in-item){width:100%}:host(.in-item) ::slotted(ion-label){align-self:center}:host{--knob-border-radius:50%;--knob-background:var(--bar-background-active);--knob-box-shadow:none;--knob-size:18px;--bar-height:2px;--bar-background:rgba(var(--ion-color-primary-rgb, 56, 128, 255), 0.26);--bar-background-active:var(--ion-color-primary, #3880ff);--bar-border-radius:0;--height:42px;--pin-background:var(--ion-color-primary, #3880ff);--pin-color:var(--ion-color-primary-contrast, #fff);padding-left:14px;padding-right:14px;padding-top:8px;padding-bottom:8px;font-size:12px}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){:host{padding-left:unset;padding-right:unset;-webkit-padding-start:14px;padding-inline-start:14px;-webkit-padding-end:14px;padding-inline-end:14px}}:host(.ion-color) .range-bar{background:rgba(var(--ion-color-base-rgb), 0.26)}:host(.ion-color) .range-bar-active,:host(.ion-color) .range-knob,:host(.ion-color) .range-pin,:host(.ion-color) .range-pin::before,:host(.ion-color) .range-tick{background:var(--ion-color-base);color:var(--ion-color-contrast)}::slotted([slot=start]){margin-left:0;margin-right:14px;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:14px;margin-inline-end:14px}}::slotted([slot=end]){margin-left:14px;margin-right:0;margin-top:0;margin-bottom:0}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:14px;margin-inline-start:14px;-webkit-margin-end:0;margin-inline-end:0}}:host(.range-has-pin){padding-top:28px}.range-bar-active{bottom:0;width:auto;background:var(--bar-background-active)}.range-knob{transform:scale(0.67);transition-duration:120ms;transition-property:transform, background-color, border;transition-timing-function:ease;z-index:2}.range-tick{position:absolute;top:calc((var(--height) - var(--bar-height)) / 2);width:var(--bar-height);height:var(--bar-height);background:var(--bar-background-active);z-index:1;pointer-events:none}.range-tick-active{background:transparent}.range-pin{padding-left:0;padding-right:0;padding-top:8px;padding-bottom:8px;border-radius:50%;transform:translate3d(0, 0, 0) scale(0.01);display:inline-block;position:relative;min-width:28px;height:28px;transition:transform 120ms ease, background 120ms ease;background:var(--pin-background);color:var(--pin-color);text-align:center}.range-pin::before{left:50%;top:3px;margin-left:-13px;border-radius:50% 50% 50% 0;position:absolute;width:26px;height:26px;transform:rotate(-45deg);transition:background 120ms ease;background:var(--pin-background);content:\"\";z-index:-1}[dir=rtl] .range-pin::before,:host-context([dir=rtl]) .range-pin::before{left:unset;right:unset;right:50%}@supports (margin-inline-start: 0) or (-webkit-margin-start: 0){.range-pin::before{margin-left:unset;-webkit-margin-start:-13px;margin-inline-start:-13px}}[dir=rtl] .range-pin::before,:host-context([dir=rtl]) .range-pin::before{left:unset}.range-knob-pressed .range-pin{transform:translate3d(0, -24px, 0) scale(1)}:host(:not(.range-has-pin)) .range-knob-pressed .range-knob{transform:scale(1)}:host(.range-disabled) .range-bar-active,:host(.range-disabled) .range-bar,:host(.range-disabled) .range-tick{background-color:var(--ion-color-step-250, #bfbfbf)}:host(.range-disabled) .range-knob{transform:scale(0.55);outline:5px solid #fff;background-color:var(--ion-color-step-250, #bfbfbf)}";
12
-
13
- const Range = class {
14
- constructor(hostRef) {
15
- registerInstance(this, hostRef);
16
- this.ionChange = createEvent(this, "ionChange", 7);
17
- this.ionStyle = createEvent(this, "ionStyle", 7);
18
- this.ionFocus = createEvent(this, "ionFocus", 7);
19
- this.ionBlur = createEvent(this, "ionBlur", 7);
20
- this.ionKnobMoveStart = createEvent(this, "ionKnobMoveStart", 7);
21
- this.ionKnobMoveEnd = createEvent(this, "ionKnobMoveEnd", 7);
22
- this.didLoad = false;
23
- this.noUpdate = false;
24
- this.hasFocus = false;
25
- this.inheritedAttributes = {};
26
- this.contentEl = null;
27
- this.initialContentScrollY = true;
28
- this.ratioA = 0;
29
- this.ratioB = 0;
30
- /**
31
- * How long, in milliseconds, to wait to trigger the
32
- * `ionChange` event after each change in the range value.
33
- * This also impacts form bindings such as `ngModel` or `v-model`.
34
- */
35
- this.debounce = 0;
36
- // TODO: In Ionic Framework v6 this should initialize to this.rangeId like the other form components do.
37
- /**
38
- * The name of the control, which is submitted with the form data.
39
- */
40
- this.name = '';
41
- /**
42
- * Show two knobs.
43
- */
44
- this.dualKnobs = false;
45
- /**
46
- * Minimum integer value of the range.
47
- */
48
- this.min = 0;
49
- /**
50
- * Maximum integer value of the range.
51
- */
52
- this.max = 100;
53
- /**
54
- * If `true`, a pin with integer value is shown when the knob
55
- * is pressed.
56
- */
57
- this.pin = false;
58
- /**
59
- * A callback used to format the pin text.
60
- * By default the pin text is set to `Math.round(value)`.
61
- */
62
- this.pinFormatter = (value) => Math.round(value);
63
- /**
64
- * If `true`, the knob snaps to tick marks evenly spaced based
65
- * on the step property value.
66
- */
67
- this.snaps = false;
68
- /**
69
- * Specifies the value granularity.
70
- */
71
- this.step = 1;
72
- /**
73
- * If `true`, tick marks are displayed based on the step value.
74
- * Only applies when `snaps` is `true`.
75
- */
76
- this.ticks = true;
77
- /**
78
- * If `true`, the user cannot interact with the range.
79
- */
80
- this.disabled = false;
81
- /**
82
- * the value of the range.
83
- */
84
- this.value = 0;
85
- this.clampBounds = (value) => {
86
- return clamp(this.min, value, this.max);
87
- };
88
- this.ensureValueInBounds = (value) => {
89
- if (this.dualKnobs) {
90
- return {
91
- lower: this.clampBounds(value.lower),
92
- upper: this.clampBounds(value.upper),
93
- };
94
- }
95
- else {
96
- return this.clampBounds(value);
97
- }
98
- };
99
- this.setupGesture = async () => {
100
- const rangeSlider = this.rangeSlider;
101
- if (rangeSlider) {
102
- this.gesture = (await import('./index-21661af2.js')).createGesture({
103
- el: rangeSlider,
104
- gestureName: 'range',
105
- gesturePriority: 100,
106
- threshold: 0,
107
- onStart: (ev) => this.onStart(ev),
108
- onMove: (ev) => this.onMove(ev),
109
- onEnd: (ev) => this.onEnd(ev),
110
- });
111
- this.gesture.enable(!this.disabled);
112
- }
113
- };
114
- this.handleKeyboard = (knob, isIncrease) => {
115
- const { ensureValueInBounds } = this;
116
- let step = this.step;
117
- step = step > 0 ? step : 1;
118
- step = step / (this.max - this.min);
119
- if (!isIncrease) {
120
- step *= -1;
121
- }
122
- if (knob === 'A') {
123
- this.ratioA = clamp(0, this.ratioA + step, 1);
124
- }
125
- else {
126
- this.ratioB = clamp(0, this.ratioB + step, 1);
127
- }
128
- this.ionKnobMoveStart.emit({ value: ensureValueInBounds(this.value) });
129
- this.updateValue();
130
- this.ionKnobMoveEnd.emit({ value: ensureValueInBounds(this.value) });
131
- };
132
- this.onBlur = () => {
133
- if (this.hasFocus) {
134
- this.hasFocus = false;
135
- this.ionBlur.emit();
136
- this.emitStyle();
137
- }
138
- };
139
- this.onFocus = () => {
140
- if (!this.hasFocus) {
141
- this.hasFocus = true;
142
- this.ionFocus.emit();
143
- this.emitStyle();
144
- }
145
- };
146
- }
147
- debounceChanged() {
148
- this.ionChange = debounceEvent(this.ionChange, this.debounce);
149
- }
150
- minChanged() {
151
- if (!this.noUpdate) {
152
- this.updateRatio();
153
- }
154
- }
155
- maxChanged() {
156
- if (!this.noUpdate) {
157
- this.updateRatio();
158
- }
159
- }
160
- activeBarStartChanged() {
161
- const { activeBarStart } = this;
162
- if (activeBarStart !== undefined) {
163
- if (activeBarStart > this.max) {
164
- printIonWarning(`Range: The value of activeBarStart (${activeBarStart}) is greater than the max (${this.max}). Valid values are greater than or equal to the min value and less than or equal to the max value.`, this.el);
165
- this.activeBarStart = this.max;
166
- }
167
- else if (activeBarStart < this.min) {
168
- printIonWarning(`Range: The value of activeBarStart (${activeBarStart}) is less than the min (${this.min}). Valid values are greater than or equal to the min value and less than or equal to the max value.`, this.el);
169
- this.activeBarStart = this.min;
170
- }
171
- }
172
- }
173
- disabledChanged() {
174
- if (this.gesture) {
175
- this.gesture.enable(!this.disabled);
176
- }
177
- this.emitStyle();
178
- }
179
- valueChanged(value) {
180
- if (!this.noUpdate) {
181
- this.updateRatio();
182
- }
183
- value = this.ensureValueInBounds(value);
184
- this.ionChange.emit({ value });
185
- }
186
- componentWillLoad() {
187
- /**
188
- * If user has custom ID set then we should
189
- * not assign the default incrementing ID.
190
- */
191
- this.rangeId = this.el.hasAttribute('id') ? this.el.getAttribute('id') : `ion-r-${rangeIds++}`;
192
- this.inheritedAttributes = inheritAriaAttributes(this.el);
193
- }
194
- componentDidLoad() {
195
- this.setupGesture();
196
- this.didLoad = true;
197
- }
198
- connectedCallback() {
199
- this.updateRatio();
200
- this.debounceChanged();
201
- this.disabledChanged();
202
- this.activeBarStartChanged();
203
- /**
204
- * If we have not yet rendered
205
- * ion-range, then rangeSlider is not defined.
206
- * But if we are moving ion-range via appendChild,
207
- * then rangeSlider will be defined.
208
- */
209
- if (this.didLoad) {
210
- this.setupGesture();
211
- }
212
- this.contentEl = findClosestIonContent(this.el);
213
- }
214
- disconnectedCallback() {
215
- if (this.gesture) {
216
- this.gesture.destroy();
217
- this.gesture = undefined;
218
- }
219
- }
220
- getValue() {
221
- const value = this.value || 0;
222
- if (this.dualKnobs) {
223
- if (typeof value === 'object') {
224
- return value;
225
- }
226
- return {
227
- lower: 0,
228
- upper: value,
229
- };
230
- }
231
- else {
232
- if (typeof value === 'object') {
233
- return value.upper;
234
- }
235
- return value;
236
- }
237
- }
238
- emitStyle() {
239
- this.ionStyle.emit({
240
- interactive: true,
241
- 'interactive-disabled': this.disabled,
242
- });
243
- }
244
- onStart(detail) {
245
- const { contentEl } = this;
246
- if (contentEl) {
247
- this.initialContentScrollY = disableContentScrollY(contentEl);
248
- }
249
- const rect = (this.rect = this.rangeSlider.getBoundingClientRect());
250
- const currentX = detail.currentX;
251
- // figure out which knob they started closer to
252
- let ratio = clamp(0, (currentX - rect.left) / rect.width, 1);
253
- if (isRTL(this.el)) {
254
- ratio = 1 - ratio;
255
- }
256
- this.pressedKnob = !this.dualKnobs || Math.abs(this.ratioA - ratio) < Math.abs(this.ratioB - ratio) ? 'A' : 'B';
257
- this.setFocus(this.pressedKnob);
258
- // update the active knob's position
259
- this.update(currentX);
260
- this.ionKnobMoveStart.emit({ value: this.ensureValueInBounds(this.value) });
261
- }
262
- onMove(detail) {
263
- this.update(detail.currentX);
264
- }
265
- onEnd(detail) {
266
- const { contentEl, initialContentScrollY } = this;
267
- if (contentEl) {
268
- resetContentScrollY(contentEl, initialContentScrollY);
269
- }
270
- this.update(detail.currentX);
271
- this.pressedKnob = undefined;
272
- this.ionKnobMoveEnd.emit({ value: this.ensureValueInBounds(this.value) });
273
- }
274
- update(currentX) {
275
- // figure out where the pointer is currently at
276
- // update the knob being interacted with
277
- const rect = this.rect;
278
- let ratio = clamp(0, (currentX - rect.left) / rect.width, 1);
279
- if (isRTL(this.el)) {
280
- ratio = 1 - ratio;
281
- }
282
- if (this.snaps) {
283
- // snaps the ratio to the current value
284
- ratio = valueToRatio(ratioToValue(ratio, this.min, this.max, this.step), this.min, this.max);
285
- }
286
- // update which knob is pressed
287
- if (this.pressedKnob === 'A') {
288
- this.ratioA = ratio;
289
- }
290
- else {
291
- this.ratioB = ratio;
292
- }
293
- // Update input value
294
- this.updateValue();
295
- }
296
- get valA() {
297
- return ratioToValue(this.ratioA, this.min, this.max, this.step);
298
- }
299
- get valB() {
300
- return ratioToValue(this.ratioB, this.min, this.max, this.step);
301
- }
302
- get ratioLower() {
303
- if (this.dualKnobs) {
304
- return Math.min(this.ratioA, this.ratioB);
305
- }
306
- const { activeBarStart } = this;
307
- if (activeBarStart == null) {
308
- return 0;
309
- }
310
- return valueToRatio(activeBarStart, this.min, this.max);
311
- }
312
- get ratioUpper() {
313
- if (this.dualKnobs) {
314
- return Math.max(this.ratioA, this.ratioB);
315
- }
316
- return this.ratioA;
317
- }
318
- updateRatio() {
319
- const value = this.getValue();
320
- const { min, max } = this;
321
- if (this.dualKnobs) {
322
- this.ratioA = valueToRatio(value.lower, min, max);
323
- this.ratioB = valueToRatio(value.upper, min, max);
324
- }
325
- else {
326
- this.ratioA = valueToRatio(value, min, max);
327
- }
328
- }
329
- updateValue() {
330
- this.noUpdate = true;
331
- const { valA, valB } = this;
332
- this.value = !this.dualKnobs
333
- ? valA
334
- : {
335
- lower: Math.min(valA, valB),
336
- upper: Math.max(valA, valB),
337
- };
338
- this.noUpdate = false;
339
- }
340
- setFocus(knob) {
341
- if (this.el.shadowRoot) {
342
- const knobEl = this.el.shadowRoot.querySelector(knob === 'A' ? '.range-knob-a' : '.range-knob-b');
343
- if (knobEl) {
344
- knobEl.focus();
345
- }
346
- }
347
- }
348
- render() {
349
- var _a;
350
- const { min, max, step, el, handleKeyboard, pressedKnob, disabled, pin, ratioLower, ratioUpper, inheritedAttributes, rangeId, pinFormatter, } = this;
351
- /**
352
- * Look for external label, ion-label, or aria-labelledby.
353
- * If none, see if user placed an aria-label on the host
354
- * and use that instead.
355
- */
356
- let { labelText } = getAriaLabel(el, rangeId);
357
- if (labelText === undefined || labelText === null) {
358
- labelText = inheritedAttributes['aria-label'];
359
- }
360
- const mode = getIonMode(this);
361
- let barStart = `${ratioLower * 100}%`;
362
- let barEnd = `${100 - ratioUpper * 100}%`;
363
- const rtl = isRTL(this.el);
364
- const start = rtl ? 'right' : 'left';
365
- const end = rtl ? 'left' : 'right';
366
- const tickStyle = (tick) => {
367
- return {
368
- [start]: tick[start],
369
- };
370
- };
371
- if (this.dualKnobs === false) {
372
- /**
373
- * When the value is less than the activeBarStart or the min value,
374
- * the knob will display at the start of the active bar.
375
- */
376
- if (this.valA < ((_a = this.activeBarStart) !== null && _a !== void 0 ? _a : this.min)) {
377
- /**
378
- * Sets the bar positions relative to the upper and lower limits.
379
- * Converts the ratio values into percentages, used as offsets for left/right styles.
380
- *
381
- * The ratioUpper refers to the knob position on the bar.
382
- * The ratioLower refers to the end position of the active bar (the value).
383
- */
384
- barStart = `${ratioUpper * 100}%`;
385
- barEnd = `${100 - ratioLower * 100}%`;
386
- }
387
- else {
388
- /**
389
- * Otherwise, the knob will display at the end of the active bar.
390
- *
391
- * The ratioLower refers to the start position of the active bar (the value).
392
- * The ratioUpper refers to the knob position on the bar.
393
- */
394
- barStart = `${ratioLower * 100}%`;
395
- barEnd = `${100 - ratioUpper * 100}%`;
396
- }
397
- }
398
- const barStyle = {
399
- [start]: barStart,
400
- [end]: barEnd,
401
- };
402
- const ticks = [];
403
- if (this.snaps && this.ticks) {
404
- for (let value = min; value <= max; value += step) {
405
- const ratio = valueToRatio(value, min, max);
406
- const ratioMin = Math.min(ratioLower, ratioUpper);
407
- const ratioMax = Math.max(ratioLower, ratioUpper);
408
- const tick = {
409
- ratio,
410
- /**
411
- * Sets the tick mark as active when the tick is between the min bounds and the knob.
412
- * When using activeBarStart, the tick mark will be active between the knob and activeBarStart.
413
- */
414
- active: ratio >= ratioMin && ratio <= ratioMax,
415
- };
416
- tick[start] = `${ratio * 100}%`;
417
- ticks.push(tick);
418
- }
419
- }
420
- renderHiddenInput(true, el, this.name, JSON.stringify(this.getValue()), disabled);
421
- return (h(Host, { onFocusin: this.onFocus, onFocusout: this.onBlur, id: rangeId, class: createColorClasses(this.color, {
422
- [mode]: true,
423
- 'in-item': hostContext('ion-item', el),
424
- 'range-disabled': disabled,
425
- 'range-pressed': pressedKnob !== undefined,
426
- 'range-has-pin': pin,
427
- }) }, h("slot", { name: "start" }), h("div", { class: "range-slider", ref: (rangeEl) => (this.rangeSlider = rangeEl) }, ticks.map((tick) => (h("div", { style: tickStyle(tick), role: "presentation", class: {
428
- 'range-tick': true,
429
- 'range-tick-active': tick.active,
430
- }, part: tick.active ? 'tick-active' : 'tick' }))), h("div", { class: "range-bar", role: "presentation", part: "bar" }), h("div", { class: "range-bar range-bar-active", role: "presentation", style: barStyle, part: "bar-active" }), renderKnob(rtl, {
431
- knob: 'A',
432
- pressed: pressedKnob === 'A',
433
- value: this.valA,
434
- ratio: this.ratioA,
435
- pin,
436
- pinFormatter,
437
- disabled,
438
- handleKeyboard,
439
- min,
440
- max,
441
- labelText,
442
- }), this.dualKnobs &&
443
- renderKnob(rtl, {
444
- knob: 'B',
445
- pressed: pressedKnob === 'B',
446
- value: this.valB,
447
- ratio: this.ratioB,
448
- pin,
449
- pinFormatter,
450
- disabled,
451
- handleKeyboard,
452
- min,
453
- max,
454
- labelText,
455
- })), h("slot", { name: "end" })));
456
- }
457
- get el() { return getElement(this); }
458
- static get watchers() { return {
459
- "debounce": ["debounceChanged"],
460
- "min": ["minChanged"],
461
- "max": ["maxChanged"],
462
- "activeBarStart": ["activeBarStartChanged"],
463
- "disabled": ["disabledChanged"],
464
- "value": ["valueChanged"]
465
- }; }
466
- };
467
- const renderKnob = (rtl, { knob, value, ratio, min, max, disabled, pressed, pin, handleKeyboard, labelText, pinFormatter }) => {
468
- const start = rtl ? 'right' : 'left';
469
- const knobStyle = () => {
470
- const style = {};
471
- style[start] = `${ratio * 100}%`;
472
- return style;
473
- };
474
- return (h("div", { onKeyDown: (ev) => {
475
- const key = ev.key;
476
- if (key === 'ArrowLeft' || key === 'ArrowDown') {
477
- handleKeyboard(knob, false);
478
- ev.preventDefault();
479
- ev.stopPropagation();
480
- }
481
- else if (key === 'ArrowRight' || key === 'ArrowUp') {
482
- handleKeyboard(knob, true);
483
- ev.preventDefault();
484
- ev.stopPropagation();
485
- }
486
- }, class: {
487
- 'range-knob-handle': true,
488
- 'range-knob-a': knob === 'A',
489
- 'range-knob-b': knob === 'B',
490
- 'range-knob-pressed': pressed,
491
- 'range-knob-min': value === min,
492
- 'range-knob-max': value === max,
493
- }, style: knobStyle(), role: "slider", tabindex: disabled ? -1 : 0, "aria-label": labelText, "aria-valuemin": min, "aria-valuemax": max, "aria-disabled": disabled ? 'true' : null, "aria-valuenow": value }, pin && (h("div", { class: "range-pin", role: "presentation", part: "pin" }, pinFormatter(value))), h("div", { class: "range-knob", role: "presentation", part: "knob" })));
494
- };
495
- const ratioToValue = (ratio, min, max, step) => {
496
- let value = (max - min) * ratio;
497
- if (step > 0) {
498
- value = Math.round(value / step) * step + min;
499
- }
500
- return clamp(min, value, max);
501
- };
502
- const valueToRatio = (value, min, max) => {
503
- return clamp(0, (value - min) / (max - min), 1);
504
- };
505
- let rangeIds = 0;
506
- Range.style = {
507
- ios: rangeIosCss,
508
- md: rangeMdCss
509
- };
510
-
511
- export { Range as ion_range };
@@ -1,20 +0,0 @@
1
- import { r as registerInstance, h, H as Host } from './index-9db08224.js';
2
- import { g as getIonMode } from './ionic-global-293e882b.js';
3
- import { c as createColorClasses } from './theme-7ef00c83.js';
4
-
5
- const textCss = ":host(.ion-color){color:var(--ion-color-base)}";
6
-
7
- const Text = class {
8
- constructor(hostRef) {
9
- registerInstance(this, hostRef);
10
- }
11
- render() {
12
- const mode = getIonMode(this);
13
- return (h(Host, { class: createColorClasses(this.color, {
14
- [mode]: true,
15
- }) }, h("slot", null)));
16
- }
17
- };
18
- Text.style = textCss;
19
-
20
- export { Text as ion_text };