Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
270
Chart tool tip position in cross browser
posted

Hi,

We customize chart tooltip formatting everything working fine in Internet Explorer and Google Chrome but not working perfectly in Mozilla Firefox.

Issues details

  • If you open attached sample application in IE and chrome tooltip working fine next to the point hover in chart area, but in Mozilla Firefox tooltip is always in upper left corner with following issues date format and volume commas are disturbed, can you fix those, so our chart is compatible in all browsers ?

                [Firefox] Format price and volume like this

                      o   Date format:  10/29/15

                      o   All prices should be fixed at 2 decimal places

                      o   Volume should use commas

  • Tooltip prices (open, high, low, close) is not properly fixed at 2 decimal places, Zero (0) is not appeared after decimals like we have High value in chart collection is '47.6000' but display in tooltip like this '47.6' zero (0) is not displayed. How to fix that ?
  • Currently tooltip background is white semi-transparent color, when we set grey background its transparency is go away. How to set semi-transparent grey background (#F7F7F7) of tooltip with sky blue border color ? 

Regards,

Sufyan

Chart.zip
Parents Reply
  • 8421
    posted in reply to Abu Sufyan

    Hello Sufyan,

    Looking in to this the tooltip position issue was due to Firefox not supporting innerText. What you need to use is textContent instead which is considered the standard by the W3C. If you change all of your innerText calls to textContent then the tooltip shows in the correct position with the formatting that you want on the date and Vol fields. Essentially what was happening is that a JavaScript error was getting thrown in your tooltipShown event and prevented the rest of the logic from executing.

    As for formatting the rest of the numbers, you can modify your tooltipShown event to call toFixed(2) and update the labels. All together your event handler would look like the following:

    tooltipShown: function (evt, ui) {
        var labels = ui.element.find("label");
        for (var i = 0; i < labels.length; i++) {
            var labelStart = labels[i].textContent.slice(0, -1);

            if (labelStart === "Vol") {
                var divVol = $(labels[i]).parent();
                var labelMarkup = "<label style='width: 45px; font-weight: bold;'>Vol:</label> ";
                $(divVol).empty().html(labelMarkup + ui.item["Volume"].toLocaleString());
            }
            else if (labelStart === "Date") {
                var divEl = $(labels[i]).parent();

                var labelMarkup = "<label style='width: 45px; font-weight: bold;'>Date:</label> ";
                var month = ui.item[labelStart].toDateTime().getMonth() + 1;
                var date = ui.item[labelStart].toDateTime().getDate();
                var year = ui.item[labelStart].toDateTime().getFullYear().toString().substr(2, 2);

                $(divEl).empty().html(labelMarkup + month + "/" + date + "/" + year);
            }
            else {
                var divVal = $(labels[i]).parent();

                var labelMarkup = "<label style='width: 45px; font-weight: bold;'>" + labelStart + ":</label> ";
                var formattedNumber = ui.item[labelStart].toFixed(2);

                $(divVal).empty().html(labelMarkup + formattedNumber);
            }
        }
    },

    I've attached a modified version of your sample so you can see these changes there.

    As for the wrapping issue, is that occurring in a specific browser? I have not been able to reproduce that behavior. What are the steps that I need to follow to get that behavior?

    ChartMod.zip
Children
No Data