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

added function to show full traceID in #2536

Open
wants to merge 11 commits into
base: main
Choose a base branch
from

Conversation

avinpy-255
Copy link
Contributor

Which problem is this PR solving?

Description of the changes

  • I've added a funtion to show the full trace ID in the trace details page

How was this change tested?

  • here is the screenshot of the function Full ID
    Screenshot from 2025-01-03 18-00-08

  • after clicking the Full ID
    Screenshot from 2025-01-03 17-59-45

Checklist

@avinpy-255 avinpy-255 requested a review from a team as a code owner January 3, 2025 12:30
@avinpy-255 avinpy-255 requested review from jkowall and removed request for a team January 3, 2025 12:30
Copy link

codecov bot commented Jan 3, 2025

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 96.61%. Comparing base (14837c3) to head (b82c9dc).
Report is 3 commits behind head on main.

Additional details and impacted files
@@           Coverage Diff           @@
##             main    #2536   +/-   ##
=======================================
  Coverage   96.61%   96.61%           
=======================================
  Files         255      256    +1     
  Lines        7745     7750    +5     
  Branches     1935     2003   +68     
=======================================
+ Hits         7483     7488    +5     
  Misses        262      262           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@MAX-786
Copy link

MAX-786 commented Jan 11, 2025

looks great ... but IMHO it takes extra space as it's showing the User same information as it's already available on top. what you can do is that make the shorten traceID clickable and then clicking on it would expand to show Full ID and again clicking on it would collapse it. This would also clean-up the UI and IMO would be a better UX design

@avinpy-255
Copy link
Contributor Author

looks great ... but IMHO it takes extra space as it's showing the User same information as it's already available on top. what you can do is that make the shorten traceID clickable and then clicking on it would expand to show Full ID and again clicking on it would collapse it. This would also clean-up the UI and IMO would be a better UX design

Thanks! I'll make TraceID clickable for better UX

@avinpy-255
Copy link
Contributor Author

Hey @MAX-786
As suggested, I've successfully updated the ui here is the example:
Screencast from 2025-01-13 19-53-13.webm

@MAX-786
Copy link

MAX-786 commented Jan 13, 2025

@avinpy-255 Hi,
yepp, wait for the review from the maintainers.

@yurishkuro
Copy link
Member

The original issue was asking for configuration to make the trace ID displayed in full. There is no configuration added in this PR. The configuration can be specifying the desired length from the ID to display, e.g. 32 would display full ID.

@@ -20,6 +20,8 @@ import getVersion from '../utils/version/get-version';
import { version } from '../../package.json';
import { Config } from '../types/config';

export const TraceIDLength = 7;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we don't use constants for anything else, just use the value directly

@@ -149,7 +150,7 @@ export function TracePageHeaderFn(props: TracePageHeaderEmbedProps & { forwarded
return { ...rest, value: renderer(trace) };
});

const traceShortID = trace.traceID.slice(0, 7);
const traceShortID = trace.traceID.slice(0, TraceIDLength);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add a test?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ok, I will add a test for tracIDlength

Copy link
Member

@yurishkuro yurishkuro left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The new format should be applied consistently across the UI. I would recommend a dedicated component for trace ID display (I would also make it have a popup tooltip showing the full length string if the default max size is smaller)

image image

@@ -135,6 +135,9 @@ export type Config = {
// TODO when is it useful?
scripts?: readonly TScript[];

// traceIDLength controls the length of the trace ID displayed in the UI.
traceIDLength?: number;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
traceIDLength?: number;
traceIdDisplayLength?: number;

@@ -149,7 +150,8 @@ export function TracePageHeaderFn(props: TracePageHeaderEmbedProps & { forwarded
return { ...rest, value: renderer(trace) };
});

const traceShortID = trace.traceID.slice(0, 7);
const traceIDLength = getConfigValue('traceIDLength');
const traceShortID = trace.traceID.slice(0, traceIDLength);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This doesn't play nice with styling when very long.

image

I think the ID needs to be in smaller font.

className?: string;
};

export function TraceIdDisplayLength({ traceId, className = '' }: Props) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
export function TraceIdDisplayLength({ traceId, className = '' }: Props) {
export function TraceId({ traceId, className = '' }: Props) {

"DisplayLength" is implementation detail irrelevant to the user.

@@ -37,7 +37,7 @@ import { getTraceLinks } from '../../../model/link-patterns';
import './TracePageHeader.css';
import ExternalLinks from '../../common/ExternalLinks';
import { getTargetEmptyOrBlank } from '../../../utils/config/get-target';
import TraceIdDisplayLength from '../../common/TraceIdDisplayLength';
import TraceId from '../../common/TraceIdDisplayLength';
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
import TraceId from '../../common/TraceIdDisplayLength';
import TraceId from '../../common/TraceId';

Signed-off-by: Avinash <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Feature]: UI configuration to display the entire trace ID
3 participants