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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wind',
            data: [3,3,3,3,3,3,3,3,3,4,4,4,4,4,4,4,4,4,4,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,4,4,4,4,4,4,4,4,4,4,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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wind',
            data: [10,10,10,10,8,10,10,10,10,12,12,12,12,12,12,14,14,12,12,8,8,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,10,10,8,10,10,10,10,12,12,12,12,12,12,14,14,12,12,8,8,10,10,10], 1, 16),
                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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wind',
            data: [18,18,18,18,14.4,18,18,18,18,21.6,21.6,21.6,21.6,21.6,21.6,25.2,25.2,21.6,21.6,14.4,14.4,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,18,18,14.4,18,18,18,18,21.6,21.6,21.6,21.6,21.6,21.6,25.2,25.2,21.6,21.6,14.4,14.4,18,18,18], 1, 27.2),
                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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wind',
            data: [5,5,5,5,4,5,5,5,5,6,6,6,6,6,6,7,7,6,6,4,4,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,5,5,4,5,5,5,5,6,6,6,6,6,6,7,7,6,6,4,4,5,5,5], 1, 9),
                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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'luchtdruk',
            data: [1017.1,1017.1,1017.3,1017.5,1017.7,1018,1018.2,1018.4,1018.2,1017.8,1017.4,1016.8,1016.4,1016,1015.6,1015.3,1015,1014.9,1014.9,1015,1015,1014.8,1014.6,1014.4],
            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.1,1017.3,1017.5,1017.7,1018,1018.2,1018.4,1018.2,1017.8,1017.4,1016.8,1016.4,1016,1015.6,1015.3,1015,1014.9,1014.9,1015,1015,1014.8,1014.6,1014.4], 1009, 1023),
                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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'temperatuur',
            data: [12,12,12,12,12,12,12,13,13,14,15,15,15,15,14,14,14,14,14,14,13,13,13,12],
            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([12,12,12,12,12,12,12,13,13,14,15,15,15,15,14,14,14,14,14,14,13,13,13,12], 11, 17),
                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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wolken',
            data: [100,98,100,100,100,100,96,100,100,1,0,0,0,0,0,0,0,0,0,100,54,99,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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wolken',
            data: [98,1,95,100,100,100,79,73,0,0,0,7,91,10,19,38,69,100,100,100,100,100,28,90],
            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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'wolken',
            data: [100,98,99,33,0,0,74,4,92,89,94,100,100,100,100,100,100,100,100,93,0,0,4,98],
            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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'Global radiation',
            data: [0,0,0,0,0,5,16,33,42,86,109,69,16,10,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: ["03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","00","01","02"],
        datasets: [{
            label: 'zicht',
            data: [3735,3606,3375,3881,3976,4606,6666,50000,8876,11377,50000,15401,50000,50000,14987,50000,50000,17115,50000,50000,50000,50000,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';
                    }
                }
            }
        }
    }
});