@neiltron/session-visualizer 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +92 -0
- package/bin/session-visualizer.js +1371 -0
- package/dist/assets/index-CDAS4q4l.css +1 -0
- package/dist/assets/index-JUkOHAxs.js +77 -0
- package/dist/index.html +13 -0
- package/package.json +67 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
:root{--bg-app: #181818;--bg-panel: #232323;--bg-header: #2d2d2d;--bg-input: #1e1e1e;--bg-hover: #313131;--bg-selected: #3a3a3a;--bg-track: #1d1d1d;--bg-track-alt: #222222;--border-deep: #111111;--border-light: #383838;--text-primary: #dddddd;--text-secondary: #8a8a8a;--text-muted: #666666;--text-active: #ffffff;--text-value-blue: #61a8ff;--accent-metadata: #7f8ea1;--accent-user: #4f96ea;--accent-assistant: #8e75ed;--accent-tools: #dbab39;--accent-custom: #4eb9ab;--accent-error: #d14e4e;--accent-warning: #dbab39;--shadow-selected: 0 0 0 1px rgba(255, 255, 255, .6), 0 0 12px rgba(255, 255, 255, .08)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;height:100%}body{background:var(--bg-app);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:11px;line-height:1.3;overflow:hidden;-webkit-user-select:none;user-select:none}button,input,select,textarea,pre,code,.selectable{-webkit-user-select:text;user-select:text}button,input,select{font:inherit}button{color:inherit}.mono{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,monospace;font-variant-numeric:tabular-nums}.app-shell{display:flex;flex-direction:column;height:100%}.app-top-bar{display:flex;align-items:center;gap:14px;height:36px;padding:0 12px;border-bottom:1px solid var(--border-deep);background:linear-gradient(180deg,#1a1a1a,#181818)}.app-brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.02em}.app-brand-mark{color:var(--text-value-blue);font-size:14px}.app-tab{background:transparent;border:0;border-bottom:2px solid transparent;padding:0 2px;height:100%;display:inline-flex;align-items:center;cursor:pointer;color:var(--text-secondary)}.app-tab:hover:not(:disabled){background:#ffffff0d}.app-tab:disabled{cursor:default;opacity:.5}.app-tab.is-active{color:var(--text-value-blue);border-bottom-color:var(--text-value-blue)}.app-spacer{flex:1}.app-meta{color:var(--text-secondary)}.source-display-row{display:flex;align-items:center;gap:8px;min-width:0;padding:3px 4px 3px 10px;border:1px solid var(--border-light);background:#ffffff0a;border-radius:4px}.source-root-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.source-root-label{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.source-edit-row{display:flex;align-items:center;gap:6px;min-width:0}.source-input-inline{width:min(400px,30vw);height:20px;font-size:11px}.source-edit-row .ghost-button{height:20px;font-size:10px;padding:0 8px}.view{display:flex;flex:1;min-height:0;gap:2px;padding:2px}.view-browser{flex-direction:column}.panel{border:1px solid var(--border-deep);background:var(--bg-panel);min-height:0}.panel-header{display:flex;align-items:center;gap:12px;height:29px;padding:2px 8px;background:var(--bg-header);border-bottom:1px solid var(--border-deep)}.panel-title{text-transform:uppercase;letter-spacing:.06em;font-size:10px;color:var(--text-secondary)}.toolbar{flex:0 0 auto}.toolbar-filter-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.toolbar-filter-bar .toolbar-count{margin-left:auto}.toolbar-search{display:flex;align-items:center;gap:8px;padding-right:12px;border-right:1px solid var(--border-light)}.toolbar-icon{color:var(--text-secondary);font-size:13px;line-height:1}.search-input,.toolbar-select{height:22px;border:1px solid var(--border-deep);background:var(--bg-input);color:var(--text-primary);padding:0 8px;outline:none}.search-input{width:280px}.search-input:focus,.toolbar-select:focus{border-color:var(--text-value-blue)}.toolbar-select-wrap{display:flex;align-items:center;gap:6px}.toolbar-label,.toolbar-count{color:var(--text-secondary)}.notice-warning{color:var(--accent-warning)}.notice-error{color:var(--accent-error)}.notice-info{color:var(--text-secondary)}.notice-banner{display:flex;align-items:center;gap:8px;padding:8px 10px;border-top:1px solid var(--border-light)}.table-panel{flex:1;min-height:0}.table-scroll{height:100%;overflow:auto}.session-table{width:100%;border-collapse:collapse}.session-table thead th{position:sticky;top:0;z-index:1;background:var(--bg-header);border-bottom:1px solid var(--border-deep);border-right:1px solid var(--border-light);color:var(--text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.06em;font-size:10px;padding:5px 8px}.session-table thead th.sortable-th{cursor:pointer}.session-table thead th.sortable-th:hover{color:var(--text-primary);background:var(--bg-hover)}.session-table td{padding:4px 8px;border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);white-space:nowrap;vertical-align:top}.session-table tbody tr{cursor:pointer}.session-table tbody tr:nth-child(2n){background:#00000014}.session-table tbody tr:hover{background:var(--bg-hover)}.session-table tbody tr.is-active{background:#61a8ff33}.cell-group-path{max-width:280px;overflow:hidden;text-overflow:ellipsis}.cell-stats{display:flex;gap:4px;align-items:center;white-space:nowrap}.cell-stats-sep{color:var(--text-muted)}.cell-strong{color:var(--text-value-blue)}.cell-muted{color:var(--text-secondary)}.cell-error{color:var(--accent-error)}.cell-warning{color:var(--accent-warning)}.empty-panel{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:8px;padding:22px}.empty-panel h2{margin:0;font-size:15px}.empty-panel p{margin:0;max-width:72ch;color:var(--text-secondary)}.empty-panel-error h2{color:var(--accent-error)}.empty-panel-actions{display:flex;gap:8px;margin-top:8px}.ghost-button{height:24px;border:1px solid var(--border-light);margin-left:3px;background:var(--bg-input);color:var(--text-primary);padding:0 10px;cursor:pointer}.ghost-button:hover{background:var(--bg-hover)}.view-session{flex-direction:column}.session-header{flex:0 0 auto}.session-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px 0}.breadcrumbs{display:flex;align-items:center;gap:6px;color:var(--text-secondary);min-width:0;overflow:hidden}.breadcrumbs-segment{display:inline-flex;align-items:center;gap:6px;min-width:0}.breadcrumbs-segment .mono{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.breadcrumbs-file{font-weight:700;color:var(--text-primary);white-space:nowrap}.breadcrumbs-button{border:0;background:transparent;color:var(--text-value-blue);cursor:pointer;padding:0}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--border-light);background:var(--bg-input);color:var(--text-primary);cursor:pointer;padding:0;font-size:13px;line-height:1}.icon-button:hover{background:var(--bg-hover)}.session-actions{display:flex;gap:8px}.session-path-meta{padding:6px 12px 0;color:var(--text-secondary)}.session-summary-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;padding:10px 12px 12px}.summary-metric{min-height:48px;border:1px solid var(--border-light);background:#00000029;padding:8px}.summary-metric .summary-value{font-size:14px}.summary-metric-error{border-left:2px solid var(--accent-error)}.summary-label{margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:10px}.warning-banner{display:flex;align-items:center;gap:8px;padding:8px 12px 12px;border-top:1px solid var(--border-light);color:var(--accent-warning)}.session-workspace{display:grid;grid-template-columns:minmax(0,2.1fr) minmax(320px,1fr);gap:2px;flex:1;min-height:0}.timeline-panel,.inspector-panel{display:flex;flex-direction:column}.timeline-header-controls{justify-content:space-between;gap:16px;flex-wrap:wrap;min-height:32px;height:auto;padding-top:4px;padding-bottom:4px}.timeline-header-main{display:flex;align-items:center;gap:12px;min-width:0}.timeline-meta{display:flex;gap:12px;color:var(--text-secondary);min-width:0;flex-wrap:wrap}.timeline-zoom-controls{display:flex;align-items:center;gap:6px;margin-left:auto}.zoom-button,.zoom-pill{height:22px;border:1px solid var(--border-light);background:linear-gradient(180deg,#262626,#1d1d1d);color:var(--text-primary);padding:0 8px;cursor:pointer;box-shadow:inset 0 1px #ffffff08}.zoom-button:hover,.zoom-pill:hover{background:linear-gradient(180deg,#313131,#252525)}.zoom-button{width:24px;padding:0;text-align:center}.zoom-pill{min-width:40px;text-align:center;font-variant-numeric:lining-nums tabular-nums}.zoom-slider-shell{position:relative;width:156px;height:22px;border:1px solid var(--border-light);background:linear-gradient(180deg,#262626,#1b1b1b);box-shadow:inset 0 1px #ffffff08;overflow:hidden;padding-left:8px;padding-right:8px}.zoom-slider-track,.zoom-slider-fill{position:absolute;top:50%;height:4px;transform:translateY(-50%);pointer-events:none;box-sizing:border-box}.zoom-slider-track{background:#4a4a4a}.zoom-slider-fill{background:linear-gradient(90deg,#5c96da 0%,var(--text-value-blue) 100%);box-shadow:0 0 8px #61a8ff33}.zoom-slider{position:absolute;top:0;right:0;bottom:0;left:2%;width:96%;margin:0;background:transparent;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.zoom-slider::-webkit-slider-runnable-track{height:22px;background:transparent}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:14px;margin-top:4px;border:1px solid #89bbff;background:linear-gradient(180deg,#7eb6ff,#4f96ea);box-shadow:0 0 0 1px #00000059,0 0 8px #61a8ff2e}.zoom-slider::-moz-range-track{height:22px;background:transparent;border:0}.zoom-slider::-moz-range-progress{height:22px;background:transparent}.zoom-slider::-moz-range-thumb{width:10px;height:14px;border:1px solid #89bbff;border-radius:0;background:linear-gradient(180deg,#7eb6ff,#4f96ea);box-shadow:0 0 0 1px #00000059,0 0 8px #61a8ff2e}.zoom-slider:focus-visible{outline:none}.zoom-slider-shell:has(.zoom-slider:focus-visible){border-color:var(--text-value-blue)}.timeline-body{display:grid;grid-template-columns:170px minmax(0,1fr);min-height:0;flex:1}.timeline-outliner{border-right:1px solid var(--border-deep);background:var(--bg-panel)}.timeline-outliner-ruler{height:26px}.timeline-outliner-row,.timeline-track-row{height:46px}.timeline-outliner-row{display:flex;align-items:center;gap:8px;padding:0 10px;border-bottom:1px solid var(--border-light)}.lane-glyph{font-size:12px}.lane-metadata{color:var(--accent-metadata)}.lane-user{color:var(--accent-user)}.lane-assistant{color:var(--accent-assistant)}.lane-tools{color:var(--accent-tools)}.lane-custom{color:var(--accent-custom)}.timeline-scroll{min-width:0;overflow:auto;background:var(--bg-track)}.timeline-ruler{position:sticky;top:0;z-index:3;height:26px;background:linear-gradient(180deg,#303030,#2a2a2a);border-bottom:1px solid var(--border-deep)}.timeline-tick{position:absolute;top:0;bottom:0;width:1px;background:var(--border-light)}.timeline-tick-label{position:absolute;top:4px;left:6px;color:var(--text-secondary);white-space:nowrap}.timeline-tracks{position:relative}.timeline-track-row{position:relative;border-bottom:1px solid var(--border-deep);overflow:hidden}.timeline-track-row:nth-child(2n){background:var(--bg-track-alt)}.timeline-playhead{position:absolute;top:26px;bottom:0;width:1px;background:var(--accent-error);z-index:4}.timeline-playhead:before{content:"";position:absolute;top:-8px;left:-4px;width:9px;height:9px;background:var(--accent-error);clip-path:polygon(0 0,100% 0,50% 100%)}.timeline-span,.timeline-event{position:absolute;top:8px;border:1px solid rgba(0,0,0,.48);background:transparent;padding:0;cursor:pointer;text-align:left}.timeline-span:hover,.timeline-event:hover,.timeline-span.is-selected,.timeline-event.is-selected{box-shadow:var(--shadow-selected)}.timeline-span{height:30px;min-width:12px;border-radius:2px;background:color-mix(in srgb,var(--accent-tools) 58%,transparent);overflow:hidden}.timeline-span.is-error{background:color-mix(in srgb,var(--accent-error) 66%,transparent)}.timeline-span.is-orphan{border-style:dashed}.timeline-span-inner{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;height:100%;padding:0 8px}.timeline-span-label,.timeline-span-duration{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-event{height:28px;transform:translate(-50%);overflow:hidden}.timeline-event-card{border-radius:2px}.timeline-event-anchor{width:16px!important;height:16px;top:15px;border-radius:2px;transform:translate(-50%) rotate(45deg)}.timeline-event-anchor .timeline-event-inner{display:none}.timeline-event-inner{display:flex;align-items:center;gap:6px;padding:0 7px;height:100%}.timeline-event-badge{color:#ffffffb8;font-size:9px;text-transform:uppercase;letter-spacing:.04em}.timeline-event-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timeline-event.lane-metadata,.timeline-event.lane-metadata .timeline-event-inner,.timeline-event.lane-metadata.timeline-event-anchor,.timeline-event.lane-metadata.timeline-event-card{background:color-mix(in srgb,var(--accent-metadata) 78%,#27303b)}.timeline-event.lane-user,.timeline-event.lane-user .timeline-event-inner,.timeline-event.lane-user.timeline-event-anchor,.timeline-event.lane-user.timeline-event-card{background:color-mix(in srgb,var(--accent-user) 78%,#243142)}.timeline-event.lane-assistant,.timeline-event.lane-assistant .timeline-event-inner,.timeline-event.lane-assistant.timeline-event-anchor,.timeline-event.lane-assistant.timeline-event-card{background:color-mix(in srgb,var(--accent-assistant) 78%,#2c2544)}.timeline-event.lane-tools,.timeline-event.lane-tools .timeline-event-inner,.timeline-event.lane-tools.timeline-event-anchor,.timeline-event.lane-tools.timeline-event-card{background:color-mix(in srgb,var(--accent-tools) 78%,#46391e)}.timeline-event.lane-custom,.timeline-event.lane-custom .timeline-event-inner,.timeline-event.lane-custom.timeline-event-anchor,.timeline-event.lane-custom.timeline-event-card{background:color-mix(in srgb,var(--accent-custom) 78%,#1d3634)}.timeline-event.is-error,.timeline-event.is-error .timeline-event-inner{background:color-mix(in srgb,var(--accent-error) 78%,#4a2020)}.inspector-scroll{flex:1;min-height:0;overflow:auto;padding:12px}.inspector-section{margin-bottom:14px}.inspector-section h3{margin:0 0 6px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.inspector-card{border:1px solid var(--border-light);background:#191919;padding:10px}.kv-row{display:grid;grid-template-columns:86px minmax(0,1fr);gap:10px;padding:3px 0}.kv-key{color:var(--text-secondary)}.kv-value{min-width:0;word-break:break-word}.preview-block{margin-top:10px;padding:8px 10px;border-left:2px solid var(--text-value-blue);background:#0000002e;color:#ced6e5}.content-block-stack{display:flex;flex-direction:column;gap:12px}.content-block{display:flex;flex-direction:column;gap:6px}.content-block img{max-width:100%}.content-block-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.markdown-body,.formatted-pre{margin:0;padding:10px;border:1px solid var(--border-deep);background:#111;color:#d9d9d9;line-height:1.5}.markdown-body>:first-child{margin-top:0}.markdown-body>:last-child{margin-bottom:0}.markdown-body p,.markdown-body ul,.markdown-body ol,.markdown-body pre,.markdown-body blockquote{margin:0 0 8px}.markdown-body ul,.markdown-body ol{padding-left:18px}.markdown-body code{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,monospace;background:#ffffff0f;padding:1px 4px}.markdown-body pre code{display:block;padding:0;background:transparent}.markdown-body a{color:var(--text-value-blue)}.formatted-pre{white-space:pre-wrap;word-break:break-word;overflow:auto}.raw-meta{margin-bottom:6px;color:var(--text-secondary)}.raw-json{margin:0;padding:10px;max-height:340px;overflow:auto;border:1px solid var(--border-deep);background:#111;color:#d9d9d9;line-height:1.45}.empty-inline{color:var(--text-secondary)}@media(max-width:1180px){.session-workspace{grid-template-columns:1fr;grid-template-rows:minmax(320px,1fr) minmax(260px,.9fr)}}@media(max-width:900px){.search-input{width:180px}.session-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.timeline-body{grid-template-columns:120px minmax(0,1fr)}}
|