glassbox 0.1.1 → 0.1.2

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: #1e1e2e;--bg-surface: #252536;--bg-hover: #2d2d44;--bg-active: #363652;--text: #cdd6f4;--text-dim: #8888aa;--text-bright: #ffffff;--accent: #89b4fa;--accent-hover: #74a8fc;--green: #a6e3a1;--red: #f38ba8;--yellow: #f9e2af;--orange: #fab387;--blue: #89b4fa;--purple: #cba6f7;--teal: #94e2d5;--border: #363652;--diff-add-bg: rgba(166, 227, 161, 0.1);--diff-add-border: rgba(166, 227, 161, 0.3);--diff-remove-bg: rgba(243, 139, 168, 0.1);--diff-remove-border: rgba(243, 139, 168, 0.3);--diff-context-bg: transparent;--gutter-bg: #1a1a2e;--gutter-text: #555577;--sidebar-w: 300px;--radius: 6px;--font-mono: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;--font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden}.review-app{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);min-width:200px;max-width:60vw;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar-resize{width:4px;cursor:col-resize;background:rgba(0,0,0,0);flex-shrink:0;transition:background .15s}.sidebar-resize:hover,.sidebar-resize.dragging{background:var(--accent)}.sidebar-header{padding:16px;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:16px;font-weight:600;color:var(--text-bright)}.review-mode{font-size:12px;color:var(--text-dim);margin-top:4px;display:block}.file-filter{padding:8px 16px;border-bottom:1px solid var(--border)}.file-filter-input{width:100%;padding:5px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;outline:none}.file-filter-input:focus{border-color:var(--accent)}.file-filter-input::placeholder{color:var(--text-dim)}.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.file-list{flex:1;overflow-y:auto;padding:8px 0}.file-item{display:flex;align-items:center;padding:6px 16px 6px 16px;cursor:pointer;font-size:13px;gap:8px;border-left:3px solid rgba(0,0,0,0);transition:background .1s}.file-item:hover{background:var(--bg-hover)}.file-item.active{background:var(--bg-active);border-left-color:var(--accent)}.file-item .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.file-item .status-dot.pending{background:var(--text-dim)}.file-item .status-dot.reviewed{background:var(--green)}.file-item .status-dot.skipped{background:var(--yellow)}.file-item .file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono);font-size:12px}.file-item .file-status{font-size:11px;font-weight:500;padding:1px 6px;border-radius:3px}.file-status.added{color:var(--green);background:rgba(166,227,161,.1)}.file-status.modified{color:var(--yellow);background:rgba(249,226,175,.1)}.file-status.deleted{color:var(--red);background:rgba(243,139,168,.1)}.file-status.renamed{color:var(--purple);background:rgba(203,166,247,.1)}.annotation-count{font-size:11px;color:var(--accent);background:rgba(137,180,250,.15);padding:0 5px;border-radius:8px;min-width:18px;text-align:center}.folder-header{display:flex;align-items:center;padding:4px 16px;font-size:12px;color:var(--text-dim);gap:4px;user-select:none}.folder-header.collapsible{cursor:pointer}.folder-header.collapsible:hover{color:var(--text)}.folder-header.collapsed+.folder-content{display:none}.folder-header.collapsed .folder-arrow{transform:rotate(-90deg)}.folder-arrow{width:12px;font-size:10px;flex-shrink:0;text-align:center;transition:transform .1s}.folder-arrow-spacer{width:12px;flex-shrink:0}.folder-name{font-family:var(--font-mono);font-size:12px}.stale-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin:8px 16px}.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.diff-container{flex:1;overflow:auto}.welcome-message{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--text-dim);gap:8px}.welcome-message h3{color:var(--text)}.diff-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border)}.diff-header .file-path{font-family:var(--font-mono);font-size:13px;color:var(--text-bright)}.diff-header-actions{display:flex;gap:8px;align-items:center}.outline-bar{position:sticky;top:41px;z-index:9;background:var(--bg-surface);border-bottom:1px solid var(--border);min-height:28px}.outline-breadcrumb{display:flex;align-items:center;gap:4px;padding:4px 16px;cursor:pointer;font-size:12px;font-family:var(--font-mono);color:var(--text-dim);user-select:none}.outline-breadcrumb:hover{background:var(--bg-hover)}.outline-icon{font-size:14px;margin-right:4px;color:var(--text-dim)}.outline-separator{color:var(--text-dim);margin:0 2px}.outline-crumb{color:var(--text)}.outline-crumb.outline-kind-class{color:var(--yellow, #f9e2af)}.outline-crumb.outline-kind-function{color:var(--purple, #cba6f7)}.outline-crumb-empty{color:var(--text-dim);font-style:italic}.outline-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-surface);border:1px solid var(--border);border-top:none;box-shadow:0 4px 16px rgba(0,0,0,.3);max-height:320px;overflow-y:auto}.outline-item{display:flex;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-family:var(--font-mono);cursor:pointer;color:var(--text)}.outline-item:hover{background:var(--bg-hover)}.outline-item.outline-kind-class .outline-item-icon{color:var(--yellow, #f9e2af)}.outline-item.outline-kind-function .outline-item-icon{color:var(--purple, #cba6f7)}.outline-item-icon{font-size:10px;font-weight:bold;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:2px;background:hsla(0,0%,100%,.05);flex-shrink:0}.outline-item-line{color:var(--text-dim);margin-left:auto;font-size:11px}.diff-table-split{width:100%;font-family:var(--font-mono);font-size:13px;line-height:20px}.diff-table-split .hunk-separator{grid-column:1/-1}.split-row{display:grid;grid-template-columns:1fr 1fr}.split-row .diff-line{display:flex;min-width:0;overflow:hidden}.split-row .diff-line.empty{background:var(--gutter-bg);min-height:20px}.split-row .gutter{width:50px;min-width:50px;padding:0 6px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px;flex-shrink:0}.split-left{border-right:1px solid var(--border)}.diff-line{display:flex;min-height:20px;border-bottom:1px solid rgba(54,54,82,.3);cursor:pointer}.diff-line:hover{filter:brightness(1.2)}.diff-line.add{background:var(--diff-add-bg)}.diff-line.remove{background:var(--diff-remove-bg)}.diff-line.context{background:var(--diff-context-bg)}.diff-line .gutter{width:60px;min-width:60px;padding:0 8px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px;display:flex;align-items:center;justify-content:flex-end}.diff-line .code{flex:1;padding:0 12px;white-space:pre;overflow-x:auto;tab-size:4;scrollbar-width:none}.diff-line .code::-webkit-scrollbar{height:0}.diff-line.add .code::before{content:"+";color:var(--green);margin-right:4px}.diff-line.remove .code::before{content:"-";color:var(--red);margin-right:4px}.diff-line.drag-over{outline:2px solid var(--accent);outline-offset:-2px}.diff-table-unified{width:100%;font-family:var(--font-mono);font-size:13px;line-height:20px}.diff-table-unified .diff-line{display:flex;min-width:0}.diff-table-unified .gutter-old,.diff-table-unified .gutter-new{width:50px;min-width:50px;padding:0 6px;text-align:right;color:var(--gutter-text);background:var(--gutter-bg);user-select:none;font-size:12px}.hunk-separator{padding:4px 16px;background:rgba(137,180,250,.05);color:var(--text-dim);font-size:12px;font-family:var(--font-mono);border-top:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer}.hunk-separator:hover{background:rgba(137,180,250,.1)}.expand-controls{display:flex;gap:8px;padding:2px 16px;background:rgba(137,180,250,.05);border-bottom:1px solid var(--border)}.expand-btn{font-size:11px;color:var(--accent);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:3px}.expand-btn:hover{background:rgba(137,180,250,.15)}.expanded-context{background:rgba(137,180,250,.03)}.wrap-lines .code{white-space:pre-wrap !important;word-break:break-all;overflow-x:visible !important}.diff-toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--bg-surface);border-top:1px solid var(--border);flex-shrink:0}.diff-toolbar-left,.diff-toolbar-right{display:flex;align-items:center;gap:8px}.segmented-control{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.segment{padding:3px 12px;font-size:12px;background:none;border:none;color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s;font-family:var(--font-sans)}.segment:hover{color:var(--text);background:var(--bg-hover)}.segment.active{background:var(--accent);color:var(--bg)}.segment+.segment{border-left:1px solid var(--border)}.toolbar-btn{padding:3px 10px;font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);cursor:pointer;font-family:var(--font-sans);transition:background .15s,color .15s}.toolbar-btn:hover{color:var(--text);background:var(--bg-hover)}.toolbar-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.language-popup{position:fixed;z-index:1000;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);width:200px;max-height:320px;display:flex;flex-direction:column}.language-filter{padding:6px 8px;background:var(--bg);color:var(--text);border:none;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:12px;outline:none}.language-filter::placeholder{color:var(--text-dim)}.language-list{overflow-y:auto;max-height:280px}.language-option{padding:4px 10px;font-size:12px;cursor:pointer;color:var(--text);font-family:var(--font-mono)}.language-option:hover{background:var(--bg-hover)}.language-option.active{background:var(--bg-active);color:var(--accent)}.language-option.disabled{color:var(--text-dim);cursor:default;font-style:italic}.language-option.disabled:hover{background:none}.language-separator{height:1px;background:var(--border);margin:4px 0}.has-annotation .gutter{position:relative}.has-annotation .gutter::after{content:"";position:absolute;right:2px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent)}.annotation-row{padding:8px 16px 8px 76px;background:rgba(137,180,250,.05);border-left:3px solid var(--accent);font-family:var(--font-sans);font-size:13px}.annotation-row .annotation-item{display:flex;gap:8px;align-items:flex-start;padding:4px 0}.annotation-row:has(.annotation-stale){border-left-color:var(--orange);background:rgba(250,179,135,.05)}.annotation-category{font-size:11px;font-weight:600;padding:1px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0}.annotation-category[data-action=reclassify]{cursor:pointer}.annotation-category[data-action=reclassify]:hover{filter:brightness(1.3)}.category-bug{color:var(--red);background:rgba(243,139,168,.15)}.category-fix{color:var(--orange);background:rgba(250,179,135,.15)}.category-style{color:var(--purple);background:rgba(203,166,247,.15)}.category-pattern-follow{color:var(--green);background:rgba(166,227,161,.15)}.category-pattern-avoid{color:var(--red);background:rgba(243,139,168,.15)}.category-note{color:var(--blue);background:rgba(137,180,250,.15)}.category-remember{color:var(--yellow);background:rgba(249,226,175,.15)}.annotation-text{flex:1;color:var(--text);line-height:1.4}.annotation-actions{display:flex;gap:4px;flex-shrink:0}.annotation-stale{opacity:.7}.btn-keep{color:var(--orange)}.btn-keep:hover{background:rgba(250,179,135,.15)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:3px 4px}.btn-icon svg{display:block}.reclassify-popup{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px 0;box-shadow:0 4px 12px rgba(0,0,0,.3);min-width:140px}.reclassify-option{padding:6px 12px;cursor:pointer}.reclassify-option:hover{background:var(--bg-hover)}.reclassify-option.active{background:rgba(137,180,250,.1)}.annotation-drag-handle{cursor:grab;color:var(--text-dim);font-size:14px;line-height:1;flex-shrink:0;user-select:none;padding:0 2px}.annotation-drag-handle:hover{color:var(--text)}.annotation-form-container{padding:12px 16px 12px 76px;background:rgba(137,180,250,.08);border-left:3px solid var(--accent)}.annotation-form{display:flex;flex-direction:column;gap:8px}.annotation-form textarea{width:100%;min-height:60px;padding:8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;resize:vertical}.annotation-form textarea:focus{outline:none;border-color:var(--accent)}.form-category-badge{cursor:pointer;align-self:flex-start}.form-category-badge:hover{filter:brightness(1.3)}.annotation-form-actions{display:flex;gap:8px;justify-content:flex-end}.btn{padding:6px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-surface);color:var(--text);cursor:pointer;font-size:13px;transition:background .15s}.btn:hover{background:var(--bg-hover)}.btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-sm{padding:3px 10px;font-size:12px}.btn-xs{padding:2px 6px;font-size:11px}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{color:var(--red)}.btn-danger:hover{background:rgba(243,139,168,.15)}.btn-link{background:none;border:none;color:var(--accent);text-decoration:none;text-align:center}.btn-link:hover{text-decoration:underline}body:has(.history-page){overflow:auto}.history-page{max-width:800px;margin:0 auto;padding:40px 20px}.history-page h1{margin-bottom:24px}.history-item{padding:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;position:relative}.history-item h3{font-size:15px;margin-bottom:4px;padding-right:32px}.history-item .meta{font-size:12px;color:var(--text-dim)}.history-item .delete-review-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:var(--radius);font-size:16px;line-height:1;opacity:0;transition:opacity .15s,color .15s}.history-item .delete-review-btn:hover{color:var(--red);background:rgba(243,139,168,.15)}.history-item:hover .delete-review-btn{opacity:1}.bulk-actions{display:flex;gap:8px;margin:12px 0;padding:4px 0;align-items:center}.bulk-actions span{font-size:13px;color:var(--text-dim);margin-right:auto}.status-badge{display:inline-block;font-size:11px;padding:1px 8px;border-radius:10px;font-weight:500}.status-badge.in_progress,.status-badge.in-progress{color:var(--yellow);background:rgba(249,226,175,.15)}.status-badge.completed{color:var(--green);background:rgba(166,227,161,.15)}.history-item-link{text-decoration:none;color:inherit;display:block}.history-item-link:hover .history-item{border-color:var(--accent);background:var(--bg-hover)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:480px;width:90%}.modal h3{margin-bottom:12px}.modal p{margin-bottom:16px;color:var(--text-dim);font-size:14px}.modal-label{margin-bottom:4px !important;font-size:13px !important;color:var(--text-dim) !important}.modal-copyable{font-family:var(--font-mono);font-size:12px;color:var(--accent);background:var(--bg);padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;cursor:pointer;position:relative;word-break:break-all;transition:border-color .15s}.modal-copyable:hover{border-color:var(--accent)}.modal-copyable.copied::after{content:"Copied!";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--green);font-family:var(--font-sans)}.modal-gitignore{margin-bottom:16px;padding-top:12px;border-top:1px solid var(--border)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.hljs-keyword,.hljs-selector-tag,.hljs-built_in,.hljs-name{color:var(--purple)}.hljs-string,.hljs-attr,.hljs-template-variable,.hljs-addition{color:var(--green)}.hljs-comment,.hljs-quote{color:var(--text-dim);font-style:italic}.hljs-number,.hljs-literal,.hljs-selector-id{color:var(--orange)}.hljs-type,.hljs-class .hljs-title,.hljs-title.class_,.hljs-title.function_{color:var(--yellow)}.hljs-variable,.hljs-template-variable{color:var(--red)}.hljs-regexp,.hljs-link{color:var(--teal)}.hljs-symbol,.hljs-bullet{color:var(--orange)}.hljs-meta,.hljs-meta .hljs-keyword{color:var(--blue)}.hljs-deletion{color:var(--red)}.hljs-section,.hljs-title{color:var(--blue);font-weight:600}.hljs-attribute{color:var(--yellow)}.hljs-tag{color:var(--red)}.hljs-tag .hljs-name{color:var(--red)}.hljs-tag .hljs-attr{color:var(--yellow)}.hljs-params{color:var(--text)}.hljs-property{color:var(--blue)}.hljs-punctuation{color:var(--text-dim)}.hljs-operator{color:var(--teal)}.hljs-subst{color:var(--text)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "glassbox",
3
- "version": "0.1.1",
3
+ "version": "0.1.2",
4
4
  "description": "A local code review tool for AI-generated code. Review diffs, annotate lines, and export structured feedback that AI tools can act on.",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -28,8 +28,9 @@
28
28
  "glassbox": "./dist/cli.js"
29
29
  },
30
30
  "scripts": {
31
- "dev": "tsx --tsconfig tsconfig.json src/cli.ts",
31
+ "dev": "npm run build:client && tsx --tsconfig tsconfig.json src/cli.ts",
32
32
  "build": "tsup",
33
+ "build:client": "mkdir -p dist/client && npx esbuild src/client/app.ts --bundle --format=iife --outfile=dist/client/app.global.js --target=es2020 --jsx=automatic --jsx-import-source=#jsx --alias:#jsx/jsx-runtime=./src/jsx-runtime.ts && npx sass src/client/styles.scss dist/client/styles.css --style compressed --no-source-map",
33
34
  "clean": "rm -rf dist node_modules/.cache",
34
35
  "release": "bash scripts/release.sh",
35
36
  "prepublishOnly": "npm run build"
@@ -46,6 +47,8 @@
46
47
  "devDependencies": {
47
48
  "@types/node": "^22.0.0",
48
49
  "esbuild": "^0.27.3",
50
+ "highlight.js": "^11.11.1",
51
+ "sass": "^1.97.3",
49
52
  "tsup": "^8.5.1",
50
53
  "tsx": "^4.21.0",
51
54
  "typescript": "^5.9.3"