How to fix chart Legends width-height with overflow scroll in ChartJS












4















I want to create pie chart for my project, so I am using ChartJS for it, but there are some issues with chartJS, If I am work with 10 to 20 data-field that time chart is looks good, But when I am apply more than 50 to 60 data-field in one chart, So that chart is looks smaller instead of legends, and If sometimes data-field is too much than the chart is hide, you can see only legends, chart is gone.



I want to set height or width to that legends and also apply to scrollbar if there is more data.



Here is the fiddle link for your reference



https://jsfiddle.net/KDM1010/5um78rbk/



enter image description here



<canvas id="myChart" width="500" height="300"></canvas>


var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
type: 'pie',
data: {
labels: ["lable_1", "lable_2", "lable_3", "lable_4", "lable_5", "lable_6", "lable_7", "lable_8", "lable_9", "lable_10", "lable_11", "lable_12", "lable_13", "lable_14", "lable_15", "lable_16", "lable_17", "lable_18", "lable_19", "lable_20", "lable_21", "lable_22", "lable_23", "lable_24", "lable_25", "lable_26", "lable_27", "lable_28", "lable_29", "lable_30", "lable_31", "lable_32", "lable_33", "lable_34", "lable_35", "lable_36", "lable_37", "lable_38", "lable_39", "lable_40", "lable_41", "lable_42", "lable_43", "lable_44", "lable_45", "lable_46", "lable_47", "lable_48", "lable_49", "lable_50"],
datasets: [{
backgroundColor: ["#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#9a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#955a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f,"#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e"
],
data: [74, 22, 77, 19, 72, 17, 55, 14, 64, 93, 99, 58, 6, 13, 31, 61, 19, 97, 25, 94, 50, 83, 3, 15, 54, 19, 60, 41, 37, 27, 51, 21, 36, 69, 80, 20, 64, 74, 79, 48, 66, 1, 94, 57, 5, 18, 83, 41, 64, 48]
}]
}
});









share|improve this question























  • Since its an canvas so styling is futile but you can look into how space can be saved one such thing would be to change width of color box legends as jsfiddle.net/5um78rbk/1 or jsfiddle.net/5um78rbk/2 or jsfiddle.net/5um78rbk/3/try some orientation or font to utilize max space of chart hope this helps

    – Vinod Louis
    Apr 5 '17 at 11:33













  • @VinodLouis Thank you for answer but In our app we don't know how many data field we have, for example some chart has 10 data-field and some chart has more than 200 data-field, we are not fix that how many data-field we have.

    – Kaushik Makwana
    Apr 5 '17 at 11:40
















4















I want to create pie chart for my project, so I am using ChartJS for it, but there are some issues with chartJS, If I am work with 10 to 20 data-field that time chart is looks good, But when I am apply more than 50 to 60 data-field in one chart, So that chart is looks smaller instead of legends, and If sometimes data-field is too much than the chart is hide, you can see only legends, chart is gone.



I want to set height or width to that legends and also apply to scrollbar if there is more data.



Here is the fiddle link for your reference



https://jsfiddle.net/KDM1010/5um78rbk/



enter image description here



<canvas id="myChart" width="500" height="300"></canvas>


var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
type: 'pie',
data: {
labels: ["lable_1", "lable_2", "lable_3", "lable_4", "lable_5", "lable_6", "lable_7", "lable_8", "lable_9", "lable_10", "lable_11", "lable_12", "lable_13", "lable_14", "lable_15", "lable_16", "lable_17", "lable_18", "lable_19", "lable_20", "lable_21", "lable_22", "lable_23", "lable_24", "lable_25", "lable_26", "lable_27", "lable_28", "lable_29", "lable_30", "lable_31", "lable_32", "lable_33", "lable_34", "lable_35", "lable_36", "lable_37", "lable_38", "lable_39", "lable_40", "lable_41", "lable_42", "lable_43", "lable_44", "lable_45", "lable_46", "lable_47", "lable_48", "lable_49", "lable_50"],
datasets: [{
backgroundColor: ["#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#9a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#955a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f,"#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e"
],
data: [74, 22, 77, 19, 72, 17, 55, 14, 64, 93, 99, 58, 6, 13, 31, 61, 19, 97, 25, 94, 50, 83, 3, 15, 54, 19, 60, 41, 37, 27, 51, 21, 36, 69, 80, 20, 64, 74, 79, 48, 66, 1, 94, 57, 5, 18, 83, 41, 64, 48]
}]
}
});









share|improve this question























  • Since its an canvas so styling is futile but you can look into how space can be saved one such thing would be to change width of color box legends as jsfiddle.net/5um78rbk/1 or jsfiddle.net/5um78rbk/2 or jsfiddle.net/5um78rbk/3/try some orientation or font to utilize max space of chart hope this helps

    – Vinod Louis
    Apr 5 '17 at 11:33













  • @VinodLouis Thank you for answer but In our app we don't know how many data field we have, for example some chart has 10 data-field and some chart has more than 200 data-field, we are not fix that how many data-field we have.

    – Kaushik Makwana
    Apr 5 '17 at 11:40














4












4








4


0






I want to create pie chart for my project, so I am using ChartJS for it, but there are some issues with chartJS, If I am work with 10 to 20 data-field that time chart is looks good, But when I am apply more than 50 to 60 data-field in one chart, So that chart is looks smaller instead of legends, and If sometimes data-field is too much than the chart is hide, you can see only legends, chart is gone.



I want to set height or width to that legends and also apply to scrollbar if there is more data.



Here is the fiddle link for your reference



https://jsfiddle.net/KDM1010/5um78rbk/



enter image description here



<canvas id="myChart" width="500" height="300"></canvas>


var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
type: 'pie',
data: {
labels: ["lable_1", "lable_2", "lable_3", "lable_4", "lable_5", "lable_6", "lable_7", "lable_8", "lable_9", "lable_10", "lable_11", "lable_12", "lable_13", "lable_14", "lable_15", "lable_16", "lable_17", "lable_18", "lable_19", "lable_20", "lable_21", "lable_22", "lable_23", "lable_24", "lable_25", "lable_26", "lable_27", "lable_28", "lable_29", "lable_30", "lable_31", "lable_32", "lable_33", "lable_34", "lable_35", "lable_36", "lable_37", "lable_38", "lable_39", "lable_40", "lable_41", "lable_42", "lable_43", "lable_44", "lable_45", "lable_46", "lable_47", "lable_48", "lable_49", "lable_50"],
datasets: [{
backgroundColor: ["#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#9a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#955a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f,"#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e"
],
data: [74, 22, 77, 19, 72, 17, 55, 14, 64, 93, 99, 58, 6, 13, 31, 61, 19, 97, 25, 94, 50, 83, 3, 15, 54, 19, 60, 41, 37, 27, 51, 21, 36, 69, 80, 20, 64, 74, 79, 48, 66, 1, 94, 57, 5, 18, 83, 41, 64, 48]
}]
}
});









share|improve this question














I want to create pie chart for my project, so I am using ChartJS for it, but there are some issues with chartJS, If I am work with 10 to 20 data-field that time chart is looks good, But when I am apply more than 50 to 60 data-field in one chart, So that chart is looks smaller instead of legends, and If sometimes data-field is too much than the chart is hide, you can see only legends, chart is gone.



I want to set height or width to that legends and also apply to scrollbar if there is more data.



Here is the fiddle link for your reference



https://jsfiddle.net/KDM1010/5um78rbk/



enter image description here



<canvas id="myChart" width="500" height="300"></canvas>


var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
type: 'pie',
data: {
labels: ["lable_1", "lable_2", "lable_3", "lable_4", "lable_5", "lable_6", "lable_7", "lable_8", "lable_9", "lable_10", "lable_11", "lable_12", "lable_13", "lable_14", "lable_15", "lable_16", "lable_17", "lable_18", "lable_19", "lable_20", "lable_21", "lable_22", "lable_23", "lable_24", "lable_25", "lable_26", "lable_27", "lable_28", "lable_29", "lable_30", "lable_31", "lable_32", "lable_33", "lable_34", "lable_35", "lable_36", "lable_37", "lable_38", "lable_39", "lable_40", "lable_41", "lable_42", "lable_43", "lable_44", "lable_45", "lable_46", "lable_47", "lable_48", "lable_49", "lable_50"],
datasets: [{
backgroundColor: ["#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#9a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#955a6","#9b59b6","#f1c40f","#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f,"#e74c3c","#34495e","#2ecc71","#3498db","#95a5a6","#9b59b6","#f1c40f","#e74c3c","#34495e"
],
data: [74, 22, 77, 19, 72, 17, 55, 14, 64, 93, 99, 58, 6, 13, 31, 61, 19, 97, 25, 94, 50, 83, 3, 15, 54, 19, 60, 41, 37, 27, 51, 21, 36, 69, 80, 20, 64, 74, 79, 48, 66, 1, 94, 57, 5, 18, 83, 41, 64, 48]
}]
}
});






javascript jquery css chart.js pie-chart






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Apr 5 '17 at 11:16









Kaushik MakwanaKaushik Makwana

490828




490828













  • Since its an canvas so styling is futile but you can look into how space can be saved one such thing would be to change width of color box legends as jsfiddle.net/5um78rbk/1 or jsfiddle.net/5um78rbk/2 or jsfiddle.net/5um78rbk/3/try some orientation or font to utilize max space of chart hope this helps

    – Vinod Louis
    Apr 5 '17 at 11:33













  • @VinodLouis Thank you for answer but In our app we don't know how many data field we have, for example some chart has 10 data-field and some chart has more than 200 data-field, we are not fix that how many data-field we have.

    – Kaushik Makwana
    Apr 5 '17 at 11:40



















  • Since its an canvas so styling is futile but you can look into how space can be saved one such thing would be to change width of color box legends as jsfiddle.net/5um78rbk/1 or jsfiddle.net/5um78rbk/2 or jsfiddle.net/5um78rbk/3/try some orientation or font to utilize max space of chart hope this helps

    – Vinod Louis
    Apr 5 '17 at 11:33













  • @VinodLouis Thank you for answer but In our app we don't know how many data field we have, for example some chart has 10 data-field and some chart has more than 200 data-field, we are not fix that how many data-field we have.

    – Kaushik Makwana
    Apr 5 '17 at 11:40

















Since its an canvas so styling is futile but you can look into how space can be saved one such thing would be to change width of color box legends as jsfiddle.net/5um78rbk/1 or jsfiddle.net/5um78rbk/2 or jsfiddle.net/5um78rbk/3/try some orientation or font to utilize max space of chart hope this helps

– Vinod Louis
Apr 5 '17 at 11:33







Since its an canvas so styling is futile but you can look into how space can be saved one such thing would be to change width of color box legends as jsfiddle.net/5um78rbk/1 or jsfiddle.net/5um78rbk/2 or jsfiddle.net/5um78rbk/3/try some orientation or font to utilize max space of chart hope this helps

– Vinod Louis
Apr 5 '17 at 11:33















@VinodLouis Thank you for answer but In our app we don't know how many data field we have, for example some chart has 10 data-field and some chart has more than 200 data-field, we are not fix that how many data-field we have.

– Kaushik Makwana
Apr 5 '17 at 11:40





@VinodLouis Thank you for answer but In our app we don't know how many data field we have, for example some chart has 10 data-field and some chart has more than 200 data-field, we are not fix that how many data-field we have.

– Kaushik Makwana
Apr 5 '17 at 11:40












2 Answers
2






active

oldest

votes


















12














You can try one thing



Try to separate the legend into an different div. now you have full control of the div you can use custom placement and css of your own consider the following code :



 <div id="js-legend" class="chart-legend"></div>
document.getElementById('js-legend').innerHTML = myChart.generateLegend();


For reference see this FIDDLE



For handling legend interactive you need to extend the callback function and manipulate like this :



$("#js-legend > ul > li").on("click",function(e){
var index = $(this).index();
$(this).toggleClass("strike")
var ci = e.view.myChart;
var curr = ci.data.datasets[0]._meta[0].data[index];
curr.hidden = !curr.hidden
ci.update();
})


For Legend in action see this FIDDLE



Explanation :



I binded chart to window so that event view can get it, and later by the index manipulated the data and updated runtime used few css tricks to illustrate the strike effect.






share|improve this answer


























  • Aweeesommee mate !!!!!!!!!!!!!

    – Kaushik Makwana
    Apr 5 '17 at 11:54











  • :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

    – Vinod Louis
    Apr 5 '17 at 11:56











  • Yes that's what I want.... Thank you vary much..... I love your work

    – Kaushik Makwana
    Apr 5 '17 at 11:58











  • You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

    – Kaushik Makwana
    Apr 5 '17 at 12:03






  • 1





    Thanks you so much mate!!! It was really helpful.. :D

    – Ajithkumar S
    Apr 9 '18 at 3:18



















1














I did not found any solution for this, but you can turn off legend if too many labels are to be shown (I did it in my project) - here is set to max 15 labels:



options : {
responsive: true,
maintainAspectRatio: false,
layout: {
padding: {
left : 0,
right : 0,
top : 0,
bottom : 0
}
},
animation: {
duration : 5000
},
legend: {
display: this.chartValues.length <= 15,
}
}


You can also make place for rendering charts bigger. Add this to your scss file:



.chartjs-render-monitor{
height: 300px !important;
}


I hope it gonna help someone






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f43229626%2fhow-to-fix-chart-legends-width-height-with-overflow-scroll-in-chartjs%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    12














    You can try one thing



    Try to separate the legend into an different div. now you have full control of the div you can use custom placement and css of your own consider the following code :



     <div id="js-legend" class="chart-legend"></div>
    document.getElementById('js-legend').innerHTML = myChart.generateLegend();


    For reference see this FIDDLE



    For handling legend interactive you need to extend the callback function and manipulate like this :



    $("#js-legend > ul > li").on("click",function(e){
    var index = $(this).index();
    $(this).toggleClass("strike")
    var ci = e.view.myChart;
    var curr = ci.data.datasets[0]._meta[0].data[index];
    curr.hidden = !curr.hidden
    ci.update();
    })


    For Legend in action see this FIDDLE



    Explanation :



    I binded chart to window so that event view can get it, and later by the index manipulated the data and updated runtime used few css tricks to illustrate the strike effect.






    share|improve this answer


























    • Aweeesommee mate !!!!!!!!!!!!!

      – Kaushik Makwana
      Apr 5 '17 at 11:54











    • :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

      – Vinod Louis
      Apr 5 '17 at 11:56











    • Yes that's what I want.... Thank you vary much..... I love your work

      – Kaushik Makwana
      Apr 5 '17 at 11:58











    • You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

      – Kaushik Makwana
      Apr 5 '17 at 12:03






    • 1





      Thanks you so much mate!!! It was really helpful.. :D

      – Ajithkumar S
      Apr 9 '18 at 3:18
















    12














    You can try one thing



    Try to separate the legend into an different div. now you have full control of the div you can use custom placement and css of your own consider the following code :



     <div id="js-legend" class="chart-legend"></div>
    document.getElementById('js-legend').innerHTML = myChart.generateLegend();


    For reference see this FIDDLE



    For handling legend interactive you need to extend the callback function and manipulate like this :



    $("#js-legend > ul > li").on("click",function(e){
    var index = $(this).index();
    $(this).toggleClass("strike")
    var ci = e.view.myChart;
    var curr = ci.data.datasets[0]._meta[0].data[index];
    curr.hidden = !curr.hidden
    ci.update();
    })


    For Legend in action see this FIDDLE



    Explanation :



    I binded chart to window so that event view can get it, and later by the index manipulated the data and updated runtime used few css tricks to illustrate the strike effect.






    share|improve this answer


























    • Aweeesommee mate !!!!!!!!!!!!!

      – Kaushik Makwana
      Apr 5 '17 at 11:54











    • :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

      – Vinod Louis
      Apr 5 '17 at 11:56











    • Yes that's what I want.... Thank you vary much..... I love your work

      – Kaushik Makwana
      Apr 5 '17 at 11:58











    • You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

      – Kaushik Makwana
      Apr 5 '17 at 12:03






    • 1





      Thanks you so much mate!!! It was really helpful.. :D

      – Ajithkumar S
      Apr 9 '18 at 3:18














    12












    12








    12







    You can try one thing



    Try to separate the legend into an different div. now you have full control of the div you can use custom placement and css of your own consider the following code :



     <div id="js-legend" class="chart-legend"></div>
    document.getElementById('js-legend').innerHTML = myChart.generateLegend();


    For reference see this FIDDLE



    For handling legend interactive you need to extend the callback function and manipulate like this :



    $("#js-legend > ul > li").on("click",function(e){
    var index = $(this).index();
    $(this).toggleClass("strike")
    var ci = e.view.myChart;
    var curr = ci.data.datasets[0]._meta[0].data[index];
    curr.hidden = !curr.hidden
    ci.update();
    })


    For Legend in action see this FIDDLE



    Explanation :



    I binded chart to window so that event view can get it, and later by the index manipulated the data and updated runtime used few css tricks to illustrate the strike effect.






    share|improve this answer















    You can try one thing



    Try to separate the legend into an different div. now you have full control of the div you can use custom placement and css of your own consider the following code :



     <div id="js-legend" class="chart-legend"></div>
    document.getElementById('js-legend').innerHTML = myChart.generateLegend();


    For reference see this FIDDLE



    For handling legend interactive you need to extend the callback function and manipulate like this :



    $("#js-legend > ul > li").on("click",function(e){
    var index = $(this).index();
    $(this).toggleClass("strike")
    var ci = e.view.myChart;
    var curr = ci.data.datasets[0]._meta[0].data[index];
    curr.hidden = !curr.hidden
    ci.update();
    })


    For Legend in action see this FIDDLE



    Explanation :



    I binded chart to window so that event view can get it, and later by the index manipulated the data and updated runtime used few css tricks to illustrate the strike effect.







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited Apr 5 '17 at 13:08

























    answered Apr 5 '17 at 11:51









    Vinod LouisVinod Louis

    3,95211434




    3,95211434













    • Aweeesommee mate !!!!!!!!!!!!!

      – Kaushik Makwana
      Apr 5 '17 at 11:54











    • :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

      – Vinod Louis
      Apr 5 '17 at 11:56











    • Yes that's what I want.... Thank you vary much..... I love your work

      – Kaushik Makwana
      Apr 5 '17 at 11:58











    • You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

      – Kaushik Makwana
      Apr 5 '17 at 12:03






    • 1





      Thanks you so much mate!!! It was really helpful.. :D

      – Ajithkumar S
      Apr 9 '18 at 3:18



















    • Aweeesommee mate !!!!!!!!!!!!!

      – Kaushik Makwana
      Apr 5 '17 at 11:54











    • :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

      – Vinod Louis
      Apr 5 '17 at 11:56











    • Yes that's what I want.... Thank you vary much..... I love your work

      – Kaushik Makwana
      Apr 5 '17 at 11:58











    • You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

      – Kaushik Makwana
      Apr 5 '17 at 12:03






    • 1





      Thanks you so much mate!!! It was really helpful.. :D

      – Ajithkumar S
      Apr 9 '18 at 3:18

















    Aweeesommee mate !!!!!!!!!!!!!

    – Kaushik Makwana
    Apr 5 '17 at 11:54





    Aweeesommee mate !!!!!!!!!!!!!

    – Kaushik Makwana
    Apr 5 '17 at 11:54













    :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

    – Vinod Louis
    Apr 5 '17 at 11:56





    :) @KaushikMakwana something like this should solve your problem jsfiddle.net/5um78rbk/5

    – Vinod Louis
    Apr 5 '17 at 11:56













    Yes that's what I want.... Thank you vary much..... I love your work

    – Kaushik Makwana
    Apr 5 '17 at 11:58





    Yes that's what I want.... Thank you vary much..... I love your work

    – Kaushik Makwana
    Apr 5 '17 at 11:58













    You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

    – Kaushik Makwana
    Apr 5 '17 at 12:03





    You know what the legend are show as pain text, I want functional legend see my fiddle : jsfiddle.net/KDM1010/5um78rbk

    – Kaushik Makwana
    Apr 5 '17 at 12:03




    1




    1





    Thanks you so much mate!!! It was really helpful.. :D

    – Ajithkumar S
    Apr 9 '18 at 3:18





    Thanks you so much mate!!! It was really helpful.. :D

    – Ajithkumar S
    Apr 9 '18 at 3:18













    1














    I did not found any solution for this, but you can turn off legend if too many labels are to be shown (I did it in my project) - here is set to max 15 labels:



    options : {
    responsive: true,
    maintainAspectRatio: false,
    layout: {
    padding: {
    left : 0,
    right : 0,
    top : 0,
    bottom : 0
    }
    },
    animation: {
    duration : 5000
    },
    legend: {
    display: this.chartValues.length <= 15,
    }
    }


    You can also make place for rendering charts bigger. Add this to your scss file:



    .chartjs-render-monitor{
    height: 300px !important;
    }


    I hope it gonna help someone






    share|improve this answer




























      1














      I did not found any solution for this, but you can turn off legend if too many labels are to be shown (I did it in my project) - here is set to max 15 labels:



      options : {
      responsive: true,
      maintainAspectRatio: false,
      layout: {
      padding: {
      left : 0,
      right : 0,
      top : 0,
      bottom : 0
      }
      },
      animation: {
      duration : 5000
      },
      legend: {
      display: this.chartValues.length <= 15,
      }
      }


      You can also make place for rendering charts bigger. Add this to your scss file:



      .chartjs-render-monitor{
      height: 300px !important;
      }


      I hope it gonna help someone






      share|improve this answer


























        1












        1








        1







        I did not found any solution for this, but you can turn off legend if too many labels are to be shown (I did it in my project) - here is set to max 15 labels:



        options : {
        responsive: true,
        maintainAspectRatio: false,
        layout: {
        padding: {
        left : 0,
        right : 0,
        top : 0,
        bottom : 0
        }
        },
        animation: {
        duration : 5000
        },
        legend: {
        display: this.chartValues.length <= 15,
        }
        }


        You can also make place for rendering charts bigger. Add this to your scss file:



        .chartjs-render-monitor{
        height: 300px !important;
        }


        I hope it gonna help someone






        share|improve this answer













        I did not found any solution for this, but you can turn off legend if too many labels are to be shown (I did it in my project) - here is set to max 15 labels:



        options : {
        responsive: true,
        maintainAspectRatio: false,
        layout: {
        padding: {
        left : 0,
        right : 0,
        top : 0,
        bottom : 0
        }
        },
        animation: {
        duration : 5000
        },
        legend: {
        display: this.chartValues.length <= 15,
        }
        }


        You can also make place for rendering charts bigger. Add this to your scss file:



        .chartjs-render-monitor{
        height: 300px !important;
        }


        I hope it gonna help someone







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Oct 9 '18 at 11:53









        Marcin AugustynMarcin Augustyn

        314




        314






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f43229626%2fhow-to-fix-chart-legends-width-height-with-overflow-scroll-in-chartjs%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            MongoDB - Not Authorized To Execute Command

            in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

            How to fix TextFormField cause rebuild widget in Flutter