qiskit_trebugger.views.widget.timeline_utils

Utility functions to support the timeline view

  1"""Utility functions to support the timeline view
  2"""
  3from io import BytesIO
  4from binascii import b2a_base64
  5from qiskit.circuit import qpy_serialization
  6import ipywidgets as widgets
  7
  8
  9def get_args_panel(**kwargs):
 10    """Returns kwarg panel for the debugger
 11
 12    Returns:
 13        widgets.HBox: Horizontal Box containing the
 14                      arg panel
 15    """
 16    # make two boxes for each key and values
 17    key_box = {}
 18    val_box = {}
 19
 20    box_kwargs = dict(
 21        width="50%", display="flex", align_items="stretch", flex_flow="column"
 22    )
 23    for i in range(2):
 24        key_box[i] = widgets.VBox(layout=box_kwargs)
 25        val_box[i] = widgets.VBox(layout=box_kwargs)
 26
 27    # make children dicts
 28    key_children = {0: [], 1: []}
 29    value_children = {0: [], 1: []}
 30
 31    # counter
 32    index = 0
 33
 34    for i, (key, val) in enumerate(kwargs.items()):
 35        if val is None:
 36            continue
 37
 38        # make key and value labels
 39        key_label = widgets.HTML(r"<p class = 'params-key'><b> " + key + "</b></p>")
 40
 41        value = val
 42        value_label = widgets.HTML(r"<p class = 'params-value'>" + str(value) + "</p>")
 43
 44        # add to the list
 45        key_children[index].append(key_label)
 46        value_children[index].append(value_label)
 47
 48        # flip box id
 49        index = 0 if i < len(kwargs.items()) // 2 else 1
 50
 51    # construct the inner vertical boxes
 52    for i in range(2):
 53        key_box[i].children = key_children[i]
 54        val_box[i].children = value_children[i]
 55
 56    # construct HBoxes
 57    args_boxes = [
 58        widgets.HBox([key_box[0], val_box[0]], layout={"width": "50%"}),
 59        widgets.HBox([key_box[1], val_box[1]], layout={"width": "50%"}),
 60    ]
 61
 62    # construct final HBox
 63    return widgets.HBox(args_boxes, layout=dict(margin="10px 0 0 15px"))
 64
 65
 66def view_circuit(disp_circuit, suffix):
 67    """Displays the circuit with diff for the debuuger
 68
 69    Args:
 70        disp_circuit : The circuit to display
 71        suffix (str) : The name to be added to pass
 72
 73     Returns:
 74         str : HTML string with img data to be
 75               rendered into the debugger
 76    """
 77    if "diff" in suffix:
 78        # means checkbox has been chosen for diff
 79        img_style = {"gatefacecolor": "orange", "gatetextcolor": "black"}
 80    else:
 81        img_style = None
 82
 83    fig = disp_circuit.draw(
 84        "mpl",
 85        idle_wires=False,
 86        with_layout=False,
 87        scale=0.9,
 88        fold=20,
 89        style=img_style,
 90    )
 91
 92    img_bio = BytesIO()
 93    fig.savefig(img_bio, format="png", bbox_inches="tight")
 94    fig.clf()
 95    img_data = b2a_base64(img_bio.getvalue()).decode()
 96
 97    qpy_bio = BytesIO()
 98    qpy_serialization.dump(disp_circuit, qpy_bio)
 99    qpy_data = b2a_base64(qpy_bio.getvalue()).decode()
100
101    # qasm couldn't handle the circuit changed names
102    for instr in disp_circuit.data:
103        instr[0].name = instr[0].name.strip()
104
105    qasm_str = disp_circuit.qasm()
106    qasm_bio = BytesIO(bytes(qasm_str, "ascii"))
107    qasm_data = b2a_base64(qasm_bio.getvalue()).decode()
108
109    img_html = f"""
110        <div class="circuit-plot-wpr">
111            <img src="data:image/png;base64,{img_data}&#10;">
112        </div>
113        <div class="circuit-export-wpr">
114            Save:
115            <a download="circuit_{suffix}.png" href="data:image/png;base64,{img_data}" download>
116                <i class="fa fa-download"></i> <span>PNG</span>
117            </a>
118            <a download="circuit_{suffix}.qpy" href="data:application/octet-stream;base64,{qpy_data}" download>
119                <i class="fa fa-download"></i> <span>QPY</span>
120            </a>
121            <a download="circuit_{suffix}.qasm" href="data:application/octet-stream;base64,{qasm_data}" download>
122                <i class="fa fa-download"></i> <span>QASM</span>
123            </a>
124        </div>
125        """
126
127    return img_html
128
129
130def get_spinner_html():
131    """Return the spinner html string"""
132    return '<div class="lds-spinner"><div></div><div></div><div>\
133            </div><div></div><div></div><div></div><div></div><div>\
134            </div><div></div><div></div><div></div><div></div></div>'
135
136
137def get_styles():
138    """Return the style for the debugger"""
139    return """
140        <style>
141        .title h1 { font-size: 45px; font-weight: bold; text-align: center; padding: 10px 10px 10px 10px; }
142        .logo { margin: 0 15px; background-position: center; background-repeat: no-repeat; background-size: contain; background-image: url('')}        
143        .step-details { min-height: 350px; background: #eee; }
144        .step-details-hide { display: none !important; }
145
146        .options { border-top: 1px solid #eee; }
147        .options > div { font-size : 0.7 em; text-align: center; font-family: 'Roboto Mono', monospace; background: #eee; }
148
149        .tp-widget { border:1px solid #aaa; min-width: 300px; }
150        .p-TabPanel-tabContents { padding: 5px !important; }
151        .p-Collapse-header { padding: 1px 5px; background: #eee; }
152        .p-Collapse-open > .p-Collapse-header { background: #ddd; }
153        .p-Collapse-contents { padding-top: 0; padding-left: 0; padding-bottom: 0; padding-right: 0; height: 220px; background: #f5f5f5; }
154        .p-Collapse-contents button {
155            width: 20%;
156            background: #fff;
157            text-align: center;
158            padding: 0;
159            font-weight: bold; }
160
161
162        div.output_scroll { box-shadow: none }
163
164        .widget-gridbox.table { background: #f5f5f5; }
165        .widget-gridbox.table .widget-label {
166            background-color: #fff;
167            padding: 0 3px;
168            font-family: 'Open Sans', monospace;
169            font-size: 14px;
170        }
171
172        .exist { font-weight: bold; }
173        .not-exist { display: none; }
174
175        .stats-title {
176            background: #eee;
177            margin: 0;
178            text-align: center;
179            font-size: 15px;
180            font-weight: bold;
181            font-family: 'Roboto Mono', monospace; }
182
183        .widget-label.new, .widget-hbox.new .widget-label { font-weight: bold; color: #4b7bec; }
184        .widget-label.updated, .widget-hbox.updated .widget-label { font-weight: bold; color: #e74c3c; }
185
186        .transpilation-step {
187            background: #fff;
188            padding-top: 5px;
189            border-bottom: 1px solid #ddd;
190            grid-template-columns: 35px auto 70px 70px 70px 70px 70px 70px;
191        }
192        .transpilation-step:hover { background: #eee; }
193        .transpilation-step button { background: #fff; }
194        .transpilation-step .transformation {
195                            color: cornsilk;
196                            font-family : 'Lato';
197                            padding: 3px 3px 3px 10px;
198                            background-color: rgba(0, 67, 206, 0.8);
199                            margin-right : 10%;
200        }
201        .transpilation-step .analysis {
202                        color: cornsilk;
203                        padding: 3px 3px 3px 10px;
204                        font-family : 'Lato';
205                        background-color: rgba(180, 77, 224, 0.8);
206                        margin-right: 10%;
207        }
208
209        .transpilation-step div.fs10 { font-size: 10px; }
210        .transpilation-step div.fs11 { font-size: 11px; }
211        .transpilation-step div.fs12 { font-size: 12px; }
212        .transpilation-step div.fs13 { font-size: 13px; }
213        .transpilation-step div.fs14 { font-size: 14px; }
214        .transpilation-step div.fs15 { font-size: 15px; }
215        .transpilation-step > :nth-child(1) button { width: 11px; font-size: 20px; background: transparent; outline: 0 !important; border: none !important; }
216        .transpilation-step > :nth-child(1) button:hover { border: none !important; outline: none !important; box-shadow: none !important; }
217        .transpilation-step > :nth-child(1) button:focus { border: none !important; outline: none !important; box-shadow: none !important; }
218
219        .transpilation-step.active > :nth-child(2) { font-weight: bold; }
220
221        .transpilation-step > :nth-child(2) {
222            font-family: 'Roboto Mono', monospace;
223            font-size: 16px;
224            overflow: hidden;
225            text-overflow: ellipsis;
226            white-space: nowrap;
227        }
228        .transpilation-step > :nth-child(3) { font-family: 'Roboto Mono', monospace; font-size: 10px; color: #900; text-align: right; }
229        .transpilation-step > :nth-child(4) { font-family: 'Roboto Mono', monospace; text-align: center; }
230        .transpilation-step > :nth-child(5) { font-family: 'Roboto Mono', monospace; text-align: center; }
231        .transpilation-step > :nth-child(6) { font-family: 'Roboto Mono', monospace; text-align: center; }
232        .transpilation-step > :nth-child(7) { font-family: 'Roboto Mono', monospace; text-align: center; }
233        .transpilation-step > :nth-child(8) { font-family: 'Roboto Mono', monospace; text-align: center; }
234
235        .stat-name { font-size: 10px; color: #aaa; }
236        .stat-value { font-size: 12px; color: #000; }
237        .highlight .stat-value { font-weight: bold; color: #e74c3c; }
238
239        .logs-wpr { display: grid; grid-template-columns: 70px 60px auto; }
240        .logs-wpr pre.date { font-size: 10px; }
241        .logs-wpr pre.level { font-size: 10px; text-align: right; padding-right: 5px; }
242        .logs-wpr pre.log-entry { font-size: 12px; }
243        .logs-wpr pre.DEBUG { color: #000000; }
244        .logs-wpr pre.INFO { color: #1c84a2; }
245        .logs-wpr pre.WARNING { color: #ed7723; }
246        .logs-wpr pre.ERROR { color: #d64e4a; }
247        .logs-wpr pre.CRITICAL { color: white; background: #d64e4a; }
248
249        div.output_area pre.help { font-family: Helvetica,Arial,sans-serif; font-size: 13px;
250            border: 1px solid #ccc; padding: 10px;}
251        div.help-header {
252            font-family: 'Roboto Mono', monospace;
253            font-size: 12px;
254            border: 1px solid #ccc;
255            border-bottom: none;
256            margin-top: 4px;
257            padding: 5px 10px;
258            font-weight: bold;
259            background: #f5f5f5;
260        }
261        .toggle-button{
262            padding: 5px 25px 10px 10px;
263            font-size : 1.1em;
264            height : 5%;
265            text-align: left;
266            background: #fff;
267            transition: 0.5s;
268            border: none !important;
269        }
270        .toggle-button:hover{
271            background: #eee;
272            border: none;
273            transition: 1s;
274        }
275        .params-key{
276            margin: 2% 1% 1% 4%;
277            padding: 5px 20px 5px 20px;
278            font-size: 1em;
279            color: cornsilk;
280            background: rgba(15,23,229,0.7);
281        }
282
283        .params-value{
284            margin: 1% 1% 1% 1%;
285            padding: 5px 20px 5px 20px;
286            border-left : 2px solid black;
287            font-size: 1.1em;
288        }
289
290        .transform-label {
291            margin-left : 5%;
292            color: cornsilk;
293            padding: 10px 15px 10px 15px;
294            font-size: 1.3em;
295            background-color: rgba(0, 67, 206, 0.8);
296        }
297
298        .analyse-label {
299            margin-left : 5%;
300            padding: 10px 15px 10px 15px;
301            color: cornsilk;
302            font-size: 1.3em;
303            background-color: rgba(180, 77, 224, 0.8);
304        }
305
306        .label-text{
307            padding: 2px 2px 2px 2px; margin-left:10%; font-size: 1.1em;
308        }
309
310        .label-purple-back{
311            margin-left : 5%;
312            padding: 5px 0px 2px 15px;
313            font-size: 1.2em;
314            color : #444444;
315            background-color: rgba(245,174,230,0.4);
316        }
317
318
319        .content-wpr {
320            overflow:hidden;
321        }
322
323        .content { overflow-y: auto; height: 325px; margin: 0; padding: 0; }
324        .p-TabPanel-tabContents td { text-align: left; font-family: 'Roboto Mono', monospace; }
325        .p-TabPanel-tabContents th { text-align: center; font-family: 'Roboto Mono', monospace; font-size: 14px; }
326
327        .circuit-plot-wpr { height: 225px; overflow: auto; border: 1px solid #aaa; }
328        .circuit-plot-wpr img { max-width: none; }
329        .circuit-export-wpr a {
330            display: inline-block;
331            margin: 5px 2px;
332            padding: 2px 15px;
333            color: #000;
334            background: #ddd;
335            border: 1px solid transparent;
336            text-decoration: none !important;
337        }
338        .circuit-export-wpr a:hover { border-color: #aaa; }
339
340        .p-TabBar-tabIcon:before { font: normal normal normal 14px/1 FontAwesome; padding-right: 5px; }
341        .p-TabBar-content > :nth-child(1) .p-TabBar-tabIcon:before { content: "\\f1de"; color: #b587f7; }
342        .p-TabBar-content > :nth-child(2) .p-TabBar-tabIcon:before { content: "\\f00a"; color: #b33771; }
343        .p-TabBar-content > :nth-child(3) .p-TabBar-tabIcon:before { content: "\\f039"; color: #ff9d85; }
344        .p-TabBar-content > :nth-child(4) .p-TabBar-tabIcon:before { content: "\\f05a"; color: #6ea2c9; }
345
346        .no-props .p-TabBar-content > :nth-child(2) .p-TabBar-tabLabel,
347        .no-props .p-TabBar-content > :nth-child(2) .p-TabBar-tabIcon:before { color: #aaa; }
348        .no-logs .p-TabBar-content > :nth-child(3) .p-TabBar-tabLabel,
349        .no-logs .p-TabBar-content > :nth-child(3) .p-TabBar-tabIcon:before { color: #aaa; }
350
351        .message { width: 90%; font-size: 26px; text-align: center; margin: 70px 0; font-weight: bold;}
352
353        @media (max-width: 1000px) {
354            .options { grid-template-columns: repeat(3, auto) !important; }
355            .options > :nth-child(4) { display: none; }
356
357            .transpilation-step { grid-template-columns: 35px auto 70px 70px 70px 70px 70px; }
358            .transpilation-step > :nth-child(2) { font-size: 12px !important; }
359            .transpilation-step > :nth-child(3) { display: none; }
360        }
361
362        @media (max-width:985px) {
363            .title h1 { font-size: 26px; }
364            .logo {margin : 0px 2px;}
365            .transpilation-step { grid-template-columns: 35px auto 70px 70px 70px 70px; }
366            .transpilation-step > :nth-child(6) { display: none; }
367
368        }
369
370        @media (max-width:800px) {
371            
372            
373            .options { grid-template-columns: repeat(2, auto) !important; }
374            .options > :nth-child(3) { display: none; }
375
376            .transpilation-step { grid-template-columns: 35px auto 70px 70px 70px; }
377            .transpilation-step > :nth-child(7) { display: none; }
378        }
379
380        @media (max-width:700px) {
381            
382            .summary-panel { grid-template-columns: repeat(1, auto) !important; }
383
384            .property-set { width: 100% !important; }
385            .property-items { display: none !important; }
386
387            .circuit-export-wpr a {
388                font-size: 12px;
389                padding: 2px 6px;
390            }
391
392            .transpilation-step { grid-template-columns: 35px auto 70px 70px; }
393            .transpilation-step > :nth-child(5) { display: none; }
394        }
395
396        @media (max-width:550px) {
397             .logo {display: none;}
398             .title {font-size : 14px;}
399            .transpilation-step { grid-template-columns: 35px auto; }
400            .transpilation-step > :nth-child(4) { display: none; }
401            .transpilation-step > :nth-child(8) { display: none; }
402        }
403
404        .lds-spinner {
405            position: relative;
406            width: 80px;
407            height: 80px;
408            margin: 50px auto;
409        }
410        .lds-spinner div {
411            transform-origin: 40px 40px;
412            animation: lds-spinner 1.2s linear infinite;
413        }
414        .lds-spinner div:after {
415            content: " ";
416            display: block;
417            position: absolute;
418            top: 3px;
419            left: 37px;
420            width: 6px;
421            height: 18px;
422            border-radius: 20%;
423            background: #aaa;
424        }
425        .lds-spinner div:nth-child(1) {
426            transform: rotate(0deg);
427            animation-delay: -1.1s;
428        }
429        .lds-spinner div:nth-child(2) {
430            transform: rotate(30deg);
431            animation-delay: -1s;
432        }
433        .lds-spinner div:nth-child(3) {
434            transform: rotate(60deg);
435            animation-delay: -0.9s;
436        }
437        .lds-spinner div:nth-child(4) {
438            transform: rotate(90deg);
439            animation-delay: -0.8s;
440        }
441        .lds-spinner div:nth-child(5) {
442            transform: rotate(120deg);
443            animation-delay: -0.7s;
444        }
445        .lds-spinner div:nth-child(6) {
446            transform: rotate(150deg);
447            animation-delay: -0.6s;
448        }
449        .lds-spinner div:nth-child(7) {
450            transform: rotate(180deg);
451            animation-delay: -0.5s;
452        }
453        .lds-spinner div:nth-child(8) {
454            transform: rotate(210deg);
455            animation-delay: -0.4s;
456        }
457        .lds-spinner div:nth-child(9) {
458            transform: rotate(240deg);
459            animation-delay: -0.3s;
460        }
461        .lds-spinner div:nth-child(10) {
462            transform: rotate(270deg);
463            animation-delay: -0.2s;
464        }
465        .lds-spinner div:nth-child(11) {
466            transform: rotate(300deg);
467            animation-delay: -0.1s;
468        }
469        .lds-spinner div:nth-child(12) {
470            transform: rotate(330deg);
471            animation-delay: 0s;
472        }
473        @keyframes lds-spinner {
474            0% { opacity: 1; }
475            100% { opacity: 0; }
476        }
477        </style>
478        """
def get_args_panel(**kwargs):
10def get_args_panel(**kwargs):
11    """Returns kwarg panel for the debugger
12
13    Returns:
14        widgets.HBox: Horizontal Box containing the
15                      arg panel
16    """
17    # make two boxes for each key and values
18    key_box = {}
19    val_box = {}
20
21    box_kwargs = dict(
22        width="50%", display="flex", align_items="stretch", flex_flow="column"
23    )
24    for i in range(2):
25        key_box[i] = widgets.VBox(layout=box_kwargs)
26        val_box[i] = widgets.VBox(layout=box_kwargs)
27
28    # make children dicts
29    key_children = {0: [], 1: []}
30    value_children = {0: [], 1: []}
31
32    # counter
33    index = 0
34
35    for i, (key, val) in enumerate(kwargs.items()):
36        if val is None:
37            continue
38
39        # make key and value labels
40        key_label = widgets.HTML(r"<p class = 'params-key'><b> " + key + "</b></p>")
41
42        value = val
43        value_label = widgets.HTML(r"<p class = 'params-value'>" + str(value) + "</p>")
44
45        # add to the list
46        key_children[index].append(key_label)
47        value_children[index].append(value_label)
48
49        # flip box id
50        index = 0 if i < len(kwargs.items()) // 2 else 1
51
52    # construct the inner vertical boxes
53    for i in range(2):
54        key_box[i].children = key_children[i]
55        val_box[i].children = value_children[i]
56
57    # construct HBoxes
58    args_boxes = [
59        widgets.HBox([key_box[0], val_box[0]], layout={"width": "50%"}),
60        widgets.HBox([key_box[1], val_box[1]], layout={"width": "50%"}),
61    ]
62
63    # construct final HBox
64    return widgets.HBox(args_boxes, layout=dict(margin="10px 0 0 15px"))

Returns kwarg panel for the debugger

Returns: widgets.HBox: Horizontal Box containing the arg panel

def view_circuit(disp_circuit, suffix):
 67def view_circuit(disp_circuit, suffix):
 68    """Displays the circuit with diff for the debuuger
 69
 70    Args:
 71        disp_circuit : The circuit to display
 72        suffix (str) : The name to be added to pass
 73
 74     Returns:
 75         str : HTML string with img data to be
 76               rendered into the debugger
 77    """
 78    if "diff" in suffix:
 79        # means checkbox has been chosen for diff
 80        img_style = {"gatefacecolor": "orange", "gatetextcolor": "black"}
 81    else:
 82        img_style = None
 83
 84    fig = disp_circuit.draw(
 85        "mpl",
 86        idle_wires=False,
 87        with_layout=False,
 88        scale=0.9,
 89        fold=20,
 90        style=img_style,
 91    )
 92
 93    img_bio = BytesIO()
 94    fig.savefig(img_bio, format="png", bbox_inches="tight")
 95    fig.clf()
 96    img_data = b2a_base64(img_bio.getvalue()).decode()
 97
 98    qpy_bio = BytesIO()
 99    qpy_serialization.dump(disp_circuit, qpy_bio)
100    qpy_data = b2a_base64(qpy_bio.getvalue()).decode()
101
102    # qasm couldn't handle the circuit changed names
103    for instr in disp_circuit.data:
104        instr[0].name = instr[0].name.strip()
105
106    qasm_str = disp_circuit.qasm()
107    qasm_bio = BytesIO(bytes(qasm_str, "ascii"))
108    qasm_data = b2a_base64(qasm_bio.getvalue()).decode()
109
110    img_html = f"""
111        <div class="circuit-plot-wpr">
112            <img src="data:image/png;base64,{img_data}&#10;">
113        </div>
114        <div class="circuit-export-wpr">
115            Save:
116            <a download="circuit_{suffix}.png" href="data:image/png;base64,{img_data}" download>
117                <i class="fa fa-download"></i> <span>PNG</span>
118            </a>
119            <a download="circuit_{suffix}.qpy" href="data:application/octet-stream;base64,{qpy_data}" download>
120                <i class="fa fa-download"></i> <span>QPY</span>
121            </a>
122            <a download="circuit_{suffix}.qasm" href="data:application/octet-stream;base64,{qasm_data}" download>
123                <i class="fa fa-download"></i> <span>QASM</span>
124            </a>
125        </div>
126        """
127
128    return img_html

Displays the circuit with diff for the debuuger

Args: disp_circuit : The circuit to display suffix (str) : The name to be added to pass

Returns: str : HTML string with img data to be rendered into the debugger

def get_spinner_html():
131def get_spinner_html():
132    """Return the spinner html string"""
133    return '<div class="lds-spinner"><div></div><div></div><div>\
134            </div><div></div><div></div><div></div><div></div><div>\
135            </div><div></div><div></div><div></div><div></div></div>'

Return the spinner html string

def get_styles():
138def get_styles():
139    """Return the style for the debugger"""
140    return """
141        <style>
142        .title h1 { font-size: 45px; font-weight: bold; text-align: center; padding: 10px 10px 10px 10px; }
143        .logo { margin: 0 15px; background-position: center; background-repeat: no-repeat; background-size: contain; background-image: url('')}        
144        .step-details { min-height: 350px; background: #eee; }
145        .step-details-hide { display: none !important; }
146
147        .options { border-top: 1px solid #eee; }
148        .options > div { font-size : 0.7 em; text-align: center; font-family: 'Roboto Mono', monospace; background: #eee; }
149
150        .tp-widget { border:1px solid #aaa; min-width: 300px; }
151        .p-TabPanel-tabContents { padding: 5px !important; }
152        .p-Collapse-header { padding: 1px 5px; background: #eee; }
153        .p-Collapse-open > .p-Collapse-header { background: #ddd; }
154        .p-Collapse-contents { padding-top: 0; padding-left: 0; padding-bottom: 0; padding-right: 0; height: 220px; background: #f5f5f5; }
155        .p-Collapse-contents button {
156            width: 20%;
157            background: #fff;
158            text-align: center;
159            padding: 0;
160            font-weight: bold; }
161
162
163        div.output_scroll { box-shadow: none }
164
165        .widget-gridbox.table { background: #f5f5f5; }
166        .widget-gridbox.table .widget-label {
167            background-color: #fff;
168            padding: 0 3px;
169            font-family: 'Open Sans', monospace;
170            font-size: 14px;
171        }
172
173        .exist { font-weight: bold; }
174        .not-exist { display: none; }
175
176        .stats-title {
177            background: #eee;
178            margin: 0;
179            text-align: center;
180            font-size: 15px;
181            font-weight: bold;
182            font-family: 'Roboto Mono', monospace; }
183
184        .widget-label.new, .widget-hbox.new .widget-label { font-weight: bold; color: #4b7bec; }
185        .widget-label.updated, .widget-hbox.updated .widget-label { font-weight: bold; color: #e74c3c; }
186
187        .transpilation-step {
188            background: #fff;
189            padding-top: 5px;
190            border-bottom: 1px solid #ddd;
191            grid-template-columns: 35px auto 70px 70px 70px 70px 70px 70px;
192        }
193        .transpilation-step:hover { background: #eee; }
194        .transpilation-step button { background: #fff; }
195        .transpilation-step .transformation {
196                            color: cornsilk;
197                            font-family : 'Lato';
198                            padding: 3px 3px 3px 10px;
199                            background-color: rgba(0, 67, 206, 0.8);
200                            margin-right : 10%;
201        }
202        .transpilation-step .analysis {
203                        color: cornsilk;
204                        padding: 3px 3px 3px 10px;
205                        font-family : 'Lato';
206                        background-color: rgba(180, 77, 224, 0.8);
207                        margin-right: 10%;
208        }
209
210        .transpilation-step div.fs10 { font-size: 10px; }
211        .transpilation-step div.fs11 { font-size: 11px; }
212        .transpilation-step div.fs12 { font-size: 12px; }
213        .transpilation-step div.fs13 { font-size: 13px; }
214        .transpilation-step div.fs14 { font-size: 14px; }
215        .transpilation-step div.fs15 { font-size: 15px; }
216        .transpilation-step > :nth-child(1) button { width: 11px; font-size: 20px; background: transparent; outline: 0 !important; border: none !important; }
217        .transpilation-step > :nth-child(1) button:hover { border: none !important; outline: none !important; box-shadow: none !important; }
218        .transpilation-step > :nth-child(1) button:focus { border: none !important; outline: none !important; box-shadow: none !important; }
219
220        .transpilation-step.active > :nth-child(2) { font-weight: bold; }
221
222        .transpilation-step > :nth-child(2) {
223            font-family: 'Roboto Mono', monospace;
224            font-size: 16px;
225            overflow: hidden;
226            text-overflow: ellipsis;
227            white-space: nowrap;
228        }
229        .transpilation-step > :nth-child(3) { font-family: 'Roboto Mono', monospace; font-size: 10px; color: #900; text-align: right; }
230        .transpilation-step > :nth-child(4) { font-family: 'Roboto Mono', monospace; text-align: center; }
231        .transpilation-step > :nth-child(5) { font-family: 'Roboto Mono', monospace; text-align: center; }
232        .transpilation-step > :nth-child(6) { font-family: 'Roboto Mono', monospace; text-align: center; }
233        .transpilation-step > :nth-child(7) { font-family: 'Roboto Mono', monospace; text-align: center; }
234        .transpilation-step > :nth-child(8) { font-family: 'Roboto Mono', monospace; text-align: center; }
235
236        .stat-name { font-size: 10px; color: #aaa; }
237        .stat-value { font-size: 12px; color: #000; }
238        .highlight .stat-value { font-weight: bold; color: #e74c3c; }
239
240        .logs-wpr { display: grid; grid-template-columns: 70px 60px auto; }
241        .logs-wpr pre.date { font-size: 10px; }
242        .logs-wpr pre.level { font-size: 10px; text-align: right; padding-right: 5px; }
243        .logs-wpr pre.log-entry { font-size: 12px; }
244        .logs-wpr pre.DEBUG { color: #000000; }
245        .logs-wpr pre.INFO { color: #1c84a2; }
246        .logs-wpr pre.WARNING { color: #ed7723; }
247        .logs-wpr pre.ERROR { color: #d64e4a; }
248        .logs-wpr pre.CRITICAL { color: white; background: #d64e4a; }
249
250        div.output_area pre.help { font-family: Helvetica,Arial,sans-serif; font-size: 13px;
251            border: 1px solid #ccc; padding: 10px;}
252        div.help-header {
253            font-family: 'Roboto Mono', monospace;
254            font-size: 12px;
255            border: 1px solid #ccc;
256            border-bottom: none;
257            margin-top: 4px;
258            padding: 5px 10px;
259            font-weight: bold;
260            background: #f5f5f5;
261        }
262        .toggle-button{
263            padding: 5px 25px 10px 10px;
264            font-size : 1.1em;
265            height : 5%;
266            text-align: left;
267            background: #fff;
268            transition: 0.5s;
269            border: none !important;
270        }
271        .toggle-button:hover{
272            background: #eee;
273            border: none;
274            transition: 1s;
275        }
276        .params-key{
277            margin: 2% 1% 1% 4%;
278            padding: 5px 20px 5px 20px;
279            font-size: 1em;
280            color: cornsilk;
281            background: rgba(15,23,229,0.7);
282        }
283
284        .params-value{
285            margin: 1% 1% 1% 1%;
286            padding: 5px 20px 5px 20px;
287            border-left : 2px solid black;
288            font-size: 1.1em;
289        }
290
291        .transform-label {
292            margin-left : 5%;
293            color: cornsilk;
294            padding: 10px 15px 10px 15px;
295            font-size: 1.3em;
296            background-color: rgba(0, 67, 206, 0.8);
297        }
298
299        .analyse-label {
300            margin-left : 5%;
301            padding: 10px 15px 10px 15px;
302            color: cornsilk;
303            font-size: 1.3em;
304            background-color: rgba(180, 77, 224, 0.8);
305        }
306
307        .label-text{
308            padding: 2px 2px 2px 2px; margin-left:10%; font-size: 1.1em;
309        }
310
311        .label-purple-back{
312            margin-left : 5%;
313            padding: 5px 0px 2px 15px;
314            font-size: 1.2em;
315            color : #444444;
316            background-color: rgba(245,174,230,0.4);
317        }
318
319
320        .content-wpr {
321            overflow:hidden;
322        }
323
324        .content { overflow-y: auto; height: 325px; margin: 0; padding: 0; }
325        .p-TabPanel-tabContents td { text-align: left; font-family: 'Roboto Mono', monospace; }
326        .p-TabPanel-tabContents th { text-align: center; font-family: 'Roboto Mono', monospace; font-size: 14px; }
327
328        .circuit-plot-wpr { height: 225px; overflow: auto; border: 1px solid #aaa; }
329        .circuit-plot-wpr img { max-width: none; }
330        .circuit-export-wpr a {
331            display: inline-block;
332            margin: 5px 2px;
333            padding: 2px 15px;
334            color: #000;
335            background: #ddd;
336            border: 1px solid transparent;
337            text-decoration: none !important;
338        }
339        .circuit-export-wpr a:hover { border-color: #aaa; }
340
341        .p-TabBar-tabIcon:before { font: normal normal normal 14px/1 FontAwesome; padding-right: 5px; }
342        .p-TabBar-content > :nth-child(1) .p-TabBar-tabIcon:before { content: "\\f1de"; color: #b587f7; }
343        .p-TabBar-content > :nth-child(2) .p-TabBar-tabIcon:before { content: "\\f00a"; color: #b33771; }
344        .p-TabBar-content > :nth-child(3) .p-TabBar-tabIcon:before { content: "\\f039"; color: #ff9d85; }
345        .p-TabBar-content > :nth-child(4) .p-TabBar-tabIcon:before { content: "\\f05a"; color: #6ea2c9; }
346
347        .no-props .p-TabBar-content > :nth-child(2) .p-TabBar-tabLabel,
348        .no-props .p-TabBar-content > :nth-child(2) .p-TabBar-tabIcon:before { color: #aaa; }
349        .no-logs .p-TabBar-content > :nth-child(3) .p-TabBar-tabLabel,
350        .no-logs .p-TabBar-content > :nth-child(3) .p-TabBar-tabIcon:before { color: #aaa; }
351
352        .message { width: 90%; font-size: 26px; text-align: center; margin: 70px 0; font-weight: bold;}
353
354        @media (max-width: 1000px) {
355            .options { grid-template-columns: repeat(3, auto) !important; }
356            .options > :nth-child(4) { display: none; }
357
358            .transpilation-step { grid-template-columns: 35px auto 70px 70px 70px 70px 70px; }
359            .transpilation-step > :nth-child(2) { font-size: 12px !important; }
360            .transpilation-step > :nth-child(3) { display: none; }
361        }
362
363        @media (max-width:985px) {
364            .title h1 { font-size: 26px; }
365            .logo {margin : 0px 2px;}
366            .transpilation-step { grid-template-columns: 35px auto 70px 70px 70px 70px; }
367            .transpilation-step > :nth-child(6) { display: none; }
368
369        }
370
371        @media (max-width:800px) {
372            
373            
374            .options { grid-template-columns: repeat(2, auto) !important; }
375            .options > :nth-child(3) { display: none; }
376
377            .transpilation-step { grid-template-columns: 35px auto 70px 70px 70px; }
378            .transpilation-step > :nth-child(7) { display: none; }
379        }
380
381        @media (max-width:700px) {
382            
383            .summary-panel { grid-template-columns: repeat(1, auto) !important; }
384
385            .property-set { width: 100% !important; }
386            .property-items { display: none !important; }
387
388            .circuit-export-wpr a {
389                font-size: 12px;
390                padding: 2px 6px;
391            }
392
393            .transpilation-step { grid-template-columns: 35px auto 70px 70px; }
394            .transpilation-step > :nth-child(5) { display: none; }
395        }
396
397        @media (max-width:550px) {
398             .logo {display: none;}
399             .title {font-size : 14px;}
400            .transpilation-step { grid-template-columns: 35px auto; }
401            .transpilation-step > :nth-child(4) { display: none; }
402            .transpilation-step > :nth-child(8) { display: none; }
403        }
404
405        .lds-spinner {
406            position: relative;
407            width: 80px;
408            height: 80px;
409            margin: 50px auto;
410        }
411        .lds-spinner div {
412            transform-origin: 40px 40px;
413            animation: lds-spinner 1.2s linear infinite;
414        }
415        .lds-spinner div:after {
416            content: " ";
417            display: block;
418            position: absolute;
419            top: 3px;
420            left: 37px;
421            width: 6px;
422            height: 18px;
423            border-radius: 20%;
424            background: #aaa;
425        }
426        .lds-spinner div:nth-child(1) {
427            transform: rotate(0deg);
428            animation-delay: -1.1s;
429        }
430        .lds-spinner div:nth-child(2) {
431            transform: rotate(30deg);
432            animation-delay: -1s;
433        }
434        .lds-spinner div:nth-child(3) {
435            transform: rotate(60deg);
436            animation-delay: -0.9s;
437        }
438        .lds-spinner div:nth-child(4) {
439            transform: rotate(90deg);
440            animation-delay: -0.8s;
441        }
442        .lds-spinner div:nth-child(5) {
443            transform: rotate(120deg);
444            animation-delay: -0.7s;
445        }
446        .lds-spinner div:nth-child(6) {
447            transform: rotate(150deg);
448            animation-delay: -0.6s;
449        }
450        .lds-spinner div:nth-child(7) {
451            transform: rotate(180deg);
452            animation-delay: -0.5s;
453        }
454        .lds-spinner div:nth-child(8) {
455            transform: rotate(210deg);
456            animation-delay: -0.4s;
457        }
458        .lds-spinner div:nth-child(9) {
459            transform: rotate(240deg);
460            animation-delay: -0.3s;
461        }
462        .lds-spinner div:nth-child(10) {
463            transform: rotate(270deg);
464            animation-delay: -0.2s;
465        }
466        .lds-spinner div:nth-child(11) {
467            transform: rotate(300deg);
468            animation-delay: -0.1s;
469        }
470        .lds-spinner div:nth-child(12) {
471            transform: rotate(330deg);
472            animation-delay: 0s;
473        }
474        @keyframes lds-spinner {
475            0% { opacity: 1; }
476            100% { opacity: 0; }
477        }
478        </style>
479        """

Return the style for the debugger