@vandenberghinc/volt 1.2.5 → 1.2.6

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 (489) hide show
  1. package/frontend/assets/admin/admin.png +0 -0
  2. package/frontend/assets/admin/password.webp +0 -0
  3. package/frontend/assets/icons/arrow.v1.webp +0 -0
  4. package/frontend/assets/icons/copy.webp +0 -0
  5. package/frontend/assets/payments/arrow.long.webp +0 -0
  6. package/frontend/assets/payments/arrow.long2.webp +0 -0
  7. package/frontend/assets/payments/cancelled.webp +0 -0
  8. package/frontend/assets/payments/check.sign.webp +0 -0
  9. package/frontend/assets/payments/check.webp +0 -0
  10. package/frontend/assets/payments/close.webp +0 -0
  11. package/frontend/assets/payments/error.webp +0 -0
  12. package/frontend/assets/payments/exclamation.webp +0 -0
  13. package/frontend/assets/payments/minus.webp +0 -0
  14. package/frontend/assets/payments/party.webp +0 -0
  15. package/frontend/assets/payments/plus.webp +0 -0
  16. package/frontend/assets/payments/shopping_cart.webp +0 -0
  17. package/frontend/assets/payments/trash.webp +0 -0
  18. package/package.json +5 -1
  19. package/.libris/config.json +0 -82
  20. package/backend/dist/cjs/backend/src/blacklist.d.ts +0 -12
  21. package/backend/dist/cjs/backend/src/blacklist.js +0 -78
  22. package/backend/dist/cjs/backend/src/cli.d.ts +0 -2
  23. package/backend/dist/cjs/backend/src/cli.js +0 -198
  24. package/backend/dist/cjs/backend/src/database/collection.d.ts +0 -1765
  25. package/backend/dist/cjs/backend/src/database/collection.js +0 -3301
  26. package/backend/dist/cjs/backend/src/database/database.d.ts +0 -92
  27. package/backend/dist/cjs/backend/src/database/database.js +0 -170
  28. package/backend/dist/cjs/backend/src/database/document.d.ts +0 -1
  29. package/backend/dist/cjs/backend/src/database/document.js +0 -15
  30. package/backend/dist/cjs/backend/src/database/filters/filters.d.ts +0 -6
  31. package/backend/dist/cjs/backend/src/database/filters/filters.js +0 -15
  32. package/backend/dist/cjs/backend/src/database/filters/strict_filter.d.ts +0 -223
  33. package/backend/dist/cjs/backend/src/database/filters/strict_filter.js +0 -15
  34. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.d.ts +0 -1
  35. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.js +0 -443
  36. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.d.ts +0 -1
  37. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.js +0 -15
  38. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.d.ts +0 -50
  39. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.js +0 -15
  40. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.d.ts +0 -76
  41. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.js +0 -15
  42. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.d.ts +0 -75
  43. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.js +0 -15
  44. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.d.ts +0 -219
  45. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.js +0 -15
  46. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.d.ts +0 -165
  47. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.js +0 -15
  48. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.d.ts +0 -5
  49. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.js +0 -355
  50. package/backend/dist/cjs/backend/src/database/flatten.d.ts +0 -78
  51. package/backend/dist/cjs/backend/src/database/flatten.js +0 -53
  52. package/backend/dist/cjs/backend/src/database/flatten_test.d.ts +0 -1
  53. package/backend/dist/cjs/backend/src/database/flatten_test.js +0 -175
  54. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.d.ts +0 -533
  55. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.js +0 -1046
  56. package/backend/dist/cjs/backend/src/database/quota/quota.d.ts +0 -551
  57. package/backend/dist/cjs/backend/src/database/quota/quota.js +0 -1108
  58. package/backend/dist/cjs/backend/src/database/quota/quota_v1.d.ts +0 -534
  59. package/backend/dist/cjs/backend/src/database/quota/quota_v1.js +0 -1087
  60. package/backend/dist/cjs/backend/src/database/quota/safe_int.d.ts +0 -412
  61. package/backend/dist/cjs/backend/src/database/quota/safe_int.js +0 -745
  62. package/backend/dist/cjs/backend/src/endpoint.d.ts +0 -346
  63. package/backend/dist/cjs/backend/src/endpoint.js +0 -468
  64. package/backend/dist/cjs/backend/src/errors/index.d.ts +0 -7
  65. package/backend/dist/cjs/backend/src/errors/index.js +0 -25
  66. package/backend/dist/cjs/backend/src/errors/internal_external.d.ts +0 -52
  67. package/backend/dist/cjs/backend/src/errors/internal_external.js +0 -95
  68. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.d.ts +0 -41
  69. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.js +0 -47
  70. package/backend/dist/cjs/backend/src/errors/system_error.d.ts +0 -261
  71. package/backend/dist/cjs/backend/src/errors/system_error.js +0 -436
  72. package/backend/dist/cjs/backend/src/events.d.ts +0 -97
  73. package/backend/dist/cjs/backend/src/events.js +0 -15
  74. package/backend/dist/cjs/backend/src/frontend.d.ts +0 -11
  75. package/backend/dist/cjs/backend/src/frontend.js +0 -37
  76. package/backend/dist/cjs/backend/src/image_endpoint.d.ts +0 -44
  77. package/backend/dist/cjs/backend/src/image_endpoint.js +0 -185
  78. package/backend/dist/cjs/backend/src/index.d.ts +0 -23
  79. package/backend/dist/cjs/backend/src/index.js +0 -70
  80. package/backend/dist/cjs/backend/src/logger.d.ts +0 -5
  81. package/backend/dist/cjs/backend/src/logger.js +0 -15
  82. package/backend/dist/cjs/backend/src/meta.d.ts +0 -112
  83. package/backend/dist/cjs/backend/src/meta.js +0 -181
  84. package/backend/dist/cjs/backend/src/payments/paddle.d.ts +0 -329
  85. package/backend/dist/cjs/backend/src/payments/paddle.js +0 -1996
  86. package/backend/dist/cjs/backend/src/payments/stripe/checkout.d.ts +0 -113
  87. package/backend/dist/cjs/backend/src/payments/stripe/checkout.js +0 -295
  88. package/backend/dist/cjs/backend/src/payments/stripe/customers.d.ts +0 -17
  89. package/backend/dist/cjs/backend/src/payments/stripe/customers.js +0 -164
  90. package/backend/dist/cjs/backend/src/payments/stripe/error.d.ts +0 -74
  91. package/backend/dist/cjs/backend/src/payments/stripe/error.js +0 -64
  92. package/backend/dist/cjs/backend/src/payments/stripe/events.d.ts +0 -155
  93. package/backend/dist/cjs/backend/src/payments/stripe/events.js +0 -15
  94. package/backend/dist/cjs/backend/src/payments/stripe/meters.d.ts +0 -105
  95. package/backend/dist/cjs/backend/src/payments/stripe/meters.js +0 -230
  96. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.d.ts +0 -58
  97. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.js +0 -109
  98. package/backend/dist/cjs/backend/src/payments/stripe/products.d.ts +0 -519
  99. package/backend/dist/cjs/backend/src/payments/stripe/products.js +0 -650
  100. package/backend/dist/cjs/backend/src/payments/stripe/stripe.d.ts +0 -215
  101. package/backend/dist/cjs/backend/src/payments/stripe/stripe.js +0 -468
  102. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.d.ts +0 -172
  103. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.js +0 -557
  104. package/backend/dist/cjs/backend/src/payments/stripe/utils.d.ts +0 -63
  105. package/backend/dist/cjs/backend/src/payments/stripe/utils.js +0 -118
  106. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.d.ts +0 -105
  107. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.js +0 -627
  108. package/backend/dist/cjs/backend/src/plugins/browser.d.ts +0 -1
  109. package/backend/dist/cjs/backend/src/plugins/browser.js +0 -15
  110. package/backend/dist/cjs/backend/src/plugins/communication.d.ts +0 -70
  111. package/backend/dist/cjs/backend/src/plugins/communication.js +0 -196
  112. package/backend/dist/cjs/backend/src/plugins/mail/mail.d.ts +0 -255
  113. package/backend/dist/cjs/backend/src/plugins/mail/mail.js +0 -381
  114. package/backend/dist/cjs/backend/src/plugins/mail/ui.d.ts +0 -297
  115. package/backend/dist/cjs/backend/src/plugins/mail/ui.js +0 -1370
  116. package/backend/dist/cjs/backend/src/plugins/pdf.d.ts +0 -1
  117. package/backend/dist/cjs/backend/src/plugins/pdf.js +0 -1456
  118. package/backend/dist/cjs/backend/src/plugins/thread_monitor.d.ts +0 -18
  119. package/backend/dist/cjs/backend/src/plugins/thread_monitor.js +0 -116
  120. package/backend/dist/cjs/backend/src/rate_limit.d.ts +0 -148
  121. package/backend/dist/cjs/backend/src/rate_limit.js +0 -543
  122. package/backend/dist/cjs/backend/src/route.d.ts +0 -39
  123. package/backend/dist/cjs/backend/src/route.js +0 -172
  124. package/backend/dist/cjs/backend/src/server.d.ts +0 -502
  125. package/backend/dist/cjs/backend/src/server.js +0 -1713
  126. package/backend/dist/cjs/backend/src/server.old.d.ts +0 -594
  127. package/backend/dist/cjs/backend/src/server.old.js +0 -2058
  128. package/backend/dist/cjs/backend/src/splash_screen.d.ts +0 -93
  129. package/backend/dist/cjs/backend/src/splash_screen.js +0 -119
  130. package/backend/dist/cjs/backend/src/status.d.ts +0 -89
  131. package/backend/dist/cjs/backend/src/status.js +0 -211
  132. package/backend/dist/cjs/backend/src/stream.d.ts +0 -494
  133. package/backend/dist/cjs/backend/src/stream.js +0 -1370
  134. package/backend/dist/cjs/backend/src/users.d.ts +0 -926
  135. package/backend/dist/cjs/backend/src/users.js +0 -2223
  136. package/backend/dist/cjs/backend/src/utils.d.ts +0 -22
  137. package/backend/dist/cjs/backend/src/utils.js +0 -626
  138. package/backend/dist/cjs/backend/src/view.d.ts +0 -115
  139. package/backend/dist/cjs/backend/src/view.js +0 -519
  140. package/backend/dist/cjs/backend/src/vinc.d.ts +0 -6
  141. package/backend/dist/cjs/backend/src/vinc.js +0 -40
  142. package/backend/dist/cjs/backend/src/volt.d.ts +0 -24
  143. package/backend/dist/cjs/backend/src/volt.js +0 -72
  144. package/backend/dist/cjs/frontend/src/modules/request.d.ts +0 -70
  145. package/backend/dist/cjs/frontend/src/modules/request.js +0 -99
  146. package/backend/dist/cjs/package.json +0 -1
  147. package/backend/dist/esm/backend/src/blacklist.d.ts +0 -12
  148. package/backend/dist/esm/backend/src/blacklist.js +0 -52
  149. package/backend/dist/esm/backend/src/cli.d.ts +0 -2
  150. package/backend/dist/esm/backend/src/cli.js +0 -211
  151. package/backend/dist/esm/backend/src/database/collection.d.ts +0 -1765
  152. package/backend/dist/esm/backend/src/database/collection.js +0 -3779
  153. package/backend/dist/esm/backend/src/database/database.d.ts +0 -92
  154. package/backend/dist/esm/backend/src/database/database.js +0 -214
  155. package/backend/dist/esm/backend/src/database/document.d.ts +0 -1
  156. package/backend/dist/esm/backend/src/database/document.js +0 -558
  157. package/backend/dist/esm/backend/src/database/filters/filters.d.ts +0 -6
  158. package/backend/dist/esm/backend/src/database/filters/filters.js +0 -1
  159. package/backend/dist/esm/backend/src/database/filters/strict_filter.d.ts +0 -223
  160. package/backend/dist/esm/backend/src/database/filters/strict_filter.js +0 -3
  161. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.d.ts +0 -1
  162. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.js +0 -505
  163. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.d.ts +0 -1
  164. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.js +0 -712
  165. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.d.ts +0 -50
  166. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.js +0 -5
  167. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.d.ts +0 -76
  168. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.js +0 -44
  169. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.d.ts +0 -75
  170. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.js +0 -5
  171. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.d.ts +0 -219
  172. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.js +0 -1
  173. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.d.ts +0 -165
  174. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.js +0 -5
  175. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.d.ts +0 -5
  176. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.js +0 -415
  177. package/backend/dist/esm/backend/src/database/flatten.d.ts +0 -78
  178. package/backend/dist/esm/backend/src/database/flatten.js +0 -22
  179. package/backend/dist/esm/backend/src/database/flatten_test.d.ts +0 -1
  180. package/backend/dist/esm/backend/src/database/flatten_test.js +0 -174
  181. package/backend/dist/esm/backend/src/database/quota/quoata_v2.d.ts +0 -533
  182. package/backend/dist/esm/backend/src/database/quota/quoata_v2.js +0 -1155
  183. package/backend/dist/esm/backend/src/database/quota/quota.d.ts +0 -551
  184. package/backend/dist/esm/backend/src/database/quota/quota.js +0 -1219
  185. package/backend/dist/esm/backend/src/database/quota/quota_v1.d.ts +0 -534
  186. package/backend/dist/esm/backend/src/database/quota/quota_v1.js +0 -1242
  187. package/backend/dist/esm/backend/src/database/quota/safe_int.d.ts +0 -412
  188. package/backend/dist/esm/backend/src/database/quota/safe_int.js +0 -810
  189. package/backend/dist/esm/backend/src/endpoint.d.ts +0 -346
  190. package/backend/dist/esm/backend/src/endpoint.js +0 -479
  191. package/backend/dist/esm/backend/src/errors/index.d.ts +0 -7
  192. package/backend/dist/esm/backend/src/errors/index.js +0 -7
  193. package/backend/dist/esm/backend/src/errors/internal_external.d.ts +0 -52
  194. package/backend/dist/esm/backend/src/errors/internal_external.js +0 -86
  195. package/backend/dist/esm/backend/src/errors/invalid_usage_error.d.ts +0 -41
  196. package/backend/dist/esm/backend/src/errors/invalid_usage_error.js +0 -33
  197. package/backend/dist/esm/backend/src/errors/system_error.d.ts +0 -261
  198. package/backend/dist/esm/backend/src/errors/system_error.js +0 -444
  199. package/backend/dist/esm/backend/src/events.d.ts +0 -97
  200. package/backend/dist/esm/backend/src/events.js +0 -5
  201. package/backend/dist/esm/backend/src/frontend.d.ts +0 -11
  202. package/backend/dist/esm/backend/src/frontend.js +0 -12
  203. package/backend/dist/esm/backend/src/image_endpoint.d.ts +0 -44
  204. package/backend/dist/esm/backend/src/image_endpoint.js +0 -196
  205. package/backend/dist/esm/backend/src/index.d.ts +0 -23
  206. package/backend/dist/esm/backend/src/index.js +0 -26
  207. package/backend/dist/esm/backend/src/logger.d.ts +0 -5
  208. package/backend/dist/esm/backend/src/logger.js +0 -8
  209. package/backend/dist/esm/backend/src/meta.d.ts +0 -112
  210. package/backend/dist/esm/backend/src/meta.js +0 -152
  211. package/backend/dist/esm/backend/src/payments/paddle.d.ts +0 -329
  212. package/backend/dist/esm/backend/src/payments/paddle.js +0 -2276
  213. package/backend/dist/esm/backend/src/payments/stripe/checkout.d.ts +0 -113
  214. package/backend/dist/esm/backend/src/payments/stripe/checkout.js +0 -356
  215. package/backend/dist/esm/backend/src/payments/stripe/customers.d.ts +0 -17
  216. package/backend/dist/esm/backend/src/payments/stripe/customers.js +0 -193
  217. package/backend/dist/esm/backend/src/payments/stripe/error.d.ts +0 -74
  218. package/backend/dist/esm/backend/src/payments/stripe/error.js +0 -51
  219. package/backend/dist/esm/backend/src/payments/stripe/events.d.ts +0 -155
  220. package/backend/dist/esm/backend/src/payments/stripe/events.js +0 -5
  221. package/backend/dist/esm/backend/src/payments/stripe/meters.d.ts +0 -105
  222. package/backend/dist/esm/backend/src/payments/stripe/meters.js +0 -318
  223. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.d.ts +0 -58
  224. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.js +0 -135
  225. package/backend/dist/esm/backend/src/payments/stripe/products.d.ts +0 -519
  226. package/backend/dist/esm/backend/src/payments/stripe/products.js +0 -896
  227. package/backend/dist/esm/backend/src/payments/stripe/stripe.d.ts +0 -215
  228. package/backend/dist/esm/backend/src/payments/stripe/stripe.js +0 -464
  229. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.d.ts +0 -172
  230. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.js +0 -754
  231. package/backend/dist/esm/backend/src/payments/stripe/utils.d.ts +0 -63
  232. package/backend/dist/esm/backend/src/payments/stripe/utils.js +0 -131
  233. package/backend/dist/esm/backend/src/payments/stripe/webhooks.d.ts +0 -105
  234. package/backend/dist/esm/backend/src/payments/stripe/webhooks.js +0 -752
  235. package/backend/dist/esm/backend/src/plugins/browser.d.ts +0 -1
  236. package/backend/dist/esm/backend/src/plugins/browser.js +0 -170
  237. package/backend/dist/esm/backend/src/plugins/communication.d.ts +0 -70
  238. package/backend/dist/esm/backend/src/plugins/communication.js +0 -169
  239. package/backend/dist/esm/backend/src/plugins/mail/mail.d.ts +0 -255
  240. package/backend/dist/esm/backend/src/plugins/mail/mail.js +0 -396
  241. package/backend/dist/esm/backend/src/plugins/mail/ui.d.ts +0 -297
  242. package/backend/dist/esm/backend/src/plugins/mail/ui.js +0 -1400
  243. package/backend/dist/esm/backend/src/plugins/pdf.d.ts +0 -1
  244. package/backend/dist/esm/backend/src/plugins/pdf.js +0 -1694
  245. package/backend/dist/esm/backend/src/plugins/thread_monitor.d.ts +0 -18
  246. package/backend/dist/esm/backend/src/plugins/thread_monitor.js +0 -120
  247. package/backend/dist/esm/backend/src/rate_limit.d.ts +0 -148
  248. package/backend/dist/esm/backend/src/rate_limit.js +0 -667
  249. package/backend/dist/esm/backend/src/route.d.ts +0 -39
  250. package/backend/dist/esm/backend/src/route.js +0 -222
  251. package/backend/dist/esm/backend/src/server.d.ts +0 -502
  252. package/backend/dist/esm/backend/src/server.js +0 -2034
  253. package/backend/dist/esm/backend/src/server.old.d.ts +0 -594
  254. package/backend/dist/esm/backend/src/server.old.js +0 -2630
  255. package/backend/dist/esm/backend/src/splash_screen.d.ts +0 -93
  256. package/backend/dist/esm/backend/src/splash_screen.js +0 -156
  257. package/backend/dist/esm/backend/src/status.d.ts +0 -89
  258. package/backend/dist/esm/backend/src/status.js +0 -213
  259. package/backend/dist/esm/backend/src/stream.d.ts +0 -494
  260. package/backend/dist/esm/backend/src/stream.js +0 -1611
  261. package/backend/dist/esm/backend/src/users.d.ts +0 -926
  262. package/backend/dist/esm/backend/src/users.js +0 -2423
  263. package/backend/dist/esm/backend/src/utils.d.ts +0 -22
  264. package/backend/dist/esm/backend/src/utils.js +0 -463
  265. package/backend/dist/esm/backend/src/view.d.ts +0 -115
  266. package/backend/dist/esm/backend/src/view.js +0 -584
  267. package/backend/dist/esm/backend/src/vinc.d.ts +0 -6
  268. package/backend/dist/esm/backend/src/vinc.js +0 -6
  269. package/backend/dist/esm/backend/src/volt.d.ts +0 -24
  270. package/backend/dist/esm/backend/src/volt.js +0 -27
  271. package/backend/dist/esm/frontend/src/modules/request.d.ts +0 -70
  272. package/backend/dist/esm/frontend/src/modules/request.js +0 -117
  273. package/backend/old/file_watcher.ts +0 -359
  274. package/backend/old/request.deprc.js +0 -626
  275. package/backend/old/response.deprc.js +0 -354
  276. package/frontend/dist/backend/src/database/collection.d.ts +0 -1765
  277. package/frontend/dist/backend/src/database/collection.js +0 -3779
  278. package/frontend/dist/backend/src/database/database.d.ts +0 -92
  279. package/frontend/dist/backend/src/database/database.js +0 -214
  280. package/frontend/dist/backend/src/database/filters/filters.d.ts +0 -6
  281. package/frontend/dist/backend/src/database/filters/filters.js +0 -1
  282. package/frontend/dist/backend/src/database/filters/strict_filter.d.ts +0 -223
  283. package/frontend/dist/backend/src/database/filters/strict_filter.js +0 -3
  284. package/frontend/dist/backend/src/database/filters/strict_update_filter.d.ts +0 -165
  285. package/frontend/dist/backend/src/database/filters/strict_update_filter.js +0 -5
  286. package/frontend/dist/backend/src/database/flatten.d.ts +0 -78
  287. package/frontend/dist/backend/src/database/flatten.js +0 -22
  288. package/frontend/dist/backend/src/endpoint.d.ts +0 -346
  289. package/frontend/dist/backend/src/endpoint.js +0 -479
  290. package/frontend/dist/backend/src/errors/index.d.ts +0 -7
  291. package/frontend/dist/backend/src/errors/index.js +0 -7
  292. package/frontend/dist/backend/src/errors/internal_external.d.ts +0 -52
  293. package/frontend/dist/backend/src/errors/internal_external.js +0 -86
  294. package/frontend/dist/backend/src/errors/invalid_usage_error.d.ts +0 -41
  295. package/frontend/dist/backend/src/errors/invalid_usage_error.js +0 -33
  296. package/frontend/dist/backend/src/errors/system_error.d.ts +0 -261
  297. package/frontend/dist/backend/src/errors/system_error.js +0 -444
  298. package/frontend/dist/backend/src/events.d.ts +0 -97
  299. package/frontend/dist/backend/src/events.js +0 -5
  300. package/frontend/dist/backend/src/frontend.d.ts +0 -11
  301. package/frontend/dist/backend/src/frontend.js +0 -12
  302. package/frontend/dist/backend/src/image_endpoint.d.ts +0 -44
  303. package/frontend/dist/backend/src/image_endpoint.js +0 -196
  304. package/frontend/dist/backend/src/meta.d.ts +0 -112
  305. package/frontend/dist/backend/src/meta.js +0 -152
  306. package/frontend/dist/backend/src/payments/paddle.d.ts +0 -329
  307. package/frontend/dist/backend/src/payments/paddle.js +0 -2276
  308. package/frontend/dist/backend/src/payments/stripe/checkout.d.ts +0 -113
  309. package/frontend/dist/backend/src/payments/stripe/checkout.js +0 -356
  310. package/frontend/dist/backend/src/payments/stripe/customers.d.ts +0 -17
  311. package/frontend/dist/backend/src/payments/stripe/customers.js +0 -193
  312. package/frontend/dist/backend/src/payments/stripe/error.d.ts +0 -74
  313. package/frontend/dist/backend/src/payments/stripe/error.js +0 -51
  314. package/frontend/dist/backend/src/payments/stripe/events.d.ts +0 -155
  315. package/frontend/dist/backend/src/payments/stripe/events.js +0 -5
  316. package/frontend/dist/backend/src/payments/stripe/meters.d.ts +0 -105
  317. package/frontend/dist/backend/src/payments/stripe/meters.js +0 -318
  318. package/frontend/dist/backend/src/payments/stripe/payment_methods.d.ts +0 -58
  319. package/frontend/dist/backend/src/payments/stripe/payment_methods.js +0 -135
  320. package/frontend/dist/backend/src/payments/stripe/products.d.ts +0 -519
  321. package/frontend/dist/backend/src/payments/stripe/products.js +0 -896
  322. package/frontend/dist/backend/src/payments/stripe/stripe.d.ts +0 -215
  323. package/frontend/dist/backend/src/payments/stripe/stripe.js +0 -464
  324. package/frontend/dist/backend/src/payments/stripe/subscriptions.d.ts +0 -172
  325. package/frontend/dist/backend/src/payments/stripe/subscriptions.js +0 -754
  326. package/frontend/dist/backend/src/payments/stripe/utils.d.ts +0 -63
  327. package/frontend/dist/backend/src/payments/stripe/utils.js +0 -131
  328. package/frontend/dist/backend/src/payments/stripe/webhooks.d.ts +0 -105
  329. package/frontend/dist/backend/src/payments/stripe/webhooks.js +0 -752
  330. package/frontend/dist/backend/src/plugins/mail/mail.d.ts +0 -255
  331. package/frontend/dist/backend/src/plugins/mail/mail.js +0 -396
  332. package/frontend/dist/backend/src/plugins/mail/ui.d.ts +0 -297
  333. package/frontend/dist/backend/src/plugins/mail/ui.js +0 -1400
  334. package/frontend/dist/backend/src/rate_limit.d.ts +0 -148
  335. package/frontend/dist/backend/src/rate_limit.js +0 -667
  336. package/frontend/dist/backend/src/route.d.ts +0 -39
  337. package/frontend/dist/backend/src/route.js +0 -222
  338. package/frontend/dist/backend/src/server.d.ts +0 -502
  339. package/frontend/dist/backend/src/server.js +0 -2034
  340. package/frontend/dist/backend/src/splash_screen.d.ts +0 -93
  341. package/frontend/dist/backend/src/splash_screen.js +0 -156
  342. package/frontend/dist/backend/src/status.d.ts +0 -89
  343. package/frontend/dist/backend/src/status.js +0 -213
  344. package/frontend/dist/backend/src/stream.d.ts +0 -494
  345. package/frontend/dist/backend/src/stream.js +0 -1611
  346. package/frontend/dist/backend/src/users.d.ts +0 -926
  347. package/frontend/dist/backend/src/users.js +0 -2423
  348. package/frontend/dist/backend/src/utils.d.ts +0 -22
  349. package/frontend/dist/backend/src/utils.js +0 -463
  350. package/frontend/dist/backend/src/view.d.ts +0 -115
  351. package/frontend/dist/backend/src/view.js +0 -584
  352. package/frontend/dist/frontend/src/elements/base.d.ts +0 -3743
  353. package/frontend/dist/frontend/src/elements/base.js +0 -12151
  354. package/frontend/dist/frontend/src/elements/module.d.ts +0 -95
  355. package/frontend/dist/frontend/src/elements/module.js +0 -216
  356. package/frontend/dist/frontend/src/elements/register_element.d.ts +0 -3
  357. package/frontend/dist/frontend/src/elements/register_element.js +0 -22
  358. package/frontend/dist/frontend/src/elements/resize_query_manager.d.ts +0 -0
  359. package/frontend/dist/frontend/src/elements/resize_query_manager.js +0 -150
  360. package/frontend/dist/frontend/src/elements/types.d.ts +0 -52
  361. package/frontend/dist/frontend/src/elements/types.js +0 -5
  362. package/frontend/dist/frontend/src/index.d.ts +0 -21
  363. package/frontend/dist/frontend/src/index.js +0 -29
  364. package/frontend/dist/frontend/src/modules/attachment.d.ts +0 -126
  365. package/frontend/dist/frontend/src/modules/attachment.js +0 -306
  366. package/frontend/dist/frontend/src/modules/auth.d.ts +0 -44
  367. package/frontend/dist/frontend/src/modules/auth.js +0 -80
  368. package/frontend/dist/frontend/src/modules/color.d.ts +0 -160
  369. package/frontend/dist/frontend/src/modules/color.js +0 -316
  370. package/frontend/dist/frontend/src/modules/compression.d.ts +0 -39
  371. package/frontend/dist/frontend/src/modules/compression.js +0 -102
  372. package/frontend/dist/frontend/src/modules/cookies.d.ts +0 -44
  373. package/frontend/dist/frontend/src/modules/cookies.js +0 -143
  374. package/frontend/dist/frontend/src/modules/events.d.ts +0 -31
  375. package/frontend/dist/frontend/src/modules/events.js +0 -79
  376. package/frontend/dist/frontend/src/modules/google.d.ts +0 -23
  377. package/frontend/dist/frontend/src/modules/google.js +0 -52
  378. package/frontend/dist/frontend/src/modules/meta.d.ts +0 -14
  379. package/frontend/dist/frontend/src/modules/meta.js +0 -48
  380. package/frontend/dist/frontend/src/modules/paddle.d.ts +0 -1207
  381. package/frontend/dist/frontend/src/modules/paddle.js +0 -2594
  382. package/frontend/dist/frontend/src/modules/request.d.ts +0 -70
  383. package/frontend/dist/frontend/src/modules/request.js +0 -117
  384. package/frontend/dist/frontend/src/modules/settings.d.ts +0 -3
  385. package/frontend/dist/frontend/src/modules/settings.js +0 -5
  386. package/frontend/dist/frontend/src/modules/statics.d.ts +0 -21
  387. package/frontend/dist/frontend/src/modules/statics.js +0 -43
  388. package/frontend/dist/frontend/src/modules/stripe/cart.d.ts +0 -112
  389. package/frontend/dist/frontend/src/modules/stripe/cart.js +0 -321
  390. package/frontend/dist/frontend/src/modules/stripe/checkout.d.ts +0 -7
  391. package/frontend/dist/frontend/src/modules/stripe/checkout.js +0 -37
  392. package/frontend/dist/frontend/src/modules/stripe/index.m.d.ts +0 -6
  393. package/frontend/dist/frontend/src/modules/stripe/index.m.js +0 -6
  394. package/frontend/dist/frontend/src/modules/stripe/payments.d.ts +0 -58
  395. package/frontend/dist/frontend/src/modules/stripe/payments.js +0 -92
  396. package/frontend/dist/frontend/src/modules/support.d.ts +0 -30
  397. package/frontend/dist/frontend/src/modules/support.js +0 -53
  398. package/frontend/dist/frontend/src/modules/theme.d.ts +0 -133
  399. package/frontend/dist/frontend/src/modules/theme.js +0 -406
  400. package/frontend/dist/frontend/src/modules/themes.d.ts +0 -12
  401. package/frontend/dist/frontend/src/modules/themes.js +0 -22
  402. package/frontend/dist/frontend/src/modules/user.d.ts +0 -164
  403. package/frontend/dist/frontend/src/modules/user.js +0 -270
  404. package/frontend/dist/frontend/src/modules/utils.d.ts +0 -176
  405. package/frontend/dist/frontend/src/modules/utils.js +0 -569
  406. package/frontend/dist/frontend/src/types/gradient.d.ts +0 -29
  407. package/frontend/dist/frontend/src/types/gradient.js +0 -79
  408. package/frontend/dist/frontend/src/ui/border_button.d.ts +0 -94
  409. package/frontend/dist/frontend/src/ui/border_button.js +0 -228
  410. package/frontend/dist/frontend/src/ui/button.d.ts +0 -241
  411. package/frontend/dist/frontend/src/ui/button.js +0 -682
  412. package/frontend/dist/frontend/src/ui/canvas.d.ts +0 -138
  413. package/frontend/dist/frontend/src/ui/canvas.js +0 -444
  414. package/frontend/dist/frontend/src/ui/checkbox.d.ts +0 -74
  415. package/frontend/dist/frontend/src/ui/checkbox.js +0 -321
  416. package/frontend/dist/frontend/src/ui/code.d.ts +0 -235
  417. package/frontend/dist/frontend/src/ui/code.js +0 -1007
  418. package/frontend/dist/frontend/src/ui/context_menu.d.ts +0 -36
  419. package/frontend/dist/frontend/src/ui/context_menu.js +0 -205
  420. package/frontend/dist/frontend/src/ui/css.d.ts +0 -16
  421. package/frontend/dist/frontend/src/ui/css.js +0 -48
  422. package/frontend/dist/frontend/src/ui/divider.d.ts +0 -15
  423. package/frontend/dist/frontend/src/ui/divider.js +0 -78
  424. package/frontend/dist/frontend/src/ui/dropdown.d.ts +0 -176
  425. package/frontend/dist/frontend/src/ui/dropdown.js +0 -481
  426. package/frontend/dist/frontend/src/ui/for_each.d.ts +0 -37
  427. package/frontend/dist/frontend/src/ui/for_each.js +0 -92
  428. package/frontend/dist/frontend/src/ui/form.d.ts +0 -34
  429. package/frontend/dist/frontend/src/ui/form.js +0 -233
  430. package/frontend/dist/frontend/src/ui/frame_modes.d.ts +0 -37
  431. package/frontend/dist/frontend/src/ui/frame_modes.js +0 -108
  432. package/frontend/dist/frontend/src/ui/google_map.d.ts +0 -24
  433. package/frontend/dist/frontend/src/ui/google_map.js +0 -106
  434. package/frontend/dist/frontend/src/ui/gradient.d.ts +0 -25
  435. package/frontend/dist/frontend/src/ui/gradient.js +0 -131
  436. package/frontend/dist/frontend/src/ui/image.d.ts +0 -111
  437. package/frontend/dist/frontend/src/ui/image.js +0 -576
  438. package/frontend/dist/frontend/src/ui/input.d.ts +0 -392
  439. package/frontend/dist/frontend/src/ui/input.js +0 -1201
  440. package/frontend/dist/frontend/src/ui/link.d.ts +0 -25
  441. package/frontend/dist/frontend/src/ui/link.js +0 -140
  442. package/frontend/dist/frontend/src/ui/list.d.ts +0 -37
  443. package/frontend/dist/frontend/src/ui/list.js +0 -170
  444. package/frontend/dist/frontend/src/ui/loader_button.d.ts +0 -80
  445. package/frontend/dist/frontend/src/ui/loader_button.js +0 -193
  446. package/frontend/dist/frontend/src/ui/loaders.d.ts +0 -57
  447. package/frontend/dist/frontend/src/ui/loaders.js +0 -157
  448. package/frontend/dist/frontend/src/ui/popup.d.ts +0 -94
  449. package/frontend/dist/frontend/src/ui/popup.js +0 -510
  450. package/frontend/dist/frontend/src/ui/pseudo.d.ts +0 -44
  451. package/frontend/dist/frontend/src/ui/pseudo.js +0 -154
  452. package/frontend/dist/frontend/src/ui/scroller.d.ts +0 -105
  453. package/frontend/dist/frontend/src/ui/scroller.js +0 -1253
  454. package/frontend/dist/frontend/src/ui/slider.d.ts +0 -45
  455. package/frontend/dist/frontend/src/ui/slider.js +0 -217
  456. package/frontend/dist/frontend/src/ui/spacer.d.ts +0 -15
  457. package/frontend/dist/frontend/src/ui/spacer.js +0 -78
  458. package/frontend/dist/frontend/src/ui/span.d.ts +0 -15
  459. package/frontend/dist/frontend/src/ui/span.js +0 -73
  460. package/frontend/dist/frontend/src/ui/stack.d.ts +0 -66
  461. package/frontend/dist/frontend/src/ui/stack.js +0 -335
  462. package/frontend/dist/frontend/src/ui/steps.d.ts +0 -131
  463. package/frontend/dist/frontend/src/ui/steps.js +0 -308
  464. package/frontend/dist/frontend/src/ui/style.d.ts +0 -17
  465. package/frontend/dist/frontend/src/ui/style.js +0 -73
  466. package/frontend/dist/frontend/src/ui/switch.d.ts +0 -69
  467. package/frontend/dist/frontend/src/ui/switch.js +0 -357
  468. package/frontend/dist/frontend/src/ui/table.d.ts +0 -100
  469. package/frontend/dist/frontend/src/ui/table.js +0 -405
  470. package/frontend/dist/frontend/src/ui/tabs.d.ts +0 -111
  471. package/frontend/dist/frontend/src/ui/tabs.js +0 -424
  472. package/frontend/dist/frontend/src/ui/text.d.ts +0 -15
  473. package/frontend/dist/frontend/src/ui/text.js +0 -83
  474. package/frontend/dist/frontend/src/ui/title.d.ts +0 -91
  475. package/frontend/dist/frontend/src/ui/title.js +0 -272
  476. package/frontend/dist/frontend/src/ui/ui.d.ts +0 -35
  477. package/frontend/dist/frontend/src/ui/ui.js +0 -38
  478. package/frontend/dist/frontend/src/ui/view.d.ts +0 -15
  479. package/frontend/dist/frontend/src/ui/view.js +0 -88
  480. package/frontend/dist/frontend/src/volt.d.ts +0 -20
  481. package/frontend/dist/frontend/src/volt.js +0 -27
  482. package/frontend/examples/theme/theme.ts +0 -58
  483. package/frontend/tools/bundle_d_ts.js +0 -71
  484. package/frontend/tools/convert_to_jsdoc_input.txt +0 -9452
  485. package/frontend/tools/convert_to_jsdoc_output.txt +0 -7626
  486. package/frontend/tools/convert_to_jsdoc_tmp.js +0 -345
  487. package/frontend/tools/scan_mixed_imports.js +0 -69
  488. /package/frontend/{dist/frontend/src/css → css}/adyen.css +0 -0
  489. /package/frontend/{dist/frontend/src/css → css}/volt.css +0 -0
@@ -1,1253 +0,0 @@
1
- /**
2
- * @author Daan van den Bergh
3
- * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
- */
5
- var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
6
- function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
7
- var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
8
- var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
9
- var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
10
- var _, done = false;
11
- for (var i = decorators.length - 1; i >= 0; i--) {
12
- var context = {};
13
- for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
14
- for (var p in contextIn.access) context.access[p] = contextIn.access[p];
15
- context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
16
- var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
17
- if (kind === "accessor") {
18
- if (result === void 0) continue;
19
- if (result === null || typeof result !== "object") throw new TypeError("Object expected");
20
- if (_ = accept(result.get)) descriptor.get = _;
21
- if (_ = accept(result.set)) descriptor.set = _;
22
- if (_ = accept(result.init)) initializers.unshift(_);
23
- }
24
- else if (_ = accept(result)) {
25
- if (kind === "field") initializers.unshift(_);
26
- else descriptor[key] = _;
27
- }
28
- }
29
- if (target) Object.defineProperty(target, contextIn.name, descriptor);
30
- done = true;
31
- };
32
- var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
33
- var useValue = arguments.length > 2;
34
- for (var i = 0; i < initializers.length; i++) {
35
- value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
36
- }
37
- return useValue ? value : void 0;
38
- };
39
- // Imports.
40
- import { Elements, VElementTagMap } from "../elements/module.js";
41
- import { Utils } from "../modules/utils.js";
42
- import { VStack, VStackElement } from "./stack.js";
43
- // Scroller.
44
- // - Warning: Setting padding on element attribute "content" may cause undefined behaviour.
45
- let ScrollerElement = (() => {
46
- let _classDecorators = [Elements.create({
47
- name: "ScrollerElement",
48
- default_style: {
49
- "position": "relative", // is required for attribute "track"
50
- "margin": "0px",
51
- "padding": "0px",
52
- // "clear": "both",
53
- "display": "flex", // to support vertical spacers.
54
- "overflow": "hidden",
55
- // "flex": "1", // disabled to support horizontal spacers in VStacks.
56
- "align-content": "flex-start", // align items at start, do not stretch / space when inside HStack.
57
- "flex-direction": "column",
58
- // "text-align": "start",
59
- "scroll-behavior": "auto",
60
- "overscroll-behavior": "auto", // relay to parent to resume scroll when local scroll has ended.
61
- "height": "fit-content", // set height to max compared to parents non overflow, so scrolling can take effect.
62
- "content-visibility": "auto", // improve rendering.
63
- // "align-content": "flex-start", // align items at start, do not stretch / space when inside HStack.
64
- // "align-items": "flex-start", // align items at start, do not stretch / space when inside HStack.
65
- },
66
- })];
67
- let _classDescriptor;
68
- let _classExtraInitializers = [];
69
- let _classThis;
70
- let _classSuper = VElementTagMap.div;
71
- var ScrollerElement = class extends _classSuper {
72
- static { _classThis = this; }
73
- static {
74
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
75
- __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
76
- ScrollerElement = _classThis = _classDescriptor.value;
77
- if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
78
- __runInitializers(_classThis, _classExtraInitializers);
79
- }
80
- // @ts-expect-error
81
- content;
82
- thumb;
83
- track;
84
- on_scroll_callbacks;
85
- iterate;
86
- iterate_nodes;
87
- m_delay;
88
- _h_alignment;
89
- _current_h_alignment;
90
- _v_alignment;
91
- _current_v_alignment;
92
- _alignment_callback_activated;
93
- _alignment_callback;
94
- _fadeout_timeout;
95
- // Constructor.
96
- constructor(...children) {
97
- // Initialize base class.
98
- super({
99
- derived: ScrollerElement,
100
- });
101
- // Style.
102
- if (this.position() != "absolute") {
103
- this.position("relative"); // is required for attribute "track"
104
- }
105
- super.overflow("hidden"); // should always be hidden to enable scrolling, and otherwise the thumb not be visible due to overflow width.
106
- this.class("volt_hide_scrollbar");
107
- this.styles({
108
- "content-visibility": "auto",
109
- });
110
- // Content.
111
- this.content = VStack(...children)
112
- .parent(this)
113
- .class("volt_hide_scrollbar")
114
- .position("relative") // in case it has absolute children that should scroll, otherwise the content wont scroll without "relative".
115
- .frame("100%", "100%")
116
- .flex("1 1 0") // flex-basis 0 otherwise it expands its parent.
117
- .overflow("scroll")
118
- .overscroll_behavior(ScrollerElement.default_style["overscroll-behavior"])
119
- .styles({
120
- "content-visibility": "auto",
121
- });
122
- // Scroll bar.
123
- this.thumb = VStack()
124
- .parent(this)
125
- .position(0, 0, null, 0)
126
- .height(30)
127
- .border_radius(10)
128
- .overflow("visible") // for thumb shadow.
129
- .background_color("#CCCCCC")
130
- .opacity(0)
131
- .transition("opacity 0.3s linear")
132
- .box_shadow("0px 0px 5px #00000005");
133
- this.track = VStack(this.thumb)
134
- .parent(this)
135
- .class("volt_hide_scrollbar")
136
- .position(5, 5, 5, null)
137
- .width(10)
138
- .background_color("transparent")
139
- .border_radius(10)
140
- .transition("background-color 0.3s linear")
141
- .assign("background_value", "#28292E")
142
- .overflow("visible");
143
- // Add children.
144
- super.append(this.content, this.track);
145
- // The on scroll callbacks.
146
- this.on_scroll_callbacks = [];
147
- // Alias functions.
148
- // this.raw_append = super.append.bind(super);
149
- this.iterate = this.content.iterate.bind(this.content);
150
- this.iterate_nodes = this.content.iterate_nodes.bind(this.content);
151
- // Set default delay.
152
- this.m_delay = 1000;
153
- // Overwrite track background functions to keep the background color.
154
- // this.track.__background__ = this.track.background;
155
- // this.track.__background_color__ = this.background_color;
156
- this.track.background = function (value) {
157
- if (value == null) {
158
- return this.__background_value__ ?? "";
159
- }
160
- this.__background_value__ = value;
161
- return this;
162
- };
163
- this.track.background_color = function (value) {
164
- if (value == null) {
165
- return this.__background_value__ ?? "";
166
- }
167
- this.__background_value__ = value;
168
- return this;
169
- };
170
- // Mouse enter event.
171
- this.track.addEventListener("mouseenter", (event) => {
172
- if (!this.is_scrollable()) {
173
- return null;
174
- }
175
- this.track.style.backgroundColor = this.track.__background_value__;
176
- clearTimeout(this._fadeout_timeout);
177
- this.thumb.style.opacity = "1"; // keep as opacity for box shadow.
178
- });
179
- // Mouse leave event.
180
- this.track.addEventListener("mouseleave", (event) => {
181
- if (!this.is_scrollable()) {
182
- return null;
183
- }
184
- if (!this.thumb.dragging) {
185
- this.track.style.backgroundColor = "transparent";
186
- this.thumb.style.opacity = "0"; // keep as opacity for box shadow.
187
- }
188
- });
189
- // Scroll event.
190
- this.content.addEventListener("scroll", (event) => {
191
- // Calculate thumb offset.
192
- const height = this.content.clientHeight;
193
- const relative_height = this.track.clientHeight; //this.content.clientHeight;
194
- const thumb_height = this.thumb.clientHeight;
195
- const scroll_height = this.content.scrollHeight;
196
- const scroll_top = this.content.scrollTop;
197
- let relative_top;
198
- if (scroll_top >= scroll_height - height) {
199
- relative_top = relative_height - thumb_height;
200
- }
201
- else {
202
- relative_top = relative_height * (scroll_top / (scroll_height - height)) - thumb_height / 2;
203
- if (relative_top + thumb_height >= relative_height) {
204
- relative_top = relative_height - thumb_height - 3;
205
- }
206
- }
207
- if (relative_top < 0) {
208
- relative_top = 0;
209
- }
210
- this.thumb.style.transform = `translateY(${relative_top}px)`;
211
- // Fade in.
212
- // this.track.style.backgroundColor = this.track.__background_value__;
213
- clearTimeout(this._fadeout_timeout);
214
- this.thumb.style.opacity = "1";
215
- // Fade out.
216
- clearTimeout(this._fadeout_timeout);
217
- this._fadeout_timeout = setTimeout(() => {
218
- this.track.style.backgroundColor = "transparent"; // also hide track so that when the user drags the thumb and the track becomes visible, the track and the thumb fade out simultaneously when the dragging ends.
219
- this.thumb.style.opacity = "0";
220
- }, this.m_delay);
221
- });
222
- // Set scroll by dragging thumb.
223
- let start_y, old_user_select;
224
- const mouse_up_handler = (event) => {
225
- // No longer dragging.
226
- this.thumb.dragging = false;
227
- // Restore user select.
228
- this.style.userSelect = old_user_select;
229
- // Remove handler.
230
- document.body.removeEventListener("mouseup", mouse_up_handler);
231
- };
232
- this.thumb.onmousedown = (event) => {
233
- // Not scrollable.
234
- if (!this.is_scrollable()) {
235
- return null;
236
- }
237
- // Set start y.
238
- start_y = this.content.getBoundingClientRect().top + parseFloat(window.getComputedStyle(this.track).marginTop);
239
- // Set user select.
240
- // Should be set on "this" on "this.content" does not work correctly.
241
- old_user_select = this.content.style.userSelect;
242
- this.style.userSelect = "none";
243
- // Set dragging.
244
- this.thumb.dragging = true;
245
- // Show track.
246
- this.track.style.backgroundColor = this.track.__background_value__;
247
- clearTimeout(this._fadeout_timeout);
248
- this.thumb.style.opacity = "1"; // keep as opacity for box shadow.
249
- // Add mouse up handler to body.
250
- document.body.addEventListener("mouseup", mouse_up_handler);
251
- };
252
- this.addEventListener("mousemove", (event) => {
253
- if (this.thumb.dragging) {
254
- // Vars.
255
- const height = this.content.clientHeight;
256
- const y = Math.max(0, event.clientY - start_y);
257
- let y_percentage = Utils.round(y / height, 2); // needs to be rounder otherwise it always remains at 0.9999 and never reaches the end.
258
- const computed = window.getComputedStyle(this.content);
259
- const max_scroll_top = (this.content.scrollHeight -
260
- this.content.clientHeight +
261
- parseFloat(computed.paddingTop) +
262
- parseFloat(computed.paddingBottom));
263
- const scroll_top = Math.round(max_scroll_top * y_percentage);
264
- // Set the scroll top.
265
- this.content.scrollTop = scroll_top; // triggers on scroll which updates the thumb top.
266
- }
267
- });
268
- // Scroll by clicking on the track.
269
- this.track.onclick = (event) => {
270
- // Not scrollable.
271
- if (!this.is_scrollable()) {
272
- return null;
273
- }
274
- // Vars.
275
- const height = this.content.clientHeight;
276
- const start_y = this.content.getBoundingClientRect().top + parseFloat(window.getComputedStyle(this.track).marginTop);
277
- const y = Math.max(0, event.clientY - start_y);
278
- let y_percentage = Utils.round(y / height, 2); // needs to be rounder otherwise it always remains at 0.9999 and never reaches the end.
279
- const computed = window.getComputedStyle(this.content);
280
- const max_scroll_top = (this.content.scrollHeight -
281
- this.content.clientHeight +
282
- parseFloat(computed.paddingTop) +
283
- parseFloat(computed.paddingBottom));
284
- const scroll_top = Math.round(max_scroll_top * y_percentage);
285
- // Set the scroll top.
286
- this.content.scrollTop = scroll_top; // triggers on scroll which updates the thumb top.
287
- };
288
- // On alignment check callback.
289
- // When the alignment is set to not leading, and the content can scroll, then it is temporarily set to leading till the content is no longer scrollable.
290
- this._h_alignment = undefined;
291
- this._current_h_alignment = undefined;
292
- this._v_alignment = undefined;
293
- this._current_v_alignment = undefined;
294
- this._alignment_callback_activated = false;
295
- this._alignment_callback = () => {
296
- if (this._h_alignment !== undefined) {
297
- if (this.content.clientWidth >= this.clientWidth) {
298
- if (this._current_h_alignment !== "normal") {
299
- super.align_items("normal");
300
- this._current_h_alignment = "normal";
301
- }
302
- }
303
- else {
304
- if (this._current_h_alignment !== this._h_alignment) {
305
- super.align(this._h_alignment);
306
- this._current_h_alignment = this._h_alignment;
307
- }
308
- }
309
- }
310
- if (this._v_alignment !== undefined) {
311
- if (this.content.clientHeight > this.clientHeight) {
312
- if (this._current_v_alignment !== "normal") {
313
- super.align_vertical("normal");
314
- this._current_v_alignment = "normal";
315
- }
316
- }
317
- else {
318
- if (this._current_v_alignment !== this._v_alignment) {
319
- super.align_vertical(this._v_alignment);
320
- this._current_v_alignment = this._v_alignment;
321
- }
322
- }
323
- }
324
- };
325
- }
326
- // Is scrollable.
327
- is_scrollable() {
328
- return this.content.scrollHeight > this.content.clientHeight || this.content.scrollWidth > this.content.clientWidth;
329
- }
330
- // Set remove children to content.
331
- remove_children() {
332
- this.content.inner_html("");
333
- return this;
334
- }
335
- // By default append items to the content.
336
- append(...children) {
337
- this.content.append(...children);
338
- return this;
339
- }
340
- // By default get child of the content.
341
- child(index) {
342
- return this.content.child(index);
343
- }
344
- overflow(value) {
345
- if (value == null) {
346
- return this.content.overflow();
347
- }
348
- this.content.overflow(value);
349
- return this;
350
- }
351
- overflow_x(value) {
352
- if (value == null) {
353
- return this.content.overflow_x();
354
- }
355
- this.content.overflow_x(value);
356
- return this;
357
- }
358
- super_overflow_x(value) {
359
- if (value == null) {
360
- return super.overflow_x();
361
- }
362
- super.overflow_x(value);
363
- return this;
364
- }
365
- overflow_y(value) {
366
- if (value == null) {
367
- return this.content.overflow_y();
368
- }
369
- this.content.overflow_y(value);
370
- return this;
371
- }
372
- super_overflow_y(value) {
373
- if (value == null) {
374
- return super.overflow_y();
375
- }
376
- super.overflow_y(value);
377
- return this;
378
- }
379
- // Show the overflow so the scroller no longer scrolls.
380
- show_overflow() {
381
- super.overflow("visible");
382
- this.content.overflow("visible");
383
- return this;
384
- }
385
- // Hide the overflow so the scroller can scrolls.
386
- hide_overflow() {
387
- super.overflow("hidden");
388
- this.content.overflow("auto");
389
- return this;
390
- }
391
- delay(msec) {
392
- if (msec == null) {
393
- return this.m_delay;
394
- }
395
- this.m_delay = msec;
396
- return this;
397
- }
398
- scroll_top(value) {
399
- if (value == null) {
400
- return this._try_parse_float(this.content.scrollTop, this.content.scrollTop);
401
- }
402
- this.content.scrollTop = this.pad_numeric(value);
403
- return this;
404
- }
405
- scroll_left(value) {
406
- if (value == null) {
407
- return this._try_parse_float(this.content.scrollLeft, this.content.scrollLeft);
408
- }
409
- this.content.scrollLeft = this.pad_numeric(value);
410
- return this;
411
- }
412
- // Get the scroll height.
413
- scroll_height() {
414
- return this.content.scrollHeight;
415
- }
416
- // Get the scroll width.
417
- scroll_width() {
418
- return this.content.scrollWidth;
419
- }
420
- // @ts-expect-error
421
- on_scroll(opts_or_callback = { callback: null, delay: null }) {
422
- if (opts_or_callback == null) {
423
- return this.on_scroll_callbacks;
424
- }
425
- let callback;
426
- if (Utils.is_func(opts_or_callback)) {
427
- const element = this;
428
- callback = (event) => opts_or_callback(element, event);
429
- this.on_scroll_callbacks.push({ callback, user_callback: opts_or_callback });
430
- }
431
- else {
432
- if (opts_or_callback.delay == null) {
433
- callback = opts_or_callback.callback;
434
- }
435
- else {
436
- let timer;
437
- const element = this;
438
- callback = function (event) {
439
- clearTimeout(timer);
440
- setTimeout(() => opts_or_callback.callback(element, event), opts_or_callback.delay);
441
- };
442
- }
443
- this.on_scroll_callbacks.push({ callback, user_callback: opts_or_callback.callback });
444
- }
445
- this.content.addEventListener("scroll", callback);
446
- return this;
447
- }
448
- // Remove a on scroll callback.
449
- remove_on_scroll(callback) {
450
- let dropped = [];
451
- for (const item of this.on_scroll_callbacks) {
452
- if (item.user_callback === callback) {
453
- this.content.removeEventListener("scroll", item.callback);
454
- }
455
- else {
456
- dropped.push(item);
457
- }
458
- }
459
- this.on_scroll_callbacks = dropped;
460
- return this;
461
- }
462
- // Small wrapper to set scroll top without triggering a certain on scroll handler.
463
- set_scroll_top_without_event(top) {
464
- return this.set_scroll_position_without_event(top);
465
- }
466
- // Small wrapper to set scroll left without triggering a certain on scroll handler.
467
- set_scroll_left_without_event(left) {
468
- return this.set_scroll_position_without_event(undefined, left);
469
- }
470
- // Small wrapper to set scroll top / left without triggering a certain on scroll handler.
471
- set_scroll_position_without_event(top, left) {
472
- for (const item of this.on_scroll_callbacks) {
473
- this.content.removeEventListener("scroll", item.callback);
474
- }
475
- ;
476
- if (top != null) {
477
- this.scroll_top(top);
478
- }
479
- if (left != null) {
480
- this.scroll_left(left);
481
- }
482
- for (const item of this.on_scroll_callbacks) {
483
- this.content.addEventListener("scroll", item.callback);
484
- }
485
- ;
486
- return this;
487
- }
488
- align(value) {
489
- if (value == null) {
490
- return this._h_alignment ?? "";
491
- }
492
- super.align(value);
493
- this._h_alignment = value;
494
- if (this._alignment_callback_activated !== true) {
495
- this._alignment_callback_activated = true;
496
- this.on_resize(this._alignment_callback);
497
- this.on_render(this._alignment_callback);
498
- }
499
- return this;
500
- }
501
- center() {
502
- this.align("center");
503
- return this;
504
- }
505
- leading() {
506
- this.align("start");
507
- return this;
508
- }
509
- trailing() {
510
- this.align("end");
511
- return this;
512
- }
513
- align_vertical(value) {
514
- if (value == null) {
515
- return this._v_alignment ?? "";
516
- }
517
- super.align_vertical(value);
518
- this._v_alignment = value;
519
- if (this._alignment_callback_activated !== true) {
520
- this._alignment_callback_activated = true;
521
- this.on_resize(this._alignment_callback);
522
- this.on_render(this._alignment_callback);
523
- }
524
- return this;
525
- }
526
- center_vertical() {
527
- this.align_vertical("center");
528
- return this;
529
- }
530
- leading_vertical() {
531
- this.align_vertical("start");
532
- return this;
533
- }
534
- trailing_vertical() {
535
- this.align_vertical("end");
536
- return this;
537
- }
538
- };
539
- return ScrollerElement = _classThis;
540
- })();
541
- export { ScrollerElement };
542
- export const Scroller = Elements.wrapper(ScrollerElement);
543
- export const NullScroller = Elements.create_null(ScrollerElement);
544
- // Virtual Scroller.
545
- // /* @ docs:
546
- // @nav Frontend
547
- // @chapter: Elements
548
- // @title: Virtual Scroller
549
- // @experimental: true
550
- // @note: The `VirtualScrollerElement` is also initializable under function `VirtualScroller`.
551
- // @description:
552
- // The virtual scroller element.
553
- // Can be initialed with function `VirtualScroller()`.
554
- // After appending children you should call `render()` otherwise the children will only show up after a scroll event.
555
- // The virtual scroller can work in two ways.
556
- // 1) You must set a fixed height for every direct child.
557
- // 2) You call the member function `update_heights()` after any height involving edits are made and before you call member function `render()` for the first time.
558
- // @warning: Using content-visibility on the direct or nested children may cause undefined behaviour, it may cause elements to become hidden.
559
- // @warning: Every element must have a fixed height, Unless you use `update_heights()`. Otherwise the rendering will throw an error. Any incorrect heights may cause undefined behaviour.
560
- // @warning: Setting padding on element attribute "content" may cause undefined behaviour.
561
- // @parameter:
562
- // @name: children
563
- // @description: The elements children.
564
- // @type: array[Node]
565
- // */
566
- // @Elements.register
567
- // export class VirtualScrollerElement extends (ScrollerElement as any as VElementBaseSignature) {
568
- // public _v_children: any[];
569
- // public top_diff: number;
570
- // public scroll_top_value: number;
571
- // public _last_v_children: number;
572
- // public visible_container: VStackElement;
573
- // public height_measurer: any;
574
- // // Constructor.
575
- // constructor(...children: AppendType[]) {
576
- // // Initialize base class.
577
- // super();
578
- // this._init_derived({ derived: VirtualScrollerElement, })
579
- // // Virtual children.
580
- // this._v_children = [];
581
- // // Attributes.
582
- // this.top_diff = 0;
583
- // this.scroll_top_value = 0;
584
- // this._last_v_children = 0;
585
- // // Append children.
586
- // this.append(...children);
587
- // // The visible container with the scroll dimensions and positioned children inside.
588
- // this.visible_container = VStack()
589
- // .position("relative")
590
- // .overflow_x("visible")
591
- // .overflow_y("hidden")
592
- // .styles({
593
- // "content-visibility": "auto",
594
- // })
595
- // this.content.append(this.visible_container)
596
- // // The height measurer.
597
- // this.height_measurer = Span()
598
- // .visibility("hidden")
599
- // this.content.append(this.height_measurer)
600
- // // Render.
601
- // this.render();
602
- // // Set scroll event listener.
603
- // // @todo set_scroll_top_without event wont work with this new scroll event.
604
- // this.content.addEventListener("scroll", () => this.render())
605
- // }
606
- // // Set default since it inherits HStackElement.
607
- // set_default(): this {
608
- // return super.set_default(VirtualScrollerElement);
609
- // }
610
- // // Replace overflow.
611
- // overflow(): string;
612
- // overflow(value: string): this;
613
- // overflow(value?: string): string | this {
614
- // if (value == null) {
615
- // return this.content.overflow();
616
- // }
617
- // this.content.overflow(value);
618
- // this.visible_container.overflow_x(value.split(" ")[0]);
619
- // return this;
620
- // }
621
- // overflow_x(): string;
622
- // overflow_x(value: string): this;
623
- // overflow_x(value?: string): string | this {
624
- // if (value == null) {
625
- // return this.content.overflow_x();
626
- // }
627
- // this.content.overflow_x(value);
628
- // this.visible_container.overflow_x(value);
629
- // return this;
630
- // }
631
- // // keep overflow y on this.visible_container always hidden otherwise it may mess with expanding this.content and cause an infinite scroll event.
632
- // // Set remove children to content.
633
- // remove_children(): this {
634
- // this._v_children = [];
635
- // this.visible_container.min_height(0);
636
- // this.visible_container.max_height(0);
637
- // this.visible_container.inner_html("");
638
- // return this;
639
- // }
640
- // // Render the visible content.
641
- // render(): this {
642
- // // Do not use a clearTimeout setTimout structure cause that will cause some elements to be appended too late on a very fast sroll.
643
- // // Get scroll direction.
644
- // const last_scroll_top = this.scroll_top_value;
645
- // this.scroll_top_value = this.content.scrollTop;
646
- // const last_v_children = this._last_v_children;
647
- // this._last_v_children = this._v_children.length;
648
- // let scrolling_down = true;
649
- // if (this.scroll_top_value > last_scroll_top) {
650
- // scrolling_down = true;
651
- // } else if (this.scroll_top_value < last_scroll_top) {
652
- // scrolling_down = false;
653
- // }
654
- // // Disable forced behaviour because when height edits are made it should also be updated, but this is easily forgotten by the user.
655
- // // else if (!forced && this.last_v_children == last_v_children) {
656
- // // return null; // horizontal scroll.
657
- // // }
658
- // // Get the start and end y.
659
- // const start_y = this.content.scrollTop;
660
- // const end_y = start_y + this.content.offsetHeight + this.top_diff;
661
- // // Iterate.
662
- // let is_first = true;
663
- // let is_visible = false;
664
- // let total_height = 0;
665
- // let visible_height = 0;
666
- // this._v_children.iterate((child) => {
667
- // // Child vars.
668
- // const height = child.v_height !== undefined ? child.v_height : this.get_height(child);
669
- // if (height == 0) {
670
- // return null; // no fixed height or no height.
671
- // }
672
- // const child_start_y = total_height;
673
- // const child_end_y = total_height + height; // Adjust as needed
674
- // total_height += height;
675
- // // First item.
676
- // if (is_first && child_end_y >= start_y) {
677
- // child.transform(`translateY(${child_start_y}px)`); // also update when still visible but height changes may have been made to an element.
678
- // visible_height += height;
679
- // is_first = false;
680
- // is_visible = true;
681
- // if (!child.rendered) {
682
- // if (scrolling_down) {
683
- // this.visible_container.appendChild(child);
684
- // } else {
685
- // this.visible_container.insertBefore(child, this.visible_container.firstChild);
686
- // }
687
- // child.rendered = true;
688
- // }
689
- // }
690
- // // Last visible element.
691
- // else if (is_visible && child_start_y >= end_y) {
692
- // child.transform(`translateY(${child_start_y - visible_height}px)`); // also update when still visible but height changes may have been made to an element.
693
- // visible_height += height;
694
- // is_visible = false;
695
- // if (!child.rendered) {
696
- // if (scrolling_down) {
697
- // this.visible_container.appendChild(child);
698
- // } else {
699
- // this.visible_container.insertBefore(child, this.visible_container.firstChild);
700
- // }
701
- // child.rendered = true;
702
- // }
703
- // }
704
- // // Visible elements.
705
- // else if (is_visible) {
706
- // child.transform(`translateY(${child_start_y - visible_height}px)`); // also update when still visible but height changes may have been made to an element.
707
- // visible_height += height;
708
- // if (!child.rendered) {
709
- // if (scrolling_down) {
710
- // this.visible_container.appendChild(child);
711
- // } else {
712
- // this.visible_container.insertBefore(child, this.visible_container.firstChild);
713
- // }
714
- // child.rendered = true;
715
- // }
716
- // }
717
- // // Invisible elements.
718
- // else if (child.rendered) {
719
- // child.remove();
720
- // child.rendered = false;
721
- // }
722
- // })
723
- // // Set scroll dimension.
724
- // this.visible_container.min_height(total_height);
725
- // this.visible_container.max_height(total_height);
726
- // // Return this.
727
- // return this;
728
- // }
729
- // // Update heights.
730
- // update_heights(): this {
731
- // this._v_children.iterate((child) => {
732
- // child.v_height = this.get_height(child, false);
733
- // })
734
- // return this;
735
- // }
736
- // // Update height of a certain child.
737
- // update_height(child: any): this {
738
- // child.v_height = this.get_height(child, false);
739
- // return this;
740
- // }
741
- // // Get the height of an element.
742
- // get_height(element, fixed = true): number {
743
- // let height;
744
- // // Get fixed height.
745
- // if (fixed) {
746
- // height = parseFloat(element.style.height);
747
- // if (isNaN(height)) {
748
- // console.error("Every element in the virtual scroller must have a fixed height, ignoring element: " + element);
749
- // element.style.display = "none";
750
- // return 0;
751
- // }
752
- // }
753
- // // Append to document and get height.
754
- // // Does not require fixed heights but is slow.
755
- // else {
756
- // element.rendered = false; // set rendered to false because this will remove the child from this.visible_container when it was rendered.
757
- // this.height_measurer.appendChild(element);
758
- // height = element.offsetHeight;
759
- // this.height_measurer.removeChild(element);
760
- // }
761
- // // Add margin.
762
- // const margin_top = parseFloat(element.style.marginTop);
763
- // if (!isNaN(margin_top)) {
764
- // height += margin_top;
765
- // }
766
- // const margin_bottom = parseFloat(element.style.marginBottom);
767
- // if (!isNaN(margin_bottom)) {
768
- // height += margin_bottom;
769
- // }
770
- // // Handler.
771
- // return height;
772
- // }
773
- // // Custom append function.
774
- // append(...children: AppendType[]): this {
775
- // for (let i = 0; i < children.length; i++) {
776
- // const child = children[i];
777
- // if (child != null) {
778
- // // VWeb element.
779
- // if (child.element_name != null) {
780
- // if (
781
- // child.element_name == "ForEachElement" ||
782
- // child.element_name == "IfElement" ||
783
- // child.element_name == "IfDeviceWithElement"
784
- // ) {
785
- // child.append_children_to(this);
786
- // } else {
787
- // this._v_children.push(child);
788
- // }
789
- // }
790
- // // Execute function.
791
- // else if (Utils.is_func(child)) {
792
- // this.append(child());
793
- // }
794
- // // Node element.
795
- // else if (child instanceof Node) {
796
- // this._v_children.push(child);
797
- // }
798
- // // Append text.
799
- // else if (Utils.is_string(child)) {
800
- // this._v_children.push(document.createTextNode(child));
801
- // }
802
- // }
803
- // }
804
- // return this;
805
- // }
806
- // }
807
- // export const VirtualScroller = Elements.wrapper(VirtualScrollerElement);
808
- // export const NullVirtualScroller = Elements.create_null(VirtualScrollerElement);
809
- // declare module './any_element.d.ts' { interface AnyElementMap { VirtualScrollerElement: VirtualScrollerElement }}
810
- /**
811
- * Scrolls the windows per window (snap scrolling).
812
- * This class is still experimental.
813
- * @experimental true
814
- * @note The `SnapScrollerElement` is also initializable under function `SnapScroller`.
815
- * @nav Frontend/Elements
816
- * @docs
817
- */
818
- let SnapScrollerElement = (() => {
819
- let _classDecorators = [Elements.create({
820
- name: "SnapScrollerElement",
821
- })];
822
- let _classDescriptor;
823
- let _classExtraInitializers = [];
824
- let _classThis;
825
- let _classSuper = VStackElement;
826
- var SnapScrollerElement = class extends _classSuper {
827
- static { _classThis = this; }
828
- static {
829
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
830
- __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
831
- SnapScrollerElement = _classThis = _classDescriptor.value;
832
- if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
833
- __runInitializers(_classThis, _classExtraInitializers);
834
- }
835
- // Constructor.
836
- constructor(...children) {
837
- // Base.
838
- super();
839
- this._init({
840
- derived: SnapScrollerElement,
841
- });
842
- // Style.
843
- this.overflow_y("scroll");
844
- this.scroll_snap_type("y mandatory");
845
- // Add children.
846
- this.append(...children);
847
- }
848
- // Append.
849
- // @ts-ignore base type accepts more input types, this one only accepts velements
850
- append(...children) {
851
- for (let i = 0; i < children.length; i++) {
852
- const win = children[i];
853
- if (win == null) {
854
- continue;
855
- }
856
- // Style.
857
- win.min_height("100%");
858
- // win.scroll_snap_align("start");
859
- // Set alignment.
860
- win.on_render((e) => {
861
- if (win.scrollHeight > this.clientHeight) {
862
- e.align_vertical("default");
863
- }
864
- else {
865
- e.center_vertical();
866
- }
867
- });
868
- win.on_resize((e) => {
869
- if (win.scrollHeight > this.clientHeight) {
870
- e.align_vertical("default");
871
- }
872
- else {
873
- e.center_vertical();
874
- }
875
- });
876
- // Append.
877
- win.style.height = "100%";
878
- win.style.minHeight = "100%";
879
- win.style.maxHeight = "100%";
880
- win.style.overflowY = "scroll";
881
- win.style["scroll-snap-align"] = "start";
882
- super.append(win);
883
- // const section = document.createElement("section");
884
- // section.style.height = "100%";
885
- // section.style.minHeight = "100%";
886
- // section.style.maxHeight = "100%";
887
- // section.style.overflowY = "scroll";
888
- // section.style["scroll-snap-align"] = "start";
889
- // section.appendChild(win);
890
- // super.append(section);
891
- }
892
- // Response.
893
- return this;
894
- }
895
- // Scroll into child.
896
- scroll_into_child(index, behaviour = "smooth") {
897
- this.child(index).scrollIntoView({ behavior: behaviour });
898
- return this;
899
- }
900
- };
901
- return SnapScrollerElement = _classThis;
902
- })();
903
- export { SnapScrollerElement };
904
- export const SnapScroller = Elements.wrapper(SnapScrollerElement);
905
- export const NullSnapScroller = Elements.create_null(SnapScrollerElement);
906
- // Window Scroller.
907
- /*
908
- @constructor_wrapper
909
- @Elements.register
910
- class WindowScrollerElement extends Elements.create({
911
- type: "WindowScroller",
912
- tag: "div",
913
- default_style: {
914
- "margin": "0px",
915
- "padding": "0px",
916
- "display": "flex", // to support vertical spacers.
917
- "overflow": "visible",
918
- "align-content": "flex-start", // align items at start, do not stretch / space when inside HStack.
919
- "flex-direction": "column",
920
- },
921
- }) {
922
- constructor({
923
- duration = 500, // duration of the animation.
924
- _topbar = null, // can be passed to assign a shadow to an item when the content is scrolling and a shadow should present.
925
- } = {}) {
926
-
927
-
928
- // Super.
929
- super();
930
-
931
- // Attributes.
932
- this.duration = duration;
933
- this.index = 0;
934
- this.windows = [];
935
- this.last_scroll_top = 0;
936
- this.window_scroll_height = 50; // the minimum scroll required to go to the next window.
937
-
938
- // Styling.
939
- this.min_width("100%");
940
- this.stretch(true);
941
- this.position("relative");
942
- this.overflow("hidden scroll");
943
- this.class("volt_hide_scrollbar");
944
-
945
- // The event that will be called when the window scrolls.
946
- this.on_animation_scroll = () => {};
947
-
948
- // @todo update scroll position on resize.
949
- const _this_ = this;
950
- this.child_scrolling = false;
951
- this._child_on_scroll = function (e) {
952
-
953
- // console.log("Child:", _this_.child_scrolling)
954
- _this_.child_scrolling = true;
955
- setTimeout(() => {_this_.child_scrolling = false}, 250)
956
-
957
- // Set top bar shadow.
958
- if (_topbar != null) {
959
- if (this.scrollTop > 0 && _topbar.has_shadow !== true) {
960
- _topbar.has_shadow = true;
961
- _topbar.shadow("0px 0px 10px #000000")
962
- } else if (this.scrollTop === 0 && _topbar.has_shadow === true) {
963
- _topbar.has_shadow = false;
964
- _topbar.shadow("none")
965
- }
966
- }
967
-
968
- // Relay scroll when the child can no longer scroll.
969
- if (this.scrollTop === 0) {
970
- _this_.scrollTop = (_this_.index - 1) * _this_.window_scroll_height;
971
- } else if (this.scrollTop + this.clientHeight >= this.scrollHeight) {
972
- _this_.scrollTop = (_this_.index + 1) * _this_.window_scroll_height;
973
- }
974
- }
975
-
976
- // On wheel event.
977
- const _on_scroll_callback = (e) => {
978
-
979
- // Prevent default on already animating.
980
- // console.log("Parent:", _this_.child_scrolling)
981
- if (this.animating === true || _this_.child_scrolling) {
982
- e.preventDefault();
983
- return ;
984
- }
985
-
986
- // Vars.
987
- const win = this.windows[this.index];
988
- const scroll_top = this.scrollTop;
989
- const height = this.clientHeight;
990
- const scroll_up = this.scrollTop > this.last_scroll_top;
991
- this.last_scroll_top = scroll_top;
992
-
993
- // Set top bar shadow.
994
- if (_topbar != null) {
995
- if (win.scrollTop > 0 && _topbar.has_shadow !== true) {
996
- _topbar.has_shadow = true;
997
- _topbar.shadow("0px 0px 10px #000000")
998
- } else if (win.scrollTop === 0 && _topbar.has_shadow === true) {
999
- setTimeout(() => {
1000
- _topbar.has_shadow = false;
1001
- _topbar.shadow("none")
1002
- }, this.duration) // must be the at least the duration of window transition.
1003
- }
1004
- }
1005
-
1006
- // Prevent default on max scroll height.
1007
- if (scroll_top > this.windows.length * this.window_scroll_height) {
1008
- this.scrollTop = this.windows.length * this.window_scroll_height;
1009
- e.stopPropagation();
1010
- e.preventDefault();
1011
- return null;
1012
- }
1013
-
1014
- // Next or previous.
1015
- // Skip when the child is not fully scroller.
1016
- if (
1017
- (win.scrollTop + win.clientHeight >= win.scrollHeight) ||
1018
- (win.scrollTop === 0)
1019
- ) {
1020
-
1021
- // Check views.
1022
- const scroll_index = parseInt(scroll_top / this.window_scroll_height);
1023
- const stop_animating = () => {
1024
- setTimeout(() => {
1025
- this.animating = false;
1026
- this.scrollTop = this.index * this.window_scroll_height;
1027
- }, 250)
1028
- }
1029
- if (scroll_index > this.index) {
1030
- this.animating = true;
1031
- e.preventDefault();
1032
- this.next(scroll_index, false)
1033
- .then(stop_animating)
1034
- .catch(stop_animating)
1035
- this.scrollTop = this.index * this.window_scroll_height;
1036
- } else if (scroll_index < this.index) {
1037
- this.animating = true;
1038
- e.preventDefault();
1039
- this.prev(scroll_index, false)
1040
- .then(stop_animating)
1041
- .catch(stop_animating)
1042
- this.scrollTop = this.index * this.window_scroll_height;
1043
- }
1044
-
1045
- }
1046
-
1047
- }
1048
-
1049
- // Add event listener.
1050
- this.addEventListener("scroll", _on_scroll_callback, { passive: false });
1051
-
1052
- // Add the on hash change listener for any direct children id's.
1053
- window.addEventListener("hashchange", (e) => {
1054
- const hash = window.location.hash.substr(1);
1055
- if (hash != null && hash !== "") {
1056
- this.windows.iterate((win) => {
1057
- if (hash === win.id()) {
1058
- console.log("Select", win.id())
1059
- if (win.index > this.index) {
1060
- this.next(win.index, true);
1061
- } else {
1062
- this.prev(win.index, true);
1063
- }
1064
- return false;
1065
- }
1066
- })
1067
- // window.location.hash = ""; // reset the hash so that when the user clicks the hash button again it is rerendered.
1068
- }
1069
- })
1070
- }
1071
-
1072
-
1073
- // Add a window.
1074
- append(win) {
1075
-
1076
- // Update window.
1077
- win.transition(`opacity ${this.duration*2}ms, transform ${this.duration}ms ease`)
1078
- win.fixed_frame("100%", "100%");
1079
- win.position(0, 0, 0, 0);
1080
- win.position("sticky");
1081
- win.overflow("scroll");
1082
- win.overscroll_behavior("bounce"); // must be bounce so the on scroll event is also called when the user scrolls up and the page is already scrolled all the way up.
1083
- // win.align("default"); // must start with leading for checks will be centered later
1084
- win.align_vertical("default"); // must start with leading for checks will be centered later
1085
- win.addEventListener("scroll", this._child_on_scroll);
1086
- win.outline("none"); // otherwise an outline border may appear while scrolling windows.
1087
- win.border("none"); // otherwise an outline border may appear while scrolling windows.
1088
- win.center();
1089
-
1090
- // Add scroll forwarder.
1091
-
1092
- // Initial window.
1093
- if (this.windows.length > 0) {
1094
- win.transform("translateY(100%)")
1095
- win.opacity(0)
1096
- }
1097
-
1098
- // Other windows.
1099
- else {
1100
- win.transform("translateY(0)")
1101
- win.opacity(1)
1102
- }
1103
-
1104
- // Set alignment.
1105
- win.on_render((e) => {
1106
- // Setting horizontal align causes issues with slide in animations.
1107
- // setTimeout(() => {
1108
- // const width = this.clientWidth;
1109
- // const width = e.clientWidth;
1110
- // if (e.scrollWidth > width) {
1111
- // console.log(e.scrollWidth, width, "default", win.child(0).text().substr(0, 10))
1112
- // e.align("default");
1113
- // } else {
1114
- // console.log(e.scrollWidth, width, "center", win.child(0).text().substr(0, 10))
1115
- // e.center();
1116
- // }
1117
- if (win.scrollHeight > this.clientHeight) {
1118
- e.align_vertical("default");
1119
- } else {
1120
- e.center_vertical();
1121
- }
1122
- })
1123
- win.on_resize((e) => {
1124
- if (win.scrollHeight > this.clientHeight) {
1125
- e.align_vertical("default");
1126
- } else {
1127
- e.center_vertical();
1128
- }
1129
- })
1130
-
1131
- // Append.
1132
- win.index = this.windows.length;
1133
- this.windows.push(win);
1134
- super.append(win);
1135
-
1136
- // Check if the href hash is set on this windows id.
1137
- const hash = window.location.hash.substr(1);
1138
- if (hash != null && hash !== "" && hash === win.id()) {
1139
- this.on_render(() => {
1140
- this.next(win.index, true);
1141
- })
1142
- }
1143
-
1144
-
1145
- // response.
1146
- return this;
1147
- }
1148
-
1149
- // Next window.
1150
- async next(index, update_scroll_top = true) {
1151
- return new Promise(async (resolve) => {
1152
- if (index < this.windows.length) {
1153
-
1154
- // Update scroll top.
1155
- if (update_scroll_top) {
1156
- this.scrollTop = this.window_scroll_height * index;
1157
- }
1158
-
1159
- // Slide out.
1160
- const current = this.windows[this.index];
1161
- current.style.opacity = 0;
1162
- current.style.transform = 'translateY(-100%)';
1163
-
1164
- // Update index.
1165
- this.index = index;
1166
-
1167
- // Slide in.
1168
- const next = this.windows[this.index];
1169
- if (next.is_scrollable()) {
1170
- next.leading_vertical()
1171
- } else {
1172
- next.center_vertical()
1173
- }
1174
- next.scrollTop = 0;
1175
- next.style.opacity = 1;
1176
- next.style.transform = 'translateY(0)';
1177
- next.scrollTop = 0; // required since sometimes it does not start at the start or end, which requires the user to scroll up and down before it can scroll to the next window.
1178
-
1179
- // Call on appear on children.
1180
- if (Array.isArray(next._on_appear_callbacks)) {
1181
- let promises = [];
1182
- for (let i = 0; i < next._on_appear_callbacks.length; i++) {
1183
- const res = next._on_appear_callbacks[i].exec()
1184
- if (res instanceof Promise) {
1185
- promises.push(res);
1186
- }
1187
- }
1188
- await Promise.all(promises);
1189
- }
1190
-
1191
- // Resolve.
1192
- setTimeout(resolve, this.duration);
1193
- }
1194
- else {
1195
- resolve();
1196
- }
1197
- });
1198
- }
1199
-
1200
- // Previous window.
1201
- async prev(index, update_scroll_top = true) {
1202
- return new Promise(async (resolve) => {
1203
- const old_index = this.index;
1204
- if (index >= 0) {
1205
-
1206
- // Update scroll top.
1207
- if (update_scroll_top) {
1208
- this.scrollTop = this.window_scroll_height * index;
1209
- }
1210
-
1211
- // Slide out.
1212
- const current = this.windows[this.index];
1213
- current.style.opacity = 0;
1214
- current.style.transform = 'translateY(100%)';
1215
-
1216
- // Update index.
1217
- this.index = index;
1218
-
1219
- // Slide in.
1220
- const next = this.windows[this.index];
1221
- if (next.is_scrollable()) {
1222
- next.leading_vertical()
1223
- } else {
1224
- next.center_vertical()
1225
- }
1226
- next.scrollTop = next.scrollHeight;
1227
- next.style.opacity = 1;
1228
- next.style.transform = 'translateY(0)';
1229
- next.scrollTop = next.scrollHeight; // required since sometimes it does not start at the start or end, which requires the user to scroll up and down before it can scroll to the next window.
1230
-
1231
- // Call on appear on children.
1232
- if (Array.isArray(next._on_appear_callbacks)) {
1233
- let promises = [];
1234
- for (let i = 0; i < next._on_appear_callbacks.length; i++) {
1235
- const res = next._on_appear_callbacks[i].exec()
1236
- if (res instanceof Promise) {
1237
- promises.push(res);
1238
- }
1239
- }
1240
- await Promise.all(promises);
1241
- }
1242
-
1243
- // Resolve.
1244
- setTimeout(resolve, this.duration);
1245
- }
1246
- else {
1247
- resolve();
1248
- }
1249
- });
1250
- }
1251
-
1252
- }
1253
- */