@delon/chart 12.4.1 → 13.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (345) hide show
  1. package/bar/bar.component.d.ts +4 -1
  2. package/bar/bar.d.ts +1 -0
  3. package/bar/bar.module.d.ts +8 -0
  4. package/bar/package.json +5 -6
  5. package/card/card.component.d.ts +7 -4
  6. package/card/card.d.ts +1 -0
  7. package/card/card.module.d.ts +9 -0
  8. package/card/package.json +5 -6
  9. package/card/style/index.less +11 -0
  10. package/{custom/g2Custom.d.ts → chart-echarts/chart-echarts.d.ts} +1 -0
  11. package/chart-echarts/echarts.component.d.ts +3 -0
  12. package/chart-echarts/echarts.module.d.ts +7 -0
  13. package/chart-echarts/echarts.service.d.ts +3 -0
  14. package/chart-echarts/package.json +6 -7
  15. package/chart.d.ts +1 -0
  16. package/{chart-echarts/delon-chart-chart-echarts.d.ts → core/core.d.ts} +1 -0
  17. package/core/g2.base.component.d.ts +4 -1
  18. package/core/g2.servicce.d.ts +3 -0
  19. package/core/package.json +6 -7
  20. package/custom/custom.component.d.ts +4 -1
  21. package/{core/delon-chart-core.d.ts → custom/custom.d.ts} +1 -0
  22. package/custom/custom.module.d.ts +7 -0
  23. package/custom/package.json +6 -7
  24. package/esm2020/bar/bar.component.mjs +143 -0
  25. package/{esm2015/bar/bar.js → esm2020/bar/bar.mjs} +0 -0
  26. package/esm2020/bar/bar.module.mjs +21 -0
  27. package/{esm2015/bar/public_api.js → esm2020/bar/public_api.mjs} +0 -0
  28. package/esm2020/card/card.component.mjs +55 -0
  29. package/{esm2015/card/card.js → esm2020/card/card.mjs} +0 -0
  30. package/esm2020/card/card.module.mjs +22 -0
  31. package/{esm2015/card/public_api.js → esm2020/card/public_api.mjs} +0 -0
  32. package/esm2020/chart-echarts/chart-echarts.mjs +5 -0
  33. package/esm2020/chart-echarts/echarts.component.mjs +162 -0
  34. package/esm2020/chart-echarts/echarts.module.mjs +20 -0
  35. package/esm2020/chart-echarts/echarts.service.mjs +60 -0
  36. package/{esm2015/chart-echarts/echarts.types.js → esm2020/chart-echarts/echarts.types.mjs} +0 -0
  37. package/{esm2015/chart-echarts/public_api.js → esm2020/chart-echarts/public_api.mjs} +0 -0
  38. package/{esm2015/chart.js → esm2020/chart.mjs} +0 -0
  39. package/esm2020/core/core.mjs +5 -0
  40. package/esm2020/core/g2.base.component.mjs +109 -0
  41. package/esm2020/core/g2.servicce.mjs +54 -0
  42. package/{esm2015/core/public_api.js → esm2020/core/public_api.mjs} +0 -0
  43. package/{esm2015/core/types/interaction.js → esm2020/core/types/interaction.mjs} +0 -0
  44. package/{esm2015/core/types/time.js → esm2020/core/types/time.mjs} +0 -0
  45. package/esm2020/core/utils.mjs +21 -0
  46. package/esm2020/custom/custom.component.mjs +70 -0
  47. package/esm2020/custom/custom.mjs +5 -0
  48. package/esm2020/custom/custom.module.mjs +20 -0
  49. package/{esm2015/custom/public_api.js → esm2020/custom/public_api.mjs} +0 -0
  50. package/esm2020/gauge/gauge.component.mjs +169 -0
  51. package/{esm2015/gauge/gauge.js → esm2020/gauge/gauge.mjs} +0 -0
  52. package/esm2020/gauge/gauge.module.mjs +20 -0
  53. package/{esm2015/gauge/public_api.js → esm2020/gauge/public_api.mjs} +0 -0
  54. package/esm2020/mini-area/mini-area.component.mjs +133 -0
  55. package/{esm2015/mini-area/mini-area.js → esm2020/mini-area/mini-area.mjs} +0 -0
  56. package/esm2020/mini-area/mini-area.module.mjs +19 -0
  57. package/{esm2015/mini-area/public_api.js → esm2020/mini-area/public_api.mjs} +0 -0
  58. package/esm2020/mini-bar/mini-bar.component.mjs +100 -0
  59. package/{esm2015/mini-bar/mini-bar.js → esm2020/mini-bar/mini-bar.mjs} +0 -0
  60. package/esm2020/mini-bar/mini-bar.module.mjs +19 -0
  61. package/{esm2015/mini-bar/public_api.js → esm2020/mini-bar/public_api.mjs} +0 -0
  62. package/esm2020/mini-progress/mini-progress.component.mjs +46 -0
  63. package/{esm2015/mini-progress/mini-progress.js → esm2020/mini-progress/mini-progress.mjs} +0 -0
  64. package/esm2020/mini-progress/mini-progress.module.mjs +21 -0
  65. package/{esm2015/mini-progress/public_api.js → esm2020/mini-progress/public_api.mjs} +0 -0
  66. package/esm2020/number-info/number-info.component.mjs +45 -0
  67. package/{esm2015/number-info/number-info.js → esm2020/number-info/number-info.mjs} +0 -0
  68. package/esm2020/number-info/number-info.module.mjs +21 -0
  69. package/{esm2015/number-info/public_api.js → esm2020/number-info/public_api.mjs} +0 -0
  70. package/esm2020/pie/pie.component.mjs +215 -0
  71. package/{esm2015/pie/pie.js → esm2020/pie/pie.mjs} +0 -0
  72. package/esm2020/pie/pie.module.mjs +22 -0
  73. package/{esm2015/pie/public_api.js → esm2020/pie/public_api.mjs} +0 -0
  74. package/{esm2015/public_api.js → esm2020/public_api.mjs} +0 -0
  75. package/{esm2015/radar/public_api.js → esm2020/radar/public_api.mjs} +0 -0
  76. package/esm2020/radar/radar.component.mjs +148 -0
  77. package/{esm2015/radar/radar.js → esm2020/radar/radar.mjs} +0 -0
  78. package/esm2020/radar/radar.module.mjs +22 -0
  79. package/{esm2015/single-bar/public_api.js → esm2020/single-bar/public_api.mjs} +0 -0
  80. package/esm2020/single-bar/single-bar.component.mjs +126 -0
  81. package/{esm2015/single-bar/single-bar.js → esm2020/single-bar/single-bar.mjs} +0 -0
  82. package/esm2020/single-bar/single-bar.module.mjs +19 -0
  83. package/{esm2015/tag-cloud/public_api.js → esm2020/tag-cloud/public_api.mjs} +0 -0
  84. package/esm2020/tag-cloud/tag-cloud.component.mjs +161 -0
  85. package/{esm2015/tag-cloud/tag-cloud.js → esm2020/tag-cloud/tag-cloud.mjs} +0 -0
  86. package/esm2020/tag-cloud/tag-cloud.module.mjs +20 -0
  87. package/{esm2015/timeline/public_api.js → esm2020/timeline/public_api.mjs} +0 -0
  88. package/esm2020/timeline/timeline.component.mjs +204 -0
  89. package/{esm2015/timeline/timeline.js → esm2020/timeline/timeline.mjs} +0 -0
  90. package/esm2020/timeline/timeline.module.mjs +21 -0
  91. package/{esm2015/trend/public_api.js → esm2020/trend/public_api.mjs} +0 -0
  92. package/esm2020/trend/trend.component.mjs +52 -0
  93. package/{esm2015/trend/trend.js → esm2020/trend/trend.mjs} +0 -0
  94. package/esm2020/trend/trend.module.mjs +20 -0
  95. package/{esm2015/water-wave/public_api.js → esm2020/water-wave/public_api.mjs} +0 -0
  96. package/esm2020/water-wave/water-wave.component.mjs +221 -0
  97. package/{esm2015/water-wave/water-wave.js → esm2020/water-wave/water-wave.mjs} +0 -0
  98. package/esm2020/water-wave/water-wave.module.mjs +20 -0
  99. package/fesm2015/{bar.js → bar.mjs} +57 -34
  100. package/fesm2015/bar.mjs.map +1 -0
  101. package/fesm2015/card.mjs +81 -0
  102. package/fesm2015/card.mjs.map +1 -0
  103. package/fesm2015/{delon-chart-chart-echarts.js → chart-echarts.mjs} +62 -53
  104. package/fesm2015/chart-echarts.mjs.map +1 -0
  105. package/fesm2015/{chart.js → chart.mjs} +1 -1
  106. package/fesm2015/chart.mjs.map +1 -0
  107. package/fesm2015/{delon-chart-core.js → core.mjs} +23 -29
  108. package/fesm2015/core.mjs.map +1 -0
  109. package/fesm2015/custom.mjs +94 -0
  110. package/fesm2015/custom.mjs.map +1 -0
  111. package/fesm2015/{gauge.js → gauge.mjs} +46 -31
  112. package/fesm2015/gauge.mjs.map +1 -0
  113. package/fesm2015/mini-area.mjs +156 -0
  114. package/fesm2015/mini-area.mjs.map +1 -0
  115. package/fesm2015/mini-bar.mjs +123 -0
  116. package/fesm2015/mini-bar.mjs.map +1 -0
  117. package/fesm2015/mini-progress.mjs +71 -0
  118. package/fesm2015/mini-progress.mjs.map +1 -0
  119. package/fesm2015/number-info.mjs +70 -0
  120. package/fesm2015/number-info.mjs.map +1 -0
  121. package/fesm2015/pie.mjs +241 -0
  122. package/fesm2015/pie.mjs.map +1 -0
  123. package/fesm2015/{radar.js → radar.mjs} +43 -33
  124. package/fesm2015/radar.mjs.map +1 -0
  125. package/fesm2015/single-bar.mjs +147 -0
  126. package/fesm2015/single-bar.mjs.map +1 -0
  127. package/fesm2015/{tag-cloud.js → tag-cloud.mjs} +39 -26
  128. package/fesm2015/tag-cloud.mjs.map +1 -0
  129. package/fesm2015/{timeline.js → timeline.mjs} +64 -36
  130. package/fesm2015/timeline.mjs.map +1 -0
  131. package/fesm2015/trend.mjs +76 -0
  132. package/fesm2015/trend.mjs.map +1 -0
  133. package/fesm2015/{water-wave.js → water-wave.mjs} +38 -37
  134. package/fesm2015/water-wave.mjs.map +1 -0
  135. package/fesm2020/bar.mjs +168 -0
  136. package/fesm2020/bar.mjs.map +1 -0
  137. package/fesm2020/card.mjs +81 -0
  138. package/fesm2020/card.mjs.map +1 -0
  139. package/fesm2020/chart-echarts.mjs +242 -0
  140. package/fesm2020/chart-echarts.mjs.map +1 -0
  141. package/fesm2020/chart.mjs +7 -0
  142. package/fesm2020/chart.mjs.map +1 -0
  143. package/fesm2020/core.mjs +187 -0
  144. package/fesm2020/core.mjs.map +1 -0
  145. package/fesm2020/custom.mjs +94 -0
  146. package/fesm2020/custom.mjs.map +1 -0
  147. package/fesm2020/gauge.mjs +193 -0
  148. package/fesm2020/gauge.mjs.map +1 -0
  149. package/fesm2020/mini-area.mjs +156 -0
  150. package/fesm2020/mini-area.mjs.map +1 -0
  151. package/fesm2020/mini-bar.mjs +123 -0
  152. package/fesm2020/mini-bar.mjs.map +1 -0
  153. package/fesm2020/mini-progress.mjs +71 -0
  154. package/fesm2020/mini-progress.mjs.map +1 -0
  155. package/fesm2020/number-info.mjs +70 -0
  156. package/fesm2020/number-info.mjs.map +1 -0
  157. package/fesm2020/pie.mjs +241 -0
  158. package/fesm2020/pie.mjs.map +1 -0
  159. package/fesm2020/radar.mjs +174 -0
  160. package/fesm2020/radar.mjs.map +1 -0
  161. package/fesm2020/single-bar.mjs +149 -0
  162. package/fesm2020/single-bar.mjs.map +1 -0
  163. package/fesm2020/tag-cloud.mjs +185 -0
  164. package/fesm2020/tag-cloud.mjs.map +1 -0
  165. package/fesm2020/timeline.mjs +229 -0
  166. package/fesm2020/timeline.mjs.map +1 -0
  167. package/fesm2020/trend.mjs +76 -0
  168. package/fesm2020/trend.mjs.map +1 -0
  169. package/fesm2020/water-wave.mjs +245 -0
  170. package/fesm2020/water-wave.mjs.map +1 -0
  171. package/gauge/gauge.component.d.ts +8 -5
  172. package/gauge/gauge.d.ts +1 -0
  173. package/gauge/gauge.module.d.ts +7 -0
  174. package/gauge/package.json +5 -6
  175. package/mini-area/mini-area.component.d.ts +3 -0
  176. package/mini-area/mini-area.d.ts +1 -0
  177. package/mini-area/mini-area.module.d.ts +6 -0
  178. package/mini-area/package.json +5 -6
  179. package/mini-bar/mini-bar.component.d.ts +3 -0
  180. package/mini-bar/mini-bar.d.ts +1 -0
  181. package/mini-bar/mini-bar.module.d.ts +6 -0
  182. package/mini-bar/package.json +5 -6
  183. package/mini-progress/mini-progress.component.d.ts +6 -3
  184. package/mini-progress/mini-progress.d.ts +1 -0
  185. package/mini-progress/mini-progress.module.d.ts +8 -0
  186. package/mini-progress/package.json +5 -6
  187. package/mini-progress/style/index.less +5 -0
  188. package/number-info/number-info.component.d.ts +9 -6
  189. package/number-info/number-info.d.ts +1 -0
  190. package/number-info/number-info.module.d.ts +8 -0
  191. package/number-info/package.json +5 -6
  192. package/number-info/style/index.less +12 -0
  193. package/package.json +160 -12
  194. package/pie/package.json +5 -6
  195. package/pie/pie.component.d.ts +8 -5
  196. package/pie/pie.d.ts +1 -0
  197. package/pie/pie.module.d.ts +9 -0
  198. package/pie/style/index.less +14 -0
  199. package/radar/package.json +5 -6
  200. package/radar/radar.component.d.ts +4 -1
  201. package/radar/radar.d.ts +1 -0
  202. package/radar/radar.module.d.ts +9 -0
  203. package/radar/style/index.less +6 -0
  204. package/single-bar/package.json +5 -6
  205. package/single-bar/single-bar.component.d.ts +4 -1
  206. package/single-bar/single-bar.d.ts +1 -0
  207. package/single-bar/single-bar.module.d.ts +6 -0
  208. package/tag-cloud/package.json +5 -6
  209. package/tag-cloud/tag-cloud.component.d.ts +3 -0
  210. package/tag-cloud/tag-cloud.d.ts +1 -0
  211. package/tag-cloud/tag-cloud.module.d.ts +7 -0
  212. package/timeline/package.json +5 -6
  213. package/timeline/timeline.component.d.ts +5 -2
  214. package/timeline/timeline.d.ts +1 -0
  215. package/timeline/timeline.module.d.ts +8 -0
  216. package/trend/package.json +5 -6
  217. package/trend/style/index.less +6 -0
  218. package/trend/trend.component.d.ts +4 -1
  219. package/trend/trend.d.ts +1 -0
  220. package/trend/trend.module.d.ts +7 -0
  221. package/water-wave/package.json +5 -6
  222. package/water-wave/style/index.less +4 -0
  223. package/water-wave/water-wave.component.d.ts +5 -2
  224. package/water-wave/water-wave.d.ts +1 -0
  225. package/water-wave/water-wave.module.d.ts +7 -0
  226. package/bar/bar.metadata.json +0 -1
  227. package/bundles/bar.umd.js +0 -471
  228. package/bundles/bar.umd.js.map +0 -1
  229. package/bundles/card.umd.js +0 -408
  230. package/bundles/card.umd.js.map +0 -1
  231. package/bundles/chart.umd.js +0 -19
  232. package/bundles/chart.umd.js.map +0 -1
  233. package/bundles/delon-chart-chart-echarts.umd.js +0 -617
  234. package/bundles/delon-chart-chart-echarts.umd.js.map +0 -1
  235. package/bundles/delon-chart-core.umd.js +0 -550
  236. package/bundles/delon-chart-core.umd.js.map +0 -1
  237. package/bundles/g2Custom.umd.js +0 -407
  238. package/bundles/g2Custom.umd.js.map +0 -1
  239. package/bundles/gauge.umd.js +0 -511
  240. package/bundles/gauge.umd.js.map +0 -1
  241. package/bundles/mini-area.umd.js +0 -471
  242. package/bundles/mini-area.umd.js.map +0 -1
  243. package/bundles/mini-bar.umd.js +0 -444
  244. package/bundles/mini-bar.umd.js.map +0 -1
  245. package/bundles/mini-progress.umd.js +0 -401
  246. package/bundles/mini-progress.umd.js.map +0 -1
  247. package/bundles/number-info.umd.js +0 -392
  248. package/bundles/number-info.umd.js.map +0 -1
  249. package/bundles/pie.umd.js +0 -567
  250. package/bundles/pie.umd.js.map +0 -1
  251. package/bundles/radar.umd.js +0 -497
  252. package/bundles/radar.umd.js.map +0 -1
  253. package/bundles/single-bar.umd.js +0 -464
  254. package/bundles/single-bar.umd.js.map +0 -1
  255. package/bundles/tag-cloud.umd.js +0 -495
  256. package/bundles/tag-cloud.umd.js.map +0 -1
  257. package/bundles/timeline.umd.js +0 -524
  258. package/bundles/timeline.umd.js.map +0 -1
  259. package/bundles/trend.umd.js +0 -391
  260. package/bundles/trend.umd.js.map +0 -1
  261. package/bundles/water-wave.umd.js +0 -587
  262. package/bundles/water-wave.umd.js.map +0 -1
  263. package/card/card.metadata.json +0 -1
  264. package/chart-echarts/delon-chart-chart-echarts.metadata.json +0 -1
  265. package/chart.metadata.json +0 -1
  266. package/core/delon-chart-core.metadata.json +0 -1
  267. package/custom/g2Custom.metadata.json +0 -1
  268. package/esm2015/bar/bar.component.js +0 -124
  269. package/esm2015/bar/bar.module.js +0 -16
  270. package/esm2015/card/card.component.js +0 -52
  271. package/esm2015/card/card.module.js +0 -17
  272. package/esm2015/chart-echarts/delon-chart-chart-echarts.js +0 -5
  273. package/esm2015/chart-echarts/echarts.component.js +0 -152
  274. package/esm2015/chart-echarts/echarts.module.js +0 -15
  275. package/esm2015/chart-echarts/echarts.service.js +0 -64
  276. package/esm2015/core/delon-chart-core.js +0 -5
  277. package/esm2015/core/g2.base.component.js +0 -110
  278. package/esm2015/core/g2.servicce.js +0 -58
  279. package/esm2015/core/utils.js +0 -15
  280. package/esm2015/custom/custom.component.js +0 -58
  281. package/esm2015/custom/custom.module.js +0 -15
  282. package/esm2015/custom/g2Custom.js +0 -5
  283. package/esm2015/gauge/gauge.component.js +0 -158
  284. package/esm2015/gauge/gauge.module.js +0 -15
  285. package/esm2015/mini-area/mini-area.component.js +0 -117
  286. package/esm2015/mini-area/mini-area.module.js +0 -14
  287. package/esm2015/mini-bar/mini-bar.component.js +0 -90
  288. package/esm2015/mini-bar/mini-bar.module.js +0 -14
  289. package/esm2015/mini-progress/mini-progress.component.js +0 -50
  290. package/esm2015/mini-progress/mini-progress.module.js +0 -16
  291. package/esm2015/number-info/number-info.component.js +0 -40
  292. package/esm2015/number-info/number-info.module.js +0 -16
  293. package/esm2015/pie/pie.component.js +0 -197
  294. package/esm2015/pie/pie.module.js +0 -17
  295. package/esm2015/radar/radar.component.js +0 -142
  296. package/esm2015/radar/radar.module.js +0 -17
  297. package/esm2015/single-bar/single-bar.component.js +0 -111
  298. package/esm2015/single-bar/single-bar.module.js +0 -14
  299. package/esm2015/tag-cloud/tag-cloud.component.js +0 -142
  300. package/esm2015/tag-cloud/tag-cloud.module.js +0 -15
  301. package/esm2015/timeline/timeline.component.js +0 -178
  302. package/esm2015/timeline/timeline.module.js +0 -16
  303. package/esm2015/trend/trend.component.js +0 -42
  304. package/esm2015/trend/trend.module.js +0 -15
  305. package/esm2015/water-wave/water-wave.component.js +0 -224
  306. package/esm2015/water-wave/water-wave.module.js +0 -15
  307. package/fesm2015/bar.js.map +0 -1
  308. package/fesm2015/card.js +0 -74
  309. package/fesm2015/card.js.map +0 -1
  310. package/fesm2015/chart.js.map +0 -1
  311. package/fesm2015/delon-chart-chart-echarts.js.map +0 -1
  312. package/fesm2015/delon-chart-core.js.map +0 -1
  313. package/fesm2015/g2Custom.js +0 -78
  314. package/fesm2015/g2Custom.js.map +0 -1
  315. package/fesm2015/gauge.js.map +0 -1
  316. package/fesm2015/mini-area.js +0 -136
  317. package/fesm2015/mini-area.js.map +0 -1
  318. package/fesm2015/mini-bar.js +0 -109
  319. package/fesm2015/mini-bar.js.map +0 -1
  320. package/fesm2015/mini-progress.js +0 -70
  321. package/fesm2015/mini-progress.js.map +0 -1
  322. package/fesm2015/number-info.js +0 -61
  323. package/fesm2015/number-info.js.map +0 -1
  324. package/fesm2015/pie.js +0 -219
  325. package/fesm2015/pie.js.map +0 -1
  326. package/fesm2015/radar.js.map +0 -1
  327. package/fesm2015/single-bar.js +0 -130
  328. package/fesm2015/single-bar.js.map +0 -1
  329. package/fesm2015/tag-cloud.js.map +0 -1
  330. package/fesm2015/timeline.js.map +0 -1
  331. package/fesm2015/trend.js +0 -62
  332. package/fesm2015/trend.js.map +0 -1
  333. package/fesm2015/water-wave.js.map +0 -1
  334. package/gauge/gauge.metadata.json +0 -1
  335. package/mini-area/mini-area.metadata.json +0 -1
  336. package/mini-bar/mini-bar.metadata.json +0 -1
  337. package/mini-progress/mini-progress.metadata.json +0 -1
  338. package/number-info/number-info.metadata.json +0 -1
  339. package/pie/pie.metadata.json +0 -1
  340. package/radar/radar.metadata.json +0 -1
  341. package/single-bar/single-bar.metadata.json +0 -1
  342. package/tag-cloud/tag-cloud.metadata.json +0 -1
  343. package/timeline/timeline.metadata.json +0 -1
  344. package/trend/trend.metadata.json +0 -1
  345. package/water-wave/water-wave.metadata.json +0 -1
@@ -0,0 +1,149 @@
1
+ import { __decorate } from 'tslib';
2
+ import * as i0 from '@angular/core';
3
+ import { Component, ChangeDetectionStrategy, ViewEncapsulation, Input, NgModule } from '@angular/core';
4
+ import { G2BaseComponent } from '@delon/chart/core';
5
+ import { InputNumber, InputBoolean } from '@delon/util/decorator';
6
+ import { CommonModule } from '@angular/common';
7
+
8
+ class G2SingleBarComponent extends G2BaseComponent {
9
+ constructor() {
10
+ super(...arguments);
11
+ // #region fields
12
+ this.plusColor = '#40a9ff';
13
+ this.minusColor = '#ff4d4f';
14
+ this.height = 60;
15
+ this.barSize = 30;
16
+ this.min = 0;
17
+ this.max = 100;
18
+ this.value = 0;
19
+ this.line = false;
20
+ this.padding = 0;
21
+ this.textStyle = { fontSize: 12, color: '#595959' };
22
+ this.onlyChangeData = (changes) => {
23
+ return Object.keys(changes).length === 1 && !!changes.value;
24
+ };
25
+ }
26
+ // #endregion
27
+ install() {
28
+ const { el, height, padding, textStyle, line, format, theme, min, max, plusColor, minusColor, barSize } = this;
29
+ const chart = (this._chart = new window.G2.Chart({
30
+ container: el.nativeElement,
31
+ autoFit: true,
32
+ height,
33
+ padding,
34
+ theme
35
+ }));
36
+ chart.legend(false);
37
+ chart.axis(false);
38
+ chart.scale({ value: { max, min } });
39
+ chart.tooltip(false);
40
+ chart.coordinate().transpose();
41
+ chart
42
+ .interval()
43
+ .position('1*value')
44
+ .color('value', (val) => (val > 0 ? plusColor : minusColor))
45
+ .size(barSize)
46
+ .label('value', () => ({
47
+ formatter: format,
48
+ style: {
49
+ ...textStyle
50
+ }
51
+ }));
52
+ if (line) {
53
+ chart.annotation().line({
54
+ start: ['50%', '0%'],
55
+ end: ['50%', '100%'],
56
+ style: {
57
+ stroke: '#e8e8e8',
58
+ lineDash: [0, 0]
59
+ }
60
+ });
61
+ }
62
+ this.changeData();
63
+ chart.render();
64
+ }
65
+ changeData() {
66
+ const { _chart, value } = this;
67
+ if (!_chart)
68
+ return;
69
+ _chart.changeData([{ value }]);
70
+ }
71
+ }
72
+ G2SingleBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2SingleBarComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
73
+ G2SingleBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: G2SingleBarComponent, selector: "g2-single-bar", inputs: { plusColor: "plusColor", minusColor: "minusColor", height: "height", barSize: "barSize", min: "min", max: "max", value: "value", line: "line", format: "format", padding: "padding", textStyle: "textStyle" }, host: { properties: { "style.height.px": "height" } }, exportAs: ["g2SingleBar"], usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
74
+ __decorate([
75
+ InputNumber()
76
+ ], G2SingleBarComponent.prototype, "height", void 0);
77
+ __decorate([
78
+ InputNumber()
79
+ ], G2SingleBarComponent.prototype, "barSize", void 0);
80
+ __decorate([
81
+ InputNumber()
82
+ ], G2SingleBarComponent.prototype, "min", void 0);
83
+ __decorate([
84
+ InputNumber()
85
+ ], G2SingleBarComponent.prototype, "max", void 0);
86
+ __decorate([
87
+ InputNumber()
88
+ ], G2SingleBarComponent.prototype, "value", void 0);
89
+ __decorate([
90
+ InputBoolean()
91
+ ], G2SingleBarComponent.prototype, "line", void 0);
92
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2SingleBarComponent, decorators: [{
93
+ type: Component,
94
+ args: [{
95
+ selector: 'g2-single-bar',
96
+ exportAs: 'g2SingleBar',
97
+ template: ``,
98
+ host: {
99
+ '[style.height.px]': 'height'
100
+ },
101
+ preserveWhitespaces: false,
102
+ changeDetection: ChangeDetectionStrategy.OnPush,
103
+ encapsulation: ViewEncapsulation.None
104
+ }]
105
+ }], propDecorators: { plusColor: [{
106
+ type: Input
107
+ }], minusColor: [{
108
+ type: Input
109
+ }], height: [{
110
+ type: Input
111
+ }], barSize: [{
112
+ type: Input
113
+ }], min: [{
114
+ type: Input
115
+ }], max: [{
116
+ type: Input
117
+ }], value: [{
118
+ type: Input
119
+ }], line: [{
120
+ type: Input
121
+ }], format: [{
122
+ type: Input
123
+ }], padding: [{
124
+ type: Input
125
+ }], textStyle: [{
126
+ type: Input
127
+ }] } });
128
+
129
+ const COMPONENTS = [G2SingleBarComponent];
130
+ class G2SingleBarModule {
131
+ }
132
+ G2SingleBarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2SingleBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
133
+ G2SingleBarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2SingleBarModule, declarations: [G2SingleBarComponent], imports: [CommonModule], exports: [G2SingleBarComponent] });
134
+ G2SingleBarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2SingleBarModule, imports: [[CommonModule]] });
135
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2SingleBarModule, decorators: [{
136
+ type: NgModule,
137
+ args: [{
138
+ imports: [CommonModule],
139
+ declarations: COMPONENTS,
140
+ exports: COMPONENTS
141
+ }]
142
+ }] });
143
+
144
+ /**
145
+ * Generated bundle index. Do not edit.
146
+ */
147
+
148
+ export { G2SingleBarComponent, G2SingleBarModule };
149
+ //# sourceMappingURL=single-bar.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"single-bar.mjs","sources":["../../../../packages/chart/single-bar/single-bar.component.ts","../../../../packages/chart/single-bar/single-bar.module.ts","../../../../packages/chart/single-bar/single-bar.ts"],"sourcesContent":["import { ChangeDetectionStrategy, Component, Input, SimpleChanges, ViewEncapsulation } from '@angular/core';\n\nimport type { Chart } from '@antv/g2';\n\nimport { G2BaseComponent } from '@delon/chart/core';\nimport { BooleanInput, InputBoolean, InputNumber, NumberInput } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\n@Component({\n selector: 'g2-single-bar',\n exportAs: 'g2SingleBar',\n template: ``,\n host: {\n '[style.height.px]': 'height'\n },\n preserveWhitespaces: false,\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None\n})\nexport class G2SingleBarComponent extends G2BaseComponent {\n static ngAcceptInputType_height: NumberInput;\n static ngAcceptInputType_barSize: NumberInput;\n static ngAcceptInputType_min: NumberInput;\n static ngAcceptInputType_max: NumberInput;\n static ngAcceptInputType_value: NumberInput;\n static ngAcceptInputType_line: BooleanInput;\n\n // #region fields\n\n @Input() plusColor = '#40a9ff';\n @Input() minusColor = '#ff4d4f';\n @Input() @InputNumber() height = 60;\n @Input() @InputNumber() barSize = 30;\n @Input() @InputNumber() min = 0;\n @Input() @InputNumber() max = 100;\n @Input() @InputNumber() value = 0;\n @Input() @InputBoolean() line = false;\n @Input() format?: (value: number, item: NzSafeAny, index: number) => string;\n @Input() padding: number | number[] | 'auto' = 0;\n @Input() textStyle: { [key: string]: NzSafeAny } = { fontSize: 12, color: '#595959' };\n\n // #endregion\n\n install(): void {\n const { el, height, padding, textStyle, line, format, theme, min, max, plusColor, minusColor, barSize } = this;\n const chart: Chart = (this._chart = new (window as NzSafeAny).G2.Chart({\n container: el.nativeElement,\n autoFit: true,\n height,\n padding,\n theme\n }));\n chart.legend(false);\n chart.axis(false);\n chart.scale({ value: { max, min } });\n chart.tooltip(false);\n chart.coordinate().transpose();\n chart\n .interval()\n .position('1*value')\n .color('value', (val: number) => (val > 0 ? plusColor : minusColor))\n .size(barSize)\n .label('value', () => ({\n formatter: format,\n style: {\n ...textStyle\n }\n }));\n\n if (line) {\n chart.annotation().line({\n start: ['50%', '0%'],\n end: ['50%', '100%'],\n style: {\n stroke: '#e8e8e8',\n lineDash: [0, 0]\n }\n });\n }\n\n this.changeData();\n\n chart.render();\n }\n\n onlyChangeData = (changes: SimpleChanges): boolean => {\n return Object.keys(changes).length === 1 && !!changes.value;\n };\n\n changeData(): void {\n const { _chart, value } = this;\n if (!_chart) return;\n _chart.changeData([{ value }]);\n }\n}\n","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\n\nimport { G2SingleBarComponent } from './single-bar.component';\n\nconst COMPONENTS = [G2SingleBarComponent];\n\n@NgModule({\n imports: [CommonModule],\n declarations: COMPONENTS,\n exports: COMPONENTS\n})\nexport class G2SingleBarModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,185 @@
1
+ import { __decorate } from 'tslib';
2
+ import * as i0 from '@angular/core';
3
+ import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, Output, NgModule } from '@angular/core';
4
+ import { fromEvent } from 'rxjs';
5
+ import { filter, debounceTime } from 'rxjs/operators';
6
+ import { G2BaseComponent } from '@delon/chart/core';
7
+ import { InputNumber } from '@delon/util/decorator';
8
+ import * as i1 from 'ng-zorro-antd/skeleton';
9
+ import { NzSkeletonModule } from 'ng-zorro-antd/skeleton';
10
+ import * as i2 from '@angular/common';
11
+ import { CommonModule } from '@angular/common';
12
+
13
+ class G2TagCloudComponent extends G2BaseComponent {
14
+ constructor() {
15
+ super(...arguments);
16
+ // #region fields
17
+ this.width = 0;
18
+ this.height = 200;
19
+ this.padding = 0;
20
+ this.data = [];
21
+ this.clickItem = new EventEmitter();
22
+ }
23
+ // #endregion
24
+ initTagCloud() {
25
+ window.G2.registerShape('point', 'cloud', {
26
+ draw(cfg, container) {
27
+ const data = cfg.data;
28
+ const textShape = container.addShape({
29
+ type: 'text',
30
+ name: 'tag-cloud-text',
31
+ attrs: {
32
+ ...cfg.style,
33
+ fontSize: data.size,
34
+ text: data.text,
35
+ textAlign: 'center',
36
+ fontFamily: data.font,
37
+ fill: cfg.color,
38
+ textBaseline: 'Alphabetic',
39
+ x: cfg.x,
40
+ y: cfg.y
41
+ }
42
+ });
43
+ if (data.rotate) {
44
+ window.G2.Util.rotate(textShape, (data.rotate * Math.PI) / 180);
45
+ }
46
+ return textShape;
47
+ }
48
+ });
49
+ }
50
+ install() {
51
+ this.initTagCloud();
52
+ const { el, padding, theme } = this;
53
+ if (this.height === 0) {
54
+ this.height = this.el.nativeElement.clientHeight;
55
+ }
56
+ if (this.width === 0) {
57
+ this.width = this.el.nativeElement.clientWidth;
58
+ }
59
+ const chart = (this._chart = new window.G2.Chart({
60
+ container: el.nativeElement,
61
+ autoFit: false,
62
+ padding,
63
+ height: this.height,
64
+ width: this.width,
65
+ theme
66
+ }));
67
+ chart.scale({
68
+ x: { nice: false },
69
+ y: { nice: false }
70
+ });
71
+ chart.legend(false);
72
+ chart.axis(false);
73
+ chart.tooltip({
74
+ showTitle: false,
75
+ showMarkers: false
76
+ });
77
+ chart.coordinate().reflect();
78
+ chart
79
+ .point()
80
+ .position('x*y')
81
+ .color('text')
82
+ .shape('cloud')
83
+ .state({
84
+ active: {
85
+ style: {
86
+ fillOpacity: 0.4
87
+ }
88
+ }
89
+ });
90
+ chart.interaction('element-active');
91
+ chart.on('tag-cloud-text:click', (ev) => {
92
+ this.ngZone.run(() => this.clickItem.emit({ item: ev.data?.data, ev }));
93
+ });
94
+ this.changeData();
95
+ chart.render();
96
+ }
97
+ changeData() {
98
+ const { _chart, data } = this;
99
+ if (!_chart || !Array.isArray(data) || data.length <= 0)
100
+ return;
101
+ const dv = new window.DataSet.View().source(data);
102
+ const range = dv.range('value');
103
+ const min = range[0];
104
+ const max = range[1];
105
+ dv.transform({
106
+ type: 'tag-cloud',
107
+ fields: ['name', 'value'],
108
+ // imageMask,
109
+ font: 'Verdana',
110
+ size: [this.width, this.height],
111
+ padding: 0,
112
+ timeInterval: 5000,
113
+ rotate() {
114
+ let random = ~~(Math.random() * 4) % 4;
115
+ if (random === 2) {
116
+ random = 0;
117
+ }
118
+ return random * 90; // 0, 90, 270
119
+ },
120
+ fontSize(d) {
121
+ return ((d.value - min) / (max - min)) * (32 - 8) + 8;
122
+ }
123
+ });
124
+ _chart.changeData(dv.rows);
125
+ }
126
+ installResizeEvent() {
127
+ this.resize$ = fromEvent(window, 'resize')
128
+ .pipe(filter(() => !!this._chart), debounceTime(200))
129
+ .subscribe(() => this.changeData());
130
+ }
131
+ onInit() {
132
+ this.installResizeEvent();
133
+ }
134
+ }
135
+ G2TagCloudComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TagCloudComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
136
+ G2TagCloudComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: G2TagCloudComponent, selector: "g2-tag-cloud", inputs: { width: "width", height: "height", padding: "padding", data: "data" }, outputs: { clickItem: "clickItem" }, exportAs: ["g2TagCloud"], usesInheritance: true, ngImport: i0, template: `<nz-skeleton *ngIf="!loaded"></nz-skeleton>`, isInline: true, components: [{ type: i1.NzSkeletonComponent, selector: "nz-skeleton", inputs: ["nzActive", "nzLoading", "nzRound", "nzTitle", "nzAvatar", "nzParagraph"], exportAs: ["nzSkeleton"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
137
+ __decorate([
138
+ InputNumber()
139
+ ], G2TagCloudComponent.prototype, "width", void 0);
140
+ __decorate([
141
+ InputNumber()
142
+ ], G2TagCloudComponent.prototype, "height", void 0);
143
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TagCloudComponent, decorators: [{
144
+ type: Component,
145
+ args: [{
146
+ selector: 'g2-tag-cloud',
147
+ exportAs: 'g2TagCloud',
148
+ template: `<nz-skeleton *ngIf="!loaded"></nz-skeleton>`,
149
+ preserveWhitespaces: false,
150
+ changeDetection: ChangeDetectionStrategy.OnPush,
151
+ encapsulation: ViewEncapsulation.None
152
+ }]
153
+ }], propDecorators: { width: [{
154
+ type: Input
155
+ }], height: [{
156
+ type: Input
157
+ }], padding: [{
158
+ type: Input
159
+ }], data: [{
160
+ type: Input
161
+ }], clickItem: [{
162
+ type: Output
163
+ }] } });
164
+
165
+ const COMPONENTS = [G2TagCloudComponent];
166
+ class G2TagCloudModule {
167
+ }
168
+ G2TagCloudModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TagCloudModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
169
+ G2TagCloudModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TagCloudModule, declarations: [G2TagCloudComponent], imports: [CommonModule, NzSkeletonModule], exports: [G2TagCloudComponent] });
170
+ G2TagCloudModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TagCloudModule, imports: [[CommonModule, NzSkeletonModule]] });
171
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TagCloudModule, decorators: [{
172
+ type: NgModule,
173
+ args: [{
174
+ imports: [CommonModule, NzSkeletonModule],
175
+ declarations: COMPONENTS,
176
+ exports: COMPONENTS
177
+ }]
178
+ }] });
179
+
180
+ /**
181
+ * Generated bundle index. Do not edit.
182
+ */
183
+
184
+ export { G2TagCloudComponent, G2TagCloudModule };
185
+ //# sourceMappingURL=tag-cloud.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tag-cloud.mjs","sources":["../../../../packages/chart/tag-cloud/tag-cloud.component.ts","../../../../packages/chart/tag-cloud/tag-cloud.module.ts","../../../../packages/chart/tag-cloud/tag-cloud.ts"],"sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\nimport { fromEvent } from 'rxjs';\nimport { debounceTime, filter } from 'rxjs/operators';\n\nimport type { Chart, Event } from '@antv/g2';\n\nimport { G2BaseComponent } from '@delon/chart/core';\nimport { InputNumber, NumberInput } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nexport interface G2TagCloudData {\n value?: number;\n name?: string;\n [key: string]: NzSafeAny;\n}\n\nexport interface G2TagCloudClickItem {\n item: G2TagCloudData;\n ev: Event;\n}\n\n@Component({\n selector: 'g2-tag-cloud',\n exportAs: 'g2TagCloud',\n template: `<nz-skeleton *ngIf=\"!loaded\"></nz-skeleton>`,\n preserveWhitespaces: false,\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None\n})\nexport class G2TagCloudComponent extends G2BaseComponent {\n static ngAcceptInputType_height: NumberInput;\n static ngAcceptInputType_width: NumberInput;\n\n // #region fields\n\n @Input() @InputNumber() width = 0;\n @Input() @InputNumber() height = 200;\n @Input() padding: number | number[] | 'auto' = 0;\n @Input() data: G2TagCloudData[] = [];\n @Output() readonly clickItem = new EventEmitter<G2TagCloudClickItem>();\n\n // #endregion\n\n private initTagCloud(): void {\n (window as NzSafeAny).G2.registerShape('point', 'cloud', {\n draw(cfg: NzSafeAny, container: NzSafeAny) {\n const data = cfg.data as NzSafeAny;\n const textShape = container.addShape({\n type: 'text',\n name: 'tag-cloud-text',\n attrs: {\n ...cfg.style,\n fontSize: data.size,\n text: data.text,\n textAlign: 'center',\n fontFamily: data.font,\n fill: cfg.color,\n textBaseline: 'Alphabetic',\n x: cfg.x,\n y: cfg.y\n } as NzSafeAny\n });\n if (data.rotate) {\n (window as NzSafeAny).G2.Util.rotate(textShape, (data.rotate * Math.PI) / 180);\n }\n return textShape;\n }\n });\n }\n\n install(): void {\n this.initTagCloud();\n\n const { el, padding, theme } = this;\n if (this.height === 0) {\n this.height = this.el.nativeElement.clientHeight;\n }\n if (this.width === 0) {\n this.width = this.el.nativeElement.clientWidth;\n }\n\n const chart: Chart = (this._chart = new (window as NzSafeAny).G2.Chart({\n container: el.nativeElement,\n autoFit: false,\n padding,\n height: this.height,\n width: this.width,\n theme\n }));\n chart.scale({\n x: { nice: false },\n y: { nice: false }\n });\n chart.legend(false);\n chart.axis(false);\n chart.tooltip({\n showTitle: false,\n showMarkers: false\n });\n (chart.coordinate() as NzSafeAny).reflect();\n chart\n .point()\n .position('x*y')\n .color('text')\n .shape('cloud')\n .state({\n active: {\n style: {\n fillOpacity: 0.4\n }\n }\n });\n chart.interaction('element-active');\n\n chart.on('tag-cloud-text:click', (ev: Event) => {\n this.ngZone.run(() => this.clickItem.emit({ item: ev.data?.data, ev }));\n });\n\n this.changeData();\n chart.render();\n }\n\n changeData(): void {\n const { _chart, data } = this;\n if (!_chart || !Array.isArray(data) || data.length <= 0) return;\n\n const dv = new (window as NzSafeAny).DataSet.View().source(data);\n const range = dv.range('value');\n const min = range[0];\n const max = range[1];\n\n dv.transform({\n type: 'tag-cloud',\n fields: ['name', 'value'],\n // imageMask,\n font: 'Verdana',\n size: [this.width, this.height], // 宽高设置最好根据 imageMask 做调整\n padding: 0,\n timeInterval: 5000, // max execute time\n rotate() {\n let random = ~~(Math.random() * 4) % 4;\n if (random === 2) {\n random = 0;\n }\n return random * 90; // 0, 90, 270\n },\n fontSize(d: NzSafeAny) {\n return ((d.value - min) / (max - min)) * (32 - 8) + 8;\n }\n } as NzSafeAny);\n\n _chart.changeData(dv.rows);\n }\n\n private installResizeEvent(): void {\n this.resize$ = fromEvent(window, 'resize')\n .pipe(\n filter(() => !!this._chart),\n debounceTime(200)\n )\n .subscribe(() => this.changeData());\n }\n\n onInit(): void {\n this.installResizeEvent();\n }\n}\n","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\n\nimport { NzSkeletonModule } from 'ng-zorro-antd/skeleton';\n\nimport { G2TagCloudComponent } from './tag-cloud.component';\n\nconst COMPONENTS = [G2TagCloudComponent];\n\n@NgModule({\n imports: [CommonModule, NzSkeletonModule],\n declarations: COMPONENTS,\n exports: COMPONENTS\n})\nexport class G2TagCloudModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,229 @@
1
+ import { __decorate } from 'tslib';
2
+ import * as i0 from '@angular/core';
3
+ import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, Output, NgModule } from '@angular/core';
4
+ import { format } from 'date-fns';
5
+ import { G2BaseComponent } from '@delon/chart/core';
6
+ import { toDate } from '@delon/util/date-time';
7
+ import { InputNumber, InputBoolean } from '@delon/util/decorator';
8
+ import * as i1 from 'ng-zorro-antd/skeleton';
9
+ import { NzSkeletonModule } from 'ng-zorro-antd/skeleton';
10
+ import * as i2 from 'ng-zorro-antd/core/outlet';
11
+ import { NzOutletModule } from 'ng-zorro-antd/core/outlet';
12
+ import * as i3 from '@angular/common';
13
+ import { CommonModule } from '@angular/common';
14
+
15
+ class G2TimelineComponent extends G2BaseComponent {
16
+ constructor() {
17
+ super(...arguments);
18
+ this.maxAxis = 2;
19
+ this.data = [];
20
+ this.colorMap = { y1: '#5B8FF9', y2: '#5AD8A6', y3: '#5D7092', y4: '#F6BD16', y5: '#E86452' };
21
+ this.mask = 'HH:mm';
22
+ this.maskSlider = 'HH:mm';
23
+ this.position = 'top';
24
+ this.height = 450;
25
+ this.padding = [40, 8, 64, 40];
26
+ this.borderWidth = 2;
27
+ this.slider = true;
28
+ this.clickItem = new EventEmitter();
29
+ // #endregion
30
+ this.onlyChangeData = (changes) => {
31
+ const tm = changes.titleMap;
32
+ return !(tm && !tm.firstChange && tm.currentValue !== tm.previousValue);
33
+ };
34
+ }
35
+ install() {
36
+ const { node, height, padding, slider, maxAxis, theme, maskSlider } = this;
37
+ const chart = (this._chart = new window.G2.Chart({
38
+ container: node.nativeElement,
39
+ autoFit: true,
40
+ height,
41
+ padding,
42
+ theme
43
+ }));
44
+ chart.axis('time', { title: null });
45
+ chart.axis('y1', { title: null });
46
+ for (let i = 2; i <= maxAxis; i++) {
47
+ chart.axis(`y${i}`, false);
48
+ }
49
+ chart.line().position('time*y1');
50
+ for (let i = 2; i <= maxAxis; i++) {
51
+ chart.line().position(`time*y${i}`);
52
+ }
53
+ chart.tooltip({
54
+ showCrosshairs: true,
55
+ shared: true
56
+ });
57
+ const sliderPadding = { ...[], ...padding };
58
+ sliderPadding[0] = 0;
59
+ if (slider) {
60
+ chart.option('slider', {
61
+ height: 26,
62
+ start: 0,
63
+ end: 1,
64
+ trendCfg: {
65
+ isArea: false
66
+ },
67
+ minLimit: 2,
68
+ formatter: (val) => format(val, maskSlider)
69
+ });
70
+ }
71
+ chart.on(`plot:click`, (ev) => {
72
+ const records = this._chart.getSnapRecords({ x: ev.x, y: ev.y });
73
+ this.ngZone.run(() => this.clickItem.emit({ item: records[0]._origin, ev }));
74
+ });
75
+ chart.on(`legend-item:click`, (ev) => {
76
+ const item = ev?.target?.get('delegateObject').item;
77
+ const id = item?.id;
78
+ const line = chart.geometries.find(w => w.getAttribute('position').getFields()[1] === id);
79
+ if (line) {
80
+ line.changeVisible(!item.unchecked);
81
+ }
82
+ });
83
+ this.changeData();
84
+ chart.render();
85
+ }
86
+ changeData() {
87
+ const { _chart, height, padding, mask, titleMap, position, colorMap, borderWidth, maxAxis } = this;
88
+ let data = [...this.data];
89
+ if (!_chart || data.length <= 0)
90
+ return;
91
+ const arrAxis = [...Array(maxAxis)].map((_, index) => index + 1);
92
+ _chart.legend({
93
+ position,
94
+ custom: true,
95
+ items: arrAxis.map(id => {
96
+ const key = `y${id}`;
97
+ return {
98
+ id: key,
99
+ name: titleMap[key],
100
+ value: key,
101
+ marker: { style: { fill: colorMap[key] } }
102
+ };
103
+ })
104
+ });
105
+ // border
106
+ _chart.geometries.forEach((v, idx) => {
107
+ v.color(colorMap[`y${idx + 1}`]).size(borderWidth);
108
+ });
109
+ _chart.height = height;
110
+ _chart.padding = padding;
111
+ // 转换成日期类型
112
+ data = data
113
+ .map(item => {
114
+ item.time = toDate(item.time);
115
+ item._time = +item.time;
116
+ return item;
117
+ })
118
+ .sort((a, b) => a._time - b._time);
119
+ const max = Math.max(...arrAxis.map(id => [...data].sort((a, b) => b[`y${id}`] - a[`y${id}`])[0][`y${id}`]));
120
+ const scaleOptions = {};
121
+ arrAxis.forEach(id => {
122
+ const key = `y${id}`;
123
+ scaleOptions[key] = {
124
+ alias: titleMap[key],
125
+ max,
126
+ min: 0
127
+ };
128
+ });
129
+ _chart.scale({
130
+ time: {
131
+ type: 'time',
132
+ mask,
133
+ range: [0, 1]
134
+ },
135
+ ...scaleOptions
136
+ });
137
+ const initialRange = {
138
+ start: data[0]._time,
139
+ end: data[data.length - 1]._time
140
+ };
141
+ const filterData = data.filter(val => val._time >= initialRange.start && val._time <= initialRange.end);
142
+ _chart.changeData(filterData);
143
+ }
144
+ }
145
+ G2TimelineComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TimelineComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
146
+ G2TimelineComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: G2TimelineComponent, selector: "g2-timeline", inputs: { title: "title", maxAxis: "maxAxis", data: "data", titleMap: "titleMap", colorMap: "colorMap", mask: "mask", maskSlider: "maskSlider", position: "position", height: "height", padding: "padding", borderWidth: "borderWidth", slider: "slider" }, outputs: { clickItem: "clickItem" }, exportAs: ["g2Timeline"], usesInheritance: true, ngImport: i0, template: `
147
+ <ng-container *nzStringTemplateOutlet="title">
148
+ <h4>{{ title }}</h4>
149
+ </ng-container>
150
+ <nz-skeleton *ngIf="!loaded"></nz-skeleton>
151
+ <div #container></div>
152
+ `, isInline: true, components: [{ type: i1.NzSkeletonComponent, selector: "nz-skeleton", inputs: ["nzActive", "nzLoading", "nzRound", "nzTitle", "nzAvatar", "nzParagraph"], exportAs: ["nzSkeleton"] }], directives: [{ type: i2.NzStringTemplateOutletDirective, selector: "[nzStringTemplateOutlet]", inputs: ["nzStringTemplateOutletContext", "nzStringTemplateOutlet"], exportAs: ["nzStringTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
153
+ __decorate([
154
+ InputNumber()
155
+ ], G2TimelineComponent.prototype, "maxAxis", void 0);
156
+ __decorate([
157
+ InputNumber()
158
+ ], G2TimelineComponent.prototype, "height", void 0);
159
+ __decorate([
160
+ InputNumber()
161
+ ], G2TimelineComponent.prototype, "borderWidth", void 0);
162
+ __decorate([
163
+ InputBoolean()
164
+ ], G2TimelineComponent.prototype, "slider", void 0);
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TimelineComponent, decorators: [{
166
+ type: Component,
167
+ args: [{
168
+ selector: 'g2-timeline',
169
+ exportAs: 'g2Timeline',
170
+ template: `
171
+ <ng-container *nzStringTemplateOutlet="title">
172
+ <h4>{{ title }}</h4>
173
+ </ng-container>
174
+ <nz-skeleton *ngIf="!loaded"></nz-skeleton>
175
+ <div #container></div>
176
+ `,
177
+ preserveWhitespaces: false,
178
+ changeDetection: ChangeDetectionStrategy.OnPush,
179
+ encapsulation: ViewEncapsulation.None
180
+ }]
181
+ }], propDecorators: { title: [{
182
+ type: Input
183
+ }], maxAxis: [{
184
+ type: Input
185
+ }], data: [{
186
+ type: Input
187
+ }], titleMap: [{
188
+ type: Input
189
+ }], colorMap: [{
190
+ type: Input
191
+ }], mask: [{
192
+ type: Input
193
+ }], maskSlider: [{
194
+ type: Input
195
+ }], position: [{
196
+ type: Input
197
+ }], height: [{
198
+ type: Input
199
+ }], padding: [{
200
+ type: Input
201
+ }], borderWidth: [{
202
+ type: Input
203
+ }], slider: [{
204
+ type: Input
205
+ }], clickItem: [{
206
+ type: Output
207
+ }] } });
208
+
209
+ const COMPONENTS = [G2TimelineComponent];
210
+ class G2TimelineModule {
211
+ }
212
+ G2TimelineModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TimelineModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
213
+ G2TimelineModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TimelineModule, declarations: [G2TimelineComponent], imports: [CommonModule, NzOutletModule, NzSkeletonModule], exports: [G2TimelineComponent] });
214
+ G2TimelineModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TimelineModule, imports: [[CommonModule, NzOutletModule, NzSkeletonModule]] });
215
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: G2TimelineModule, decorators: [{
216
+ type: NgModule,
217
+ args: [{
218
+ imports: [CommonModule, NzOutletModule, NzSkeletonModule],
219
+ declarations: COMPONENTS,
220
+ exports: COMPONENTS
221
+ }]
222
+ }] });
223
+
224
+ /**
225
+ * Generated bundle index. Do not edit.
226
+ */
227
+
228
+ export { G2TimelineComponent, G2TimelineModule };
229
+ //# sourceMappingURL=timeline.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timeline.mjs","sources":["../../../../packages/chart/timeline/timeline.component.ts","../../../../packages/chart/timeline/timeline.module.ts","../../../../packages/chart/timeline/timeline.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n EventEmitter,\n Input,\n Output,\n SimpleChanges,\n TemplateRef,\n ViewEncapsulation\n} from '@angular/core';\n\nimport type { Chart, Event, Types } from '@antv/g2';\nimport { format } from 'date-fns';\n\nimport { G2BaseComponent, G2Time } from '@delon/chart/core';\nimport { toDate } from '@delon/util/date-time';\nimport { BooleanInput, InputBoolean, InputNumber, NumberInput } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nexport interface G2TimelineData {\n /**\n * 时间值\n */\n time?: G2Time;\n /** 指标1数据 */\n y1: number;\n /** 指标2数据 */\n y2: number;\n /** 指标3数据 */\n y3?: number;\n /** 指标4数据 */\n y4?: number;\n /** 指标5数据 */\n y5?: number;\n [key: string]: NzSafeAny;\n}\n\nexport interface G2TimelineMap {\n /** 指标1 */\n y1: string;\n /** 指标 */\n y2: string;\n /** 指标3 */\n y3?: string;\n /** 指标4 */\n y4?: string;\n /** 指标5 */\n y5?: string;\n\n [key: string]: string | undefined;\n}\n\nexport interface G2TimelineClickItem {\n item: G2TimelineData;\n ev: Event;\n}\n\n@Component({\n selector: 'g2-timeline',\n exportAs: 'g2Timeline',\n template: `\n <ng-container *nzStringTemplateOutlet=\"title\">\n <h4>{{ title }}</h4>\n </ng-container>\n <nz-skeleton *ngIf=\"!loaded\"></nz-skeleton>\n <div #container></div>\n `,\n preserveWhitespaces: false,\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None\n})\nexport class G2TimelineComponent extends G2BaseComponent {\n static ngAcceptInputType_height: NumberInput;\n static ngAcceptInputType_maxAxis: NumberInput;\n static ngAcceptInputType_borderWidth: NumberInput;\n static ngAcceptInputType_slider: BooleanInput;\n\n // #region fields\n\n @Input() title?: string | TemplateRef<void> | null;\n @Input() @InputNumber() maxAxis = 2;\n @Input() data: G2TimelineData[] = [];\n @Input() titleMap?: G2TimelineMap | null;\n @Input() colorMap: G2TimelineMap = { y1: '#5B8FF9', y2: '#5AD8A6', y3: '#5D7092', y4: '#F6BD16', y5: '#E86452' };\n @Input() mask: string = 'HH:mm';\n @Input() maskSlider: string = 'HH:mm';\n @Input() position: 'top' | 'right' | 'bottom' | 'left' = 'top';\n @Input() @InputNumber() height = 450;\n @Input() padding: number[] = [40, 8, 64, 40];\n @Input() @InputNumber() borderWidth = 2;\n @Input() @InputBoolean() slider = true;\n @Output() readonly clickItem = new EventEmitter<G2TimelineClickItem>();\n\n // #endregion\n\n onlyChangeData = (changes: SimpleChanges): boolean => {\n const tm = changes.titleMap;\n return !(tm && !tm.firstChange && tm.currentValue !== tm.previousValue);\n };\n\n install(): void {\n const { node, height, padding, slider, maxAxis, theme, maskSlider } = this;\n const chart: Chart = (this._chart = new (window as NzSafeAny).G2.Chart({\n container: node.nativeElement,\n autoFit: true,\n height,\n padding,\n theme\n }));\n chart.axis('time', { title: null });\n chart.axis('y1', { title: null });\n for (let i = 2; i <= maxAxis; i++) {\n chart.axis(`y${i}`, false);\n }\n\n chart.line().position('time*y1');\n for (let i = 2; i <= maxAxis; i++) {\n chart.line().position(`time*y${i}`);\n }\n\n chart.tooltip({\n showCrosshairs: true,\n shared: true\n });\n\n const sliderPadding = { ...[], ...padding };\n sliderPadding[0] = 0;\n if (slider) {\n chart.option('slider', {\n height: 26,\n start: 0,\n end: 1,\n trendCfg: {\n isArea: false\n },\n minLimit: 2,\n formatter: (val: Date) => format(val, maskSlider)\n });\n }\n\n chart.on(`plot:click`, (ev: Event) => {\n const records = this._chart.getSnapRecords({ x: ev.x, y: ev.y });\n this.ngZone.run(() => this.clickItem.emit({ item: records[0]._origin, ev }));\n });\n\n chart.on(`legend-item:click`, (ev: Event) => {\n const item = ev?.target?.get('delegateObject').item;\n const id = item?.id;\n const line = chart.geometries.find(w => w.getAttribute('position').getFields()[1] === id);\n if (line) {\n line.changeVisible(!item.unchecked);\n }\n });\n\n this.changeData();\n\n chart.render();\n }\n\n changeData(): void {\n const { _chart, height, padding, mask, titleMap, position, colorMap, borderWidth, maxAxis } = this;\n let data = [...this.data];\n if (!_chart || data.length <= 0) return;\n\n const arrAxis = [...Array(maxAxis)].map((_, index) => index + 1);\n\n _chart.legend({\n position,\n custom: true,\n items: arrAxis.map(id => {\n const key = `y${id}`;\n return {\n id: key,\n name: titleMap![key],\n value: key,\n marker: { style: { fill: colorMap[key] } }\n } as Types.LegendItem;\n })\n });\n\n // border\n _chart.geometries.forEach((v, idx: number) => {\n v.color((colorMap as NzSafeAny)[`y${idx + 1}`]).size(borderWidth);\n });\n _chart.height = height;\n _chart.padding = padding;\n\n // 转换成日期类型\n data = data\n .map(item => {\n item.time = toDate(item.time!);\n item._time = +item.time;\n return item;\n })\n .sort((a, b) => a._time - b._time);\n\n const max = Math.max(...arrAxis.map(id => [...data].sort((a, b) => b[`y${id}`] - a[`y${id}`])[0][`y${id}`]));\n const scaleOptions: Record<string, Types.ScaleOption> = {};\n arrAxis.forEach(id => {\n const key = `y${id}`;\n scaleOptions[key] = {\n alias: titleMap![key],\n max,\n min: 0\n };\n });\n _chart.scale({\n time: {\n type: 'time',\n mask,\n range: [0, 1]\n },\n ...scaleOptions\n });\n\n const initialRange = {\n start: data[0]._time,\n end: data[data.length - 1]._time\n };\n const filterData = data.filter(val => val._time >= initialRange.start && val._time <= initialRange.end);\n _chart.changeData(filterData);\n }\n}\n","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\n\nimport { NzOutletModule } from 'ng-zorro-antd/core/outlet';\nimport { NzSkeletonModule } from 'ng-zorro-antd/skeleton';\n\nimport { G2TimelineComponent } from './timeline.component';\n\nconst COMPONENTS = [G2TimelineComponent];\n\n@NgModule({\n imports: [CommonModule, NzOutletModule, NzSkeletonModule],\n declarations: COMPONENTS,\n exports: COMPONENTS\n})\nexport class G2TimelineModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}