| <!DOCTYPE HTML> | |
| <html> | |
| <head> | |
|     <title>Graph2d | External legend Example</title> | |
|     <link href="../../dist/vis.css" rel="stylesheet" type="text/css" /> | |
|     <style type="text/css"> | |
|         body, html { | |
|             font-family: sans-serif; | |
|         } | |
| 
 | |
|         .customStyle1 { | |
|             fill: #f2ea00; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #b3ab00; | |
|         } | |
| 
 | |
|         .customStyle2 { | |
|             fill: #00a0f2; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #050092; | |
|         } | |
| 
 | |
|         .customStyle3 { | |
|             fill: #00f201; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #029200; | |
|         } | |
| 
 | |
|         path.customStyle3.fill { | |
|             fill-opacity:0.5 !important; | |
|             stroke: none; | |
|         } | |
| 
 | |
|          .graphGroup0 { | |
|             fill:#4f81bd; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #4f81bd; | |
|         } | |
| 
 | |
|          .graphGroup1 { | |
|             fill:#f79646; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #f79646; | |
|         } | |
| 
 | |
|          .graphGroup2 { | |
|             fill: #8c51cf; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #8c51cf; | |
|         } | |
| 
 | |
|          .graphGroup3 { | |
|             fill: #75c841; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #75c841; | |
|         } | |
| 
 | |
|          .graphGroup4 { | |
|             fill: #ff0100; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #ff0100; | |
|         } | |
| 
 | |
|          .graphGroup5 { | |
|             fill: #37d8e6; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #37d8e6; | |
|         } | |
| 
 | |
|          .graphGroup6 { | |
|             fill: #042662; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #042662; | |
|         } | |
| 
 | |
|          .graphGroup7 { | |
|             fill:#00ff26; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #00ff26; | |
|         } | |
| 
 | |
|          .graphGroup8 { | |
|             fill:#ff00ff; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #ff00ff; | |
|         } | |
| 
 | |
|          .graphGroup9 { | |
|             fill: #8f3938; | |
|             fill-opacity:0; | |
|             stroke-width:2px; | |
|             stroke: #8f3938; | |
|         } | |
| 
 | |
|          .fill { | |
|             fill-opacity:0.1; | |
|             stroke: none; | |
|         } | |
| 
 | |
| 
 | |
|          .bar { | |
|             fill-opacity:0.5; | |
|             stroke-width:1px; | |
|         } | |
| 
 | |
|          .point { | |
|             stroke-width:2px; | |
|             fill-opacity:1.0; | |
|         } | |
| 
 | |
| 
 | |
|          .legendBackground { | |
|             stroke-width:1px; | |
|             fill-opacity:0.9; | |
|             fill: #ffffff; | |
|             stroke: #c2c2c2; | |
|         } | |
| 
 | |
| 
 | |
|          .outline { | |
|             stroke-width:1px; | |
|             fill-opacity:1; | |
|             fill: #ffffff; | |
|             stroke: #e5e5e5; | |
|         } | |
| 
 | |
|          .iconFill { | |
|             fill-opacity:0.3; | |
|             stroke: none; | |
|         } | |
| 
 | |
|         div.descriptionContainer { | |
|             float:left; | |
|             height:30px; | |
|             width:160px; | |
|             padding-left:5px; | |
|             padding-right:5px; | |
|             line-height: 30px; | |
|         } | |
| 
 | |
|         div.iconContainer { | |
|             float:left; | |
|         } | |
| 
 | |
|         div.legendElementContainer { | |
|             display:inline-block; | |
|             width:200px; | |
|             height:30px; | |
|             border-style:solid; | |
|             border-width:1px; | |
|             border-color: #e0e0e0; | |
|             background-color: #ffffff; | |
|             margin:4px; | |
|             padding:4px; | |
|             -webkit-touch-callout: none; | |
|             -webkit-user-select: none; | |
|             -khtml-user-select: none; | |
|             -moz-user-select: none; | |
|             -ms-user-select: none; | |
|             user-select: none; | |
|             cursor:pointer; | |
|         } | |
|         div.legendElementContainer.hidden { | |
|             background-color: #d3e6ff; | |
|         } | |
| 
 | |
|         svg.legendIcon { | |
|             width:30px; | |
|             height:30px; | |
|         } | |
| 
 | |
|         div.externalLegend { | |
|             position:relative; | |
|             margin-left: -5px; | |
|             width: 900px; | |
|         } | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     </style> | |
| 
 | |
|     <script src="../../dist/vis.js"></script> | |
| 
 | |
| </head> | |
| <body> | |
| <h2>Graph2d | External custom legend</h2> | |
| <div style="width:800px; font-size:14px; text-align: justify;"> | |
|     This example shows how to create an external custom legend using the getLegend function. We use normal JavaScript to show and hide the | |
|     groups by updating the dataset. | |
| 
 | |
| </div> | |
| <br /> | |
| <div id="Legend" class="externalLegend"></div> | |
| <div id="visualization"></div> | |
| 
 | |
| 
 | |
| <script type="text/javascript"> | |
|     // create a dataSet with groups | |
|     var names = ['SquareShaded', 'Bar', 'Blank', 'CircleShaded']; | |
|     var groups = new vis.DataSet(); | |
|     groups.add({ | |
|         id: 0, | |
|         content: names[0], | |
|         className: 'customStyle1', | |
|         options: { | |
|             drawPoints: { | |
|                 style: 'square' // square, circle | |
|             }, | |
|             shaded: { | |
|                 orientation: 'bottom' // top, bottom | |
|             } | |
|         }}); | |
| 
 | |
|     groups.add({ | |
|         id: 1, | |
|         content: names[1], | |
|         className: 'customStyle2', | |
|         options: { | |
|             style:'bar', | |
|             drawPoints: {style: 'circle', | |
|                 size: 10 | |
|             } | |
|         }}); | |
| 
 | |
|     groups.add({ | |
|         id: 2, | |
|         content: names[2], | |
|         options: { | |
|             yAxisOrientation: 'right', // right, left | |
|             drawPoints: false | |
|         } | |
|     }); | |
| 
 | |
|     groups.add({ | |
|         id: 3, | |
|         content: names[3], | |
|         className: 'customStyle3', | |
|         options: { | |
|             yAxisOrientation: 'right', // right, left | |
|             drawPoints: { | |
|                 style: 'circle' // square, circle | |
|             }, | |
|             shaded: { | |
|                 orientation: 'top' // top, bottom | |
|             } | |
|         }}); | |
| 
 | |
|     var container = document.getElementById('visualization'); | |
|     var items = [ | |
|         {x: '2014-06-12', y: 0 , group: 0}, | |
|         {x: '2014-06-13', y: 30, group: 0}, | |
|         {x: '2014-06-14', y: 10, group: 0}, | |
|         {x: '2014-06-15', y: 15, group: 1}, | |
|         {x: '2014-06-16', y: 30, group: 1}, | |
|         {x: '2014-06-17', y: 10, group: 1}, | |
|         {x: '2014-06-18', y: 15, group: 1}, | |
|         {x: '2014-06-19', y: 52, group: 1}, | |
|         {x: '2014-06-20', y: 10, group: 1}, | |
|         {x: '2014-06-21', y: 20, group: 2}, | |
|         {x: '2014-06-22', y: 600, group: 2}, | |
|         {x: '2014-06-23', y: 100, group: 2}, | |
|         {x: '2014-06-24', y: 250, group: 2}, | |
|         {x: '2014-06-25', y: 300, group: 2}, | |
|         {x: '2014-06-26', y: 200, group: 3}, | |
|         {x: '2014-06-27', y: 600, group: 3}, | |
|         {x: '2014-06-28', y: 1000, group: 3}, | |
|         {x: '2014-06-29', y: 250, group: 3}, | |
|         {x: '2014-06-30', y: 300, group: 3} | |
|     ]; | |
| 
 | |
|     var dataset = new vis.DataSet(items); | |
|     var options = { | |
|         dataAxis: {showMinorLabels: false}, | |
|         start: '2014-06-09', | |
|         end: '2014-07-03' | |
|     }; | |
|     var graph2d = new vis.Graph2d(container, items, options, groups); | |
| 
 | |
| 
 | |
|     /** | |
|      * this function fills the external legend with content using the getLegend() function. | |
|      */ | |
|     function populateExternalLegend() { | |
|         var groupsData = groups.get(); | |
|         var legendDiv = document.getElementById("Legend"); | |
|         legendDiv.innerHTML = ""; | |
| 
 | |
|         // get for all groups: | |
|         for (var i = 0; i < groupsData.length; i++) { | |
|             // create divs | |
|             var containerDiv = document.createElement("div"); | |
|             var iconDiv = document.createElement("div"); | |
|             var descriptionDiv = document.createElement("div"); | |
| 
 | |
|             // give divs classes and Ids where necessary | |
|             containerDiv.className = 'legendElementContainer'; | |
|             containerDiv.id = groupsData[i].id + "_legendContainer" | |
|             iconDiv.className = "iconContainer"; | |
|             descriptionDiv.className = "descriptionContainer"; | |
| 
 | |
|             // get the legend for this group. | |
|             var legend = graph2d.getLegend(groupsData[i].id,30,30); | |
| 
 | |
|             // append class to icon. All styling classes from the vis.css have been copied over into the head here to be able to style the | |
|             // icons with the same classes if they are using the default ones. | |
|             legend.icon.setAttributeNS(null, "class", "legendIcon"); | |
| 
 | |
|             // append the legend to the corresponding divs | |
|             iconDiv.appendChild(legend.icon); | |
|             descriptionDiv.innerHTML = legend.label; | |
| 
 | |
|             // determine the order for left and right orientation | |
|             if (legend.orientation == 'left') { | |
|                 descriptionDiv.style.textAlign = "left"; | |
|                 containerDiv.appendChild(iconDiv); | |
|                 containerDiv.appendChild(descriptionDiv); | |
|             } | |
|             else { | |
|                 descriptionDiv.style.textAlign = "right"; | |
|                 containerDiv.appendChild(descriptionDiv); | |
|                 containerDiv.appendChild(iconDiv); | |
|             } | |
| 
 | |
|             // append to the legend container div | |
|             legendDiv.appendChild(containerDiv); | |
| 
 | |
|             // bind click event to this legend element. | |
|             containerDiv.onclick = toggleGraph.bind(this,groupsData[i].id); | |
|         } | |
|     } | |
| 
 | |
|     /** | |
|      * This function switchs the visible option of the selected group on an off. | |
|      * @param groupId | |
|      */ | |
|     function toggleGraph(groupId) { | |
|         // get the container that was clicked on. | |
|         var container = document.getElementById(groupId + "_legendContainer") | |
|         // if visible, hide | |
|         if (graph2d.isGroupVisible(groupId) == true) { | |
|             groups.update({id:groupId, visible:false}); | |
|             container.className = container.className + " hidden"; | |
|         } | |
|         else { // if invisible, show | |
|             groups.update({id:groupId, visible:true}); | |
|             container.className = container.className.replace("hidden",""); | |
|         } | |
|     } | |
| 
 | |
|     populateExternalLegend() | |
| 
 | |
| </script> | |
| </body> | |
| </html> |