@wyxos/vibe 2.2.5 → 3.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/README.md +451 -95
  2. package/lib/components/FullscreenHeader.vue.d.ts +25 -0
  3. package/lib/components/FullscreenMediaBar.vue.d.ts +14 -0
  4. package/lib/components/FullscreenSurface.vue.d.ts +46 -0
  5. package/lib/components/Layout.vue.d.ts +42 -0
  6. package/lib/components/ListCard.vue.d.ts +44 -0
  7. package/lib/components/ListSurface.vue.d.ts +64 -0
  8. package/lib/components/viewer-core/assetErrors.d.ts +30 -0
  9. package/lib/components/viewer-core/assetState.d.ts +12 -0
  10. package/lib/components/viewer-core/autoBuckets.d.ts +18 -0
  11. package/lib/components/viewer-core/autoResolveHelpers.d.ts +19 -0
  12. package/lib/components/viewer-core/autoResolveState.d.ts +50 -0
  13. package/lib/components/viewer-core/dom.d.ts +2 -0
  14. package/lib/components/viewer-core/fillDelay.d.ts +9 -0
  15. package/lib/components/viewer-core/format.d.ts +1 -0
  16. package/lib/components/viewer-core/itemIdentity.d.ts +6 -0
  17. package/lib/components/viewer-core/listCardAsset.d.ts +4 -0
  18. package/lib/components/viewer-core/listPreview.d.ts +10 -0
  19. package/lib/components/viewer-core/loadError.d.ts +4 -0
  20. package/lib/components/viewer-core/masonryLayout.d.ts +37 -0
  21. package/lib/components/viewer-core/masonryViewport.d.ts +7 -0
  22. package/lib/components/viewer-core/media.d.ts +4 -0
  23. package/lib/components/viewer-core/mediaPlayback.d.ts +1 -0
  24. package/lib/components/viewer-core/removalState.d.ts +50 -0
  25. package/lib/components/viewer-core/slotContent.d.ts +2 -0
  26. package/lib/components/viewer-core/surfaceSlots.d.ts +22 -0
  27. package/lib/components/viewer-core/theme.d.ts +3 -0
  28. package/lib/components/viewer-core/useActivation.d.ts +8 -0
  29. package/lib/components/viewer-core/useAssetLoadQueue.d.ts +22 -0
  30. package/lib/components/viewer-core/useAutoResolveSource.d.ts +51 -0
  31. package/lib/components/viewer-core/useController.d.ts +71 -0
  32. package/lib/components/viewer-core/useDataSource.d.ts +100 -0
  33. package/lib/components/viewer-core/useEdgeBoundary.d.ts +16 -0
  34. package/lib/components/viewer-core/useFullscreen.d.ts +1 -0
  35. package/lib/components/viewer-core/useMasonryList.d.ts +43 -0
  36. package/lib/components/viewer-core/useMasonryMotion.d.ts +29 -0
  37. package/lib/components/viewer-core/useMedia.d.ts +40 -0
  38. package/lib/components/viewer-core/useViewer.d.ts +61 -0
  39. package/lib/components/viewer-core/virtualization.d.ts +14 -0
  40. package/lib/components/viewer.d.ts +16 -0
  41. package/lib/index.cjs +1 -1
  42. package/lib/index.d.ts +58 -5
  43. package/lib/index.js +3202 -1486
  44. package/lib/style.css +3 -0
  45. package/package.json +86 -83
  46. package/lib/App.vue.d.ts +0 -3
  47. package/lib/apple-touch-icon-114x114.png +0 -0
  48. package/lib/apple-touch-icon-120x120.png +0 -0
  49. package/lib/apple-touch-icon-144x144.png +0 -0
  50. package/lib/apple-touch-icon-152x152.png +0 -0
  51. package/lib/apple-touch-icon-180x180.png +0 -0
  52. package/lib/apple-touch-icon-57x57.png +0 -0
  53. package/lib/apple-touch-icon-60x60.png +0 -0
  54. package/lib/apple-touch-icon-72x72.png +0 -0
  55. package/lib/apple-touch-icon-76x76.png +0 -0
  56. package/lib/components/Masonry.vue.d.ts +0 -68
  57. package/lib/components/MasonryItem.vue.d.ts +0 -3
  58. package/lib/components/MasonryLoader.vue.d.ts +0 -27
  59. package/lib/components/MasonryVideoControls.vue.d.ts +0 -30
  60. package/lib/components/masonryItemRegistry.d.ts +0 -24
  61. package/lib/favicon-128x128.png +0 -0
  62. package/lib/favicon-16x16.png +0 -0
  63. package/lib/favicon-256x256.png +0 -0
  64. package/lib/favicon-32x32.png +0 -0
  65. package/lib/favicon-48x48.png +0 -0
  66. package/lib/favicon-64x64.png +0 -0
  67. package/lib/favicon.ico +0 -0
  68. package/lib/logo-dark.svg +0 -36
  69. package/lib/logo-light.svg +0 -29
  70. package/lib/logo.svg +0 -32
  71. package/lib/manifest.json +0 -41
  72. package/lib/masonry/backfill.d.ts +0 -53
  73. package/lib/masonry/layout.d.ts +0 -13
  74. package/lib/masonry/layoutEngine.d.ts +0 -33
  75. package/lib/masonry/types.d.ts +0 -95
package/lib/style.css ADDED
@@ -0,0 +1,3 @@
1
+ /*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
2
+ @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-amber-100:oklch(96.2% .059 95.617);--color-amber-200:oklch(92.4% .12 95.746);--color-amber-300:oklch(87.9% .169 91.605);--color-amber-400:oklch(82.8% .189 84.429);--color-emerald-300:oklch(84.5% .143 164.978);--color-emerald-500:oklch(69.6% .17 162.48);--color-sky-300:oklch(82.8% .111 230.318);--color-rose-100:oklch(94.1% .03 12.58);--color-rose-300:oklch(81% .117 11.638);--color-rose-400:oklch(71.2% .194 13.428);--color-rose-500:oklch(64.5% .246 16.439);--color-stone-500:oklch(55.3% .013 58.071);--color-stone-900:oklch(21.6% .006 56.043);--color-stone-950:oklch(14.7% .004 49.25);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-3xl:48rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.top-3{top:calc(var(--spacing) * 3)}.top-5{top:calc(var(--spacing) * 5)}.top-6{top:calc(var(--spacing) * 6)}.right-0{right:calc(var(--spacing) * 0)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.right-\[0\.625rem\]{right:.625rem}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-4{bottom:calc(var(--spacing) * 4)}.bottom-6{bottom:calc(var(--spacing) * 6)}.bottom-\[1\.8rem\]{bottom:1.8rem}.bottom-\[5\.8rem\]{bottom:5.8rem}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-3{left:calc(var(--spacing) * 3)}.left-5{left:calc(var(--spacing) * 5)}.left-\[-9999px\]{left:-9999px}.z-10{z-index:10}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[1\]{z-index:1}.z-\[2\]{z-index:2}.z-\[3\]{z-index:3}.z-\[4\]{z-index:4}.z-\[5\]{z-index:5}.z-\[6\]{z-index:6}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.aspect-\[4\/3\]{aspect-ratio:4/3}.aspect-square{aspect-ratio:1}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-\[clamp\(220px\,30vw\,360px\)\]{height:clamp(220px,30vw,360px)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-11{min-height:calc(var(--spacing) * 11)}.min-h-\[4\.25rem\]{min-height:4.25rem}.min-h-\[4\.75rem\]{min-height:4.75rem}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-1{width:calc(var(--spacing) * 1)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-\[clamp\(220px\,30vw\,360px\)\]{width:clamp(220px,30vw,360px)}.w-\[clamp\(320px\,46vw\,560px\)\]{width:clamp(320px,46vw,560px)}.w-auto{width:auto}.w-full{width:100%}.w-px{width:1px}.max-w-3xl{max-width:var(--container-3xl)}.max-w-6xl{max-width:var(--container-6xl)}.max-w-\[22rem\]{max-width:22rem}.max-w-\[24rem\]{max-width:24rem}.max-w-\[1100px\]{max-width:1100px}.max-w-\[1120px\]{max-width:1120px}.max-w-\[1600px\]{max-width:1600px}.max-w-\[calc\(100vw-2\.5rem\)\]{max-width:calc(100vw - 2.5rem)}.max-w-full{max-width:100%}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[4\.25rem\]{min-width:4.25rem}.min-w-full{min-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-0{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-full{--tw-translate-x:100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-3{--tw-translate-y:calc(var(--spacing) * -3);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-0{--tw-translate-y:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-3{--tw-translate-y:calc(var(--spacing) * 3);translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.transform-gpu{transform:translateZ(0) var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.scroll-mt-6{scroll-margin-top:calc(var(--spacing) * 6)}.grid-cols-\[auto_minmax\(0\,1fr\)_auto\]{grid-template-columns:auto minmax(0,1fr) auto}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.content-center{align-content:center}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-items-center{justify-items:center}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-5{column-gap:calc(var(--spacing) * 5)}.gap-y-2{row-gap:calc(var(--spacing) * 2)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.overscroll-y-contain{overscroll-behavior-y:contain}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-amber-300\/26{border-color:#ffd23642}@supports (color:color-mix(in lab, red, red)){.border-amber-300\/26{border-color:color-mix(in oklab, var(--color-amber-300) 26%, transparent)}}.border-amber-300\/28{border-color:#ffd23647}@supports (color:color-mix(in lab, red, red)){.border-amber-300\/28{border-color:color-mix(in oklab, var(--color-amber-300) 28%, transparent)}}.border-amber-300\/35{border-color:#ffd23659}@supports (color:color-mix(in lab, red, red)){.border-amber-300\/35{border-color:color-mix(in oklab, var(--color-amber-300) 35%, transparent)}}.border-amber-400\/45{border-color:#fcbb0073}@supports (color:color-mix(in lab, red, red)){.border-amber-400\/45{border-color:color-mix(in oklab, var(--color-amber-400) 45%, transparent)}}.border-emerald-300\/26{border-color:#5ee9b542}@supports (color:color-mix(in lab, red, red)){.border-emerald-300\/26{border-color:color-mix(in oklab, var(--color-emerald-300) 26%, transparent)}}.border-rose-300\/28{border-color:#ffa2ae47}@supports (color:color-mix(in lab, red, red)){.border-rose-300\/28{border-color:color-mix(in oklab, var(--color-rose-300) 28%, transparent)}}.border-rose-400\/55{border-color:#ff667f8c}@supports (color:color-mix(in lab, red, red)){.border-rose-400\/55{border-color:color-mix(in oklab, var(--color-rose-400) 55%, transparent)}}.border-sky-300\/26{border-color:#77d4ff42}@supports (color:color-mix(in lab, red, red)){.border-sky-300\/26{border-color:color-mix(in oklab, var(--color-sky-300) 26%, transparent)}}.border-stone-900{border-color:var(--color-stone-900)}.border-white\/8{border-color:#ffffff14}@supports (color:color-mix(in lab, red, red)){.border-white\/8{border-color:color-mix(in oklab, var(--color-white) 8%, transparent)}}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.border-white\/10{border-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}.border-white\/12{border-color:#ffffff1f}@supports (color:color-mix(in lab, red, red)){.border-white\/12{border-color:color-mix(in oklab, var(--color-white) 12%, transparent)}}.border-white\/14{border-color:#ffffff24}@supports (color:color-mix(in lab, red, red)){.border-white\/14{border-color:color-mix(in oklab, var(--color-white) 14%, transparent)}}.border-white\/16{border-color:#ffffff29}@supports (color:color-mix(in lab, red, red)){.border-white\/16{border-color:color-mix(in oklab, var(--color-white) 16%, transparent)}}.border-white\/18{border-color:#ffffff2e}@supports (color:color-mix(in lab, red, red)){.border-white\/18{border-color:color-mix(in oklab, var(--color-white) 18%, transparent)}}.border-white\/26{border-color:#ffffff42}@supports (color:color-mix(in lab, red, red)){.border-white\/26{border-color:color-mix(in oklab, var(--color-white) 26%, transparent)}}.border-white\/28{border-color:#ffffff47}@supports (color:color-mix(in lab, red, red)){.border-white\/28{border-color:color-mix(in oklab, var(--color-white) 28%, transparent)}}.border-white\/70{border-color:#ffffffb3}@supports (color:color-mix(in lab, red, red)){.border-white\/70{border-color:color-mix(in oklab, var(--color-white) 70%, transparent)}}.bg-\[\#0a0b0f\]{background-color:#0a0b0f}.bg-\[\#05060a\]{background-color:#05060a}.bg-\[\#06070b\]{background-color:#06070b}.bg-\[\#08090d\]{background-color:#08090d}.bg-\[\#f7f1ea\]{background-color:#f7f1ea}.bg-\[radial-gradient\(circle_at_top_left\,rgba\(245\,158\,11\,0\.24\)\,transparent_28\%\)\,radial-gradient\(circle_at_bottom_right\,rgba\(14\,165\,233\,0\.2\)\,transparent_32\%\)\,\#f6efe6\]{background-color:radial-gradient(circle at top left,#f59e0b3d,transparent 28%),radial-gradient(circle at bottom right,#0ea5e933,transparent 32%),#f6efe6}.bg-amber-300\/\[0\.09\]{background-color:#ffd23617}@supports (color:color-mix(in lab, red, red)){.bg-amber-300\/\[0\.09\]{background-color:color-mix(in oklab, var(--color-amber-300) 9%, transparent)}}.bg-amber-300\/\[0\.045\]{background-color:#ffd2360b}@supports (color:color-mix(in lab, red, red)){.bg-amber-300\/\[0\.045\]{background-color:color-mix(in oklab, var(--color-amber-300) 4.5%, transparent)}}.bg-black\/18{background-color:#0000002e}@supports (color:color-mix(in lab, red, red)){.bg-black\/18{background-color:color-mix(in oklab, var(--color-black) 18%, transparent)}}.bg-black\/20{background-color:#0003}@supports (color:color-mix(in lab, red, red)){.bg-black\/20{background-color:color-mix(in oklab, var(--color-black) 20%, transparent)}}.bg-black\/28{background-color:#00000047}@supports (color:color-mix(in lab, red, red)){.bg-black\/28{background-color:color-mix(in oklab, var(--color-black) 28%, transparent)}}.bg-black\/30{background-color:#0000004d}@supports (color:color-mix(in lab, red, red)){.bg-black\/30{background-color:color-mix(in oklab, var(--color-black) 30%, transparent)}}.bg-black\/34{background-color:#00000057}@supports (color:color-mix(in lab, red, red)){.bg-black\/34{background-color:color-mix(in oklab, var(--color-black) 34%, transparent)}}.bg-black\/35{background-color:#00000059}@supports (color:color-mix(in lab, red, red)){.bg-black\/35{background-color:color-mix(in oklab, var(--color-black) 35%, transparent)}}.bg-black\/36{background-color:#0000005c}@supports (color:color-mix(in lab, red, red)){.bg-black\/36{background-color:color-mix(in oklab, var(--color-black) 36%, transparent)}}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab, var(--color-black) 40%, transparent)}}.bg-black\/45{background-color:#00000073}@supports (color:color-mix(in lab, red, red)){.bg-black\/45{background-color:color-mix(in oklab, var(--color-black) 45%, transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab, red, red)){.bg-black\/50{background-color:color-mix(in oklab, var(--color-black) 50%, transparent)}}.bg-black\/55{background-color:#0000008c}@supports (color:color-mix(in lab, red, red)){.bg-black\/55{background-color:color-mix(in oklab, var(--color-black) 55%, transparent)}}.bg-black\/58{background-color:#00000094}@supports (color:color-mix(in lab, red, red)){.bg-black\/58{background-color:color-mix(in oklab, var(--color-black) 58%, transparent)}}.bg-black\/60{background-color:#0009}@supports (color:color-mix(in lab, red, red)){.bg-black\/60{background-color:color-mix(in oklab, var(--color-black) 60%, transparent)}}.bg-black\/70{background-color:#000000b3}@supports (color:color-mix(in lab, red, red)){.bg-black\/70{background-color:color-mix(in oklab, var(--color-black) 70%, transparent)}}.bg-black\/72{background-color:#000000b8}@supports (color:color-mix(in lab, red, red)){.bg-black\/72{background-color:color-mix(in oklab, var(--color-black) 72%, transparent)}}.bg-black\/82{background-color:#000000d1}@supports (color:color-mix(in lab, red, red)){.bg-black\/82{background-color:color-mix(in oklab, var(--color-black) 82%, transparent)}}.bg-emerald-300\/\[0\.045\]{background-color:#5ee9b50b}@supports (color:color-mix(in lab, red, red)){.bg-emerald-300\/\[0\.045\]{background-color:color-mix(in oklab, var(--color-emerald-300) 4.5%, transparent)}}.bg-emerald-500\/12{background-color:#00bb7f1f}@supports (color:color-mix(in lab, red, red)){.bg-emerald-500\/12{background-color:color-mix(in oklab, var(--color-emerald-500) 12%, transparent)}}.bg-rose-300\/\[0\.1\]{background-color:#ffa2ae1a}@supports (color:color-mix(in lab, red, red)){.bg-rose-300\/\[0\.1\]{background-color:color-mix(in oklab, var(--color-rose-300) 10%, transparent)}}.bg-rose-500\/18{background-color:#ff23572e}@supports (color:color-mix(in lab, red, red)){.bg-rose-500\/18{background-color:color-mix(in oklab, var(--color-rose-500) 18%, transparent)}}.bg-sky-300\/\[0\.045\]{background-color:#77d4ff0b}@supports (color:color-mix(in lab, red, red)){.bg-sky-300\/\[0\.045\]{background-color:color-mix(in oklab, var(--color-sky-300) 4.5%, transparent)}}.bg-stone-900{background-color:var(--color-stone-900)}.bg-transparent{background-color:#0000}.bg-white\/8{background-color:#ffffff14}@supports (color:color-mix(in lab, red, red)){.bg-white\/8{background-color:color-mix(in oklab, var(--color-white) 8%, transparent)}}.bg-white\/12{background-color:#ffffff1f}@supports (color:color-mix(in lab, red, red)){.bg-white\/12{background-color:color-mix(in oklab, var(--color-white) 12%, transparent)}}.bg-white\/34{background-color:#ffffff57}@supports (color:color-mix(in lab, red, red)){.bg-white\/34{background-color:color-mix(in oklab, var(--color-white) 34%, transparent)}}.bg-white\/52{background-color:#ffffff85}@supports (color:color-mix(in lab, red, red)){.bg-white\/52{background-color:color-mix(in oklab, var(--color-white) 52%, transparent)}}.bg-white\/65{background-color:#ffffffa6}@supports (color:color-mix(in lab, red, red)){.bg-white\/65{background-color:color-mix(in oklab, var(--color-white) 65%, transparent)}}.bg-white\/\[0\.03\]{background-color:#ffffff08}@supports (color:color-mix(in lab, red, red)){.bg-white\/\[0\.03\]{background-color:color-mix(in oklab, var(--color-white) 3%, transparent)}}.bg-white\/\[0\.04\]{background-color:#ffffff0a}@supports (color:color-mix(in lab, red, red)){.bg-white\/\[0\.04\]{background-color:color-mix(in oklab, var(--color-white) 4%, transparent)}}.bg-white\/\[0\.06\]{background-color:#ffffff0f}@supports (color:color-mix(in lab, red, red)){.bg-white\/\[0\.06\]{background-color:color-mix(in oklab, var(--color-white) 6%, transparent)}}.bg-\[linear-gradient\(180deg\,rgba\(0\,0\,0\,0\.18\)\,rgba\(255\,255\,255\,0\.02\)\)\]{background-image:linear-gradient(#0000002e,#ffffff05)}.bg-\[linear-gradient\(180deg\,rgba\(6\,7\,10\,0\.96\)\,rgba\(6\,7\,10\,0\.84\)\)\]{background-image:linear-gradient(#06070af5,#06070ad6)}.bg-\[linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.04\)\,rgba\(255\,255\,255\,0\.02\)\)\,radial-gradient\(circle_at_center\,rgba\(16\,185\,129\,0\.14\)\,transparent_58\%\)\]{background-image:linear-gradient(#ffffff0a,#ffffff05),radial-gradient(circle,#10b98124,#0000 58%)}.bg-\[linear-gradient\(180deg\,transparent\,rgba\(0\,0\,0\,0\.42\)_24\%\,rgba\(0\,0\,0\,0\.78\)\)\]{background-image:linear-gradient(#0000,#0000006b 24%,#000000c7)}.bg-\[radial-gradient\(circle\,rgba\(16\,185\,129\,0\.16\)\,transparent_66\%\)\]{background-image:radial-gradient(circle,#10b98129,#0000 66%)}.bg-\[radial-gradient\(circle\,rgba\(239\,68\,68\,0\.12\)\,transparent_66\%\)\]{background-image:radial-gradient(circle,#ef44441f,#0000 66%)}.bg-\[radial-gradient\(circle\,rgba\(255\,255\,255\,0\.08\)\,transparent_62\%\)\]{background-image:radial-gradient(circle,#ffffff14,#0000 62%)}.bg-\[radial-gradient\(circle_at_center\,rgba\(16\,185\,129\,0\.32\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#06120f\,\#040506\)\]{background-image:radial-gradient(circle,#10b98152 0,#0000 42%),linear-gradient(#06120f,#040506)}.bg-\[radial-gradient\(circle_at_center\,rgba\(56\,189\,248\,0\.38\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#07111c\,\#050608\)\]{background-image:radial-gradient(circle,#38bdf861 0,#0000 42%),linear-gradient(#07111c,#050608)}.bg-\[radial-gradient\(circle_at_center\,rgba\(148\,163\,184\,0\.28\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#0d0c10\,\#040506\)\]{background-image:radial-gradient(circle,#94a3b847 0,#0000 42%),linear-gradient(#0d0c10,#040506)}.bg-\[radial-gradient\(circle_at_center\,rgba\(239\,68\,68\,0\.12\)\,transparent_65\%\)\,linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.04\)\,rgba\(255\,255\,255\,0\.02\)\)\]{background-image:radial-gradient(circle,#ef44441f,#0000 65%),linear-gradient(#ffffff0a,#ffffff05)}.bg-\[radial-gradient\(circle_at_center\,rgba\(251\,191\,36\,0\.4\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#120d08\,\#050507\)\]{background-image:radial-gradient(circle,#fbbf2466 0,#0000 42%),linear-gradient(#120d08,#050507)}.bg-\[radial-gradient\(circle_at_center\,rgba\(255\,255\,255\,0\.08\)\,transparent_65\%\)\,linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.04\)\,rgba\(255\,255\,255\,0\.02\)\)\]{background-image:radial-gradient(circle,#ffffff14,#0000 65%),linear-gradient(#ffffff0a,#ffffff05)}.bg-\[radial-gradient\(circle_at_top_center\,rgba\(16\,185\,129\,0\.32\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#06120f\,\#040506\)\]{background-image:radial-gradient(circle at top,#10b98152 0,#0000 42%),linear-gradient(#06120f,#040506)}.bg-\[radial-gradient\(circle_at_top_center\,rgba\(56\,189\,248\,0\.38\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#07111c\,\#050608\)\]{background-image:radial-gradient(circle at top,#38bdf861 0,#0000 42%),linear-gradient(#07111c,#050608)}.bg-\[radial-gradient\(circle_at_top_center\,rgba\(148\,163\,184\,0\.28\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#0d0c10\,\#040506\)\]{background-image:radial-gradient(circle at top,#94a3b847 0,#0000 42%),linear-gradient(#0d0c10,#040506)}.bg-\[radial-gradient\(circle_at_top_center\,rgba\(251\,191\,36\,0\.4\)_0\,transparent_42\%\)\,linear-gradient\(180deg\,\#120d08\,\#050507\)\]{background-image:radial-gradient(circle at top,#fbbf2466 0,#0000 42%),linear-gradient(#120d08,#050507)}.bg-\[radial-gradient\(circle_at_top_center\,rgba\(255\,255\,255\,0\.04\)\,transparent_28\%\)\,linear-gradient\(180deg\,\#06070b\,\#05060a\)\]{background-image:radial-gradient(circle at top,#ffffff0a,#0000 28%),linear-gradient(#06070b,#05060a)}.stroke-2{stroke-width:2px}.stroke-\[1\.8\]{stroke-width:1.8px}.stroke-\[1\.9\]{stroke-width:1.9px}.stroke-\[2\.1\]{stroke-width:2.1px}.stroke-\[2\.2\]{stroke-width:2.2px}.stroke-\[2\]{stroke-width:2px}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-\[clamp\(1\.25rem\,2\.6vw\,2\.25rem\)\]{padding:clamp(1.25rem,2.6vw,2.25rem)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.px-\[clamp\(1rem\,2\.6vw\,2\.25rem\)\]{padding-inline:clamp(1rem,2.6vw,2.25rem)}.px-\[clamp\(2rem\,4vw\,3rem\)\]{padding-inline:clamp(2rem,4vw,3rem)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-7{padding-block:calc(var(--spacing) * 7)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-\[clamp\(2rem\,4vw\,3rem\)\]{padding-block:clamp(2rem,4vw,3rem)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.pb-24{padding-bottom:calc(var(--spacing) * 24)}.pb-\[1\.15rem\]{padding-bottom:1.15rem}.pb-\[5\.75rem\]{padding-bottom:5.75rem}.pl-2{padding-left:calc(var(--spacing) * 2)}.text-center{text-align:center}.text-left{text-align:left}.\[font-family\:\'Segoe_UI_Variable\'\,\'Segoe_UI\'\,sans-serif\]{font-family:Segoe UI Variable,Segoe UI,sans-serif}.font-mono{font-family:var(--font-mono)}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.6rem\]{font-size:.6rem}.text-\[0\.7rem\]{font-size:.7rem}.text-\[0\.8rem\]{font-size:.8rem}.text-\[0\.9rem\]{font-size:.9rem}.text-\[0\.62rem\]{font-size:.62rem}.text-\[0\.63rem\]{font-size:.63rem}.text-\[0\.64rem\]{font-size:.64rem}.text-\[0\.66rem\]{font-size:.66rem}.text-\[0\.68rem\]{font-size:.68rem}.text-\[0\.72rem\]{font-size:.72rem}.text-\[0\.74rem\]{font-size:.74rem}.text-\[0\.75rem\]{font-size:.75rem}.text-\[0\.76rem\]{font-size:.76rem}.text-\[0\.78rem\]{font-size:.78rem}.text-\[0\.82rem\]{font-size:.82rem}.text-\[0\.88rem\]{font-size:.88rem}.text-\[0\.95rem\]{font-size:.95rem}.text-\[1\.8rem\]{font-size:1.8rem}.text-\[1\.35rem\]{font-size:1.35rem}.text-\[clamp\(0\.98rem\,1\.3vw\,1\.12rem\)\]{font-size:clamp(.98rem,1.3vw,1.12rem)}.text-\[clamp\(2rem\,4\.4vw\,3\.6rem\)\]{font-size:clamp(2rem,4.4vw,3.6rem)}.text-\[clamp\(2rem\,4vw\,3\.35rem\)\]{font-size:clamp(2rem,4vw,3.35rem)}.leading-6{--tw-leading:calc(var(--spacing) * 6);line-height:calc(var(--spacing) * 6)}.leading-7{--tw-leading:calc(var(--spacing) * 7);line-height:calc(var(--spacing) * 7)}.leading-\[0\.94\]{--tw-leading:.94;line-height:.94}.leading-\[0\.95\]{--tw-leading:.95;line-height:.95}.leading-\[1\.8\]{--tw-leading:1.8;line-height:1.8}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.03em\]{--tw-tracking:-.03em;letter-spacing:-.03em}.tracking-\[-0\.04em\]{--tw-tracking:-.04em;letter-spacing:-.04em}.tracking-\[-0\.05em\]{--tw-tracking:-.05em;letter-spacing:-.05em}.tracking-\[0\.2em\]{--tw-tracking:.2em;letter-spacing:.2em}.tracking-\[0\.12em\]{--tw-tracking:.12em;letter-spacing:.12em}.tracking-\[0\.18em\]{--tw-tracking:.18em;letter-spacing:.18em}.tracking-\[0\.22em\]{--tw-tracking:.22em;letter-spacing:.22em}.tracking-\[0\.24em\]{--tw-tracking:.24em;letter-spacing:.24em}.tracking-\[0\.28em\]{--tw-tracking:.28em;letter-spacing:.28em}.tracking-\[0\.32em\]{--tw-tracking:.32em;letter-spacing:.32em}.tracking-\[0\.38em\]{--tw-tracking:.38em;letter-spacing:.38em}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.text-\[\#78dce8\]{color:#78dce8}.text-\[\#72798a\]{color:#72798a}.text-\[\#a9dc76\]{color:#a9dc76}.text-\[\#ab9df2\]{color:#ab9df2}.text-\[\#f7f1ea\]{color:#f7f1ea}.text-\[\#f7f1ea\]\/34{color:oklab(96.0873% .0035257 .0107867/.34)}.text-\[\#f7f1ea\]\/36{color:oklab(96.0873% .0035257 .0107867/.36)}.text-\[\#f7f1ea\]\/38{color:oklab(96.0873% .0035257 .0107867/.38)}.text-\[\#f7f1ea\]\/42{color:oklab(96.0873% .0035257 .0107867/.42)}.text-\[\#f7f1ea\]\/44{color:oklab(96.0873% .0035257 .0107867/.44)}.text-\[\#f7f1ea\]\/46{color:oklab(96.0873% .0035257 .0107867/.46)}.text-\[\#f7f1ea\]\/48{color:oklab(96.0873% .0035257 .0107867/.48)}.text-\[\#f7f1ea\]\/54{color:oklab(96.0873% .0035257 .0107867/.54)}.text-\[\#f7f1ea\]\/56{color:oklab(96.0873% .0035257 .0107867/.56)}.text-\[\#f7f1ea\]\/62{color:oklab(96.0873% .0035257 .0107867/.62)}.text-\[\#f7f1ea\]\/64{color:oklab(96.0873% .0035257 .0107867/.64)}.text-\[\#f7f1ea\]\/66{color:oklab(96.0873% .0035257 .0107867/.66)}.text-\[\#f7f1ea\]\/68{color:oklab(96.0873% .0035257 .0107867/.68)}.text-\[\#f7f1ea\]\/70{color:oklab(96.0873% .0035257 .0107867/.7)}.text-\[\#f7f1ea\]\/72{color:oklab(96.0873% .0035257 .0107867/.72)}.text-\[\#f7f1ea\]\/74{color:oklab(96.0873% .0035257 .0107867/.74)}.text-\[\#f7f1ea\]\/76{color:oklab(96.0873% .0035257 .0107867/.76)}.text-\[\#f7f1ea\]\/78{color:oklab(96.0873% .0035257 .0107867/.78)}.text-\[\#f7f1ea\]\/82{color:oklab(96.0873% .0035257 .0107867/.82)}.text-\[\#f7f1ea\]\/86{color:oklab(96.0873% .0035257 .0107867/.86)}.text-\[\#fc9867\]{color:#fc9867}.text-\[\#ff7ab8\]{color:#ff7ab8}.text-\[\#ff6188\]{color:#ff6188}.text-\[\#ffd866\]{color:#ffd866}.text-amber-100{color:var(--color-amber-100)}.text-amber-200{color:var(--color-amber-200)}.text-rose-100{color:var(--color-rose-100)}.text-stone-500{color:var(--color-stone-500)}.text-stone-950{color:var(--color-stone-950)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.opacity-0{opacity:0}.opacity-85{opacity:.85}.opacity-100{opacity:1}.shadow-\[-28px_0_80px_-48px_rgba\(0\,0\,0\,0\.92\)\]{--tw-shadow:-28px 0 80px -48px var(--tw-shadow-color,#000000eb);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_18px_40px_-18px_rgba\(0\,0\,0\,0\.85\)\]{--tw-shadow:0 18px 40px -18px var(--tw-shadow-color,#000000d9);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_20px_60px_-48px_rgba\(0\,0\,0\,0\.9\)\]{--tw-shadow:0 20px 60px -48px var(--tw-shadow-color,#000000e6);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_24px_60px_-42px_rgba\(0\,0\,0\,0\.88\)\]{--tw-shadow:0 24px 60px -42px var(--tw-shadow-color,#000000e0);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_28px_80px_-50px_rgba\(0\,0\,0\,0\.88\)\]{--tw-shadow:0 28px 80px -50px var(--tw-shadow-color,#000000e0);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_30px_90px_-48px_rgba\(31\,26\,22\,0\.45\)\]{--tw-shadow:0 30px 90px -48px var(--tw-shadow-color,#1f1a1673);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_40px_120px_-60px_rgba\(0\,0\,0\,0\.9\)\]{--tw-shadow:0 40px 120px -60px var(--tw-shadow-color,#000000e6);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-\[14px\]{--tw-backdrop-blur:blur(14px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-\[18px\]{--tw-backdrop-blur:blur(18px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-\[20px\]{--tw-backdrop-blur:blur(20px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[background\]{transition-property:background;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[border-color\,background\]{transition-property:border-color,background;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[border-color\,transform\]{transition-property:border-color,transform;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[height\,transform\,background-color\,opacity\]{transition-property:height,transform,background-color,opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[opacity\,transform\]{transition-property:opacity,transform;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-260{--tw-duration:.26s;transition-duration:.26s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-320{--tw-duration:.32s;transition-duration:.32s}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.will-change-transform{will-change:transform}.\[-ms-overflow-style\:none\]{-ms-overflow-style:none}.\[overflow-anchor\:none\]{overflow-anchor:none}.\[scrollbar-width\:none\]{scrollbar-width:none}.last\:border-b-0:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}.last\:pb-0:last-child{padding-bottom:calc(var(--spacing) * 0)}@media (hover:hover){.hover\:border-white\/18:hover{border-color:#ffffff2e}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/18:hover{border-color:color-mix(in oklab, var(--color-white) 18%, transparent)}}.hover\:border-white\/22:hover{border-color:#ffffff38}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/22:hover{border-color:color-mix(in oklab, var(--color-white) 22%, transparent)}}.hover\:border-white\/24:hover{border-color:#ffffff3d}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/24:hover{border-color:color-mix(in oklab, var(--color-white) 24%, transparent)}}.hover\:border-white\/28:hover{border-color:#ffffff47}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/28:hover{border-color:color-mix(in oklab, var(--color-white) 28%, transparent)}}.hover\:border-white\/30:hover{border-color:#ffffff4d}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/30:hover{border-color:color-mix(in oklab, var(--color-white) 30%, transparent)}}.hover\:bg-amber-300\/\[0\.14\]:hover{background-color:#ffd23624}@supports (color:color-mix(in lab, red, red)){.hover\:bg-amber-300\/\[0\.14\]:hover{background-color:color-mix(in oklab, var(--color-amber-300) 14.0%, transparent)}}.hover\:bg-black\/35:hover{background-color:#00000059}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/35:hover{background-color:color-mix(in oklab, var(--color-black) 35%, transparent)}}.hover\:bg-black\/45:hover{background-color:#00000073}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/45:hover{background-color:color-mix(in oklab, var(--color-black) 45%, transparent)}}.hover\:bg-black\/48:hover{background-color:#0000007a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/48:hover{background-color:color-mix(in oklab, var(--color-black) 48%, transparent)}}.hover\:bg-black\/50:hover{background-color:#00000080}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/50:hover{background-color:color-mix(in oklab, var(--color-black) 50%, transparent)}}.hover\:bg-black\/55:hover{background-color:#0000008c}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/55:hover{background-color:color-mix(in oklab, var(--color-black) 55%, transparent)}}.hover\:bg-rose-500\/28:hover{background-color:#ff235747}@supports (color:color-mix(in lab, red, red)){.hover\:bg-rose-500\/28:hover{background-color:color-mix(in oklab, var(--color-rose-500) 28%, transparent)}}.hover\:bg-white\/12:hover{background-color:#ffffff1f}@supports (color:color-mix(in lab, red, red)){.hover\:bg-white\/12:hover{background-color:color-mix(in oklab, var(--color-white) 12%, transparent)}}.hover\:bg-white\/\[0\.08\]:hover{background-color:#ffffff14}@supports (color:color-mix(in lab, red, red)){.hover\:bg-white\/\[0\.08\]:hover{background-color:color-mix(in oklab, var(--color-white) 8%, transparent)}}.hover\:bg-\[linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.07\)\,rgba\(255\,255\,255\,0\.03\)\)\,radial-gradient\(circle_at_center\,rgba\(16\,185\,129\,0\.18\)\,transparent_58\%\)\]:hover{background-image:linear-gradient(#ffffff12,#ffffff08),radial-gradient(circle,#10b9812e,#0000 58%)}.hover\:text-\[\#f7f1ea\]:hover{color:#f7f1ea}.hover\:text-white:hover{color:var(--color-white)}}.focus-visible\:outline:focus-visible{outline-style:var(--tw-outline-style);outline-width:1px}.focus-visible\:outline-2:focus-visible{outline-style:var(--tw-outline-style);outline-width:2px}.focus-visible\:outline-offset-4:focus-visible{outline-offset:4px}.focus-visible\:outline-\[\#f7f1ea\]:focus-visible{outline-color:#f7f1ea}.disabled\:cursor-default:disabled{cursor:default}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}@media not all and (width>=720px){.max-\[720px\]\:bottom-\[1\.3rem\]{bottom:1.3rem}.max-\[720px\]\:bottom-\[7\.4rem\]{bottom:7.4rem}.max-\[720px\]\:w-\[calc\(100\%-2\.5rem\)\]{width:calc(100% - 2.5rem)}.max-\[720px\]\:justify-center{justify-content:center}.max-\[720px\]\:justify-items-start{justify-items:start}.max-\[720px\]\:pb-\[7rem\]{padding-bottom:7rem}}@media (width>=721px){.min-\[721px\]\:gap-3{gap:calc(var(--spacing) * 3)}.min-\[721px\]\:px-4{padding-inline:calc(var(--spacing) * 4)}.min-\[721px\]\:py-3{padding-block:calc(var(--spacing) * 3)}.min-\[721px\]\:pl-3{padding-left:calc(var(--spacing) * 3)}.min-\[721px\]\:text-\[0\.74rem\]{font-size:.74rem}.min-\[721px\]\:text-\[1\.2rem\]{font-size:1.2rem}.min-\[721px\]\:tracking-\[0\.2em\]{--tw-tracking:.2em;letter-spacing:.2em}}@media (width>=1024px){.min-\[1024px\]\:block{display:block}}@media (width>=40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-\[auto_auto\]{grid-template-columns:auto auto}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:px-5{padding-inline:calc(var(--spacing) * 5)}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}.sm\:px-8{padding-inline:calc(var(--spacing) * 8)}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-\[0\.98rem\]{font-size:.98rem}.sm\:text-\[1\.55rem\]{font-size:1.55rem}}@media (width>=48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=64rem){.lg\:sticky{position:sticky}.lg\:top-0{top:calc(var(--spacing) * 0)}.lg\:grid-cols-\[17rem_minmax\(0\,1fr\)\]{grid-template-columns:17rem minmax(0,1fr)}.lg\:grid-cols-\[240px_minmax\(0\,1fr\)\]{grid-template-columns:240px minmax(0,1fr)}.lg\:items-start{align-items:flex-start}.lg\:gap-8{gap:calc(var(--spacing) * 8)}.lg\:self-start{align-self:flex-start}.lg\:px-8{padding-inline:calc(var(--spacing) * 8)}.lg\:px-12{padding-inline:calc(var(--spacing) * 12)}}@media (width>=80rem){.xl\:sticky{position:sticky}.xl\:top-5{top:calc(var(--spacing) * 5)}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.xl\:grid-cols-\[minmax\(0\,1\.3fr\)_minmax\(320px\,0\.82fr\)\]{grid-template-columns:minmax(0,1.3fr) minmax(320px,.82fr)}.xl\:grid-cols-\[minmax\(0\,1fr\)_auto\]{grid-template-columns:minmax(0,1fr) auto}.xl\:items-end{align-items:flex-end}.xl\:justify-items-end{justify-items:end}.xl\:self-start{align-self:flex-start}}.\[\&\:\:-webkit-scrollbar\]\:hidden::-webkit-scrollbar{display:none}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@keyframes spin{to{transform:rotate(360deg)}}.vibe-media-slider{appearance:none}.vibe-media-slider::-webkit-slider-runnable-track{background:0 0;height:1rem}.vibe-media-slider::-webkit-slider-thumb{appearance:none;background:#f7f1ea;border:1px solid #f7f1ea33;border-radius:9999px;width:.875rem;height:.875rem;margin-top:1px}.vibe-media-slider::-moz-range-track{background:0 0;height:1rem}.vibe-media-slider::-moz-range-thumb{background:#f7f1ea;border:1px solid #f7f1ea33;border-radius:9999px;width:.875rem;height:.875rem}
3
+ /*$vite$:1*/
package/package.json CHANGED
@@ -1,83 +1,86 @@
1
- {
2
- "name": "@wyxos/vibe",
3
- "version": "2.2.5",
4
- "description": "A high-performance, responsive masonry layout engine for Vue 3 with built-in infinite scrolling and virtualization.",
5
- "keywords": [
6
- "vue",
7
- "vue3",
8
- "masonry",
9
- "grid",
10
- "layout",
11
- "infinite-scroll",
12
- "virtualization",
13
- "responsive",
14
- "performance"
15
- ],
16
- "license": "MIT",
17
- "repository": {
18
- "type": "git",
19
- "url": "https://github.com/wyxos/vibe.git"
20
- },
21
- "homepage": "https://vibe.wyxos.com/",
22
- "bugs": {
23
- "url": "https://github.com/wyxos/vibe/issues"
24
- },
25
- "type": "module",
26
- "main": "./lib/index.cjs",
27
- "module": "./lib/index.js",
28
- "types": "./lib/index.d.ts",
29
- "exports": {
30
- ".": {
31
- "types": "./lib/index.d.ts",
32
- "import": "./lib/index.js",
33
- "require": "./lib/index.cjs"
34
- },
35
- "./package.json": "./package.json"
36
- },
37
- "files": [
38
- "lib"
39
- ],
40
- "scripts": {
41
- "dev": "vite",
42
- "build": "vite build && node write-cname.js",
43
- "build:lib": "vite build -c vite.config.lib.js && npm run build:types",
44
- "build:types": "vue-tsc -p tsconfig.lib.json",
45
- "prepublishOnly": "npm run check && npm run build:lib && npm run build:types",
46
- "preview": "vite preview",
47
- "check": "npm run lint && npm run typecheck && npm run test && npm run test:e2e",
48
- "lint": "eslint . --max-warnings 0",
49
- "lint:fix": "eslint . --fix",
50
- "release": "npx @wyxos/zephyr --type=node",
51
- "test": "vitest run --reporter=dot",
52
- "test:unit": "vitest run",
53
- "test:watch": "vitest",
54
- "test:e2e": "playwright test",
55
- "typecheck": "vue-tsc --noEmit --pretty false"
56
- },
57
- "peerDependencies": {
58
- "vue": "^3.0.0"
59
- },
60
- "devDependencies": {
61
- "@fortawesome/fontawesome-free": "^7.1.0",
62
- "@playwright/test": "^1.50.0",
63
- "@tailwindcss/vite": "^4.1.18",
64
- "@eslint/js": "^9.37.0",
65
- "@types/node": "^25.0.3",
66
- "@typescript-eslint/eslint-plugin": "^8.33.0",
67
- "@typescript-eslint/parser": "^8.33.0",
68
- "@vitejs/plugin-vue": "^6.0.3",
69
- "@vue/test-utils": "^2.4.6",
70
- "eslint": "^9.37.0",
71
- "eslint-plugin-vue": "^10.5.1",
72
- "globals": "^16.4.0",
73
- "jsdom": "^26.0.0",
74
- "tailwindcss": "^4.1.18",
75
- "typescript": "^5.9.3",
76
- "vite": "7.1.11",
77
- "vitest": "^2.1.8",
78
- "vue": "^3.5.13",
79
- "vue-router": "^4.6.4",
80
- "vue-eslint-parser": "^10.0.0",
81
- "vue-tsc": "^3.2.1"
82
- }
83
- }
1
+ {
2
+ "name": "@wyxos/vibe",
3
+ "version": "3.0.1",
4
+ "description": "A Vue 3 media viewer for large feeds of image, video, audio, and mixed-content items.",
5
+ "keywords": [
6
+ "vue",
7
+ "vite",
8
+ "typescript",
9
+ "tailwindcss",
10
+ "component-library"
11
+ ],
12
+ "license": "MIT",
13
+ "repository": {
14
+ "type": "git",
15
+ "url": "https://github.com/wyxos/vibe.git"
16
+ },
17
+ "homepage": "https://vibe.wyxos.com/",
18
+ "bugs": {
19
+ "url": "https://github.com/wyxos/vibe/issues"
20
+ },
21
+ "type": "module",
22
+ "main": "./lib/index.cjs",
23
+ "module": "./lib/index.js",
24
+ "style": "./lib/style.css",
25
+ "types": "./lib/index.d.ts",
26
+ "exports": {
27
+ ".": {
28
+ "types": "./lib/index.d.ts",
29
+ "import": "./lib/index.js",
30
+ "require": "./lib/index.cjs"
31
+ },
32
+ "./style.css": "./lib/style.css",
33
+ "./package.json": "./package.json"
34
+ },
35
+ "files": [
36
+ "lib"
37
+ ],
38
+ "scripts": {
39
+ "dev": "vite",
40
+ "build": "vite build && node scripts/write-cname.mjs",
41
+ "build:lib": "vite build --config vite.config.lib.ts && npm run build:types",
42
+ "build:types": "vue-tsc -p tsconfig.lib.json",
43
+ "check:package": "node scripts/check-package-shape.mjs",
44
+ "prepublishOnly": "npm run check && npm run test:unit && npm run build:lib && npm run test:e2e && npm run check:package",
45
+ "preview": "vite preview",
46
+ "release": "npx @wyxos/zephyr --type=node",
47
+ "test:e2e": "playwright test",
48
+ "test:e2e:headed": "playwright test --headed",
49
+ "test:e2e:install": "playwright install chromium",
50
+ "test:e2e:ui": "playwright test --ui",
51
+ "test:unit": "vitest run",
52
+ "test:unit:watch": "vitest",
53
+ "check": "npm run lint && npm run typecheck",
54
+ "lint": "eslint . --max-warnings 0",
55
+ "lint:fix": "eslint . --fix",
56
+ "typecheck": "vue-tsc --noEmit --pretty false"
57
+ },
58
+ "peerDependencies": {
59
+ "vue": "^3.5.0"
60
+ },
61
+ "devDependencies": {
62
+ "@playwright/test": "^1.59.1",
63
+ "@eslint/js": "^9.37.0",
64
+ "@tailwindcss/vite": "^4.1.18",
65
+ "@types/node": "^24.12.0",
66
+ "@typescript-eslint/eslint-plugin": "^8.33.0",
67
+ "@typescript-eslint/parser": "^8.33.0",
68
+ "@vitejs/plugin-vue": "^6.0.5",
69
+ "@vue/test-utils": "^2.4.6",
70
+ "eslint": "^9.37.0",
71
+ "eslint-plugin-vue": "^10.5.1",
72
+ "globals": "^16.4.0",
73
+ "jsdom": "^29.0.1",
74
+ "tailwindcss": "^4.1.18",
75
+ "typescript": "~5.9.3",
76
+ "vite": "^8.0.1",
77
+ "vitest": "^4.1.2",
78
+ "vue": "^3.5.30",
79
+ "vue-eslint-parser": "^10.0.0",
80
+ "vue-router": "^4.6.3",
81
+ "vue-tsc": "^3.2.5"
82
+ },
83
+ "dependencies": {
84
+ "lucide-vue-next": "^1.0.0"
85
+ }
86
+ }
package/lib/App.vue.d.ts DELETED
@@ -1,3 +0,0 @@
1
- declare const __VLS_export: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
2
- declare const _default: typeof __VLS_export;
3
- export default _default;
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
@@ -1,68 +0,0 @@
1
- import { type BackfillStats, type MasonryItemBase, type MasonryProps, type PageToken } from '@/masonry/types';
2
- export type { BackfillStats, GetContentFn, GetContentResult, MasonryItemBase, MasonryMode, MasonryRestoredPages, PageToken, } from '@/masonry/types';
3
- declare function restore(itemsOrIds: string | MasonryItemBase | Array<string | MasonryItemBase>): Promise<void>;
4
- declare function undo(): Promise<void>;
5
- declare function forget(itemsOrIds: string | MasonryItemBase | Array<string | MasonryItemBase>): void;
6
- declare function remove(itemsOrIds: string | MasonryItemBase | Array<string | MasonryItemBase>): Promise<void>;
7
- declare function cancel(): void;
8
- declare function loadNextPage(): Promise<void>;
9
- declare var __VLS_1: {};
10
- type __VLS_Slots = {} & {
11
- default?: (props: typeof __VLS_1) => any;
12
- };
13
- declare const __VLS_base: import("vue").DefineComponent<MasonryProps, {
14
- remove: typeof remove;
15
- restore: typeof restore;
16
- undo: typeof undo;
17
- forget: typeof forget;
18
- loadNextPage: typeof loadNextPage;
19
- cancel: typeof cancel;
20
- pagesLoaded: PageToken[];
21
- nextPage: PageToken | null;
22
- readonly isLoading: boolean;
23
- readonly hasReachedEnd: boolean;
24
- readonly backfillStats: BackfillStats;
25
- }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
26
- "update:items": (items: MasonryItemBase[]) => any;
27
- preloaded: (items: MasonryItemBase[]) => any;
28
- failures: (payloads: {
29
- item: MasonryItemBase;
30
- error: unknown;
31
- }[]) => any;
32
- removed: (payload: {
33
- items: MasonryItemBase[];
34
- ids: string[];
35
- }) => any;
36
- }, string, import("vue").PublicProps, Readonly<MasonryProps> & Readonly<{
37
- "onUpdate:items"?: ((items: MasonryItemBase[]) => any) | undefined;
38
- onPreloaded?: ((items: MasonryItemBase[]) => any) | undefined;
39
- onFailures?: ((payloads: {
40
- item: MasonryItemBase;
41
- error: unknown;
42
- }[]) => any) | undefined;
43
- onRemoved?: ((payload: {
44
- items: MasonryItemBase[];
45
- ids: string[];
46
- }) => any) | undefined;
47
- }>, {
48
- mode: import("@/masonry/types").MasonryMode;
49
- pageSize: number;
50
- backfillRequestDelayMs: number;
51
- enterStaggerMs: number;
52
- page: PageToken;
53
- itemWidth: number;
54
- prefetchThresholdPx: number;
55
- gapX: number;
56
- gapY: number;
57
- headerHeight: number;
58
- footerHeight: number;
59
- overscanPx: number;
60
- }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
61
- declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
62
- declare const _default: typeof __VLS_export;
63
- export default _default;
64
- type __VLS_WithSlots<T, S> = T & {
65
- new (): {
66
- $slots: S;
67
- };
68
- };
@@ -1,3 +0,0 @@
1
- declare const _default: typeof __VLS_export;
2
- export default _default;
3
- declare const __VLS_export: import("vue").DefineComponent<{}, () => null, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
@@ -1,27 +0,0 @@
1
- import type { MasonryItemBase } from '@/masonry/types';
2
- import type { MasonryItemErrorSlotProps, MasonryItemLoaderSlotProps } from '@/components/masonryItemRegistry';
3
- import type { Slot } from 'vue';
4
- type Props = {
5
- item: MasonryItemBase;
6
- remove?: () => void;
7
- loaderSlotFn?: Slot<MasonryItemLoaderSlotProps>;
8
- errorSlotFn?: Slot<MasonryItemErrorSlotProps>;
9
- hovered?: boolean;
10
- };
11
- declare const __VLS_export: import("vue").DefineComponent<Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
12
- success: (item: MasonryItemBase) => any;
13
- error: (payload: {
14
- item: MasonryItemBase;
15
- error: unknown;
16
- }) => any;
17
- }, string, import("vue").PublicProps, Readonly<Props> & Readonly<{
18
- onSuccess?: ((item: MasonryItemBase) => any) | undefined;
19
- onError?: ((payload: {
20
- item: MasonryItemBase;
21
- error: unknown;
22
- }) => any) | undefined;
23
- }>, {
24
- hovered: boolean;
25
- }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
26
- declare const _default: typeof __VLS_export;
27
- export default _default;
@@ -1,30 +0,0 @@
1
- type Props = {
2
- currentTime: number;
3
- duration: number;
4
- ariaLabel?: string;
5
- step?: number;
6
- keyboardStep?: number;
7
- };
8
- declare function seekTo(next: number): void;
9
- declare function focus(): void;
10
- declare const __VLS_export: import("vue").DefineComponent<Props, {
11
- focus: typeof focus;
12
- seekTo: typeof seekTo;
13
- percent: import("vue").ComputedRef<number>;
14
- currentValue: import("vue").ComputedRef<number>;
15
- maxValue: import("vue").ComputedRef<number>;
16
- isDragging: import("vue").Ref<boolean, boolean>;
17
- rootEl: import("vue").Ref<HTMLElement | null, HTMLElement | null>;
18
- trackEl: import("vue").Ref<HTMLElement | null, HTMLElement | null>;
19
- thumbEl: import("vue").Ref<HTMLElement | null, HTMLElement | null>;
20
- }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
21
- seek: (time: number) => any;
22
- }, string, import("vue").PublicProps, Readonly<Props> & Readonly<{
23
- onSeek?: ((time: number) => any) | undefined;
24
- }>, {
25
- ariaLabel: string;
26
- step: number;
27
- keyboardStep: number;
28
- }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
29
- declare const _default: typeof __VLS_export;
30
- export default _default;
@@ -1,24 +0,0 @@
1
- import type { InjectionKey, Slot } from 'vue';
2
- import type { MasonryItemBase } from '@/masonry/types';
3
- export type MasonryItemSlotProps = {
4
- item: MasonryItemBase;
5
- remove: () => void;
6
- };
7
- export type MasonryItemLoaderSlotProps = MasonryItemSlotProps;
8
- export type MasonryItemErrorSlotProps = MasonryItemSlotProps & {
9
- error: unknown;
10
- };
11
- export type MasonryItemDefinition = {
12
- header?: Slot<MasonryItemSlotProps>;
13
- loader?: Slot<MasonryItemLoaderSlotProps>;
14
- overlay?: Slot<MasonryItemSlotProps>;
15
- error?: Slot<MasonryItemErrorSlotProps>;
16
- footer?: Slot<MasonryItemSlotProps>;
17
- onPreloaded?: (item: MasonryItemBase) => void;
18
- onFailed?: (payload: {
19
- item: MasonryItemBase;
20
- error: unknown;
21
- }) => void;
22
- };
23
- export type RegisterMasonryItem = (definition: MasonryItemDefinition) => void;
24
- export declare const masonryItemRegistryKey: InjectionKey<RegisterMasonryItem>;
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
package/lib/favicon.ico DELETED
Binary file
package/lib/logo-dark.svg DELETED
@@ -1,36 +0,0 @@
1
- <svg width="120" height="120" viewBox="0 0 120 120" fill="none" xmlns="http://www.w3.org/2000/svg">
2
- <defs>
3
- <linearGradient id="vibeGrad" x1="0%" y1="0%" x2="100%" y2="100%">
4
- <stop offset="0%" style="stop-color:#3b82f6;stop-opacity:1" />
5
- <stop offset="100%" style="stop-color:#06b6d4;stop-opacity:1" />
6
- </linearGradient>
7
- <linearGradient id="vibeGradLight" x1="0%" y1="0%" x2="100%" y2="100%">
8
- <stop offset="0%" style="stop-color:#60a5fa;stop-opacity:1" />
9
- <stop offset="100%" style="stop-color:#22d3ee;stop-opacity:1" />
10
- </linearGradient>
11
- </defs>
12
-
13
- <!-- Background -->
14
- <rect width="120" height="120" rx="24" fill="url(#vibeGrad)"/>
15
-
16
- <!-- Masonry blocks - representing the infinite block engine -->
17
- <!-- Left column -->
18
- <rect x="18" y="20" width="24" height="32" rx="5" fill="white" opacity="0.95"/>
19
- <rect x="18" y="58" width="24" height="20" rx="5" fill="white" opacity="0.85"/>
20
- <rect x="18" y="84" width="24" height="16" rx="5" fill="white" opacity="0.9"/>
21
-
22
- <!-- Middle column -->
23
- <rect x="48" y="28" width="24" height="22" rx="5" fill="white" opacity="0.9"/>
24
- <rect x="48" y="56" width="24" height="36" rx="5" fill="white" opacity="0.95"/>
25
- <rect x="48" y="98" width="24" height="14" rx="5" fill="white" opacity="0.8"/>
26
-
27
- <!-- Right column -->
28
- <rect x="78" y="22" width="24" height="38" rx="5" fill="white" opacity="0.85"/>
29
- <rect x="78" y="66" width="24" height="24" rx="5" fill="white" opacity="0.9"/>
30
- <rect x="78" y="96" width="24" height="16" rx="5" fill="white" opacity="0.85"/>
31
-
32
- <!-- Infinite loop symbol (subtle overlay) -->
33
- <path d="M 30 60 Q 40 50, 50 60 Q 60 70, 70 60" stroke="url(#vibeGradLight)" stroke-width="3" fill="none" opacity="0.4" stroke-linecap="round"/>
34
- <path d="M 30 60 Q 40 70, 50 60 Q 60 50, 70 60" stroke="url(#vibeGradLight)" stroke-width="3" fill="none" opacity="0.4" stroke-linecap="round"/>
35
- </svg>
36
-
@@ -1,29 +0,0 @@
1
- <svg width="120" height="120" viewBox="0 0 120 120" fill="none" xmlns="http://www.w3.org/2000/svg">
2
- <defs>
3
- <linearGradient id="vibeGradLight" x1="0%" y1="0%" x2="100%" y2="100%">
4
- <stop offset="0%" style="stop-color:#3b82f6;stop-opacity:1" />
5
- <stop offset="100%" style="stop-color:#06b6d4;stop-opacity:1" />
6
- </linearGradient>
7
- </defs>
8
-
9
- <!-- Masonry blocks - representing the infinite block engine -->
10
- <!-- Left column -->
11
- <rect x="18" y="20" width="24" height="32" rx="5" fill="url(#vibeGradLight)" opacity="0.95"/>
12
- <rect x="18" y="58" width="24" height="20" rx="5" fill="url(#vibeGradLight)" opacity="0.85"/>
13
- <rect x="18" y="84" width="24" height="16" rx="5" fill="url(#vibeGradLight)" opacity="0.9"/>
14
-
15
- <!-- Middle column -->
16
- <rect x="48" y="28" width="24" height="22" rx="5" fill="url(#vibeGradLight)" opacity="0.9"/>
17
- <rect x="48" y="56" width="24" height="36" rx="5" fill="url(#vibeGradLight)" opacity="0.95"/>
18
- <rect x="48" y="98" width="24" height="14" rx="5" fill="url(#vibeGradLight)" opacity="0.8"/>
19
-
20
- <!-- Right column -->
21
- <rect x="78" y="22" width="24" height="38" rx="5" fill="url(#vibeGradLight)" opacity="0.85"/>
22
- <rect x="78" y="66" width="24" height="24" rx="5" fill="url(#vibeGradLight)" opacity="0.9"/>
23
- <rect x="78" y="96" width="24" height="16" rx="5" fill="url(#vibeGradLight)" opacity="0.85"/>
24
-
25
- <!-- Infinite loop symbol (subtle overlay) -->
26
- <path d="M 30 60 Q 40 50, 50 60 Q 60 70, 70 60" stroke="url(#vibeGradLight)" stroke-width="3" fill="none" opacity="0.6" stroke-linecap="round"/>
27
- <path d="M 30 60 Q 40 70, 50 60 Q 60 50, 70 60" stroke="url(#vibeGradLight)" stroke-width="3" fill="none" opacity="0.6" stroke-linecap="round"/>
28
- </svg>
29
-
package/lib/logo.svg DELETED
@@ -1,32 +0,0 @@
1
- <svg width="120" height="120" viewBox="0 0 120 120" fill="none" xmlns="http://www.w3.org/2000/svg">
2
- <defs>
3
- <linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="100%">
4
- <stop offset="0%" style="stop-color:#3b82f6;stop-opacity:1" />
5
- <stop offset="100%" style="stop-color:#06b6d4;stop-opacity:1" />
6
- </linearGradient>
7
- </defs>
8
-
9
- <!-- Background circle -->
10
- <circle cx="60" cy="60" r="58" fill="url(#grad1)" opacity="0.1"/>
11
-
12
- <!-- Masonry blocks representing infinite layout -->
13
- <!-- Column 1 -->
14
- <rect x="20" y="15" width="22" height="28" rx="4" fill="url(#grad1)" opacity="0.9"/>
15
- <rect x="20" y="48" width="22" height="18" rx="4" fill="url(#grad1)" opacity="0.7"/>
16
- <rect x="20" y="71" width="22" height="34" rx="4" fill="url(#grad1)" opacity="0.8"/>
17
-
18
- <!-- Column 2 -->
19
- <rect x="49" y="25" width="22" height="20" rx="4" fill="url(#grad1)" opacity="0.8"/>
20
- <rect x="49" y="50" width="22" height="32" rx="4" fill="url(#grad1)" opacity="0.9"/>
21
- <rect x="49" y="87" width="22" height="18" rx="4" fill="url(#grad1)" opacity="0.6"/>
22
-
23
- <!-- Column 3 -->
24
- <rect x="78" y="18" width="22" height="35" rx="4" fill="url(#grad1)" opacity="0.7"/>
25
- <rect x="78" y="58" width="22" height="22" rx="4" fill="url(#grad1)" opacity="0.9"/>
26
- <rect x="78" y="85" width="22" height="20" rx="4" fill="url(#grad1)" opacity="0.8"/>
27
-
28
- <!-- Infinite symbol overlay (subtle) -->
29
- <path d="M 35 60 Q 45 50, 55 60 Q 65 70, 75 60" stroke="url(#grad1)" stroke-width="2.5" fill="none" opacity="0.6" stroke-linecap="round"/>
30
- <path d="M 35 60 Q 45 70, 55 60 Q 65 50, 75 60" stroke="url(#grad1)" stroke-width="2.5" fill="none" opacity="0.6" stroke-linecap="round"/>
31
- </svg>
32
-