- <!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
- });