ngx-hana-nameserver-history-viewer 1.1.2 → 1.1.9-2.beta

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 (241) hide show
  1. package/README.md +6 -5
  2. package/esm2020/ngx-hana-nameserver-history-viewer.mjs +5 -0
  3. package/esm2020/public-api.mjs +2 -0
  4. package/esm2020/src/nameserver-history-viewer/components/alert/alert.component.mjs +68 -0
  5. package/esm2020/src/nameserver-history-viewer/components/alert/alert.module.mjs +22 -0
  6. package/esm2020/src/nameserver-history-viewer/components/alert/index.mjs +3 -0
  7. package/esm2020/src/nameserver-history-viewer/components/file-drop-input/file-drop-input.component.mjs +112 -0
  8. package/esm2020/src/nameserver-history-viewer/components/file-drop-input/index.mjs +2 -0
  9. package/esm2020/src/nameserver-history-viewer/components/index.mjs +9 -0
  10. package/esm2020/src/nameserver-history-viewer/components/instruction/index.mjs +2 -0
  11. package/esm2020/src/nameserver-history-viewer/components/instruction/instruction.component.mjs +42 -0
  12. package/esm2020/src/nameserver-history-viewer/components/nameserver-history.component.mjs +550 -0
  13. package/esm2020/src/nameserver-history-viewer/components/port-selector/index.mjs +2 -0
  14. package/esm2020/src/nameserver-history-viewer/components/port-selector/port-selector.component.mjs +69 -0
  15. package/esm2020/src/nameserver-history-viewer/components/port-selector/port-selector.service.mjs +41 -0
  16. package/esm2020/src/nameserver-history-viewer/components/progress-bar/index.mjs +2 -0
  17. package/esm2020/src/nameserver-history-viewer/components/progress-bar/progress-bar.component.mjs +40 -0
  18. package/esm2020/src/nameserver-history-viewer/components/time-range-selector/index.mjs +2 -0
  19. package/esm2020/src/nameserver-history-viewer/components/time-range-selector/time-range-selector.component.mjs +70 -0
  20. package/esm2020/src/nameserver-history-viewer/components/timezone-selector/index.mjs +2 -0
  21. package/esm2020/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.component.mjs +90 -0
  22. package/esm2020/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.service.mjs +49 -0
  23. package/esm2020/src/nameserver-history-viewer/index.mjs +3 -0
  24. package/esm2020/src/nameserver-history-viewer/nameserver-history.module.mjs +63 -0
  25. package/esm2020/src/nameserver-history-viewer/services/chart.service.mjs +323 -0
  26. package/esm2020/src/nameserver-history-viewer/services/file.service.mjs +390 -0
  27. package/esm2020/src/nameserver-history-viewer/services/index.mjs +4 -0
  28. package/esm2020/src/nameserver-history-viewer/services/ui.service.mjs +557 -0
  29. package/esm2020/src/nameserver-history-viewer/types/abort.types.mjs +6 -0
  30. package/esm2020/src/nameserver-history-viewer/types/alert.types.mjs +8 -0
  31. package/esm2020/src/nameserver-history-viewer/types/chart-content-data-item.types.mjs +2 -0
  32. package/esm2020/src/nameserver-history-viewer/types/chart-content-data.types.mjs +2 -0
  33. package/esm2020/src/nameserver-history-viewer/types/chart-content-header.types.mjs +2 -0
  34. package/esm2020/src/nameserver-history-viewer/types/chart-content-time.types.mjs +2 -0
  35. package/esm2020/src/nameserver-history-viewer/types/chart-content.types.mjs +2 -0
  36. package/esm2020/src/nameserver-history-viewer/types/color-rgba.types.mjs +2 -0
  37. package/esm2020/src/nameserver-history-viewer/types/html-element.type.mjs +9 -0
  38. package/esm2020/src/nameserver-history-viewer/types/index.mjs +28 -0
  39. package/esm2020/src/nameserver-history-viewer/types/item.types.mjs +14 -0
  40. package/esm2020/src/nameserver-history-viewer/types/legend-color.types.mjs +2 -0
  41. package/esm2020/src/nameserver-history-viewer/types/load-history-info-backup.types.mjs +2 -0
  42. package/esm2020/src/nameserver-history-viewer/types/load-history-info-columnstore.types.mjs +2 -0
  43. package/esm2020/src/nameserver-history-viewer/types/load-history-info-host.types.mjs +2 -0
  44. package/esm2020/src/nameserver-history-viewer/types/load-history-info-item.types.mjs +2 -0
  45. package/esm2020/src/nameserver-history-viewer/types/load-history-info-persistence.types.mjs +2 -0
  46. package/esm2020/src/nameserver-history-viewer/types/load-history-info-rowstore.types.mjs +2 -0
  47. package/esm2020/src/nameserver-history-viewer/types/load-history-info-server.types.mjs +2 -0
  48. package/esm2020/src/nameserver-history-viewer/types/load-history-info-session-admission-control.types.mjs +2 -0
  49. package/esm2020/src/nameserver-history-viewer/types/load-history-info-sql.types.mjs +2 -0
  50. package/esm2020/src/nameserver-history-viewer/types/load-history-info-sync-primitives.types.mjs +2 -0
  51. package/esm2020/src/nameserver-history-viewer/types/load-history-info-threads.types.mjs +2 -0
  52. package/esm2020/src/nameserver-history-viewer/types/load-history-info.types.mjs +2 -0
  53. package/esm2020/src/nameserver-history-viewer/types/port.types.mjs +2 -0
  54. package/esm2020/src/nameserver-history-viewer/types/scale-group.types.mjs +17 -0
  55. package/esm2020/src/nameserver-history-viewer/types/unit-category.types.mjs +10 -0
  56. package/esm2020/src/nameserver-history-viewer/types/unit.types.mjs +14 -0
  57. package/esm2020/src/nameserver-history-viewer/utils/chart-util.mjs +25 -0
  58. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/chartjs_ext.mjs +2 -0
  59. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/data_culling.mjs +57 -0
  60. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/data_mipmap.mjs +139 -0
  61. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/index.mjs +41 -0
  62. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/lttb_data_mipmap.mjs +106 -0
  63. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/responsive_downsample_plugin.mjs +168 -0
  64. package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/utils.mjs +114 -0
  65. package/esm2020/src/nameserver-history-viewer/utils/chartjs-zoom/chart.zoom.mjs +527 -0
  66. package/esm2020/src/nameserver-history-viewer/utils/chartjs-zoom/index.mjs +2 -0
  67. package/esm2020/src/nameserver-history-viewer/utils/file-util.mjs +154 -0
  68. package/esm2020/src/nameserver-history-viewer/utils/index.mjs +5 -0
  69. package/esm2020/src/nameserver-history-viewer/utils/time-util.mjs +101 -0
  70. package/esm2020/src/nameserver-history-viewer/utils/ui-util.mjs +162 -0
  71. package/fesm2015/{ngx-hana-nameserver-history-viewer.js → ngx-hana-nameserver-history-viewer.mjs} +971 -2679
  72. package/fesm2015/ngx-hana-nameserver-history-viewer.mjs.map +1 -0
  73. package/fesm2020/ngx-hana-nameserver-history-viewer.mjs +4081 -0
  74. package/fesm2020/ngx-hana-nameserver-history-viewer.mjs.map +1 -0
  75. package/ngx-hana-nameserver-history-viewer.d.ts +1 -1
  76. package/package.json +33 -57
  77. package/src/nameserver-history-viewer/components/alert/alert.component.d.ts +4 -1
  78. package/src/nameserver-history-viewer/components/alert/alert.module.d.ts +6 -0
  79. package/src/nameserver-history-viewer/components/file-drop-input/file-drop-input.component.d.ts +3 -0
  80. package/src/nameserver-history-viewer/components/instruction/instruction.component.d.ts +3 -0
  81. package/src/nameserver-history-viewer/components/nameserver-history.component.d.ts +33 -14
  82. package/src/nameserver-history-viewer/components/port-selector/port-selector.component.d.ts +4 -1
  83. package/src/nameserver-history-viewer/components/port-selector/port-selector.service.d.ts +3 -0
  84. package/src/nameserver-history-viewer/components/progress-bar/progress-bar.component.d.ts +3 -0
  85. package/src/nameserver-history-viewer/components/time-range-selector/time-range-selector.component.d.ts +3 -0
  86. package/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.component.d.ts +3 -0
  87. package/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.service.d.ts +3 -0
  88. package/src/nameserver-history-viewer/index.d.ts +1 -0
  89. package/src/nameserver-history-viewer/nameserver-history.module.d.ts +17 -0
  90. package/src/nameserver-history-viewer/services/chart.service.d.ts +4 -1
  91. package/src/nameserver-history-viewer/services/file.service.d.ts +4 -0
  92. package/src/nameserver-history-viewer/services/ui.service.d.ts +5 -2
  93. package/src/nameserver-history-viewer/utils/chartjs-downsample/lttb_data_mipmap.d.ts +1 -1
  94. package/src/nameserver-history-viewer/utils/file-util.d.ts +11 -0
  95. package/bundles/ngx-hana-nameserver-history-viewer.umd.js +0 -6735
  96. package/bundles/ngx-hana-nameserver-history-viewer.umd.js.map +0 -1
  97. package/bundles/ngx-hana-nameserver-history-viewer.umd.min.js +0 -2
  98. package/bundles/ngx-hana-nameserver-history-viewer.umd.min.js.map +0 -1
  99. package/esm2015/ngx-hana-nameserver-history-viewer.js +0 -10
  100. package/esm2015/public-api.js +0 -6
  101. package/esm2015/src/nameserver-history-viewer/components/alert/alert.component.js +0 -114
  102. package/esm2015/src/nameserver-history-viewer/components/alert/alert.module.js +0 -21
  103. package/esm2015/src/nameserver-history-viewer/components/alert/index.js +0 -7
  104. package/esm2015/src/nameserver-history-viewer/components/file-drop-input/file-drop-input.component.js +0 -141
  105. package/esm2015/src/nameserver-history-viewer/components/file-drop-input/index.js +0 -6
  106. package/esm2015/src/nameserver-history-viewer/components/index.js +0 -13
  107. package/esm2015/src/nameserver-history-viewer/components/instruction/index.js +0 -6
  108. package/esm2015/src/nameserver-history-viewer/components/instruction/instruction.component.js +0 -62
  109. package/esm2015/src/nameserver-history-viewer/components/nameserver-history.component.js +0 -868
  110. package/esm2015/src/nameserver-history-viewer/components/port-selector/index.js +0 -6
  111. package/esm2015/src/nameserver-history-viewer/components/port-selector/port-selector.component.js +0 -93
  112. package/esm2015/src/nameserver-history-viewer/components/port-selector/port-selector.service.js +0 -60
  113. package/esm2015/src/nameserver-history-viewer/components/progress-bar/index.js +0 -6
  114. package/esm2015/src/nameserver-history-viewer/components/progress-bar/progress-bar.component.js +0 -35
  115. package/esm2015/src/nameserver-history-viewer/components/time-range-selector/index.js +0 -6
  116. package/esm2015/src/nameserver-history-viewer/components/time-range-selector/time-range-selector.component.js +0 -68
  117. package/esm2015/src/nameserver-history-viewer/components/timezone-selector/index.js +0 -6
  118. package/esm2015/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.component.js +0 -151
  119. package/esm2015/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.service.js +0 -80
  120. package/esm2015/src/nameserver-history-viewer/index.js +0 -6
  121. package/esm2015/src/nameserver-history-viewer/nameserver-history.module.js +0 -42
  122. package/esm2015/src/nameserver-history-viewer/services/chart.service.js +0 -504
  123. package/esm2015/src/nameserver-history-viewer/services/file.service.js +0 -487
  124. package/esm2015/src/nameserver-history-viewer/services/index.js +0 -8
  125. package/esm2015/src/nameserver-history-viewer/services/ui.service.js +0 -922
  126. package/esm2015/src/nameserver-history-viewer/types/abort.types.js +0 -13
  127. package/esm2015/src/nameserver-history-viewer/types/alert.types.js +0 -13
  128. package/esm2015/src/nameserver-history-viewer/types/chart-content-data-item.types.js +0 -15
  129. package/esm2015/src/nameserver-history-viewer/types/chart-content-data.types.js +0 -9
  130. package/esm2015/src/nameserver-history-viewer/types/chart-content-header.types.js +0 -15
  131. package/esm2015/src/nameserver-history-viewer/types/chart-content-time.types.js +0 -9
  132. package/esm2015/src/nameserver-history-viewer/types/chart-content.types.js +0 -21
  133. package/esm2015/src/nameserver-history-viewer/types/color-rgba.types.js +0 -19
  134. package/esm2015/src/nameserver-history-viewer/types/html-element.type.js +0 -19
  135. package/esm2015/src/nameserver-history-viewer/types/index.js +0 -32
  136. package/esm2015/src/nameserver-history-viewer/types/item.types.js +0 -19
  137. package/esm2015/src/nameserver-history-viewer/types/legend-color.types.js +0 -9
  138. package/esm2015/src/nameserver-history-viewer/types/load-history-info-backup.types.js +0 -19
  139. package/esm2015/src/nameserver-history-viewer/types/load-history-info-columnstore.types.js +0 -19
  140. package/esm2015/src/nameserver-history-viewer/types/load-history-info-host.types.js +0 -35
  141. package/esm2015/src/nameserver-history-viewer/types/load-history-info-item.types.js +0 -31
  142. package/esm2015/src/nameserver-history-viewer/types/load-history-info-persistence.types.js +0 -27
  143. package/esm2015/src/nameserver-history-viewer/types/load-history-info-rowstore.types.js +0 -15
  144. package/esm2015/src/nameserver-history-viewer/types/load-history-info-server.types.js +0 -25
  145. package/esm2015/src/nameserver-history-viewer/types/load-history-info-session-admission-control.types.js +0 -25
  146. package/esm2015/src/nameserver-history-viewer/types/load-history-info-sql.types.js +0 -37
  147. package/esm2015/src/nameserver-history-viewer/types/load-history-info-sync-primitives.types.js +0 -15
  148. package/esm2015/src/nameserver-history-viewer/types/load-history-info-threads.types.js +0 -23
  149. package/esm2015/src/nameserver-history-viewer/types/load-history-info.types.js +0 -31
  150. package/esm2015/src/nameserver-history-viewer/types/port.types.js +0 -17
  151. package/esm2015/src/nameserver-history-viewer/types/scale-group.types.js +0 -35
  152. package/esm2015/src/nameserver-history-viewer/types/unit-category.types.js +0 -21
  153. package/esm2015/src/nameserver-history-viewer/types/unit.types.js +0 -19
  154. package/esm2015/src/nameserver-history-viewer/utils/chart-util.js +0 -38
  155. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/chartjs_ext.js +0 -100
  156. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/data_culling.js +0 -88
  157. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/data_mipmap.js +0 -222
  158. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/index.js +0 -46
  159. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/lttb_data_mipmap.js +0 -166
  160. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/responsive_downsample_plugin.js +0 -311
  161. package/esm2015/src/nameserver-history-viewer/utils/chartjs-downsample/utils.js +0 -130
  162. package/esm2015/src/nameserver-history-viewer/utils/chartjs-zoom/chart.zoom.js +0 -827
  163. package/esm2015/src/nameserver-history-viewer/utils/chartjs-zoom/index.js +0 -6
  164. package/esm2015/src/nameserver-history-viewer/utils/file-util.js +0 -162
  165. package/esm2015/src/nameserver-history-viewer/utils/index.js +0 -9
  166. package/esm2015/src/nameserver-history-viewer/utils/time-util.js +0 -139
  167. package/esm2015/src/nameserver-history-viewer/utils/ui-util.js +0 -239
  168. package/esm5/ngx-hana-nameserver-history-viewer.js +0 -10
  169. package/esm5/public-api.js +0 -6
  170. package/esm5/src/nameserver-history-viewer/components/alert/alert.component.js +0 -146
  171. package/esm5/src/nameserver-history-viewer/components/alert/alert.module.js +0 -25
  172. package/esm5/src/nameserver-history-viewer/components/alert/index.js +0 -7
  173. package/esm5/src/nameserver-history-viewer/components/file-drop-input/file-drop-input.component.js +0 -155
  174. package/esm5/src/nameserver-history-viewer/components/file-drop-input/index.js +0 -6
  175. package/esm5/src/nameserver-history-viewer/components/index.js +0 -13
  176. package/esm5/src/nameserver-history-viewer/components/instruction/index.js +0 -6
  177. package/esm5/src/nameserver-history-viewer/components/instruction/instruction.component.js +0 -67
  178. package/esm5/src/nameserver-history-viewer/components/nameserver-history.component.js +0 -1116
  179. package/esm5/src/nameserver-history-viewer/components/port-selector/index.js +0 -6
  180. package/esm5/src/nameserver-history-viewer/components/port-selector/port-selector.component.js +0 -93
  181. package/esm5/src/nameserver-history-viewer/components/port-selector/port-selector.service.js +0 -85
  182. package/esm5/src/nameserver-history-viewer/components/progress-bar/index.js +0 -6
  183. package/esm5/src/nameserver-history-viewer/components/progress-bar/progress-bar.component.js +0 -26
  184. package/esm5/src/nameserver-history-viewer/components/time-range-selector/index.js +0 -6
  185. package/esm5/src/nameserver-history-viewer/components/time-range-selector/time-range-selector.component.js +0 -58
  186. package/esm5/src/nameserver-history-viewer/components/timezone-selector/index.js +0 -6
  187. package/esm5/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.component.js +0 -180
  188. package/esm5/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.service.js +0 -110
  189. package/esm5/src/nameserver-history-viewer/index.js +0 -6
  190. package/esm5/src/nameserver-history-viewer/nameserver-history.module.js +0 -46
  191. package/esm5/src/nameserver-history-viewer/services/chart.service.js +0 -659
  192. package/esm5/src/nameserver-history-viewer/services/file.service.js +0 -606
  193. package/esm5/src/nameserver-history-viewer/services/index.js +0 -8
  194. package/esm5/src/nameserver-history-viewer/services/ui.service.js +0 -1141
  195. package/esm5/src/nameserver-history-viewer/types/abort.types.js +0 -13
  196. package/esm5/src/nameserver-history-viewer/types/alert.types.js +0 -13
  197. package/esm5/src/nameserver-history-viewer/types/chart-content-data-item.types.js +0 -15
  198. package/esm5/src/nameserver-history-viewer/types/chart-content-data.types.js +0 -9
  199. package/esm5/src/nameserver-history-viewer/types/chart-content-header.types.js +0 -15
  200. package/esm5/src/nameserver-history-viewer/types/chart-content-time.types.js +0 -9
  201. package/esm5/src/nameserver-history-viewer/types/chart-content.types.js +0 -21
  202. package/esm5/src/nameserver-history-viewer/types/color-rgba.types.js +0 -19
  203. package/esm5/src/nameserver-history-viewer/types/html-element.type.js +0 -19
  204. package/esm5/src/nameserver-history-viewer/types/index.js +0 -32
  205. package/esm5/src/nameserver-history-viewer/types/item.types.js +0 -19
  206. package/esm5/src/nameserver-history-viewer/types/legend-color.types.js +0 -9
  207. package/esm5/src/nameserver-history-viewer/types/load-history-info-backup.types.js +0 -19
  208. package/esm5/src/nameserver-history-viewer/types/load-history-info-columnstore.types.js +0 -19
  209. package/esm5/src/nameserver-history-viewer/types/load-history-info-host.types.js +0 -35
  210. package/esm5/src/nameserver-history-viewer/types/load-history-info-item.types.js +0 -31
  211. package/esm5/src/nameserver-history-viewer/types/load-history-info-persistence.types.js +0 -27
  212. package/esm5/src/nameserver-history-viewer/types/load-history-info-rowstore.types.js +0 -15
  213. package/esm5/src/nameserver-history-viewer/types/load-history-info-server.types.js +0 -25
  214. package/esm5/src/nameserver-history-viewer/types/load-history-info-session-admission-control.types.js +0 -25
  215. package/esm5/src/nameserver-history-viewer/types/load-history-info-sql.types.js +0 -37
  216. package/esm5/src/nameserver-history-viewer/types/load-history-info-sync-primitives.types.js +0 -15
  217. package/esm5/src/nameserver-history-viewer/types/load-history-info-threads.types.js +0 -23
  218. package/esm5/src/nameserver-history-viewer/types/load-history-info.types.js +0 -31
  219. package/esm5/src/nameserver-history-viewer/types/port.types.js +0 -17
  220. package/esm5/src/nameserver-history-viewer/types/scale-group.types.js +0 -35
  221. package/esm5/src/nameserver-history-viewer/types/unit-category.types.js +0 -21
  222. package/esm5/src/nameserver-history-viewer/types/unit.types.js +0 -19
  223. package/esm5/src/nameserver-history-viewer/utils/chart-util.js +0 -39
  224. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/chartjs_ext.js +0 -100
  225. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/data_culling.js +0 -88
  226. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/data_mipmap.js +0 -316
  227. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/index.js +0 -46
  228. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/lttb_data_mipmap.js +0 -240
  229. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/responsive_downsample_plugin.js +0 -366
  230. package/esm5/src/nameserver-history-viewer/utils/chartjs-downsample/utils.js +0 -142
  231. package/esm5/src/nameserver-history-viewer/utils/chartjs-zoom/chart.zoom.js +0 -827
  232. package/esm5/src/nameserver-history-viewer/utils/chartjs-zoom/index.js +0 -6
  233. package/esm5/src/nameserver-history-viewer/utils/file-util.js +0 -163
  234. package/esm5/src/nameserver-history-viewer/utils/index.js +0 -9
  235. package/esm5/src/nameserver-history-viewer/utils/time-util.js +0 -139
  236. package/esm5/src/nameserver-history-viewer/utils/ui-util.js +0 -241
  237. package/fesm2015/ngx-hana-nameserver-history-viewer.js.map +0 -1
  238. package/fesm5/ngx-hana-nameserver-history-viewer.js +0 -6861
  239. package/fesm5/ngx-hana-nameserver-history-viewer.js.map +0 -1
  240. package/ngx-hana-nameserver-history-viewer-1.1.2.tgz +0 -0
  241. package/ngx-hana-nameserver-history-viewer.metadata.json +0 -1
@@ -0,0 +1,550 @@
1
+ import { Component, ElementRef, Input, ViewChild } from '@angular/core';
2
+ import { SelectionModel } from '@angular/cdk/collections';
3
+ import { setChartHeight, sleep, isEmptyData, getDisplayPort, getFileFromInput, isSameFile, getAbbreviatedFileName, getFileFromDrop, getRealPorts, getTimeString, printProcessedTime, getTimeRangeString, generatePorts, getDefaultTimezone, blobToFile } from '../utils';
4
+ import { Abort, Alert, HtmlElement, Item } from '../types';
5
+ import { FileService, ChartService, UIService } from '../services';
6
+ import 'hammerjs';
7
+ import '../utils/chartjs-downsample';
8
+ import '../utils/chartjs-zoom';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../services";
11
+ import * as i2 from "./file-drop-input/file-drop-input.component";
12
+ import * as i3 from "./progress-bar/progress-bar.component";
13
+ import * as i4 from "./time-range-selector/time-range-selector.component";
14
+ import * as i5 from "./timezone-selector/timezone-selector.component";
15
+ import * as i6 from "./port-selector/port-selector.component";
16
+ import * as i7 from "./instruction/instruction.component";
17
+ import * as i8 from "ngx-selection-table";
18
+ import * as i9 from "./alert/alert.component";
19
+ import * as i10 from "@angular/common";
20
+ var SearchType;
21
+ (function (SearchType) {
22
+ SearchType["searchWithSubHeader"] = "searchWithSubHeader";
23
+ SearchType["searchAll"] = "searchAll";
24
+ SearchType["searchInChildren"] = "searchInChildren";
25
+ })(SearchType || (SearchType = {}));
26
+ export class NameServerHistoryComponent {
27
+ constructor(fileService, chartService, uiService) {
28
+ this.fileService = fileService;
29
+ this.chartService = chartService;
30
+ this.uiService = uiService;
31
+ /**
32
+ * Input (optional) bind to [showInstruction]
33
+ */
34
+ this.showInstruction = true;
35
+ /**
36
+ * time info of the name server history file
37
+ */
38
+ this.time = {};
39
+ /**
40
+ * data of the name server history file
41
+ */
42
+ this.data = {};
43
+ /**
44
+ * header of the name server history file
45
+ */
46
+ this.header = [];
47
+ /**
48
+ * host of the name server history file
49
+ */
50
+ this.host = 'nameserver history file';
51
+ /**
52
+ * the progress for reading file
53
+ */
54
+ this.readProgress = 0;
55
+ /**
56
+ * selected/dropped file name (abbreviation), full file name will be shown via the tooltips
57
+ */
58
+ this.abbreviatedFileName = 'or Drop File Here';
59
+ /**
60
+ * for the instruction step 4
61
+ */
62
+ this.stepShowChart = false;
63
+ this.searchType = SearchType.searchAll;
64
+ }
65
+ ngOnInit() {
66
+ // this.timezone = this.defaultTimezone;
67
+ this.onResize();
68
+ // init items' status
69
+ // reset chart button will be disable by default later, only be enabled after zoomed
70
+ this._toggleItems([
71
+ { id: HtmlElement.chartArea, status: false },
72
+ { id: HtmlElement.readFileProgress, status: false },
73
+ { id: HtmlElement.showChartButton, status: false },
74
+ { id: HtmlElement.loadPortsButton, status: true },
75
+ { id: HtmlElement.resetChartButton, status: false }
76
+ ]);
77
+ }
78
+ ngOnChanges(changes) {
79
+ const fbc = changes.fileBuffer;
80
+ if (fbc && fbc.currentValue && fbc.currentValue !== fbc.previousValue) {
81
+ // simulate selecting file
82
+ const simulatedEvent = { target: { files: [blobToFile(this.fileBuffer, this.streamModeFileName)] } };
83
+ this.fileSelected(simulatedEvent);
84
+ }
85
+ }
86
+ /**
87
+ * Reset Chart to initial status
88
+ * If legend is already selected/unselected from the list, it wouldn't be restored.
89
+ */
90
+ resetChart() {
91
+ this._toggleItems([{ id: HtmlElement.resetChartButton, status: false }]);
92
+ if (this.tableSource && this._selection) {
93
+ this.chartService.resetChart(this.tableSource, this._selection)
94
+ .catch(e => this._showMessage(Alert.error, e));
95
+ }
96
+ }
97
+ /**
98
+ * read the file and display the chart
99
+ */
100
+ showChart() {
101
+ // after click, this button and reset button needs to be disabled
102
+ this._toggleItems([
103
+ { id: HtmlElement.resetChartButton, status: false },
104
+ { id: HtmlElement.showChartButton, status: false }
105
+ ]);
106
+ this.stepShowChart = true;
107
+ this._initChartEnv().then(() => {
108
+ const selectedTime = this._selectedTimeRange;
109
+ if (selectedTime.startTime > selectedTime.endTime) {
110
+ this._showMessage(Alert.error, 'Time range is not correct.');
111
+ return;
112
+ }
113
+ if (this.file) {
114
+ // it's time for displaying the reading progress bar
115
+ this._toggleItems([{ id: HtmlElement.readFileProgress, status: true }]);
116
+ return this._buildChartFromDataFile(this.file, selectedTime.startTime, selectedTime.endTime, this.port);
117
+ }
118
+ }).catch(e => {
119
+ this._showMessage(Alert.error, e);
120
+ this._toggleItems([{ id: HtmlElement.readFileProgress, status: false }]);
121
+ });
122
+ }
123
+ /**
124
+ * load all ports from file
125
+ */
126
+ loadPorts() {
127
+ // do confirmation actions
128
+ if (this.file) {
129
+ // before start loading ports from file, display progress bar and disable the show chart button
130
+ this._toggleItems([
131
+ { id: HtmlElement.readFileProgress, status: true },
132
+ { id: HtmlElement.showChartButton, status: false }
133
+ ]);
134
+ this._readPortsFromFile(this.file);
135
+ }
136
+ }
137
+ /**
138
+ * select name server history file, currently only supports 1 file.
139
+ */
140
+ fileSelected(event) {
141
+ const selectedFile = getFileFromInput(event.target);
142
+ if (selectedFile) {
143
+ if (!isSameFile(this.file, selectedFile)) {
144
+ // init port selector
145
+ this._initPortSelector().catch(e => this._showMessage(Alert.error, e));
146
+ this.file = selectedFile;
147
+ this.abbreviatedFileName = getAbbreviatedFileName(this.file.name);
148
+ // after file has been selected, the show chart button needs to be enabled
149
+ this._toggleItems([{ id: HtmlElement.showChartButton, status: true }]);
150
+ }
151
+ }
152
+ }
153
+ /**
154
+ * drop name server history file, currently only supports 1 file.
155
+ */
156
+ fileDropped(event) {
157
+ getFileFromDrop(event)
158
+ .then(file => {
159
+ if (!isSameFile(this.file, file)) {
160
+ // init port selector
161
+ this.file = file;
162
+ if (this.file) {
163
+ this.abbreviatedFileName = getAbbreviatedFileName(this.file.name);
164
+ // after file has been dropped, the show chart button needs to be enabled
165
+ this._toggleItems([{ id: HtmlElement.showChartButton, status: true }]);
166
+ }
167
+ }
168
+ })
169
+ .then(() => {
170
+ return this._initPortSelector();
171
+ })
172
+ .catch(e => this._showMessage(Alert.error, e));
173
+ }
174
+ /**
175
+ * Select one item from selection table, relative dataset will be shown or hidden
176
+ */
177
+ selectItem(event) {
178
+ if (event && event.tableRow) {
179
+ const row = event.tableRow;
180
+ this._selection.toggle(row);
181
+ this.chartService.toggleDataInChart(row.KPI, !this._selection.isSelected(row))
182
+ .catch(e => this._showMessage(Alert.error, e));
183
+ }
184
+ }
185
+ /**
186
+ * recalculating chart height when resizing
187
+ */
188
+ onResize() {
189
+ const nameserverHistoryAllElement = this.nameserverHistoryAllRef ? this.nameserverHistoryAllRef.nativeElement : null;
190
+ const nameserverHistoryContentElement = this.nameserverHistoryContentRef ? this.nameserverHistoryContentRef.nativeElement : null;
191
+ setChartHeight(nameserverHistoryAllElement, nameserverHistoryContentElement);
192
+ }
193
+ /**
194
+ * Switch port and reinitialize chart, triggered by changing the port
195
+ * @param port the selected port
196
+ */
197
+ switchPortForChart(port) {
198
+ if (port === this._currentChartPort) {
199
+ // not to switch port, because the relative port is displaying, no need to render twice.
200
+ return;
201
+ }
202
+ if (!this.file || !port || port.length === 0 || port.slice(1, 3) === '**') {
203
+ return;
204
+ }
205
+ else if (Object.keys(this.time).length > 1 && !getRealPorts(Object.keys(this.time).filter(key => this.time[key])).includes(port)) {
206
+ this._showMessage(Alert.info, `Data of port:${port} is not loaded, please load the data first by clicking the "Show" button.`);
207
+ return;
208
+ }
209
+ // only do switch ports when available ports number > 1
210
+ if (Object.keys(this.time).filter(key => this.time[key]).length > 1) {
211
+ // disable the "show chart" and "reset chart" button first
212
+ this._toggleItems([
213
+ { id: HtmlElement.showChartButton, status: false },
214
+ { id: HtmlElement.resetChartButton, status: false }
215
+ ]);
216
+ // init the environment with switch flag
217
+ this._initChartEnv(true).then(() => {
218
+ return this._buildChart(port, null, true);
219
+ }).catch(e => this._showMessage(Alert.error, e));
220
+ }
221
+ }
222
+ /**
223
+ * get the columns which need to be hidden from the selection table
224
+ */
225
+ get hiddenColumns() {
226
+ return this.uiService.getHiddenColumns(this.hideMeasureColumns);
227
+ }
228
+ /**
229
+ * get default timezone
230
+ */
231
+ get defaultTimezone() {
232
+ return getDefaultTimezone();
233
+ }
234
+ /**
235
+ * get the key column (KPI)
236
+ */
237
+ get kpiColumn() {
238
+ return Item.kpi;
239
+ }
240
+ /**
241
+ * get the key column (KPI)
242
+ */
243
+ get descColumn() {
244
+ return Item.description;
245
+ }
246
+ /**
247
+ * get the selected time range, set second and millisecond part to 0
248
+ */
249
+ get _selectedTimeRange() {
250
+ let startTime = 0;
251
+ let endTime = 4102358400000; // 2099/12/31
252
+ if (this.dateTimeRange != null) {
253
+ if (this.dateTimeRange.length >= 1) {
254
+ // get start time
255
+ if (this.dateTimeRange[0]) {
256
+ startTime = this.dateTimeRange[0].setSeconds(0, 0);
257
+ }
258
+ if (this.dateTimeRange[1]) {
259
+ endTime = this.dateTimeRange[1].setSeconds(0, 0);
260
+ }
261
+ }
262
+ }
263
+ return { startTime: startTime, endTime: endTime };
264
+ }
265
+ /**
266
+ * get the time range string, eg: 2018-10-25 10:25 ~ 2018-10-26 10:26
267
+ */
268
+ get _selectedTimeRangeString() {
269
+ const selectedTimeRangeString = this._selectedTimeRange;
270
+ return `${getTimeString(selectedTimeRangeString.startTime)} ~ ${getTimeString(selectedTimeRangeString.endTime)}`;
271
+ }
272
+ /**
273
+ * get array of header key
274
+ */
275
+ get _headerKey() {
276
+ if (this.header) {
277
+ return this.header.map(headerItem => headerItem.key);
278
+ }
279
+ }
280
+ /**
281
+ * get array of header text
282
+ */
283
+ get _headerText() {
284
+ return this.header.map(headerItem => headerItem.text);
285
+ }
286
+ /**
287
+ * read ports from the selected nameserver history file
288
+ * @param file nameserver history file
289
+ */
290
+ _readPortsFromFile(file) {
291
+ this.fileService.getPortsFromFile(file, (progress) => {
292
+ this.readProgress = progress;
293
+ }).then(ports => {
294
+ return sleep(100).then(() => {
295
+ return this._initPortSelector(ports);
296
+ });
297
+ }).catch(e => this._showMessage(Alert.error, e));
298
+ }
299
+ /**
300
+ * build chart from the selected nameserver history file
301
+ * @param file the nameserver history file
302
+ * @param startTime start time
303
+ * @param endTime end time
304
+ * @param selectedPort selected port for nameserver history file (MDC system)
305
+ */
306
+ _buildChartFromDataFile(file, startTime, endTime, selectedPort) {
307
+ return this.fileService.getChartContentFromFile(file, startTime, endTime, selectedPort, this.timezone, this.maxRowsLimitation, progress => this.readProgress = progress)
308
+ .then(result => {
309
+ // parsing done
310
+ const beginTime = new Date();
311
+ const promises = [];
312
+ const ports = getRealPorts(Object.keys(result.time), true);
313
+ ports.forEach(port => {
314
+ // convert the unit and generate controlling data for all ports
315
+ promises.push(this.uiService.convertUnitAndGenerateControlData(result.data[port], result.header, port));
316
+ });
317
+ return Promise.all(promises)
318
+ .then(() => {
319
+ // get all ports from the analyzed data(time)
320
+ // get the port that will be shown in the page
321
+ const port = getDisplayPort(ports, selectedPort);
322
+ printProcessedTime(beginTime, 'converting step');
323
+ ports.forEach(portItem => this.uiService.generateYScale(portItem));
324
+ printProcessedTime(beginTime, 'generating YScale step');
325
+ this.data = result.data;
326
+ this.time = result.time;
327
+ this.header = this.uiService.getHeader(result.header, port);
328
+ this.host = result.host;
329
+ if (result.aborted === Abort.maxLineNumReached) {
330
+ this._showMessage(Alert.warning, `Maximum number of lines reached. Processed time range is: ${getTimeRangeString(this.time)}.`);
331
+ }
332
+ else {
333
+ if (isEmptyData(this.data)) {
334
+ this._showMessage(Alert.info, `Cannot find any data for the selected time period: ${this._selectedTimeRangeString}`);
335
+ }
336
+ else {
337
+ this._showMessage(Alert.success, `Processed time range is: ${getTimeRangeString(this.time)}.`);
338
+ }
339
+ }
340
+ return sleep(100).then(() => {
341
+ return this._buildChart(port, ports);
342
+ });
343
+ });
344
+ });
345
+ }
346
+ /**
347
+ * reinitialize the port selector with the ports
348
+ */
349
+ _initPortSelector(ports = null, selectedPort = null) {
350
+ return new Promise(resolve => {
351
+ // initialization for ngx-select
352
+ if (ports != null && ports.length > 1) {
353
+ // MDC, remove default '0000' port
354
+ this.ports = generatePorts(getRealPorts(ports), selectedPort);
355
+ }
356
+ else {
357
+ this.ports = generatePorts(ports);
358
+ }
359
+ if (ports != null && selectedPort === null) {
360
+ // reset status when doing:
361
+ // 1. loading ports
362
+ // 2. the file doesn't contain the selected Port
363
+ this.readProgress = 0;
364
+ // hide the progress bar and enable the "show chart" button
365
+ this._toggleItems([
366
+ { id: HtmlElement.readFileProgress, status: false },
367
+ { id: HtmlElement.showChartButton, status: true }
368
+ ]);
369
+ }
370
+ resolve();
371
+ });
372
+ }
373
+ /**
374
+ * build and display the chart on page
375
+ * @param port the selected port
376
+ * @param ports all available ports
377
+ * @param switchFlag indicates whether this function is triggered from switching ports (no init port selector needed)
378
+ */
379
+ _buildChart(port, ports, switchFlag = false) {
380
+ const beginTime = new Date();
381
+ if (port) {
382
+ return Promise.resolve(this._loadSettingsForSelectionsTable(port))
383
+ .then(() => {
384
+ // get the config
385
+ return this.chartService.buildChart(this.time[port], this.data[port], this.uiService.getYScale(this._headerKey, port), this._headerText, this._headerKey, this._selection, this.tableSource, this._getHostTitle(port), this.uiService.getDisplayItems(this._headerKey, port, this.defaultSelectedItems), this._onZoom.bind(this))
386
+ .then(() => {
387
+ this.readProgress = 0;
388
+ // after chart has been created, show the chart area, hide progress bar and enable the "show chart" button
389
+ this._toggleItems([
390
+ { id: HtmlElement.chartArea, status: true },
391
+ { id: HtmlElement.readFileProgress, status: false },
392
+ { id: HtmlElement.showChartButton, status: true }
393
+ ]);
394
+ // set port to current displaying port
395
+ this._currentChartPort = port;
396
+ printProcessedTime(beginTime, 'step_build_chart');
397
+ if (ports && ports.length > 0) {
398
+ if (!switchFlag) {
399
+ // initialize port selector. Do not need to do it when switching port.
400
+ return this._initPortSelector(ports, port);
401
+ }
402
+ }
403
+ });
404
+ });
405
+ }
406
+ else {
407
+ if (ports.length > 0) {
408
+ this._showMessage(Alert.warning, 'The selected port does not exist in the name server history file. Please choose a correct port and have a try again.');
409
+ if (!switchFlag) {
410
+ // initialize port selector. Do not need to do it when switching port.
411
+ return this._initPortSelector(ports, port);
412
+ }
413
+ }
414
+ }
415
+ }
416
+ /**
417
+ * get the string that will be displayed on the title area of the chart
418
+ * eg: host1 - 30040 (2018-09-05 15:32:32 ~ 2018-09-07 15:32:15)
419
+ * @param port selected port
420
+ */
421
+ _getHostTitle(port) {
422
+ if (this.host) {
423
+ return `${this.host} - ${port} ( ${getTimeRangeString(this.time[port])} )`;
424
+ }
425
+ }
426
+ /**
427
+ * after zoom, enable the reset button.
428
+ */
429
+ _onZoom() {
430
+ this._toggleItems([{ id: HtmlElement.resetChartButton, status: true }]);
431
+ }
432
+ /**
433
+ * initialize chart, including: destroy current chart, initialize config, initialize all relative data
434
+ */
435
+ _initChartEnv(switchFlag = false) {
436
+ return this.chartService.destroyChart().then(() => {
437
+ {
438
+ // cleanup other data
439
+ this._toggleItems([{ id: HtmlElement.chartArea, status: false }]);
440
+ if (!switchFlag) {
441
+ Object.keys(this.time).forEach(key => {
442
+ if (this.time[key]) {
443
+ this.time[key].length = 0;
444
+ }
445
+ });
446
+ this.time = {};
447
+ Object.keys(this.data).forEach(key => {
448
+ if (this.data[key]) {
449
+ this.data[key].length = 0;
450
+ }
451
+ });
452
+ this.data = {};
453
+ this.header.length = 0;
454
+ this.host = 'nameserver history file';
455
+ this.tableSource = void 0;
456
+ this.readProgress = 0;
457
+ this.uiService.clearLoadHistoryInfos();
458
+ }
459
+ }
460
+ });
461
+ }
462
+ /**
463
+ * Load settings for the selection table (the right part of the chart)
464
+ * @param port the selected port
465
+ */
466
+ _loadSettingsForSelectionsTable(port) {
467
+ this.tableSource = this.uiService.getSelectionTableRows(this._headerKey, port, this.defaultSelectedItems);
468
+ this._selection = new SelectionModel(true, []);
469
+ this.tableSource.forEach(row => {
470
+ if (this.uiService.getDisplayItems(this._headerKey, port, this.defaultSelectedItems).includes(row.KPI)) {
471
+ this._selection.select(row);
472
+ }
473
+ });
474
+ }
475
+ /**
476
+ * Show messages
477
+ * @param type type of the message
478
+ * @param message message text
479
+ */
480
+ _showMessage(type, message) {
481
+ if (type) {
482
+ switch (type) {
483
+ case Alert.success:
484
+ case Alert.info:
485
+ break;
486
+ case Alert.warning:
487
+ console.warn(message);
488
+ break;
489
+ case Alert.error:
490
+ console.error(message);
491
+ }
492
+ }
493
+ if (this.alertMessage === message) {
494
+ // try trigger the change event of the alert.
495
+ this.alertMessage = void 0;
496
+ setTimeout(() => this.alertMessage = message, 100);
497
+ }
498
+ else {
499
+ this.alertMessage = message;
500
+ }
501
+ this.alertType = type;
502
+ }
503
+ /**
504
+ * toggle items with the provided status (show or hide the relative element on the page)
505
+ * @param items items with the relative id and status.
506
+ */
507
+ _toggleItems(items) {
508
+ const getVariableNameByTypeId = (id) => {
509
+ switch (id) {
510
+ case HtmlElement.chartArea: return 'showChartFlag';
511
+ case HtmlElement.readFileProgress: return 'showReadFileProgress';
512
+ case HtmlElement.showChartButton: return 'enableShowChartButton';
513
+ case HtmlElement.loadPortsButton: return 'enableLoadPortsButton';
514
+ case HtmlElement.resetChartButton: return 'enableResetChartButton';
515
+ }
516
+ };
517
+ if (items) {
518
+ items.forEach(item => {
519
+ this[getVariableNameByTypeId(item.id)] = item.status;
520
+ });
521
+ }
522
+ }
523
+ }
524
+ NameServerHistoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NameServerHistoryComponent, deps: [{ token: i1.FileService }, { token: i1.ChartService }, { token: i1.UIService }], target: i0.ɵɵFactoryTarget.Component });
525
+ NameServerHistoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: NameServerHistoryComponent, selector: "ngx-hana-nameserver-history-viewer", inputs: { defaultSelectedItems: "defaultSelectedItems", hideMeasureColumns: "hideMeasureColumns", maxRowsLimitation: "maxRowsLimitation", showInstruction: "showInstruction", timezone: "timezone", fileBuffer: "fileBuffer", streamModeFileName: "streamModeFileName" }, providers: [FileService, ChartService, UIService], viewQueries: [{ propertyName: "nameserverHistoryAllRef", first: true, predicate: ["nameserverHistoryAll"], descendants: true, read: ElementRef }, { propertyName: "nameserverHistoryContentRef", first: true, predicate: ["nameserverHistoryContent"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<div #nameserverHistoryAll class=\"nameserver-history-all\" (window:resize)=\"onResize()\">\r\n <div class=\"toolbar-chart\">\r\n <div class=\"upload-box-content\">\r\n <div *ngIf=\"!showReadFileProgress\">\r\n <file-drop-input (fileDrop)=\"fileDropped($event)\" (fileInput)=\"fileSelected($event)\"\r\n [dropAreaText]= \"abbreviatedFileName\"\r\n [inputAreaText]=\"'Browse'\"\r\n [title]=\"file?.name? file.name:'Select a name server history file from your local disk.'\"\r\n *ngIf=\"!fileBuffer\">\r\n </file-drop-input>\r\n <p *ngIf=\"fileBuffer\">{{streamModeFileName || 'nameserver_history.trc (stream mode)'}}</p>\r\n </div>\r\n <div *ngIf=\"showReadFileProgress\">\r\n <progress-bar [progress]=\"readProgress\"></progress-bar>\r\n </div>\r\n </div>\r\n <div class=\"input-time\">\r\n <div class=\"input-time-range\">\r\n <time-range-selector [disabled]=\"showReadFileProgress\" [(dateTimeRange)]=\"dateTimeRange\"></time-range-selector>\r\n </div>\r\n <div class=\"timezone-selector\">\r\n <timezone-selector [(timezone)]=\"timezone\" [disabled]=\"showReadFileProgress\"></timezone-selector>\r\n </div>\r\n </div>\r\n\r\n <div class=\"port-selection\">\r\n <div class=\"port-selector\">\r\n <port-selector (portChange)=\"switchPortForChart($event)\" [(port)]=\"port\" [ports]=\"ports\" [disabled]=\"showReadFileProgress\"></port-selector>\r\n </div>\r\n <div class=\"port-load-button\">\r\n <button (click)=\"loadPorts()\" title=\"Load all ports from name server history trace file.\" [disabled]=\"!enableShowChartButton || port || !enableLoadPortsButton\">{{showReadFileProgress? \"Loading...\" : \"Load\"}}</button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"chart-operation\">\r\n <div class=\"left\">\r\n <button (click)=\"showChart()\" title=\"Load and display all data from name server history trace file.\" [disabled]=\"!enableShowChartButton\">{{showReadFileProgress? \"Loading...\" : \"Show\"}}</button>\r\n </div>\r\n <div class=\"right\">\r\n <button (click)=\"resetChart()\" title=\"Reset zoom of chart.\" [disabled]=\"showReadFileProgress || !enableResetChartButton\">Reset Chart</button>\r\n </div>\r\n </div>\r\n </div>\r\n <div #nameserverHistoryContent class=\"nameserver-history-content\">\r\n <div class=\"nameserver-history-content-chart\">\r\n <instruction [(show)]=\"showInstruction\" *ngIf=\"!showChartFlag && showInstruction\"\r\n [step1Finished]=\"!!file\"\r\n [step2Finished]=\"dateTimeRange && (!!dateTimeRange[0] || !!dateTimeRange[1]) || timezone != defaultTimezone\"\r\n [step3Finished]=\"!!port\"\r\n [step4Finished]=\"stepShowChart && !enableShowChartButton\"\r\n [step5Finished]=\"false\">\r\n </instruction>\r\n <canvas id=\"chartNameServerHistory\" ></canvas>\r\n </div>\r\n <div class=\"nameserver-history-content-controller\" >\r\n <ngx-selection-table (change)=\"selectItem($event)\" *ngIf=\"showChartFlag\"\r\n [filter]=\"true\"\r\n [checkbox]=\"true\"\r\n [tableSource]=\"tableSource\"\r\n [keyColumn]=\"kpiColumn\"\r\n [hiddenColumns]=\"hiddenColumns\"\r\n [tooltipColumn]=\"descColumn\"\r\n [searchStyle]=\"searchType\"\r\n [searchColumn]=\"kpiColumn\"\r\n [multiSelection]=\"true\">\r\n </ngx-selection-table>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"message-container\" *ngIf=\"alertMessage\">\r\n <alert [(alertMessage)]=\"alertMessage\" [alertType]=\"alertType\" [alertTimeout]=\"30000\"></alert>\r\n</div>\r\n", styles: [":host *,:host *:before,:host *:after{box-sizing:inherit;display:inherit;font-size:inherit;font-weight:inherit;font-family:inherit}:host .hover-box,:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button:hover{outline:0;box-shadow:0 0 6px #23adff}:host .dashed-box,:host .nameserver-history-all .toolbar-chart .chart-operation button,:host .nameserver-history-all .toolbar-chart .port-selection,:host .nameserver-history-all .toolbar-chart .input-time,:host .nameserver-history-all .toolbar-chart .upload-box-content{background:#f8f8f8;box-shadow:inset 0 20px 20px -20px #0009;border:1px dashed #0782d0}:host .solid-box,:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button{background:#fff none;border:1px solid #ccc;border-radius:4px;line-height:1.42857143}:host .nameserver-history-all{width:98%;min-width:1314px;height:auto;border:1px none #0782d0;border-bottom-style:dashed;margin:3px 1%;box-sizing:border-box;display:inline-block;font-size:14px;font-weight:400;font-family:Helvetica,Arial,sans-serif}:host .nameserver-history-all .toolbar-chart{width:100%;height:48px}:host .nameserver-history-all .toolbar-chart button{text-align:center;white-space:nowrap;vertical-align:middle}:host .nameserver-history-all .toolbar-chart button:hover{text-shadow:1px 1px 3px royalblue;cursor:pointer;font-weight:600}:host .nameserver-history-all .toolbar-chart button:disabled{text-shadow:none;opacity:.65;cursor:default;color:#a9a9a9;font-weight:400}:host .nameserver-history-all .toolbar-chart .upload-box-content{width:20%;height:100%;float:left;text-align:center;color:#00008b}:host .nameserver-history-all .toolbar-chart .input-time{margin-left:1%;margin-right:1%;width:43%;height:100%}:host .nameserver-history-all .toolbar-chart .input-time .input-time-range{height:100%;width:57%;float:left}:host .nameserver-history-all .toolbar-chart .input-time .timezone-selector{margin-top:6px;height:100%;width:42.5%;margin-right:.5%;float:right}:host .nameserver-history-all .toolbar-chart .port-selection{width:14%;margin-right:1%;height:48px}:host .nameserver-history-all .toolbar-chart .port-selection .port-selector{margin-top:6px;margin-left:2%;margin-right:1%;width:47%;float:left}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button{margin-top:6px;margin-left:1%;margin-right:2%;width:47%;float:right}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button{color:#333;width:100%;padding:6px 12px;margin-bottom:0}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button:hover{text-shadow:None;font-weight:400}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button:disabled{box-shadow:none}:host .nameserver-history-all .toolbar-chart .chart-operation{width:20%;height:48px;float:right}:host .nameserver-history-all .toolbar-chart .chart-operation .left{margin-right:1%;width:49%;height:100%;float:left}:host .nameserver-history-all .toolbar-chart .chart-operation .right{width:50%;height:100%;float:right}:host .nameserver-history-all .toolbar-chart .chart-operation button{width:100%;height:100%;color:#00008b}:host .nameserver-history-all .nameserver-history-content{width:100%;height:730px;margin:5px 5px 5px 0}:host .nameserver-history-all .nameserver-history-content .nameserver-history-content-chart{width:75%;height:100%;position:relative;float:left}:host .nameserver-history-all .nameserver-history-content .nameserver-history-content-controller{width:25%;height:100%;float:right;overflow:auto}:host .message-container{width:98%;margin:0 1%;box-sizing:border-box;display:inline-block}\n"], components: [{ type: i2.FileDropInputComponent, selector: "file-drop-input", inputs: ["dropAreaText", "inputAreaText"], outputs: ["fileDrop", "fileInput"] }, { type: i3.ProgressBarComponent, selector: "progress-bar", inputs: ["progress"] }, { type: i4.TimeRangeSelectorComponent, selector: "time-range-selector", inputs: ["disabled", "dateTimeRange"], outputs: ["dateTimeRangeChange"] }, { type: i5.TimezoneSelectorComponent, selector: "timezone-selector", inputs: ["disabled", "timezone"], outputs: ["timezoneChange"] }, { type: i6.PortSelectorComponent, selector: "port-selector", inputs: ["disabled", "port", "ports"], outputs: ["portChange"] }, { type: i7.InstructionComponent, selector: "instruction", inputs: ["step1Finished", "step2Finished", "step3Finished", "step4Finished", "step5Finished", "show"], outputs: ["showChange"] }, { type: i8.SelectionTableComponent, selector: "ngx-selection-table", inputs: ["filter", "keyColumn", "tableSource", "checkbox", "multiSelection", "clickToSelect", "hiddenColumns", "tooltipColumn", "searchStyle", "searchColumn"], outputs: ["change"] }, { type: i9.AlertComponent, selector: "alert", inputs: ["alertMessage", "alertType", "alertTimeout"], outputs: ["alertMessageChange"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
526
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NameServerHistoryComponent, decorators: [{
527
+ type: Component,
528
+ args: [{ selector: 'ngx-hana-nameserver-history-viewer', providers: [FileService, ChartService, UIService], template: "<div #nameserverHistoryAll class=\"nameserver-history-all\" (window:resize)=\"onResize()\">\r\n <div class=\"toolbar-chart\">\r\n <div class=\"upload-box-content\">\r\n <div *ngIf=\"!showReadFileProgress\">\r\n <file-drop-input (fileDrop)=\"fileDropped($event)\" (fileInput)=\"fileSelected($event)\"\r\n [dropAreaText]= \"abbreviatedFileName\"\r\n [inputAreaText]=\"'Browse'\"\r\n [title]=\"file?.name? file.name:'Select a name server history file from your local disk.'\"\r\n *ngIf=\"!fileBuffer\">\r\n </file-drop-input>\r\n <p *ngIf=\"fileBuffer\">{{streamModeFileName || 'nameserver_history.trc (stream mode)'}}</p>\r\n </div>\r\n <div *ngIf=\"showReadFileProgress\">\r\n <progress-bar [progress]=\"readProgress\"></progress-bar>\r\n </div>\r\n </div>\r\n <div class=\"input-time\">\r\n <div class=\"input-time-range\">\r\n <time-range-selector [disabled]=\"showReadFileProgress\" [(dateTimeRange)]=\"dateTimeRange\"></time-range-selector>\r\n </div>\r\n <div class=\"timezone-selector\">\r\n <timezone-selector [(timezone)]=\"timezone\" [disabled]=\"showReadFileProgress\"></timezone-selector>\r\n </div>\r\n </div>\r\n\r\n <div class=\"port-selection\">\r\n <div class=\"port-selector\">\r\n <port-selector (portChange)=\"switchPortForChart($event)\" [(port)]=\"port\" [ports]=\"ports\" [disabled]=\"showReadFileProgress\"></port-selector>\r\n </div>\r\n <div class=\"port-load-button\">\r\n <button (click)=\"loadPorts()\" title=\"Load all ports from name server history trace file.\" [disabled]=\"!enableShowChartButton || port || !enableLoadPortsButton\">{{showReadFileProgress? \"Loading...\" : \"Load\"}}</button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"chart-operation\">\r\n <div class=\"left\">\r\n <button (click)=\"showChart()\" title=\"Load and display all data from name server history trace file.\" [disabled]=\"!enableShowChartButton\">{{showReadFileProgress? \"Loading...\" : \"Show\"}}</button>\r\n </div>\r\n <div class=\"right\">\r\n <button (click)=\"resetChart()\" title=\"Reset zoom of chart.\" [disabled]=\"showReadFileProgress || !enableResetChartButton\">Reset Chart</button>\r\n </div>\r\n </div>\r\n </div>\r\n <div #nameserverHistoryContent class=\"nameserver-history-content\">\r\n <div class=\"nameserver-history-content-chart\">\r\n <instruction [(show)]=\"showInstruction\" *ngIf=\"!showChartFlag && showInstruction\"\r\n [step1Finished]=\"!!file\"\r\n [step2Finished]=\"dateTimeRange && (!!dateTimeRange[0] || !!dateTimeRange[1]) || timezone != defaultTimezone\"\r\n [step3Finished]=\"!!port\"\r\n [step4Finished]=\"stepShowChart && !enableShowChartButton\"\r\n [step5Finished]=\"false\">\r\n </instruction>\r\n <canvas id=\"chartNameServerHistory\" ></canvas>\r\n </div>\r\n <div class=\"nameserver-history-content-controller\" >\r\n <ngx-selection-table (change)=\"selectItem($event)\" *ngIf=\"showChartFlag\"\r\n [filter]=\"true\"\r\n [checkbox]=\"true\"\r\n [tableSource]=\"tableSource\"\r\n [keyColumn]=\"kpiColumn\"\r\n [hiddenColumns]=\"hiddenColumns\"\r\n [tooltipColumn]=\"descColumn\"\r\n [searchStyle]=\"searchType\"\r\n [searchColumn]=\"kpiColumn\"\r\n [multiSelection]=\"true\">\r\n </ngx-selection-table>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"message-container\" *ngIf=\"alertMessage\">\r\n <alert [(alertMessage)]=\"alertMessage\" [alertType]=\"alertType\" [alertTimeout]=\"30000\"></alert>\r\n</div>\r\n", styles: [":host *,:host *:before,:host *:after{box-sizing:inherit;display:inherit;font-size:inherit;font-weight:inherit;font-family:inherit}:host .hover-box,:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button:hover{outline:0;box-shadow:0 0 6px #23adff}:host .dashed-box,:host .nameserver-history-all .toolbar-chart .chart-operation button,:host .nameserver-history-all .toolbar-chart .port-selection,:host .nameserver-history-all .toolbar-chart .input-time,:host .nameserver-history-all .toolbar-chart .upload-box-content{background:#f8f8f8;box-shadow:inset 0 20px 20px -20px #0009;border:1px dashed #0782d0}:host .solid-box,:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button{background:#fff none;border:1px solid #ccc;border-radius:4px;line-height:1.42857143}:host .nameserver-history-all{width:98%;min-width:1314px;height:auto;border:1px none #0782d0;border-bottom-style:dashed;margin:3px 1%;box-sizing:border-box;display:inline-block;font-size:14px;font-weight:400;font-family:Helvetica,Arial,sans-serif}:host .nameserver-history-all .toolbar-chart{width:100%;height:48px}:host .nameserver-history-all .toolbar-chart button{text-align:center;white-space:nowrap;vertical-align:middle}:host .nameserver-history-all .toolbar-chart button:hover{text-shadow:1px 1px 3px royalblue;cursor:pointer;font-weight:600}:host .nameserver-history-all .toolbar-chart button:disabled{text-shadow:none;opacity:.65;cursor:default;color:#a9a9a9;font-weight:400}:host .nameserver-history-all .toolbar-chart .upload-box-content{width:20%;height:100%;float:left;text-align:center;color:#00008b}:host .nameserver-history-all .toolbar-chart .input-time{margin-left:1%;margin-right:1%;width:43%;height:100%}:host .nameserver-history-all .toolbar-chart .input-time .input-time-range{height:100%;width:57%;float:left}:host .nameserver-history-all .toolbar-chart .input-time .timezone-selector{margin-top:6px;height:100%;width:42.5%;margin-right:.5%;float:right}:host .nameserver-history-all .toolbar-chart .port-selection{width:14%;margin-right:1%;height:48px}:host .nameserver-history-all .toolbar-chart .port-selection .port-selector{margin-top:6px;margin-left:2%;margin-right:1%;width:47%;float:left}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button{margin-top:6px;margin-left:1%;margin-right:2%;width:47%;float:right}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button{color:#333;width:100%;padding:6px 12px;margin-bottom:0}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button:hover{text-shadow:None;font-weight:400}:host .nameserver-history-all .toolbar-chart .port-selection .port-load-button button:disabled{box-shadow:none}:host .nameserver-history-all .toolbar-chart .chart-operation{width:20%;height:48px;float:right}:host .nameserver-history-all .toolbar-chart .chart-operation .left{margin-right:1%;width:49%;height:100%;float:left}:host .nameserver-history-all .toolbar-chart .chart-operation .right{width:50%;height:100%;float:right}:host .nameserver-history-all .toolbar-chart .chart-operation button{width:100%;height:100%;color:#00008b}:host .nameserver-history-all .nameserver-history-content{width:100%;height:730px;margin:5px 5px 5px 0}:host .nameserver-history-all .nameserver-history-content .nameserver-history-content-chart{width:75%;height:100%;position:relative;float:left}:host .nameserver-history-all .nameserver-history-content .nameserver-history-content-controller{width:25%;height:100%;float:right;overflow:auto}:host .message-container{width:98%;margin:0 1%;box-sizing:border-box;display:inline-block}\n"] }]
529
+ }], ctorParameters: function () { return [{ type: i1.FileService }, { type: i1.ChartService }, { type: i1.UIService }]; }, propDecorators: { nameserverHistoryAllRef: [{
530
+ type: ViewChild,
531
+ args: ['nameserverHistoryAll', { read: ElementRef }]
532
+ }], nameserverHistoryContentRef: [{
533
+ type: ViewChild,
534
+ args: ['nameserverHistoryContent', { read: ElementRef }]
535
+ }], defaultSelectedItems: [{
536
+ type: Input
537
+ }], hideMeasureColumns: [{
538
+ type: Input
539
+ }], maxRowsLimitation: [{
540
+ type: Input
541
+ }], showInstruction: [{
542
+ type: Input
543
+ }], timezone: [{
544
+ type: Input
545
+ }], fileBuffer: [{
546
+ type: Input
547
+ }], streamModeFileName: [{
548
+ type: Input
549
+ }] } });
550
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nameserver-history.component.js","sourceRoot":"","sources":["../../../../../src/nameserver-history-viewer/components/nameserver-history.component.ts","../../../../../src/nameserver-history-viewer/components/nameserver-history.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, OnChanges, OnInit, SimpleChanges, ViewChild} from '@angular/core';\r\nimport { SelectionModel } from '@angular/cdk/collections';\r\nimport {\r\n  setChartHeight,\r\n  sleep,\r\n  isEmptyData,\r\n  getDisplayPort,\r\n  getFileFromInput,\r\n  isSameFile,\r\n  getAbbreviatedFileName,\r\n  getFileFromDrop,\r\n  getRealPorts,\r\n  getTimeString,\r\n  printProcessedTime,\r\n  getTimeRangeString,\r\n  generatePorts,\r\n  getDefaultTimezone,\r\n  blobToFile\r\n} from '../utils';\r\nimport { Abort, Alert, HtmlElement, Item, ChartContentData, ChartContentHeader, ChartContentTime, Port } from '../types';\r\nimport { FileService, ChartService, UIService } from '../services';\r\n\r\nimport 'hammerjs';\r\nimport '../utils/chartjs-downsample';\r\nimport '../utils/chartjs-zoom';\r\n\r\nenum SearchType {\r\n  searchWithSubHeader = 'searchWithSubHeader',\r\n  searchAll = 'searchAll',\r\n  searchInChildren = 'searchInChildren'\r\n}\r\n\r\n@Component({\r\n  selector: 'ngx-hana-nameserver-history-viewer',\r\n  templateUrl: './nameserver-history.component.html',\r\n  styleUrls: [ './nameserver-history.component.scss' ],\r\n  providers: [ FileService, ChartService, UIService ]\r\n})\r\nexport class NameServerHistoryComponent implements OnChanges, OnInit {\r\n  @ViewChild('nameserverHistoryAll', { read: ElementRef }) nameserverHistoryAllRef: ElementRef;\r\n  @ViewChild('nameserverHistoryContent', { read: ElementRef }) nameserverHistoryContentRef: ElementRef;\r\n\r\n  /**\r\n   * Input (optional) bind to [defaultSelectedItems]\r\n   */\r\n  @Input() defaultSelectedItems: string[];\r\n\r\n  /**\r\n   * Input (optional) bind to [hideMeasureColumns]\r\n   */\r\n  @Input() hideMeasureColumns: string[];\r\n\r\n  /**\r\n   * Input (optional) bind to [maxRowsLimitation]\r\n   */\r\n  @Input() maxRowsLimitation: number;\r\n\r\n  /**\r\n   * Input (optional) bind to [showInstruction]\r\n   */\r\n  @Input() showInstruction = true;\r\n\r\n  /**\r\n   * Input (optional) bind to [timezone]\r\n   */\r\n  @Input() timezone: string;\r\n\r\n  /**\r\n   * file buffer, use this for stream mode\r\n   */\r\n  @Input() fileBuffer: Blob;\r\n\r\n  /**\r\n   * file name for stream mode\r\n   */\r\n  @Input() streamModeFileName: string;\r\n\r\n\r\n  /**\r\n   * selected name server history file\r\n   */\r\n  file: File;\r\n\r\n  /**\r\n   * time info of the name server history file\r\n   */\r\n  time: ChartContentTime = {};\r\n\r\n  /**\r\n   * data of the name server history file\r\n   */\r\n  data: ChartContentData = {};\r\n\r\n  /**\r\n   * header of the name server history file\r\n   */\r\n  header: ChartContentHeader[] = [];\r\n\r\n  /**\r\n   * host of the name server history file\r\n   */\r\n  host = 'nameserver history file';\r\n\r\n  /**\r\n   * alert message content\r\n   */\r\n  alertMessage: string;\r\n\r\n  /**\r\n   * alert message type\r\n   */\r\n  alertType: Alert;\r\n\r\n  /**\r\n   * selected port\r\n   */\r\n  port: string;\r\n\r\n  /**\r\n   * all the ports from the nameserver history file\r\n   */\r\n  ports: Port[];\r\n\r\n  /**\r\n   * selected time range\r\n   */\r\n  dateTimeRange: Date[];\r\n\r\n  /**\r\n   * data source for the selection table (right part of the chart)\r\n   */\r\n  tableSource: any[];\r\n\r\n  /**\r\n   * the progress for reading file\r\n   */\r\n  readProgress = 0;\r\n\r\n  /**\r\n   * selected/dropped file name (abbreviation), full file name will be shown via the tooltips\r\n   */\r\n  abbreviatedFileName = 'or Drop File Here';\r\n\r\n  /**\r\n   * for the instruction step 4\r\n   */\r\n  stepShowChart = false;\r\n\r\n  /**\r\n   * control flag for showing the name server history chart\r\n   */\r\n  showChartFlag: boolean;\r\n\r\n  /**\r\n   * control flag for showing the file reading progress\r\n   */\r\n  showReadFileProgress: boolean;\r\n\r\n  /**\r\n   * control flag for \"Load\" ports button\r\n   */\r\n  enableLoadPortsButton: boolean;\r\n\r\n  /**\r\n   * control flag for enabling \"Show\" chart button\r\n   */\r\n  enableShowChartButton: boolean;\r\n\r\n  /**\r\n   * control flag for \"Reset\" chart button\r\n   */\r\n  enableResetChartButton: boolean;\r\n\r\n  searchType = SearchType.searchAll;\r\n\r\n  /**\r\n   * selection information for the selection table\r\n   */\r\n  private _selection: SelectionModel<any>;\r\n\r\n  /**\r\n   * current displaying port\r\n   */\r\n  private _currentChartPort: string;\r\n\r\n  constructor(private fileService: FileService,\r\n              private chartService: ChartService,\r\n              private uiService: UIService) {}\r\n\r\n  ngOnInit() {\r\n    // this.timezone = this.defaultTimezone;\r\n    this.onResize();\r\n\r\n    // init items' status\r\n    // reset chart button will be disable by default later, only be enabled after zoomed\r\n    this._toggleItems([\r\n      {id: HtmlElement.chartArea, status: false},\r\n      {id: HtmlElement.readFileProgress, status: false},\r\n      {id: HtmlElement.showChartButton, status: false},\r\n      {id: HtmlElement.loadPortsButton, status: true},\r\n      {id: HtmlElement.resetChartButton, status: false}]);\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const fbc = changes.fileBuffer;\r\n    if (fbc && fbc.currentValue && fbc.currentValue !== fbc.previousValue) {\r\n      // simulate selecting file\r\n      const simulatedEvent = {target: {files: [blobToFile(this.fileBuffer, this.streamModeFileName)]}};\r\n      this.fileSelected(simulatedEvent);\r\n    }\r\n  }\r\n\r\n    /**\r\n   * Reset Chart to initial status\r\n   * If legend is already selected/unselected from the list, it wouldn't be restored.\r\n   */\r\n  resetChart(): void {\r\n    this._toggleItems([{id: HtmlElement.resetChartButton, status: false}]);\r\n\r\n    if (this.tableSource && this._selection) {\r\n      this.chartService.resetChart(this.tableSource, this._selection)\r\n        .catch(e => this._showMessage(Alert.error, e));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * read the file and display the chart\r\n   */\r\n  showChart(): void {\r\n    // after click, this button and reset button needs to be disabled\r\n    this._toggleItems([\r\n      {id: HtmlElement.resetChartButton, status: false},\r\n      {id: HtmlElement.showChartButton, status: false}]);\r\n\r\n    this.stepShowChart = true;\r\n\r\n    this._initChartEnv().then(() => {\r\n      const selectedTime = this._selectedTimeRange;\r\n      if (selectedTime.startTime > selectedTime.endTime) {\r\n        this._showMessage(Alert.error, 'Time range is not correct.');\r\n        return;\r\n      }\r\n      if (this.file) {\r\n        // it's time for displaying the reading progress bar\r\n        this._toggleItems([{id: HtmlElement.readFileProgress, status: true}]);\r\n        return this._buildChartFromDataFile(this.file, selectedTime.startTime, selectedTime.endTime, this.port);\r\n      }\r\n    }).catch(e => {\r\n      this._showMessage(Alert.error, e);\r\n      this._toggleItems([{id: HtmlElement.readFileProgress, status: false}]);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * load all ports from file\r\n   */\r\n  loadPorts(): void {\r\n    // do confirmation actions\r\n    if (this.file) {\r\n      // before start loading ports from file, display progress bar and disable the show chart button\r\n      this._toggleItems([\r\n        {id: HtmlElement.readFileProgress, status: true},\r\n        {id: HtmlElement.showChartButton, status: false}\r\n      ]);\r\n      this._readPortsFromFile(this.file);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * select name server history file, currently only supports 1 file.\r\n   */\r\n  fileSelected(event: any) {\r\n    const selectedFile = getFileFromInput(event.target);\r\n    if (selectedFile) {\r\n      if (!isSameFile(this.file, selectedFile)) {\r\n        // init port selector\r\n        this._initPortSelector().catch(e => this._showMessage(Alert.error, e));\r\n\r\n        this.file = selectedFile;\r\n        this.abbreviatedFileName = getAbbreviatedFileName(this.file.name);\r\n        // after file has been selected, the show chart button needs to be enabled\r\n        this._toggleItems([{id: HtmlElement.showChartButton, status: true}]);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * drop name server history file, currently only supports 1 file.\r\n   */\r\n  fileDropped(event: any) {\r\n    getFileFromDrop(event)\r\n      .then(file => {\r\n        if (!isSameFile(this.file, file)) {\r\n          // init port selector\r\n          this.file = file;\r\n          if (this.file) {\r\n            this.abbreviatedFileName = getAbbreviatedFileName(this.file.name);\r\n            // after file has been dropped, the show chart button needs to be enabled\r\n            this._toggleItems([{id: HtmlElement.showChartButton, status: true}]);\r\n          }\r\n        }})\r\n      .then(() =>  {\r\n        return this._initPortSelector();\r\n      })\r\n      .catch(e => this._showMessage(Alert.error, e));\r\n  }\r\n\r\n  /**\r\n   * Select one item from selection table, relative dataset will be shown or hidden\r\n   */\r\n  selectItem(event: any) {\r\n    if (event && event.tableRow) {\r\n      const row = event.tableRow;\r\n      this._selection.toggle(row);\r\n      this.chartService.toggleDataInChart(row.KPI, !this._selection.isSelected(row))\r\n        .catch(e => this._showMessage(Alert.error, e));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * recalculating chart height when resizing\r\n   */\r\n  onResize() {\r\n    const nameserverHistoryAllElement = this.nameserverHistoryAllRef ? this.nameserverHistoryAllRef.nativeElement : null;\r\n    const nameserverHistoryContentElement = this.nameserverHistoryContentRef ? this.nameserverHistoryContentRef.nativeElement : null;\r\n    setChartHeight(nameserverHistoryAllElement, nameserverHistoryContentElement);\r\n  }\r\n\r\n  /**\r\n   * Switch port and reinitialize chart, triggered by changing the port\r\n   * @param port the selected port\r\n   */\r\n  switchPortForChart(port: string): void {\r\n    if (port === this._currentChartPort) {\r\n      // not to switch port, because the relative port is displaying, no need to render twice.\r\n      return;\r\n    }\r\n    if (!this.file || !port || port.length === 0 || port.slice(1, 3) === '**') {\r\n      return;\r\n    } else if (Object.keys(this.time).length > 1 && !getRealPorts(Object.keys(this.time).filter(key => this.time[key])).includes(port)) {\r\n      this._showMessage(Alert.info, `Data of port:${port} is not loaded, please load the data first by clicking the \"Show\" button.`);\r\n      return;\r\n    }\r\n\r\n    // only do switch ports when available ports number > 1\r\n    if (Object.keys(this.time).filter(key => this.time[key]).length > 1) {\r\n      // disable the \"show chart\" and \"reset chart\" button first\r\n      this._toggleItems([\r\n        {id: HtmlElement.showChartButton, status: false},\r\n        {id: HtmlElement.resetChartButton, status: false}]);\r\n      // init the environment with switch flag\r\n      this._initChartEnv(true).then(() => {\r\n        return this._buildChart(port, null, true);\r\n      }).catch(e => this._showMessage(Alert.error, e));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * get the columns which need to be hidden from the selection table\r\n   */\r\n  get hiddenColumns(): string[] {\r\n    return this.uiService.getHiddenColumns(this.hideMeasureColumns);\r\n  }\r\n\r\n  /**\r\n   * get default timezone\r\n   */\r\n  get defaultTimezone(): string {\r\n    return getDefaultTimezone();\r\n  }\r\n\r\n  /**\r\n   * get the key column (KPI)\r\n   */\r\n  get kpiColumn(): Item {\r\n    return Item.kpi;\r\n  }\r\n\r\n  /**\r\n   * get the key column (KPI)\r\n   */\r\n  get descColumn(): Item {\r\n    return Item.description;\r\n  }\r\n\r\n  /**\r\n   * get the selected time range, set second and millisecond part to 0\r\n   */\r\n  private get _selectedTimeRange(): {startTime: number, endTime: number} {\r\n    let startTime = 0;\r\n    let endTime = 4102358400000; // 2099/12/31\r\n    if (this.dateTimeRange != null) {\r\n      if (this.dateTimeRange.length >= 1) {\r\n        // get start time\r\n        if (this.dateTimeRange[0]) {\r\n          startTime = this.dateTimeRange[0].setSeconds(0, 0);\r\n        }\r\n        if (this.dateTimeRange[1]) {\r\n          endTime = this.dateTimeRange[1].setSeconds(0, 0);\r\n        }\r\n      }\r\n    }\r\n    return {startTime: startTime, endTime: endTime};\r\n  }\r\n\r\n  /**\r\n   * get the time range string, eg: 2018-10-25 10:25 ~ 2018-10-26 10:26\r\n   */\r\n  private get _selectedTimeRangeString(): string {\r\n    const selectedTimeRangeString = this._selectedTimeRange;\r\n    return `${getTimeString(selectedTimeRangeString.startTime)} ~ ${getTimeString(selectedTimeRangeString.endTime)}`;\r\n  }\r\n\r\n  /**\r\n   * get array of header key\r\n   */\r\n  private get _headerKey(): string[] {\r\n    if (this.header) {\r\n      return this.header.map(headerItem => headerItem.key);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * get array of header text\r\n   */\r\n  private get _headerText(): string[] {\r\n    return this.header.map(headerItem => headerItem.text);\r\n  }\r\n\r\n  /**\r\n   * read ports from the selected nameserver history file\r\n   * @param file nameserver history file\r\n   */\r\n  private _readPortsFromFile(file: File): void {\r\n    this.fileService.getPortsFromFile(file, (progress) => {\r\n      this.readProgress = progress;\r\n    }).then(ports => {\r\n      return sleep(100).then(() => {\r\n        return this._initPortSelector(ports);\r\n      });\r\n    }).catch(e => this._showMessage(Alert.error, e));\r\n  }\r\n\r\n  /**\r\n   * build chart from the selected nameserver history file\r\n   * @param file the nameserver history file\r\n   * @param startTime start time\r\n   * @param endTime end time\r\n   * @param selectedPort selected port for nameserver history file (MDC system)\r\n   */\r\n  private _buildChartFromDataFile(file: File, startTime: number, endTime: number, selectedPort: string): Promise<any> {\r\n    return this.fileService.getChartContentFromFile(\r\n      file,\r\n      startTime,\r\n      endTime,\r\n      selectedPort,\r\n      this.timezone,\r\n      this.maxRowsLimitation, progress => this.readProgress = progress)\r\n      .then(result => {\r\n        // parsing done\r\n        const beginTime = new Date();\r\n        const promises = [];\r\n        const ports = getRealPorts(Object.keys(result.time), true);\r\n        ports.forEach(port => {\r\n          // convert the unit and generate controlling data for all ports\r\n          promises.push(this.uiService.convertUnitAndGenerateControlData(result.data[port], result.header, port));\r\n        });\r\n\r\n        return Promise.all(promises)\r\n          .then(() => {\r\n\r\n            // get all ports from the analyzed data(time)\r\n            // get the port that will be shown in the page\r\n            const port = getDisplayPort(ports, selectedPort);\r\n\r\n            printProcessedTime(beginTime, 'converting step');\r\n            ports.forEach( portItem => this.uiService.generateYScale(portItem));\r\n            printProcessedTime(beginTime, 'generating YScale step');\r\n            this.data = result.data;\r\n            this.time = result.time;\r\n            this.header = this.uiService.getHeader(result.header, port);\r\n            this.host = result.host;\r\n            if (result.aborted === Abort.maxLineNumReached) {\r\n              this._showMessage(\r\n                Alert.warning, `Maximum number of lines reached. Processed time range is: ${getTimeRangeString(this.time)}.`);\r\n            } else {\r\n              if (isEmptyData(this.data)) {\r\n                this._showMessage(Alert.info, `Cannot find any data for the selected time period: ${this._selectedTimeRangeString}`);\r\n              } else {\r\n                this._showMessage(Alert.success, `Processed time range is: ${getTimeRangeString(this.time)}.`);\r\n              }\r\n            }\r\n            return sleep(100).then(() => {\r\n              return this._buildChart(port, ports);\r\n            });\r\n          });\r\n      });\r\n  }\r\n\r\n  /**\r\n   * reinitialize the port selector with the ports\r\n   */\r\n  private _initPortSelector(ports: string[] = null, selectedPort: string = null): Promise<void> {\r\n    return new Promise(resolve => {\r\n      // initialization for ngx-select\r\n      if (ports != null && ports.length > 1) {\r\n        // MDC, remove default '0000' port\r\n        this.ports = generatePorts(getRealPorts(ports), selectedPort);\r\n      } else {\r\n        this.ports = generatePorts(ports);\r\n      }\r\n\r\n      if (ports != null && selectedPort === null) {\r\n        // reset status when doing:\r\n        // 1. loading ports\r\n        // 2. the file doesn't contain the selected Port\r\n        this.readProgress = 0;\r\n        // hide the progress bar and enable the \"show chart\" button\r\n        this._toggleItems([\r\n          {id: HtmlElement.readFileProgress, status: false},\r\n          {id: HtmlElement.showChartButton, status: true}\r\n        ]);\r\n      }\r\n      resolve();\r\n    });\r\n  }\r\n\r\n  /**\r\n   * build and display the chart on page\r\n   * @param port the selected port\r\n   * @param ports all available ports\r\n   * @param switchFlag indicates whether this function is triggered from switching ports (no init port selector needed)\r\n   */\r\n  private _buildChart(port: string, ports: string[], switchFlag = false): Promise<any> {\r\n    const beginTime = new Date();\r\n    if (port) {\r\n      return Promise.resolve(this._loadSettingsForSelectionsTable(port))\r\n        .then( () => {\r\n          // get the config\r\n          return this.chartService.buildChart(\r\n            this.time[port],\r\n            this.data[port],\r\n            this.uiService.getYScale(this._headerKey, port),\r\n            this._headerText,\r\n            this._headerKey,\r\n            this._selection,\r\n            this.tableSource,\r\n            this._getHostTitle(port),\r\n            this.uiService.getDisplayItems(this._headerKey, port, this.defaultSelectedItems),\r\n            this._onZoom.bind(this))\r\n            .then(() => {\r\n              this.readProgress = 0;\r\n              // after chart has been created, show the chart area, hide progress bar and enable the \"show chart\" button\r\n              this._toggleItems([\r\n                {id: HtmlElement.chartArea, status: true},\r\n                {id: HtmlElement.readFileProgress, status: false},\r\n                {id: HtmlElement.showChartButton, status: true}\r\n              ]);\r\n              // set port to current displaying port\r\n              this._currentChartPort = port;\r\n              printProcessedTime(beginTime, 'step_build_chart');\r\n              if (ports && ports.length > 0) {\r\n                if (!switchFlag) {\r\n                  // initialize port selector. Do not need to do it when switching port.\r\n                  return this._initPortSelector(ports, port);\r\n                }\r\n              }\r\n            });\r\n        });\r\n    } else {\r\n      if (ports.length > 0) {\r\n        this._showMessage(\r\n          Alert.warning,\r\n          'The selected port does not exist in the name server history file. Please choose a correct port and have a try again.');\r\n        if (!switchFlag) {\r\n          // initialize port selector. Do not need to do it when switching port.\r\n          return this._initPortSelector(ports, port);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * get the string that will be displayed on the title area of the chart\r\n   * eg: host1 - 30040 (2018-09-05 15:32:32 ~ 2018-09-07 15:32:15)\r\n   * @param port selected port\r\n   */\r\n  private _getHostTitle(port: string): string {\r\n    if (this.host) {\r\n      return  `${this.host} - ${port} ( ${getTimeRangeString(this.time[port])} )`;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * after zoom, enable the reset button.\r\n   */\r\n  private _onZoom(): void {\r\n    this._toggleItems([{id: HtmlElement.resetChartButton, status: true}]);\r\n  }\r\n\r\n  /**\r\n   * initialize chart, including: destroy current chart, initialize config, initialize all relative data\r\n   */\r\n  private _initChartEnv(switchFlag: boolean = false): Promise<any> {\r\n    return this.chartService.destroyChart().then(() => {\r\n      {\r\n        // cleanup other data\r\n        this._toggleItems([{id: HtmlElement.chartArea, status: false}]);\r\n\r\n        if (!switchFlag) {\r\n          Object.keys(this.time).forEach(key => {\r\n            if (this.time[key]) {\r\n              this.time[key].length = 0;\r\n            }});\r\n          this.time = {};\r\n          Object.keys(this.data).forEach(key => {\r\n            if (this.data[key]) {\r\n              this.data[key].length = 0;\r\n            }});\r\n          this.data = {};\r\n          this.header.length = 0;\r\n          this.host = 'nameserver history file';\r\n          this.tableSource = void 0;\r\n          this.readProgress = 0;\r\n          this.uiService.clearLoadHistoryInfos();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Load settings for the selection table (the right part of the chart)\r\n   * @param port the selected port\r\n   */\r\n  private _loadSettingsForSelectionsTable(port: string): void {\r\n    this.tableSource = this.uiService.getSelectionTableRows(this._headerKey, port, this.defaultSelectedItems);\r\n    this._selection = new SelectionModel(true, []);\r\n    this.tableSource.forEach(row => {\r\n      if (this.uiService.getDisplayItems(this._headerKey, port, this.defaultSelectedItems).includes(row.KPI)) {\r\n        this._selection.select(row);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show messages\r\n   * @param type type of the message\r\n   * @param message message text\r\n   */\r\n  private _showMessage(type: Alert, message: string): void {\r\n    if (type) {\r\n      switch (type) {\r\n        case Alert.success:\r\n        case Alert.info:\r\n          break;\r\n        case Alert.warning:\r\n          console.warn(message);\r\n          break;\r\n        case Alert.error:\r\n          console.error(message);\r\n      }\r\n    }\r\n    if (this.alertMessage === message) {\r\n      // try trigger the change event of the alert.\r\n      this.alertMessage = void 0;\r\n      setTimeout(() => this.alertMessage = message, 100);\r\n    } else {\r\n      this.alertMessage = message;\r\n    }\r\n    this.alertType = type;\r\n  }\r\n\r\n  /**\r\n   * toggle items with the provided status (show or hide the relative element on the page)\r\n   * @param items items with the relative id and status.\r\n   */\r\n  private _toggleItems(items: {id: HtmlElement, status: boolean}[]) {\r\n    const getVariableNameByTypeId = (id: HtmlElement) => {\r\n      switch (id) {\r\n        case HtmlElement.chartArea: return 'showChartFlag';\r\n        case HtmlElement.readFileProgress: return 'showReadFileProgress';\r\n        case HtmlElement.showChartButton: return 'enableShowChartButton';\r\n        case HtmlElement.loadPortsButton: return 'enableLoadPortsButton';\r\n        case HtmlElement.resetChartButton: return 'enableResetChartButton';\r\n      }\r\n    };\r\n    if (items) {\r\n      items.forEach(item => {\r\n        this[getVariableNameByTypeId(item.id)] = item.status;\r\n      });\r\n    }\r\n  }\r\n}\r\n","<div #nameserverHistoryAll class=\"nameserver-history-all\" (window:resize)=\"onResize()\">\r\n  <div class=\"toolbar-chart\">\r\n    <div class=\"upload-box-content\">\r\n      <div *ngIf=\"!showReadFileProgress\">\r\n        <file-drop-input (fileDrop)=\"fileDropped($event)\" (fileInput)=\"fileSelected($event)\"\r\n                         [dropAreaText]= \"abbreviatedFileName\"\r\n                         [inputAreaText]=\"'Browse'\"\r\n                         [title]=\"file?.name? file.name:'Select a name server history file from your local disk.'\"\r\n                         *ngIf=\"!fileBuffer\">\r\n        </file-drop-input>\r\n        <p *ngIf=\"fileBuffer\">{{streamModeFileName || 'nameserver_history.trc (stream mode)'}}</p>\r\n      </div>\r\n      <div *ngIf=\"showReadFileProgress\">\r\n        <progress-bar [progress]=\"readProgress\"></progress-bar>\r\n      </div>\r\n    </div>\r\n    <div class=\"input-time\">\r\n     <div class=\"input-time-range\">\r\n       <time-range-selector [disabled]=\"showReadFileProgress\" [(dateTimeRange)]=\"dateTimeRange\"></time-range-selector>\r\n     </div>\r\n      <div class=\"timezone-selector\">\r\n        <timezone-selector [(timezone)]=\"timezone\" [disabled]=\"showReadFileProgress\"></timezone-selector>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"port-selection\">\r\n      <div class=\"port-selector\">\r\n        <port-selector (portChange)=\"switchPortForChart($event)\" [(port)]=\"port\" [ports]=\"ports\" [disabled]=\"showReadFileProgress\"></port-selector>\r\n      </div>\r\n      <div class=\"port-load-button\">\r\n        <button (click)=\"loadPorts()\" title=\"Load all ports from name server history trace file.\" [disabled]=\"!enableShowChartButton || port || !enableLoadPortsButton\">{{showReadFileProgress? \"Loading...\" : \"Load\"}}</button>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"chart-operation\">\r\n      <div class=\"left\">\r\n        <button (click)=\"showChart()\" title=\"Load and display all data from name server history trace file.\" [disabled]=\"!enableShowChartButton\">{{showReadFileProgress? \"Loading...\" : \"Show\"}}</button>\r\n      </div>\r\n      <div class=\"right\">\r\n        <button (click)=\"resetChart()\" title=\"Reset zoom of chart.\" [disabled]=\"showReadFileProgress || !enableResetChartButton\">Reset Chart</button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div #nameserverHistoryContent class=\"nameserver-history-content\">\r\n    <div class=\"nameserver-history-content-chart\">\r\n      <instruction [(show)]=\"showInstruction\" *ngIf=\"!showChartFlag && showInstruction\"\r\n                   [step1Finished]=\"!!file\"\r\n                   [step2Finished]=\"dateTimeRange && (!!dateTimeRange[0] || !!dateTimeRange[1]) || timezone != defaultTimezone\"\r\n                   [step3Finished]=\"!!port\"\r\n                   [step4Finished]=\"stepShowChart && !enableShowChartButton\"\r\n                   [step5Finished]=\"false\">\r\n      </instruction>\r\n      <canvas id=\"chartNameServerHistory\" ></canvas>\r\n    </div>\r\n    <div class=\"nameserver-history-content-controller\" >\r\n      <ngx-selection-table (change)=\"selectItem($event)\" *ngIf=\"showChartFlag\"\r\n                           [filter]=\"true\"\r\n                           [checkbox]=\"true\"\r\n                           [tableSource]=\"tableSource\"\r\n                           [keyColumn]=\"kpiColumn\"\r\n                           [hiddenColumns]=\"hiddenColumns\"\r\n                           [tooltipColumn]=\"descColumn\"\r\n                           [searchStyle]=\"searchType\"\r\n                           [searchColumn]=\"kpiColumn\"\r\n                           [multiSelection]=\"true\">\r\n      </ngx-selection-table>\r\n    </div>\r\n  </div>\r\n</div>\r\n<div class=\"message-container\" *ngIf=\"alertMessage\">\r\n  <alert [(alertMessage)]=\"alertMessage\" [alertType]=\"alertType\" [alertTimeout]=\"30000\"></alert>\r\n</div>\r\n"]}