Skip to content

Commit

Permalink
Restyling debug panel
Browse files Browse the repository at this point in the history
Signed-off-by: Anatoliy Bazko <abazko@redhat.com>
  • Loading branch information
tolusha committed Aug 14, 2018
1 parent 73546f2 commit c7034ac
Show file tree
Hide file tree
Showing 7 changed files with 118 additions and 107 deletions.
2 changes: 1 addition & 1 deletion packages/core/src/browser/shell/tab-bars.ts
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ export class TabBarRenderer extends TabBar.Renderer {
const iconSize = data.iconSize;
let height: string | undefined;
if (labelSize || iconSize) {
const labelHeight = labelSize ? labelSize.width : 0;
const labelHeight = labelSize ? (this.tabBar && this.tabBar.orientation === 'horizontal' ? labelSize.height : labelSize.width) : 0;
const iconHeight = iconSize ? iconSize.height : 0;
let paddingTop = data.paddingTop || 0;
if (labelHeight > 0 && iconHeight > 0) {
Expand Down
100 changes: 41 additions & 59 deletions packages/debug/src/browser/style/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -14,105 +14,75 @@
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************/

.theia-debug-panel {
display: flex;
}
.theia-debug-panel { }

.theia-debug-panel:focus {
outline: 0;
box-shadow: none;
}

.theia-debug-target {
display: flex;
}

.theia-debug-threads-container {
overflow: auto;
display: inline-table;
color: var(--theia-ui-font-color1);
background: var(--theia-layout-color0);
font-size: var(--theia-ui-font-size1);
max-height: calc(100% - var(--theia-border-width));
position: relative;
width: 300px;
width: 100%;
}

.theia-debug-threads-container:focus .theia-mod-selected {
.theia-debug-entry { }

.theia-debug-entry:focus .theia-mod-selected {
background: var(--theia-accent-color3);
}

.theia-debug-threads-container:not(:focus) .theia-mod-selected {
.theia-debug-entry:not(:focus) .theia-mod-selected {
background: var(--theia-accent-color4);
}

.theia-debug-thread {
.theia-debug-threads {
overflow: auto;
height: 180px;
}

.theia-debug-thread-item {
line-height: var(--theia-private-horizontal-tab-height);
align-items: baseline;
padding-left: 5px;
display: flex;
}

.theia-debug-thread:hover {
.theia-debug-thread-item:hover {
background: var(--theia-accent-color4);
cursor: pointer;
}

.theia-debug-frames-container {
.theia-debug-frames {
overflow: auto;
color: var(--theia-ui-font-color1);
background: var(--theia-layout-color0);
font-size: var(--theia-ui-font-size1);
max-height: calc(100% - var(--theia-border-width));
position: relative;
width: 400px;
}

.theia-debug-frames-container:focus .theia-mod-selected {
background: var(--theia-accent-color3);
}

.theia-debug-frames-container:not(:focus) .theia-mod-selected {
background: var(--theia-accent-color4);
height: 200px;
}

.theia-debug-frame {
.theia-debug-frame-item {
line-height: var(--theia-private-horizontal-tab-height);
align-items: baseline;
padding-left: 5px;
display: flex;
}

.theia-debug-frame:hover {
.theia-debug-frame-item:hover {
background: var(--theia-accent-color4);
cursor: pointer;
}

.theia-debug-breakpoints-container {
.theia-debug-breakpoints {
overflow: auto;
color: var(--theia-ui-font-color1);
background: var(--theia-layout-color0);
font-size: var(--theia-ui-font-size1);
max-height: calc(100% - var(--theia-border-width));
position: relative;
width: 400px;
}

.theia-debug-breakpoints-container:focus .theia-mod-selected {
background: var(--theia-accent-color3);
}

.theia-debug-breakpoints-container:not(:focus) .theia-mod-selected {
background: var(--theia-accent-color4);
height: 150px;
}

.theia-debug-breakpoint {
.theia-debug-breakpoint-item {
line-height: var(--theia-private-horizontal-tab-height);
align-items: baseline;
padding-left: 5px;
display: flex;
}

.theia-debug-breakpoint:hover {
.theia-debug-breakpoint-item:hover {
background: var(--theia-accent-color4);
cursor: pointer;
}
Expand All @@ -121,24 +91,36 @@
height: 400px;
}

.theia-debug-variables-container {
overflow: auto;
color: var(--theia-ui-font-color1);
.theia-debug-breakpoint-dialog .theia-debug-breakpoints {
background: var(--theia-layout-color0);
font-size: var(--theia-ui-font-size1);
max-height: calc(100% - var(--theia-border-width));
position: relative;
width: 400px;
height: 380px
}

.theia-debug-variables {
overflow: hidden;
height: 200px;
white-space: nowrap;
}

.theia-debug-active-line {
background-color: rgba(255, 120, 100, 0.5);
}

.theia-debug-header {
background: var(--theia-layout-color3);
text-transform: uppercase;
font-size: var(--theia-ui-font-size0);
font-weight: 800;
border: 4px solid;
border-color: var(--theia-layout-color3);
}

.theia-debug-inactive-breakpoint {
transform: scale(0.5);
background-image: url();
}

.theia-debug-active-breakpoint {
transform: scale(0.5);
background-image: url();
}
26 changes: 16 additions & 10 deletions packages/debug/src/browser/view/debug-breakpoints-widget.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import { injectable, inject, postConstruct } from "inversify";
import { BreakpointsManager } from "../breakpoint/breakpoint-manager";
import { ExtDebugProtocol } from "../../common/debug-common";
import { DebugUtils } from "../debug-utils";
import { Disposable } from "@theia/core";

/**
* Is it used to display breakpoints.
Expand All @@ -41,16 +42,19 @@ export class DebugBreakpointsWidget extends VirtualWidget {
super();

this.id = 'debug-breakpoints' + (debugSession ? `-${debugSession.sessionId}` : '');
this.addClass(Styles.BREAKPOINTS_CONTAINER);
this.addClass('theia-debug-entry');
this.node.setAttribute("tabIndex", "0");

}

@postConstruct()
protected init() {
this.breakpointManager.onDidChangeBreakpoints(() => this.refreshBreakpoints());
this.toDisposeOnDetach.push(this.breakpointManager.onDidChangeBreakpoints(() => this.refreshBreakpoints()));
if (this.debugSession) {
this.debugSession.on('configurationDone', () => this.refreshBreakpoints());
const configurationDoneListener = () => this.refreshBreakpoints();

this.debugSession.on('configurationDone', configurationDoneListener);
this.toDisposeOnDetach.push(Disposable.create(() => this.debugSession!.removeListener('configurationDone', configurationDoneListener)));
}
}

Expand All @@ -68,24 +72,26 @@ export class DebugBreakpointsWidget extends VirtualWidget {
} else {
this.breakpoints = await this.breakpointManager.getAll();
}
this.breakpoints.sort();

super.update();
}

protected render(): h.Child {
const header = h.div({ className: "theia-header" }, "Breakpoints");
const header = h.div({ className: "theia-debug-header" }, "Breakpoints");
const items: h.Child = [];

for (const breakpoint of this.breakpoints) {
const item =
h.div({
id: DebugUtils.makeBreakpointId(breakpoint),
className: Styles.BREAKPOINT,
className: Styles.BREAKPOINT_ITEM,
onclick: event => {
const selected = this.node.getElementsByClassName(SELECTED_CLASS)[0];
if (selected) {
selected.className = Styles.BREAKPOINT;
selected.className = Styles.BREAKPOINT_ITEM;
}
(event.target as HTMLDivElement).className = `${Styles.BREAKPOINT} ${SELECTED_CLASS}`;
(event.target as HTMLDivElement).className = `${Styles.BREAKPOINT_ITEM} ${SELECTED_CLASS}`;

this.onDidClickBreakpointEmitter.fire(breakpoint);
},
Expand All @@ -94,7 +100,7 @@ export class DebugBreakpointsWidget extends VirtualWidget {
items.push(item);
}

return [header, h.div(items)];
return [header, h.div({ className: Styles.BREAKPOINTS }, items)];
}

private toDisplayName(breakpoint: ExtDebugProtocol.AggregatedBreakpoint): string {
Expand Down Expand Up @@ -165,7 +171,7 @@ export class BreakpointsDialog extends AbstractDialog<void> {
}

namespace Styles {
export const BREAKPOINTS_CONTAINER = 'theia-debug-breakpoints-container';
export const BREAKPOINT = 'theia-debug-breakpoint';
export const BREAKPOINTS = 'theia-debug-breakpoints';
export const BREAKPOINT_ITEM = 'theia-debug-breakpoint-item';
export const BREAKPOINT_DIALOG = 'theia-debug-breakpoint-dialog';
}
36 changes: 24 additions & 12 deletions packages/debug/src/browser/view/debug-stack-frames-widget.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,10 @@ import {
import { DebugSession } from "../debug-model";
import { h } from '@phosphor/virtualdom';
import { DebugProtocol } from 'vscode-debugprotocol';
import { injectable, inject } from "inversify";
import { injectable, inject, postConstruct } from "inversify";
import { DebugSelection } from "./debug-selection-service";
import { SourceOpener, DebugUtils } from "../debug-utils";
import { Disposable } from "@theia/core";

/**
* Is it used to display call stack.
Expand All @@ -39,11 +40,22 @@ export class DebugStackFramesWidget extends VirtualWidget {
super();

this.id = this.createId();
this.addClass(Styles.FRAMES_CONTAINER);
this.addClass('theia-debug-entry');
this.node.setAttribute("tabIndex", "0");
this.debugSession.on('stopped', event => this.onStoppedEvent(event));
this.debugSession.on('continued', event => this.onContinuedEvent(event));
this.debugSelection.onDidSelectThread(thread => this.onThreadSelected(thread));
}

@postConstruct()
protected init() {
this.toDisposeOnDetach.push(this.debugSelection.onDidSelectThread(thread => this.onThreadSelected(thread)));

const stoppedEventListener = (event: DebugProtocol.StoppedEvent) => this.onStoppedEvent(event);
const continuedEventListener = (event: DebugProtocol.ContinuedEvent) => this.onContinuedEvent(event);

this.debugSession.on('stopped', stoppedEventListener);
this.debugSession.on('continued', continuedEventListener);

this.toDisposeOnDetach.push(Disposable.create(() => this.debugSession.removeListener('stopped', stoppedEventListener)));
this.toDisposeOnDetach.push(Disposable.create(() => this.debugSession.removeListener('continued', continuedEventListener)));
}

get frames(): DebugProtocol.StackFrame[] {
Expand All @@ -56,12 +68,12 @@ export class DebugStackFramesWidget extends VirtualWidget {
}

protected render(): h.Child {
const header = h.div({ className: "theia-header" }, "Call stack");
const header = h.div({ className: "theia-debug-header" }, "Call stack");
const items: h.Child = [];

const selectedFrame = this.debugSelection.frame;
for (const frame of this._frames) {
const className = Styles.FRAME + (DebugUtils.isEqual(selectedFrame, frame) ? ` ${SELECTED_CLASS}` : '');
const className = Styles.FRAME_ITEM + (DebugUtils.isEqual(selectedFrame, frame) ? ` ${SELECTED_CLASS}` : '');
const id = this.createId(frame);

const item =
Expand All @@ -76,7 +88,7 @@ export class DebugStackFramesWidget extends VirtualWidget {
items.push(item);
}

return [header, h.div(items)];
return [header, h.div({ className: Styles.FRAMES }, items)];
}

protected onThreadSelected(thread: DebugProtocol.Thread | undefined) {
Expand All @@ -93,14 +105,14 @@ export class DebugStackFramesWidget extends VirtualWidget {
if (currentFrame) {
const element = document.getElementById(this.createId(currentFrame));
if (element) {
element.className = Styles.FRAME;
element.className = Styles.FRAME_ITEM;
}
}

if (newFrame) {
const element = document.getElementById(this.createId(newFrame));
if (element) {
element.className = `${Styles.FRAME} ${SELECTED_CLASS}`;
element.className = `${Styles.FRAME_ITEM} ${SELECTED_CLASS}`;
}
}

Expand Down Expand Up @@ -151,6 +163,6 @@ export class DebugStackFramesWidget extends VirtualWidget {
}

namespace Styles {
export const FRAMES_CONTAINER = 'theia-debug-frames-container';
export const FRAME = 'theia-debug-frame';
export const FRAMES = 'theia-debug-frames';
export const FRAME_ITEM = 'theia-debug-frame-item';
}
Loading

0 comments on commit c7034ac

Please sign in to comment.