Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Critical path configuration menu and critical path view #1065

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 6 additions & 1 deletion packages/base/src/signals/signal-manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ export declare interface SignalManager {
fireRequestSelectionRangeChange(payload: TimeRangeUpdatePayload): void;
fireContributeContextMenu(payload: ContextMenuContributedSignalPayload): void;
fireContextMenuItemClicked(payload: ContextMenuItemClickedSignalPayload): void;
fireTraceContexModelUpdated(payload: { [key: string]: unknown }): void;
}

export const Signals = {
Expand Down Expand Up @@ -84,7 +85,8 @@ export const Signals = {
REQUEST_SELECTION_RANGE_CHANGE: 'change selection range',
OUTPUT_DATA_CHANGED: 'output data changed',
CONTRIBUTE_CONTEXT_MENU: 'contribute context menu',
CONTEXT_MENU_ITEM_CLICKED: 'context menu item clicked'
CONTEXT_MENU_ITEM_CLICKED: 'context menu item clicked',
TRACE_MODEL_UPDATED: 'trace model updated'
};

export class SignalManager extends EventEmitter implements SignalManager {
Expand Down Expand Up @@ -193,6 +195,9 @@ export class SignalManager extends EventEmitter implements SignalManager {
fireContextMenuItemClicked(payload: ContextMenuItemClickedSignalPayload): void {
this.emit(Signals.CONTEXT_MENU_ITEM_CLICKED, payload);
}
fireTraceContexModelUpdated(payload: { [key: string]: unknown }): void {
this.emit(Signals.TRACE_MODEL_UPDATED, payload);
}
}

let instance: SignalManager = new SignalManager();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,8 @@
this.chartLayer.updateChart();
}, 500);

private additonalParameters: { [key: string]: unknown } | undefined;

constructor(props: TimegraphOutputProps) {
super(props);
this.state = {
Expand Down Expand Up @@ -260,6 +262,12 @@
});
this.waitAnalysisCompletion();
this.subscribeToEvents();

/* Server-side context menus */
if (this.props.outputDescriptor) {
console.log('this.props.outputDescriptor');
this.registerServerSideMenus();
}
}

componentWillUnmount(): void {
Expand All @@ -273,13 +281,17 @@
signalManager().on(Signals.OUTPUT_DATA_CHANGED, this.onOutputDataChanged);
signalManager().on(Signals.THEME_CHANGED, this.onThemeChange);
signalManager().on(Signals.SELECTION_CHANGED, this.onSelectionChanged);
signalManager().on(Signals.CONTEXT_MENU_ITEM_CLICKED, this._onContextMenuItemClicked);
signalManager().on(Signals.TRACE_MODEL_UPDATED, this.onModelUpdated);
}

protected unsubscribeToEvents(): void {
signalManager().off(Signals.CONTRIBUTE_CONTEXT_MENU, this.onContextMenuContributed);
signalManager().off(Signals.OUTPUT_DATA_CHANGED, this.onOutputDataChanged);
signalManager().off(Signals.THEME_CHANGED, this.onThemeChange);
signalManager().off(Signals.SELECTION_CHANGED, this.onSelectionChanged);
signalManager().off(Signals.CONTEXT_MENU_ITEM_CLICKED, this._onContextMenuItemClicked);
signalManager().off(Signals.TRACE_MODEL_UPDATED, this.onModelUpdated);
}

async fetchTree(): Promise<ResponseStatus> {
Expand Down Expand Up @@ -1482,4 +1494,44 @@
);
this.chartLayer.selectAndReveal(rowIndex);
}

protected registerServerSideMenus(): void {
// TODO: create generic API to register server driven menus
const ctxMenu: ContextMenuItems = {
submenus: [],
items: [{ id: 'org.eclipse.tracecompass.follow.thread.id', label: 'Follow thread' }]
};
const pld: ContextMenuContributedSignalPayload = new ContextMenuContributedSignalPayload(
this.props.outputDescriptor.id,
ctxMenu
);
signalManager().fireContributeContextMenu(pld);
}

private _onContextMenuItemClicked = async (payload: ContextMenuItemClickedSignalPayload): Promise<void> => {
// handle item clicked payload and perform whatever function you need to based on the selection
// TODO: create generic API to execute command-handler for server driven actions
// For example, a pre-defined way to query additional query parameters that are passed to back-end calls (global filter)

if (payload?.getItemId() === 'org.eclipse.tracecompass.follow.thread.id') {
const items: { id: number; parentId?: number; metadata?: { [key: string]: unknown } }[] =
payload.getProps()['selectedRows'];
const item = items[0].id;
const parameters = QueryHelper.selectionQuery([item]);

Check failure on line 1520 in packages/react-components/src/components/timegraph-output-component.tsx

View workflow job for this annotation

GitHub Actions / Build and test (ubuntu-latest, 18)

Property 'selectionQuery' does not exist on type 'typeof QueryHelper'.
const tspClientResponse = await this.props.tspClient.fetchTimeGraphTreeContext(

Check failure on line 1521 in packages/react-components/src/components/timegraph-output-component.tsx

View workflow job for this annotation

GitHub Actions / Build and test (ubuntu-latest, 18)

Property 'fetchTimeGraphTreeContext' does not exist on type 'ITspClient'.
this.props.traceId,
this.props.outputDescriptor.id,
parameters
);
const model: { [key: string]: unknown } | undefined = tspClientResponse.getModel()?.model;
if (model) {
signalManager().fireTraceContexModelUpdated(model);
}
}
};

onModelUpdated = (model: { [key: string]: unknown }): void => {
// TODO add model as addtional parameters to back-end queries
this.additonalParameters = model;
};
}
Original file line number Diff line number Diff line change
Expand Up @@ -219,6 +219,23 @@ export class TheiaRpcTspProxy implements ITspClient {
);
}

/**
* Fetch Time Graph tree, Model is a key-value map
* @param expUUID Experiment UUID
* @param outputID Output ID
* @param parameters Query object
* @returns Time graph entry response with model is a key-value map
*/
public async fetchTimeGraphTreeContext(
expUUID: string,
outputID: string,
parameters: Query
): Promise<TspClientResponse<GenericResponse<{ [key: string]: unknown }>>> {
return this.toTspClientResponse<GenericResponse<{ [key: string]: unknown }>>(
await this.tspClient.fetchTimeGraphTreeContext(expUUID, outputID, parameters)
);
}

/**
* Fetch Time Graph states. Model extends TimeGraphModel
* @param expUUID Experiment UUID
Expand Down
Loading