dashboard.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404
  1. define(['jquery', 'bootstrap', 'backend', 'addtabs', 'table', 'echarts', 'echarts-theme', 'template'], function ($, undefined, Backend, Datatable, Table, Echarts, undefined, Template) {
  2. var series=[];
  3. $.each(Orderdata.sourcedata,function(index){
  4. if(index != 0){
  5. series.push({type: 'line', smooth: true, seriesLayoutBy: 'row', emphasis: {focus: 'series'}});
  6. }
  7. });
  8. var length=Orderdata.sourcedata[0].length;
  9. length=length-1;
  10. series.push({
  11. type: 'pie',
  12. id: 'pie',
  13. radius: '30%',
  14. center: ['50%', '28%'],
  15. emphasis: {focus: 'data'},
  16. label: {
  17. formatter: '{b}: {@'+Orderdata.sourcedata[0][length]+'} ({d}%)'
  18. },
  19. encode: {
  20. itemName: Orderdata.sourcedata[0][0],
  21. value: Orderdata.sourcedata[0][length],
  22. tooltip: Orderdata.sourcedata[0][length]
  23. }
  24. });
  25. var Controller = {
  26. index: function () {
  27. // 初始化表格参数配置
  28. Table.api.init();
  29. //绑定事件
  30. $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
  31. var panel = $($(this).attr("href"));
  32. if (panel.length > 0) {
  33. Controller.table[panel.attr("id")].call(this);
  34. $(this).on('click', function (e) {
  35. $($(this).attr("href")).find(".btn-refresh").trigger("click");
  36. });
  37. }
  38. //移除绑定的事件
  39. $(this).unbind('shown.bs.tab');
  40. });
  41. //必须默认触发shown.bs.tab事件
  42. $('ul.nav-tabs li.active a[data-toggle="tab"]').trigger("shown.bs.tab");
  43. },
  44. table: {
  45. one: function () {
  46. // 基于准备好的dom,初始化echarts实例
  47. var myChart = Echarts.init(document.getElementById('echart'), 'walden');
  48. // 指定图表的配置项和数据
  49. var option = {
  50. legend: {},
  51. tooltip: {
  52. trigger: 'axis',
  53. showContent: false
  54. },
  55. dataset: {
  56. source: Orderdata.Personsourcedata
  57. },
  58. xAxis: {type: 'category'},
  59. yAxis: {gridIndex: 0},
  60. grid: {top: '55%'},
  61. series:series
  62. };
  63. myChart.on('updateAxisPointer', function (event) {
  64. var xAxisInfo = event.axesInfo[0];
  65. if (xAxisInfo) {
  66. var dimension = xAxisInfo.value + 1;
  67. myChart.setOption({
  68. series: {
  69. id: 'pie',
  70. label: {
  71. formatter: '{b}: {@[' + dimension + ']} ({d}%)'
  72. },
  73. encode: {
  74. value: dimension,
  75. tooltip: dimension
  76. }
  77. }
  78. });
  79. }
  80. });
  81. // 使用刚指定的配置项和数据显示图表。
  82. myChart.setOption(option);
  83. var myChart2=Echarts.init(document.getElementById('echart2'), 'walden');
  84. var option2 = {
  85. tooltip: {
  86. trigger: 'axis',
  87. axisPointer: {
  88. type: 'cross',
  89. crossStyle: {
  90. color: '#999'
  91. }
  92. }
  93. },
  94. toolbox: {
  95. feature: {
  96. dataView: {show: true, readOnly: false},
  97. magicType: {show: true, type: ['line', 'bar']},
  98. restore: {show: true},
  99. saveAsImage: {show: true}
  100. }
  101. },
  102. legend: {
  103. data: ['合同金额', '合同份数']
  104. },
  105. xAxis: [
  106. {
  107. type: 'category',
  108. data: Orderdata.personcontactdata.date,
  109. axisPointer: {
  110. type: 'shadow'
  111. }
  112. }
  113. ],
  114. yAxis: [
  115. {
  116. type: 'value',
  117. name: '金额',
  118. axisLabel: {
  119. formatter: '{value} 元'
  120. }
  121. },
  122. {
  123. type: 'value',
  124. name: '合同数',
  125. axisLabel: {
  126. formatter: '{value} 份'
  127. }
  128. }
  129. ],
  130. series: [
  131. {
  132. name: '合同金额',
  133. type: 'bar',
  134. data: Orderdata.personcontactdata.contract
  135. },
  136. {
  137. name: '合同份数',
  138. type: 'line',
  139. yAxisIndex: 1,
  140. data: Orderdata.personcontactdata.num
  141. }
  142. ]
  143. };
  144. // 使用刚指定的配置项和数据显示图表。
  145. myChart2.setOption(option2);
  146. var myChart3=Echarts.init(document.getElementById('echart3'), 'walden');
  147. var option3 = {
  148. tooltip: {
  149. trigger: 'axis',
  150. axisPointer: {
  151. type: 'cross',
  152. crossStyle: {
  153. color: '#999'
  154. }
  155. }
  156. },
  157. toolbox: {
  158. feature: {
  159. dataView: {show: true, readOnly: false},
  160. magicType: {show: true, type: ['line', 'bar']},
  161. restore: {show: true},
  162. saveAsImage: {show: true}
  163. }
  164. },
  165. legend: {
  166. data: ['回款金额']
  167. },
  168. xAxis: [
  169. {
  170. type: 'category',
  171. data: Orderdata.personcontactdata.date,
  172. axisPointer: {
  173. type: 'shadow'
  174. }
  175. }
  176. ],
  177. yAxis: [
  178. {
  179. type: 'value',
  180. name: '金额',
  181. axisLabel: {
  182. formatter: '{value} 元'
  183. }
  184. }
  185. ],
  186. series: [
  187. {
  188. name: '回款金额',
  189. type: 'bar',
  190. data: Orderdata.personcontactdata.receivables
  191. }
  192. ]
  193. };
  194. // 使用刚指定的配置项和数据显示图表。
  195. myChart3.setOption(option3);
  196. $(window).resize(function () {
  197. myChart.resize();
  198. });
  199. $(document).on("click", ".btn-refresh", function () {
  200. setTimeout(function () {
  201. myChart.resize();
  202. }, 0);
  203. });
  204. },
  205. two: function () {
  206. // 基于准备好的dom,初始化echarts实例
  207. var myChart = Echarts.init(document.getElementById('echart6'), 'walden');
  208. // 指定图表的配置项和数据
  209. var option = {
  210. legend: {},
  211. tooltip: {
  212. trigger: 'axis',
  213. showContent: false
  214. },
  215. dataset: {
  216. source: Orderdata.sourcedata
  217. },
  218. xAxis: {type: 'category'},
  219. yAxis: {gridIndex: 0},
  220. grid: {top: '55%'},
  221. series:series
  222. };
  223. myChart.on('updateAxisPointer', function (event) {
  224. var xAxisInfo = event.axesInfo[0];
  225. if (xAxisInfo) {
  226. var dimension = xAxisInfo.value + 1;
  227. myChart.setOption({
  228. series: {
  229. id: 'pie',
  230. label: {
  231. formatter: '{b}: {@[' + dimension + ']} ({d}%)'
  232. },
  233. encode: {
  234. value: dimension,
  235. tooltip: dimension
  236. }
  237. }
  238. });
  239. }
  240. });
  241. // 使用刚指定的配置项和数据显示图表。
  242. myChart.setOption(option);
  243. var myChart2=Echarts.init(document.getElementById('echart7'), 'walden');
  244. var option2 = {
  245. tooltip: {
  246. trigger: 'axis',
  247. axisPointer: {
  248. type: 'cross',
  249. crossStyle: {
  250. color: '#999'
  251. }
  252. }
  253. },
  254. toolbox: {
  255. feature: {
  256. dataView: {show: true, readOnly: false},
  257. magicType: {show: true, type: ['line', 'bar']},
  258. restore: {show: true},
  259. saveAsImage: {show: true}
  260. }
  261. },
  262. legend: {
  263. data: ['合同金额', '合同份数']
  264. },
  265. xAxis: [
  266. {
  267. type: 'category',
  268. data: Orderdata.contactdata.date,
  269. axisPointer: {
  270. type: 'shadow'
  271. }
  272. }
  273. ],
  274. yAxis: [
  275. {
  276. type: 'value',
  277. name: '金额',
  278. axisLabel: {
  279. formatter: '{value} 元'
  280. }
  281. },
  282. {
  283. type: 'value',
  284. name: '合同数',
  285. axisLabel: {
  286. formatter: '{value} 份'
  287. }
  288. }
  289. ],
  290. series: [
  291. {
  292. name: '合同金额',
  293. type: 'bar',
  294. data: Orderdata.contactdata.contract
  295. },
  296. {
  297. name: '合同份数',
  298. type: 'line',
  299. yAxisIndex: 1,
  300. data: Orderdata.contactdata.num
  301. }
  302. ]
  303. };
  304. // 使用刚指定的配置项和数据显示图表。
  305. myChart2.setOption(option2);
  306. var myChart3=Echarts.init(document.getElementById('echart5'), 'walden');
  307. var option3 = {
  308. tooltip: {
  309. trigger: 'axis',
  310. axisPointer: {
  311. type: 'cross',
  312. crossStyle: {
  313. color: '#999'
  314. }
  315. }
  316. },
  317. toolbox: {
  318. feature: {
  319. dataView: {show: true, readOnly: false},
  320. magicType: {show: true, type: ['line', 'bar']},
  321. restore: {show: true},
  322. saveAsImage: {show: true}
  323. }
  324. },
  325. legend: {
  326. data: ['回款金额']
  327. },
  328. xAxis: [
  329. {
  330. type: 'category',
  331. data: Orderdata.contactdata.date,
  332. axisPointer: {
  333. type: 'shadow'
  334. }
  335. }
  336. ],
  337. yAxis: [
  338. {
  339. type: 'value',
  340. name: '金额',
  341. axisLabel: {
  342. formatter: '{value} 元'
  343. }
  344. }
  345. ],
  346. series: [
  347. {
  348. name: '回款金额',
  349. type: 'bar',
  350. data: Orderdata.contactdata.receivables
  351. }
  352. ]
  353. };
  354. // 使用刚指定的配置项和数据显示图表。
  355. myChart3.setOption(option3);
  356. $(window).resize(function () {
  357. myChart.resize();
  358. });
  359. $(document).on("click", ".btn-refresh", function () {
  360. setTimeout(function () {
  361. myChart.resize();
  362. }, 0);
  363. });
  364. },
  365. },
  366. };
  367. return Controller;
  368. });