|  | <!doctype html> | 
|  | <!-- | 
|  | Copyright 2024 The Dawn & Tint Authors | 
|  |  | 
|  | Redistribution and use in source and binary forms, with or without | 
|  | modification, are permitted provided that the following conditions are met: | 
|  |  | 
|  | 1. Redistributions of source code must retain the above copyright notice, this | 
|  | list of conditions and the following disclaimer. | 
|  |  | 
|  | 2. Redistributions in binary form must reproduce the above copyright notice, | 
|  | this list of conditions and the following disclaimer in the documentation | 
|  | and/or other materials provided with the distribution. | 
|  |  | 
|  | 3. Neither the name of the copyright holder nor the names of its | 
|  | contributors may be used to endorse or promote products derived from | 
|  | this software without specific prior written permission. | 
|  |  | 
|  | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | 
|  | AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
|  | IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 
|  | DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | 
|  | FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | 
|  | DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | 
|  | SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | 
|  | CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | 
|  | OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
|  | OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
|  | --> | 
|  |  | 
|  | <html> | 
|  | <head> | 
|  | <link rel="preconnect" href="https://fonts.googleapis.com"> | 
|  | <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> | 
|  | <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@300&display=swap" rel="stylesheet"> | 
|  | <script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script> | 
|  | <style> | 
|  | html, body { | 
|  | width: 100%; height: 100%; | 
|  | margin: 0; padding: 0; | 
|  | } | 
|  | body { | 
|  | font-family: 'Roboto', serif; | 
|  | font-size: 12px; | 
|  | background-color: #e4e4e4; | 
|  | } | 
|  | </style> | 
|  | <script type="text/javascript"> | 
|  | const add_commas = x => x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",") | 
|  |  | 
|  | addEventListener('beforeunload', () => { | 
|  | fetch("viewer.closed"); | 
|  | }); | 
|  |  | 
|  | google.charts.load('current', {'packages':['treemap']}); | 
|  | google.charts.setOnLoadCallback(drawChart); | 
|  | function drawChart() { | 
|  | fetch("data.json").then(response => response.json()).then(json => { | 
|  | document.getElementById('desc_div').innerHTML = json.desc; | 
|  | var data = google.visualization.arrayToDataTable(json.data); | 
|  | tree = new google.visualization.TreeMap(document.getElementById('chart_div')); | 
|  |  | 
|  | tree.draw(data, { | 
|  | maxDepth: 3, | 
|  | maxPostDepth: 10, | 
|  | hintOpacity: 0.1, | 
|  | minColorValue: 1, | 
|  | maxColorValue: json.limit, | 
|  | minColor: '#00cc00', | 
|  | midColor: '#cccc00', | 
|  | maxColor: '#cc00cc', | 
|  | headerHeight: 15, | 
|  | fontColor: 'black', | 
|  | showScale: true, | 
|  | generateTooltip:  (row, size, value) => { | 
|  | return ` | 
|  | <div style="background:#fd9; padding:10px; border-style:solid"> | 
|  | <code>${data.getValue(row, 0)}</code><br>${data.getColumnLabel(2)}: ${add_commas(size)} | 
|  | </div>`; | 
|  | }, | 
|  | }); | 
|  | }); | 
|  | } | 
|  | </script> | 
|  | </head> | 
|  | <body> | 
|  | <div id="desc_div"></div> | 
|  | <div id="chart_div" style="width: 100%; height: 90%;"></div> | 
|  | </body> | 
|  | </html> |