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

Label artifacts on long pages #236

Open
benrifkah opened this issue Aug 14, 2013 · 3 comments
Open

Label artifacts on long pages #236

benrifkah opened this issue Aug 14, 2013 · 3 comments

Comments

@benrifkah
Copy link

Some graphs with labels leave text artifacts when used on long pages over 10000px in height.

Steps to reproduce:

  1. Visit the flotr2 examples page here: http://www.humblesoftware.com/flotr2/#!basic-axis
  2. Inspect the #header div with your favorite developer tools.
  3. Add the following style to the #header div "height: 10000px" to make the page very long and push the example graph far down the page

Results: in the area where the graph example is displayed note the floating "This is a subtitle" text artifact which occludes the "Basic Axis example" heading.

Expected Results: no text artifact.

This example is admittedly contrived. However, I have some long report pages where this is an issue.

@benrifkah
Copy link
Author

I traced this to the following code in the flotr2.js file:

2277   html : function (text, element, style, className) {
2278
2279     var div = D.create('div');
2280
2281     D.setStyles(div, { 'position' : 'absolute', 'top' : '-10000px' });
2282     D.insert(div, '<div style="'+style+'" class="'+className+' flotr-dummy-div">' + text + '</div>');
2283     D.insert(this.o.element, div);
2284
2285     return D.size(div);
2286   },

This inserts a div that is meant to be invisible so that the dimensions of text can be determined if it is rendered as html. The div is made invisible by placing it 10000px above the position of the graph. The div is then returned and the height and width are taken from its attributes by the Text.html() caller.

I believe this can be fixed by storing the results of D.size(div) and then removing the dummy div before returning the results. I'll submit a pull request later today.

benrifkah added a commit to benrifkah/Flotr2 that referenced this issue Aug 14, 2013
@benrifkah
Copy link
Author

Here is a jsfiddle that demonstrates the problem.

@Pyrolistical
Copy link

Ran into this today. If you just need it for the dim, why not delete it afterwards?

shimondoodkin added a commit to shimondoodkin/Flotr2 that referenced this issue Apr 5, 2018
hide dummy div after measuring for issue HumbleSoftware#236
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

2 participants