Skip to content

Commit

Permalink
Update circuits widget sizing behavior (#1921)
Browse files Browse the repository at this point in the history
This change fixes a few quirks of the `Circuit` widget, specifically:

- if the width of the widget is greater than the width of the cell
output area, scroll bars are added, and
- setting a custom zoom level by changing the value in the zoom control
disables the resize handling so that VS Code doesn't incorrectly trigger
a recalculation of the default zoom and undo the manual change.

Confirmed with manual testing that window resizing in VS Code circuit
display is still hadled properly.

---------

Co-authored-by: Mine Starks <[email protected]>
  • Loading branch information
swernli and minestarks authored Sep 27, 2024
1 parent 6c3ab39 commit a51dcb3
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 7 deletions.
21 changes: 14 additions & 7 deletions npm/qsharp/ux/circuit.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ function ZoomableCircuit(props: { circuit: qviz.Circuit }) {
const circuitDiv = useRef<HTMLDivElement>(null);
const [zoomLevel, setZoomLevel] = useState(100);
const [rendering, setRendering] = useState(true);
const [zoomOnResize, setZoomOnResize] = useState(true);

useEffect(() => {
// Enable "rendering" text while the circuit is being drawn
Expand Down Expand Up @@ -67,7 +68,7 @@ function ZoomableCircuit(props: { circuit: qviz.Circuit }) {
window.removeEventListener("resize", onResize);
};
}
}, [rendering]);
}, [rendering, zoomOnResize]);

useEffect(() => {
updateWidth();
Expand All @@ -77,7 +78,7 @@ function ZoomableCircuit(props: { circuit: qviz.Circuit }) {
<div>
<div>
{rendering ? null : (
<ZoomControl zoom={zoomLevel} onChange={setZoomLevel} />
<ZoomControl zoom={zoomLevel} onInput={userSetZoomLevel} />
)}
</div>
<div>
Expand All @@ -94,6 +95,10 @@ function ZoomableCircuit(props: { circuit: qviz.Circuit }) {
* based on the new window width.
*/
function onResize() {
if (!zoomOnResize) {
return;
}

const [container, svg] = [circuitDiv.current, currentSvg()];
if (container && svg) {
// Recalculate the zoom level based on the container width
Expand Down Expand Up @@ -151,6 +156,11 @@ function ZoomableCircuit(props: { circuit: qviz.Circuit }) {
function currentSvg(): SVGElement | undefined {
return circuitDiv.current?.querySelector(".qviz") ?? undefined;
}

function userSetZoomLevel(zoom: number) {
setZoomOnResize(false);
setZoomLevel(zoom);
}
}

function Unrenderable(props: { qubits: number; operations: number }) {
Expand Down Expand Up @@ -178,10 +188,7 @@ function Unrenderable(props: { qubits: number; operations: number }) {
return <div class="qs-circuit-error">{errorDiv}</div>;
}

function ZoomControl(props: {
zoom: number;
onChange: (zoom: number) => void;
}) {
function ZoomControl(props: { zoom: number; onInput: (zoom: number) => void }) {
return (
<p>
<label htmlFor="qs-circuit-zoom">Zoom </label>
Expand All @@ -193,7 +200,7 @@ function ZoomControl(props: {
step="10"
value={props.zoom}
onInput={(e) =>
props.onChange(parseInt((e.target as HTMLInputElement).value) || 0)
props.onInput(parseInt((e.target as HTMLInputElement).value) || 0)
}
/>
%
Expand Down
1 change: 1 addition & 0 deletions widgets/src/qsharp_widgets/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -179,3 +179,4 @@ class Circuit(anywidget.AnyWidget):
def __init__(self, circuit):
super().__init__()
self.circuit_json = circuit.json()
self.layout.overflow = "visible scroll"

0 comments on commit a51dcb3

Please sign in to comment.