@vmasrani/fuzzy-img-viewer 0.1.6 → 0.1.7

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.
@@ -0,0 +1 @@
1
+ :root{--bg-primary: #05070c;--bg-secondary: rgba(12, 16, 24, .9);--bg-tertiary: rgba(255, 255, 255, .04);--bg-elevated: rgba(255, 255, 255, .1);--bg-overlay: rgba(2, 5, 12, .85);--border: rgba(255, 255, 255, .12);--border-muted: rgba(255, 255, 255, .08);--border-accent: #86e8ff;--text-primary: #f4f7fb;--text-secondary: #c8cedd;--text-muted: #8c92a4;--accent: #7ed2ff;--accent-emphasis: #4db0ff;--accent-muted: rgba(126, 210, 255, .25);--success: #56f5b0;--success-muted: rgba(86, 245, 176, .15);--warning: #ffc781;--danger: #ff7b86;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font-sans: "SF Pro Display", "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, "Noto Sans", Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", "SF Mono", Menlo, Consolas, monospace;--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-lg: 16px;--text-xl: 18px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--shadow-sm: 0 8px 20px rgba(0, 0, 0, .2);--shadow-md: 0 20px 40px rgba(0, 0, 0, .35);--shadow-lg: 0 35px 70px rgba(0, 0, 0, .5);--transition-fast: .12s ease;--transition-normal: .18s ease;--transition-slow: .32s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-base);background:radial-gradient(circle at 25% 20%,#141a2c,#05070c 55%);color:var(--text-primary);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100vw;height:100vh;display:flex;flex-direction:column;background:linear-gradient(145deg,#161c2cd9,#04060cf2)}.app{display:flex;flex-direction:column;height:100vh;width:100vw;background:transparent}.main-content{flex:1;overflow:hidden;position:relative}.search-header{padding:18px 32px 16px;background:#05080fa6;-webkit-backdrop-filter:blur(24px) saturate(160%);backdrop-filter:blur(24px) saturate(160%);border-bottom:1px solid rgba(255,255,255,.04);box-shadow:0 25px 60px #00000073;flex-shrink:0;position:sticky;top:0;z-index:5}.search-hero{max-width:1160px;margin:0 auto var(--space-3);display:flex;flex-direction:column;gap:4px}.search-hero-copy h1{font-size:20px;font-weight:600;margin-bottom:0}.search-hero-copy p{font-size:12px;color:#fff9}@media(max-width:900px){.search-hero{gap:6px}}.search-container{position:relative;max-width:1160px;margin:0 auto}.search-box{width:100%;padding:18px 24px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:999px;color:var(--text-primary);font-size:15px;font-family:var(--font-sans);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-shadow:inset 0 1px #ffffff0d,0 20px 40px #00000059}.search-box::placeholder{color:var(--text-muted)}.search-box:focus{border-color:var(--border-accent);box-shadow:0 5px 40px #7ed2ff40}.search-dropdown{position:absolute;top:calc(100% + var(--space-2));left:0;right:0;max-height:400px;overflow-y:auto;background:#080c14e6;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100}.search-dropdown-item{padding:var(--space-2) var(--space-3);cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background var(--transition-fast)}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item:hover{background:#ffffff08}.search-dropdown-item.highlighted{background:#ffffff08;border-left:2px solid var(--border-accent);padding-left:calc(var(--space-3) - 2px)}.search-dropdown-item.checked{background:var(--success-muted)}.search-dropdown-item.highlighted.checked{background:var(--accent-muted);border-left:2px solid var(--success)}.search-dropdown-item-content{display:flex;gap:var(--space-2);align-items:flex-start}.search-dropdown-checkbox{flex-shrink:0;width:16px;height:16px;border:1px solid rgba(255,255,255,.1);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);background:#ffffff05;color:var(--success);font-weight:600}.search-dropdown-item.checked .search-dropdown-checkbox{background:var(--success);border-color:var(--success);color:var(--bg-primary)}.search-dropdown-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.search-dropdown-item.disabled{cursor:default;color:var(--text-muted);font-style:italic}.search-dropdown-item.disabled:hover{background:transparent}.search-dropdown-path{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.search-dropdown mark{background:#ffffff59;color:var(--bg-primary);padding:0 3px;border-radius:4px}.search-info{margin:var(--space-3) auto 0;font-size:13px;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center;max-width:1160px;flex-wrap:wrap;gap:var(--space-3)}.search-info-details{display:flex;flex-direction:column;gap:4px}.search-info-summary{font-weight:500;color:var(--text-primary)}.search-info-stats{display:flex;gap:var(--space-2);flex-wrap:wrap}.info-chip{padding:4px 10px;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.05);font-size:11px;text-transform:uppercase;letter-spacing:.06em}.toolbar{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.toolbar button{padding:8px 18px;background:#ffffff0a;border:1px solid transparent;border-radius:999px;color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-sans);transition:all var(--transition-fast);box-shadow:inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toolbar button:hover{background:#ffffff14;color:var(--text-primary)}.toolbar button:active{background:#0003}.grid-container{width:100%;height:100%;overflow:auto;background:transparent;padding:32px 48px 48px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.grid-row{display:flex;gap:24px;padding:0}.group-header-row{display:flex;align-items:center;gap:20px;padding:0 18px;background:#070b12bf;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.group-collapse-button{width:38px;height:38px;border-radius:50%;border:1px solid transparent;background:#ffffff0d;color:var(--text-primary);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);flex-shrink:0}.group-collapse-button:hover{background:#ffffff1f;transform:translateY(-1px)}.group-header-content{flex:1;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.group-header-title{display:flex;flex-direction:column;gap:2px}.group-label{font-size:18px;font-weight:600;color:var(--text-primary)}.group-subtitle{font-size:13px;color:var(--text-secondary);letter-spacing:.01em}.group-count{font-size:13px;font-weight:500;color:#ffffffb3}.group-header-actions{display:flex;align-items:center;gap:var(--space-2)}.group-type-badge{font-size:var(--text-xs);padding:4px 12px;border-radius:999px;border:none;text-transform:uppercase;letter-spacing:.08em;background:#ffffff0f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.group-type-badge.prefix{background:#7ed2ff26;color:var(--accent)}.group-type-badge.folder{background:#97c94c26;color:var(--success)}.group-reorder{display:flex;gap:4px}.group-reorder button{width:34px;height:34px;border-radius:50%;border:none;background:#ffffff0d;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.group-reorder button:disabled{opacity:.3;cursor:not-allowed}.group-reorder button:not(:disabled):hover{background:#ffffff26}.tile{display:flex;flex-direction:column;background:#090c13d9;border-radius:18px;overflow:hidden;cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-fast);border:1px solid rgba(255,255,255,.04);box-shadow:0 25px 60px #00000073}.tile:hover{transform:translateY(-6px);box-shadow:0 35px 70px #0000008c}.tile.active{border-color:var(--border-accent);box-shadow:0 0 0 1px var(--border-accent),0 35px 70px #0009}.tile.selected{border-color:var(--success);background:#56f5b01a}.tile.active.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 0 6px #56f5b040}.tile-header{padding:var(--space-2) var(--space-3);background:#00000059;border-bottom:none;flex-shrink:0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tile-filename{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.tile-meta{font-size:var(--text-xs);color:#ffffffb3;margin-top:2px;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.tile-image-container{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 30%,#ffffff14,#000000a6);overflow:hidden;min-height:0;padding:8px}.tile-image-container img{width:100%;height:100%;object-fit:contain;border-radius:12px;box-shadow:0 15px 35px #00000073}.tile-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.tile-loading-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--border-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 15%,#020610f2,#000206fa);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);display:flex;flex-direction:column;z-index:1000}.viewer-chrome{padding:24px 36px 12px;display:flex;justify-content:space-between;align-items:flex-end;gap:24px}.viewer-title{display:flex;flex-direction:column;gap:8px}.viewer-filename{font-size:22px;font-weight:600}.viewer-details{display:flex;gap:10px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#ffffffb3}.viewer-controls{display:flex;gap:12px}.viewer-pill{padding:10px 24px;border-radius:999px;border:none;background:#ffffff2e;color:#010308;font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 15px 30px #00000059}.viewer-pill.secondary{background:#ffffff14;color:var(--text-primary)}.viewer-pill:hover{transform:translateY(-1px);box-shadow:0 25px 45px #00000073}.viewer-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.viewer-image-container{max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;cursor:grab}.viewer-image-container:active{cursor:grabbing}.viewer-image{max-width:100%;max-height:100%;object-fit:contain;transition:transform var(--transition-fast)}.viewer-bottom-bar{position:absolute;left:50%;bottom:32px;transform:translate(-50%);min-width:40%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:10px 20px;background:#00000073;border:1px solid rgba(255,255,255,.08);border-radius:999px;font-size:12px;color:#ffffffd9}.viewer-path{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono)}.viewer-counter{font-weight:600;color:var(--text-primary)}.viewer-nav{position:absolute;top:50%;transform:translateY(-50%);background:#00000073;border:1px solid rgba(255,255,255,.08);color:var(--text-primary);font-size:24px;padding:18px;cursor:pointer;border-radius:50%;transition:all var(--transition-fast);opacity:.85}.viewer-nav:hover{background:#000000b3;opacity:1}.viewer-nav.prev{left:32px}.viewer-nav.next{right:32px}.compare-grid{display:grid;gap:32px;padding:36px;height:100%;overflow:auto;background:transparent}.compare-item{background:#080c14cc;border:1px solid rgba(255,255,255,.06);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.compare-item img{width:100%;height:100%;object-fit:contain;background:radial-gradient(circle at 50% 35%,#ffffff0f,#000c)}.compare-label{padding:10px 16px;background:#00000059;font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text-secondary);text-align:center;border-top:1px solid rgba(255,255,255,.05);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quicklook-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 50%,#05080fe6,#000000f2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-8)}.quicklook-container{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;background:#080c14e6;border:1px solid rgba(255,255,255,.08);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden}.quicklook-header{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;background:transparent;border-bottom:1px solid rgba(255,255,255,.06)}.quicklook-title{display:flex;flex-direction:column;gap:2px;min-width:0}.quicklook-filename{font-size:var(--text-base);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quicklook-counter{font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono)}.quicklook-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;font-size:20px;transition:all var(--transition-fast)}.quicklook-close:hover{background:#ffffff26;color:var(--text-primary)}.quicklook-content{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:#030408cc;min-height:300px}.quicklook-image-wrapper{display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.quicklook-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:16px;box-shadow:var(--shadow-md)}.quicklook-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0000008c;border:1px solid rgba(255,255,255,.08);border-radius:50%;color:var(--text-primary);font-size:24px;cursor:pointer;transition:all var(--transition-fast);opacity:.7}.quicklook-nav:hover{background:#000000bf;opacity:1}.quicklook-nav-prev{left:32px}.quicklook-nav-next{right:32px}.quicklook-footer{padding:16px 28px;background:#0000004d;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;align-items:center}.quicklook-path{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quicklook-meta{font-size:var(--text-xs);color:var(--text-secondary)}.quicklook-empty{display:flex;align-items:center;justify-content:center;padding:var(--space-8);color:var(--text-muted)}.command-palette-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;padding-top:15vh;z-index:2000}.command-palette{width:100%;max-width:600px;max-height:60vh;background:#070a12f2;border:1px solid rgba(255,255,255,.08);border-radius:24px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.command-palette-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.05);background:transparent}.command-palette-input{width:100%;padding:18px 22px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;color:var(--text-primary);font-size:16px;font-family:var(--font-sans);outline:none;transition:border-color var(--transition-fast)}.command-palette-input::placeholder{color:var(--text-muted)}.command-palette-input:focus{border-color:var(--accent)}.command-palette-list{flex:1;overflow-y:auto;padding:var(--space-2) 0}.command-palette-group{margin-bottom:var(--space-2)}.command-palette-group-label{padding:var(--space-1) var(--space-4);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.command-palette-item{display:flex;justify-content:space-between;align-items:center;padding:12px 22px;cursor:pointer;transition:background var(--transition-fast)}.command-palette-item:hover,.command-palette-item.selected{background:#ffffff14}.command-palette-item-label{font-size:var(--text-base);color:var(--text-primary)}.command-palette-item-shortcut{font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text-muted);padding:4px 8px;background:#ffffff0d;border-radius:8px}.command-palette-empty{padding:var(--space-4);text-align:center;color:var(--text-muted)}.keyboard-help-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#010206d9;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-4)}.keyboard-help{width:100%;max-width:700px;max-height:80vh;background:#070a12f2;border:1px solid rgba(255,255,255,.08);border-radius:24px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.keyboard-help-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);background:transparent;border-bottom:1px solid rgba(255,255,255,.08)}.keyboard-help-header h2{font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.keyboard-help-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;font-size:24px;transition:all var(--transition-fast)}.keyboard-help-close:hover{background:#ffffff26;color:var(--text-primary)}.keyboard-help-content{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-5);display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5)}.keyboard-help-group{display:flex;flex-direction:column;gap:var(--space-2)}.keyboard-help-group-title{font-size:var(--text-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-1)}.keyboard-help-shortcuts{display:flex;flex-direction:column;gap:var(--space-2)}.keyboard-help-shortcut{display:flex;align-items:center;gap:var(--space-3)}.keyboard-help-key{min-width:80px;padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);text-align:center}.keyboard-help-description{font-size:var(--text-sm);color:var(--text-secondary)}.keyboard-help-footer{padding:var(--space-3) var(--space-5);background:#00000059;border-top:1px solid rgba(255,255,255,.08);text-align:center;font-size:var(--text-sm);color:var(--text-muted)}.keyboard-help-footer kbd{padding:4px var(--space-2);background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:8px;font-family:var(--font-mono);font-size:var(--text-xs)}.keybindings-help{position:fixed;bottom:24px;right:24px;padding:10px 16px;background:#00000073;border:1px solid rgba(255,255,255,.06);border-radius:999px;font-size:11px;color:var(--text-muted);display:flex;gap:14px;opacity:.85;transition:opacity var(--transition-normal);box-shadow:var(--shadow-sm)}.keybindings-help:hover{opacity:1}.keybinding{display:flex;gap:var(--space-1);align-items:center}.key{padding:4px var(--space-2);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:6px;font-family:var(--font-mono);font-size:10px}.loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:var(--text-lg);color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);gap:var(--space-4)}.empty-state h2{font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.empty-state button{padding:14px 32px;background:linear-gradient(135deg,var(--accent-emphasis),var(--accent));border:none;border-radius:999px;color:#04111d;font-size:var(--text-base);font-weight:500;cursor:pointer;transition:background var(--transition-fast);box-shadow:0 20px 40px #0006}.empty-state button:hover{filter:brightness(1.05)}.folder-browser-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#010308d9;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;z-index:2000}.folder-browser{width:90%;max-width:600px;max-height:80vh;background:#070a12f2;border:1px solid rgba(255,255,255,.08);border-radius:24px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.folder-browser-header{padding:var(--space-5) var(--space-6) var(--space-4);background:transparent;border-bottom:1px solid rgba(255,255,255,.06)}.folder-browser-header h3{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.folder-browser-path{font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text-muted);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-browser-actions{padding:var(--space-3) var(--space-6);display:flex;gap:var(--space-3);background:#ffffff05;border-bottom:1px solid rgba(255,255,255,.05)}.folder-browser-actions button{padding:10px 20px;background:#ffffff0d;border:none;border-radius:14px;color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-sans);transition:all var(--transition-fast)}.folder-browser-actions button:hover:not(:disabled){background:#ffffff1f}.folder-browser-actions button:disabled{opacity:.5;cursor:not-allowed}.folder-browser-actions button.primary{background:var(--accent-emphasis);border-color:transparent;color:#01111b}.folder-browser-actions button.primary:hover:not(:disabled){background:var(--accent)}.folder-browser-list{flex:1;overflow-y:auto;padding:var(--space-2) 0;min-height:200px;max-height:400px}.folder-browser-item{padding:14px 32px;display:flex;align-items:center;gap:var(--space-3);cursor:pointer;transition:background var(--transition-fast)}.folder-browser-item:hover{background:#ffffff0d}.folder-icon{font-size:var(--text-lg)}.folder-name{font-size:var(--text-base);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-browser-loading,.folder-browser-empty,.folder-browser-error{padding:var(--space-6);text-align:center;color:var(--text-muted);font-size:var(--text-base)}.folder-browser-error{color:var(--danger)}.folder-browser-footer{padding:var(--space-4) var(--space-6);background:#00000059;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:flex-end}.folder-browser-footer button{padding:var(--space-2) var(--space-5);background:#ffffff0d;border:none;border-radius:14px;color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-sans);transition:all var(--transition-fast)}.folder-browser-footer button:hover{background:#ffffff1f}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff05;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}::selection{background:#7ed2ff59;color:#04111d}.compare-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.compare-mode-switcher{display:flex;gap:6px;background:#00000040;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.05)}.compare-mode-btn{padding:6px 18px;background:transparent;border:none;border-radius:999px;color:var(--text-secondary);cursor:pointer;font-size:13px;font-family:var(--font-sans);transition:all var(--transition-fast)}.compare-mode-btn:hover{color:var(--text-primary);background:#ffffff14}.compare-mode-btn.active{background:#fff3;color:var(--text-primary)}.compare-footer{padding:10px 16px;background:#00000040;border-top:1px solid rgba(255,255,255,.04);text-align:center}.compare-solo{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:#04060ce6}.compare-solo-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;display:flex;align-items:center;justify-content:center;background:#00000073;border:1px solid rgba(255,255,255,.08);border-radius:50%;color:var(--text-primary);font-size:28px;cursor:pointer;transition:all var(--transition-fast);opacity:.85;z-index:10}.compare-solo-nav:hover{background:#000000bf;opacity:1}.compare-solo-nav.prev{left:var(--space-4)}.compare-solo-nav.next{right:var(--space-4)}.compare-solo-image-container{display:flex;align-items:center;justify-content:center;max-width:90%;max-height:100%}.compare-solo-image-container img{max-width:100%;max-height:80vh;object-fit:contain;transition:transform var(--transition-fast)}.compare-solo-info{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;background:#0000008c;border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:8px 18px}.compare-solo-filename{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.compare-solo-counter{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.compare-sidebyside{flex:1;display:flex;gap:2px;background:#ffffff0d;overflow:hidden;border-radius:20px;border:1px solid rgba(255,255,255,.05)}.compare-sidebyside-panel{flex:1;display:flex;flex-direction:column;background:#00000059;overflow:hidden}.compare-sidebyside-image{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.compare-sidebyside-image img{max-width:100%;max-height:100%;object-fit:contain;transition:transform var(--transition-fast)}.compare-sidebyside-label{padding:10px 16px;background:#00000073;font-size:var(--text-sm);font-family:var(--font-mono);color:var(--text-secondary);text-align:center;border-top:1px solid rgba(255,255,255,.04);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compare-sidebyside-divider{width:1px;background:var(--border-accent)}
package/dist/index.html CHANGED
@@ -4,8 +4,8 @@
4
4
  <meta charset="UTF-8" />
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
6
  <title>AquaEye Viz</title>
7
- <script type="module" crossorigin src="/assets/index-Ct480H81.js"></script>
8
- <link rel="stylesheet" crossorigin href="/assets/index-D6oVaE-9.css">
7
+ <script type="module" crossorigin src="/assets/index-6CqpoA1i.js"></script>
8
+ <link rel="stylesheet" crossorigin href="/assets/index-BWfhbXib.css">
9
9
  </head>
10
10
  <body>
11
11
  <div id="root"></div>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vmasrani/fuzzy-img-viewer",
3
- "version": "0.1.6",
3
+ "version": "0.1.7",
4
4
  "description": "High-performance image browser with fuzzy search and virtualized grid rendering",
5
5
  "author": "vmasrani",
6
6
  "license": "MIT",
@@ -14,8 +14,9 @@
14
14
  "install.js"
15
15
  ],
16
16
  "scripts": {
17
- "dev": "vite",
18
- "build": "npm run build:frontend",
17
+ "dev": "node scripts/dev.js",
18
+ "dev:frontend": "vite",
19
+ "build": "npm run build:frontend && cargo build --manifest-path backend/Cargo.toml --release",
19
20
  "build:frontend": "tsc && vite build",
20
21
  "preview": "vite preview",
21
22
  "postinstall": "node install.js",
@@ -23,38 +24,23 @@
23
24
  "prepublishOnly": "npm run build"
24
25
  },
25
26
  "dependencies": {
26
- "@tanstack/react-virtual": "^3.10.8",
27
- "fuzzysort": "3.1.0",
27
+ "@tanstack/react-virtual": "^3.11.1",
28
+ "cmdk": "^1.0.0",
29
+ "flexsearch": "^0.7.31",
30
+ "fuzzysort": "^2.0.4",
28
31
  "react": "^18.3.1",
29
32
  "react-dom": "^18.3.1",
33
+ "react-photo-album": "^3.1.0",
34
+ "react-virtuoso": "^4.10.1",
35
+ "yet-another-react-lightbox": "^3.21.4",
30
36
  "zustand": "^4.5.5"
31
37
  },
32
38
  "optionalDependencies": {
33
- "@vmasrani/fuzzy-img-viewer-darwin-arm64": "0.1.6",
34
- "@vmasrani/fuzzy-img-viewer-darwin-x64": "0.1.6",
35
- "@vmasrani/fuzzy-img-viewer-linux-x64": "0.1.6",
36
- "@vmasrani/fuzzy-img-viewer-linux-arm64": "0.1.6",
37
- "@vmasrani/fuzzy-img-viewer-win32-x64": "0.1.6",
38
- "@vmasrani/fuzzy-img-viewer-darwin-arm64": "0.1.6",
39
- "@vmasrani/fuzzy-img-viewer-darwin-x64": "0.1.6",
40
- "@vmasrani/fuzzy-img-viewer-linux-x64": "0.1.6",
41
- "@vmasrani/fuzzy-img-viewer-linux-arm64": "0.1.6",
42
- "@vmasrani/fuzzy-img-viewer-win32-x64": "0.1.6",
43
- "@vmasrani/fuzzy-img-viewer-darwin-arm64": "0.1.6",
44
- "@vmasrani/fuzzy-img-viewer-darwin-x64": "0.1.6",
45
- "@vmasrani/fuzzy-img-viewer-linux-x64": "0.1.6",
46
- "@vmasrani/fuzzy-img-viewer-linux-arm64": "0.1.6",
47
- "@vmasrani/fuzzy-img-viewer-win32-x64": "0.1.6",
48
- "@vmasrani/fuzzy-img-viewer-darwin-arm64": "0.1.6",
49
- "@vmasrani/fuzzy-img-viewer-darwin-x64": "0.1.6",
50
- "@vmasrani/fuzzy-img-viewer-linux-x64": "0.1.6",
51
- "@vmasrani/fuzzy-img-viewer-linux-arm64": "0.1.6",
52
- "@vmasrani/fuzzy-img-viewer-win32-x64": "0.1.6",
53
- "@vmasrani/fuzzy-img-viewer-darwin-arm64": "0.1.6",
54
- "@vmasrani/fuzzy-img-viewer-darwin-x64": "0.1.6",
55
- "@vmasrani/fuzzy-img-viewer-linux-x64": "0.1.6",
56
- "@vmasrani/fuzzy-img-viewer-linux-arm64": "0.1.6",
57
- "@vmasrani/fuzzy-img-viewer-win32-x64": "0.1.6"
39
+ "@vmasrani/fuzzy-img-viewer-darwin-arm64": "0.1.7",
40
+ "@vmasrani/fuzzy-img-viewer-darwin-x64": "0.1.7",
41
+ "@vmasrani/fuzzy-img-viewer-linux-x64": "0.1.7",
42
+ "@vmasrani/fuzzy-img-viewer-linux-arm64": "0.1.7",
43
+ "@vmasrani/fuzzy-img-viewer-win32-x64": "0.1.7"
58
44
  },
59
45
  "devDependencies": {
60
46
  "@types/react": "^18.3.12",