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} "> 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} "> 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