glassbox 0.6.0 → 0.7.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/dist/cli.js +1149 -442
- package/dist/client/app.global.js +8 -8
- package/dist/client/history.global.js +1 -1
- package/dist/client/styles.css +1 -1
- package/package.json +7 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";(()=>{var h=Object.defineProperty;var k=(e,t,n)=>t in e?h(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var s=(e,t,n)=>k(e,typeof t!="symbol"?t+"":t,n);function c(e){let t=document.createElement("template");return t.innerHTML=String(e).trim(),t.content.firstElementChild}function p(e){return e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function m(e){return e.replace(/&/g,"&").replace(/"/g,""").replace(/'/g,"'").replace(/</g,"<").replace(/>/g,">")}var i=class{constructor(t){s(this,"__html");this.__html=t}toString(){return this.__html}};var y=new Set(["area","base","br","col","embed","hr","img","input","link","meta","source","track","wbr"]);function d(e){return e==null||typeof e=="boolean"?"":e instanceof i?e.__html:typeof e=="string"?p(e):typeof e=="number"?String(e):Array.isArray(e)?e.map(d).join(""):""}var x={className:"class",htmlFor:"for",httpEquiv:"http-equiv",acceptCharset:"accept-charset",accessKey:"accesskey",autoCapitalize:"autocapitalize",autoComplete:"autocomplete",autoFocus:"autofocus",autoPlay:"autoplay",colSpan:"colspan",contentEditable:"contenteditable",crossOrigin:"crossorigin",dateTime:"datetime",defaultChecked:"checked",defaultValue:"value",encType:"enctype",formAction:"formaction",formEncType:"formenctype",formMethod:"formmethod",formNoValidate:"formnovalidate",formTarget:"formtarget",hrefLang:"hreflang",inputMode:"inputmode",maxLength:"maxlength",minLength:"minlength",noModule:"nomodule",noValidate:"novalidate",readOnly:"readonly",referrerPolicy:"referrerpolicy",rowSpan:"rowspan",spellCheck:"spellcheck",srcDoc:"srcdoc",srcLang:"srclang",srcSet:"srcset",tabIndex:"tabindex",useMap:"usemap",strokeWidth:"stroke-width",strokeLinecap:"stroke-linecap",strokeLinejoin:"stroke-linejoin",strokeDasharray:"stroke-dasharray",strokeDashoffset:"stroke-dashoffset",strokeMiterlimit:"stroke-miterlimit",strokeOpacity:"stroke-opacity",fillOpacity:"fill-opacity",fillRule:"fill-rule",clipPath:"clip-path",clipRule:"clip-rule",colorInterpolation:"color-interpolation",colorInterpolationFilters:"color-interpolation-filters",floodColor:"flood-color",floodOpacity:"flood-opacity",lightingColor:"lighting-color",stopColor:"stop-color",stopOpacity:"stop-opacity",shapeRendering:"shape-rendering",imageRendering:"image-rendering",textRendering:"text-rendering",pointerEvents:"pointer-events",vectorEffect:"vector-effect",paintOrder:"paint-order",fontFamily:"font-family",fontSize:"font-size",fontStyle:"font-style",fontVariant:"font-variant",fontWeight:"font-weight",fontStretch:"font-stretch",textAnchor:"text-anchor",textDecoration:"text-decoration",dominantBaseline:"dominant-baseline",alignmentBaseline:"alignment-baseline",baselineShift:"baseline-shift",letterSpacing:"letter-spacing",wordSpacing:"word-spacing",writingMode:"writing-mode",glyphOrientationHorizontal:"glyph-orientation-horizontal",glyphOrientationVertical:"glyph-orientation-vertical",markerStart:"marker-start",markerMid:"marker-mid",markerEnd:"marker-end",gradientUnits:"gradientUnits",gradientTransform:"gradientTransform",spreadMethod:"spreadMethod",patternUnits:"patternUnits",patternContentUnits:"patternContentUnits",patternTransform:"patternTransform",maskUnits:"maskUnits",maskContentUnits:"maskContentUnits",filterUnits:"filterUnits",primitiveUnits:"primitiveUnits",clipPathUnits:"clipPathUnits",xlinkHref:"xlink:href",xlinkShow:"xlink:show",xlinkActuate:"xlink:actuate",xlinkType:"xlink:type",xlinkRole:"xlink:role",xlinkTitle:"xlink:title",xlinkArcrole:"xlink:arcrole",xmlBase:"xml:base",xmlLang:"xml:lang",xmlSpace:"xml:space",xmlns:"xmlns",xmlnsXlink:"xmlns:xlink",stdDeviation:"stdDeviation",baseFrequency:"baseFrequency",numOctaves:"numOctaves",kernelMatrix:"kernelMatrix",surfaceScale:"surfaceScale",specularConstant:"specularConstant",specularExponent:"specularExponent",diffuseConstant:"diffuseConstant",pointsAtX:"pointsAtX",pointsAtY:"pointsAtY",pointsAtZ:"pointsAtZ",limitingConeAngle:"limitingConeAngle",tableValues:"tableValues"};function b(e,t){let n=x[e]??e;if(t==null||t===!1)return"";if(t===!0)return` ${n}`;let r;return t instanceof i?r=t.__html:typeof t=="number"?r=String(t):typeof t=="string"?r=m(t):r="",` ${n}="${r}"`}function o(e,t){if(typeof e=="function")return e(t);let{children:n,...r}=t,l=Object.entries(r).map(([u,g])=>b(u,g)).join("");if(y.has(e))return new i(`<${e}${l}>`);let f=n!=null?d(n):"";return new i(`<${e}${l}>${f}</${e}>`)}function
|
|
1
|
+
"use strict";(()=>{var h=Object.defineProperty;var k=(e,t,n)=>t in e?h(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var s=(e,t,n)=>k(e,typeof t!="symbol"?t+"":t,n);function c(e){let t=document.createElement("template");return t.innerHTML=String(e).trim(),t.content.firstElementChild}function p(e){return e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function m(e){return e.replace(/&/g,"&").replace(/"/g,""").replace(/'/g,"'").replace(/</g,"<").replace(/>/g,">")}var i=class{constructor(t){s(this,"__html");this.__html=t}toString(){return this.__html}};var y=new Set(["area","base","br","col","embed","hr","img","input","link","meta","source","track","wbr"]);function d(e){return e==null||typeof e=="boolean"?"":e instanceof i?e.__html:typeof e=="string"?p(e):typeof e=="number"?String(e):Array.isArray(e)?e.map(d).join(""):""}var x={className:"class",htmlFor:"for",httpEquiv:"http-equiv",acceptCharset:"accept-charset",accessKey:"accesskey",autoCapitalize:"autocapitalize",autoComplete:"autocomplete",autoFocus:"autofocus",autoPlay:"autoplay",colSpan:"colspan",contentEditable:"contenteditable",crossOrigin:"crossorigin",dateTime:"datetime",defaultChecked:"checked",defaultValue:"value",encType:"enctype",formAction:"formaction",formEncType:"formenctype",formMethod:"formmethod",formNoValidate:"formnovalidate",formTarget:"formtarget",hrefLang:"hreflang",inputMode:"inputmode",maxLength:"maxlength",minLength:"minlength",noModule:"nomodule",noValidate:"novalidate",readOnly:"readonly",referrerPolicy:"referrerpolicy",rowSpan:"rowspan",spellCheck:"spellcheck",srcDoc:"srcdoc",srcLang:"srclang",srcSet:"srcset",tabIndex:"tabindex",useMap:"usemap",strokeWidth:"stroke-width",strokeLinecap:"stroke-linecap",strokeLinejoin:"stroke-linejoin",strokeDasharray:"stroke-dasharray",strokeDashoffset:"stroke-dashoffset",strokeMiterlimit:"stroke-miterlimit",strokeOpacity:"stroke-opacity",fillOpacity:"fill-opacity",fillRule:"fill-rule",clipPath:"clip-path",clipRule:"clip-rule",colorInterpolation:"color-interpolation",colorInterpolationFilters:"color-interpolation-filters",floodColor:"flood-color",floodOpacity:"flood-opacity",lightingColor:"lighting-color",stopColor:"stop-color",stopOpacity:"stop-opacity",shapeRendering:"shape-rendering",imageRendering:"image-rendering",textRendering:"text-rendering",pointerEvents:"pointer-events",vectorEffect:"vector-effect",paintOrder:"paint-order",fontFamily:"font-family",fontSize:"font-size",fontStyle:"font-style",fontVariant:"font-variant",fontWeight:"font-weight",fontStretch:"font-stretch",textAnchor:"text-anchor",textDecoration:"text-decoration",dominantBaseline:"dominant-baseline",alignmentBaseline:"alignment-baseline",baselineShift:"baseline-shift",letterSpacing:"letter-spacing",wordSpacing:"word-spacing",writingMode:"writing-mode",glyphOrientationHorizontal:"glyph-orientation-horizontal",glyphOrientationVertical:"glyph-orientation-vertical",markerStart:"marker-start",markerMid:"marker-mid",markerEnd:"marker-end",gradientUnits:"gradientUnits",gradientTransform:"gradientTransform",spreadMethod:"spreadMethod",patternUnits:"patternUnits",patternContentUnits:"patternContentUnits",patternTransform:"patternTransform",maskUnits:"maskUnits",maskContentUnits:"maskContentUnits",filterUnits:"filterUnits",primitiveUnits:"primitiveUnits",clipPathUnits:"clipPathUnits",xlinkHref:"xlink:href",xlinkShow:"xlink:show",xlinkActuate:"xlink:actuate",xlinkType:"xlink:type",xlinkRole:"xlink:role",xlinkTitle:"xlink:title",xlinkArcrole:"xlink:arcrole",xmlBase:"xml:base",xmlLang:"xml:lang",xmlSpace:"xml:space",xmlns:"xmlns",xmlnsXlink:"xmlns:xlink",stdDeviation:"stdDeviation",baseFrequency:"baseFrequency",numOctaves:"numOctaves",kernelMatrix:"kernelMatrix",surfaceScale:"surfaceScale",specularConstant:"specularConstant",specularExponent:"specularExponent",diffuseConstant:"diffuseConstant",pointsAtX:"pointsAtX",pointsAtY:"pointsAtY",pointsAtZ:"pointsAtZ",limitingConeAngle:"limitingConeAngle",tableValues:"tableValues"};function b(e,t){let n=x[e]??e;if(t==null||t===!1)return"";if(t===!0)return` ${n}`;let r;return t instanceof i?r=t.__html:typeof t=="number"?r=String(t):typeof t=="string"?r=m(t):r="",` ${n}="${r}"`}function o(e,t){if(typeof e=="function")return e(t);let{children:n,...r}=t,l=Object.entries(r).map(([u,g])=>b(u,g)).join("");if(y.has(e))return new i(`<${e}${l}>`);let f=n!=null?d(n):"";return new i(`<${e}${l}>${f}</${e}>`)}function v(){let e=document.querySelector(".bulk-actions");e&&!document.querySelector(".delete-review-btn")&&e.remove()}function a(e,t){let n=c(o("div",{className:"modal-overlay",children:o("div",{className:"modal",children:[o("h3",{children:"Confirm"}),o("p",{children:e}),o("div",{className:"modal-actions",children:[o("button",{className:"btn btn-sm modal-cancel",children:"Cancel"}),o("button",{className:"btn btn-sm btn-danger modal-confirm",children:"Delete"})]})]})}));n.querySelector(".modal-cancel")?.addEventListener("click",()=>{n.remove()}),n.querySelector(".modal-confirm")?.addEventListener("click",()=>{n.remove(),t()}),n.addEventListener("click",r=>{r.target===n&&n.remove()}),document.body.appendChild(n)}document.querySelectorAll(".delete-review-btn").forEach(e=>{e.addEventListener("click",t=>{t.preventDefault(),t.stopPropagation();let n=e.dataset.deleteId??"";a("Delete this review? This cannot be undone.",()=>{fetch("/api/review/"+encodeURIComponent(n),{method:"DELETE"}).then(r=>r.json()).then(()=>{e.closest(".history-item-link")?.parentElement?.remove(),v()})})})});document.getElementById("delete-completed-btn")?.addEventListener("click",()=>{a("Delete all completed reviews (except current)? This cannot be undone.",()=>{fetch("/api/reviews/delete-completed",{method:"POST",headers:{"Content-Type":"application/json"}}).then(e=>e.json()).then(()=>{location.reload()})})});document.getElementById("delete-all-btn")?.addEventListener("click",()=>{a("Delete ALL reviews except the current one? This cannot be undone.",()=>{fetch("/api/reviews/delete-all",{method:"POST",headers:{"Content-Type":"application/json"}}).then(e=>e.json()).then(()=>{location.reload()})})});})();
|
package/dist/client/styles.css
CHANGED
|
@@ -1 +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;flex-direction:column;height:100vh}.review-body{display:flex;flex:1;overflow:hidden}.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{position:relative;padding:16px;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:16px;font-weight:600;color:var(--text-bright);padding-right:52px}.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;min-height:0;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-nav-bar{display:flex;align-items:center;gap:2px;padding:4px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.nav-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 4px;border-radius:var(--radius);display:flex;align-items:center}.nav-btn:hover:not(.disabled){color:var(--text);background:var(--bg-hover)}.nav-btn.disabled{opacity:.3;cursor:default}.nav-btn svg{display:block}.nav-file-path{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);margin-left:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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-file{display:flex;align-items:center;min-width:0}.diff-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.reveal-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 4px;border-radius:var(--radius);display:flex;align-items:center;margin-left:4px;flex-shrink:0}.reveal-btn:hover{color:var(--text);background:var(--bg-hover)}.reveal-btn svg{display:block}.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-row .gutter::after{content:attr(data-line-number)}.split-columns{display:flex}.split-columns .split-col{flex:1;min-width:0;overflow:hidden}.split-columns .diff-line{display:flex;min-width:0;overflow:hidden}.split-columns .diff-line.empty{background:var(--gutter-bg);min-height:20px}.split-columns .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-columns .gutter::after{content:attr(data-line-number)}.split-columns .split-col-left{border-right:1px solid var(--border)}.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 .gutter::after{content:attr(data-line-number)}.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.add .char-change{background:rgba(166,227,161,.25);border-radius:2px}.diff-line.remove .char-change{background:rgba(243,139,168,.25);border-radius:2px}.diff-line.jump-highlight{animation:jump-flash 1.5s ease-out}.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}.diff-table-unified .gutter-old::after,.diff-table-unified .gutter-new::after{content:attr(data-line-number)}.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}.find-bar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.find-input{width:240px;padding:4px 8px;font-size:13px;font-family:var(--font-mono);background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);outline:none}.find-input:focus{border-color:var(--accent)}.find-match-count{font-size:12px;color:var(--text-dim);min-width:60px}.find-nav-btn,.find-close-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 6px;font-size:13px;border-radius:var(--radius)}.find-nav-btn:hover,.find-close-btn:hover{color:var(--text);background:var(--bg-hover)}.find-highlight{background:rgba(250,204,21,.35);border-radius:2px}.find-highlight-active{background:rgba(250,204,21,.7);outline:2px solid rgba(250,204,21,.9)}.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}.goto-toast{position:fixed;bottom:60px;left:50%;transform:translateX(-50%);padding:6px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);font-size:13px;z-index:1000;animation:toast-fade 2s ease-out forwards}@keyframes toast-fade{0%,70%{opacity:1}100%{opacity:0}}@keyframes jump-flash{0%{background:rgba(137,180,250,.3)}100%{background:rgba(0,0,0,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}.sort-mode-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;border-bottom:1px solid var(--border)}.sort-mode-control{flex-shrink:0}.sort-mode-control .sort-segment{padding:3px 8px;display:inline-flex;align-items:center;justify-content:center}.sort-mode-control .sort-segment svg{display:block}.sort-risk-controls{display:flex;align-items:center;gap:4px;margin-left:auto}.sort-risk-toggle{font-size:11px;padding:2px 6px}.sort-dimension-select{font-size:11px;padding:2px 4px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);cursor:pointer}.sort-dimension-select:focus{outline:none;border-color:var(--accent)}.risk-badge{font-size:11px;font-weight:600;font-family:var(--font-mono);padding:0 4px;border-radius:3px;cursor:pointer;flex-shrink:0;min-width:32px;text-align:center;background:hsla(0,0%,100%,.05)}.risk-badge:hover{background:hsla(0,0%,100%,.1)}.risk-critical{background:rgba(243,139,168,.15) !important}.risk-high{background:rgba(250,179,135,.15) !important}.risk-medium{background:rgba(249,226,175,.15) !important}.risk-low{background:rgba(166,227,161,.15) !important}.risk-popover{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);padding:12px;min-width:240px;max-width:320px}.risk-popover-header{font-size:12px;font-weight:600;color:var(--text-bright);margin-bottom:8px}.risk-popover-dimensions{display:flex;flex-direction:column;gap:4px}.risk-dimension-row{display:flex;align-items:center;gap:8px;font-size:11px}.risk-dimension-label{width:90px;flex-shrink:0;color:var(--text-dim);text-transform:capitalize}.risk-dimension-bar-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.risk-dimension-bar-fill{height:100%;border-radius:2px;transition:width .3s}.risk-dimension-value{width:28px;text-align:right;font-family:var(--font-mono);font-size:10px;flex-shrink:0}.risk-popover-rationale{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim);line-height:1.4}.narrative-position{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-dim);background:hsla(0,0%,100%,.05);border-radius:50%;flex-shrink:0}.file-path-dim{font-size:10px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;font-family:var(--font-mono)}.analysis-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 16px;color:var(--text-dim);font-size:13px}.analysis-loading-inline{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-dim);font-size:12px;border-bottom:1px solid var(--border);background:hsla(0,0%,100%,.02)}.analysis-progress-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.analysis-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.analysis-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.analysis-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.analysis-spinner-sm{width:14px;height:14px;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.analysis-error{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;color:var(--red);font-size:12px;text-align:center;overflow-wrap:break-word;word-break:break-word;overflow:hidden;max-width:100%}.ai-note-overview{padding:8px 12px;font-size:12px;line-height:1.5;border-bottom:1px solid var(--border)}.ai-note-risk.ai-note-overview{background:rgba(243,139,168,.06)}.ai-note-risk.ai-note-row{background:rgba(243,139,168,.06)}.ai-note-narrative.ai-note-overview{background:rgba(137,180,250,.06)}.ai-note-narrative.ai-note-row{background:rgba(137,180,250,.06)}.ai-note-overview-content{display:flex;align-items:flex-start;gap:8px}.ai-note-label{font-size:10px;font-weight:600;text-transform:uppercase;padding:1px 5px;border-radius:3px;flex-shrink:0;letter-spacing:.5px}.ai-note-label-risk{color:var(--red);background:rgba(243,139,168,.15)}.ai-note-label-narrative{color:var(--blue, #89b4fa);background:rgba(137,180,250,.15)}.ai-note-guided.ai-note-overview{background:rgba(166,227,161,.06)}.ai-note-guided.ai-note-row{background:rgba(166,227,161,.06)}.ai-note-label-guided{color:var(--green, #a6e3a1);background:rgba(166,227,161,.15)}.ai-note-text{color:var(--text-dim)}.ai-note-row{padding:4px 12px 4px 60px;border-top:1px solid hsla(0,0%,100%,.03)}.ai-note-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.4}.settings-dialog{max-width:480px;padding:0;display:flex;flex-direction:column;max-height:85vh;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.settings-header h3{margin-bottom:0}.settings-close{background:none;border:none;color:var(--text-dim);font-size:20px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:var(--radius)}.settings-close:hover{color:var(--text);background:var(--bg-hover)}.settings-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;padding:0 12px;gap:2px}.settings-tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px 10px;font-size:11px;font-family:var(--font-sans);color:var(--text-dim);border:none;border-bottom:2px solid rgba(0,0,0,0);margin-bottom:-1px;background:none;cursor:pointer;transition:color .15s}.settings-tab svg{flex-shrink:0}.settings-tab:hover{color:var(--text)}.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.settings-body{padding:20px;overflow-y:auto;flex:1;min-height:0}.settings-tab-panel{display:none}.settings-tab-panel.active{display:block}.settings-section{margin-bottom:16px}.settings-section-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.settings-heading{font-size:13px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.04em}.settings-beta-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--orange);background:color-mix(in srgb, var(--orange) 15%, transparent);padding:1px 5px;border-radius:3px;line-height:1.4}.settings-disclaimer{font-size:11px;color:var(--text-dim);margin-bottom:12px;line-height:1.4}.settings-hint{font-size:11px;color:var(--text-dim);margin-top:4px;line-height:1.4}.settings-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.settings-label{display:block;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:6px}.settings-label.settings-label-spaced{margin-top:12px}.settings-platform-control{width:100%}.settings-platform-control .segment{flex:1;text-align:center}.settings-select{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;cursor:pointer}.settings-select:focus{outline:none;border-color:var(--accent)}.settings-input{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;margin-top:8px}.settings-input:focus{outline:none;border-color:var(--accent)}.settings-input::placeholder{color:var(--text-dim)}.settings-key-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.settings-key-status svg{flex-shrink:0}.settings-key-status.settings-key-configured{color:var(--green)}.settings-key-missing{color:var(--orange)}.settings-key-input-group{margin-top:4px}.settings-key-row{display:flex;gap:8px;align-items:flex-end}.settings-key-row .settings-input{flex:1}.settings-key-row .btn{flex-shrink:0;margin-top:8px}.settings-storage-options{display:flex;flex-direction:column;gap:4px;margin-top:8px}.settings-radio{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text);cursor:pointer}.settings-radio input[type=radio]{accent-color:var(--accent)}.settings-warning{font-size:11px;color:var(--orange);margin-top:4px;line-height:1.4}.settings-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}.settings-checkbox input[type=checkbox]{accent-color:var(--accent)}.settings-guided-topics{margin-bottom:16px}.settings-tags{display:flex;flex-wrap:wrap;gap:6px}.settings-tag{font-size:12px;padding:3px 10px;border-radius:12px;border:1px solid var(--border);background:rgba(0,0,0,0);color:var(--text-dim);cursor:pointer;transition:all .15s ease;font-family:var(--font-sans)}.settings-tag:hover{border-color:var(--accent);color:var(--text)}.settings-tag.active{background:color-mix(in srgb, var(--accent) 20%, transparent);border-color:var(--accent);color:var(--accent);font-weight:500}.settings-more-toggle{display:block;margin-top:8px;padding:0;border:none;background:none;color:var(--accent);font-size:11px;cursor:pointer;font-family:var(--font-sans)}.settings-more-toggle:hover{text-decoration:underline}.settings-tags-more{margin-top:8px}.sidebar-header-btn,.refresh-btn,.settings-gear{position:absolute;top:12px;padding:4px;color:var(--text-dim);background:none;border:none;cursor:pointer;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.sidebar-header-btn:hover,.refresh-btn:hover,.settings-gear:hover{color:var(--text);background:var(--bg-hover)}.sidebar-header-btn svg,.refresh-btn svg,.settings-gear svg{display:block}.settings-gear{right:12px}.refresh-btn{right:36px}.settings-dialog .modal-actions{padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0}.update-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 20px;background:#dcfce7;border-bottom:2px solid #22c55e;font-size:13px;color:#166534;flex-shrink:0}@media(prefers-color-scheme: dark){.update-banner{background:#14532d;border-bottom-color:#22c55e;color:#86efac}}.update-banner-actions{display:flex;gap:8px;flex-shrink:0}.btn-accent{color:#fff;background:#22c55e;border-color:#22c55e}.btn-accent:hover:not(:disabled){background:#16a34a}.btn-accent:disabled{opacity:.7;cursor:default}.image-diff{padding:0}.image-diff .image-diff-metadata{padding:16px}.image-diff-panel{display:none}.image-diff-panel.active{display:block}.image-font-warning{padding:8px 16px;font-size:12px;color:var(--yellow, #f9e2af);background:rgba(249,226,175,.08);border-bottom:1px solid rgba(249,226,175,.15)}.image-metadata-loading,.image-metadata-error{padding:12px 16px;color:var(--text-dim);font-size:13px;font-family:var(--font-mono)}.image-metadata-diff,.image-metadata-single{font-family:var(--font-mono);font-size:13px;line-height:20px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.metadata-line{padding:2px 16px}.metadata-line.context{color:var(--text)}.metadata-line.add{background:rgba(166,227,161,.1);color:var(--green)}.metadata-line.add::before{content:"+ "}.metadata-line.remove{background:rgba(243,139,168,.1);color:var(--red)}.metadata-line.remove::before{content:"- "}.image-visual-canvas{height:calc(100vh - 80px);display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.image-zoom-wrap{position:relative;transform-origin:0 0}.image-zoom-wrap .image-layer{position:absolute;top:0;left:0;width:100%;height:100%}[data-panel=difference] .image-visual-canvas{background:#000}[data-panel=difference] .image-layer-old{z-index:1}[data-panel=difference] .image-blend{z-index:2;mix-blend-mode:difference}.image-slice-clipped{z-index:2}.slice-line{position:absolute;height:2px;background:var(--accent);z-index:10;pointer-events:none}.slice-handle{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);z-index:11;cursor:grab;transform:translate(-50%, -50%);box-shadow:0 1px 4px rgba(0,0,0,.4)}.slice-handle:active{cursor:grabbing}.diff-toolbar-image{display:flex;align-items:center;justify-content:space-between;width:100%}.diff-toolbar-image .diff-toolbar-left,.diff-toolbar-image .diff-toolbar-right{display:flex;align-items:center;gap:4px}.image-zoom-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-dim);cursor:pointer;font-size:16px;padding:0}.image-zoom-btn:hover{color:var(--text);background:var(--bg-hover)}.image-zoom-btn svg{display:block}.diff-toolbar-text{display:flex;align-items:center;justify-content:space-between;width:100%}.diff-toolbar-svg-toggle{display:flex;align-items:center;margin-right:12px;flex-shrink:0}.diff-toolbar.svg-file .diff-toolbar-text,.diff-toolbar.svg-file .diff-toolbar-image{width:auto;flex:1}.image-diff-single{display:flex;flex-direction:column;align-items:center;padding:24px}.image-diff-single img{max-width:100%;max-height:70vh;border:1px solid var(--border);border-radius:var(--radius)}.image-diff-status{margin-top:8px;color:var(--text-dim);font-size:13px}
|
|
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;flex-direction:column;height:100vh}.review-body{display:flex;flex:1;overflow:hidden}.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{position:relative;padding:16px;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:16px;font-weight:600;color:var(--text-bright);padding-right:52px}.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;min-height:0;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-nav-bar{display:flex;align-items:center;gap:2px;padding:4px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.nav-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 4px;border-radius:var(--radius);display:flex;align-items:center}.nav-btn:hover:not(.disabled){color:var(--text);background:var(--bg-hover)}.nav-btn.disabled{opacity:.3;cursor:default}.nav-btn svg{display:block}.nav-file-path{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);margin-left:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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-file{display:flex;align-items:center;min-width:0}.diff-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.reveal-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 4px;border-radius:var(--radius);display:flex;align-items:center;margin-left:4px;flex-shrink:0}.reveal-btn:hover{color:var(--text);background:var(--bg-hover)}.reveal-btn svg{display:block}.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-row .gutter::after{content:attr(data-line-number)}.split-columns{display:flex}.split-columns .split-col{flex:1;min-width:0;overflow:hidden}.split-columns .diff-line{display:flex;min-width:0;overflow:hidden}.split-columns .diff-line.empty{background:var(--gutter-bg);min-height:20px}.split-columns .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-columns .gutter::after{content:attr(data-line-number)}.split-columns .split-col-left{border-right:1px solid var(--border)}.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 .gutter::after{content:attr(data-line-number)}.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.add .char-change{background:rgba(166,227,161,.25);border-radius:2px}.diff-line.remove .char-change{background:rgba(243,139,168,.25);border-radius:2px}.diff-line.jump-highlight{animation:jump-flash 1.5s ease-out}.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}.diff-table-unified .gutter-old::after,.diff-table-unified .gutter-new::after{content:attr(data-line-number)}.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}.find-bar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.find-input{width:240px;padding:4px 8px;font-size:13px;font-family:var(--font-mono);background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);outline:none}.find-input:focus{border-color:var(--accent)}.find-match-count{font-size:12px;color:var(--text-dim);min-width:60px}.find-nav-btn,.find-close-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 6px;font-size:13px;border-radius:var(--radius)}.find-nav-btn:hover,.find-close-btn:hover{color:var(--text);background:var(--bg-hover)}.find-highlight{background:rgba(250,204,21,.35);border-radius:2px}.find-highlight-active{background:rgba(250,204,21,.7);outline:2px solid rgba(250,204,21,.9)}.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}.goto-toast{position:fixed;bottom:60px;left:50%;transform:translateX(-50%);padding:6px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);font-size:13px;z-index:1000;animation:toast-fade 2s ease-out forwards}@keyframes toast-fade{0%,70%{opacity:1}100%{opacity:0}}@keyframes jump-flash{0%{background:rgba(137,180,250,.3)}100%{background:rgba(0,0,0,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}.sort-mode-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;border-bottom:1px solid var(--border)}.sort-mode-control{flex-shrink:0}.sort-mode-control .sort-segment{padding:3px 8px;display:inline-flex;align-items:center;justify-content:center}.sort-mode-control .sort-segment svg{display:block}.sort-risk-controls{display:flex;align-items:center;gap:4px;margin-left:auto}.sort-risk-toggle{font-size:11px;padding:2px 6px}.sort-dimension-select{font-size:11px;padding:2px 4px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);cursor:pointer}.sort-dimension-select:focus{outline:none;border-color:var(--accent)}.risk-badge{font-size:11px;font-weight:600;font-family:var(--font-mono);padding:0 4px;border-radius:3px;cursor:pointer;flex-shrink:0;min-width:32px;text-align:center;background:hsla(0,0%,100%,.05)}.risk-badge:hover{background:hsla(0,0%,100%,.1)}.risk-critical{background:rgba(243,139,168,.15) !important}.risk-high{background:rgba(250,179,135,.15) !important}.risk-medium{background:rgba(249,226,175,.15) !important}.risk-low{background:rgba(166,227,161,.15) !important}.risk-popover{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.4);padding:12px;min-width:240px;max-width:320px}.risk-popover-header{font-size:12px;font-weight:600;color:var(--text-bright);margin-bottom:8px}.risk-popover-dimensions{display:flex;flex-direction:column;gap:4px}.risk-dimension-row{display:flex;align-items:center;gap:8px;font-size:11px}.risk-dimension-label{width:90px;flex-shrink:0;color:var(--text-dim);text-transform:capitalize}.risk-dimension-bar-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.risk-dimension-bar-fill{height:100%;border-radius:2px;transition:width .3s}.risk-dimension-value{width:28px;text-align:right;font-family:var(--font-mono);font-size:10px;flex-shrink:0}.risk-popover-rationale{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim);line-height:1.4}.narrative-position{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-dim);background:hsla(0,0%,100%,.05);border-radius:50%;flex-shrink:0}.file-path-dim{font-size:10px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;font-family:var(--font-mono)}.analysis-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 16px;color:var(--text-dim);font-size:13px}.analysis-loading-inline{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-dim);font-size:12px;border-bottom:1px solid var(--border);background:hsla(0,0%,100%,.02)}.analysis-progress-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.analysis-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.analysis-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.analysis-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.analysis-spinner-sm{width:14px;height:14px;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.analysis-error{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;color:var(--red);font-size:12px;text-align:center;overflow-wrap:break-word;word-break:break-word;overflow:hidden;max-width:100%}.ai-note-overview{padding:8px 12px;font-size:12px;line-height:1.5;border-bottom:1px solid var(--border)}.ai-note-risk.ai-note-overview{background:rgba(243,139,168,.06)}.ai-note-risk.ai-note-row{background:rgba(243,139,168,.06)}.ai-note-narrative.ai-note-overview{background:rgba(137,180,250,.06)}.ai-note-narrative.ai-note-row{background:rgba(137,180,250,.06)}.ai-note-overview-content{display:flex;align-items:flex-start;gap:8px}.ai-note-label{font-size:10px;font-weight:600;text-transform:uppercase;padding:1px 5px;border-radius:3px;flex-shrink:0;letter-spacing:.5px}.ai-note-label-risk{color:var(--red);background:rgba(243,139,168,.15)}.ai-note-label-narrative{color:var(--blue, #89b4fa);background:rgba(137,180,250,.15)}.ai-note-guided.ai-note-overview{background:rgba(166,227,161,.06)}.ai-note-guided.ai-note-row{background:rgba(166,227,161,.06)}.ai-note-label-guided{color:var(--green, #a6e3a1);background:rgba(166,227,161,.15)}.ai-note-text{color:var(--text-dim)}.ai-note-row{padding:4px 12px 4px 60px;border-top:1px solid hsla(0,0%,100%,.03)}.ai-note-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.4}.theme-editor-dialog{max-width:520px}.theme-editor-body{padding:12px 20px 20px;overflow-y:auto;max-height:65vh}.theme-editor-toolbar{display:flex;justify-content:flex-end;margin-bottom:12px}.theme-editor-group{margin-bottom:16px}.theme-editor-group-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.theme-editor-row{display:flex;align-items:center;gap:8px;padding:4px 0}.theme-editor-row:hover{background:var(--bg-hover);border-radius:4px}.theme-editor-label{flex:1;font-size:13px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-editor-swatch{width:20px;height:20px;border-radius:4px;border:1px solid rgba(128,128,128,.3);flex-shrink:0}.theme-editor-picker{width:28px;height:24px;padding:0;border:none;background:none;cursor:pointer;flex-shrink:0}.theme-editor-hex{width:110px;font-size:12px;font-family:var(--font-mono);padding:3px 6px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;flex-shrink:0}.theme-editor-reset{font-size:14px;padding:2px 6px;flex-shrink:0}.theme-manager-dialog{max-width:420px}.theme-manager-body{padding:12px 20px 20px;overflow-y:auto;max-height:60vh}.theme-manager-list{display:flex;flex-direction:column;gap:2px}.theme-manager-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--radius);cursor:pointer;gap:8px}.theme-manager-item:hover{background:var(--bg-hover)}.theme-manager-item.active{background:var(--bg-active)}.theme-manager-info{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.theme-manager-swatches{display:flex;gap:3px;flex-shrink:0}.theme-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid rgba(128,128,128,.3)}.theme-manager-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-manager-badge{font-size:10px;padding:1px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0}.theme-manager-badge.active{color:var(--green);border:1px solid var(--green);opacity:.7}.theme-manager-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);padding:12px 12px 4px}.tm-menu-btn{flex-shrink:0;opacity:.5}.tm-menu-btn:hover{opacity:1}.tm-context-menu{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px;box-shadow:0 4px 16px rgba(0,0,0,.4);min-width:160px}.tm-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;background:none;border:none;color:var(--text);font-size:13px;border-radius:4px;cursor:pointer;text-align:left}.tm-menu-item:hover{background:var(--bg-hover)}.tm-menu-item svg{flex-shrink:0;opacity:.7}.tm-menu-item.tm-menu-danger{color:var(--red)}.tm-menu-item.tm-menu-danger:hover{background:rgba(243,139,168,.1)}.theme-editor-name-section{margin-bottom:16px}.settings-theme-row{display:flex;gap:8px;align-items:center}.settings-theme-row .settings-select{flex:1}.settings-dialog{max-width:480px;padding:0;display:flex;flex-direction:column;max-height:85vh;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.settings-header h3{margin-bottom:0}.settings-close{background:none;border:none;color:var(--text-dim);font-size:20px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:var(--radius)}.settings-close:hover{color:var(--text);background:var(--bg-hover)}.settings-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;padding:0 12px;gap:2px}.settings-tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px 10px;font-size:11px;font-family:var(--font-sans);color:var(--text-dim);border:none;border-bottom:2px solid rgba(0,0,0,0);margin-bottom:-1px;background:none;cursor:pointer;transition:color .15s}.settings-tab svg{flex-shrink:0}.settings-tab:hover{color:var(--text)}.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.settings-body{padding:20px;overflow-y:auto;flex:1;min-height:0}.settings-tab-panel{display:none}.settings-tab-panel.active{display:block}.settings-section{margin-bottom:16px}.settings-section-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.settings-heading{font-size:13px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.04em}.settings-beta-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--orange);background:color-mix(in srgb, var(--orange) 15%, transparent);padding:1px 5px;border-radius:3px;line-height:1.4}.settings-disclaimer{font-size:11px;color:var(--text-dim);margin-bottom:12px;line-height:1.4}.settings-hint{font-size:11px;color:var(--text-dim);margin-top:4px;line-height:1.4}.settings-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.settings-label{display:block;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:6px}.settings-label.settings-label-spaced{margin-top:12px}.settings-platform-control{width:100%}.settings-platform-control .segment{flex:1;text-align:center}.settings-select{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;cursor:pointer}.settings-select:focus{outline:none;border-color:var(--accent)}.settings-input{width:100%;padding:6px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;margin-top:8px}.settings-input:focus{outline:none;border-color:var(--accent)}.settings-input::placeholder{color:var(--text-dim)}.settings-key-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.settings-key-status svg{flex-shrink:0}.settings-key-status.settings-key-configured{color:var(--green)}.settings-key-missing{color:var(--orange)}.settings-key-input-group{margin-top:4px}.settings-key-row{display:flex;gap:8px;align-items:flex-end}.settings-key-row .settings-input{flex:1}.settings-key-row .btn{flex-shrink:0;margin-top:8px}.settings-storage-options{display:flex;flex-direction:column;gap:4px;margin-top:8px}.settings-radio{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text);cursor:pointer}.settings-radio input[type=radio]{accent-color:var(--accent)}.settings-warning{font-size:11px;color:var(--orange);margin-top:4px;line-height:1.4}.settings-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}.settings-checkbox input[type=checkbox]{accent-color:var(--accent)}.settings-guided-topics{margin-bottom:16px}.settings-tags{display:flex;flex-wrap:wrap;gap:6px}.settings-tag{font-size:12px;padding:3px 10px;border-radius:12px;border:1px solid var(--border);background:rgba(0,0,0,0);color:var(--text-dim);cursor:pointer;transition:all .15s ease;font-family:var(--font-sans)}.settings-tag:hover{border-color:var(--accent);color:var(--text)}.settings-tag.active{background:color-mix(in srgb, var(--accent) 20%, transparent);border-color:var(--accent);color:var(--accent);font-weight:500}.settings-more-toggle{display:block;margin-top:8px;padding:0;border:none;background:none;color:var(--accent);font-size:11px;cursor:pointer;font-family:var(--font-sans)}.settings-more-toggle:hover{text-decoration:underline}.settings-tags-more{margin-top:8px}.sidebar-header-btn,.refresh-btn,.settings-gear{position:absolute;top:12px;padding:4px;color:var(--text-dim);background:none;border:none;cursor:pointer;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.sidebar-header-btn:hover,.refresh-btn:hover,.settings-gear:hover{color:var(--text);background:var(--bg-hover)}.sidebar-header-btn svg,.refresh-btn svg,.settings-gear svg{display:block}.settings-gear{right:12px}.refresh-btn{right:36px}.settings-dialog .modal-actions{padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0}.update-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 20px;background:#dcfce7;border-bottom:2px solid #22c55e;font-size:13px;color:#166534;flex-shrink:0}@media(prefers-color-scheme: dark){.update-banner{background:#14532d;border-bottom-color:#22c55e;color:#86efac}}.update-banner-actions{display:flex;gap:8px;flex-shrink:0}.btn-accent{color:#fff;background:#22c55e;border-color:#22c55e}.btn-accent:hover:not(:disabled){background:#16a34a}.btn-accent:disabled{opacity:.7;cursor:default}.image-diff{padding:0}.image-diff .image-diff-metadata{padding:16px}.image-diff-panel{display:none}.image-diff-panel.active{display:block}.image-font-warning{padding:8px 16px;font-size:12px;color:var(--yellow, #f9e2af);background:rgba(249,226,175,.08);border-bottom:1px solid rgba(249,226,175,.15)}.image-metadata-loading,.image-metadata-error{padding:12px 16px;color:var(--text-dim);font-size:13px;font-family:var(--font-mono)}.image-metadata-diff,.image-metadata-single{font-family:var(--font-mono);font-size:13px;line-height:20px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.metadata-line{padding:2px 16px}.metadata-line.context{color:var(--text)}.metadata-line.add{background:rgba(166,227,161,.1);color:var(--green)}.metadata-line.add::before{content:"+ "}.metadata-line.remove{background:rgba(243,139,168,.1);color:var(--red)}.metadata-line.remove::before{content:"- "}.image-visual-canvas{height:calc(100vh - 80px);display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.image-zoom-wrap{position:relative;transform-origin:0 0}.image-zoom-wrap .image-layer{position:absolute;top:0;left:0;width:100%;height:100%}[data-panel=difference] .image-visual-canvas{background:#000}[data-panel=difference] .image-layer-old{z-index:1}[data-panel=difference] .image-blend{z-index:2;mix-blend-mode:difference}.image-slice-clipped{z-index:2}.slice-line{position:absolute;height:2px;background:var(--accent);z-index:10;pointer-events:none}.slice-handle{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);z-index:11;cursor:grab;transform:translate(-50%, -50%);box-shadow:0 1px 4px rgba(0,0,0,.4)}.slice-handle:active{cursor:grabbing}.diff-toolbar-image{display:flex;align-items:center;justify-content:space-between;width:100%}.diff-toolbar-image .diff-toolbar-left,.diff-toolbar-image .diff-toolbar-right{display:flex;align-items:center;gap:4px}.image-zoom-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-dim);cursor:pointer;font-size:16px;padding:0}.image-zoom-btn:hover{color:var(--text);background:var(--bg-hover)}.image-zoom-btn svg{display:block}.diff-toolbar-text{display:flex;align-items:center;justify-content:space-between;width:100%}.diff-toolbar-svg-toggle{display:flex;align-items:center;margin-right:12px;flex-shrink:0}.diff-toolbar.svg-file .diff-toolbar-text,.diff-toolbar.svg-file .diff-toolbar-image{width:auto;flex:1}.image-diff-single{display:flex;flex-direction:column;align-items:center;padding:24px}.image-diff-single img{max-width:100%;max-height:70vh;border:1px solid var(--border);border-radius:var(--radius)}.image-diff-status{margin-top:8px;color:var(--text-dim);font-size:13px}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "glassbox",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.7.0",
|
|
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",
|
|
@@ -30,15 +30,16 @@
|
|
|
30
30
|
"scripts": {
|
|
31
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.tsx --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 esbuild src/client/history.tsx --bundle --format=iife --outfile=dist/client/history.global.js --target=es2020 --minify --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
|
+
"build:client": "mkdir -p dist/client && npx esbuild src/client/app.tsx --bundle --format=iife --outfile=dist/client/app.global.js --target=es2020 --sourcemap --jsx=automatic --jsx-import-source=#jsx --alias:#jsx/jsx-runtime=./src/jsx-runtime.ts && npx esbuild src/client/history.tsx --bundle --format=iife --outfile=dist/client/history.global.js --target=es2020 --minify --sourcemap --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",
|
|
34
34
|
"dev:server": "npm run build:client && tsx --tsconfig tsconfig.json src/cli.ts --no-open --strict-port",
|
|
35
35
|
"tauri": "tauri",
|
|
36
36
|
"tauri:clean": "rm -rf src-tauri/target",
|
|
37
37
|
"tauri:dev": "bash scripts/tauri-dev.sh",
|
|
38
38
|
"tauri:build": "bash scripts/build-sidecar.sh && tauri build",
|
|
39
|
-
"test": "vitest run",
|
|
39
|
+
"test": "vitest run --coverage",
|
|
40
40
|
"test:watch": "vitest",
|
|
41
|
-
"test:
|
|
41
|
+
"test:all": "bash scripts/test-all.sh",
|
|
42
|
+
"test:e2e": "npx playwright test",
|
|
42
43
|
"lint": "eslint src/",
|
|
43
44
|
"clean": "rm -rf dist node_modules/.cache",
|
|
44
45
|
"release": "bash scripts/release.sh",
|
|
@@ -56,9 +57,11 @@
|
|
|
56
57
|
},
|
|
57
58
|
"devDependencies": {
|
|
58
59
|
"@eslint/js": "^9.39.3",
|
|
60
|
+
"@playwright/test": "^1.59.1",
|
|
59
61
|
"@tauri-apps/cli": "^2.10.1",
|
|
60
62
|
"@types/node": "^22.0.0",
|
|
61
63
|
"@vitest/coverage-v8": "^4.1.0",
|
|
64
|
+
"c8": "^11.0.0",
|
|
62
65
|
"esbuild": "^0.27.3",
|
|
63
66
|
"eslint": "^9.39.3",
|
|
64
67
|
"eslint-plugin-import-x": "^4.16.1",
|