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

Using timestamps as x-axis values results in misaligned labels #450

Open
davestewart opened this issue Sep 25, 2024 · 7 comments
Open

Using timestamps as x-axis values results in misaligned labels #450

davestewart opened this issue Sep 25, 2024 · 7 comments

Comments

@davestewart
Copy link

Hello,

We're using timestamps as our Datum x-axis values, but it seems to result in misaligned x-axis labels:

image

Using indices, the labels line up perfectly:

image

Feels like a bug.

Is it?

@AnthonyCVP
Copy link

+1, I am having the same problem.

@davestewart
Copy link
Author

davestewart commented Sep 26, 2024

Right now I am using the following workaround:

  • add index values to data (which already contains timestamp)
  • set x-axis as (d) => d.index
  • in tickFormat() do this: tickFormat: (x, index) => formatAsMonth(data[index].timestamp)

EDIT: index will be incorrect if numTicks is modified (index is the index of the tick, not the datapoint), so will need to determine the datapoint index with something like:

tickFormat: (x: number) => {
  // workaround for https://github.com/f5/unovis/issues/450
  if (format.startsWith('date')) {
    const index = model.data.findIndex(d => d.index === x)
    return formatValue(model.data[index].timestamp, format)
  }
  return formatValue(x, format)
},

This gets us over a hump, until hopefully a fix arrives:

CleanShot 2024-09-26 at 18 16 06

@AnthonyCVP
Copy link

Thank you, I did that after your original post suggestion. Much appreciated @davestewart !

@garbit
Copy link

garbit commented Jan 15, 2025

Neat work around @davestewart - thanks

@dennisadriaans
Copy link

@davestewart does indeed fix it. A small addition: NumericAccessor has an index parameter you could use so that you can leave the original data untouched.

<VisGroupedBar :data="data" :x="(_: T, index: number) => index" />
<VisAxis :tick-format="(index: number) => { const value = data[index] }" />

Then you can format your date as needed.

@davestewart
Copy link
Author

@dennisadriaans thanks! I'll confirm when I'm back on this bit of the project.

@rokotyan
Copy link
Contributor

Currently, this is the expected behavior of the axis component - it doesn't know anything about your data and assumes the data is continuous and behaves the same whether you have hundreds of data points or just a few.

We may tweak this behavior later, but for now we plan to leave it as it is because it's pretty easy to reconfigure by explicitly providing an array of `tickValues'.

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

No branches or pull requests

5 participants