Ir ao conteúdo

Posts recomendados

Postado

Senhores, estou usando algumas tabelas do chart.js e me deparei com um problema, criei os comparativos bonitinhos no gráfico mas preciso que aqueles que foram selecionados não apareçam na pagina de impressão, alguma ideia de como fazer isso?

 

por ex, nesse chart, selecionei a variação do CDI:
v6OnC1N.png

 

Na tela de impressão, ele fica assim, eu gostaria que os labels (titulos de escolha para os gráficos) sumissem e ficasse apenas o selecionado.

IxU39f0.png

 

essa é minha configuração de um chart, tentei juntar tudo para deixar melhor visivel, perdão pela macarronada, JS não é minha linguagem principal então sei apenas o básico.

 

const config_{{ unique_id }} = {
    type: '{{ chart_type|default("line") }}',
    data: data_{{ unique_id }},
    options: {
        responsive: true,
        maintainAspectRatio: false,
        scales: {
            x: {
                display: true,
                title: {
                    display: true,
                    text: '{{ x_axis_title|default("Data") }}',
                    font: {
                        size: 14,
                        family: 'Times New Roman',
                        weight: 'bold'
                    },
                    color: 'black',
                    className: 'chart-axis'
                },
                ticks: {
                    color: 'black',
                    font: {
                        family: 'Times New Roman',
                        weight: 'bold'
                    },
                    className: 'chart-axis'
                }
            },
            y: {
                display: true,
                title: {
                    display: true,
                    text: '{{ y_axis_title|default("Valor") }}',
                    font: {
                        size: 14,
                        family: 'Times New Roman',
                        weight: 'bold'
                    },
                    color: 'black',
                    className: 'chart-axis'
                },
                ticks: {
                    color: 'black',
                    font: {
                        family: 'Times New Roman',
                        weight: 'bold'
                    },
                    className: 'chart-axis'
                }
            }
        },
        plugins: {
            title: {
                display: true,
                text: '{{ chart_title|default("Meu Gráfico") }}',
                font: {
                    size: 18,
                    family: 'Times New Roman',
                    weight: 'bold'
                },
                color: 'black',
                className: 'chart-title'
            },
            legend: {
                display: true,
                labels: {
                    usePointStyle: true,
                    color: 'black',
                    font: {
                        family: 'Times New Roman',
                        weight: 'bold'
                    },
                    className: 'chart-label',
                    generateLabels: function(chart) {
                        const original = Chart.defaults.plugins.legend.labels.generateLabels;
                        const labelsOriginal = original.call(this, chart);

                        labelsOriginal.forEach(label => {
                            const index = label.datasetIndex;
                            if (visibleDatasets_{{ unique_id }}.includes(index)) {
                                label.fillStyle = 'green';
                            } else {
                                label.fillStyle = 'gray';
                            }
                        });

                        return labelsOriginal;
                    }
                },
                onClick: function(e, legendItem, legend) {
                    const index = legendItem.datasetIndex;
                    const ci = legend.chart;
                    const isVisible = ci.isDatasetVisible(index);

                    ci.setDatasetVisibility(index, !isVisible);
                    ci.update();

                    if (isVisible) {
                        visibleDatasets_{{ unique_id }} = visibleDatasets_{{ unique_id }}.filter(idx => idx !== index);
                    } else {
                        visibleDatasets_{{ unique_id }}.push(index);
                    }

                    legend.legendItems[index].fillStyle = isVisible ? 'gray' : 'green';
                    ci.legend.update();
                }
            }
        }
    },
    plugins: [{
        id: 'removeStrikethrough',
        afterUpdate: function(chart) {
            const originalFillText = chart.ctx.fillText;
            chart.ctx.fillText = function(text, x, y, maxWidth) {
                originalFillText.apply(this, arguments);
                this.fillStyle = "rgba(0,0,0,0)";
            };
        }
    }, {
        id: 'dataLabels',
        afterDatasetsDraw: function(chart) {
            const ctx = chart.ctx;
            chart.data.datasets.forEach((dataset, i) => {
                const meta = chart.getDatasetMeta(i);
                if (!chart.isDatasetVisible(i)) return;

                meta.data.forEach((element, index) => {
                    ctx.fillStyle = 'black';
                    const fontSize = 12;
                    const fontStyle = 'normal';
                    const fontFamily = 'Times New Roman';
                    ctx.font = Chart.helpers.fontString(fontSize, fontStyle, fontFamily);

                    const dataString = dataset.data[index].toFixed(2).toString();

                    ctx.textAlign = 'center';
                    ctx.textBaseline = 'middle';

                    const padding = 5;
                    const position = element.tooltipPosition();
                    ctx.fillText(dataString, position.x, position.y - (fontSize / 2) - padding);
                });
            });
        }
    }]
};


    new Chart(ctx_{{ unique_id }}, config_{{ unique_id }});

 

 

 

 

 

 

  • Curtir 1

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...