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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wind',
            data: [3,3,3,3,3,3,3,3,3,3,3,3,3,4,4,3,4,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,3,3,3,3,3,3,3,3,3,3,4,4,3,4,3,3,3,3,3,3,3], 1, 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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wind',
            data: [10,10,8,10,8,8,10,10,10,8,10,10,10,12,12,10,12,10,10,10,10,10,10,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,8,10,8,8,10,10,10,8,10,10,10,12,12,10,12,10,10,10,10,10,10,10], 1, 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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wind',
            data: [18,18,14.4,18,14.4,14.4,18,18,18,14.4,18,18,18,21.6,21.6,18,21.6,18,18,18,18,18,18,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,14.4,18,14.4,14.4,18,18,18,14.4,18,18,18,21.6,21.6,18,21.6,18,18,18,18,18,18,18], 1, 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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wind',
            data: [5,5,4,5,4,4,5,5,5,4,5,5,5,6,6,5,6,5,5,5,5,5,5,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,4,5,4,4,5,5,5,4,5,5,5,6,6,5,6,5,5,5,5,5,5,5], 1, 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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'luchtdruk',
            data: [1017.1,1017.3,1017.7,1018.1,1018.4,1018.6,1018.6,1018.3,1018,1017.6,1017.3,1017,1016.7,1016.4,1016.1,1015.9,1015.8,1015.7,1015.7,1015.6,1015.3,1015.1,1015.1,1015.1],
            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([1017.1,1017.3,1017.7,1018.1,1018.4,1018.6,1018.6,1018.3,1018,1017.6,1017.3,1017,1016.7,1016.4,1016.1,1015.9,1015.8,1015.7,1015.7,1015.6,1015.3,1015.1,1015.1,1015.1], 1010, 1024),
                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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'temperatuur',
            data: [13,13,13,13,13,13,13,13,14,14,14,14,14,13,13,13,13,13,12,12,12,12,11,11],
            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([13,13,13,13,13,13,13,13,14,14,14,14,14,13,13,13,13,13,12,12,12,12,11,11], 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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wolken',
            data: [100,100,90,83,100,100,100,99,42,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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wolken',
            data: [93,93,99,0,0,0,0,0,0,31,87,11,6,6,0,2,100,100,100,27,19,25,17,11],
            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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'wolken',
            data: [95,70,59,74,100,48,94,89,95,98,100,100,100,100,100,100,100,100,97,5,89,91,64,95],
            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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'Global radiation',
            data: [0,0,0,12,31,20,56,30,72,68,29,2,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 + ' 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: ["05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02","03","04"],
        datasets: [{
            label: 'zicht',
            data: [50000,7377,50000,50000,50000,50000,50000,50000,13227,50000,50000,50000,50000,12187,50000,50000,12616,50000,50000,12764,50000,13738,50000,50000],
            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';
                    }
                }
            }
        }
    }
});