var windv = document.getElementById('windc').getContext('2d');
var windkmh = document.getElementById('windkmh').getContext('2d');
var windms = document.getElementById('windms').getContext('2d');
var windknp = document.getElementById('windknp').getContext('2d');
var luchtdruk = document.getElementById('luchtdruk').getContext('2d');
var temperatuur = document.getElementById('temperatuur').getContext('2d');
var wolken = document.getElementById('bewolking').getContext('2d');
var mwolken = document.getElementById('mbewolking').getContext('2d');
var hwolken = document.getElementById('hbewolking').getContext('2d');
var neerslag = document.getElementById('neerslag').getContext('2d');
var straling = document.getElementById('straling').getContext('2d');
var zicht = document.getElementById('zicht').getContext('2d');
// $("#windr").html("test");
document.getElementById("windr").innerHTML="
  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 
"; 
var gradient = windv.createLinearGradient(0, 0, 0, 400);
gradient.addColorStop(0, 'rgba(0,111,174,0.8)');
gradient.addColorStop(1, 'rgba(21,31,38,0.5)');
// Functie om min/max waarden te berekenen met 25% marge
function calculateYAxisRange(data, minValue, maxValue) {
    const range = maxValue - minValue;
    const margin = range * 0.25;
    
    return {
        min: Math.max(0, minValue - margin), // Nooit onder nul
        max: maxValue + margin
    };
}
var windChart = new Chart(windv, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wind',
            data: [3,3,3,4,3,4,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                ...calculateYAxisRange([3,3,3,4,3,4,3,3,3,3,3,2,3,3,3,3,3,3,3,3,3,3,3,3], 0, 6),
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' bft';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' bft';
                    }
                }
            }
        }
    }
});
var windknpChart = new Chart(windknp, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wind',
            data: [10,10,10,12,10,12,10,8,8,10,8,6,10,8,10,8,8,10,10,10,10,10,8,10],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                ...calculateYAxisRange([10,10,10,12,10,12,10,8,8,10,8,6,10,8,10,8,8,10,10,10,10,10,8,10], 0, 14),
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' knp';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' knp';
                    }
                }
            }
        }
    }
});
var windkmhChart = new Chart(windkmh, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wind',
            data: [18,18,18,21.6,18,21.6,18,14.4,14.4,18,14.4,10.8,18,14.4,18,14.4,14.4,18,18,18,18,18,14.4,18],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                ...calculateYAxisRange([18,18,18,21.6,18,21.6,18,14.4,14.4,18,14.4,10.8,18,14.4,18,14.4,14.4,18,18,18,18,18,14.4,18], 0, 23.6),
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' km/h';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' km/h';
                    }
                }
            }
        }
    }
});
var windmsChart = new Chart(windms, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wind',
            data: [5,5,5,6,5,6,5,4,4,5,4,3,5,4,5,4,4,5,5,5,5,5,4,5],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                ...calculateYAxisRange([5,5,5,6,5,6,5,4,4,5,4,3,5,4,5,4,4,5,5,5,5,5,4,5], 0, 8),
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' m/s';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' m/s';
                    }
                }
            }
        }
    }
});
var luchtdChart = new Chart(luchtdruk, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'luchtdruk',
            data: [1015.1,1015.1,1014.8,1014.5,1014.5,1014.5,1014.6,1014.7,1014.5,1014.3,1014.2,1014.1,1014,1014,1013.9,1013.9,1014.1,1014.2,1014.1,1014,1013.6,1013.3,1013.2,1013],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                ...calculateYAxisRange([1015.1,1015.1,1014.8,1014.5,1014.5,1014.5,1014.6,1014.7,1014.5,1014.3,1014.2,1014.1,1014,1014,1013.9,1013.9,1014.1,1014.2,1014.1,1014,1013.6,1013.3,1013.2,1013], 1008, 1020),
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' hPa';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' hPa';
                    }
                }
            }
        }
    }
});
var tempChart = new Chart(temperatuur, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'temperatuur',
            data: [14,14,13,13,13,13,13,13,13,12,12,11,11,11,11,11,11,11,12,13,13,14,14,14],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                ...calculateYAxisRange([14,14,13,13,13,13,13,13,13,12,12,11,11,11,11,11,11,11,12,13,13,14,14,14], 10, 16),
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' ºC';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' ºC';
                    }
                }
            }
        }
    }
});
var wolkenChart = new Chart(wolken, {
    type: 'bar',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wolken',
            data: [0,0,0,0,0,0,80,66,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                beginAtZero: true,
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' %';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' %';
                    }
                }
            }
        }
    }
});
var mwolkenChart = new Chart(mwolken, {
    type: 'bar',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wolken',
            data: [16,1,0,33,100,31,100,85,100,0,0,96,43,43,99,67,1,1,22,100,100,100,100,100],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                beginAtZero: true,
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' %';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' %';
                    }
                }
            }
        }
    }
});
var hwolkenChart = new Chart(hwolken, {
    type: 'bar',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'wolken',
            data: [100,100,100,100,100,100,38,1,15,7,0,12,93,31,99,97,100,100,85,100,31,0,96,56],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                beginAtZero: true,
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' %';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' %';
                    }
                }
            }
        }
    }
});
var neerslagChart = new Chart(neerslag, {
    type: 'bar',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'neerslag',
            data: [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                beginAtZero: true,
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' mm';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' mm';
                    }
                }
            }
        }
    }
});
var stralingChart = new Chart(straling, {
    type: 'bar',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'Global radiation',
            data: [8,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,19,50,69,63,49,37,13,27],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                beginAtZero: true,
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' W/m2';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' W/m2';
                    }
                }
            }
        }
    }
});
var zichtChart = new Chart(zicht, {
    type: 'line',
    data: {
        labels: ["16","17","18","19","20","21","22","23","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15"],
        datasets: [{
            label: 'zicht',
            data: [50000,50000,13466,50000,50000,16900,50000,50000,15833,50000,13032,50000,50000,50000,50000,50000,50000,12403,14392,15112,50000,50000,50000,15304],
            backgroundColor: 'rgba(0,111,174,0.8)',
            borderColor: 'rgba(0,111,174,1)',
            borderWidth: 1,
            fill: true
        }]
    },
    options: {
        plugins: {
            legend: {
                display: false
            }
        },
        scales: {
            y: {
                min: 0,
                max: 55000,
                ticks: {
                    callback: function(value, index, ticks) {
                        return value + ' m';
                    }
                }
            }
        },
        plugins: {
            tooltip: {
                enabled: true,
                mode: 'index',
                intersect: false,
                callbacks: {
                    title: function(tooltipItems) {
                        return tooltipItems[0].label + ' uur';
                    },
                    label: function(tooltipItem) {
                        return tooltipItem.raw + ' m';
                    }
                }
            }
        }
    }
});