Skip to content Skip to sidebar Skip to footer

Bar Chart Plugin - Make The Each Bar Clickable (diffrenet Link For Each )

i have used a plugin http://www.jqueryscript.net/demo/Simple-Bar-Chart-Plugin-with-jQuery-Bootstrap-jchart/ but the problem is that ,I am not able to make the bars clickable . My

Solution 1:

I have forked your fiddle and updated it here: http://jsfiddle.net/5ryEZ/5/

Changes: The plugin had to be edited for this to work. I copied the entire plugin into document.ready() and made the changes.

<divclass="define-chart-row"data-clicker="http://google.com"data-color="#009182"title="1">13</div>

Your code for document.ready is present at the bottom. For urls, add "data-clicker" attribute to the divs.

/* replace this code in the jChart.js */
    $.fn.jChart = function (options) {
        var selector = $(this);
        var default_color = "#6b9bd6";
        var bar_height = 19;

        var settings = $.extend({
            width: 750,
            clicker: "http://wditot.in",
            name: null,
            type: "bar",
            headers: null,
            values: null,
            footers: Array(),
            sort: false,
            sort_colors: false,
            colors: Array(),
            x_label: null
        }, options);

        //Initialize some settings that can be set via HTMLif (settings.name == null) {
            settings.name = $(this).attr("name");
        }
        if ($(this).data("sort") == true) {
            settings.sort = true;
        }
        if ($(this).data("width") != null) {
            settings.width = parseInt($(this).data("width"));
        }
        if ($(this).data("x_label") != null) {
            settings.x_label = $(this).data("x_label");
        }
        if ($(this).data("clicker") != null) {
            settings.clicker = $(this).data("clicker");
        }
        var chart_width = settings.width;
        if ($(this).hasClass("chart-sm")) {
            bar_height = 17;
        } elseif ($(this).hasClass("chart-lg")) {
            bar_height = 25;
        } elseif (settings.width != null) {
            chart_width = parseInt(settings.width);
        }

        checkForHTMLSettings();

        //Clear the data in the jChart div
        $(this).html("");

        //Create the html containers for the chartvar chart_title = $("<div>", {
            class: "chart-title",
            html: settings.name
        });
        var legend_left = $("<div>", {
            class: "legend legend-left"
        });
        var x_label = $("<span>", {
            class: "chart-x-label",
            html: settings.x_label
        });

        //Calculate what the chart width should bevar max_data = Math.max.apply(Math, settings.values);
        var max_footer = Math.max.apply(Math, settings.footers);
        var maxes = [max_data, max_footer];
        var chart_max = Math.max.apply(Math, maxes);
        var container_width = chart_width + 250;

        var chart_container = $("<div>", {
            class: "chart-container",
            width: container_width + "px"
        });
        var chart = $("<div>", {
            class: "chart",
            width: chart_width + "px"
        });
        var legend_bottom = $("<div>", {
            class: "legend-bottom"
        });

        //Place the containers into the target element
        $(this).append(chart_container);
        chart_container.append(chart_title);
        chart_container.append(legend_left);
        chart_container.append(chart);

        //Sort the data if the setting is enabled (Insertion sort)if (settings.sort) {
            for (var i = 1; i < settings.values.length; i++) {
                var j = i;
                while (j > 0 && settings.values[j - 1] < settings.values[j]) {
                    var temp = settings.values[j];
                    var head_temp = settings.headers[j];
                    settings.values[j] = settings.values[j - 1];
                    settings.values[j - 1] = temp;

                    //Sort headings
                    settings.headers[j] = settings.headers[j - 1];
                    settings.headers[j - 1] = head_temp;

                    //Sort colorsif (settings.sort_colors) {
                        var color_temp = settings.colors[j];
                        settings.colors[j] = settings.colors[j - 1];
                        settings.colors[j - 1] = color_temp;
                    }
                    j--;
                }
            }
        }

        //Loop through headings and create/place them and their corresponding value barsfor (var i = 0; i < settings.headers.length; i++) {
            var heading = $("<div>", {
                class: "heading heading-left",
                style: "height: " + bar_height + "px;font-size: 10pt;",
                html: settings.headers[i]
            });
            var bar_width = (settings.values[i] / chart_max) * chart_width;
            var bar = $("<div>", {
                class: "bar",
                    "data-placement": "right",
                    "data-toggle": "tooltip",
                title: commaSeparateNumber(settings.values[i]),
                style: "height:" + bar_height + "px;background-color:" + settings.colors[i % settings.colors.length],
                width: bar_width,
                onclick: settings.clicker[i]
            });
            legend_left.append(heading);
            chart.append(bar);
        }
        chart.append(legend_bottom);
        for (var i = 0; i < settings.footers.length; i++) {
            var margin = "margin-left:" + ((settings.footers[i] / chart_max) * chart_width - 9).toString() + "px;";
            var chart_label_bottom = $("<div>", {
                class: "chart-label chart-label-bottom",
                style: margin,
                html: commaSeparateNumber(settings.footers[i])
            });
            var margin = "margin-left:" + ((settings.footers[i] / chart_max) * chart_width - 2).toString() + "px;";
            var chart_label_hr = $("<div>", {
                class: "chart-label-hr",
                style: margin

            });
            legend_bottom.append(chart_label_bottom);
            chart.append(chart_label_hr);
            legend_bottom.append(x_label);
        }

        //Enable hover details
        $(".bar").tooltip();

        returnthis;

        /**
         * Checks for settings defined in the HTML
         * like chart-define-row and chart-define-footer classes
         */functioncheckForHTMLSettings() {
            //Check for HTML defined bar chart dataif (selector.find(".define-chart-row").length > 0) {
                settings.headers = Array();
                settings.values = Array();
                settings.clicker = Array();
                selector.find(".define-chart-row").each(function () {
                    settings.headers.push($(this).attr("title"));
                    var value = $(this).html();
                    if (value == null || value == "") {
                        settings.values.push(0);
                    } else {
                        settings.values.push(parseInt(value));
                    }
                    var color = $(this).data("color");
                    var clicker = $(this).data("clicker"); {
                        if (clicker == null || clicker == "") {
                            settings.clicker.push('#');
                        } else {
                            settings.clicker.push(clicker);
                        }

                    }
                    if (color != null) {
                        settings.sort_colors = true;
                        settings.colors.push(color);
                    } else {
                        settings.colors.push(default_color);
                    }
                });
            } else {
                settings.colors.push(default_color);
            }
            //Check for HTML defined footersif (selector.find(".define-chart-footer").length > 0) {
                settings.footers = Array();
                selector.find(".define-chart-footer").each(function () {
                    var footer = $(this).html();
                    if (footer != null && footer != "") {
                        settings.footers.push(parseInt(footer));
                    }
                });
            }
        }

        /**
         * Converts a number into a comma separated string
         */functioncommaSeparateNumber(val) {
            while (/(\d+)(\d{3})/.test(val.toString())) {
                val = val.toString().replace(/(\d+)(\d{3})/, '$1' + ',' + '$2');
            }
            return val;
        }


    };

    /* End of code to be copied into jChart.js */

Post a Comment for "Bar Chart Plugin - Make The Each Bar Clickable (diffrenet Link For Each )"