ku4web-components 6.4.84 → 6.4.88

Sign up to get free protection for your applications and to get access to all the features.
Files changed (279) hide show
  1. package/angular/index.js +1 -1
  2. package/angular/index.mjs +1 -1
  3. package/dist/cjs/index-57e2cfa5.js +10 -0
  4. package/dist/cjs/{index-a7b6d98c.js → index-845c56d4.js} +1 -1
  5. package/dist/cjs/ku4-carousel-controls.cjs.entry.js +3 -3
  6. package/dist/cjs/ku4-carousel-slide.cjs.entry.js +1 -1
  7. package/dist/cjs/ku4-carousel.cjs.entry.js +3 -3
  8. package/dist/cjs/ku4-col.cjs.entry.js +1 -1
  9. package/dist/cjs/ku4-drawer.cjs.entry.js +1 -1
  10. package/dist/cjs/ku4-feature.cjs.entry.js +2 -2
  11. package/dist/cjs/ku4-focus-trap.cjs.entry.js +37 -37
  12. package/dist/cjs/ku4-form.cjs.entry.js +3 -3
  13. package/dist/cjs/ku4-grid.cjs.entry.js +1 -1
  14. package/dist/cjs/ku4-label.cjs.entry.js +2 -2
  15. package/dist/cjs/ku4-mask.cjs.entry.js +3 -3
  16. package/dist/cjs/ku4-modal.cjs.entry.js +9 -4
  17. package/dist/cjs/ku4-panel.cjs.entry.js +1 -1
  18. package/dist/cjs/ku4-preview.cjs.entry.js +14 -43
  19. package/dist/cjs/ku4-tab-list.cjs.entry.js +4 -4
  20. package/dist/cjs/ku4-tab-panel.cjs.entry.js +3 -3
  21. package/dist/cjs/ku4-tab.cjs.entry.js +3 -3
  22. package/dist/cjs/ku4-table.cjs.entry.js +1 -1
  23. package/dist/cjs/ku4-tooltip.cjs.entry.js +2 -2
  24. package/dist/cjs/ku4-validation.cjs.entry.js +2 -2
  25. package/dist/cjs/ku4web-components.cjs.js +8 -103
  26. package/dist/cjs/loader.cjs.js +3 -19
  27. package/dist/cjs/{shadow-css-78860e39.js → shadow-css-546083ef.js} +1 -1
  28. package/dist/esm/{index-81a98b72.js → index-45c399b0.js} +1 -1
  29. package/dist/esm/index-f9890388.js +3 -0
  30. package/dist/esm/ku4-carousel-controls.entry.js +3 -3
  31. package/dist/esm/ku4-carousel-slide.entry.js +1 -1
  32. package/dist/esm/ku4-carousel.entry.js +3 -3
  33. package/dist/esm/ku4-col.entry.js +1 -1
  34. package/dist/esm/ku4-drawer.entry.js +1 -1
  35. package/dist/esm/ku4-feature.entry.js +2 -2
  36. package/dist/esm/ku4-focus-trap.entry.js +14 -14
  37. package/dist/esm/ku4-form.entry.js +3 -3
  38. package/dist/esm/ku4-grid.entry.js +1 -1
  39. package/dist/esm/ku4-label.entry.js +2 -2
  40. package/dist/esm/ku4-mask.entry.js +3 -3
  41. package/dist/esm/ku4-modal.entry.js +9 -4
  42. package/dist/esm/ku4-panel.entry.js +1 -1
  43. package/dist/esm/ku4-preview.entry.js +5 -34
  44. package/dist/esm/ku4-tab-list.entry.js +4 -4
  45. package/dist/esm/ku4-tab-panel.entry.js +3 -3
  46. package/dist/esm/ku4-tab.entry.js +3 -3
  47. package/dist/esm/ku4-table.entry.js +1 -1
  48. package/dist/esm/ku4-tooltip.entry.js +2 -2
  49. package/dist/esm/ku4-validation.entry.js +2 -2
  50. package/dist/esm/ku4web-components.js +8 -103
  51. package/dist/esm/loader.js +3 -19
  52. package/dist/esm/polyfills/css-shim.js +1 -1
  53. package/dist/{ku4web-components/shadow-css-4d56fa31.js → esm/shadow-css-dfa0587f.js} +1 -1
  54. package/dist/esm-es5/{index-81a98b72.js → index-45c399b0.js} +1 -1
  55. package/dist/esm-es5/{index-316624d1.js → index-f9890388.js} +1 -1
  56. package/dist/esm-es5/ku4-carousel-controls.entry.js +1 -1
  57. package/dist/esm-es5/ku4-carousel-slide.entry.js +1 -1
  58. package/dist/esm-es5/ku4-carousel.entry.js +1 -1
  59. package/dist/esm-es5/ku4-col.entry.js +1 -1
  60. package/dist/esm-es5/ku4-drawer.entry.js +1 -1
  61. package/dist/esm-es5/ku4-feature.entry.js +1 -1
  62. package/dist/esm-es5/ku4-focus-trap.entry.js +1 -1
  63. package/dist/esm-es5/ku4-form.entry.js +1 -1
  64. package/dist/esm-es5/ku4-grid.entry.js +1 -1
  65. package/dist/esm-es5/ku4-label.entry.js +1 -1
  66. package/dist/esm-es5/ku4-mask.entry.js +1 -1
  67. package/dist/esm-es5/ku4-modal.entry.js +1 -1
  68. package/dist/esm-es5/ku4-panel.entry.js +1 -1
  69. package/dist/esm-es5/ku4-preview.entry.js +1 -1
  70. package/dist/esm-es5/ku4-tab-list.entry.js +1 -1
  71. package/dist/esm-es5/ku4-tab-panel.entry.js +1 -1
  72. package/dist/esm-es5/ku4-tab.entry.js +1 -1
  73. package/dist/esm-es5/ku4-table.entry.js +1 -1
  74. package/dist/esm-es5/ku4-tooltip.entry.js +1 -1
  75. package/dist/esm-es5/ku4-validation.entry.js +1 -1
  76. package/dist/esm-es5/ku4web-components.js +1 -1
  77. package/dist/esm-es5/loader.js +1 -1
  78. package/dist/esm-es5/{shadow-css-4d56fa31.js → shadow-css-dfa0587f.js} +0 -0
  79. package/dist/index.js +1 -1
  80. package/dist/ku4web-components/index.esm.js +0 -1
  81. package/dist/ku4web-components/ku4web-components.css +1 -299
  82. package/dist/ku4web-components/ku4web-components.esm.js +1 -129
  83. package/dist/ku4web-components/ku4web-components.js +1 -1
  84. package/dist/ku4web-components/{p-6a5a7d81.entry.js → p-005353c6.entry.js} +1 -1
  85. package/dist/ku4web-components/{p-66b8247f.entry.js → p-09f09ad6.entry.js} +1 -1
  86. package/dist/ku4web-components/{p-6b9e3523.system.entry.js → p-09f10910.system.entry.js} +1 -1
  87. package/dist/ku4web-components/p-11652204.entry.js +1 -0
  88. package/dist/ku4web-components/{p-c96a424d.entry.js → p-1380f375.entry.js} +1 -1
  89. package/dist/ku4web-components/p-16f6027a.js +1 -0
  90. package/dist/ku4web-components/{p-8427534d.system.entry.js → p-1cdd4c7f.system.entry.js} +1 -1
  91. package/dist/ku4web-components/{p-61214088.entry.js → p-1fbc37de.entry.js} +1 -1
  92. package/dist/ku4web-components/{p-96b69344.entry.js → p-20d3e65d.entry.js} +1 -1
  93. package/dist/ku4web-components/{p-6cfd9011.system.entry.js → p-24bf4b99.system.entry.js} +1 -1
  94. package/dist/ku4web-components/p-2da41fcc.entry.js +1 -0
  95. package/dist/ku4web-components/p-371ff218.entry.js +1 -0
  96. package/dist/ku4web-components/{p-7bfc256a.system.entry.js → p-3b70ff65.system.entry.js} +1 -1
  97. package/dist/ku4web-components/{p-e6b3a708.js → p-42dd73f2.js} +1 -1
  98. package/dist/ku4web-components/{p-0f03feb6.system.entry.js → p-4d4d3cc4.system.entry.js} +1 -1
  99. package/dist/ku4web-components/{p-073cefec.system.entry.js → p-53605e68.system.entry.js} +1 -1
  100. package/dist/ku4web-components/{p-91aa94d4.system.entry.js → p-5a6bad52.system.entry.js} +1 -1
  101. package/dist/ku4web-components/{p-881e100a.js → p-5e796581.js} +0 -0
  102. package/dist/ku4web-components/{p-10198308.system.entry.js → p-689b87db.system.entry.js} +1 -1
  103. package/dist/ku4web-components/p-6dad23e0.entry.js +1 -0
  104. package/dist/ku4web-components/{p-f3aedfdb.system.entry.js → p-72066e9d.system.entry.js} +1 -1
  105. package/dist/ku4web-components/{p-f3fbe1e6.entry.js → p-72219668.entry.js} +1 -1
  106. package/dist/ku4web-components/{p-2b3bb150.system.entry.js → p-774dbc9e.system.entry.js} +1 -1
  107. package/dist/ku4web-components/{p-96eccb13.system.entry.js → p-782336cd.system.entry.js} +1 -1
  108. package/dist/ku4web-components/{p-96ec7b4f.system.js → p-829fb4ce.system.js} +1 -1
  109. package/dist/ku4web-components/{p-9d241b2a.entry.js → p-8583d382.entry.js} +1 -1
  110. package/dist/ku4web-components/{p-99854682.system.entry.js → p-895853ef.system.entry.js} +1 -1
  111. package/dist/ku4web-components/{p-fbf3ad1e.system.js → p-8b2d8a2a.system.js} +0 -0
  112. package/dist/ku4web-components/{p-ecf7b1be.system.entry.js → p-97d806d2.system.entry.js} +1 -1
  113. package/dist/ku4web-components/{p-288482da.system.entry.js → p-9ba0f967.system.entry.js} +1 -1
  114. package/dist/ku4web-components/{p-bd251367.entry.js → p-a0dc0327.entry.js} +1 -1
  115. package/dist/ku4web-components/{p-6a40ccaa.entry.js → p-a5f54bc0.entry.js} +1 -1
  116. package/dist/ku4web-components/{p-d848909c.system.entry.js → p-a61f7c42.system.entry.js} +1 -1
  117. package/dist/ku4web-components/{p-47dc2714.entry.js → p-abcf4c43.entry.js} +1 -1
  118. package/dist/ku4web-components/{p-7ed66688.system.entry.js → p-b02eb970.system.entry.js} +1 -1
  119. package/dist/ku4web-components/{p-9bf34cc7.system.entry.js → p-bd83ef31.system.entry.js} +1 -1
  120. package/dist/ku4web-components/{p-c4479d3b.system.entry.js → p-d57468ab.system.entry.js} +1 -1
  121. package/dist/ku4web-components/p-d66b1c43.system.js +1 -0
  122. package/dist/ku4web-components/{p-579ff41b.system.entry.js → p-e550fd09.system.entry.js} +1 -1
  123. package/dist/ku4web-components/{p-3f2a008c.entry.js → p-e8d5dcce.entry.js} +1 -1
  124. package/dist/ku4web-components/p-eace33d2.system.entry.js +1 -0
  125. package/dist/ku4web-components/{p-320e2fe0.entry.js → p-ecf06d64.entry.js} +1 -1
  126. package/dist/ku4web-components/{p-5eadf115.entry.js → p-edfa2aea.entry.js} +1 -1
  127. package/dist/ku4web-components/{p-c798faf2.entry.js → p-f2a603c3.entry.js} +1 -1
  128. package/dist/ku4web-components/p-f6b9d36e.entry.js +1 -0
  129. package/dist/ku4web-components/{p-a352f533.system.js → p-f8a2bf9b.system.js} +1 -1
  130. package/dist/ku4web-components/{p-3f147a02.entry.js → p-fd6bcdde.entry.js} +1 -1
  131. package/dist/types/components/ku4-modal/ku4-modal.d.ts +5 -0
  132. package/dist/types/components.d.ts +10 -2
  133. package/package.json +31 -31
  134. package/react/index.js +1 -1
  135. package/react/index.mjs +1 -1
  136. package/vue/index.js +1 -1
  137. package/vue/index.mjs +1 -1
  138. package/vue3/index.js +1 -1
  139. package/vue3/index.mjs +1 -1
  140. package/dist/cjs/app-globals-3a1e7e63.js +0 -5
  141. package/dist/cjs/css-shim-6ca600c2.js +0 -6
  142. package/dist/cjs/dom-8d415461.js +0 -75
  143. package/dist/cjs/index-517c4086.js +0 -14
  144. package/dist/cjs/index-a530dbc9.js +0 -10
  145. package/dist/cjs/index-c904eb3a.js +0 -10
  146. package/dist/cjs/index-ca4336bd.js +0 -3093
  147. package/dist/cjs/uid-8ec2f63e.js +0 -11
  148. package/dist/collection/capabilities/a11y/aria.js +0 -26
  149. package/dist/collection/capabilities/angular/index.js +0 -24
  150. package/dist/collection/capabilities/decorators/deprecated.js +0 -20
  151. package/dist/collection/capabilities/decorators/index.js +0 -3
  152. package/dist/collection/capabilities/decorators/memoize.js +0 -7
  153. package/dist/collection/capabilities/dom/isFocusable.js +0 -7
  154. package/dist/collection/capabilities/dom/queryFocusable.js +0 -2
  155. package/dist/collection/capabilities/identity/uid.js +0 -6
  156. package/dist/collection/capabilities/mask/index.js +0 -5
  157. package/dist/collection/capabilities/mask/patterns/date.js +0 -40
  158. package/dist/collection/capabilities/mask/patterns/index.js +0 -7
  159. package/dist/collection/capabilities/react/index.js +0 -25
  160. package/dist/collection/capabilities/testing/html.js +0 -14
  161. package/dist/collection/capabilities/testing/styles.js +0 -14
  162. package/dist/collection/capabilities/vue/index.js +0 -28
  163. package/dist/collection/capabilities/vue3/index.js +0 -26
  164. package/dist/collection/collection-manifest.json +0 -31
  165. package/dist/collection/components/ku4-carousel/ku4-carousel.css +0 -221
  166. package/dist/collection/components/ku4-carousel/ku4-carousel.js +0 -369
  167. package/dist/collection/components/ku4-carousel-controls/ku4-carousel-controls.css +0 -32
  168. package/dist/collection/components/ku4-carousel-controls/ku4-carousel-controls.js +0 -112
  169. package/dist/collection/components/ku4-carousel-slide/ku4-carousel-slide.css +0 -3
  170. package/dist/collection/components/ku4-carousel-slide/ku4-carousel-slide.js +0 -159
  171. package/dist/collection/components/ku4-col/ku4-col.css +0 -601
  172. package/dist/collection/components/ku4-col/ku4-col.js +0 -288
  173. package/dist/collection/components/ku4-drawer/ku4-drawer.css +0 -56
  174. package/dist/collection/components/ku4-drawer/ku4-drawer.js +0 -163
  175. package/dist/collection/components/ku4-feature/ku4-feature.js +0 -70
  176. package/dist/collection/components/ku4-focus-trap/ku4-focus-trap.css +0 -3
  177. package/dist/collection/components/ku4-focus-trap/ku4-focus-trap.js +0 -441
  178. package/dist/collection/components/ku4-form/ku4-form.js +0 -225
  179. package/dist/collection/components/ku4-grid/ku4-grid.css +0 -751
  180. package/dist/collection/components/ku4-grid/ku4-grid.js +0 -408
  181. package/dist/collection/components/ku4-label/ku4-label.css +0 -36
  182. package/dist/collection/components/ku4-label/ku4-label.js +0 -115
  183. package/dist/collection/components/ku4-mask/ku4-mask.css +0 -3
  184. package/dist/collection/components/ku4-mask/ku4-mask.js +0 -458
  185. package/dist/collection/components/ku4-modal/ku4-modal.css +0 -85
  186. package/dist/collection/components/ku4-modal/ku4-modal.js +0 -208
  187. package/dist/collection/components/ku4-panel/ku4-panel.css +0 -14
  188. package/dist/collection/components/ku4-panel/ku4-panel.js +0 -119
  189. package/dist/collection/components/ku4-preview/ku4-preview.css +0 -23
  190. package/dist/collection/components/ku4-preview/ku4-preview.js +0 -266
  191. package/dist/collection/components/ku4-tab/ku4-tab.css +0 -82
  192. package/dist/collection/components/ku4-tab/ku4-tab.js +0 -191
  193. package/dist/collection/components/ku4-tab-list/ku4-tab-list.css +0 -6
  194. package/dist/collection/components/ku4-tab-list/ku4-tab-list.js +0 -118
  195. package/dist/collection/components/ku4-tab-panel/ku4-tab-panel.css +0 -26
  196. package/dist/collection/components/ku4-tab-panel/ku4-tab-panel.js +0 -166
  197. package/dist/collection/components/ku4-table/ku4-table.css +0 -116
  198. package/dist/collection/components/ku4-table/ku4-table.js +0 -120
  199. package/dist/collection/components/ku4-tooltip/ku4-tooltip.css +0 -56
  200. package/dist/collection/components/ku4-tooltip/ku4-tooltip.js +0 -274
  201. package/dist/collection/components/ku4-validation/ku4-validation.css +0 -19
  202. package/dist/collection/components/ku4-validation/ku4-validation.js +0 -364
  203. package/dist/collection/components/ku4-validation/validate.js +0 -14
  204. package/dist/collection/index.js +0 -1
  205. package/dist/collection/security.js +0 -27
  206. package/dist/esm/app-globals-0f993ce5.js +0 -3
  207. package/dist/esm/css-shim-e6dd2538.js +0 -4
  208. package/dist/esm/dom-7fc649b0.js +0 -73
  209. package/dist/esm/index-135dacad.js +0 -3
  210. package/dist/esm/index-316624d1.js +0 -3
  211. package/dist/esm/index-7fe386de.js +0 -3057
  212. package/dist/esm/index-7ff6e718.js +0 -3
  213. package/dist/esm/shadow-css-4d56fa31.js +0 -388
  214. package/dist/esm/uid-a7ff854d.js +0 -9
  215. package/dist/ku4web-components/app-globals-0f993ce5.js +0 -3
  216. package/dist/ku4web-components/app-globals-497eb362.system.js +0 -1
  217. package/dist/ku4web-components/css-shim-b6eec689.system.js +0 -1
  218. package/dist/ku4web-components/css-shim-e6dd2538.js +0 -4
  219. package/dist/ku4web-components/dom-7fc649b0.js +0 -73
  220. package/dist/ku4web-components/dom-88962da0.system.js +0 -21
  221. package/dist/ku4web-components/index-135dacad.js +0 -3
  222. package/dist/ku4web-components/index-5029fd1f.system.js +0 -1
  223. package/dist/ku4web-components/index-7d482e8a.system.js +0 -1
  224. package/dist/ku4web-components/index-7fe386de.js +0 -3057
  225. package/dist/ku4web-components/index-7ff6e718.js +0 -3
  226. package/dist/ku4web-components/index-dcd9a8a7.system.js +0 -1
  227. package/dist/ku4web-components/index.system.js +0 -1
  228. package/dist/ku4web-components/ku4-carousel-controls.entry.js +0 -89
  229. package/dist/ku4web-components/ku4-carousel-controls.system.entry.js +0 -1
  230. package/dist/ku4web-components/ku4-carousel-slide.entry.js +0 -47
  231. package/dist/ku4web-components/ku4-carousel-slide.system.entry.js +0 -1
  232. package/dist/ku4web-components/ku4-carousel.entry.js +0 -175
  233. package/dist/ku4web-components/ku4-carousel.system.entry.js +0 -1
  234. package/dist/ku4web-components/ku4-col.entry.js +0 -75
  235. package/dist/ku4web-components/ku4-col.system.entry.js +0 -1
  236. package/dist/ku4web-components/ku4-drawer.entry.js +0 -35
  237. package/dist/ku4web-components/ku4-drawer.system.entry.js +0 -1
  238. package/dist/ku4web-components/ku4-feature.entry.js +0 -29
  239. package/dist/ku4web-components/ku4-feature.system.entry.js +0 -1
  240. package/dist/ku4web-components/ku4-focus-trap.entry.js +0 -323
  241. package/dist/ku4web-components/ku4-focus-trap.system.entry.js +0 -1
  242. package/dist/ku4web-components/ku4-form.entry.js +0 -112
  243. package/dist/ku4web-components/ku4-form.system.entry.js +0 -1
  244. package/dist/ku4web-components/ku4-grid.entry.js +0 -108
  245. package/dist/ku4web-components/ku4-grid.system.entry.js +0 -1
  246. package/dist/ku4web-components/ku4-label.entry.js +0 -70
  247. package/dist/ku4web-components/ku4-label.system.entry.js +0 -1
  248. package/dist/ku4web-components/ku4-mask.entry.js +0 -342
  249. package/dist/ku4web-components/ku4-mask.system.entry.js +0 -1
  250. package/dist/ku4web-components/ku4-modal.entry.js +0 -75
  251. package/dist/ku4web-components/ku4-modal.system.entry.js +0 -1
  252. package/dist/ku4web-components/ku4-panel.entry.js +0 -49
  253. package/dist/ku4web-components/ku4-panel.system.entry.js +0 -1
  254. package/dist/ku4web-components/ku4-preview.entry.js +0 -128
  255. package/dist/ku4web-components/ku4-preview.system.entry.js +0 -1
  256. package/dist/ku4web-components/ku4-tab-list.entry.js +0 -76
  257. package/dist/ku4web-components/ku4-tab-list.system.entry.js +0 -1
  258. package/dist/ku4web-components/ku4-tab-panel.entry.js +0 -72
  259. package/dist/ku4web-components/ku4-tab-panel.system.entry.js +0 -1
  260. package/dist/ku4web-components/ku4-tab.entry.js +0 -63
  261. package/dist/ku4web-components/ku4-tab.system.entry.js +0 -1
  262. package/dist/ku4web-components/ku4-table.entry.js +0 -79
  263. package/dist/ku4web-components/ku4-table.system.entry.js +0 -1
  264. package/dist/ku4web-components/ku4-tooltip.entry.js +0 -120
  265. package/dist/ku4web-components/ku4-tooltip.system.entry.js +0 -1
  266. package/dist/ku4web-components/ku4-validation.entry.js +0 -162
  267. package/dist/ku4web-components/ku4-validation.system.entry.js +0 -1
  268. package/dist/ku4web-components/ku4web-components.system.js +0 -1
  269. package/dist/ku4web-components/p-0f77bef9.system.js +0 -1
  270. package/dist/ku4web-components/p-171182e4.entry.js +0 -1
  271. package/dist/ku4web-components/p-7e69d158.entry.js +0 -1
  272. package/dist/ku4web-components/p-9da3612f.entry.js +0 -1
  273. package/dist/ku4web-components/p-b3c3b463.entry.js +0 -1
  274. package/dist/ku4web-components/p-b3c3d932.entry.js +0 -1
  275. package/dist/ku4web-components/p-ba9edd72.js +0 -1
  276. package/dist/ku4web-components/p-e356b3c1.system.entry.js +0 -1
  277. package/dist/ku4web-components/shadow-css-d0426811.system.js +0 -13
  278. package/dist/ku4web-components/uid-3373ce49.system.js +0 -1
  279. package/dist/ku4web-components/uid-a7ff854d.js +0 -9
@@ -1,369 +0,0 @@
1
- import { Component, Host, Prop, State, Method, Element, h, Event } from '@stencil/core';
2
- import { Rolodex, Interval, wait } from 'ku4es-kernel';
3
- import { Swipe } from 'ku4es-ui-kernel';
4
- /**
5
- * @description ku4-carousel
6
- */
7
- export class Ku4Carousel {
8
- constructor() {
9
- /**
10
- * Sets the distance, in pixels, a touch must travel
11
- * before activating a swipe.
12
- */
13
- this.swipeTolerance = 44;
14
- /**
15
- * Will start this carousel in auto scroll mode
16
- */
17
- this.auto = false;
18
- /**
19
- * Prevents touch swiping
20
- */
21
- this.noSwipe = false;
22
- /**
23
- * Delay in millisecond between slide changes
24
- * when running in auto
25
- */
26
- this.delay = 8000;
27
- this.interval = new Interval(this.delay).onInterval(() => {
28
- if (this.host.isConnected) {
29
- this.display('next');
30
- }
31
- else {
32
- this.disconnectedCallback();
33
- }
34
- });
35
- this.handleMouse = this.handleMouse.bind(this);
36
- }
37
- /**
38
- * Display the next ku4-carousel-slide
39
- */
40
- async next() {
41
- if (!this.hasSlides) {
42
- return this;
43
- }
44
- await this.pause();
45
- return this.display('next');
46
- }
47
- /**
48
- * Display the previous ku4-carousel-slide
49
- */
50
- async previous() {
51
- if (!this.hasSlides) {
52
- return this;
53
- }
54
- await this.pause();
55
- return this.display('prev');
56
- }
57
- /**
58
- * Slide to the slide number specified.
59
- * @param {number|string} slide - Slide number or slide name to slide to.
60
- */
61
- async slideTo(slide) {
62
- await this.pause();
63
- const { slides } = this;
64
- const value = isNaN(slide)
65
- ? slides.findIndex(s => s.getAttribute('name') === slide) + 1
66
- : parseInt(slide);
67
- if (!(value === this.currentSlideNumber || value < 1 || this.rolodex.length < value)) {
68
- const move = value - this.currentSlideNumber;
69
- const slide = move < 0 ? 'prev' : 'next';
70
- let count = Math.abs(move);
71
- while (0 < --count) {
72
- await wait(10).then(() => this.rolodex[slide]);
73
- }
74
- this.display(slide);
75
- }
76
- }
77
- /**
78
- * Pause auto slide change
79
- */
80
- async pause() {
81
- this.interval.clear();
82
- }
83
- /**
84
- * Start auto slide change
85
- */
86
- async play() {
87
- const { auto, interval } = this;
88
- auto && interval.start();
89
- }
90
- get slides() {
91
- return [].slice.call(this.host.children);
92
- }
93
- get hasSlides() {
94
- return this.rolodex && (this.rolodex.length > 1);
95
- }
96
- get currentSlideNumber() {
97
- const { rolodex } = this;
98
- return rolodex && (rolodex.isEmpty ? 0 : rolodex.index + 1);
99
- }
100
- display(slide) {
101
- window.requestAnimationFrame(() => {
102
- const { previous, current } = this.slideState;
103
- const next = this.rolodex[slide];
104
- if (previous) {
105
- previous.deactivate();
106
- }
107
- current.slideOut(slide);
108
- next.slideIn(slide);
109
- this.slideState = {
110
- previous: current,
111
- current: next,
112
- };
113
- this.didSlide.emit(this.currentSlideNumber);
114
- });
115
- return this;
116
- }
117
- handleMouse(e) {
118
- if (!this.host.contains(e.relatedTarget)) {
119
- this.play();
120
- }
121
- }
122
- componentWillLoad() {
123
- if (!this.noSwipe) {
124
- this.swipe = new Swipe(this.host, this.swipeTolerance)
125
- .onLeft(() => this.next())
126
- .onRight(() => this.previous());
127
- }
128
- let slides;
129
- try {
130
- slides = this.host.querySelectorAll(':scope > ku4-carousel-slide');
131
- }
132
- catch (e) {
133
- slides = [].slice.call(this.host.querySelectorAll('ku4-carousel-slide'))
134
- .reduce((acc, item) => {
135
- if (item.parentNode === this.host) {
136
- acc.push(item);
137
- }
138
- return acc;
139
- }, []);
140
- }
141
- this.rolodex = new Rolodex(slides);
142
- (this.rolodex.current &&
143
- this.rolodex.current.activate) &&
144
- this.rolodex.current.activate();
145
- this.slideState = { current: this.rolodex.current };
146
- if (this.auto) {
147
- this.host.addEventListener('mouseout', this.handleMouse);
148
- this.play();
149
- }
150
- }
151
- connectedCallback() {
152
- if (this.swipe) {
153
- this.swipe.destroy();
154
- }
155
- this.host.removeEventListener('mouseout', this.handleMouse);
156
- this.interval.clear();
157
- }
158
- disconnectedCallback() {
159
- if (this.swipe) {
160
- this.swipe.destroy();
161
- }
162
- this.host.removeEventListener('mouseout', this.handleMouse);
163
- this.interval.clear();
164
- }
165
- render() {
166
- const { hasSlides, currentSlideNumber = 1 } = this;
167
- return (h(Host, { "aria-roledescription": "carousel", current: currentSlideNumber },
168
- hasSlides && (h("section", { class: "controls" },
169
- h("button", { type: "button", class: "prev", onClick: () => this.previous(), "aria-label": "previous slide" }),
170
- h("button", { type: "button", class: "next", onClick: () => this.next(), "aria-label": "next slide" }))),
171
- h("section", { class: "slide-container", "aria-live": "polite" },
172
- h("slot", null)),
173
- hasSlides && (h("section", { class: "pages" },
174
- h("span", { class: "pages-text" }, `${currentSlideNumber} of ${this.rolodex.length}`)))));
175
- }
176
- static get is() { return "ku4-carousel"; }
177
- static get encapsulation() { return "shadow"; }
178
- static get originalStyleUrls() { return {
179
- "$": ["ku4-carousel.scss"]
180
- }; }
181
- static get styleUrls() { return {
182
- "$": ["ku4-carousel.css"]
183
- }; }
184
- static get properties() { return {
185
- "swipeTolerance": {
186
- "type": "number",
187
- "mutable": false,
188
- "complexType": {
189
- "original": "number",
190
- "resolved": "number",
191
- "references": {}
192
- },
193
- "required": false,
194
- "optional": false,
195
- "docs": {
196
- "tags": [],
197
- "text": "Sets the distance, in pixels, a touch must travel\nbefore activating a swipe."
198
- },
199
- "attribute": "swipe-tolerance",
200
- "reflect": false,
201
- "defaultValue": "44"
202
- },
203
- "auto": {
204
- "type": "boolean",
205
- "mutable": false,
206
- "complexType": {
207
- "original": "boolean",
208
- "resolved": "boolean",
209
- "references": {}
210
- },
211
- "required": false,
212
- "optional": false,
213
- "docs": {
214
- "tags": [],
215
- "text": "Will start this carousel in auto scroll mode"
216
- },
217
- "attribute": "auto",
218
- "reflect": false,
219
- "defaultValue": "false"
220
- },
221
- "noSwipe": {
222
- "type": "boolean",
223
- "mutable": false,
224
- "complexType": {
225
- "original": "boolean",
226
- "resolved": "boolean",
227
- "references": {}
228
- },
229
- "required": false,
230
- "optional": false,
231
- "docs": {
232
- "tags": [],
233
- "text": "Prevents touch swiping"
234
- },
235
- "attribute": "no-swipe",
236
- "reflect": false,
237
- "defaultValue": "false"
238
- },
239
- "delay": {
240
- "type": "number",
241
- "mutable": false,
242
- "complexType": {
243
- "original": "number",
244
- "resolved": "number",
245
- "references": {}
246
- },
247
- "required": false,
248
- "optional": false,
249
- "docs": {
250
- "tags": [],
251
- "text": "Delay in millisecond between slide changes\nwhen running in auto"
252
- },
253
- "attribute": "delay",
254
- "reflect": false,
255
- "defaultValue": "8000"
256
- }
257
- }; }
258
- static get states() { return {
259
- "slideState": {}
260
- }; }
261
- static get events() { return [{
262
- "method": "didSlide",
263
- "name": "slide",
264
- "bubbles": true,
265
- "cancelable": true,
266
- "composed": true,
267
- "docs": {
268
- "tags": [],
269
- "text": "Event fired when slide changes"
270
- },
271
- "complexType": {
272
- "original": "any",
273
- "resolved": "any",
274
- "references": {}
275
- }
276
- }]; }
277
- static get methods() { return {
278
- "next": {
279
- "complexType": {
280
- "signature": "() => Promise<this>",
281
- "parameters": [],
282
- "references": {
283
- "Promise": {
284
- "location": "global"
285
- }
286
- },
287
- "return": "Promise<this>"
288
- },
289
- "docs": {
290
- "text": "Display the next ku4-carousel-slide",
291
- "tags": []
292
- }
293
- },
294
- "previous": {
295
- "complexType": {
296
- "signature": "() => Promise<this>",
297
- "parameters": [],
298
- "references": {
299
- "Promise": {
300
- "location": "global"
301
- }
302
- },
303
- "return": "Promise<this>"
304
- },
305
- "docs": {
306
- "text": "Display the previous ku4-carousel-slide",
307
- "tags": []
308
- }
309
- },
310
- "slideTo": {
311
- "complexType": {
312
- "signature": "(slide: any) => Promise<void>",
313
- "parameters": [{
314
- "tags": [{
315
- "name": "param",
316
- "text": "slide - Slide number or slide name to slide to."
317
- }],
318
- "text": "- Slide number or slide name to slide to."
319
- }],
320
- "references": {
321
- "Promise": {
322
- "location": "global"
323
- }
324
- },
325
- "return": "Promise<void>"
326
- },
327
- "docs": {
328
- "text": "Slide to the slide number specified.",
329
- "tags": [{
330
- "name": "param",
331
- "text": "slide - Slide number or slide name to slide to."
332
- }]
333
- }
334
- },
335
- "pause": {
336
- "complexType": {
337
- "signature": "() => Promise<void>",
338
- "parameters": [],
339
- "references": {
340
- "Promise": {
341
- "location": "global"
342
- }
343
- },
344
- "return": "Promise<void>"
345
- },
346
- "docs": {
347
- "text": "Pause auto slide change",
348
- "tags": []
349
- }
350
- },
351
- "play": {
352
- "complexType": {
353
- "signature": "() => Promise<void>",
354
- "parameters": [],
355
- "references": {
356
- "Promise": {
357
- "location": "global"
358
- }
359
- },
360
- "return": "Promise<void>"
361
- },
362
- "docs": {
363
- "text": "Start auto slide change",
364
- "tags": []
365
- }
366
- }
367
- }; }
368
- static get elementRef() { return "host"; }
369
- }
@@ -1,32 +0,0 @@
1
- :host {
2
- position: relative;
3
- display: block;
4
- }
5
-
6
- input[type=radio] {
7
- appearance: none;
8
- position: relative;
9
- width: 20px;
10
- height: 20px;
11
- margin: 0;
12
- padding: 0;
13
- border: solid 1px #888;
14
- border-radius: 50%;
15
- box-sizing: border-box;
16
- vertical-align: middle;
17
- }
18
- input[type=radio]:checked:after {
19
- content: "";
20
- position: absolute;
21
- top: 2px;
22
- left: 2px;
23
- width: 14px;
24
- height: 14px;
25
- margin: 0;
26
- padding: 0;
27
- border: solid 1px #888;
28
- border-radius: 50%;
29
- box-sizing: border-box;
30
- text-align: center;
31
- background-color: #333;
32
- }
@@ -1,112 +0,0 @@
1
- import { Component, Prop, Element, h } from '@stencil/core';
2
- import { Assert } from 'ku4es-kernel';
3
- /**
4
- * @description ku4-carousel-controls
5
- */
6
- export class Ku4CarouselControls {
7
- constructor() {
8
- this.carousel = document.getElementById(this.for);
9
- this.handleSlide = this.handleSlide.bind(this);
10
- this.handleChange = this.handleChange.bind(this);
11
- }
12
- get slides() {
13
- return [].slice.call(this.carousel.children);
14
- }
15
- get controls() {
16
- return [].slice.call(this.host.children);
17
- }
18
- handleSlide(e) {
19
- this.controls.forEach((control) => {
20
- control.removeAttribute('current');
21
- control.checked = false;
22
- });
23
- try {
24
- const current = this.controls[e.detail - 1];
25
- current.setAttribute('current', e.detail);
26
- current.checked = true;
27
- }
28
- catch (e) {
29
- /* Fail silently */
30
- }
31
- }
32
- async handleChange(e) {
33
- const { carousel, slides, controls } = this;
34
- const slideValue = e.target.getAttribute('slide');
35
- const n = isNaN(slideValue)
36
- ? slides.findIndex(slide => slide.getAttribute('name') === slideValue) + 1
37
- : parseInt(slideValue);
38
- const slide = isNaN(n) ? controls.indexOf(e.target) + 1 : n;
39
- await carousel.slideTo(slide);
40
- try {
41
- e.target.setAttribute('current', slide);
42
- }
43
- catch (e) {
44
- /* Fail silently */
45
- }
46
- }
47
- componentWillLoad() {
48
- const { carousel, controls } = this;
49
- try {
50
- carousel.addEventListener('slide', this.handleSlide, { passive: true });
51
- controls.forEach((control, i) => {
52
- if (i === 0) {
53
- control.setAttribute('current', i + 1);
54
- }
55
- if (control.nodeName === 'INPUT') {
56
- control.addEventListener('change', this.handleChange);
57
- }
58
- else {
59
- control.addEventListener('keydown', this.handleChange);
60
- control.addEventListener('mousedown', this.handleChange, { passive: true });
61
- control.addEventListener('touchstart', this.handleChange, { passive: true });
62
- }
63
- });
64
- }
65
- catch (e) {
66
- if (!Assert.exists(carousel)) {
67
- throw new ReferenceError('ku4-carousel-controls must connect to a ku4-carousel.');
68
- }
69
- }
70
- }
71
- disconnectedCallback() {
72
- const { carousel, controls } = this;
73
- carousel.removeEventListener('slide', this.handleSlide);
74
- controls.forEach((control) => {
75
- control.removeEventListener('change', this.handleChange);
76
- control.removeEventListener('keydown', this.handleChange);
77
- control.removeEventListener('mousedown', this.handleChange);
78
- control.removeEventListener('touchstart', this.handleChange);
79
- });
80
- }
81
- render() {
82
- return h("slot", null);
83
- }
84
- static get is() { return "ku4-carousel-controls"; }
85
- static get encapsulation() { return "shadow"; }
86
- static get originalStyleUrls() { return {
87
- "$": ["ku4-carousel-controls.scss"]
88
- }; }
89
- static get styleUrls() { return {
90
- "$": ["ku4-carousel-controls.css"]
91
- }; }
92
- static get properties() { return {
93
- "for": {
94
- "type": "string",
95
- "mutable": false,
96
- "complexType": {
97
- "original": "string",
98
- "resolved": "string",
99
- "references": {}
100
- },
101
- "required": false,
102
- "optional": false,
103
- "docs": {
104
- "tags": [],
105
- "text": "Controls for carousel having id of value"
106
- },
107
- "attribute": "for",
108
- "reflect": false
109
- }
110
- }; }
111
- static get elementRef() { return "host"; }
112
- }
@@ -1,3 +0,0 @@
1
- :host {
2
- overflow-x: hidden;
3
- }
@@ -1,159 +0,0 @@
1
- import { Component, Host, State, Method, h, Prop, } from '@stencil/core';
2
- /**
3
- * @description ku4-carousel-slide
4
- */
5
- export class Ku4CarouselSlide {
6
- constructor() {
7
- this.classList = '';
8
- }
9
- /**
10
- * Move this slide in to view.
11
- * @param {string} direction - Direction to move.
12
- */
13
- async slideIn(direction) {
14
- this.active = true;
15
- this.classList = `active ${direction}`;
16
- }
17
- /**
18
- * Move this slide out of view.
19
- * @param {string} direction - Direction to move.
20
- */
21
- async slideOut(direction) {
22
- this.active = false;
23
- this.classList = `inactive ${direction}`;
24
- }
25
- /**
26
- * Set this slide to active.
27
- */
28
- async activate() {
29
- this.active = true;
30
- this.classList = 'active';
31
- }
32
- /**
33
- * Set this slide to inactive.
34
- */
35
- async deactivate() {
36
- this.active = false;
37
- this.classList = '';
38
- }
39
- render() {
40
- const { active, classList } = this;
41
- return (h(Host, { class: `${classList}`, "aria-hidden": active ? 'false' : 'true', "aria-roledescription": "slide" },
42
- h("slot", null)));
43
- }
44
- static get is() { return "ku4-carousel-slide"; }
45
- static get encapsulation() { return "shadow"; }
46
- static get originalStyleUrls() { return {
47
- "$": ["ku4-carousel-slide.scss"]
48
- }; }
49
- static get styleUrls() { return {
50
- "$": ["ku4-carousel-slide.css"]
51
- }; }
52
- static get properties() { return {
53
- "name": {
54
- "type": "any",
55
- "mutable": true,
56
- "complexType": {
57
- "original": "any",
58
- "resolved": "any",
59
- "references": {}
60
- },
61
- "required": false,
62
- "optional": false,
63
- "docs": {
64
- "tags": [],
65
- "text": "Name of slide. The value of this property can be used as the\nvalue of the \"slide\" attribute of a ku4-carousel-control to\ntarget this slide as the active slide for the target ku4-carousel-control"
66
- },
67
- "attribute": "name",
68
- "reflect": true
69
- }
70
- }; }
71
- static get states() { return {
72
- "active": {},
73
- "classList": {}
74
- }; }
75
- static get methods() { return {
76
- "slideIn": {
77
- "complexType": {
78
- "signature": "(direction: 'prev' | 'next') => Promise<void>",
79
- "parameters": [{
80
- "tags": [{
81
- "name": "param",
82
- "text": "direction - Direction to move."
83
- }],
84
- "text": "- Direction to move."
85
- }],
86
- "references": {
87
- "Promise": {
88
- "location": "global"
89
- }
90
- },
91
- "return": "Promise<void>"
92
- },
93
- "docs": {
94
- "text": "Move this slide in to view.",
95
- "tags": [{
96
- "name": "param",
97
- "text": "direction - Direction to move."
98
- }]
99
- }
100
- },
101
- "slideOut": {
102
- "complexType": {
103
- "signature": "(direction: 'prev' | 'next') => Promise<void>",
104
- "parameters": [{
105
- "tags": [{
106
- "name": "param",
107
- "text": "direction - Direction to move."
108
- }],
109
- "text": "- Direction to move."
110
- }],
111
- "references": {
112
- "Promise": {
113
- "location": "global"
114
- }
115
- },
116
- "return": "Promise<void>"
117
- },
118
- "docs": {
119
- "text": "Move this slide out of view.",
120
- "tags": [{
121
- "name": "param",
122
- "text": "direction - Direction to move."
123
- }]
124
- }
125
- },
126
- "activate": {
127
- "complexType": {
128
- "signature": "() => Promise<void>",
129
- "parameters": [],
130
- "references": {
131
- "Promise": {
132
- "location": "global"
133
- }
134
- },
135
- "return": "Promise<void>"
136
- },
137
- "docs": {
138
- "text": "Set this slide to active.",
139
- "tags": []
140
- }
141
- },
142
- "deactivate": {
143
- "complexType": {
144
- "signature": "() => Promise<void>",
145
- "parameters": [],
146
- "references": {
147
- "Promise": {
148
- "location": "global"
149
- }
150
- },
151
- "return": "Promise<void>"
152
- },
153
- "docs": {
154
- "text": "Set this slide to inactive.",
155
- "tags": []
156
- }
157
- }
158
- }; }
159
- }