@nanoporetech-digital/components 7.4.5 → 7.5.1

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 (400) hide show
  1. package/dist/cjs/{algolia-data-7444589a.js → algolia-data-0447757c.js} +2 -2
  2. package/dist/cjs/{algolia-data-7444589a.js.map → algolia-data-0447757c.js.map} +1 -1
  3. package/dist/cjs/app-globals-93d8b419.js.map +1 -1
  4. package/dist/cjs/{component-store-5d69aa2a.js → component-store-6a330cd1.js} +2 -2
  5. package/dist/cjs/{component-store-5d69aa2a.js.map → component-store-6a330cd1.js.map} +1 -1
  6. package/dist/cjs/{dom-9d327924.js → dom-756fcdac.js} +2 -2
  7. package/dist/cjs/{dom-9d327924.js.map → dom-756fcdac.js.map} +1 -1
  8. package/dist/cjs/{fade-7a47badb.js → fade-2dd9dd8b.js} +6 -4
  9. package/dist/cjs/fade-2dd9dd8b.js.map +1 -0
  10. package/dist/cjs/{form-control-574da2db.js → form-control-2d88adb2.js} +2 -2
  11. package/dist/cjs/{form-control-574da2db.js.map → form-control-2d88adb2.js.map} +1 -1
  12. package/dist/cjs/{fullscreen-31e27faa.js → fullscreen-5d0422de.js} +3 -3
  13. package/dist/cjs/{fullscreen-31e27faa.js.map → fullscreen-5d0422de.js.map} +1 -1
  14. package/dist/cjs/{index-7f89ccce.js → index-7795a8f6.js} +5 -6
  15. package/dist/cjs/index-7795a8f6.js.map +1 -0
  16. package/dist/cjs/{index-05605cc8.js → index-b6fa04fa.js} +3 -3
  17. package/dist/cjs/{index-05605cc8.js.map → index-b6fa04fa.js.map} +1 -1
  18. package/dist/cjs/index.cjs.js +2 -0
  19. package/dist/cjs/index.cjs.js.map +1 -1
  20. package/dist/cjs/{lazyload-77a7f763.js → lazyload-f181cb37.js} +3 -3
  21. package/dist/cjs/{lazyload-77a7f763.js.map → lazyload-f181cb37.js.map} +1 -1
  22. package/dist/cjs/loader.cjs.js +2 -2
  23. package/dist/cjs/nano-accordion.cjs.entry.js +2 -2
  24. package/dist/cjs/nano-alert.cjs.entry.js +3 -3
  25. package/dist/cjs/nano-algolia-filter.cjs.entry.js +3 -3
  26. package/dist/cjs/nano-algolia-pagination.cjs.entry.js +2 -2
  27. package/dist/cjs/nano-algolia-results.cjs.entry.js +2 -2
  28. package/dist/cjs/nano-algolia.cjs.entry.js +4 -4
  29. package/dist/cjs/nano-algolia.cjs.entry.js.map +1 -1
  30. package/dist/cjs/nano-animation.cjs.entry.js +1 -1
  31. package/dist/cjs/nano-checkbox-group.cjs.entry.js +1 -1
  32. package/dist/cjs/nano-checkbox.cjs.entry.js +1 -1
  33. package/dist/cjs/nano-components.cjs.js +3 -3
  34. package/dist/cjs/nano-components.cjs.js.map +1 -1
  35. package/dist/cjs/nano-datalist_3.cjs.entry.js +13 -12
  36. package/dist/cjs/nano-datalist_3.cjs.entry.js.map +1 -1
  37. package/dist/cjs/nano-date-input.cjs.entry.js +1 -1
  38. package/dist/cjs/nano-date-picker.cjs.entry.js +1 -1
  39. package/dist/cjs/nano-details.cjs.entry.js +1 -1
  40. package/dist/cjs/nano-dialog.cjs.entry.js +4 -4
  41. package/dist/cjs/nano-drawer.cjs.entry.js +5 -5
  42. package/dist/cjs/nano-drawer.cjs.entry.js.map +1 -1
  43. package/dist/cjs/nano-dropdown.cjs.entry.js +5 -5
  44. package/dist/cjs/nano-dropdown.cjs.entry.js.map +1 -1
  45. package/dist/cjs/nano-field-validator.cjs.entry.js +2 -2
  46. package/dist/cjs/nano-file-upload.cjs.entry.js +1 -1
  47. package/dist/cjs/nano-global-nav-user-profile_3.cjs.entry.js +4 -4
  48. package/dist/cjs/nano-global-nav-user-profile_3.cjs.entry.js.map +1 -1
  49. package/dist/cjs/nano-global-nav.cjs.entry.js +2 -2
  50. package/dist/cjs/nano-global-search-results.cjs.entry.js +1 -1
  51. package/dist/cjs/nano-grid-item.cjs.entry.js +1 -1
  52. package/dist/cjs/nano-grid_2.cjs.entry.js +2 -2
  53. package/dist/cjs/nano-grid_2.cjs.entry.js.map +1 -1
  54. package/dist/cjs/nano-hero.cjs.entry.js +1 -1
  55. package/dist/cjs/nano-icon-button_2.cjs.entry.js +1 -1
  56. package/dist/cjs/nano-icon.cjs.entry.js +1 -1
  57. package/dist/cjs/nano-input.cjs.entry.js +4 -4
  58. package/dist/cjs/nano-input.cjs.entry.js.map +1 -1
  59. package/dist/cjs/nano-intersection-observe.cjs.entry.js +3 -3
  60. package/dist/cjs/nano-intersection-observe.cjs.entry.js.map +1 -1
  61. package/dist/cjs/nano-menu-drawer.cjs.entry.js +2 -2
  62. package/dist/cjs/nano-more-less.cjs.entry.js +1 -1
  63. package/dist/cjs/nano-overflow-nav.cjs.entry.js +2 -2
  64. package/dist/cjs/nano-progress-bar.cjs.entry.js +1 -1
  65. package/dist/cjs/nano-range.cjs.entry.js +1 -1
  66. package/dist/cjs/nano-rating.cjs.entry.js +8 -7
  67. package/dist/cjs/nano-rating.cjs.entry.js.map +1 -1
  68. package/dist/cjs/nano-resize-observe_2.cjs.entry.js +1 -1
  69. package/dist/cjs/nano-slide.cjs.entry.js +1 -1
  70. package/dist/cjs/{nano-slides-70182c35.js → nano-slides-612634dc.js} +1084 -16
  71. package/dist/cjs/nano-slides-612634dc.js.map +1 -0
  72. package/dist/cjs/nano-slides.cjs.entry.js +2 -2
  73. package/dist/cjs/nano-sortable.cjs.entry.js +1 -1
  74. package/dist/cjs/nano-spinner.cjs.entry.js +4 -4
  75. package/dist/cjs/nano-spinner.cjs.entry.js.map +1 -1
  76. package/dist/cjs/nano-split-pane.cjs.entry.js +1 -1
  77. package/dist/cjs/nano-sticker.cjs.entry.js +2 -2
  78. package/dist/cjs/nano-tab-content.cjs.entry.js +1 -1
  79. package/dist/cjs/nano-tab-group.cjs.entry.js +5 -5
  80. package/dist/cjs/nano-tab-group.cjs.entry.js.map +1 -1
  81. package/dist/cjs/nano-tab.cjs.entry.js +1 -1
  82. package/dist/cjs/{nano-table-0fdaeb8b.js → nano-table-fb9b584a.js} +16 -16
  83. package/dist/cjs/nano-table-fb9b584a.js.map +1 -0
  84. package/dist/cjs/nano-table.cjs.entry.js +3 -3
  85. package/dist/cjs/page-dots-99dd88f6.js +140 -0
  86. package/dist/cjs/page-dots-99dd88f6.js.map +1 -0
  87. package/dist/cjs/{scroll-6abe4d89.js → scroll-772f7d0d.js} +2 -2
  88. package/dist/cjs/{scroll-6abe4d89.js.map → scroll-772f7d0d.js.map} +1 -1
  89. package/dist/cjs/{table.worker-431042ce.js → table.worker-99a71d26.js} +5 -5
  90. package/dist/cjs/table.worker-99a71d26.js.map +1 -0
  91. package/dist/cjs/{table.worker-5b29550e.js → table.worker-da5412ed.js} +1 -1
  92. package/dist/collection/collection-manifest.json +1 -1
  93. package/dist/collection/components/alert/alert.helpers.js.map +1 -1
  94. package/dist/collection/components/datalist/datalist.js +12 -10
  95. package/dist/collection/components/datalist/datalist.js.map +1 -1
  96. package/dist/collection/components/drawer/drawer.css +8 -4
  97. package/dist/collection/components/dropdown/dropdown.js +5 -5
  98. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  99. package/dist/collection/components/field-validator/field-validator.js +1 -1
  100. package/dist/collection/components/grid/grid.css +3 -1
  101. package/dist/collection/components/input/input.css +1 -1
  102. package/dist/collection/components/intersection-observe/intersection-observe.js +3 -3
  103. package/dist/collection/components/intersection-observe/intersection-observe.js.map +1 -1
  104. package/dist/collection/components/rating/rating.js +7 -6
  105. package/dist/collection/components/rating/rating.js.map +1 -1
  106. package/dist/collection/components/select/select.css +1 -1
  107. package/dist/collection/components/slides/lib/js/drag.js +308 -305
  108. package/dist/collection/components/slides/lib/js/drag.js.map +1 -1
  109. package/dist/collection/components/slides/lib/js/fade.js +3 -1
  110. package/dist/collection/components/slides/lib/js/fade.js.map +1 -1
  111. package/dist/collection/components/slides/lib/js/index.js +6 -3
  112. package/dist/collection/components/slides/lib/js/index.js.map +1 -1
  113. package/dist/collection/components/slides/lib/js/player.js +123 -121
  114. package/dist/collection/components/slides/lib/js/player.js.map +1 -1
  115. package/dist/collection/components/slides/lib/js/prev-next-button.js +179 -178
  116. package/dist/collection/components/slides/lib/js/prev-next-button.js.map +1 -1
  117. package/dist/collection/components/slides/slides.js +7 -7
  118. package/dist/collection/components/slides/slides.js.map +1 -1
  119. package/dist/collection/components/sortable/sortable.js +5 -5
  120. package/dist/collection/components/spinner/spinner.js +5 -5
  121. package/dist/collection/components/spinner/spinner.js.map +1 -1
  122. package/dist/collection/components/table/table.js +12 -12
  123. package/dist/collection/components/table/table.js.map +1 -1
  124. package/dist/collection/components/table/table.worker.js +4 -5
  125. package/dist/collection/components/table/table.worker.js.map +1 -1
  126. package/dist/collection/components/tabs/tab-group.css +3 -0
  127. package/dist/collection/index.js +2 -0
  128. package/dist/collection/index.js.map +1 -1
  129. package/dist/components/algolia-data.js.map +1 -1
  130. package/dist/components/algolia.js.map +1 -1
  131. package/dist/components/datalist.js +13 -11
  132. package/dist/components/datalist.js.map +1 -1
  133. package/dist/components/dropdown.js +4 -4
  134. package/dist/components/dropdown.js.map +1 -1
  135. package/dist/components/fade.js +3 -1
  136. package/dist/components/fade.js.map +1 -1
  137. package/dist/components/grid.js +1 -1
  138. package/dist/components/grid.js.map +1 -1
  139. package/dist/components/index.js +1 -1
  140. package/dist/components/index.js.map +1 -1
  141. package/dist/components/index2.js +3 -4
  142. package/dist/components/index2.js.map +1 -1
  143. package/dist/components/input.js +1 -1
  144. package/dist/components/input.js.map +1 -1
  145. package/dist/components/nano-drawer.js +1 -1
  146. package/dist/components/nano-drawer.js.map +1 -1
  147. package/dist/components/nano-intersection-observe.js +2 -2
  148. package/dist/components/nano-intersection-observe.js.map +1 -1
  149. package/dist/components/nano-rating.js +7 -6
  150. package/dist/components/nano-rating.js.map +1 -1
  151. package/dist/components/nano-slides.js +1078 -10
  152. package/dist/components/nano-slides.js.map +1 -1
  153. package/dist/components/nano-tab-group.js +1 -1
  154. package/dist/components/nano-tab-group.js.map +1 -1
  155. package/dist/components/nano-table.js +12 -12
  156. package/dist/components/nano-table.js.map +1 -1
  157. package/dist/components/page-dots.js +1 -425
  158. package/dist/components/page-dots.js.map +1 -1
  159. package/dist/components/select.js +1 -1
  160. package/dist/components/select.js.map +1 -1
  161. package/dist/components/spinner.js +3 -3
  162. package/dist/components/spinner.js.map +1 -1
  163. package/dist/components/table.worker.js +1 -1
  164. package/dist/esm/{algolia-data-6fb6c60b.js → algolia-data-8fc24341.js} +2 -2
  165. package/dist/esm/{algolia-data-6fb6c60b.js.map → algolia-data-8fc24341.js.map} +1 -1
  166. package/dist/esm/app-globals-d4ab01f2.js.map +1 -1
  167. package/dist/esm/{component-store-a0eb3fb6.js → component-store-b798181b.js} +2 -2
  168. package/dist/esm/{component-store-a0eb3fb6.js.map → component-store-b798181b.js.map} +1 -1
  169. package/dist/esm/{dom-3db2202b.js → dom-d7f9f24c.js} +2 -2
  170. package/dist/esm/{dom-3db2202b.js.map → dom-d7f9f24c.js.map} +1 -1
  171. package/dist/esm/{fade-6d964000.js → fade-4ff5d9de.js} +6 -4
  172. package/dist/esm/fade-4ff5d9de.js.map +1 -0
  173. package/dist/esm/{form-control-53135184.js → form-control-812999d0.js} +2 -2
  174. package/dist/esm/{form-control-53135184.js.map → form-control-812999d0.js.map} +1 -1
  175. package/dist/esm/{fullscreen-a9c16b35.js → fullscreen-382d7890.js} +3 -3
  176. package/dist/esm/{fullscreen-a9c16b35.js.map → fullscreen-382d7890.js.map} +1 -1
  177. package/dist/esm/{index-815d3f98.js → index-3118109b.js} +3 -3
  178. package/dist/esm/{index-815d3f98.js.map → index-3118109b.js.map} +1 -1
  179. package/dist/esm/{index-32d24a05.js → index-d7a4a150.js} +5 -6
  180. package/dist/esm/index-d7a4a150.js.map +1 -0
  181. package/dist/esm/index.js +1 -0
  182. package/dist/esm/index.js.map +1 -1
  183. package/dist/esm/{lazyload-07e752e9.js → lazyload-49b745e4.js} +3 -3
  184. package/dist/esm/{lazyload-07e752e9.js.map → lazyload-49b745e4.js.map} +1 -1
  185. package/dist/esm/loader.js +3 -3
  186. package/dist/esm/nano-accordion.entry.js +2 -2
  187. package/dist/esm/nano-alert.entry.js +3 -3
  188. package/dist/esm/nano-algolia-filter.entry.js +3 -3
  189. package/dist/esm/nano-algolia-pagination.entry.js +2 -2
  190. package/dist/esm/nano-algolia-results.entry.js +2 -2
  191. package/dist/esm/nano-algolia.entry.js +4 -4
  192. package/dist/esm/nano-algolia.entry.js.map +1 -1
  193. package/dist/esm/nano-animation.entry.js +1 -1
  194. package/dist/esm/nano-checkbox-group.entry.js +1 -1
  195. package/dist/esm/nano-checkbox.entry.js +1 -1
  196. package/dist/esm/nano-components.js +4 -4
  197. package/dist/esm/nano-components.js.map +1 -1
  198. package/dist/esm/nano-datalist_3.entry.js +13 -12
  199. package/dist/esm/nano-datalist_3.entry.js.map +1 -1
  200. package/dist/esm/nano-date-input.entry.js +1 -1
  201. package/dist/esm/nano-date-picker.entry.js +1 -1
  202. package/dist/esm/nano-details.entry.js +1 -1
  203. package/dist/esm/nano-dialog.entry.js +4 -4
  204. package/dist/esm/nano-drawer.entry.js +5 -5
  205. package/dist/esm/nano-drawer.entry.js.map +1 -1
  206. package/dist/esm/nano-dropdown.entry.js +5 -5
  207. package/dist/esm/nano-dropdown.entry.js.map +1 -1
  208. package/dist/esm/nano-field-validator.entry.js +2 -2
  209. package/dist/esm/nano-file-upload.entry.js +1 -1
  210. package/dist/esm/nano-global-nav-user-profile_3.entry.js +4 -4
  211. package/dist/esm/nano-global-nav-user-profile_3.entry.js.map +1 -1
  212. package/dist/esm/nano-global-nav.entry.js +2 -2
  213. package/dist/esm/nano-global-search-results.entry.js +1 -1
  214. package/dist/esm/nano-grid-item.entry.js +1 -1
  215. package/dist/esm/nano-grid_2.entry.js +2 -2
  216. package/dist/esm/nano-grid_2.entry.js.map +1 -1
  217. package/dist/esm/nano-hero.entry.js +1 -1
  218. package/dist/esm/nano-icon-button_2.entry.js +1 -1
  219. package/dist/esm/nano-icon.entry.js +1 -1
  220. package/dist/esm/nano-input.entry.js +4 -4
  221. package/dist/esm/nano-input.entry.js.map +1 -1
  222. package/dist/esm/nano-intersection-observe.entry.js +3 -3
  223. package/dist/esm/nano-intersection-observe.entry.js.map +1 -1
  224. package/dist/esm/nano-menu-drawer.entry.js +2 -2
  225. package/dist/esm/nano-more-less.entry.js +1 -1
  226. package/dist/esm/nano-overflow-nav.entry.js +2 -2
  227. package/dist/esm/nano-progress-bar.entry.js +1 -1
  228. package/dist/esm/nano-range.entry.js +1 -1
  229. package/dist/esm/nano-rating.entry.js +8 -7
  230. package/dist/esm/nano-rating.entry.js.map +1 -1
  231. package/dist/esm/nano-resize-observe_2.entry.js +1 -1
  232. package/dist/esm/nano-slide.entry.js +1 -1
  233. package/dist/esm/{nano-slides-3feab833.js → nano-slides-c3eb1afe.js} +1084 -16
  234. package/dist/esm/nano-slides-c3eb1afe.js.map +1 -0
  235. package/dist/esm/nano-slides.entry.js +2 -2
  236. package/dist/esm/nano-sortable.entry.js +1 -1
  237. package/dist/esm/nano-spinner.entry.js +4 -4
  238. package/dist/esm/nano-spinner.entry.js.map +1 -1
  239. package/dist/esm/nano-split-pane.entry.js +1 -1
  240. package/dist/esm/nano-sticker.entry.js +2 -2
  241. package/dist/esm/nano-tab-content.entry.js +1 -1
  242. package/dist/esm/nano-tab-group.entry.js +5 -5
  243. package/dist/esm/nano-tab-group.entry.js.map +1 -1
  244. package/dist/esm/nano-tab.entry.js +1 -1
  245. package/dist/esm/{nano-table-dd0b6aa3.js → nano-table-5b495a5e.js} +16 -16
  246. package/dist/esm/nano-table-5b495a5e.js.map +1 -0
  247. package/dist/esm/nano-table.entry.js +3 -3
  248. package/dist/esm/page-dots-986d3b32.js +138 -0
  249. package/dist/esm/page-dots-986d3b32.js.map +1 -0
  250. package/dist/esm/{scroll-913c51a0.js → scroll-f373a189.js} +2 -2
  251. package/dist/esm/{scroll-913c51a0.js.map → scroll-f373a189.js.map} +1 -1
  252. package/dist/esm/{table.worker-e6e796b0.js → table.worker-36e8d052.js} +5 -5
  253. package/dist/esm/table.worker-36e8d052.js.map +1 -0
  254. package/dist/esm/{table.worker-5b29550e.js → table.worker-da5412ed.js} +1 -1
  255. package/dist/nano-components/{algolia-data-6fb6c60b.js → algolia-data-8fc24341.js} +2 -2
  256. package/dist/nano-components/{algolia-data-6fb6c60b.js.map → algolia-data-8fc24341.js.map} +1 -1
  257. package/dist/nano-components/app-globals-d4ab01f2.js.map +1 -1
  258. package/dist/nano-components/{component-store-a0eb3fb6.js → component-store-b798181b.js} +2 -2
  259. package/dist/nano-components/{dom-3db2202b.js → dom-d7f9f24c.js} +2 -2
  260. package/dist/nano-components/fade-4ff5d9de.js +5 -0
  261. package/dist/nano-components/fade-4ff5d9de.js.map +1 -0
  262. package/dist/nano-components/{form-control-53135184.js → form-control-812999d0.js} +2 -2
  263. package/dist/nano-components/{fullscreen-a9c16b35.js → fullscreen-382d7890.js} +2 -2
  264. package/dist/nano-components/{index-815d3f98.js → index-3118109b.js} +2 -2
  265. package/dist/nano-components/{index-815d3f98.js.map → index-3118109b.js.map} +1 -1
  266. package/dist/nano-components/index-d7a4a150.js +5 -0
  267. package/dist/nano-components/index-d7a4a150.js.map +1 -0
  268. package/dist/nano-components/index.esm.js +1 -1
  269. package/dist/nano-components/index.esm.js.map +1 -1
  270. package/dist/nano-components/{lazyload-07e752e9.js → lazyload-49b745e4.js} +2 -2
  271. package/dist/nano-components/nano-accordion.entry.js +1 -1
  272. package/dist/nano-components/nano-alert.entry.js +1 -1
  273. package/dist/nano-components/nano-algolia-filter.entry.js +1 -1
  274. package/dist/nano-components/nano-algolia-pagination.entry.js +1 -1
  275. package/dist/nano-components/nano-algolia-results.entry.js +1 -1
  276. package/dist/nano-components/nano-algolia.entry.js +1 -1
  277. package/dist/nano-components/nano-algolia.entry.js.map +1 -1
  278. package/dist/nano-components/nano-animation.entry.js +1 -1
  279. package/dist/nano-components/nano-checkbox-group.entry.js +1 -1
  280. package/dist/nano-components/nano-checkbox.entry.js +1 -1
  281. package/dist/nano-components/nano-components.esm.js +1 -1
  282. package/dist/nano-components/nano-components.esm.js.map +1 -1
  283. package/dist/nano-components/nano-datalist_3.entry.js +1 -1
  284. package/dist/nano-components/nano-datalist_3.entry.js.map +1 -1
  285. package/dist/nano-components/nano-date-input.entry.js +1 -1
  286. package/dist/nano-components/nano-date-picker.entry.js +1 -1
  287. package/dist/nano-components/nano-details.entry.js +1 -1
  288. package/dist/nano-components/nano-dialog.entry.js +1 -1
  289. package/dist/nano-components/nano-drawer.entry.js +1 -1
  290. package/dist/nano-components/nano-drawer.entry.js.map +1 -1
  291. package/dist/nano-components/nano-dropdown.entry.js +1 -1
  292. package/dist/nano-components/nano-dropdown.entry.js.map +1 -1
  293. package/dist/nano-components/nano-field-validator.entry.js +1 -1
  294. package/dist/nano-components/nano-file-upload.entry.js +1 -1
  295. package/dist/nano-components/nano-global-nav-user-profile_3.entry.js +1 -1
  296. package/dist/nano-components/nano-global-nav-user-profile_3.entry.js.map +1 -1
  297. package/dist/nano-components/nano-global-nav.entry.js +1 -1
  298. package/dist/nano-components/nano-global-search-results.entry.js +1 -1
  299. package/dist/nano-components/nano-grid-item.entry.js +1 -1
  300. package/dist/nano-components/nano-grid_2.entry.js +1 -1
  301. package/dist/nano-components/nano-grid_2.entry.js.map +1 -1
  302. package/dist/nano-components/nano-hero.entry.js +1 -1
  303. package/dist/nano-components/nano-icon-button_2.entry.js +1 -1
  304. package/dist/nano-components/nano-icon.entry.js +1 -1
  305. package/dist/nano-components/nano-input.entry.js +1 -1
  306. package/dist/nano-components/nano-input.entry.js.map +1 -1
  307. package/dist/nano-components/nano-intersection-observe.entry.js +1 -1
  308. package/dist/nano-components/nano-intersection-observe.entry.js.map +1 -1
  309. package/dist/nano-components/nano-menu-drawer.entry.js +1 -1
  310. package/dist/nano-components/nano-more-less.entry.js +1 -1
  311. package/dist/nano-components/nano-overflow-nav.entry.js +1 -1
  312. package/dist/nano-components/nano-progress-bar.entry.js +1 -1
  313. package/dist/nano-components/nano-range.entry.js +1 -1
  314. package/dist/nano-components/nano-rating.entry.js +1 -1
  315. package/dist/nano-components/nano-rating.entry.js.map +1 -1
  316. package/dist/nano-components/nano-resize-observe_2.entry.js +1 -1
  317. package/dist/nano-components/nano-slide.entry.js +1 -1
  318. package/dist/nano-components/nano-slides-c3eb1afe.js +20 -0
  319. package/dist/nano-components/nano-slides-c3eb1afe.js.map +1 -0
  320. package/dist/nano-components/nano-slides.entry.js +1 -1
  321. package/dist/nano-components/nano-sortable.entry.js +1 -1
  322. package/dist/nano-components/nano-spinner.entry.js +1 -1
  323. package/dist/nano-components/nano-spinner.entry.js.map +1 -1
  324. package/dist/nano-components/nano-split-pane.entry.js +1 -1
  325. package/dist/nano-components/nano-sticker.entry.js +1 -1
  326. package/dist/nano-components/nano-tab-content.entry.js +1 -1
  327. package/dist/nano-components/nano-tab-group.entry.js +1 -1
  328. package/dist/nano-components/nano-tab-group.entry.js.map +1 -1
  329. package/dist/nano-components/nano-tab.entry.js +1 -1
  330. package/dist/nano-components/{nano-table-dd0b6aa3.js → nano-table-5b495a5e.js} +2 -2
  331. package/dist/nano-components/{nano-table-dd0b6aa3.js.map → nano-table-5b495a5e.js.map} +1 -1
  332. package/dist/nano-components/nano-table.entry.js +1 -1
  333. package/dist/nano-components/page-dots-986d3b32.js +5 -0
  334. package/dist/nano-components/page-dots-986d3b32.js.map +1 -0
  335. package/dist/nano-components/{scroll-913c51a0.js → scroll-f373a189.js} +2 -2
  336. package/dist/nano-components/table.worker-36e8d052.js +5 -0
  337. package/dist/nano-components/{table.worker-5b29550e.js → table.worker-da5412ed.js} +1 -1
  338. package/dist/themes/nanopore.css +1 -1
  339. package/dist/themes/nanopore.css.map +1 -1
  340. package/dist/types/components/alert/alert.helpers.d.ts +1 -1
  341. package/dist/types/components/datalist/datalist.d.ts +1 -1
  342. package/dist/types/components/intersection-observe/intersection-observe.d.ts +1 -1
  343. package/dist/types/components/slides/lib/js/drag.d.ts +2 -1
  344. package/dist/types/components/slides/lib/js/index.d.ts +0 -3
  345. package/dist/types/components/slides/lib/js/player.d.ts +2 -1
  346. package/dist/types/components/slides/lib/js/prev-next-button.d.ts +2 -1
  347. package/dist/types/components/spinner/spinner.d.ts +1 -1
  348. package/dist/types/components.d.ts +4 -1408
  349. package/dist/types/index.d.ts +2 -0
  350. package/docs-json.json +17 -17
  351. package/docs-vscode.json +2 -2
  352. package/hydrate/index.js +709 -63
  353. package/hydrate/index.mjs +709 -63
  354. package/package.json +24 -4
  355. package/themes/nanopore.css +1 -1
  356. package/themes/nanopore.css.map +1 -1
  357. package/dist/cjs/fade-7a47badb.js.map +0 -1
  358. package/dist/cjs/index-7f89ccce.js.map +0 -1
  359. package/dist/cjs/nano-slides-70182c35.js.map +0 -1
  360. package/dist/cjs/nano-table-0fdaeb8b.js.map +0 -1
  361. package/dist/cjs/page-dots-ad7c3b76.js +0 -564
  362. package/dist/cjs/page-dots-ad7c3b76.js.map +0 -1
  363. package/dist/cjs/table.worker-431042ce.js.map +0 -1
  364. package/dist/collection/components/alert/alert-interface.js +0 -2
  365. package/dist/collection/components/alert/alert-interface.js.map +0 -1
  366. package/dist/esm/fade-6d964000.js.map +0 -1
  367. package/dist/esm/index-32d24a05.js.map +0 -1
  368. package/dist/esm/nano-slides-3feab833.js.map +0 -1
  369. package/dist/esm/nano-table-dd0b6aa3.js.map +0 -1
  370. package/dist/esm/page-dots-ca0bbb51.js +0 -562
  371. package/dist/esm/page-dots-ca0bbb51.js.map +0 -1
  372. package/dist/esm/table.worker-e6e796b0.js.map +0 -1
  373. package/dist/nano-components/fade-6d964000.js +0 -5
  374. package/dist/nano-components/fade-6d964000.js.map +0 -1
  375. package/dist/nano-components/index-32d24a05.js +0 -5
  376. package/dist/nano-components/index-32d24a05.js.map +0 -1
  377. package/dist/nano-components/nano-slides-3feab833.js +0 -10
  378. package/dist/nano-components/nano-slides-3feab833.js.map +0 -1
  379. package/dist/nano-components/page-dots-ca0bbb51.js +0 -10
  380. package/dist/nano-components/page-dots-ca0bbb51.js.map +0 -1
  381. package/dist/nano-components/table.worker-e6e796b0.js +0 -5
  382. package/dist/types/components/alert/alert-interface.d.ts +0 -1
  383. /package/dist/nano-components/{component-store-a0eb3fb6.js.map → component-store-b798181b.js.map} +0 -0
  384. /package/dist/nano-components/{dom-3db2202b.js.map → dom-d7f9f24c.js.map} +0 -0
  385. /package/dist/nano-components/{form-control-53135184.js.map → form-control-812999d0.js.map} +0 -0
  386. /package/dist/nano-components/{fullscreen-a9c16b35.js.map → fullscreen-382d7890.js.map} +0 -0
  387. /package/dist/nano-components/{lazyload-07e752e9.js.map → lazyload-49b745e4.js.map} +0 -0
  388. /package/dist/nano-components/{scroll-913c51a0.js.map → scroll-f373a189.js.map} +0 -0
  389. /package/dist/nano-components/{table.worker-e6e796b0.js.map → table.worker-36e8d052.js.map} +0 -0
  390. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/custom-element-doc-generator.d.ts +0 -0
  391. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/vue/generate-vue-component.d.ts +0 -0
  392. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/vue/index.d.ts +0 -0
  393. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/vue/output-vue.d.ts +0 -0
  394. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/vue/plugin.d.ts +0 -0
  395. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/vue/types.d.ts +0 -0
  396. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/generators/vue/utils.d.ts +0 -0
  397. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/stencil.config.d.ts +0 -0
  398. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/stencil.config.prod.d.ts +0 -0
  399. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/testing/mocks/intersection-observer.d.ts +0 -0
  400. /package/dist/types/builds/{_Jv_MA6J → QRg17M8b}/0/Digital/nano-components/packages/components/.stencil/wdio.conf.d.ts +0 -0
@@ -87,9 +87,9 @@ function getStyleSize(value) {
87
87
  const isValid = value.indexOf('%') == -1 && !isNaN(num);
88
88
  return isValid && num;
89
89
  }
90
- function noop() { }
90
+ function noop$1() { }
91
91
  const logError = typeof console == 'undefined'
92
- ? noop
92
+ ? noop$1
93
93
  : function (message) {
94
94
  console.error(message);
95
95
  };
@@ -1430,7 +1430,1075 @@ utils.htmlInit(Flickity, 'flickity');
1430
1430
  Flickity.Cell = Cell;
1431
1431
  Flickity.Slide = Slide;
1432
1432
 
1433
+ /*!
1434
+ * Unipointer v2.4.0
1435
+ * base class for doing one thing with pointer event
1436
+ * MIT license
1437
+ */
1438
+ function noop() { }
1439
+ function Unipointer() { }
1440
+ // inherit EvEmitter
1441
+ const pointerProto = (Unipointer.prototype = Object.create(EvEmitter.prototype));
1442
+ pointerProto.bindStartEvent = function (elem) {
1443
+ this._bindStartEvent(elem, true);
1444
+ };
1445
+ pointerProto.unbindStartEvent = function (elem) {
1446
+ this._bindStartEvent(elem, false);
1447
+ };
1448
+ /**
1449
+ * Add or remove start event
1450
+ * @param {Element} elem
1451
+ * @param {Boolean} isAdd - remove if falsey
1452
+ */
1453
+ pointerProto._bindStartEvent = function (elem, isAdd) {
1454
+ // munge isAdd, default to true
1455
+ isAdd = isAdd === undefined ? true : isAdd;
1456
+ const bindMethod = isAdd ? 'addEventListener' : 'removeEventListener';
1457
+ // default to mouse events
1458
+ let startEvent = 'mousedown';
1459
+ if ('ontouchstart' in window) {
1460
+ // HACK prefer Touch Events as you can preventDefault on touchstart to
1461
+ // disable scroll in iOS & mobile Chrome metafizzy/flickity#1177
1462
+ startEvent = 'touchstart';
1463
+ }
1464
+ else if (window.PointerEvent) {
1465
+ // Pointer Events
1466
+ startEvent = 'pointerdown';
1467
+ }
1468
+ elem[bindMethod](startEvent, this);
1469
+ };
1470
+ // trigger handler methods for events
1471
+ pointerProto.handleEvent = function (event) {
1472
+ const method = 'on' + event.type;
1473
+ if (this[method]) {
1474
+ this[method](event);
1475
+ }
1476
+ };
1477
+ // returns the touch that we're keeping track of
1478
+ pointerProto.getTouch = function (touches) {
1479
+ for (let i = 0; i < touches.length; i++) {
1480
+ const touch = touches[i];
1481
+ if (touch.identifier == this.pointerIdentifier) {
1482
+ return touch;
1483
+ }
1484
+ }
1485
+ };
1486
+ // ----- start event ----- //
1487
+ pointerProto.onmousedown = function (event) {
1488
+ // dismiss clicks from right or middle buttons
1489
+ const button = event.button;
1490
+ if (button && button !== 0 && button !== 1) {
1491
+ return;
1492
+ }
1493
+ this._pointerDown(event, event);
1494
+ };
1495
+ pointerProto.ontouchstart = function (event) {
1496
+ this._pointerDown(event, event.changedTouches[0]);
1497
+ };
1498
+ pointerProto.onpointerdown = function (event) {
1499
+ this._pointerDown(event, event);
1500
+ };
1501
+ /**
1502
+ * pointer start
1503
+ * @param {Event} event
1504
+ * @param {Event or Touch} pointer
1505
+ */
1506
+ pointerProto._pointerDown = function (event, pointer) {
1507
+ // dismiss right click and other pointers
1508
+ // button = 0 is okay, 1-4 not
1509
+ if (event.button || this.isPointerDown) {
1510
+ return;
1511
+ }
1512
+ this.isPointerDown = true;
1513
+ // save pointer identifier to match up touch events
1514
+ this.pointerIdentifier =
1515
+ pointer.pointerId !== undefined
1516
+ ? // pointerId for pointer events, touch.indentifier for touch events
1517
+ pointer.pointerId
1518
+ : pointer.identifier;
1519
+ this.pointerDown(event, pointer);
1520
+ };
1521
+ pointerProto.pointerDown = function (event, pointer) {
1522
+ this._bindPostStartEvents(event);
1523
+ this.emitEvent('pointerDown', [event, pointer]);
1524
+ };
1525
+ // hash of events to be bound after start event
1526
+ const postStartEvents = {
1527
+ mousedown: ['mousemove', 'mouseup'],
1528
+ touchstart: ['touchmove', 'touchend', 'touchcancel'],
1529
+ pointerdown: ['pointermove', 'pointerup', 'pointercancel'],
1530
+ };
1531
+ pointerProto._bindPostStartEvents = function (event) {
1532
+ if (!event) {
1533
+ return;
1534
+ }
1535
+ // get proper events to match start event
1536
+ const events = postStartEvents[event.type];
1537
+ // bind events to node
1538
+ events.forEach(function (eventName) {
1539
+ window.addEventListener(eventName, this);
1540
+ }, this);
1541
+ // save these arguments
1542
+ this._boundPointerEvents = events;
1543
+ };
1544
+ pointerProto._unbindPostStartEvents = function () {
1545
+ // check for _boundEvents, in case dragEnd triggered twice (old IE8 bug)
1546
+ if (!this._boundPointerEvents) {
1547
+ return;
1548
+ }
1549
+ this._boundPointerEvents.forEach(function (eventName) {
1550
+ window.removeEventListener(eventName, this);
1551
+ }, this);
1552
+ delete this._boundPointerEvents;
1553
+ };
1554
+ // ----- move event ----- //
1555
+ pointerProto.onmousemove = function (event) {
1556
+ this._pointerMove(event, event);
1557
+ };
1558
+ pointerProto.onpointermove = function (event) {
1559
+ if (event.pointerId == this.pointerIdentifier) {
1560
+ this._pointerMove(event, event);
1561
+ }
1562
+ };
1563
+ pointerProto.ontouchmove = function (event) {
1564
+ const touch = this.getTouch(event.changedTouches);
1565
+ if (touch) {
1566
+ this._pointerMove(event, touch);
1567
+ }
1568
+ };
1569
+ /**
1570
+ * pointer move
1571
+ * @param {Event} event
1572
+ * @param {Event or Touch} pointer
1573
+ * @private
1574
+ */
1575
+ pointerProto._pointerMove = function (event, pointer) {
1576
+ this.pointerMove(event, pointer);
1577
+ };
1578
+ // public
1579
+ pointerProto.pointerMove = function (event, pointer) {
1580
+ this.emitEvent('pointerMove', [event, pointer]);
1581
+ };
1582
+ // ----- end event ----- //
1583
+ pointerProto.onmouseup = function (event) {
1584
+ this._pointerUp(event, event);
1585
+ };
1586
+ pointerProto.onpointerup = function (event) {
1587
+ if (event.pointerId == this.pointerIdentifier) {
1588
+ this._pointerUp(event, event);
1589
+ }
1590
+ };
1591
+ pointerProto.ontouchend = function (event) {
1592
+ const touch = this.getTouch(event.changedTouches);
1593
+ if (touch) {
1594
+ this._pointerUp(event, touch);
1595
+ }
1596
+ };
1597
+ /**
1598
+ * pointer up
1599
+ * @param {Event} event
1600
+ * @param {Event or Touch} pointer
1601
+ * @private
1602
+ */
1603
+ pointerProto._pointerUp = function (event, pointer) {
1604
+ this._pointerDone();
1605
+ this.pointerUp(event, pointer);
1606
+ };
1607
+ // public
1608
+ pointerProto.pointerUp = function (event, pointer) {
1609
+ this.emitEvent('pointerUp', [event, pointer]);
1610
+ };
1611
+ // ----- pointer done ----- //
1612
+ // triggered on pointer up & pointer cancel
1613
+ pointerProto._pointerDone = function () {
1614
+ this._pointerReset();
1615
+ this._unbindPostStartEvents();
1616
+ this.pointerDone();
1617
+ };
1618
+ pointerProto._pointerReset = function () {
1619
+ // reset properties
1620
+ this.isPointerDown = false;
1621
+ delete this.pointerIdentifier;
1622
+ };
1623
+ pointerProto.pointerDone = noop;
1624
+ // ----- pointer cancel ----- //
1625
+ pointerProto.onpointercancel = function (event) {
1626
+ if (event.pointerId == this.pointerIdentifier) {
1627
+ this._pointerCancel(event, event);
1628
+ }
1629
+ };
1630
+ pointerProto.ontouchcancel = function (event) {
1631
+ const touch = this.getTouch(event.changedTouches);
1632
+ if (touch) {
1633
+ this._pointerCancel(event, touch);
1634
+ }
1635
+ };
1636
+ /**
1637
+ * pointer cancel
1638
+ * @param {Event} event
1639
+ * @param {Event or Touch} pointer
1640
+ * @private
1641
+ */
1642
+ pointerProto._pointerCancel = function (event, pointer) {
1643
+ this._pointerDone();
1644
+ this.pointerCancel(event, pointer);
1645
+ };
1646
+ // public
1647
+ pointerProto.pointerCancel = function (event, pointer) {
1648
+ this.emitEvent('pointerCancel', [event, pointer]);
1649
+ };
1650
+ // ----- ----- //
1651
+ // utility function for getting x/y coords from event
1652
+ Unipointer.getPointerPoint = function (pointer) {
1653
+ return {
1654
+ x: pointer.pageX,
1655
+ y: pointer.pageY,
1656
+ };
1657
+ };
1658
+ /*!
1659
+ * Unidragger v2.4.0
1660
+ * Draggable base class
1661
+ * MIT license
1662
+ */
1663
+ function Unidragger() { }
1664
+ // inherit Unipointer & EvEmitter
1665
+ const draggerProto = (Unidragger.prototype = Object.create(Unipointer.prototype));
1666
+ // ----- bind start ----- //
1667
+ draggerProto.bindHandles = function () {
1668
+ this._bindHandles(true);
1669
+ };
1670
+ draggerProto.unbindHandles = function () {
1671
+ this._bindHandles(false);
1672
+ };
1673
+ /**
1674
+ * Add or remove start event
1675
+ * @param {Boolean} isAdd
1676
+ */
1677
+ draggerProto._bindHandles = function (isAdd) {
1678
+ // munge isAdd, default to true
1679
+ isAdd = isAdd === undefined ? true : isAdd;
1680
+ // bind each handle
1681
+ const bindMethod = isAdd ? 'addEventListener' : 'removeEventListener';
1682
+ const touchAction = isAdd ? this._touchActionValue : '';
1683
+ for (let i = 0; i < this.handles.length; i++) {
1684
+ const handle = this.handles[i];
1685
+ this._bindStartEvent(handle, isAdd);
1686
+ handle[bindMethod]('click', this);
1687
+ // touch-action: none to override browser touch gestures. metafizzy/flickity#540
1688
+ if (window.PointerEvent) {
1689
+ handle.style.touchAction = touchAction;
1690
+ }
1691
+ }
1692
+ };
1693
+ // prototype so it can be overwriteable by Flickity
1694
+ draggerProto._touchActionValue = 'none';
1695
+ // ----- start event ----- //
1696
+ /**
1697
+ * pointer start
1698
+ * @param {Event} event
1699
+ * @param {Event or Touch} pointer
1700
+ */
1701
+ draggerProto.pointerDown = function (event, pointer) {
1702
+ const isOkay = this.okayPointerDown(event);
1703
+ if (!isOkay) {
1704
+ return;
1705
+ }
1706
+ // track start event position
1707
+ // Safari 9 overrides pageX and pageY. These values needs to be copied. flickity#842
1708
+ this.pointerDownPointer = {
1709
+ pageX: pointer.pageX,
1710
+ pageY: pointer.pageY,
1711
+ };
1712
+ event.preventDefault();
1713
+ this.pointerDownBlur();
1714
+ // bind move and end events
1715
+ this._bindPostStartEvents(event);
1716
+ this.emitEvent('pointerDown', [event, pointer]);
1717
+ };
1718
+ // nodes that have text fields
1719
+ const cursorNodes = {
1720
+ TEXTAREA: true,
1721
+ INPUT: true,
1722
+ SELECT: true,
1723
+ OPTION: true,
1724
+ };
1725
+ // input types that do not have text fields
1726
+ const clickTypes = {
1727
+ radio: true,
1728
+ checkbox: true,
1729
+ button: true,
1730
+ submit: true,
1731
+ image: true,
1732
+ file: true,
1733
+ };
1734
+ // dismiss inputs with text fields. flickity#403, flickity#404
1735
+ draggerProto.okayPointerDown = function (event) {
1736
+ const isCursorNode = cursorNodes[event.target.nodeName];
1737
+ const isClickType = clickTypes[event.target.type];
1738
+ const isOkay = !isCursorNode || isClickType;
1739
+ if (!isOkay) {
1740
+ this._pointerReset();
1741
+ }
1742
+ return isOkay;
1743
+ };
1744
+ // kludge to blur previously focused input
1745
+ draggerProto.pointerDownBlur = function () {
1746
+ const focused = document.activeElement;
1747
+ // do not blur body for IE10, metafizzy/flickity#117
1748
+ const canBlur = focused && focused.blur && focused != document.body;
1749
+ if (canBlur) {
1750
+ focused.blur();
1751
+ }
1752
+ };
1753
+ // ----- move event ----- //
1754
+ /**
1755
+ * drag move
1756
+ * @param {Event} event
1757
+ * @param {Event or Touch} pointer
1758
+ */
1759
+ draggerProto.pointerMove = function (event, pointer) {
1760
+ const moveVector = this._dragPointerMove(event, pointer);
1761
+ this.emitEvent('pointerMove', [event, pointer, moveVector]);
1762
+ this._dragMove(event, pointer, moveVector);
1763
+ };
1764
+ // base pointer move logic
1765
+ draggerProto._dragPointerMove = function (event, pointer) {
1766
+ const moveVector = {
1767
+ x: pointer.pageX - this.pointerDownPointer.pageX,
1768
+ y: pointer.pageY - this.pointerDownPointer.pageY,
1769
+ };
1770
+ // start drag if pointer has moved far enough to start drag
1771
+ if (!this.isDragging && this.hasDragStarted(moveVector)) {
1772
+ this._dragStart(event, pointer);
1773
+ }
1774
+ return moveVector;
1775
+ };
1776
+ // condition if pointer has moved far enough to start drag
1777
+ draggerProto.hasDragStarted = function (moveVector) {
1778
+ return Math.abs(moveVector.x) > 3 || Math.abs(moveVector.y) > 3;
1779
+ };
1780
+ // ----- end event ----- //
1781
+ /**
1782
+ * pointer up
1783
+ * @param {Event} event
1784
+ * @param {Event or Touch} pointer
1785
+ */
1786
+ draggerProto.pointerUp = function (event, pointer) {
1787
+ this.emitEvent('pointerUp', [event, pointer]);
1788
+ this._dragPointerUp(event, pointer);
1789
+ };
1790
+ draggerProto._dragPointerUp = function (event, pointer) {
1791
+ if (this.isDragging) {
1792
+ this._dragEnd(event, pointer);
1793
+ }
1794
+ else {
1795
+ // pointer didn't move enough for drag to start
1796
+ this._staticClick(event, pointer);
1797
+ }
1798
+ };
1799
+ // -------------------------- drag -------------------------- //
1800
+ // dragStart
1801
+ draggerProto._dragStart = function (event, pointer) {
1802
+ this.isDragging = true;
1803
+ // prevent clicks
1804
+ this.isPreventingClicks = true;
1805
+ this.dragStart(event, pointer);
1806
+ };
1807
+ draggerProto.dragStart = function (event, pointer) {
1808
+ this.emitEvent('dragStart', [event, pointer]);
1809
+ };
1810
+ // dragMove
1811
+ draggerProto._dragMove = function (event, pointer, moveVector) {
1812
+ // do not drag if not dragging yet
1813
+ if (!this.isDragging) {
1814
+ return;
1815
+ }
1816
+ this.dragMove(event, pointer, moveVector);
1817
+ };
1818
+ draggerProto.dragMove = function (event, pointer, moveVector) {
1819
+ event.preventDefault();
1820
+ this.emitEvent('dragMove', [event, pointer, moveVector]);
1821
+ };
1822
+ // dragEnd
1823
+ draggerProto._dragEnd = function (event, pointer) {
1824
+ // set flags
1825
+ this.isDragging = false;
1826
+ // re-enable clicking async
1827
+ setTimeout(function () {
1828
+ delete this.isPreventingClicks;
1829
+ }.bind(this));
1830
+ this.dragEnd(event, pointer);
1831
+ };
1832
+ draggerProto.dragEnd = function (event, pointer) {
1833
+ this.emitEvent('dragEnd', [event, pointer]);
1834
+ };
1835
+ // ----- onclick ----- //
1836
+ // handle all clicks and prevent clicks when dragging
1837
+ draggerProto.onclick = function (event) {
1838
+ if (this.isPreventingClicks) {
1839
+ event.preventDefault();
1840
+ }
1841
+ };
1842
+ // ----- staticClick ----- //
1843
+ // triggered after pointer down & up with no/tiny movement
1844
+ draggerProto._staticClick = function (event, pointer) {
1845
+ // ignore emulated mouse up clicks
1846
+ if (this.isIgnoringMouseUp && event.type == 'mouseup') {
1847
+ return;
1848
+ }
1849
+ this.staticClick(event, pointer);
1850
+ // set flag for emulated clicks 300ms after touchend
1851
+ if (event.type != 'mouseup') {
1852
+ this.isIgnoringMouseUp = true;
1853
+ // reset flag after 300ms
1854
+ setTimeout(function () {
1855
+ delete this.isIgnoringMouseUp;
1856
+ }.bind(this), 400);
1857
+ }
1858
+ };
1859
+ draggerProto.staticClick = function (event, pointer) {
1860
+ this.emitEvent('staticClick', [event, pointer]);
1861
+ };
1862
+ // ----- utils ----- //
1863
+ Unidragger.getPointerPoint = Unipointer.getPointerPoint;
1864
+
1865
+ const drag = () => {
1866
+ // ----- defaults ----- //
1867
+ utils.extend(Flickity.defaults, {
1868
+ draggable: '>1',
1869
+ dragThreshold: 3,
1870
+ });
1871
+ // ----- create ----- //
1872
+ Flickity.createMethods.push('_createDrag');
1873
+ // -------------------------- drag prototype -------------------------- //
1874
+ const proto = Flickity.prototype;
1875
+ utils.extend(proto, Unidragger.prototype);
1876
+ proto._touchActionValue = 'pan-y';
1877
+ // -------------------------- -------------------------- //
1878
+ const isTouch = 'createTouch' in document;
1879
+ let isTouchmoveScrollCanceled = false;
1880
+ proto._createDrag = function () {
1881
+ this.on('activate', this.onActivateDrag);
1882
+ this.on('uiChange', this._uiChangeDrag);
1883
+ this.on('deactivate', this.onDeactivateDrag);
1884
+ this.on('cellChange', this.updateDraggable);
1885
+ // TODO updateDraggable on resize? if groupCells & slides change
1886
+ // HACK - add seemingly innocuous handler to fix iOS 10 scroll behavior
1887
+ // #457, RubaXa/Sortable#973
1888
+ if (isTouch && !isTouchmoveScrollCanceled) {
1889
+ window.addEventListener('touchmove', function () { });
1890
+ isTouchmoveScrollCanceled = true;
1891
+ }
1892
+ };
1893
+ proto.onActivateDrag = function () {
1894
+ this.handles = [this.viewport];
1895
+ this.bindHandles();
1896
+ this.updateDraggable();
1897
+ };
1898
+ proto.onDeactivateDrag = function () {
1899
+ this.unbindHandles();
1900
+ this.element.classList.remove('is-draggable');
1901
+ };
1902
+ proto.updateDraggable = function () {
1903
+ // disable dragging if less than 2 slides. #278
1904
+ if (this.options.draggable == '>1') {
1905
+ this.isDraggable = this.slides.length > 1;
1906
+ }
1907
+ else {
1908
+ this.isDraggable = this.options.draggable;
1909
+ }
1910
+ if (this.isDraggable) {
1911
+ this.element.classList.add('is-draggable');
1912
+ }
1913
+ else {
1914
+ this.element.classList.remove('is-draggable');
1915
+ }
1916
+ };
1917
+ // backwards compatibility
1918
+ proto.bindDrag = function () {
1919
+ this.options.draggable = true;
1920
+ this.updateDraggable();
1921
+ };
1922
+ proto.unbindDrag = function () {
1923
+ this.options.draggable = false;
1924
+ this.updateDraggable();
1925
+ };
1926
+ proto._uiChangeDrag = function () {
1927
+ delete this.isFreeScrolling;
1928
+ };
1929
+ // -------------------------- pointer events -------------------------- //
1930
+ proto.pointerDown = function (event, pointer) {
1931
+ if (!this.isDraggable) {
1932
+ this._pointerDownDefault(event, pointer);
1933
+ return;
1934
+ }
1935
+ const isOkay = this.okayPointerDown(event);
1936
+ if (!isOkay) {
1937
+ return;
1938
+ }
1939
+ this._pointerDownPreventDefault(event);
1940
+ this.pointerDownFocus(event);
1941
+ // blur
1942
+ if (document.activeElement != this.element) {
1943
+ // do not blur if already focused
1944
+ this.pointerDownBlur();
1945
+ }
1946
+ // stop if it was moving
1947
+ this.dragX = this.x;
1948
+ this.viewport.classList.add('is-pointer-down');
1949
+ // track scrolling
1950
+ this.pointerDownScroll = getScrollPosition();
1951
+ window.addEventListener('scroll', this);
1952
+ this._pointerDownDefault(event, pointer);
1953
+ };
1954
+ // default pointerDown logic, used for staticClick
1955
+ proto._pointerDownDefault = function (event, pointer) {
1956
+ // track start event position
1957
+ // Safari 9 overrides pageX and pageY. These values needs to be copied. #779
1958
+ this.pointerDownPointer = {
1959
+ pageX: pointer.pageX,
1960
+ pageY: pointer.pageY,
1961
+ };
1962
+ // bind move and end events
1963
+ this._bindPostStartEvents(event);
1964
+ this.dispatchEvent('pointerDown', event, [pointer]);
1965
+ };
1966
+ const focusNodes = {
1967
+ INPUT: true,
1968
+ TEXTAREA: true,
1969
+ SELECT: true,
1970
+ };
1971
+ proto.pointerDownFocus = function (event) {
1972
+ const isFocusNode = focusNodes[event.target.nodeName];
1973
+ if (!isFocusNode) {
1974
+ this.focus();
1975
+ }
1976
+ };
1977
+ proto._pointerDownPreventDefault = function (event) {
1978
+ const isTouchStart = event.type == 'touchstart';
1979
+ const isTouchPointer = event.pointerType == 'touch';
1980
+ const isFocusNode = focusNodes[event.target.nodeName];
1981
+ if (!isTouchStart && !isTouchPointer && !isFocusNode) {
1982
+ event.preventDefault();
1983
+ }
1984
+ };
1985
+ // ----- move ----- //
1986
+ proto.hasDragStarted = function (moveVector) {
1987
+ return Math.abs(moveVector.x) > this.options.dragThreshold;
1988
+ };
1989
+ // ----- up ----- //
1990
+ proto.pointerUp = function (event, pointer) {
1991
+ delete this.isTouchScrolling;
1992
+ this.viewport.classList.remove('is-pointer-down');
1993
+ this.dispatchEvent('pointerUp', event, [pointer]);
1994
+ this._dragPointerUp(event, pointer);
1995
+ };
1996
+ proto.pointerDone = function () {
1997
+ window.removeEventListener('scroll', this);
1998
+ delete this.pointerDownScroll;
1999
+ };
2000
+ // -------------------------- dragging -------------------------- //
2001
+ proto.dragStart = function (event, pointer) {
2002
+ if (!this.isDraggable) {
2003
+ return;
2004
+ }
2005
+ this.dragStartPosition = this.x;
2006
+ this.startAnimation();
2007
+ window.removeEventListener('scroll', this);
2008
+ this.dispatchEvent('dragStart', event, [pointer]);
2009
+ };
2010
+ proto.pointerMove = function (event, pointer) {
2011
+ const moveVector = this._dragPointerMove(event, pointer);
2012
+ this.dispatchEvent('pointerMove', event, [pointer, moveVector]);
2013
+ this._dragMove(event, pointer, moveVector);
2014
+ };
2015
+ proto.dragMove = function (event, pointer, moveVector) {
2016
+ if (!this.isDraggable) {
2017
+ return;
2018
+ }
2019
+ event.preventDefault();
2020
+ this.previousDragX = this.dragX;
2021
+ // reverse if right-to-left
2022
+ const direction = this.options.rightToLeft ? -1 : 1;
2023
+ if (this.options.wrapAround) {
2024
+ // wrap around move. #589
2025
+ moveVector.x = moveVector.x % this.slideableWidth;
2026
+ }
2027
+ let dragX = this.dragStartPosition + moveVector.x * direction;
2028
+ if (!this.options.wrapAround && this.slides.length) {
2029
+ // slow drag
2030
+ const originBound = Math.max(-this.slides[0].target, this.dragStartPosition);
2031
+ dragX = dragX > originBound ? (dragX + originBound) * 0.5 : dragX;
2032
+ const endBound = Math.min(-this.getLastSlide().target, this.dragStartPosition);
2033
+ dragX = dragX < endBound ? (dragX + endBound) * 0.5 : dragX;
2034
+ }
2035
+ this.dragX = dragX;
2036
+ this.dragMoveTime = new Date();
2037
+ this.dispatchEvent('dragMove', event, [pointer, moveVector]);
2038
+ };
2039
+ proto.dragEnd = function (event, pointer) {
2040
+ if (!this.isDraggable) {
2041
+ return;
2042
+ }
2043
+ if (this.options.freeScroll) {
2044
+ this.isFreeScrolling = true;
2045
+ }
2046
+ // set selectedIndex based on where flick will end up
2047
+ let index = this.dragEndRestingSelect();
2048
+ if (this.options.freeScroll && !this.options.wrapAround) {
2049
+ // if free-scroll & not wrap around
2050
+ // do not free-scroll if going outside of bounding slides
2051
+ // so bounding slides can attract slider, and keep it in bounds
2052
+ const restingX = this.getRestingPosition();
2053
+ this.isFreeScrolling =
2054
+ -restingX > this.slides[0].target &&
2055
+ -restingX < this.getLastSlide().target;
2056
+ }
2057
+ else if (!this.options.freeScroll && index == this.selectedIndex) {
2058
+ // boost selection if selected index has not changed
2059
+ index += this.dragEndBoostSelect();
2060
+ }
2061
+ delete this.previousDragX;
2062
+ // apply selection
2063
+ // TODO refactor this, selecting here feels weird
2064
+ // HACK, set flag so dragging stays in correct direction
2065
+ this.isDragSelect = this.options.wrapAround;
2066
+ this.select(index);
2067
+ delete this.isDragSelect;
2068
+ this.dispatchEvent('dragEnd', event, [pointer]);
2069
+ };
2070
+ proto.dragEndRestingSelect = function () {
2071
+ const restingX = this.getRestingPosition();
2072
+ // how far away from selected slide
2073
+ const distance = Math.abs(this.getSlideDistance(-restingX, this.selectedIndex));
2074
+ // get closet resting going up and going down
2075
+ const positiveResting = this._getClosestResting(restingX, distance, 1);
2076
+ const negativeResting = this._getClosestResting(restingX, distance, -1);
2077
+ // use closer resting for wrap-around
2078
+ const index = positiveResting.distance < negativeResting.distance
2079
+ ? positiveResting.index
2080
+ : negativeResting.index;
2081
+ return index;
2082
+ };
2083
+ /**
2084
+ * given resting X and distance to selected cell
2085
+ * get the distance and index of the closest cell
2086
+ * @param {Number} restingX - estimated post-flick resting position
2087
+ * @param {Number} distance - distance to selected cell
2088
+ * @param {Integer} increment - +1 or -1, going up or down
2089
+ * @returns {Object} - { distance: {Number}, index: {Integer} }
2090
+ */
2091
+ proto._getClosestResting = function (restingX, distance, increment) {
2092
+ let index = this.selectedIndex;
2093
+ let minDistance = Infinity;
2094
+ const condition = this.options.contain && !this.options.wrapAround
2095
+ ? // if contain, keep going if distance is equal to minDistance
2096
+ function (d, md) {
2097
+ return d <= md;
2098
+ }
2099
+ : function (d, md) {
2100
+ return d < md;
2101
+ };
2102
+ while (condition(distance, minDistance)) {
2103
+ // measure distance to next cell
2104
+ index += increment;
2105
+ minDistance = distance;
2106
+ distance = this.getSlideDistance(-restingX, index);
2107
+ if (distance === null) {
2108
+ break;
2109
+ }
2110
+ distance = Math.abs(distance);
2111
+ }
2112
+ return {
2113
+ distance: minDistance,
2114
+ // selected was previous index
2115
+ index: index - increment,
2116
+ };
2117
+ };
2118
+ /**
2119
+ * measure distance between x and a slide target
2120
+ * @param {Number} x
2121
+ * @param {Integer} index - slide index
2122
+ * @returns null or distance number
2123
+ */
2124
+ proto.getSlideDistance = function (x, index) {
2125
+ const len = this.slides.length;
2126
+ // wrap around if at least 2 slides
2127
+ const isWrapAround = this.options.wrapAround && len > 1;
2128
+ const slideIndex = isWrapAround ? utils.modulo(index, len) : index;
2129
+ const slide = this.slides[slideIndex];
2130
+ if (!slide) {
2131
+ return null;
2132
+ }
2133
+ // add distance for wrap-around slides
2134
+ const wrap = isWrapAround
2135
+ ? this.slideableWidth * Math.floor(index / len)
2136
+ : 0;
2137
+ return x - (slide.target + wrap);
2138
+ };
2139
+ proto.dragEndBoostSelect = function () {
2140
+ // do not boost if no previousDragX or dragMoveTime
2141
+ if (this.previousDragX === undefined ||
2142
+ !this.dragMoveTime ||
2143
+ // or if drag was held for 100 ms
2144
+ new Date() - this.dragMoveTime > 100) {
2145
+ return 0;
2146
+ }
2147
+ const distance = this.getSlideDistance(-this.dragX, this.selectedIndex);
2148
+ const delta = this.previousDragX - this.dragX;
2149
+ if (distance > 0 && delta > 0) {
2150
+ // boost to next if moving towards the right, and positive velocity
2151
+ return 1;
2152
+ }
2153
+ else if (distance < 0 && delta < 0) {
2154
+ // boost to previous if moving towards the left, and negative velocity
2155
+ return -1;
2156
+ }
2157
+ return 0;
2158
+ };
2159
+ // ----- staticClick ----- //
2160
+ proto.staticClick = function (event, pointer) {
2161
+ // get clickedCell, if cell was clicked
2162
+ const clickedCell = this.getParentCell(event.target);
2163
+ const cellElem = clickedCell && clickedCell.element;
2164
+ const cellIndex = clickedCell && this.cells.indexOf(clickedCell);
2165
+ this.dispatchEvent('staticClick', event, [pointer, cellElem, cellIndex]);
2166
+ };
2167
+ // ----- scroll ----- //
2168
+ proto.onscroll = function () {
2169
+ const scroll = getScrollPosition();
2170
+ const scrollMoveX = this.pointerDownScroll.x - scroll.x;
2171
+ const scrollMoveY = this.pointerDownScroll.y - scroll.y;
2172
+ // cancel click/tap if scroll is too much
2173
+ if (Math.abs(scrollMoveX) > 3 || Math.abs(scrollMoveY) > 3) {
2174
+ this._pointerDone();
2175
+ }
2176
+ };
2177
+ // ----- utils ----- //
2178
+ function getScrollPosition() {
2179
+ return {
2180
+ x: window.scrollX,
2181
+ y: window.scrollY,
2182
+ };
2183
+ }
2184
+ };
2185
+
2186
+ const nowNext = () => {
2187
+ const svgURI = 'http://www.w3.org/2000/svg';
2188
+ // -------------------------- PrevNextButton -------------------------- //
2189
+ function PrevNextButton(direction, parent) {
2190
+ this.direction = direction;
2191
+ this.parent = parent;
2192
+ this.parentElement = this.parent.element.shadowRoot || this.parent.element;
2193
+ this._create();
2194
+ }
2195
+ PrevNextButton.prototype = Object.create(Unipointer.prototype);
2196
+ PrevNextButton.prototype._create = function () {
2197
+ // properties
2198
+ this.isEnabled = true;
2199
+ this.isPrevious = this.direction == -1;
2200
+ const leftDirection = this.parent.options.rightToLeft ? 1 : -1;
2201
+ this.isLeft = this.direction == leftDirection;
2202
+ const button = (this.element = document.createElement('button'));
2203
+ button.className = 'flickity-button flickity-prev-next-button';
2204
+ button.part.add('navigation-button');
2205
+ if (this.isPrevious) {
2206
+ button.classList.add('previous');
2207
+ button.part.add('navigation-button--previous');
2208
+ }
2209
+ else {
2210
+ button.classList.add('next');
2211
+ button.part.add('navigation-button--next');
2212
+ }
2213
+ // prevent button from submitting form http://stackoverflow.com/a/10836076/182183
2214
+ button.setAttribute('type', 'button');
2215
+ // init as disabled
2216
+ this.disable();
2217
+ button.setAttribute('aria-label', this.isPrevious ? 'Previous' : 'Next');
2218
+ const slot = document.createElement('slot');
2219
+ slot.name = this.isPrevious ? 'previous-icon' : 'next-icon';
2220
+ button.appendChild(slot);
2221
+ slot.addEventListener('slotchange', () => {
2222
+ slot.assignedElements({ flatten: true }).forEach((ele) => {
2223
+ ele.removeAttribute('hidden');
2224
+ });
2225
+ });
2226
+ // create arrow
2227
+ const svg = this.createSVG();
2228
+ slot.appendChild(svg);
2229
+ // events
2230
+ this.parent.on('select', this.update.bind(this));
2231
+ this.on('pointerDown', this.parent.childUIPointerDown.bind(this.parent));
2232
+ };
2233
+ PrevNextButton.prototype.activate = function () {
2234
+ this.bindStartEvent(this.element);
2235
+ this.element.addEventListener('click', this);
2236
+ // add to DOM
2237
+ this.parentElement.appendChild(this.element);
2238
+ };
2239
+ PrevNextButton.prototype.deactivate = function () {
2240
+ // remove from DOM
2241
+ this.parentElement.removeChild(this.element);
2242
+ // click events
2243
+ this.unbindStartEvent(this.element);
2244
+ this.element.removeEventListener('click', this);
2245
+ };
2246
+ PrevNextButton.prototype.createSVG = function () {
2247
+ const svg = document.createElementNS(svgURI, 'svg');
2248
+ svg.setAttribute('class', 'flickity-button-icon');
2249
+ svg.setAttribute('viewBox', '0 0 100 100');
2250
+ svg.part.add('navigation-icon');
2251
+ const path = document.createElementNS(svgURI, 'path');
2252
+ const pathMovements = getArrowMovements(this.parent.options.arrowShape);
2253
+ path.setAttribute('d', pathMovements);
2254
+ path.setAttribute('class', 'arrow');
2255
+ // rotate arrow
2256
+ if (!this.isLeft) {
2257
+ path.setAttribute('transform', 'translate(100, 100) rotate(180) ');
2258
+ }
2259
+ svg.appendChild(path);
2260
+ return svg;
2261
+ };
2262
+ // get SVG path movmement
2263
+ function getArrowMovements(shape) {
2264
+ // use shape as movement if string
2265
+ if (typeof shape == 'string') {
2266
+ return shape;
2267
+ }
2268
+ // create movement string
2269
+ return ('M ' +
2270
+ shape.x0 +
2271
+ ',50' +
2272
+ ' L ' +
2273
+ shape.x1 +
2274
+ ',' +
2275
+ (shape.y1 + 50) +
2276
+ ' L ' +
2277
+ shape.x2 +
2278
+ ',' +
2279
+ (shape.y2 + 50) +
2280
+ ' L ' +
2281
+ shape.x3 +
2282
+ ',50 ' +
2283
+ ' L ' +
2284
+ shape.x2 +
2285
+ ',' +
2286
+ (50 - shape.y2) +
2287
+ ' L ' +
2288
+ shape.x1 +
2289
+ ',' +
2290
+ (50 - shape.y1) +
2291
+ ' Z');
2292
+ }
2293
+ PrevNextButton.prototype.handleEvent = utils.handleEvent;
2294
+ PrevNextButton.prototype.onclick = function () {
2295
+ if (!this.isEnabled) {
2296
+ return;
2297
+ }
2298
+ this.parent.uiChange();
2299
+ const method = this.isPrevious ? 'previous' : 'next';
2300
+ this.parent[method]();
2301
+ };
2302
+ // ----- ----- //
2303
+ PrevNextButton.prototype.enable = function () {
2304
+ if (this.isEnabled) {
2305
+ return;
2306
+ }
2307
+ this.element.disabled = false;
2308
+ this.isEnabled = true;
2309
+ };
2310
+ PrevNextButton.prototype.disable = function () {
2311
+ if (!this.isEnabled) {
2312
+ return;
2313
+ }
2314
+ this.element.disabled = true;
2315
+ this.isEnabled = false;
2316
+ };
2317
+ PrevNextButton.prototype.update = function () {
2318
+ // index of first or last slide, if previous or next
2319
+ const slides = this.parent.slides;
2320
+ // enable is wrapAround and at least 2 slides
2321
+ if (this.parent.options.wrapAround && slides.length > 1) {
2322
+ this.enable();
2323
+ return;
2324
+ }
2325
+ const lastIndex = slides.length ? slides.length - 1 : 0;
2326
+ const boundIndex = this.isPrevious ? 0 : lastIndex;
2327
+ const method = this.parent.selectedIndex == boundIndex ? 'disable' : 'enable';
2328
+ this[method]();
2329
+ };
2330
+ PrevNextButton.prototype.destroy = function () {
2331
+ this.deactivate();
2332
+ this.allOff();
2333
+ };
2334
+ // -------------------------- Flickity prototype -------------------------- //
2335
+ utils.extend(Flickity.defaults, {
2336
+ prevNextButtons: true,
2337
+ arrowShape: {
2338
+ x0: 10,
2339
+ x1: 60,
2340
+ y1: 50,
2341
+ x2: 70,
2342
+ y2: 40,
2343
+ x3: 30,
2344
+ },
2345
+ });
2346
+ Flickity.createMethods.push('_createPrevNextButtons');
2347
+ const proto = Flickity.prototype;
2348
+ proto._createPrevNextButtons = function () {
2349
+ if (!this.options.prevNextButtons) {
2350
+ return;
2351
+ }
2352
+ this.prevButton = new PrevNextButton(-1, this);
2353
+ this.nextButton = new PrevNextButton(1, this);
2354
+ this.on('activate', this.activatePrevNextButtons);
2355
+ };
2356
+ proto.activatePrevNextButtons = function () {
2357
+ this.prevButton.activate();
2358
+ this.nextButton.activate();
2359
+ this.on('deactivate', this.deactivatePrevNextButtons);
2360
+ };
2361
+ proto.deactivatePrevNextButtons = function () {
2362
+ this.prevButton.deactivate();
2363
+ this.nextButton.deactivate();
2364
+ this.off('deactivate', this.deactivatePrevNextButtons);
2365
+ };
2366
+ // @ts-ignore
2367
+ Flickity.PrevNextButton = PrevNextButton;
2368
+ };
2369
+
2370
+ const player = () => {
2371
+ // -------------------------- Player -------------------------- //
2372
+ function Player(parent) {
2373
+ this.parent = parent;
2374
+ this.state = 'stopped';
2375
+ // visibility change event handler
2376
+ this.onVisibilityChange = this.visibilityChange.bind(this);
2377
+ this.onVisibilityPlay = this.visibilityPlay.bind(this);
2378
+ }
2379
+ Player.prototype = Object.create(EvEmitter.prototype);
2380
+ // start play
2381
+ Player.prototype.play = function () {
2382
+ if (this.state == 'playing') {
2383
+ return;
2384
+ }
2385
+ // do not play if page is hidden, start playing when page is visible
2386
+ const isPageHidden = document.hidden;
2387
+ if (isPageHidden) {
2388
+ document.addEventListener('visibilitychange', this.onVisibilityPlay);
2389
+ return;
2390
+ }
2391
+ this.state = 'playing';
2392
+ // listen to visibility change
2393
+ document.addEventListener('visibilitychange', this.onVisibilityChange);
2394
+ // start ticking
2395
+ this.tick();
2396
+ };
2397
+ Player.prototype.tick = function () {
2398
+ // do not tick if not playing
2399
+ if (this.state != 'playing') {
2400
+ return;
2401
+ }
2402
+ let time = this.parent.options.autoPlay;
2403
+ // default to 3 seconds
2404
+ time = typeof time == 'number' ? time : 3000;
2405
+ const _this = this;
2406
+ // HACK: reset ticks if stopped and started within interval
2407
+ this.clear();
2408
+ this.timeout = setTimeout(function () {
2409
+ _this.parent.next(true);
2410
+ _this.tick();
2411
+ }, time);
2412
+ };
2413
+ Player.prototype.stop = function () {
2414
+ this.state = 'stopped';
2415
+ this.clear();
2416
+ // remove visibility change event
2417
+ document.removeEventListener('visibilitychange', this.onVisibilityChange);
2418
+ };
2419
+ Player.prototype.clear = function () {
2420
+ clearTimeout(this.timeout);
2421
+ };
2422
+ Player.prototype.pause = function () {
2423
+ if (this.state == 'playing') {
2424
+ this.state = 'paused';
2425
+ this.clear();
2426
+ }
2427
+ };
2428
+ Player.prototype.unpause = function () {
2429
+ // re-start play if paused
2430
+ if (this.state == 'paused') {
2431
+ this.play();
2432
+ }
2433
+ };
2434
+ // pause if page visibility is hidden, unpause if visible
2435
+ Player.prototype.visibilityChange = function () {
2436
+ const isPageHidden = document.hidden;
2437
+ this[isPageHidden ? 'pause' : 'unpause']();
2438
+ };
2439
+ Player.prototype.visibilityPlay = function () {
2440
+ this.play();
2441
+ document.removeEventListener('visibilitychange', this.onVisibilityPlay);
2442
+ };
2443
+ // -------------------------- Flickity -------------------------- //
2444
+ utils.extend(Flickity.defaults, {
2445
+ pauseAutoPlayOnHover: true,
2446
+ });
2447
+ Flickity.createMethods.push('_createPlayer');
2448
+ const proto = Flickity.prototype;
2449
+ proto._createPlayer = function () {
2450
+ this.player = new Player(this);
2451
+ this.on('activate', this.activatePlayer);
2452
+ this.on('uiChange', this.stopPlayer);
2453
+ this.on('pointerDown', this.stopPlayer);
2454
+ this.on('deactivate', this.deactivatePlayer);
2455
+ };
2456
+ proto.activatePlayer = function () {
2457
+ if (!this.options.autoPlay) {
2458
+ return;
2459
+ }
2460
+ this.player.play();
2461
+ this.element.addEventListener('mouseenter', this);
2462
+ };
2463
+ // Player API, don't hate the ... thanks I know where the door is
2464
+ proto.playPlayer = function () {
2465
+ this.player.play();
2466
+ };
2467
+ proto.stopPlayer = function () {
2468
+ this.player.stop();
2469
+ };
2470
+ proto.pausePlayer = function () {
2471
+ this.player.pause();
2472
+ };
2473
+ proto.unpausePlayer = function () {
2474
+ this.player.unpause();
2475
+ };
2476
+ proto.deactivatePlayer = function () {
2477
+ this.player.stop();
2478
+ this.element.removeEventListener('mouseenter', this);
2479
+ };
2480
+ // ----- mouseenter/leave ----- //
2481
+ // pause auto-play on hover
2482
+ proto.onmouseenter = function () {
2483
+ if (!this.options.pauseAutoPlayOnHover) {
2484
+ return;
2485
+ }
2486
+ this.player.pause();
2487
+ this.element.addEventListener('mouseleave', this);
2488
+ };
2489
+ // resume auto-play on hover off
2490
+ proto.onmouseleave = function () {
2491
+ this.player.unpause();
2492
+ this.element.removeEventListener('mouseleave', this);
2493
+ };
2494
+ // @ts-ignore
2495
+ Flickity.Player = Player;
2496
+ };
2497
+
1433
2498
  const flickity = Flickity;
2499
+ drag();
2500
+ nowNext();
2501
+ player();
1434
2502
 
1435
2503
  const slidesCss = ":host{box-sizing:border-box}*,*::before,*::after{box-sizing:border-box}[hidden]{display:none !important}:host{box-sizing:border-box}*,*::before,*::after{box-sizing:border-box}[hidden]{display:none !important}:host{--dot-color:#ccc;--dot-color-active:var(--nano-color-primary, #007495);--navbtns-icon-color:var(--dot-color-active);--navbtns-bg-color:white;--navbtns-icon-color-disabled:var(--dot-color-active);--navbtns-bg-color-disabled:white;--fsbtn-icon-color:var(--dot-color-active);--fsbtn-bg-color:white;display:block;-webkit-user-select:none;user-select:none;overflow:hidden;transition:opacity 0.2s;opacity:0;max-inline-size:100vw}:host([ready]){opacity:1}.slideshow{max-block-size:100%;min-block-size:inherit;block-size:inherit;position:relative}.slideshow.not-ready{inline-size:100%;overflow:hidden}.flickity-container{opacity:0;transition:opacity 0.2s;display:flex;inline-size:fit-content;block-size:fit-content}.not-ready .flickity-container{inline-size:fit-content;block-size:fit-content}.flickity-container.slides-ready{min-block-size:inherit;max-block-size:inherit;block-size:inherit;inline-size:auto}[hidden]{display:none !important}.ui-extras{pointer-events:none;position:absolute;block-size:100%;inline-size:100%;inset-block-start:0;inset-inline-start:0}.ui-extras *{pointer-events:all}/*! Flickity v2.2.1\nhttps://flickity.metafizzy.co\n---------------------------------------------- */.flickity-enabled{position:relative;opacity:1}.flickity-enabled:focus{outline:none}.flickity-viewport{overflow:hidden;position:relative;min-block-size:100%;flex:1}.flickity-slider{position:absolute;inline-size:100%;block-size:100%}.flickity-enabled.is-draggable{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.flickity-enabled.is-draggable .flickity-viewport{cursor:move;cursor:grab;cursor:grab}.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down{cursor:grabbing}.flickity-button{position:absolute;background:var(--navbtns-bg-color);border:none;color:#333;opacity:0.75}.flickity-button:hover{opacity:1;cursor:pointer}.flickity-button:focus{outline:none;box-shadow:0 0 0 5px #19f}.flickity-button:active{opacity:0.6}.flickity-button:disabled{opacity:0.3;cursor:auto;pointer-events:none;background:var(--navbtns-bg-color-disabled)}.flickity-button-icon{fill:var(--navbtns-icon-color)}.flickity-button:disabled .flickity-button-icon{fill:var(--navbtns-icon-color-disabled)}.flickity-prev-next-button{inset-block-start:50%;inline-size:44px;block-size:44px;border-radius:50%;transform:translateY(-50%)}.flickity-prev-next-button.previous{inset-inline-start:10px}.flickity-prev-next-button.next{inset-inline-end:10px}.flickity-rtl .flickity-prev-next-button.previous{inset-inline:auto 10px}.flickity-rtl .flickity-prev-next-button.next{inset-inline:10px auto}.flickity-prev-next-button .flickity-button-icon{position:absolute;inset-inline-start:20%;inset-block-start:20%;inline-size:60%;block-size:60%}.flickity-page-dots{position:absolute;inline-size:100%;inset-block-end:10px;padding:0;margin:0;list-style:none;text-align:center;line-height:1;z-index:4}.flickity-rtl .flickity-page-dots{direction:rtl}.flickity-page-dots .dot{display:inline-block;inline-size:10px;block-size:10px;margin-block:0;margin-inline:8px;border-radius:50%;cursor:pointer;background:var(--dot-color)}.flickity-page-dots .dot.is-selected{opacity:1;background:var(--dot-color-active)}.flickity-enabled.is-fullscreen{position:fixed;inset-inline-start:0;inset-block-start:0;inline-size:100%;block-size:100%;background:hsla(0, 0%, 0%, 0.9);padding-block-end:35px;z-index:100}.flickity-enabled.is-fullscreen .flickity-page-dots{inset-block-end:45px}html.is-flickity-fullscreen{overflow:hidden}.flickity-fullscreen-button{display:block;inset-inline-end:10px;inset-block-start:10px;inline-size:24px;block-size:24px;border-radius:4px;background:var(--fsbtn-bg-color);fill:var(--fsbtn-icon-color)}.flickity-rtl .flickity-fullscreen-button{inset-inline:10px auto}.flickity-fullscreen-button-exit{display:none}.flickity-enabled.is-fullscreen .flickity-fullscreen-button-exit{display:block}.flickity-enabled.is-fullscreen .flickity-fullscreen-button-view{display:none}.flickity-fullscreen-button .flickity-button-icon{position:absolute;inline-size:16px;block-size:16px;inset-inline-start:4px;inset-block-start:4px}.flickity-enabled.is-fade .flickity-slider>*{pointer-events:none;z-index:0}.flickity-enabled.is-fade .flickity-slider ::slotted(.is-selected){pointer-events:auto;z-index:1}";
1436
2504
  const NanoSlidesStyle0 = slidesCss;
@@ -1873,10 +2941,10 @@ const Slides = /*@__PURE__*/ proxyCustomElement(class Slides extends HTMLElement
1873
2941
  select: this.handleSlideSelect,
1874
2942
  change: this.nanoSlidesChange.emit,
1875
2943
  scroll: this.nanoSlidesScroll.emit,
1876
- settle: this.nanoSlidesTransitionEnd.emit,
1877
- dragStart: this.nanoSlidesDragStart.emit,
1878
- dragMove: this.nanoSlidesDragMove.emit,
1879
- dragEnd: this.nanoSlidesDragEnd.emit,
2944
+ settle: () => requestAnimationFrame(() => this.nanoSlidesTransitionEnd.emit()),
2945
+ dragStart: () => requestAnimationFrame(() => this.nanoSlidesDragStart.emit()),
2946
+ dragMove: () => requestAnimationFrame(() => this.nanoSlidesDragMove.emit()),
2947
+ dragEnd: () => requestAnimationFrame(() => this.nanoSlidesDragEnd.emit()),
1880
2948
  staticClick: this.nanoSlidesTap.emit,
1881
2949
  fullscreenChange: this.handleFullscreen,
1882
2950
  };
@@ -1923,15 +2991,15 @@ const Slides = /*@__PURE__*/ proxyCustomElement(class Slides extends HTMLElement
1923
2991
  this.destroyflickity();
1924
2992
  }
1925
2993
  render() {
1926
- return (h(Host, { key: '984cdb5e6e920f4887e6002634fef0df2849b14d' }, h("div", { key: 'ff35fedc4e325bacfabbb254dbce68c8b43bfc2d', class: {
2994
+ return (h(Host, { key: '9e97a224eef505b29bf19db52c901ba85c058f54' }, h("div", { key: 'e3b0778a1b68bf78fe52abc32c74f30e278a00e4', class: {
1927
2995
  slideshow: true,
1928
2996
  ready: this.ready,
1929
2997
  'not-ready': !this.ready,
1930
- }, part: "base" }, h("div", { key: '5cb1962388d7bec963441ff6b6ff0cc57de138a8', ref: (div) => (this.flickityEl = div), class: {
2998
+ }, part: "base" }, h("div", { key: 'da56ec590908be9a10be1fc41bbf83fa3216e674', ref: (div) => (this.flickityEl = div), class: {
1931
2999
  'flickity-container': true,
1932
3000
  'slides-ready': this.slidesReady,
1933
3001
  'slides-not-ready': !this.slidesReady,
1934
- }, part: "slide-container" }, h("slot", { key: 'a99f63ac2cb5101f76883c67f78e0d83ca3124d4' })), h("div", { key: '5757cabd9881eb9e153999aafe1ff7e3fd957b02', class: "ui-extras" }, h("slot", { key: '6c10bea0e9ede5c30d617f74c6f871cccf9bebdd', name: "ui" })))));
3002
+ }, part: "slide-container" }, h("slot", { key: '12d359c67d1f30245e7aef788018697b0c0b94ee' })), h("div", { key: '8a0a0190ea93acb5ba932b353baa6cbbae33547b', class: "ui-extras" }, h("slot", { key: 'fddc2df69c989ac09e5908a8953783b9ae32d3ba', name: "ui" })))));
1935
3003
  }
1936
3004
  static get watchers() { return {
1937
3005
  "options": ["optionsChanged"],
@@ -2018,6 +3086,6 @@ function defineCustomElement$1() {
2018
3086
  const NanoSlides = Slides;
2019
3087
  const defineCustomElement = defineCustomElement$1;
2020
3088
 
2021
- export { EvEmitter as E, Flickity as F, NanoSlides, defineCustomElement, utils as u };
3089
+ export { Flickity as F, NanoSlides, Unipointer as U, defineCustomElement, utils as u };
2022
3090
 
2023
3091
  //# sourceMappingURL=nano-slides.js.map