/** * @Package: Ultra Admin HTML Theme * @Since: Ultra 1.0 * This file is part of Ultra Admin Theme HTML package. */ jQuery(function($) { 'use strict'; var ULTRA_SETTINGS = window.ULTRA_SETTINGS || {}; /*-------------------------------- Flot Chart --------------------------------*/ ULTRA_SETTINGS.chartFlot = function() { /*------------------ Real Time ------------------------*/ // We use an inline data source in the example, usually data would // be fetched from a server var rtdata = [], totalPoints = 300; function RealTimegetRandomData() { if (rtdata.length > 0) rtdata = rtdata.slice(1); // Do a random walk while (rtdata.length < totalPoints) { var prev = rtdata.length > 0 ? rtdata[rtdata.length - 1] : 50, y = prev + Math.random() * 10 - 5; if (y < 0) { y = 0; } else if (y > 100) { y = 100; } rtdata.push(y); } // Zip the generated y values with the x values var res = []; for (var i = 0; i < rtdata.length; ++i) { res.push([i, rtdata[i]]) } return res; } // Set up the control widget var updateInterval = 30; $("#updateInterval").val(updateInterval).change(function() { var v = $(this).val(); if (v && !isNaN(+v)) { updateInterval = +v; if (updateInterval < 1) { updateInterval = 1; } else if (updateInterval > 2000) { updateInterval = 2000; } $(this).val("" + updateInterval); } }); var realplot = $.plot("#flot-realtime", [RealTimegetRandomData()], { series: { shadowSize: 0 // Drawing is faster without shadows }, yaxis: { min: 0, max: 100 }, xaxis: { show: false }, colors: ["#9972b5"], grid: { tickColor: "#f5f5f5", borderWidth: 1, borderColor: "#eaeaea" }, }); function realtimeupdate() { realplot.setData([RealTimegetRandomData()]); // Since the axes don't change, we don't need to call realplot.setupGrid() realplot.draw(); setTimeout(realtimeupdate, updateInterval); } realtimeupdate(); /*---------------------- Percentile ------------------------*/ var males = { "15%": [ [2, 88.0], [3, 93.3], [4, 102.0], [5, 108.5], [6, 115.7], [7, 115.6], [8, 124.6], [9, 130.3], [10, 134.3], [11, 141.4], [12, 146.5], [13, 151.7], [14, 159.9], [15, 165.4], [16, 167.8], [17, 168.7], [18, 169.5], [19, 168.0] ], "90%": [ [2, 96.8], [3, 105.2], [4, 113.9], [5, 120.8], [6, 127.0], [7, 133.1], [8, 139.1], [9, 143.9], [10, 151.3], [11, 161.1], [12, 164.8], [13, 173.5], [14, 179.0], [15, 182.0], [16, 186.9], [17, 185.2], [18, 186.3], [19, 186.6] ], "25%": [ [2, 89.2], [3, 94.9], [4, 104.4], [5, 111.4], [6, 117.5], [7, 120.2], [8, 127.1], [9, 132.9], [10, 136.8], [11, 144.4], [12, 149.5], [13, 154.1], [14, 163.1], [15, 169.2], [16, 170.4], [17, 171.2], [18, 172.4], [19, 170.8] ], "10%": [ [2, 86.9], [3, 92.6], [4, 99.9], [5, 107.0], [6, 114.0], [7, 113.5], [8, 123.6], [9, 129.2], [10, 133.0], [11, 140.6], [12, 145.2], [13, 149.7], [14, 158.4], [15, 163.5], [16, 166.9], [17, 167.5], [18, 167.1], [19, 165.3] ], "mean": [ [2, 91.9], [3, 98.5], [4, 107.1], [5, 114.4], [6, 120.6], [7, 124.7], [8, 131.1], [9, 136.8], [10, 142.3], [11, 150.0], [12, 154.7], [13, 161.9], [14, 168.7], [15, 173.6], [16, 175.9], [17, 176.6], [18, 176.8], [19, 176.7] ], "75%": [ [2, 94.5], [3, 102.1], [4, 110.8], [5, 117.9], [6, 124.0], [7, 129.3], [8, 134.6], [9, 141.4], [10, 147.0], [11, 156.1], [12, 160.3], [13, 168.3], [14, 174.7], [15, 178.0], [16, 180.2], [17, 181.7], [18, 181.3], [19, 182.5] ], "85%": [ [2, 96.2], [3, 103.8], [4, 111.8], [5, 119.6], [6, 125.6], [7, 131.5], [8, 138.0], [9, 143.3], [10, 149.3], [11, 159.8], [12, 162.5], [13, 171.3], [14, 177.5], [15, 180.2], [16, 183.8], [17, 183.4], [18, 183.5], [19, 185.5] ], "50%": [ [2, 91.9], [3, 98.2], [4, 106.8], [5, 114.6], [6, 120.8], [7, 125.2], [8, 130.3], [9, 137.1], [10, 141.5], [11, 149.4], [12, 153.9], [13, 162.2], [14, 169.0], [15, 174.8], [16, 176.0], [17, 176.8], [18, 176.4], [19, 177.4] ] }; var females = { "15%": [ [2, 84.8], [3, 93.7], [4, 100.6], [5, 105.8], [6, 113.3], [7, 119.3], [8, 124.3], [9, 131.4], [10, 136.9], [11, 143.8], [12, 149.4], [13, 151.2], [14, 152.3], [15, 155.9], [16, 154.7], [17, 157.0], [18, 156.1], [19, 155.4] ], "90%": [ [2, 95.6], [3, 104.1], [4, 111.9], [5, 119.6], [6, 127.6], [7, 133.1], [8, 138.7], [9, 147.1], [10, 152.8], [11, 161.3], [12, 166.6], [13, 167.9], [14, 169.3], [15, 170.1], [16, 172.4], [17, 169.2], [18, 171.1], [19, 172.4] ], "25%": [ [2, 87.2], [3, 95.9], [4, 101.9], [5, 107.4], [6, 114.8], [7, 121.4], [8, 126.8], [9, 133.4], [10, 138.6], [11, 146.2], [12, 152.0], [13, 153.8], [14, 155.7], [15, 158.4], [16, 157.0], [17, 158.5], [18, 158.4], [19, 158.1] ], "10%": [ [2, 84.0], [3, 91.9], [4, 99.2], [5, 105.2], [6, 112.7], [7, 118.0], [8, 123.3], [9, 130.2], [10, 135.0], [11, 141.1], [12, 148.3], [13, 150.0], [14, 150.7], [15, 154.3], [16, 153.6], [17, 155.6], [18, 154.7], [19, 153.1] ], "mean": [ [2, 90.2], [3, 98.3], [4, 105.2], [5, 112.2], [6, 119.0], [7, 125.8], [8, 131.3], [9, 138.6], [10, 144.2], [11, 151.3], [12, 156.7], [13, 158.6], [14, 160.5], [15, 162.1], [16, 162.9], [17, 162.2], [18, 163.0], [19, 163.1] ], "75%": [ [2, 93.2], [3, 101.5], [4, 107.9], [5, 116.6], [6, 122.8], [7, 129.3], [8, 135.2], [9, 143.7], [10, 148.7], [11, 156.9], [12, 160.8], [13, 163.0], [14, 165.0], [15, 165.8], [16, 168.7], [17, 166.2], [18, 167.6], [19, 168.0] ], "85%": [ [2, 94.5], [3, 102.8], [4, 110.4], [5, 119.0], [6, 125.7], [7, 131.5], [8, 137.9], [9, 146.0], [10, 151.3], [11, 159.9], [12, 164.0], [13, 166.5], [14, 167.5], [15, 168.5], [16, 171.5], [17, 168.0], [18, 169.8], [19, 170.3] ], "50%": [ [2, 90.2], [3, 98.1], [4, 105.2], [5, 111.7], [6, 118.2], [7, 125.6], [8, 130.5], [9, 138.3], [10, 143.7], [11, 151.4], [12, 156.7], [13, 157.7], [14, 161.0], [15, 162.0], [16, 162.8], [17, 162.2], [18, 162.8], [19, 163.3] ] }; var dataset = [{ label: "Female mean", data: females["mean"], lines: { show: true }, color: "rgba(31,181,172,1)" }, { id: "f15%", data: females["15%"], lines: { show: true, lineWidth: 0, fill: false }, color: "rgba(31,181,172,1)" }, { id: "f25%", data: females["25%"], lines: { show: true, lineWidth: 0, fill: 0.2 }, color: "rgba(31,181,172,1)", fillBetween: "f15%" }, { id: "f50%", data: females["50%"], lines: { show: true, lineWidth: 0.5, fill: 0.4, shadowSize: 0 }, color: "rgba(31,181,172,1)", fillBetween: "f25%" }, { id: "f75%", data: females["75%"], lines: { show: true, lineWidth: 0, fill: 0.4 }, color: "rgba(31,181,172,1)", fillBetween: "f50%" }, { id: "f85%", data: females["85%"], lines: { show: true, lineWidth: 0, fill: 0.2 }, color: "rgba(31,181,172,1)", fillBetween: "f75%" }, { label: "Male mean", data: males["mean"], lines: { show: true }, color: "rgba(153,114,181,1.0)" }, { id: "m15%", data: males["15%"], lines: { show: true, lineWidth: 0, fill: false }, color: "rgba(153,114,181,1.0)" }, { id: "m25%", data: males["25%"], lines: { show: true, lineWidth: 0, fill: 0.2 }, color: "rgba(153,114,181,1.0)", fillBetween: "m15%" }, { id: "m50%", data: males["50%"], lines: { show: true, lineWidth: 0.5, fill: 0.4, shadowSize: 0 }, color: "rgba(153,114,181,1.0)", fillBetween: "m25%" }, { id: "m75%", data: males["75%"], lines: { show: true, lineWidth: 0, fill: 0.4 }, color: "rgba(153,114,181,1.0)", fillBetween: "m50%" }, { id: "m85%", data: males["85%"], lines: { show: true, lineWidth: 0, fill: 0.2 }, color: "rgba(153,114,181,1.0)", fillBetween: "m75%" } ]; $.plot($("#flot-percentile"), dataset, { xaxis: { tickDecimals: 0 }, yaxis: { tickFormatter: function(v) { return v + " cm"; } }, grid: { tickColor: "#f5f5f5", borderWidth: 1, borderColor: "#eaeaea" }, legend: { position: "se" } }); /* -------------------- Navigate ------------------------*/ // generate data set from a parametric function with a fractal look function sumf(f, t, m) { var res = 0; for (var i = 1; i < m; ++i) { res += f(i * i * t) / (i * i); } return res; } var d1 = []; for (var t = 0; t <= 2 * Math.PI; t += 0.01) { d1.push([sumf(Math.cos, t, 10), sumf(Math.sin, t, 10)]); } var data1 = [d1], placeholder = $("#flot-navigate"); var navplot = $.plot(placeholder, data1, { series: { lines: { show: true }, shadowSize: 0 }, xaxis: { zoomRange: [0.1, 10], panRange: [-10, 10] }, yaxis: { zoomRange: [0.1, 10], panRange: [-10, 10] }, zoom: { interactive: true }, pan: { interactive: true }, colors: ["#1fb5ac"], grid: { tickColor: "#f5f5f5", borderWidth: 1, borderColor: "#eaeaea" }, }); // show pan/zoom messages to illustrate events placeholder.bind("plotpan", function(event, navplot) { var axes = navplot.getAxes(); $(".message").html("Panning to x: " + axes.xaxis.min.toFixed(2) + " – " + axes.xaxis.max.toFixed(2) + " and y: " + axes.yaxis.min.toFixed(2) + " – " + axes.yaxis.max.toFixed(2)); }); placeholder.bind("plotzoom", function(event, navplot) { var axes = navplot.getAxes(); $(".message").html("Zooming to x: " + axes.xaxis.min.toFixed(2) + " – " + axes.xaxis.max.toFixed(2) + " and y: " + axes.yaxis.min.toFixed(2) + " – " + axes.yaxis.max.toFixed(2)); }); // add zoom out button $("
") .appendTo(placeholder) .click(function(event) { event.preventDefault(); navplot.zoomOut(); }); // and add panning buttons // little helper for taking the repetitive work out of placing // panning arrows function addArrow(dir, right, top, offset) { $("") .appendTo(placeholder) .click(function(e) { e.preventDefault(); navplot.pan(offset); }); } addArrow("left", 55, 60, { left: -100 }); addArrow("right", 25, 60, { left: 100 }); addArrow("up", 40, 45, { top: -100 }); addArrow("down", 40, 75, { top: 100 }); /*------------------------ Series Pie -----------------------*/ var data = [], series = Math.floor(Math.random() * 6) + 3; for (var i = 0; i < series; i++) { data[i] = { label: "Series" + (i + 1), data: Math.floor(Math.random() * 100) + 1 } } var placeholder = $("#placeholder"); $("#example-1").click(function() { placeholder.unbind(); $("#title").text("Default pie chart"); $("#description").text("The default pie chart with no options set."); $.plot(placeholder, data, { series: { pie: { show: true } } }); setCode([ "$.plot('#placeholder', data, {", " series: {", " pie: {", " show: true", " }", " }", "});" ]); }); /* ------------------------ FLOT PIE ---------------------*/ var data = [], //series = Math.floor(Math.random() * 6) + 3; series = 5; for (var i = 0; i < series; i++) { data[i] = { label: "Series" + (i + 1), data: Math.floor(Math.random() * 100) + 1 } } var flotpie = $("#flotpie"); $("#pieexample-1").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, }); }); $("#pieexample-2").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-3").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 1, label: { show: true, radius: 1, formatter: labelFormatter, background: { opacity: 0.8 } } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-4").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 1, label: { show: true, radius: 3 / 4, formatter: labelFormatter, background: { opacity: 0.5 } } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-5").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 1, label: { show: true, radius: 3 / 4, formatter: labelFormatter, background: { opacity: 0.5, color: "#000" } } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-6").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 3 / 4, label: { show: true, radius: 3 / 4, formatter: labelFormatter, background: { opacity: 0.5, color: "#000" } } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-7").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 1, label: { show: true, radius: 2 / 3, formatter: labelFormatter, threshold: 0.1 } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-8").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, combine: { color: "#999", threshold: 0.05 } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-9").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 500, label: { show: true, formatter: labelFormatter, threshold: 0.1 } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-10").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true, radius: 1, tilt: 0.5, label: { show: true, radius: 1, formatter: labelFormatter, background: { opacity: 0.8 } }, combine: { color: "#999", threshold: 0.1 } } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, legend: { show: false } }); }); $("#pieexample-11").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { innerRadius: 0.5, show: true } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979"], grid: { hoverable: true, clickable: true }, }); }); $("#pieexample-12").click(function() { flotpie.unbind(); $.plot(flotpie, data, { series: { pie: { show: true } }, colors: ["#1fb5ac", "#9972b5", "#fa8564", "#FDB45C", "#797979", "#da2527"], grid: { hoverable: true, clickable: true }, }); flotpie.bind("plothover", function(event, pos, obj) { if (!obj) { return; } var percent = parseFloat(obj.series.percent).toFixed(2); $("#hover").html("" + obj.series.label + " (" + percent + "%)"); }); flotpie.bind("plotclick", function(event, pos, obj) { if (!obj) { return; } var percent = parseFloat(obj.series.percent).toFixed(2); alert("" + obj.series.label + ": " + percent + "%"); }); }); // Show the initial default chart $("#flotpiemenu button").click(function() { $("#flotpiemenu button").removeClass("btn-success").addClass("btn-default"); $(this).addClass("btn-success").removeClass("btn-default"); }); $("#pieexample-1").click(); /*------------------ Series Toggle ---------------------*/ var togdatasets = { "usa": { label: "USA", data: [ [1988, 483994], [1989, 479060], [1990, 457648], [1991, 401949], [1992, 424705], [1993, 402375], [1994, 377867], [1995, 357382], [1996, 337946], [1997, 336185], [1998, 328611], [1999, 329421], [2000, 342172], [2001, 344932], [2002, 387303], [2003, 440813], [2004, 480451], [2005, 504638], [2006, 528692] ] }, "russia": { label: "Russia", data: [ [1988, 218000], [1989, 203000], [1990, 171000], [1992, 42500], [1993, 37600], [1994, 36600], [1995, 21700], [1996, 19200], [1997, 21300], [1998, 13600], [1999, 14000], [2000, 19100], [2001, 21300], [2002, 23600], [2003, 25100], [2004, 26100], [2005, 31100], [2006, 34700] ] }, "uk": { label: "UK", data: [ [1988, 62982], [1989, 62027], [1990, 60696], [1991, 62348], [1992, 58560], [1993, 56393], [1994, 54579], [1995, 50818], [1996, 50554], [1997, 48276], [1998, 47691], [1999, 47529], [2000, 47778], [2001, 48760], [2002, 50949], [2003, 57452], [2004, 60234], [2005, 60076], [2006, 59213] ] }, "germany": { label: "Germany", data: [ [1988, 55627], [1989, 55475], [1990, 58464], [1991, 55134], [1992, 52436], [1993, 47139], [1994, 43962], [1995, 43238], [1996, 42395], [1997, 40854], [1998, 40993], [1999, 41822], [2000, 41147], [2001, 40474], [2002, 40604], [2003, 40044], [2004, 38816], [2005, 38060], [2006, 36984] ] }, "denmark": { label: "Denmark", data: [ [1988, 3813], [1989, 3719], [1990, 3722], [1991, 3789], [1992, 3720], [1993, 3730], [1994, 3636], [1995, 3598], [1996, 3610], [1997, 3655], [1998, 3695], [1999, 3673], [2000, 3553], [2001, 3774], [2002, 3728], [2003, 3618], [2004, 3638], [2005, 3467], [2006, 3770] ] }, "sweden": { label: "Sweden", data: [ [1988, 6402], [1989, 6474], [1990, 6605], [1991, 6209], [1992, 6035], [1993, 6020], [1994, 6000], [1995, 6018], [1996, 3958], [1997, 5780], [1998, 5954], [1999, 6178], [2000, 6411], [2001, 5993], [2002, 5833], [2003, 5791], [2004, 5450], [2005, 5521], [2006, 5271] ] }, "norway": { label: "Norway", data: [ [1988, 4382], [1989, 4498], [1990, 4535], [1991, 4398], [1992, 4766], [1993, 4441], [1994, 4670], [1995, 4217], [1996, 4275], [1997, 4203], [1998, 4482], [1999, 4506], [2000, 4358], [2001, 4385], [2002, 5269], [2003, 5066], [2004, 5194], [2005, 4887], [2006, 4891] ] } }; // hard-code color indices to prevent them from shifting as // countries are turned on/off var i = 0; $.each(togdatasets, function(key, val) { val.color = i; ++i; }); // insert checkboxes var choiceContainer = $("#choices"); $.each(togdatasets, function(key, val) { choiceContainer.append("