123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740 |
- <div class="wrapper wrapper-content">
- <div class="row">
- <div class="col-lg-3">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-connectionport"></h5>
- </div>
- <div class="ibox-content">
- <h1 class="no-margins">{{.p}}</h1>
- </div>
- </div>
- </div>
- <div class="col-lg-3">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-totalclients"></h5>
- </div>
- <div class="ibox-content">
- <h1 class="no-margins">{{.data.clientCount}}</h1>
- </div>
- </div>
- </div>
- <div class="col-lg-3">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- {{/*<span class="label label-primary pull-right">今日</span>*/}}
- <h5 langtag="word-onlineclients"></h5>
- </div>
- <div class="ibox-content">
- <h1 class="no-margins">{{.data.clientOnlineCount}}</h1>
- {{/*<div class="stat-percent font-bold text-navy">44% <i class="fa fa-level-up"></i></div>*/}}
- {{/*<small>新访客</small>*/}}
- </div>
- </div>
- </div>
- <div class="col-lg-3">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-tcpconnections"></h5>
- </div>
- <div class="ibox-content">
- <h1 class="no-margins">{{.data.tcpCount}}</h1>
- </div>
- </div>
- </div>
- </div>
- <div class="row">
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-configurationinformation"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content no-padding">
- <ul class="list-group">
- <li class="list-group-item">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-bridgingmode"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.bridgeType}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-httpport"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.httpProxyPort}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-httpsport"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.httpsProxyPort}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-iprestriction"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong langtag="word-{{.data.ipLimit}}"></strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-trafficdatapersistence"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.flowStoreInterval}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-loglevel"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.logLevel}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-p2pport"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.p2pPort}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-serveriP"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.serverIp}}</strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-serverversion"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong>{{.data.version}}</strong>
- </div>
- </div>
- </li>
- </ul>
- </div>
- </div>
- </div>
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-systeminformation"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content no-padding">
- <ul class="list-group">
- <li class="list-group-item">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-cpu"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_cpu"></strong>
- </div>
- </div>
- <div class="progress progress-small">
- <div id="overview_cpu_bar" class="progress-bar"></div>
- </div>
- </li>
- <li class="list-group-item">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-memory"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_memory"></strong>
- </div>
- </div>
- <div class="progress progress-small">
- <div id="overview_memory_bar" class="progress-bar"></div>
- </div>
- </li>
- <li class="list-group-item">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-load"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_load"></strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-tcpconnections_established"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_tcp"></strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-udpconnections_established"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_udp"></strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-outbandwidth"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_send"></strong>
- </div>
- </div>
- </li>
- <li class="list-group-item ">
- <div class="row">
- <div class="col-sm-6">
- <strong langtag="word-inbandwidth"></strong>
- </div>
- <div class="col-sm-6 text-right">
- <strong id="overview_recv"></strong>
- </div>
- </div>
- </li>
- </ul>
- </div>
- </div>
- </div>
- </div>
- {{if eq true .system_info_display}}
- <div class="row">
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-load"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="load" style="height: 300px"></div>
- </div>
- </div>
- </div>
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-cpu"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="cpu" style="height: 300px"></div>
- </div>
- </div>
- </div>
- </div>
- <div class="row">
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-memory"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="memory" style="height: 300px"></div>
- </div>
- </div>
- </div>
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-connections_established"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="connections" style="height: 300px"></div>
- </div>
- </div>
- </div>
- </div>
- <div class="row">
- <div class="col-lg-12">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-bandwidth"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="bandwidth" style="height: 300px"></div>
- </div>
- </div>
- </div>
- </div>
- {{end}}
- <div class="row">
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-trafficstatistics"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="flow" style="height: 400px;"></div>
- </div>
- </div>
- </div>
- <div class="col-lg-6">
- <div class="ibox float-e-margins">
- <div class="ibox-title">
- <h5 langtag="word-type"></h5>
- <div class="ibox-tools">
- <a class="collapse-link">
- <i class="fa fa-chevron-up"></i>
- </a>
- <a class="close-link">
- <i class="fa fa-times"></i>
- </a>
- </div>
- </div>
- <div class="ibox-content">
- <div id="counts" style="height:400px;"></div>
- </div>
- </div>
- </div>
- </div>
- </div>
- <script>
- $("#overview_cpu").text("{{.data.cpu}}%")
- $("#overview_cpu_bar").width("{{.data.cpu}}%")
- $("#overview_memory").text("{{.data.virtual_mem}}%")
- $("#overview_memory_bar").width("{{.data.virtual_mem}}%")
- $.each( JSON.parse({{.data.load}}), function(i, value) { $("#overview_load").append(' ' + value) });
- $("#overview_tcp").text("{{.data.tcp}}")
- $("#overview_udp").text("{{.data.udp}}")
- $("#overview_send").text(changeunit({{.data.io_send}}) + "/s")
- $("#overview_recv").text(changeunit({{.data.io_recv}}) + "/s")
- chartdatas['load'] = {
- tooltip: {
- trigger: 'axis',
- formatter: function (params) {
- var str = params[0].axisValue + '<br/>';
- for (i in params){
- str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ params[i].data +'</br>';
- }
- return str;
- }
- },
- grid: {
- left: '3%',
- right: '3%',
- top: '5%',
- bottom: '3%',
- containLabel: true
- },
- xAxis: {
- type: 'category',
- boundaryGap: false,
- data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
- },
- yAxis: {
- type: 'value'
- },
- series: [
- {
- name: '',
- type: 'line',
- stack: 'load1',
- smooth: true,
- data: [{{.data.sys1.load1}}, {{.data.sys2.load1}}, {{.data.sys3.load1}}, {{.data.sys4.load1}}, {{.data.sys5.load1}}, {{.data.sys6.load1}}, {{.data.sys7.load1}}, {{.data.sys8.load1}}, {{.data.sys9.load1}}, {{.data.sys10.load1}}]
- },
- {
- name: '',
- type: 'line',
- stack: 'load5',
- smooth: true,
- data: [{{.data.sys1.load5}}, {{.data.sys2.load5}}, {{.data.sys3.load5}}, {{.data.sys4.load5}}, {{.data.sys5.load5}}, {{.data.sys6.load5}}, {{.data.sys7.load5}}, {{.data.sys8.load5}}, {{.data.sys9.load5}}, {{.data.sys10.load5}}]
- },
- {
- name: '',
- type: 'line',
- stack: 'load15',
- smooth: true,
- data: [{{.data.sys1.load15}}, {{.data.sys2.load15}}, {{.data.sys3.load15}}, {{.data.sys4.load15}}, {{.data.sys5.load15}}, {{.data.sys6.load15}}, {{.data.sys7.load15}}, {{.data.sys8.load15}}, {{.data.sys9.load15}}, {{.data.sys10.load15}}]
- }
- ]
- };
- chartdatas['cpu'] = {
- tooltip: {
- trigger: 'axis',
- formatter: function (params) {
- var str = params[0].axisValue + '<br/>';
- for (i in params){
- str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ params[i].data +'%</br>';
- }
- return str;
- }
- },
- grid: {
- left: '3%',
- right: '3%',
- top: '5%',
- bottom: '3%',
- containLabel: true
- },
- xAxis: {
- type: 'category',
- boundaryGap: false,
- data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
- },
- yAxis: {
- type: 'value',
- axisLabel: {
- show: true,
- interval: 'auto',
- formatter: '{value} %'
- }
- },
- series: [
- {
- name: '',
- type: 'line',
- stack: 'cpu',
- smooth: true,
- data: [{{.data.sys1.cpu}}, {{.data.sys2.cpu}}, {{.data.sys3.cpu}}, {{.data.sys4.cpu}}, {{.data.sys5.cpu}}, {{.data.sys6.cpu}}, {{.data.sys7.cpu}}, {{.data.sys8.cpu}}, {{.data.sys9.cpu}}, {{.data.sys10.cpu}}]
- }
- ]
- };
- chartdatas['memory'] = {
- tooltip: {
- trigger: 'axis',
- formatter: function (params) {
- var str = params[0].axisValue + '<br/>';
- for (i in params){
- str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ params[i].data +'MB</br>';
- }
- return str;
- }
- },
- grid: {
- left: '3%',
- right: '3%',
- top: '5%',
- bottom: '3%',
- containLabel: true
- },
- xAxis: {
- type: 'category',
- boundaryGap: false,
- data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
- },
- yAxis: {
- type: 'value',
- axisLabel: {
- show: true,
- interval: 'auto',
- formatter: '{value} MB'
- }
- },
- series: [
- {
- name: '',
- type: 'line',
- stack: 'virtual_mem',
- smooth: true,
- data: [{{.data.sys1.virtual_mem}}, {{.data.sys2.virtual_mem}}, {{.data.sys3.virtual_mem}}, {{.data.sys4.virtual_mem}}, {{.data.sys5.virtual_mem}}, {{.data.sys6.virtual_mem}}, {{.data.sys7.virtual_mem}}, {{.data.sys8.virtual_mem}}, {{.data.sys9.virtual_mem}}, {{.data.sys10.virtual_mem}}]
- },
- {
- name: '',
- type: 'line',
- stack: 'swap_mem',
- smooth: true,
- data: [{{.data.sys1.swap_mem}}, {{.data.sys2.swap_mem}}, {{.data.sys3.swap_mem}}, {{.data.sys4.swap_mem}}, {{.data.sys5.swap_mem}}, {{.data.sys6.swap_mem}}, {{.data.sys7.swap_mem}}, {{.data.sys8.swap_mem}}, {{.data.sys9.swap_mem}}, {{.data.sys10.swap_mem}}]
- }
- ]
- };
- chartdatas['connections'] = {
- tooltip: {
- trigger: 'axis'
- },
- grid: {
- left: '3%',
- right: '3%',
- top: '5%',
- bottom: '3%',
- containLabel: true
- },
- xAxis: {
- type: 'category',
- boundaryGap: false,
- data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
- },
- yAxis: {
- type: 'value'
- },
- series: [
- {
- name: '',
- type: 'line',
- stack: 'tcp',
- smooth: true,
- data: [{{.data.sys1.tcp}}, {{.data.sys2.tcp}}, {{.data.sys3.tcp}}, {{.data.sys4.tcp}}, {{.data.sys5.tcp}}, {{.data.sys6.tcp}}, {{.data.sys7.tcp}}, {{.data.sys8.tcp}}, {{.data.sys9.tcp}}, {{.data.sys10.tcp}}]
- },
- {
- name: '',
- type: 'line',
- stack: 'udp',
- smooth: true,
- data: [{{.data.sys1.udp}}, {{.data.sys2.udp}}, {{.data.sys3.udp}}, {{.data.sys4.udp}}, {{.data.sys5.udp}}, {{.data.sys6.udp}}, {{.data.sys7.udp}}, {{.data.sys8.udp}}, {{.data.sys9.udp}}, {{.data.sys10.udp}}]
- }
- ]
- };
- chartdatas['bandwidth'] = {
- tooltip: {
- trigger: 'axis',
- formatter: function (params) {
- var str = params[0].axisValue + '<br/>';
- for (i in params){
- str += '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' + params[i].color + ';"></span>' + params[i].seriesName +': '+ changeunit(params[i].data) +'/s</br>';
- }
- return str;
- }
- },
- grid: {
- left: '3%',
- right: '3%',
- top: '5%',
- bottom: '3%',
- containLabel: true
- },
- xAxis: {
- type: 'category',
- boundaryGap: false,
- data: ['{{.data.sys1.time}}', '{{.data.sys2.time}}', '{{.data.sys3.time}}', '{{.data.sys4.time}}', '{{.data.sys5.time}}', '{{.data.sys6.time}}', '{{.data.sys7.time}}', '{{.data.sys8.time}}', '{{.data.sys9.time}}', '{{.data.sys10.time}}']
- },
- yAxis: {
- type: 'value',
- axisLabel: {
- show: true,
- interval: 'auto',
- formatter: function (params){
- return changeunit (params);
- }
- }
- },
- series: [
- {
- name: '',
- type: 'line',
- stack: 'in',
- smooth: true,
- data: [{{.data.sys1.io_recv}}, {{.data.sys2.io_recv}}, {{.data.sys3.io_recv}}, {{.data.sys4.io_recv}}, {{.data.sys5.io_recv}}, {{.data.sys6.io_recv}}, {{.data.sys7.io_recv}}, {{.data.sys8.io_recv}}, {{.data.sys9.io_recv}}, {{.data.sys10.io_recv}}]
- },
- {
- name: '',
- type: 'line',
- stack: 'out',
- smooth: true,
- data: [{{.data.sys1.io_send}}, {{.data.sys2.io_send}}, {{.data.sys3.io_send}}, {{.data.sys4.io_send}}, {{.data.sys5.io_send}}, {{.data.sys6.io_send}}, {{.data.sys7.io_send}}, {{.data.sys8.io_send}}, {{.data.sys9.io_send}}, {{.data.sys10.io_send}}]
- }
- ]
- };
- chartdatas['flow'] = {
- tooltip: {
- trigger: 'item',
- formatter: function (p) {
- return p.seriesName + '<br>' + p.name + ':' + changeunit(p.data.value);
- }
- },
- legend: {
- orient: 'vertical',
- left: 'left',
- data: ['', '']
- },
- series: [
- {
- name: '',
- type: 'pie',
- radius: '55%',
- center: ['50%', '60%'],
- data: [
- {
- name: '',
- value:{{.data.inletFlowCount}}
- },
- {
- name: '',
- value:{{.data.exportFlowCount}}
- }
- ],
- itemStyle: {
- emphasis: {
- shadowBlur: 10,
- shadowOffsetX: 0,
- shadowColor: 'rgba(0, 0, 0, 0.5)'
- }
- }
- }
- ]
- };
- chartdatas['counts'] = {
- tooltip: {
- trigger: 'item',
- formatter: '{a} <br/>{b} : {c} ({d}%)'
- },
- legend: {
- orient: 'vertical',
- left: 'left',
- data: ['', '', '', '', '', '', '']
- },
- series: [
- {
- name: '',
- type: 'pie',
- radius: '55%',
- center: ['50%', '60%'],
- data: [
- {
- name: '',
- value:{{.data.hostCount}}
- },
- {
- name: '',
- value:{{.data.tcpC}}
- },
- {
- name: '',
- value:{{.data.udpCount}}
- },
- {
- name: '',
- value:{{.data.httpProxyCount}}
- },
- {
- name: '',
- value:{{.data.socks5Count}}
- },
- {
- name: '',
- value:{{.data.secretCount}}
- },
- {
- name: '',
- value:{{.data.p2pCount}}
- }
- ],
- itemStyle: {
- emphasis: {
- shadowBlur: 10,
- shadowOffsetX: 0,
- shadowColor: 'rgba(0, 0, 0, 0.5)'
- }
- }
- }
- ]
- };
- window.addEventListener('resize', () => {
- for(var key in charts){
- charts[key].resize();
- }
- });
- </script>
|