<!doctype html> <html class="zc-html"> <head> <meta charset="utf-8"> <title>ZingSoft Demo</title> <script nonce="undefined" src="https://cdn.zingchart.com/zingchart.min.js"></script> <style> .zc-body { background: #fff; } .chart--container { height: 100%; width: 100%; min-height: 530px; } .zc-ref { display: none; } </style> </head> <body class="zc-body"> <div id="myChart" class="chart--container"> <a href="https://www.zingchart.com/" rel="noopener" class="zc-ref">Powered by ZingChart</a> </div> <script> ZC.LICENSE = ["569d52cefae586f634c54f86dc99e6a9", "b55b025e438fa8a98e32482b5f768ff5"]; let cols = 40, rows = 10; let img = ''; let plots = [{ text: 'Walmart', color: '#47AC1C', employees: 2200000, medianpay: 19177 }, { text: 'Amazon', color: '#301058', employees: 798000, medianpay: 28466 }, { text: 'Yum China', color: '#B2101D', employees: 450000, medianpay: 9111 }, { text: 'Kroger', color: '#9D7A00', employees: 435000, medianpay: 21075 }, { text: 'Home Depot', color: '#DB00E3', employees: 415700, medianpay: 21095 }, { text: 'Berkshire H.', color: '#0023C6', employees: 391500, medianpay: 53510 }, { text: 'FedEx', color: '#3A5D0F', employees: 389000, medianpay: 50017 }, { text: 'IBM', color: '#8113B0', employees: 383800, medianpay: 54491 }, { text: 'UPS', color: '#D90015', employees: 377640, medianpay: 53443 }, { text: 'Target Corp.', color: '#296D62', employees: 368000, medianpay: 20581 } ]; let chartConfig = { graphset: [{ type: 'scatter', height: '100%', width: 18 * cols + 40, x: 0, y: 0, title: { text: 'Top 10 United States Largest Private Employers (as of 2020)' }, plotarea: { maskTolerance: [99, 99], margin: '50px 20px 100px 20px' }, legend: { borderWidth: 0, height: '80px', layout: '2x5', margin: 'auto auto 0 auto', offsetY: '10px', marker: { type: 'rectangle', backgroundColor: 'none', borderWidth: 0, width: '16px', height: '32px' } }, scaleX: { visible: false }, scaleY: { mirrored: true, visible: false }, tooltip: { text: '<b>%plot-text:</b> %data-employees employees (%data-percent%)', backgroundColor: '#eee', borderColor: '#333', fontSize: '17px', padding: '20px', fontWeight: null, thousandsSeparator: ',' }, plot: { animation: { effect: 'ANIMATION_FADE_IN', method: 'ANIMATION_LINEAR', sequence: 'ANIMATION_BY_PLOT', speed: 150 }, marker: { type: 'rectangle', backgroundColor: 'none', width: '16px', height: '32px' }, hoverMarker: { type: 'none', visible: false } }, series: [] }, { type: 'hbar', width: '300px', height: '100%', x: 18 * cols + 40, y: 0, plotarea: { margin: '20px 20px 70px 100px' }, tooltip: { visible: false }, scaleX: { visible: false }, scaleY: { lineWidth: 0, guide: { visible: false }, item: { visible: false }, label: { text: 'Median annual pay', align: 'left', color: '#000', fontSize: '15px', padding: 0 }, tick: { visible: false } }, source: { text: 'Source: Wikipedia', align: 'left', target: '_blank', url: 'https://en.wikipedia.org/wiki/List_of_largest_employers_in_the_United_States' }, plot: { animation: { effect: 'ANIMATION_EXPAND_BOTTOM', method: 'ANIMATION_LINEAR', sequence: 'ANIMATION_BY_PLOT', speed: 150 }, barSpace: 0.1, barsSpaceLeft: 0.1, barsSpaceRight: 0.1, valueBox: [{ text: '$%node-value', placement: 'top-out', rules: [{ rule: '%node-value > 25000', placement: 'top-in', color: '#fff' }], thousandsSeparator: ',' }, { text: '%plot-text', color: '#000', placement: 'bottom-out' } ] }, series: [] } ] }; // calculate number of items per plot let total_employees = 0; for (let p = 0; p < plots.length; p++) { total_employees += plots[p].employees; } let total_items = 0 for (let p = 0; p < plots.length; p++) { let pc = (plots[p].employees / total_employees); let items = Math.round((cols * rows) * pc); if (p === plots.length - 1) { // avoid rounding conflicts plots[p].items = (cols * rows) - total_items; } else { plots[p].items = items; } plots[p].dataPercent = (100 * pc).toFixed(2); total_items += items; } let col = 0, row = 0; for (let p = 0; p < plots.length; p++) { chartConfig.graphset[1].series.push({ text: plots[p].text, values: [plots[p].medianpay], backgroundColor: plots[p].color }); chartConfig.graphset[0].series.push({ text: plots[p].text, dataPercent: plots[p].dataPercent, dataEmployees: plots[p].employees, tooltip: { color: plots[p].color }, marker: { backgroundRepeat: 'no-repeat', backgroundImage: img, backgroundPosition: -p * 16 + 'px 0px' }, legendMarker: { backgroundRepeat: 'no-repeat', backgroundImage: img, backgroundPosition: -p * 16 + 'px 0px' }, values: [] }); for (let n = 0; n < plots[p].items; n++) { chartConfig.graphset[0].series[p].values.push([col, row]); col++; if (col === cols) { col = 0; row++; } } } zingchart.render({ id: 'myChart', width: '100%', height: '100%', output: 'svg', data: chartConfig }); </script> </body> </html>
<!doctype html> <html class="zc-html"> <head> <meta charset="utf-8"> <title>ZingSoft Demo</title> <script src="https://cdn.zingchart.com/zingchart.min.js"></script> </head> <body class="zc-body"> <div id="myChart" class="chart--container"> <a href="https://www.zingchart.com/" rel="noopener" class="zc-ref">Powered by ZingChart</a> </div> </body> </html>
.zc-body { background: #fff; } .chart--container { height: 100%; width: 100%; min-height: 530px; } .zc-ref { display: none; }
let cols = 40, rows = 10; let img = ''; let plots = [{ text: 'Walmart', color: '#47AC1C', employees: 2200000, medianpay: 19177 }, { text: 'Amazon', color: '#301058', employees: 798000, medianpay: 28466 }, { text: 'Yum China', color: '#B2101D', employees: 450000, medianpay: 9111 }, { text: 'Kroger', color: '#9D7A00', employees: 435000, medianpay: 21075 }, { text: 'Home Depot', color: '#DB00E3', employees: 415700, medianpay: 21095 }, { text: 'Berkshire H.', color: '#0023C6', employees: 391500, medianpay: 53510 }, { text: 'FedEx', color: '#3A5D0F', employees: 389000, medianpay: 50017 }, { text: 'IBM', color: '#8113B0', employees: 383800, medianpay: 54491 }, { text: 'UPS', color: '#D90015', employees: 377640, medianpay: 53443 }, { text: 'Target Corp.', color: '#296D62', employees: 368000, medianpay: 20581 } ]; let chartConfig = { graphset: [{ type: 'scatter', height: '100%', width: 18 * cols + 40, x: 0, y: 0, title: { text: 'Top 10 United States Largest Private Employers (as of 2020)' }, plotarea: { maskTolerance: [99, 99], margin: '50px 20px 100px 20px' }, legend: { borderWidth: 0, height: '80px', layout: '2x5', margin: 'auto auto 0 auto', offsetY: '10px', marker: { type: 'rectangle', backgroundColor: 'none', borderWidth: 0, width: '16px', height: '32px' } }, scaleX: { visible: false }, scaleY: { mirrored: true, visible: false }, tooltip: { text: '<b>%plot-text:</b> %data-employees employees (%data-percent%)', backgroundColor: '#eee', borderColor: '#333', fontSize: '17px', padding: '20px', fontWeight: null, thousandsSeparator: ',' }, plot: { animation: { effect: 'ANIMATION_FADE_IN', method: 'ANIMATION_LINEAR', sequence: 'ANIMATION_BY_PLOT', speed: 150 }, marker: { type: 'rectangle', backgroundColor: 'none', width: '16px', height: '32px' }, hoverMarker: { type: 'none', visible: false } }, series: [] }, { type: 'hbar', width: '300px', height: '100%', x: 18 * cols + 40, y: 0, plotarea: { margin: '20px 20px 70px 100px' }, tooltip: { visible: false }, scaleX: { visible: false }, scaleY: { lineWidth: 0, guide: { visible: false }, item: { visible: false }, label: { text: 'Median annual pay', align: 'left', color: '#000', fontSize: '15px', padding: 0 }, tick: { visible: false } }, source: { text: 'Source: Wikipedia', align: 'left', target: '_blank', url: 'https://en.wikipedia.org/wiki/List_of_largest_employers_in_the_United_States' }, plot: { animation: { effect: 'ANIMATION_EXPAND_BOTTOM', method: 'ANIMATION_LINEAR', sequence: 'ANIMATION_BY_PLOT', speed: 150 }, barSpace: 0.1, barsSpaceLeft: 0.1, barsSpaceRight: 0.1, valueBox: [{ text: '$%node-value', placement: 'top-out', rules: [{ rule: '%node-value > 25000', placement: 'top-in', color: '#fff' }], thousandsSeparator: ',' }, { text: '%plot-text', color: '#000', placement: 'bottom-out' } ] }, series: [] } ] }; // calculate number of items per plot let total_employees = 0; for (let p = 0; p < plots.length; p++) { total_employees += plots[p].employees; } let total_items = 0 for (let p = 0; p < plots.length; p++) { let pc = (plots[p].employees / total_employees); let items = Math.round((cols * rows) * pc); if (p === plots.length - 1) { // avoid rounding conflicts plots[p].items = (cols * rows) - total_items; } else { plots[p].items = items; } plots[p].dataPercent = (100 * pc).toFixed(2); total_items += items; } let col = 0, row = 0; for (let p = 0; p < plots.length; p++) { chartConfig.graphset[1].series.push({ text: plots[p].text, values: [plots[p].medianpay], backgroundColor: plots[p].color }); chartConfig.graphset[0].series.push({ text: plots[p].text, dataPercent: plots[p].dataPercent, dataEmployees: plots[p].employees, tooltip: { color: plots[p].color }, marker: { backgroundRepeat: 'no-repeat', backgroundImage: img, backgroundPosition: -p * 16 + 'px 0px' }, legendMarker: { backgroundRepeat: 'no-repeat', backgroundImage: img, backgroundPosition: -p * 16 + 'px 0px' }, values: [] }); for (let n = 0; n < plots[p].items; n++) { chartConfig.graphset[0].series[p].values.push([col, row]); col++; if (col === cols) { col = 0; row++; } } } zingchart.render({ id: 'myChart', width: '100%', height: '100%', output: 'svg', data: chartConfig });