@moni-labs/moni-ui 0.2.0

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 (451) hide show
  1. package/LICENSE +34 -0
  2. package/README.md +264 -0
  3. package/custom-elements.json +12510 -0
  4. package/dist/actions/index.d.ts +2 -0
  5. package/dist/actions/index.d.ts.map +1 -0
  6. package/dist/actions/index.js +1 -0
  7. package/dist/assets/arch.svg +1 -0
  8. package/dist/assets/arrow.svg +1 -0
  9. package/dist/assets/boom.svg +1 -0
  10. package/dist/assets/bun.svg +1 -0
  11. package/dist/assets/burst.svg +1 -0
  12. package/dist/assets/circle.svg +1 -0
  13. package/dist/assets/clamshell.svg +1 -0
  14. package/dist/assets/diamond.svg +1 -0
  15. package/dist/assets/fan.svg +1 -0
  16. package/dist/assets/flower.svg +1 -0
  17. package/dist/assets/gem.svg +1 -0
  18. package/dist/assets/ghost-ish.svg +1 -0
  19. package/dist/assets/heart.svg +1 -0
  20. package/dist/assets/leaf-clover4.svg +1 -0
  21. package/dist/assets/leaf-clover8.svg +1 -0
  22. package/dist/assets/loading-indicator.svg +1 -0
  23. package/dist/assets/material-symbols-rounded.woff2 +0 -0
  24. package/dist/assets/material-symbols-subset.woff2 +0 -0
  25. package/dist/assets/oval.svg +1 -0
  26. package/dist/assets/pentagon.svg +1 -0
  27. package/dist/assets/pill.svg +1 -0
  28. package/dist/assets/pixel-circle.svg +1 -0
  29. package/dist/assets/pixel-triangle.svg +1 -0
  30. package/dist/assets/puffy-diamond.svg +1 -0
  31. package/dist/assets/puffy.svg +1 -0
  32. package/dist/assets/semicircle.svg +1 -0
  33. package/dist/assets/shapes/arch.svg +1 -0
  34. package/dist/assets/shapes/arrow.svg +1 -0
  35. package/dist/assets/shapes/boom.svg +1 -0
  36. package/dist/assets/shapes/burst.svg +1 -0
  37. package/dist/assets/shapes/circle.svg +1 -0
  38. package/dist/assets/shapes/clamshell.svg +1 -0
  39. package/dist/assets/shapes/diamond.svg +1 -0
  40. package/dist/assets/shapes/fan.svg +1 -0
  41. package/dist/assets/shapes/flower.svg +1 -0
  42. package/dist/assets/shapes/gem.svg +1 -0
  43. package/dist/assets/shapes/ghost-ish.svg +1 -0
  44. package/dist/assets/shapes/heart.svg +1 -0
  45. package/dist/assets/shapes/leaf-clover4.svg +1 -0
  46. package/dist/assets/shapes/leaf-clover8.svg +1 -0
  47. package/dist/assets/shapes/loading-indicator.svg +1 -0
  48. package/dist/assets/shapes/oval.svg +1 -0
  49. package/dist/assets/shapes/pentagon.svg +1 -0
  50. package/dist/assets/shapes/pill.svg +1 -0
  51. package/dist/assets/shapes/pixel-circle.svg +1 -0
  52. package/dist/assets/shapes/pixel-triangle.svg +1 -0
  53. package/dist/assets/shapes/puffy-diamond.svg +1 -0
  54. package/dist/assets/shapes/puffy.svg +1 -0
  55. package/dist/assets/shapes/semicircle.svg +1 -0
  56. package/dist/assets/shapes/sided-cookie12.svg +1 -0
  57. package/dist/assets/shapes/sided-cookie4.svg +1 -0
  58. package/dist/assets/shapes/sided-cookie6.svg +1 -0
  59. package/dist/assets/shapes/sided-cookie7.svg +1 -0
  60. package/dist/assets/shapes/sided-cookie9.svg +1 -0
  61. package/dist/assets/shapes/slanted.svg +1 -0
  62. package/dist/assets/shapes/soft-boom.svg +1 -0
  63. package/dist/assets/shapes/soft-burst.svg +1 -0
  64. package/dist/assets/shapes/square.svg +1 -0
  65. package/dist/assets/shapes/sunny.svg +1 -0
  66. package/dist/assets/shapes/triangle.svg +1 -0
  67. package/dist/assets/shapes/very-sunny.svg +1 -0
  68. package/dist/assets/shapes/wavy-circle.svg +1 -0
  69. package/dist/assets/shapes/wavy.svg +1 -0
  70. package/dist/assets/sided-cookie12.svg +1 -0
  71. package/dist/assets/sided-cookie4.svg +1 -0
  72. package/dist/assets/sided-cookie6.svg +1 -0
  73. package/dist/assets/sided-cookie7.svg +1 -0
  74. package/dist/assets/sided-cookie9.svg +1 -0
  75. package/dist/assets/slanted.svg +1 -0
  76. package/dist/assets/soft-boom.svg +1 -0
  77. package/dist/assets/soft-burst.svg +1 -0
  78. package/dist/assets/square.svg +1 -0
  79. package/dist/assets/star.svg +1 -0
  80. package/dist/assets/sunny.svg +1 -0
  81. package/dist/assets/triangle.svg +1 -0
  82. package/dist/assets/very-sunny.svg +1 -0
  83. package/dist/assets/wavy-circle.svg +1 -0
  84. package/dist/assets/wavy.svg +1 -0
  85. package/dist/components/_base/field-styles.d.ts +24 -0
  86. package/dist/components/_base/field-styles.d.ts.map +1 -0
  87. package/dist/components/_base/field-styles.js +504 -0
  88. package/dist/components/_base/index.d.ts +4 -0
  89. package/dist/components/_base/index.d.ts.map +1 -0
  90. package/dist/components/_base/index.js +3 -0
  91. package/dist/components/_base/interaction-styles.d.ts +22 -0
  92. package/dist/components/_base/interaction-styles.d.ts.map +1 -0
  93. package/dist/components/_base/interaction-styles.js +123 -0
  94. package/dist/components/_base/moni-element.d.ts +18 -0
  95. package/dist/components/_base/moni-element.d.ts.map +1 -0
  96. package/dist/components/_base/moni-element.js +19 -0
  97. package/dist/components/_base/shared-styles.d.ts +22 -0
  98. package/dist/components/_base/shared-styles.d.ts.map +1 -0
  99. package/dist/components/_base/shared-styles.js +146 -0
  100. package/dist/components/index.d.ts +42 -0
  101. package/dist/components/index.d.ts.map +1 -0
  102. package/dist/components/index.js +43 -0
  103. package/dist/components/loading-shapes.d.ts +10 -0
  104. package/dist/components/loading-shapes.d.ts.map +1 -0
  105. package/dist/components/loading-shapes.js +9 -0
  106. package/dist/components/moni-app-bar.d.ts +52 -0
  107. package/dist/components/moni-app-bar.d.ts.map +1 -0
  108. package/dist/components/moni-app-bar.js +207 -0
  109. package/dist/components/moni-badge.d.ts +37 -0
  110. package/dist/components/moni-badge.d.ts.map +1 -0
  111. package/dist/components/moni-badge.js +153 -0
  112. package/dist/components/moni-bottom-sheet.d.ts +52 -0
  113. package/dist/components/moni-bottom-sheet.d.ts.map +1 -0
  114. package/dist/components/moni-bottom-sheet.js +440 -0
  115. package/dist/components/moni-button-group.d.ts +55 -0
  116. package/dist/components/moni-button-group.d.ts.map +1 -0
  117. package/dist/components/moni-button-group.js +278 -0
  118. package/dist/components/moni-button-segment.d.ts +29 -0
  119. package/dist/components/moni-button-segment.d.ts.map +1 -0
  120. package/dist/components/moni-button-segment.js +300 -0
  121. package/dist/components/moni-button.d.ts +70 -0
  122. package/dist/components/moni-button.d.ts.map +1 -0
  123. package/dist/components/moni-button.js +727 -0
  124. package/dist/components/moni-card.d.ts +48 -0
  125. package/dist/components/moni-card.d.ts.map +1 -0
  126. package/dist/components/moni-card.js +216 -0
  127. package/dist/components/moni-carousel.d.ts +111 -0
  128. package/dist/components/moni-carousel.d.ts.map +1 -0
  129. package/dist/components/moni-carousel.js +1007 -0
  130. package/dist/components/moni-checkbox.d.ts +39 -0
  131. package/dist/components/moni-checkbox.d.ts.map +1 -0
  132. package/dist/components/moni-checkbox.js +212 -0
  133. package/dist/components/moni-chip.d.ts +57 -0
  134. package/dist/components/moni-chip.d.ts.map +1 -0
  135. package/dist/components/moni-chip.js +340 -0
  136. package/dist/components/moni-color-field.d.ts +33 -0
  137. package/dist/components/moni-color-field.d.ts.map +1 -0
  138. package/dist/components/moni-color-field.js +170 -0
  139. package/dist/components/moni-context-menu.d.ts +55 -0
  140. package/dist/components/moni-context-menu.d.ts.map +1 -0
  141. package/dist/components/moni-context-menu.js +184 -0
  142. package/dist/components/moni-dialog.d.ts +37 -0
  143. package/dist/components/moni-dialog.d.ts.map +1 -0
  144. package/dist/components/moni-dialog.js +257 -0
  145. package/dist/components/moni-divider.d.ts +33 -0
  146. package/dist/components/moni-divider.d.ts.map +1 -0
  147. package/dist/components/moni-divider.js +81 -0
  148. package/dist/components/moni-expansion.d.ts +25 -0
  149. package/dist/components/moni-expansion.d.ts.map +1 -0
  150. package/dist/components/moni-expansion.js +94 -0
  151. package/dist/components/moni-fab-menu.d.ts +58 -0
  152. package/dist/components/moni-fab-menu.d.ts.map +1 -0
  153. package/dist/components/moni-fab-menu.js +247 -0
  154. package/dist/components/moni-fab.d.ts +48 -0
  155. package/dist/components/moni-fab.d.ts.map +1 -0
  156. package/dist/components/moni-fab.js +284 -0
  157. package/dist/components/moni-file-field.d.ts +47 -0
  158. package/dist/components/moni-file-field.d.ts.map +1 -0
  159. package/dist/components/moni-file-field.js +189 -0
  160. package/dist/components/moni-icon.d.ts +30 -0
  161. package/dist/components/moni-icon.d.ts.map +1 -0
  162. package/dist/components/moni-icon.js +107 -0
  163. package/dist/components/moni-list-item.d.ts +51 -0
  164. package/dist/components/moni-list-item.d.ts.map +1 -0
  165. package/dist/components/moni-list-item.js +239 -0
  166. package/dist/components/moni-list.d.ts +32 -0
  167. package/dist/components/moni-list.d.ts.map +1 -0
  168. package/dist/components/moni-list.js +67 -0
  169. package/dist/components/moni-loading-indicator.d.ts +32 -0
  170. package/dist/components/moni-loading-indicator.d.ts.map +1 -0
  171. package/dist/components/moni-loading-indicator.js +189 -0
  172. package/dist/components/moni-menu-item.d.ts +27 -0
  173. package/dist/components/moni-menu-item.d.ts.map +1 -0
  174. package/dist/components/moni-menu-item.js +99 -0
  175. package/dist/components/moni-menu.d.ts +55 -0
  176. package/dist/components/moni-menu.d.ts.map +1 -0
  177. package/dist/components/moni-menu.js +295 -0
  178. package/dist/components/moni-morph-modal.d.ts +78 -0
  179. package/dist/components/moni-morph-modal.d.ts.map +1 -0
  180. package/dist/components/moni-morph-modal.js +1223 -0
  181. package/dist/components/moni-nav-item.d.ts +38 -0
  182. package/dist/components/moni-nav-item.d.ts.map +1 -0
  183. package/dist/components/moni-nav-item.js +262 -0
  184. package/dist/components/moni-nav.d.ts +46 -0
  185. package/dist/components/moni-nav.d.ts.map +1 -0
  186. package/dist/components/moni-nav.js +272 -0
  187. package/dist/components/moni-progress.d.ts +45 -0
  188. package/dist/components/moni-progress.d.ts.map +1 -0
  189. package/dist/components/moni-progress.js +333 -0
  190. package/dist/components/moni-radio.d.ts +38 -0
  191. package/dist/components/moni-radio.d.ts.map +1 -0
  192. package/dist/components/moni-radio.js +218 -0
  193. package/dist/components/moni-ripple.d.ts +35 -0
  194. package/dist/components/moni-ripple.d.ts.map +1 -0
  195. package/dist/components/moni-ripple.js +156 -0
  196. package/dist/components/moni-segmented-button.d.ts +52 -0
  197. package/dist/components/moni-segmented-button.d.ts.map +1 -0
  198. package/dist/components/moni-segmented-button.js +208 -0
  199. package/dist/components/moni-select-option.d.ts +27 -0
  200. package/dist/components/moni-select-option.d.ts.map +1 -0
  201. package/dist/components/moni-select-option.js +102 -0
  202. package/dist/components/moni-select.d.ts +76 -0
  203. package/dist/components/moni-select.d.ts.map +1 -0
  204. package/dist/components/moni-select.js +1136 -0
  205. package/dist/components/moni-shape.d.ts +30 -0
  206. package/dist/components/moni-shape.d.ts.map +1 -0
  207. package/dist/components/moni-shape.js +146 -0
  208. package/dist/components/moni-side-sheet.d.ts +62 -0
  209. package/dist/components/moni-side-sheet.d.ts.map +1 -0
  210. package/dist/components/moni-side-sheet.js +576 -0
  211. package/dist/components/moni-slider.d.ts +73 -0
  212. package/dist/components/moni-slider.d.ts.map +1 -0
  213. package/dist/components/moni-slider.js +422 -0
  214. package/dist/components/moni-snackbar.d.ts +40 -0
  215. package/dist/components/moni-snackbar.d.ts.map +1 -0
  216. package/dist/components/moni-snackbar.js +161 -0
  217. package/dist/components/moni-split-button.d.ts +33 -0
  218. package/dist/components/moni-split-button.d.ts.map +1 -0
  219. package/dist/components/moni-split-button.js +122 -0
  220. package/dist/components/moni-step.d.ts +30 -0
  221. package/dist/components/moni-step.d.ts.map +1 -0
  222. package/dist/components/moni-step.js +175 -0
  223. package/dist/components/moni-stepper.d.ts +35 -0
  224. package/dist/components/moni-stepper.d.ts.map +1 -0
  225. package/dist/components/moni-stepper.js +101 -0
  226. package/dist/components/moni-switch.d.ts +39 -0
  227. package/dist/components/moni-switch.d.ts.map +1 -0
  228. package/dist/components/moni-switch.js +258 -0
  229. package/dist/components/moni-tab.d.ts +27 -0
  230. package/dist/components/moni-tab.d.ts.map +1 -0
  231. package/dist/components/moni-tab.js +147 -0
  232. package/dist/components/moni-tabs.d.ts +31 -0
  233. package/dist/components/moni-tabs.d.ts.map +1 -0
  234. package/dist/components/moni-tabs.js +106 -0
  235. package/dist/components/moni-text-field.d.ts +46 -0
  236. package/dist/components/moni-text-field.d.ts.map +1 -0
  237. package/dist/components/moni-text-field.js +190 -0
  238. package/dist/components/moni-textarea.d.ts +57 -0
  239. package/dist/components/moni-textarea.d.ts.map +1 -0
  240. package/dist/components/moni-textarea.js +228 -0
  241. package/dist/components/moni-time-picker.d.ts +51 -0
  242. package/dist/components/moni-time-picker.d.ts.map +1 -0
  243. package/dist/components/moni-time-picker.js +823 -0
  244. package/dist/components/moni-toolbar.d.ts +35 -0
  245. package/dist/components/moni-toolbar.d.ts.map +1 -0
  246. package/dist/components/moni-toolbar.js +128 -0
  247. package/dist/components/moni-tooltip.d.ts +65 -0
  248. package/dist/components/moni-tooltip.d.ts.map +1 -0
  249. package/dist/components/moni-tooltip.js +320 -0
  250. package/dist/components/moni-typography.d.ts +42 -0
  251. package/dist/components/moni-typography.d.ts.map +1 -0
  252. package/dist/components/moni-typography.js +205 -0
  253. package/dist/index.d.ts +7 -0
  254. package/dist/index.d.ts.map +1 -0
  255. package/dist/index.js +7 -0
  256. package/dist/styles/animations.css +46 -0
  257. package/dist/styles/base.css +248 -0
  258. package/dist/styles/index.css +3 -0
  259. package/dist/styles/tokens.css +190 -0
  260. package/dist/utils/color.d.ts +51 -0
  261. package/dist/utils/color.d.ts.map +1 -0
  262. package/dist/utils/color.js +107 -0
  263. package/dist/utils/theme.svelte.d.ts +45 -0
  264. package/dist/utils/theme.svelte.d.ts.map +1 -0
  265. package/dist/utils/theme.svelte.js +168 -0
  266. package/dist/web-components.d.ts +3 -0
  267. package/dist/web-components.d.ts.map +1 -0
  268. package/dist/web-components.js +4 -0
  269. package/package.json +76 -0
  270. package/src/actions/index.ts +2 -0
  271. package/src/assets/arch.svg +1 -0
  272. package/src/assets/arrow.svg +1 -0
  273. package/src/assets/boom.svg +1 -0
  274. package/src/assets/bun.svg +1 -0
  275. package/src/assets/burst.svg +1 -0
  276. package/src/assets/circle.svg +1 -0
  277. package/src/assets/clamshell.svg +1 -0
  278. package/src/assets/diamond.svg +1 -0
  279. package/src/assets/fan.svg +1 -0
  280. package/src/assets/flower.svg +1 -0
  281. package/src/assets/gem.svg +1 -0
  282. package/src/assets/ghost-ish.svg +1 -0
  283. package/src/assets/heart.svg +1 -0
  284. package/src/assets/leaf-clover4.svg +1 -0
  285. package/src/assets/leaf-clover8.svg +1 -0
  286. package/src/assets/loading-indicator.svg +1 -0
  287. package/src/assets/material-symbols-rounded.woff2 +0 -0
  288. package/src/assets/material-symbols-subset.woff2 +0 -0
  289. package/src/assets/oval.svg +1 -0
  290. package/src/assets/pentagon.svg +1 -0
  291. package/src/assets/pill.svg +1 -0
  292. package/src/assets/pixel-circle.svg +1 -0
  293. package/src/assets/pixel-triangle.svg +1 -0
  294. package/src/assets/puffy-diamond.svg +1 -0
  295. package/src/assets/puffy.svg +1 -0
  296. package/src/assets/semicircle.svg +1 -0
  297. package/src/assets/shapes/arch.svg +1 -0
  298. package/src/assets/shapes/arrow.svg +1 -0
  299. package/src/assets/shapes/boom.svg +1 -0
  300. package/src/assets/shapes/burst.svg +1 -0
  301. package/src/assets/shapes/circle.svg +1 -0
  302. package/src/assets/shapes/clamshell.svg +1 -0
  303. package/src/assets/shapes/diamond.svg +1 -0
  304. package/src/assets/shapes/fan.svg +1 -0
  305. package/src/assets/shapes/flower.svg +1 -0
  306. package/src/assets/shapes/gem.svg +1 -0
  307. package/src/assets/shapes/ghost-ish.svg +1 -0
  308. package/src/assets/shapes/heart.svg +1 -0
  309. package/src/assets/shapes/leaf-clover4.svg +1 -0
  310. package/src/assets/shapes/leaf-clover8.svg +1 -0
  311. package/src/assets/shapes/loading-indicator.svg +1 -0
  312. package/src/assets/shapes/oval.svg +1 -0
  313. package/src/assets/shapes/pentagon.svg +1 -0
  314. package/src/assets/shapes/pill.svg +1 -0
  315. package/src/assets/shapes/pixel-circle.svg +1 -0
  316. package/src/assets/shapes/pixel-triangle.svg +1 -0
  317. package/src/assets/shapes/puffy-diamond.svg +1 -0
  318. package/src/assets/shapes/puffy.svg +1 -0
  319. package/src/assets/shapes/semicircle.svg +1 -0
  320. package/src/assets/shapes/sided-cookie12.svg +1 -0
  321. package/src/assets/shapes/sided-cookie4.svg +1 -0
  322. package/src/assets/shapes/sided-cookie6.svg +1 -0
  323. package/src/assets/shapes/sided-cookie7.svg +1 -0
  324. package/src/assets/shapes/sided-cookie9.svg +1 -0
  325. package/src/assets/shapes/slanted.svg +1 -0
  326. package/src/assets/shapes/soft-boom.svg +1 -0
  327. package/src/assets/shapes/soft-burst.svg +1 -0
  328. package/src/assets/shapes/square.svg +1 -0
  329. package/src/assets/shapes/sunny.svg +1 -0
  330. package/src/assets/shapes/triangle.svg +1 -0
  331. package/src/assets/shapes/very-sunny.svg +1 -0
  332. package/src/assets/shapes/wavy-circle.svg +1 -0
  333. package/src/assets/shapes/wavy.svg +1 -0
  334. package/src/assets/sided-cookie12.svg +1 -0
  335. package/src/assets/sided-cookie4.svg +1 -0
  336. package/src/assets/sided-cookie6.svg +1 -0
  337. package/src/assets/sided-cookie7.svg +1 -0
  338. package/src/assets/sided-cookie9.svg +1 -0
  339. package/src/assets/slanted.svg +1 -0
  340. package/src/assets/soft-boom.svg +1 -0
  341. package/src/assets/soft-burst.svg +1 -0
  342. package/src/assets/square.svg +1 -0
  343. package/src/assets/star.svg +1 -0
  344. package/src/assets/sunny.svg +1 -0
  345. package/src/assets/triangle.svg +1 -0
  346. package/src/assets/very-sunny.svg +1 -0
  347. package/src/assets/wavy-circle.svg +1 -0
  348. package/src/assets/wavy.svg +1 -0
  349. package/src/assets.d.ts +12 -0
  350. package/src/components/_base/field-styles.ts +507 -0
  351. package/src/components/_base/index.ts +3 -0
  352. package/src/components/_base/interaction-styles.ts +125 -0
  353. package/src/components/_base/moni-element.ts +21 -0
  354. package/src/components/_base/shared-styles.ts +148 -0
  355. package/src/components/index.ts +45 -0
  356. package/src/components/loading-shapes.ts +9 -0
  357. package/src/components/moni-app-bar.test.ts +86 -0
  358. package/src/components/moni-app-bar.ts +190 -0
  359. package/src/components/moni-badge.ts +138 -0
  360. package/src/components/moni-bottom-sheet.test.ts +420 -0
  361. package/src/components/moni-bottom-sheet.ts +425 -0
  362. package/src/components/moni-button-group.test.ts +148 -0
  363. package/src/components/moni-button-group.ts +277 -0
  364. package/src/components/moni-button-segment.ts +291 -0
  365. package/src/components/moni-button.test.ts +166 -0
  366. package/src/components/moni-button.ts +709 -0
  367. package/src/components/moni-card.test.ts +83 -0
  368. package/src/components/moni-card.ts +203 -0
  369. package/src/components/moni-carousel.test.ts +238 -0
  370. package/src/components/moni-carousel.ts +1027 -0
  371. package/src/components/moni-checkbox.test.ts +78 -0
  372. package/src/components/moni-checkbox.ts +192 -0
  373. package/src/components/moni-chip.test.ts +168 -0
  374. package/src/components/moni-chip.ts +335 -0
  375. package/src/components/moni-color-field.test.ts +56 -0
  376. package/src/components/moni-color-field.ts +135 -0
  377. package/src/components/moni-context-menu.test.ts +99 -0
  378. package/src/components/moni-context-menu.ts +166 -0
  379. package/src/components/moni-dialog.ts +240 -0
  380. package/src/components/moni-divider.test.ts +42 -0
  381. package/src/components/moni-divider.ts +77 -0
  382. package/src/components/moni-expansion.ts +86 -0
  383. package/src/components/moni-fab-menu.test.ts +118 -0
  384. package/src/components/moni-fab-menu.ts +237 -0
  385. package/src/components/moni-fab.test.ts +128 -0
  386. package/src/components/moni-fab.ts +262 -0
  387. package/src/components/moni-file-field.test.ts +81 -0
  388. package/src/components/moni-file-field.ts +149 -0
  389. package/src/components/moni-icon.test.ts +70 -0
  390. package/src/components/moni-icon.ts +97 -0
  391. package/src/components/moni-list-item.test.ts +114 -0
  392. package/src/components/moni-list-item.ts +222 -0
  393. package/src/components/moni-list.ts +59 -0
  394. package/src/components/moni-loading-indicator.test.ts +41 -0
  395. package/src/components/moni-loading-indicator.ts +188 -0
  396. package/src/components/moni-menu-item.ts +85 -0
  397. package/src/components/moni-menu.test.ts +87 -0
  398. package/src/components/moni-menu.ts +287 -0
  399. package/src/components/moni-morph-modal.test.ts +286 -0
  400. package/src/components/moni-morph-modal.ts +1312 -0
  401. package/src/components/moni-nav-item.ts +243 -0
  402. package/src/components/moni-nav.test.ts +139 -0
  403. package/src/components/moni-nav.ts +266 -0
  404. package/src/components/moni-progress.test.ts +90 -0
  405. package/src/components/moni-progress.ts +322 -0
  406. package/src/components/moni-radio.test.ts +86 -0
  407. package/src/components/moni-radio.ts +196 -0
  408. package/src/components/moni-ripple.ts +146 -0
  409. package/src/components/moni-segmented-button.test.ts +99 -0
  410. package/src/components/moni-segmented-button.ts +220 -0
  411. package/src/components/moni-select-option.ts +85 -0
  412. package/src/components/moni-select.test.ts +210 -0
  413. package/src/components/moni-select.ts +1107 -0
  414. package/src/components/moni-shape.ts +128 -0
  415. package/src/components/moni-side-sheet.test.ts +128 -0
  416. package/src/components/moni-side-sheet.ts +544 -0
  417. package/src/components/moni-slider.test.ts +82 -0
  418. package/src/components/moni-slider.ts +387 -0
  419. package/src/components/moni-snackbar.test.ts +82 -0
  420. package/src/components/moni-snackbar.ts +146 -0
  421. package/src/components/moni-split-button.ts +121 -0
  422. package/src/components/moni-step.test.ts +57 -0
  423. package/src/components/moni-step.ts +155 -0
  424. package/src/components/moni-stepper.test.ts +116 -0
  425. package/src/components/moni-stepper.ts +100 -0
  426. package/src/components/moni-switch.test.ts +117 -0
  427. package/src/components/moni-switch.ts +237 -0
  428. package/src/components/moni-tab.test.ts +54 -0
  429. package/src/components/moni-tab.ts +133 -0
  430. package/src/components/moni-tabs.ts +92 -0
  431. package/src/components/moni-text-field.test.ts +115 -0
  432. package/src/components/moni-text-field.ts +149 -0
  433. package/src/components/moni-textarea.test.ts +147 -0
  434. package/src/components/moni-textarea.ts +176 -0
  435. package/src/components/moni-time-picker.test.ts +61 -0
  436. package/src/components/moni-time-picker.ts +800 -0
  437. package/src/components/moni-toolbar.test.ts +93 -0
  438. package/src/components/moni-toolbar.ts +119 -0
  439. package/src/components/moni-tooltip.test.ts +122 -0
  440. package/src/components/moni-tooltip.ts +324 -0
  441. package/src/components/moni-typography.test.ts +119 -0
  442. package/src/components/moni-typography.ts +195 -0
  443. package/src/index.ts +65 -0
  444. package/src/styles/animations.css +46 -0
  445. package/src/styles/base.css +248 -0
  446. package/src/styles/index.css +3 -0
  447. package/src/styles/tokens.css +190 -0
  448. package/src/types/svelte-runes.d.ts +7 -0
  449. package/src/utils/color.ts +170 -0
  450. package/src/utils/theme.svelte.ts +206 -0
  451. package/src/web-components.ts +5 -0
@@ -0,0 +1,1007 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { html, css } from 'lit';
8
+ import { customElement, property, query, state, queryAll } from 'lit/decorators.js';
9
+ import { MoniElement, sharedStyles } from './_base/index.js';
10
+ import { gsap } from 'gsap';
11
+ /**
12
+ * Material Design 3 Expressive Carousel component.
13
+ * Supports three layouts:
14
+ * - `multi-browse`: Shows a collection of items (large, medium, and small items).
15
+ * - `hero`: Focuses on one large item with a smaller item peeking.
16
+ * - `uncontained`: Standard same-sized layout bleeding off the edges.
17
+ *
18
+ * Attributes:
19
+ * - layout: 'multi-browse' | 'hero' | 'uncontained'
20
+ * - auto: if true, dynamically calculates items sizes to fit the container without gaps.
21
+ * - large-width: width of large items (used in non-auto mode or as a guideline).
22
+ * - medium-width: width of medium items (multi-browse layout).
23
+ * - small-width: width of small/peeking items.
24
+ * - gap: spacing between elements (default 8px).
25
+ * - padding: leading/trailing padding (default 16px).
26
+ * - border-radius: radius of cards (default 28px).
27
+ * - header-text: header title of the carousel.
28
+ * - show-all: renders a "Show all" action button/link.
29
+ * - show-all-text: customize the text for the "Show all" action.
30
+ */
31
+ let MoniCarousel = class MoniCarousel extends MoniElement {
32
+ constructor() {
33
+ super(...arguments);
34
+ this.items = [];
35
+ this.layout = 'multi-browse';
36
+ this.auto = true;
37
+ this.largeWidth = 220;
38
+ this.mediumWidth = 96;
39
+ this.smallWidth = 48;
40
+ this.gap = 8;
41
+ this.padding = 16;
42
+ this.borderRadius = 28;
43
+ this.showAll = false;
44
+ this.showAllText = 'Show all';
45
+ this.headerText = '';
46
+ this.hideNav = false;
47
+ this._containerWidth = 0;
48
+ this._slottedItems = [];
49
+ this._hasSlottedShowAll = false;
50
+ this._resizeObserver = null;
51
+ this._isDown = false;
52
+ this._startX = 0;
53
+ this._scrollLeftStart = 0;
54
+ this._velocity = 0;
55
+ this._lastTime = 0;
56
+ this._lastX = 0;
57
+ this._draggedDistance = 0;
58
+ this._rafId = null;
59
+ this._isMobile = false;
60
+ // Scroll interpolation state
61
+ this._tickerTarget = 0;
62
+ this._tickerCurrent = 0;
63
+ this._isTicking = false;
64
+ // quickSetter caches — avoid gsap.set() overhead per frame
65
+ this._cardSetX = [];
66
+ this._cardSetWidth = [];
67
+ this._imgSetX = [];
68
+ this._titleSetOpacity = [];
69
+ /**
70
+ * RAF-gated version of updateLayout for scroll events.
71
+ * Prevents multiple layout recalculations per frame.
72
+ */
73
+ this._tick = () => {
74
+ const dt = gsap.ticker.deltaRatio();
75
+ // Smoother lerp on mobile to avoid abrupt changes ("brusco")
76
+ const ease = this._isMobile ? 0.08 : 0.15;
77
+ this._tickerCurrent += (this._tickerTarget - this._tickerCurrent) * ease * dt;
78
+ if (Math.abs(this._tickerTarget - this._tickerCurrent) < 0.0005) {
79
+ this._tickerCurrent = this._tickerTarget;
80
+ gsap.ticker.remove(this._tick);
81
+ this._isTicking = false;
82
+ }
83
+ this._applyLayout(this._tickerCurrent);
84
+ };
85
+ this._scheduleLayout = () => {
86
+ if (!this._scrollContainer)
87
+ return;
88
+ this._tickerTarget = this._scrollContainer.scrollLeft / this.itemSize;
89
+ if (!this._isTicking) {
90
+ this._isTicking = true;
91
+ gsap.ticker.add(this._tick);
92
+ }
93
+ };
94
+ this.updateLayout = (instant = false) => {
95
+ if (!this._scrollContainer || !this._cards || this._cards.length === 0)
96
+ return;
97
+ // Rebuild quickSetters if card count changed (e.g. after items update)
98
+ if (this._cardSetX.length !== this._cards.length) {
99
+ this._buildQuickSetters();
100
+ }
101
+ this._tickerTarget = this._scrollContainer.scrollLeft / this.itemSize;
102
+ if (instant || (!this._isTicking && this._tickerCurrent === 0)) {
103
+ this._tickerCurrent = this._tickerTarget;
104
+ this._applyLayout(this._tickerCurrent);
105
+ }
106
+ else {
107
+ if (!this._isTicking) {
108
+ this._isTicking = true;
109
+ gsap.ticker.add(this._tick);
110
+ }
111
+ }
112
+ };
113
+ }
114
+ get effectiveItems() {
115
+ return this.items && this.items.length > 0 ? this.items : this._slottedItems;
116
+ }
117
+ static { this.styles = [
118
+ sharedStyles,
119
+ css `
120
+ :host {
121
+ display: block;
122
+ width: 100%;
123
+ user-select: none;
124
+ -webkit-user-select: none;
125
+ }
126
+
127
+ .carousel-container {
128
+ position: relative;
129
+ width: 100%;
130
+ display: flex;
131
+ flex-direction: column;
132
+ gap: 12px;
133
+ }
134
+
135
+ .carousel-header {
136
+ display: flex;
137
+ justify-content: space-between;
138
+ align-items: flex-end;
139
+ padding: 0 var(--carousel-padding, 16px);
140
+ }
141
+
142
+ .carousel-header h3 {
143
+ margin: 0;
144
+ font-family: var(--font-title, serif);
145
+ font-size: 1.5rem;
146
+ font-weight: 500;
147
+ color: var(--on-surface);
148
+ }
149
+
150
+ .show-all-link {
151
+ color: var(--primary);
152
+ font-weight: 500;
153
+ font-size: 0.875rem;
154
+ text-decoration: none;
155
+ cursor: pointer;
156
+ transition: opacity var(--speed2);
157
+ }
158
+
159
+ .show-all-link:hover {
160
+ opacity: 0.8;
161
+ text-decoration: underline;
162
+ }
163
+
164
+ .carousel-viewport {
165
+ position: relative;
166
+ width: 100%;
167
+ overflow: hidden;
168
+ }
169
+
170
+ .scroll-container {
171
+ width: 100%;
172
+ height: 296px;
173
+ overflow-x: auto;
174
+ overflow-y: hidden;
175
+ scroll-snap-type: x mandatory;
176
+ scrollbar-width: none;
177
+ -webkit-overflow-scrolling: touch;
178
+ cursor: grab;
179
+ }
180
+
181
+ .scroll-container:active {
182
+ cursor: grabbing;
183
+ }
184
+
185
+ .scroll-container::-webkit-scrollbar {
186
+ display: none;
187
+ }
188
+
189
+ .snap-track {
190
+ display: flex;
191
+ width: calc(var(--carousel-track-width, 0px) + var(--carousel-right-padding, 128px));
192
+ gap: var(--carousel-gap, 8px);
193
+ padding: 8px 0 8px var(--carousel-padding, 16px);
194
+ height: 100%;
195
+ pointer-events: none;
196
+ }
197
+
198
+ .snap-item {
199
+ flex: 0 0 var(--carousel-snap-width, 220px);
200
+ height: 100%;
201
+ scroll-snap-align: start;
202
+ pointer-events: none;
203
+ }
204
+
205
+ .visual-track {
206
+ position: absolute;
207
+ left: 0;
208
+ top: 8px;
209
+ width: 0;
210
+ height: 280px;
211
+ overflow: visible;
212
+ pointer-events: none;
213
+ }
214
+
215
+ .card {
216
+ position: absolute;
217
+ top: 0;
218
+ height: 280px;
219
+ border-radius: var(--carousel-border-radius, 28px);
220
+ overflow: hidden;
221
+ background-color: var(--surface-container-high);
222
+ pointer-events: auto;
223
+ box-shadow: var(--elevate1);
224
+ will-change: transform;
225
+ cursor: pointer;
226
+ transition: box-shadow var(--speed2);
227
+ }
228
+
229
+ .card:hover {
230
+ box-shadow: var(--elevate2);
231
+ }
232
+
233
+ .card::after {
234
+ content: '';
235
+ position: absolute;
236
+ top: 0;
237
+ left: 0;
238
+ right: 0;
239
+ bottom: 0;
240
+ background: linear-gradient(to bottom, transparent 40%, rgba(0, 0, 0, 0.7) 100%);
241
+ pointer-events: none;
242
+ z-index: 1;
243
+ }
244
+
245
+ .img-parallax-container {
246
+ width: 100%;
247
+ height: 100%;
248
+ position: relative;
249
+ overflow: hidden;
250
+ }
251
+
252
+ .card img {
253
+ width: calc(100% + 50px);
254
+ height: 100%;
255
+ object-fit: cover;
256
+ position: absolute;
257
+ left: -25px;
258
+ pointer-events: none;
259
+ user-select: none;
260
+ -webkit-user-drag: none;
261
+ will-change: transform;
262
+ }
263
+
264
+ .card-title {
265
+ position: absolute;
266
+ bottom: 20px;
267
+ left: 20px;
268
+ right: 20px;
269
+ color: #ffffff;
270
+ margin: 0;
271
+ font-size: 1.1rem;
272
+ font-weight: 500;
273
+ pointer-events: none;
274
+ white-space: nowrap;
275
+ overflow: hidden;
276
+ text-overflow: ellipsis;
277
+ z-index: 2;
278
+ }
279
+
280
+ /* Arrow navigation overlays */
281
+ .nav-button {
282
+ position: absolute;
283
+ top: 50%;
284
+ transform: translateY(-50%);
285
+ z-index: 10;
286
+ width: 48px;
287
+ height: 48px;
288
+ border-radius: 50%;
289
+ background-color: var(--surface-container-highest);
290
+ color: var(--on-surface);
291
+ border: none;
292
+ box-shadow: var(--elevate2);
293
+ display: flex;
294
+ justify-content: center;
295
+ align-items: center;
296
+ cursor: pointer;
297
+ opacity: 0;
298
+ pointer-events: none;
299
+ transition: opacity var(--speed2), background-color var(--speed2);
300
+ }
301
+
302
+ .nav-button:hover {
303
+ background-color: var(--primary-container);
304
+ color: var(--on-primary-container);
305
+ }
306
+
307
+ .nav-button.prev {
308
+ left: 24px;
309
+ }
310
+
311
+ .nav-button.next {
312
+ right: 24px;
313
+ }
314
+
315
+ .carousel-viewport:hover .nav-button.visible {
316
+ opacity: 1;
317
+ pointer-events: auto;
318
+ }
319
+
320
+ @media (max-width: 600px) {
321
+ .nav-button {
322
+ display: none !important;
323
+ }
324
+ }
325
+
326
+ /* Utility icon style inside shadow dom */
327
+ .material-symbols {
328
+ font-family: var(--font-icon);
329
+ font-weight: normal;
330
+ font-style: normal;
331
+ font-size: 24px;
332
+ line-height: 1;
333
+ letter-spacing: normal;
334
+ text-transform: none;
335
+ display: inline-block;
336
+ white-space: nowrap;
337
+ word-wrap: normal;
338
+ direction: ltr;
339
+ -webkit-font-smoothing: antialiased;
340
+ }
341
+ `
342
+ ]; }
343
+ connectedCallback() {
344
+ super.connectedCallback();
345
+ if (typeof ResizeObserver !== 'undefined') {
346
+ this._resizeObserver = new ResizeObserver((entries) => {
347
+ for (const entry of entries) {
348
+ this._containerWidth = entry.contentRect.width;
349
+ this.updateLayout(true); // Synchronous update for instant resizing!
350
+ this.requestUpdate();
351
+ }
352
+ });
353
+ this._resizeObserver.observe(this);
354
+ }
355
+ // Detect mobile for parallax toggle
356
+ if (typeof window !== 'undefined' && typeof window.matchMedia === 'function') {
357
+ const mql = window.matchMedia('(max-width: 600px)');
358
+ this._isMobile = mql.matches;
359
+ const handler = (e) => { this._isMobile = e.matches; };
360
+ mql.addEventListener('change', handler);
361
+ // Store for cleanup
362
+ this.__mqlCleanup = () => mql.removeEventListener('change', handler);
363
+ }
364
+ }
365
+ disconnectedCallback() {
366
+ if (this._resizeObserver) {
367
+ this._resizeObserver.disconnect();
368
+ }
369
+ // Cancel any pending RAF or ticker
370
+ if (this._rafId !== null) {
371
+ cancelAnimationFrame(this._rafId);
372
+ this._rafId = null;
373
+ }
374
+ gsap.ticker.remove(this._tick);
375
+ this._isTicking = false;
376
+ // Clean up matchMedia listener
377
+ if (this.__mqlCleanup) {
378
+ this.__mqlCleanup();
379
+ delete this.__mqlCleanup;
380
+ }
381
+ super.disconnectedCallback();
382
+ }
383
+ firstUpdated() {
384
+ const defaultSlot = this.shadowRoot?.querySelector('slot:not([name])');
385
+ if (defaultSlot) {
386
+ this._handleSlotChange({ target: defaultSlot });
387
+ }
388
+ const showAllSlot = this.shadowRoot?.querySelector('slot[name="show-all"]');
389
+ if (showAllSlot) {
390
+ this._handleShowAllSlotChange({ target: showAllSlot });
391
+ }
392
+ this._buildQuickSetters();
393
+ this.updateLayout(true);
394
+ }
395
+ updated(changedProperties) {
396
+ super.updated(changedProperties);
397
+ if (changedProperties.has('layout') ||
398
+ changedProperties.has('largeWidth') ||
399
+ changedProperties.has('mediumWidth') ||
400
+ changedProperties.has('smallWidth') ||
401
+ changedProperties.has('gap') ||
402
+ changedProperties.has('padding') ||
403
+ changedProperties.has('items') ||
404
+ changedProperties.has('hideNav') ||
405
+ changedProperties.has('_containerWidth') ||
406
+ changedProperties.has('_slottedItems') ||
407
+ changedProperties.has('_hasSlottedShowAll')) {
408
+ if (changedProperties.has('layout') && this._scrollContainer) {
409
+ this._scrollContainer.scrollLeft = 0;
410
+ this._scrollContainer.style.scrollSnapType =
411
+ this.layout === 'uncontained' ? 'none' : 'x mandatory';
412
+ }
413
+ this.updateLayout(true);
414
+ }
415
+ }
416
+ get computedLayout() {
417
+ const W_c = this._containerWidth || this.getBoundingClientRect().width || 360;
418
+ const gap = this.gap;
419
+ const padding = this.padding;
420
+ const W_a = W_c - 2 * padding;
421
+ let L = this.largeWidth;
422
+ let M = this.mediumWidth;
423
+ let S = this.smallWidth;
424
+ let N = 1;
425
+ if (this.auto) {
426
+ if (this.layout === 'uncontained') {
427
+ // Fits as many L items as possible, letting them bleed off the right edge.
428
+ // We target large width around 260px.
429
+ L = Math.min(W_a, 260);
430
+ }
431
+ else if (this.layout === 'hero') {
432
+ // Hero has N large items and 1 small peeking item.
433
+ // W_a = N * L + S + N * gap
434
+ S = 48;
435
+ N = Math.max(1, Math.floor((W_a - S) / (250 + gap)));
436
+ L = (W_a - S - N * gap) / N;
437
+ if (L < 150) {
438
+ N = 1;
439
+ L = W_a - S - gap;
440
+ }
441
+ }
442
+ else {
443
+ // multi-browse: N large items, 1 medium, 1 small
444
+ // W_a = N * L + M + S + (N + 1) * gap
445
+ S = 48;
446
+ let bestN = 1;
447
+ let bestL = 220;
448
+ let bestDiff = Infinity;
449
+ for (let n = 1; n <= 10; n++) {
450
+ const l = (W_a - S - (n + 1) * gap) / (n + 0.45);
451
+ if (l >= 140 && l <= 340) {
452
+ const diff = Math.abs(l - 220);
453
+ if (diff < bestDiff) {
454
+ bestDiff = diff;
455
+ bestN = n;
456
+ bestL = l;
457
+ }
458
+ }
459
+ }
460
+ if (bestDiff === Infinity) {
461
+ N = 1;
462
+ L = (W_a - S - 2 * gap) / 1.45;
463
+ }
464
+ else {
465
+ N = bestN;
466
+ L = bestL;
467
+ }
468
+ M = 0.45 * L;
469
+ }
470
+ }
471
+ else {
472
+ // Non-auto/manual sizing mode
473
+ L = this.largeWidth;
474
+ M = this.mediumWidth;
475
+ S = this.smallWidth;
476
+ if (this.layout === 'hero') {
477
+ N = 1;
478
+ }
479
+ else if (this.layout === 'uncontained') {
480
+ N = Math.max(1, Math.floor(W_a / (L + gap)));
481
+ }
482
+ else {
483
+ N = 1;
484
+ }
485
+ }
486
+ return { L, M, S, N };
487
+ }
488
+ get itemSize() {
489
+ return this.computedLayout.L + this.gap;
490
+ }
491
+ _getCardLayout(p) {
492
+ const { L, M, S, N } = this.computedLayout;
493
+ const gap = this.gap;
494
+ const padding = this.padding;
495
+ let width = L;
496
+ let x = padding;
497
+ let opacity = 1;
498
+ if (this.layout === 'uncontained') {
499
+ width = L;
500
+ x = padding + p * (L + gap);
501
+ opacity = 1;
502
+ }
503
+ else if (this.layout === 'hero') {
504
+ const X_N = padding + N * (L + gap);
505
+ const X_M1 = padding - gap - S;
506
+ if (p <= -1) {
507
+ width = S;
508
+ x = X_M1 + (p - -1) * (S + gap);
509
+ opacity = 0;
510
+ }
511
+ else if (p <= 0) {
512
+ width = gsap.utils.interpolate(S, L, p + 1);
513
+ x = gsap.utils.interpolate(X_M1, padding, p + 1);
514
+ opacity = gsap.utils.interpolate(0, 1, p + 1);
515
+ }
516
+ else if (p <= N - 1) {
517
+ width = L;
518
+ x = padding + p * (L + gap);
519
+ opacity = 1;
520
+ }
521
+ else if (p <= N) {
522
+ const u = p - (N - 1);
523
+ const X_last = padding + (N - 1) * (L + gap);
524
+ width = gsap.utils.interpolate(L, S, u);
525
+ x = gsap.utils.interpolate(X_last, X_N, u);
526
+ opacity = gsap.utils.interpolate(1, 0, u);
527
+ }
528
+ else {
529
+ width = S;
530
+ x = X_N + (p - N) * (S + gap);
531
+ opacity = 0;
532
+ }
533
+ }
534
+ else {
535
+ // multi-browse
536
+ const X_N = padding + N * (L + gap);
537
+ const X_N1 = X_N + M + gap;
538
+ const X_M1 = padding - gap - S;
539
+ if (p <= -1) {
540
+ width = S;
541
+ x = X_M1 + (p - -1) * (S + gap);
542
+ opacity = 0;
543
+ }
544
+ else if (p <= 0) {
545
+ width = gsap.utils.interpolate(S, L, p + 1);
546
+ x = gsap.utils.interpolate(X_M1, padding, p + 1);
547
+ opacity = gsap.utils.interpolate(0, 1, p + 1);
548
+ }
549
+ else if (p <= N - 1) {
550
+ width = L;
551
+ x = padding + p * (L + gap);
552
+ opacity = 1;
553
+ }
554
+ else if (p <= N) {
555
+ const u = p - (N - 1);
556
+ const X_last = padding + (N - 1) * (L + gap);
557
+ width = gsap.utils.interpolate(L, M, u);
558
+ x = gsap.utils.interpolate(X_last, X_N, u);
559
+ opacity = gsap.utils.interpolate(1, 0, u);
560
+ }
561
+ else if (p <= N + 1) {
562
+ const u = p - N;
563
+ width = gsap.utils.interpolate(M, S, u);
564
+ x = gsap.utils.interpolate(X_N, X_N1, u);
565
+ opacity = 0;
566
+ }
567
+ else {
568
+ width = S;
569
+ x = X_N1 + (p - (N + 1)) * (S + gap);
570
+ opacity = 0;
571
+ }
572
+ }
573
+ return { width, x, opacity };
574
+ }
575
+ /**
576
+ * Rebuild quickSetter caches after cards change.
577
+ * quickSetter avoids gsap.set() overhead for properties updated every frame.
578
+ */
579
+ _buildQuickSetters() {
580
+ if (!this._cards || this._cards.length === 0)
581
+ return;
582
+ this._cardSetX = [];
583
+ this._cardSetWidth = [];
584
+ this._imgSetX = [];
585
+ this._titleSetOpacity = [];
586
+ this._cards.forEach((card) => {
587
+ this._cardSetX.push(gsap.quickSetter(card, 'x', 'px'));
588
+ this._cardSetWidth.push(gsap.quickSetter(card, 'width', 'px'));
589
+ const img = card.querySelector('img');
590
+ this._imgSetX.push(img ? gsap.quickSetter(img, 'x', 'px') : (() => { }));
591
+ const title = card.querySelector('.card-title');
592
+ this._titleSetOpacity.push(title ? gsap.quickSetter(title, 'opacity') : (() => { }));
593
+ });
594
+ }
595
+ _applyLayout(t) {
596
+ const isMobile = this._isMobile;
597
+ const cardCount = this._cards.length;
598
+ for (let i = 0; i < cardCount; i++) {
599
+ const p = i - t;
600
+ const layout = this._getCardLayout(p);
601
+ // Use quickSetters — ~3x faster than gsap.set() per call
602
+ this._cardSetX[i](layout.x);
603
+ this._cardSetWidth[i](layout.width);
604
+ // Skip parallax on mobile to save per-frame work
605
+ if (!isMobile) {
606
+ const clampedP = Math.max(-1, Math.min(1, p));
607
+ this._imgSetX[i](clampedP * -25);
608
+ }
609
+ this._titleSetOpacity[i](layout.opacity);
610
+ }
611
+ }
612
+ _handleMouseDown(e) {
613
+ gsap.killTweensOf(this._scrollContainer);
614
+ this._isDown = true;
615
+ this._draggedDistance = 0;
616
+ this._scrollContainer.style.scrollBehavior = 'auto';
617
+ this._scrollContainer.style.scrollSnapType = 'none';
618
+ this._startX = e.pageX - this._scrollContainer.offsetLeft;
619
+ this._scrollLeftStart = this._scrollContainer.scrollLeft;
620
+ this._velocity = 0;
621
+ this._lastX = e.pageX;
622
+ this._lastTime = performance.now();
623
+ }
624
+ _handleMouseMove(e) {
625
+ if (!this._isDown)
626
+ return;
627
+ e.preventDefault();
628
+ const currentX = e.pageX;
629
+ const x = currentX - this._scrollContainer.offsetLeft;
630
+ this._scrollContainer.scrollLeft = this._scrollLeftStart + (this._startX - x) * 1.25;
631
+ const currentTime = performance.now();
632
+ const dt = currentTime - this._lastTime;
633
+ if (dt > 0) {
634
+ this._velocity = (currentX - this._lastX) / dt;
635
+ }
636
+ this._draggedDistance += Math.abs(currentX - this._lastX);
637
+ this._lastX = currentX;
638
+ this._lastTime = currentTime;
639
+ }
640
+ _handleMouseUp() {
641
+ if (!this._isDown)
642
+ return;
643
+ this._isDown = false;
644
+ const currentTime = performance.now();
645
+ if (currentTime - this._lastTime > 100) {
646
+ this._velocity = 0;
647
+ }
648
+ // Dynamic momentum: stronger swipes have a much higher multiplier
649
+ const momentumMultiplier = 350 + Math.abs(this._velocity) * 300;
650
+ const projectedScrollLeft = this._scrollContainer.scrollLeft - this._velocity * momentumMultiplier;
651
+ if (this.layout !== 'uncontained') {
652
+ this._scrollContainer.style.scrollSnapType = 'none';
653
+ let targetIndex = Math.round(projectedScrollLeft / this.itemSize);
654
+ targetIndex = Math.max(0, Math.min(this.effectiveItems.length - 1, targetIndex));
655
+ const snapPoint = targetIndex * this.itemSize;
656
+ // Dynamic duration: longer distance = more time, max 0.85s for faster feeling
657
+ const currentIndex = Math.round(this._scrollContainer.scrollLeft / this.itemSize);
658
+ const cardsSkipped = Math.abs(targetIndex - currentIndex);
659
+ const duration = Math.min(0.85, 0.25 + cardsSkipped * 0.04);
660
+ this._scrollContainer.style.scrollBehavior = 'auto';
661
+ gsap.to(this._scrollContainer, {
662
+ scrollLeft: snapPoint,
663
+ duration: duration,
664
+ ease: 'power3.out',
665
+ onComplete: () => {
666
+ if (!this._isDown && this._scrollContainer) {
667
+ this._scrollContainer.style.scrollSnapType = 'x mandatory';
668
+ }
669
+ }
670
+ });
671
+ }
672
+ }
673
+ _handleTouchStart(e) {
674
+ gsap.killTweensOf(this._scrollContainer);
675
+ this._isDown = true;
676
+ this._draggedDistance = 0;
677
+ this._scrollContainer.style.scrollBehavior = 'auto';
678
+ this._scrollContainer.style.scrollSnapType = 'none';
679
+ const touch = e.touches[0];
680
+ this._startX = touch.pageX - this._scrollContainer.offsetLeft;
681
+ this._scrollLeftStart = this._scrollContainer.scrollLeft;
682
+ this._velocity = 0;
683
+ this._lastX = touch.pageX;
684
+ this._lastTime = performance.now();
685
+ }
686
+ _handleTouchMove(e) {
687
+ if (!this._isDown)
688
+ return;
689
+ const touch = e.touches[0];
690
+ const currentX = touch.pageX;
691
+ const x = currentX - this._scrollContainer.offsetLeft;
692
+ this._scrollContainer.scrollLeft = this._scrollLeftStart + (this._startX - x);
693
+ const currentTime = performance.now();
694
+ const dt = currentTime - this._lastTime;
695
+ if (dt > 0) {
696
+ this._velocity = (currentX - this._lastX) / dt;
697
+ }
698
+ this._draggedDistance += Math.abs(currentX - this._lastX);
699
+ this._lastX = currentX;
700
+ this._lastTime = currentTime;
701
+ }
702
+ _handleTouchEnd() {
703
+ this._handleMouseUp();
704
+ }
705
+ _handleWheel(e) {
706
+ // Solo interceptar scroll vertical puro (rueda de mouse típica)
707
+ if (Math.abs(e.deltaY) > Math.abs(e.deltaX)) {
708
+ const maxScroll = this._scrollContainer.scrollWidth - this._scrollContainer.clientWidth;
709
+ const currentScroll = this._scrollContainer.scrollLeft;
710
+ // Comprobar si estamos en los bordes para permitir el scroll natural de la página
711
+ const isAtStart = currentScroll <= 0;
712
+ const isAtEnd = currentScroll >= maxScroll - 1; // Margen de 1px por redondeos decimales
713
+ if ((e.deltaY < 0 && isAtStart) || (e.deltaY > 0 && isAtEnd)) {
714
+ return; // Dejar que la página haga scroll vertical
715
+ }
716
+ e.preventDefault(); // Prevenir el scroll de la página
717
+ // Desactivar el snap momentáneamente para que el movimiento de rueda sea fluido
718
+ this._scrollContainer.style.scrollSnapType = 'none';
719
+ // Multiplicador si el deltaMode no es pixel (0)
720
+ let delta = e.deltaY;
721
+ if (e.deltaMode === 1)
722
+ delta *= 40; // Líneas
723
+ else if (e.deltaMode === 2)
724
+ delta *= 800; // Páginas
725
+ this._scrollContainer.scrollLeft += delta;
726
+ // Restablecer el snap después de un pequeño retraso
727
+ if (this._wheelTimeout)
728
+ clearTimeout(this._wheelTimeout);
729
+ this._wheelTimeout = setTimeout(() => {
730
+ if (this.layout !== 'uncontained') {
731
+ this._scrollContainer.style.scrollSnapType = 'x mandatory';
732
+ }
733
+ }, 150);
734
+ }
735
+ }
736
+ _handleCardClick(e, item, index) {
737
+ if (this._draggedDistance > 8) {
738
+ e.preventDefault();
739
+ e.stopPropagation();
740
+ return;
741
+ }
742
+ this.dispatchEvent(new CustomEvent('item-click', {
743
+ detail: { item, index },
744
+ bubbles: true,
745
+ composed: true
746
+ }));
747
+ }
748
+ _scrollPrevious() {
749
+ const target = Math.max(0, this._scrollContainer.scrollLeft - this.itemSize);
750
+ this._scrollContainer.style.scrollBehavior = 'smooth';
751
+ this._scrollContainer.scrollTo({ left: target, behavior: 'smooth' });
752
+ }
753
+ _scrollNext() {
754
+ const maxScroll = this._scrollContainer.scrollWidth - this._scrollContainer.clientWidth;
755
+ const target = Math.min(maxScroll, this._scrollContainer.scrollLeft + this.itemSize);
756
+ this._scrollContainer.style.scrollBehavior = 'smooth';
757
+ this._scrollContainer.scrollTo({ left: target, behavior: 'smooth' });
758
+ }
759
+ _handleShowAllClick(e) {
760
+ const target = e.target;
761
+ if (target.tagName.toLowerCase() === 'a' && target.getAttribute('href') === '#') {
762
+ e.preventDefault();
763
+ }
764
+ this.dispatchEvent(new CustomEvent('show-all-click', {
765
+ bubbles: true,
766
+ composed: true
767
+ }));
768
+ }
769
+ _handleShowAllSlotChange(e) {
770
+ const slot = e.target;
771
+ let nodes = typeof slot.assignedElements === 'function' ? slot.assignedElements({ flatten: true }) : [];
772
+ if (nodes.length === 0) {
773
+ nodes = slot.assignedNodes().filter(n => n.nodeType === 1);
774
+ }
775
+ if (nodes.length === 0) {
776
+ nodes = Array.from(this.querySelectorAll('[slot="show-all"]')); // Fallback for JSDOM
777
+ }
778
+ this._hasSlottedShowAll = nodes.length > 0;
779
+ }
780
+ _handleSlotChange(e) {
781
+ const slot = e.target;
782
+ let nodes = typeof slot.assignedElements === 'function' ? slot.assignedElements({ flatten: true }) : [];
783
+ if (nodes.length === 0) {
784
+ nodes = slot.assignedNodes().filter(n => n.nodeType === 1);
785
+ }
786
+ if (nodes.length === 0) {
787
+ nodes = Array.from(this.children).filter(child => child.getAttribute('slot') !== 'show-all'); // Fallback for JSDOM, ignore show-all slot
788
+ }
789
+ const items = [];
790
+ for (const node of nodes) {
791
+ if (node.tagName.toLowerCase() === 'img') {
792
+ const img = node;
793
+ items.push({
794
+ title: img.getAttribute('title') || img.getAttribute('alt') || '',
795
+ img: img.src
796
+ });
797
+ }
798
+ else if (node.tagName.toLowerCase() === 'a') {
799
+ const anchor = node;
800
+ const img = anchor.querySelector('img');
801
+ if (img) {
802
+ items.push({
803
+ title: img.getAttribute('title') || img.getAttribute('alt') || anchor.getAttribute('title') || '',
804
+ img: img.src,
805
+ href: anchor.href,
806
+ target: anchor.target
807
+ });
808
+ }
809
+ }
810
+ }
811
+ this._slottedItems = items;
812
+ // Check if slotted show-all button presence changed
813
+ const hasSlottedShowAll = !!this.querySelector('[slot="show-all"]');
814
+ if (hasSlottedShowAll !== this._hasSlottedShowAll) {
815
+ this._hasSlottedShowAll = hasSlottedShowAll;
816
+ }
817
+ void this.updateComplete.then(() => {
818
+ this.updateLayout(true);
819
+ });
820
+ }
821
+ render() {
822
+ const { L, M, S } = this.computedLayout;
823
+ const hasItems = this.effectiveItems && this.effectiveItems.length > 0;
824
+ const hasSlottedShowAll = this._hasSlottedShowAll || !!this.querySelector('[slot="show-all"]');
825
+ const showHeader = this.headerText || this.showAll || hasSlottedShowAll;
826
+ let rightPadding = 128;
827
+ if (this.layout === 'hero') {
828
+ rightPadding = S + this.gap;
829
+ }
830
+ else if (this.layout === 'uncontained') {
831
+ rightPadding = 16;
832
+ }
833
+ else {
834
+ rightPadding = M + S + 2 * this.gap;
835
+ }
836
+ // Ensure the scroll track is long enough to allow the last item to scroll to the start (p = 0 focus).
837
+ // Safety margin of 400px avoids fractional rounding/zoom-scale snapping blockages in Firefox.
838
+ const W_c = this._containerWidth || this.getBoundingClientRect().width || 360;
839
+ const minRightPaddingNeeded = W_c - L - this.padding + 400;
840
+ if (rightPadding < minRightPaddingNeeded) {
841
+ rightPadding = minRightPaddingNeeded;
842
+ }
843
+ const trackWidth = hasItems
844
+ ? this.effectiveItems.length * L + (this.effectiveItems.length - 1) * this.gap
845
+ : 0;
846
+ const isScrollable = hasItems && this._scrollContainer &&
847
+ (this._scrollContainer.scrollWidth > this._scrollContainer.clientWidth);
848
+ const showPrevArrow = isScrollable && this._scrollContainer.scrollLeft > 5;
849
+ const showNextArrow = isScrollable &&
850
+ (this._scrollContainer.scrollWidth - this._scrollContainer.scrollLeft - this._scrollContainer.clientWidth > 5);
851
+ return html `
852
+ <div class="carousel-container" style="
853
+ --carousel-snap-width: ${L}px;
854
+ --carousel-gap: ${this.gap}px;
855
+ --carousel-padding: ${this.padding}px;
856
+ --carousel-right-padding: ${rightPadding}px;
857
+ --carousel-border-radius: ${this.borderRadius}px;
858
+ --carousel-track-width: ${trackWidth}px;
859
+ ">
860
+ <slot @slotchange=${this._handleSlotChange} style="display: none;"></slot>
861
+ ${showHeader
862
+ ? html `
863
+ <div class="carousel-header">
864
+ ${this.headerText ? html `<h3>${this.headerText}</h3>` : ''}
865
+ <slot name="show-all" @slotchange=${this._handleShowAllSlotChange} @click=${this._handleShowAllClick}>
866
+ ${this.showAll
867
+ ? html `
868
+ <a href="#" class="show-all-link">
869
+ ${this.showAllText}
870
+ </a>
871
+ `
872
+ : ''}
873
+ </slot>
874
+ </div>
875
+ `
876
+ : ''}
877
+
878
+ <div class="carousel-viewport">
879
+ ${!this.hideNav
880
+ ? html `
881
+ <button
882
+ class="nav-button prev ${showPrevArrow ? 'visible' : ''}"
883
+ @click=${this._scrollPrevious}
884
+ aria-label="Previous items"
885
+ >
886
+ <span class="material-symbols">chevron_left</span>
887
+ </button>
888
+ `
889
+ : ''}
890
+
891
+ <div
892
+ class="scroll-container"
893
+ @scroll=${this._scheduleLayout}
894
+ @mousedown=${this._handleMouseDown}
895
+ @mousemove=${this._handleMouseMove}
896
+ @mouseup=${this._handleMouseUp}
897
+ @mouseleave=${this._handleMouseUp}
898
+ @touchstart=${this._handleTouchStart}
899
+ @touchmove=${this._handleTouchMove}
900
+ @touchend=${this._handleTouchEnd}
901
+ @wheel=${this._handleWheel}
902
+ >
903
+ <div class="snap-track">
904
+ ${hasItems ? this.effectiveItems.map(() => html `<div class="snap-item"></div>`) : ''}
905
+ </div>
906
+ <div class="visual-track">
907
+ ${hasItems
908
+ ? this.effectiveItems.map((item, idx) => html `
909
+ <div
910
+ class="card"
911
+ @click=${(e) => this._handleCardClick(e, item, idx)}
912
+ >
913
+ ${item.href
914
+ ? html `
915
+ <a href="${item.href}" target="${item.target || '_self'}" style="text-decoration:none; color:inherit;">
916
+ <div class="img-parallax-container">
917
+ <img src="${item.img}" alt="${item.title}" draggable="false" />
918
+ </div>
919
+ <h2 class="card-title">${item.title}</h2>
920
+ </a>
921
+ `
922
+ : html `
923
+ <div class="img-parallax-container">
924
+ <img src="${item.img}" alt="${item.title}" draggable="false" />
925
+ </div>
926
+ <h2 class="card-title">${item.title}</h2>
927
+ `}
928
+ </div>
929
+ `)
930
+ : ''}
931
+ </div>
932
+ </div>
933
+
934
+ ${!this.hideNav
935
+ ? html `
936
+ <button
937
+ class="nav-button next ${showNextArrow ? 'visible' : ''}"
938
+ @click=${this._scrollNext}
939
+ aria-label="Next items"
940
+ >
941
+ <span class="material-symbols">chevron_right</span>
942
+ </button>
943
+ `
944
+ : ''}
945
+ </div>
946
+ </div>
947
+ `;
948
+ }
949
+ };
950
+ __decorate([
951
+ property({ type: Array })
952
+ ], MoniCarousel.prototype, "items", void 0);
953
+ __decorate([
954
+ property({ reflect: true })
955
+ ], MoniCarousel.prototype, "layout", void 0);
956
+ __decorate([
957
+ property({ type: Boolean, reflect: true })
958
+ ], MoniCarousel.prototype, "auto", void 0);
959
+ __decorate([
960
+ property({ type: Number, attribute: 'large-width' })
961
+ ], MoniCarousel.prototype, "largeWidth", void 0);
962
+ __decorate([
963
+ property({ type: Number, attribute: 'medium-width' })
964
+ ], MoniCarousel.prototype, "mediumWidth", void 0);
965
+ __decorate([
966
+ property({ type: Number, attribute: 'small-width' })
967
+ ], MoniCarousel.prototype, "smallWidth", void 0);
968
+ __decorate([
969
+ property({ type: Number })
970
+ ], MoniCarousel.prototype, "gap", void 0);
971
+ __decorate([
972
+ property({ type: Number })
973
+ ], MoniCarousel.prototype, "padding", void 0);
974
+ __decorate([
975
+ property({ type: Number, attribute: 'border-radius' })
976
+ ], MoniCarousel.prototype, "borderRadius", void 0);
977
+ __decorate([
978
+ property({ type: Boolean, attribute: 'show-all' })
979
+ ], MoniCarousel.prototype, "showAll", void 0);
980
+ __decorate([
981
+ property({ attribute: 'show-all-text' })
982
+ ], MoniCarousel.prototype, "showAllText", void 0);
983
+ __decorate([
984
+ property({ attribute: 'header-text' })
985
+ ], MoniCarousel.prototype, "headerText", void 0);
986
+ __decorate([
987
+ property({ type: Boolean, attribute: 'hide-nav' })
988
+ ], MoniCarousel.prototype, "hideNav", void 0);
989
+ __decorate([
990
+ state()
991
+ ], MoniCarousel.prototype, "_containerWidth", void 0);
992
+ __decorate([
993
+ state()
994
+ ], MoniCarousel.prototype, "_slottedItems", void 0);
995
+ __decorate([
996
+ state()
997
+ ], MoniCarousel.prototype, "_hasSlottedShowAll", void 0);
998
+ __decorate([
999
+ query('.scroll-container')
1000
+ ], MoniCarousel.prototype, "_scrollContainer", void 0);
1001
+ __decorate([
1002
+ queryAll('.card')
1003
+ ], MoniCarousel.prototype, "_cards", void 0);
1004
+ MoniCarousel = __decorate([
1005
+ customElement('moni-carousel')
1006
+ ], MoniCarousel);
1007
+ export { MoniCarousel };