ngx-hana-nameserver-history-viewer 1.1.9-9.8.beta → 1.2.0-9.8.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.
@@ -22,7 +22,8 @@
22
22
  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23
23
  * SOFTWARE.
24
24
  */
25
- import moment from 'moment';
25
+ import * as moment_module from 'moment';
26
+ const moment = (window && window.moment) ? window.moment : moment_module;
26
27
  import * as utils from './utils';
27
28
  import { DataMipmap } from './data_mipmap';
28
29
  import { LTTBDataMipmap } from './lttb_data_mipmap';
@@ -164,4 +165,4 @@ export class ResponsiveDownsamplePlugin {
164
165
  }
165
166
  }
166
167
  }
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"responsive_downsample_plugin.js","sourceRoot":"","sources":["../../../../../../src/nameserver-history-viewer/utils/chartjs-downsample/responsive_downsample_plugin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * This plugin is adapted from: https://github.com/3dcl/chartjs-plugin-responsive-downsample\r\n * for controlling the radius of point.\r\n *\r\n * MIT License\r\n * Copyright (c) 2018 3D Content Logistics\r\n *\r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is\r\n * furnished to do so, subject to the following conditions:\r\n * The above copyright notice and this permission notice shall be included in all\r\n * copies or substantial portions of the Software.\r\n *\r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r\n * SOFTWARE.\r\n */\r\nimport moment from 'moment';\r\nimport { Chart, ChartDataSets, ChartPoint } from 'chart.js';\r\nimport { IChartPlugin, TimeScale } from './chartjs_ext';\r\nimport * as utils from './utils';\r\n\r\nimport { DataMipmap } from './data_mipmap';\r\nimport { LTTBDataMipmap } from './lttb_data_mipmap';\r\nimport * as data_culling from './data_culling';\r\n\r\ninterface MipMapDataSets extends ChartDataSets {\r\n  originalData?: ChartPoint[];\r\n  currentMipMapLevel?: number;\r\n  mipMap?: DataMipmap;\r\n}\r\n\r\nexport interface ResponsiveDownsamplePluginOptions {\r\n  /**\r\n   * Enable/disable plugin\r\n   */\r\n  enabled?: boolean;\r\n  /**\r\n   * The aggregation algorithm to thin out data. Default: LTTB\r\n   */\r\n  aggregationAlgorithm?: 'AVG' | 'LTTB';\r\n  /**\r\n   * Desired minimal distance between data points in pixels. Default: 1 pixel\r\n   */\r\n  desiredDataPointDistance?: number;\r\n  /**\r\n   * Minimal number of data points. Limits\r\n   */\r\n  minNumPoints?: number;\r\n  /**\r\n   * Cull data to displayed range of x scale\r\n   */\r\n  cullData?: boolean;\r\n  /**\r\n   * Flag is set by plugin to trigger reload of data\r\n   */\r\n  needsUpdate?: boolean;\r\n  /**\r\n   * Current target resolution(Set by plugin)\r\n   */\r\n  targetResolution?: number;\r\n  /**\r\n   * Scale range of x axis\r\n   */\r\n  scaleRange?: data_culling.Range;\r\n  /**\r\n   * Draw points only if the points number less than the limitation\r\n   */\r\n  maxNumPointsToDraw?: number;\r\n}\r\n\r\n// Using dynamic flag to fix the issue of ng-packagr #696: Lambda not supported\r\n// @dynamic\r\n/**\r\n * Chart js Plugin for downsampling data\r\n */\r\nexport class ResponsiveDownsamplePlugin implements IChartPlugin {\r\n  static getPluginOptions(chart: any): ResponsiveDownsamplePluginOptions {\r\n    const options: ResponsiveDownsamplePluginOptions = chart.options.responsiveDownsample || {};\r\n    utils.defaultsDeep(options, {\r\n      enabled: false,\r\n      aggregationAlgorithm: 'LTTB',\r\n      desiredDataPointDistance: 1,\r\n      minNumPoints: 100,\r\n      maxNumPointsToDraw: 100,\r\n      cullData: true\r\n    });\r\n\r\n    if (options.enabled) {\r\n      chart.options.responsiveDownsample = options;\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  static hasDataChanged(chart: Chart): boolean {\r\n    return !utils.isNil(\r\n      utils.findInArray(\r\n        chart.data.datasets as MipMapDataSets[],\r\n        (dataset) => {\r\n          return utils.isNil(dataset.mipMap);\r\n        }\r\n      )\r\n    );\r\n  }\r\n\r\n  static createDataMipMap(chart: Chart, options: ResponsiveDownsamplePluginOptions): void {\r\n    chart.data.datasets.forEach((dataset: MipMapDataSets) => {\r\n      // @ts-ignore\r\n      const data = !utils.isNil(dataset.originalData) ? dataset.originalData : dataset.data as ChartPoint[];\r\n\r\n      const mipMap = (options.aggregationAlgorithm === 'LTTB')\r\n        ? new LTTBDataMipmap(data, options.minNumPoints)\r\n        : new DataMipmap(data, options.minNumPoints);\r\n\r\n      dataset.originalData = data;\r\n      dataset.mipMap = mipMap;\r\n      // @ts-ignore\r\n      dataset.data = mipMap.getMipMapLevel(mipMap.getNumLevel() - 1); // set last level for first render pass\r\n    });\r\n  }\r\n\r\n  static restoreOriginalData(chart: Chart): boolean {\r\n    let updated = false;\r\n\r\n    chart.data.datasets.forEach((dataset: MipMapDataSets) => {\r\n      // @ts-ignore\r\n      if (!utils.isNil(dataset.originalData) && dataset.data !== dataset.originalData) {\r\n        // @ts-ignore\r\n        dataset.data = dataset.originalData;\r\n        updated = true;\r\n      }\r\n    });\r\n\r\n    return updated;\r\n  }\r\n\r\n  static getTargetResolution(chart: Chart, options: ResponsiveDownsamplePluginOptions): number {\r\n    const xScale: TimeScale = (chart as any).scales['x-axis-0'];\r\n\r\n    if (utils.isNil(xScale)) {\r\n      return null;\r\n    }\r\n\r\n    const start = moment(xScale.getValueForPixel(xScale.left) as any);\r\n    const end = moment(xScale.getValueForPixel(xScale.left + 1) as any);\r\n    const targetResolution = end.diff(start);\r\n\r\n    return targetResolution * options.desiredDataPointDistance;\r\n  }\r\n\r\n  static updateMipMap(chart: Chart, options: ResponsiveDownsamplePluginOptions, rangeChanged: boolean): boolean {\r\n    let updated = false;\r\n\r\n    chart.data.datasets.forEach((dataset: MipMapDataSets) => {\r\n      const mipMap = dataset.mipMap;\r\n      if (utils.isNil(mipMap)) {\r\n        return;\r\n      }\r\n\r\n      const mipMalLevel = mipMap.getMipMapIndexForResolution(options.targetResolution);\r\n      if (mipMalLevel === dataset.currentMipMapLevel && !rangeChanged) {\r\n        // skip update if mip map level and data range did not change\r\n        return;\r\n      }\r\n      updated = true;\r\n      dataset.currentMipMapLevel = mipMalLevel;\r\n\r\n      let newData = mipMap.getMipMapLevel(mipMalLevel);\r\n      if (options.cullData) {\r\n        newData = data_culling.cullData(newData, options.scaleRange);\r\n      }\r\n\r\n      // @ts-ignore\r\n      dataset.data = newData;\r\n    });\r\n\r\n    return updated;\r\n  }\r\n\r\n  beforeInit(chart: Chart): void {\r\n    const options = ResponsiveDownsamplePlugin.getPluginOptions(chart);\r\n    if (!options.enabled) { return; }\r\n\r\n    ResponsiveDownsamplePlugin.createDataMipMap(chart, options);\r\n    options.needsUpdate = true;\r\n  }\r\n\r\n  beforeDatasetsUpdate(chart: Chart): void {\r\n    const options = ResponsiveDownsamplePlugin.getPluginOptions(chart);\r\n    if (!options.enabled) {\r\n      // restore original data and remove state from options\r\n      options.needsUpdate = ResponsiveDownsamplePlugin.restoreOriginalData(chart);\r\n      delete options.targetResolution;\r\n      delete options.scaleRange;\r\n      return;\r\n    }\r\n\r\n    // only update mip map if data set was reloaded externally\r\n    if (ResponsiveDownsamplePlugin.hasDataChanged(chart)) {\r\n      ResponsiveDownsamplePlugin.createDataMipMap(chart, options);\r\n      options.needsUpdate = true;\r\n    }\r\n  }\r\n\r\n  beforeRender(chart: Chart): boolean {\r\n    const options = ResponsiveDownsamplePlugin.getPluginOptions(chart);\r\n    if (!options.enabled) {\r\n      // update chart if data was restored from original data\r\n      if (options.needsUpdate) {\r\n        options.needsUpdate = false;\r\n        chart.update(0);\r\n\r\n        return false;\r\n      }\r\n      return;\r\n    }\r\n\r\n    const targetResolution = ResponsiveDownsamplePlugin.getTargetResolution(chart, options);\r\n    const xScale: TimeScale = (chart as any).scales['x-axis-0'];\r\n    const scaleRange = data_culling.getScaleRange(xScale);\r\n    const rangeChanged = !data_culling.rangeIsEqual(options.scaleRange, scaleRange);\r\n\r\n    if (options.needsUpdate ||\r\n      options.targetResolution !== targetResolution ||\r\n      rangeChanged\r\n    ) {\r\n      options.targetResolution = targetResolution;\r\n      options.scaleRange = scaleRange;\r\n      options.needsUpdate = false;\r\n\r\n      if (ResponsiveDownsamplePlugin.updateMipMap(chart, options, rangeChanged)) {\r\n        utils.changePointRadius(chart, options);\r\n        // update chart and cancel current render\r\n        chart.update(0);\r\n\r\n        return false;\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"responsive_downsample_plugin.js","sourceRoot":"","sources":["../../../../../../src/nameserver-history-viewer/utils/chartjs-downsample/responsive_downsample_plugin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * This plugin is adapted from: https://github.com/3dcl/chartjs-plugin-responsive-downsample\r\n * for controlling the radius of point.\r\n *\r\n * MIT License\r\n * Copyright (c) 2018 3D Content Logistics\r\n *\r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is\r\n * furnished to do so, subject to the following conditions:\r\n * The above copyright notice and this permission notice shall be included in all\r\n * copies or substantial portions of the Software.\r\n *\r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r\n * SOFTWARE.\r\n */\r\nimport * as moment_module from 'moment';\r\nconst moment = (window && (window as any).moment) ? (window as any).moment : moment_module;\r\nimport { Chart, ChartDataSets, ChartPoint } from 'chart.js';\r\nimport { IChartPlugin, TimeScale } from './chartjs_ext';\r\nimport * as utils from './utils';\r\n\r\nimport { DataMipmap } from './data_mipmap';\r\nimport { LTTBDataMipmap } from './lttb_data_mipmap';\r\nimport * as data_culling from './data_culling';\r\n\r\ninterface MipMapDataSets extends ChartDataSets {\r\n  originalData?: ChartPoint[];\r\n  currentMipMapLevel?: number;\r\n  mipMap?: DataMipmap;\r\n}\r\n\r\nexport interface ResponsiveDownsamplePluginOptions {\r\n  /**\r\n   * Enable/disable plugin\r\n   */\r\n  enabled?: boolean;\r\n  /**\r\n   * The aggregation algorithm to thin out data. Default: LTTB\r\n   */\r\n  aggregationAlgorithm?: 'AVG' | 'LTTB';\r\n  /**\r\n   * Desired minimal distance between data points in pixels. Default: 1 pixel\r\n   */\r\n  desiredDataPointDistance?: number;\r\n  /**\r\n   * Minimal number of data points. Limits\r\n   */\r\n  minNumPoints?: number;\r\n  /**\r\n   * Cull data to displayed range of x scale\r\n   */\r\n  cullData?: boolean;\r\n  /**\r\n   * Flag is set by plugin to trigger reload of data\r\n   */\r\n  needsUpdate?: boolean;\r\n  /**\r\n   * Current target resolution(Set by plugin)\r\n   */\r\n  targetResolution?: number;\r\n  /**\r\n   * Scale range of x axis\r\n   */\r\n  scaleRange?: data_culling.Range;\r\n  /**\r\n   * Draw points only if the points number less than the limitation\r\n   */\r\n  maxNumPointsToDraw?: number;\r\n}\r\n\r\n// Using dynamic flag to fix the issue of ng-packagr #696: Lambda not supported\r\n// @dynamic\r\n/**\r\n * Chart js Plugin for downsampling data\r\n */\r\nexport class ResponsiveDownsamplePlugin implements IChartPlugin {\r\n  static getPluginOptions(chart: any): ResponsiveDownsamplePluginOptions {\r\n    const options: ResponsiveDownsamplePluginOptions = chart.options.responsiveDownsample || {};\r\n    utils.defaultsDeep(options, {\r\n      enabled: false,\r\n      aggregationAlgorithm: 'LTTB',\r\n      desiredDataPointDistance: 1,\r\n      minNumPoints: 100,\r\n      maxNumPointsToDraw: 100,\r\n      cullData: true\r\n    });\r\n\r\n    if (options.enabled) {\r\n      chart.options.responsiveDownsample = options;\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  static hasDataChanged(chart: Chart): boolean {\r\n    return !utils.isNil(\r\n      utils.findInArray(\r\n        chart.data.datasets as MipMapDataSets[],\r\n        (dataset) => {\r\n          return utils.isNil(dataset.mipMap);\r\n        }\r\n      )\r\n    );\r\n  }\r\n\r\n  static createDataMipMap(chart: Chart, options: ResponsiveDownsamplePluginOptions): void {\r\n    chart.data.datasets.forEach((dataset: MipMapDataSets) => {\r\n      // @ts-ignore\r\n      const data = !utils.isNil(dataset.originalData) ? dataset.originalData : dataset.data as ChartPoint[];\r\n\r\n      const mipMap = (options.aggregationAlgorithm === 'LTTB')\r\n        ? new LTTBDataMipmap(data, options.minNumPoints)\r\n        : new DataMipmap(data, options.minNumPoints);\r\n\r\n      dataset.originalData = data;\r\n      dataset.mipMap = mipMap;\r\n      // @ts-ignore\r\n      dataset.data = mipMap.getMipMapLevel(mipMap.getNumLevel() - 1); // set last level for first render pass\r\n    });\r\n  }\r\n\r\n  static restoreOriginalData(chart: Chart): boolean {\r\n    let updated = false;\r\n\r\n    chart.data.datasets.forEach((dataset: MipMapDataSets) => {\r\n      // @ts-ignore\r\n      if (!utils.isNil(dataset.originalData) && dataset.data !== dataset.originalData) {\r\n        // @ts-ignore\r\n        dataset.data = dataset.originalData;\r\n        updated = true;\r\n      }\r\n    });\r\n\r\n    return updated;\r\n  }\r\n\r\n  static getTargetResolution(chart: Chart, options: ResponsiveDownsamplePluginOptions): number {\r\n    const xScale: TimeScale = (chart as any).scales['x-axis-0'];\r\n\r\n    if (utils.isNil(xScale)) {\r\n      return null;\r\n    }\r\n\r\n    const start = moment(xScale.getValueForPixel(xScale.left) as any);\r\n    const end = moment(xScale.getValueForPixel(xScale.left + 1) as any);\r\n    const targetResolution = end.diff(start);\r\n\r\n    return targetResolution * options.desiredDataPointDistance;\r\n  }\r\n\r\n  static updateMipMap(chart: Chart, options: ResponsiveDownsamplePluginOptions, rangeChanged: boolean): boolean {\r\n    let updated = false;\r\n\r\n    chart.data.datasets.forEach((dataset: MipMapDataSets) => {\r\n      const mipMap = dataset.mipMap;\r\n      if (utils.isNil(mipMap)) {\r\n        return;\r\n      }\r\n\r\n      const mipMalLevel = mipMap.getMipMapIndexForResolution(options.targetResolution);\r\n      if (mipMalLevel === dataset.currentMipMapLevel && !rangeChanged) {\r\n        // skip update if mip map level and data range did not change\r\n        return;\r\n      }\r\n      updated = true;\r\n      dataset.currentMipMapLevel = mipMalLevel;\r\n\r\n      let newData = mipMap.getMipMapLevel(mipMalLevel);\r\n      if (options.cullData) {\r\n        newData = data_culling.cullData(newData, options.scaleRange);\r\n      }\r\n\r\n      // @ts-ignore\r\n      dataset.data = newData;\r\n    });\r\n\r\n    return updated;\r\n  }\r\n\r\n  beforeInit(chart: Chart): void {\r\n    const options = ResponsiveDownsamplePlugin.getPluginOptions(chart);\r\n    if (!options.enabled) { return; }\r\n\r\n    ResponsiveDownsamplePlugin.createDataMipMap(chart, options);\r\n    options.needsUpdate = true;\r\n  }\r\n\r\n  beforeDatasetsUpdate(chart: Chart): void {\r\n    const options = ResponsiveDownsamplePlugin.getPluginOptions(chart);\r\n    if (!options.enabled) {\r\n      // restore original data and remove state from options\r\n      options.needsUpdate = ResponsiveDownsamplePlugin.restoreOriginalData(chart);\r\n      delete options.targetResolution;\r\n      delete options.scaleRange;\r\n      return;\r\n    }\r\n\r\n    // only update mip map if data set was reloaded externally\r\n    if (ResponsiveDownsamplePlugin.hasDataChanged(chart)) {\r\n      ResponsiveDownsamplePlugin.createDataMipMap(chart, options);\r\n      options.needsUpdate = true;\r\n    }\r\n  }\r\n\r\n  beforeRender(chart: Chart): boolean {\r\n    const options = ResponsiveDownsamplePlugin.getPluginOptions(chart);\r\n    if (!options.enabled) {\r\n      // update chart if data was restored from original data\r\n      if (options.needsUpdate) {\r\n        options.needsUpdate = false;\r\n        chart.update(0);\r\n\r\n        return false;\r\n      }\r\n      return;\r\n    }\r\n\r\n    const targetResolution = ResponsiveDownsamplePlugin.getTargetResolution(chart, options);\r\n    const xScale: TimeScale = (chart as any).scales['x-axis-0'];\r\n    const scaleRange = data_culling.getScaleRange(xScale);\r\n    const rangeChanged = !data_culling.rangeIsEqual(options.scaleRange, scaleRange);\r\n\r\n    if (options.needsUpdate ||\r\n      options.targetResolution !== targetResolution ||\r\n      rangeChanged\r\n    ) {\r\n      options.targetResolution = targetResolution;\r\n      options.scaleRange = scaleRange;\r\n      options.needsUpdate = false;\r\n\r\n      if (ResponsiveDownsamplePlugin.updateMipMap(chart, options, rangeChanged)) {\r\n        utils.changePointRadius(chart, options);\r\n        // update chart and cancel current render\r\n        chart.update(0);\r\n\r\n        return false;\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,6 +1,6 @@
1
1
  import { isDevMode } from '@angular/core';
2
2
  import { getIgnoredLineNumFromTail } from './ui-util';
3
- import moment from 'moment-timezone';
3
+ import * as moment from 'moment-timezone';
4
4
  /**
5
5
  * get the time range for all ports
6
6
  */
@@ -96,4 +96,4 @@ export function printProcessedTime(beginTime, step) {
96
96
  console.log(`${step}, Parsing time: ${parsingTime} seconds`);
97
97
  }
98
98
  }
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-util.js","sourceRoot":"","sources":["../../../../../src/nameserver-history-viewer/utils/time-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core';\r\nimport { getIgnoredLineNumFromTail } from './ui-util';\r\nimport { ChartContentTime } from '../types';\r\nimport moment from 'moment-timezone';\r\n\r\n/**\r\n * get the time range for all ports\r\n */\r\nfunction _getTotalTimeRange(time: ChartContentTime): {startTime: number, endTime: number} {\r\n  if (time) {\r\n    let startTime = 4102358400000; // 2099/12/31\r\n    let endTime = 0;\r\n\r\n    Object.keys(time).forEach(port => {\r\n      if (time[port]) {\r\n        const timeRangeCurrent = _getTimeRange(time[port]);\r\n        startTime = startTime > timeRangeCurrent.startTime ? timeRangeCurrent.startTime : startTime;\r\n        endTime = endTime < timeRangeCurrent.endTime ? timeRangeCurrent.endTime : endTime;\r\n      }\r\n    });\r\n\r\n    return {startTime: startTime, endTime: endTime};\r\n  }\r\n}\r\n\r\n/**\r\n * get the time range (startTime ~ endTime) base on the time (the xScale)\r\n */\r\nfunction _getTimeRange(time: number[]): {startTime: number, endTime: number} {\r\n  const ignoredLineNumFromTail = getIgnoredLineNumFromTail();\r\n  if (time) {\r\n    let startTime = 4102358400000; // 2099/12/31\r\n    let endTime = 0;\r\n\r\n    const len = time.length;\r\n    if (len > ignoredLineNumFromTail) {\r\n      startTime = time[0] > startTime ? startTime : time[0];\r\n      endTime = time[len - ignoredLineNumFromTail - 1] > endTime ? time[len - ignoredLineNumFromTail - 1] : endTime;\r\n    }\r\n\r\n    return {startTime: startTime, endTime: endTime};\r\n  }\r\n}\r\n\r\n/**\r\n * get default local time zone\r\n */\r\nexport function getDefaultTimezone(): string {\r\n  return moment.tz.guess();\r\n}\r\n\r\n/**\r\n * Get time from provided timezone, using this only because chart.js doesn't support timezone.\r\n * This function will be removed when chart.js starts to support timezone feature.\r\n * @param time time in seconds (Epoch time)\r\n * @param timezone timezone string, uses local timezone if this is null.\r\n */\r\nexport function getTimeFromTimeZone (time: number, timezone: string): number {\r\n  if (timezone == null || timezone.length === 0) {\r\n    timezone = getDefaultTimezone();\r\n    console.warn(`getTimeFromTimeZone - Input timezone is null, returning the local (${timezone}) time. `);\r\n  }\r\n  const utcOffset = moment.tz.zone(timezone).utcOffset(time * 1000);\r\n  const currentOffset = moment.tz.zone(getDefaultTimezone()).utcOffset(time * 1000);\r\n  // convert to utc and then to selected timezone\r\n  return time + currentOffset * 60 - utcOffset * 60;\r\n}\r\n\r\n/**\r\n * Get time formatted with the provided timezone\r\n */\r\nexport function getTimeString (time: number): string {\r\n   return moment(time).format('YYYY-MM-DD HH:mm:ss');\r\n}\r\n\r\n/**\r\n * Get the time range string by time array, eg: 2018-10-25 10:10:00 ~ 2018-10-25 12:12:00\r\n */\r\nexport function getTimeRangeString(time: any): string {\r\n  let startTimeString = 'N/A';\r\n  let endTimeString = 'N/A';\r\n  let timeRange;\r\n  if (Array.isArray(time)) {\r\n    timeRange = _getTimeRange(time);\r\n  } else {\r\n    timeRange = _getTotalTimeRange(time);\r\n  }\r\n\r\n  if (timeRange) {\r\n    if (timeRange.startTime < 4102358400000) {\r\n      startTimeString = getTimeString(timeRange.startTime);\r\n    }\r\n\r\n    if (timeRange.endTime > 0) {\r\n      endTimeString = getTimeString(timeRange.endTime);\r\n    }\r\n    return `${startTimeString} ~ ${endTimeString}`;\r\n  }\r\n}\r\n\r\n/**\r\n * print processed time from the provided beginTime, only works in dev mode\r\n */\r\nexport function printProcessedTime(beginTime: Date, step: string): void {\r\n  if (isDevMode()) {\r\n    // only do it in dev mode\r\n    const timeAfter = new Date();\r\n    const parsingTime = (timeAfter.getTime() - beginTime.getTime()) / 1000;\r\n    console.log(`${step}, Parsing time: ${parsingTime} seconds`);\r\n  }\r\n}\r\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-util.js","sourceRoot":"","sources":["../../../../../src/nameserver-history-viewer/utils/time-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core';\r\nimport { getIgnoredLineNumFromTail } from './ui-util';\r\nimport { ChartContentTime } from '../types';\r\nimport * as moment from 'moment-timezone';\r\n\r\n/**\r\n * get the time range for all ports\r\n */\r\nfunction _getTotalTimeRange(time: ChartContentTime): {startTime: number, endTime: number} {\r\n  if (time) {\r\n    let startTime = 4102358400000; // 2099/12/31\r\n    let endTime = 0;\r\n\r\n    Object.keys(time).forEach(port => {\r\n      if (time[port]) {\r\n        const timeRangeCurrent = _getTimeRange(time[port]);\r\n        startTime = startTime > timeRangeCurrent.startTime ? timeRangeCurrent.startTime : startTime;\r\n        endTime = endTime < timeRangeCurrent.endTime ? timeRangeCurrent.endTime : endTime;\r\n      }\r\n    });\r\n\r\n    return {startTime: startTime, endTime: endTime};\r\n  }\r\n}\r\n\r\n/**\r\n * get the time range (startTime ~ endTime) base on the time (the xScale)\r\n */\r\nfunction _getTimeRange(time: number[]): {startTime: number, endTime: number} {\r\n  const ignoredLineNumFromTail = getIgnoredLineNumFromTail();\r\n  if (time) {\r\n    let startTime = 4102358400000; // 2099/12/31\r\n    let endTime = 0;\r\n\r\n    const len = time.length;\r\n    if (len > ignoredLineNumFromTail) {\r\n      startTime = time[0] > startTime ? startTime : time[0];\r\n      endTime = time[len - ignoredLineNumFromTail - 1] > endTime ? time[len - ignoredLineNumFromTail - 1] : endTime;\r\n    }\r\n\r\n    return {startTime: startTime, endTime: endTime};\r\n  }\r\n}\r\n\r\n/**\r\n * get default local time zone\r\n */\r\nexport function getDefaultTimezone(): string {\r\n  return moment.tz.guess();\r\n}\r\n\r\n/**\r\n * Get time from provided timezone, using this only because chart.js doesn't support timezone.\r\n * This function will be removed when chart.js starts to support timezone feature.\r\n * @param time time in seconds (Epoch time)\r\n * @param timezone timezone string, uses local timezone if this is null.\r\n */\r\nexport function getTimeFromTimeZone (time: number, timezone: string): number {\r\n  if (timezone == null || timezone.length === 0) {\r\n    timezone = getDefaultTimezone();\r\n    console.warn(`getTimeFromTimeZone - Input timezone is null, returning the local (${timezone}) time. `);\r\n  }\r\n  const utcOffset = moment.tz.zone(timezone).utcOffset(time * 1000);\r\n  const currentOffset = moment.tz.zone(getDefaultTimezone()).utcOffset(time * 1000);\r\n  // convert to utc and then to selected timezone\r\n  return time + currentOffset * 60 - utcOffset * 60;\r\n}\r\n\r\n/**\r\n * Get time formatted with the provided timezone\r\n */\r\nexport function getTimeString (time: number): string {\r\n   return moment(time).format('YYYY-MM-DD HH:mm:ss');\r\n}\r\n\r\n/**\r\n * Get the time range string by time array, eg: 2018-10-25 10:10:00 ~ 2018-10-25 12:12:00\r\n */\r\nexport function getTimeRangeString(time: any): string {\r\n  let startTimeString = 'N/A';\r\n  let endTimeString = 'N/A';\r\n  let timeRange;\r\n  if (Array.isArray(time)) {\r\n    timeRange = _getTimeRange(time);\r\n  } else {\r\n    timeRange = _getTotalTimeRange(time);\r\n  }\r\n\r\n  if (timeRange) {\r\n    if (timeRange.startTime < 4102358400000) {\r\n      startTimeString = getTimeString(timeRange.startTime);\r\n    }\r\n\r\n    if (timeRange.endTime > 0) {\r\n      endTimeString = getTimeString(timeRange.endTime);\r\n    }\r\n    return `${startTimeString} ~ ${endTimeString}`;\r\n  }\r\n}\r\n\r\n/**\r\n * print processed time from the provided beginTime, only works in dev mode\r\n */\r\nexport function printProcessedTime(beginTime: Date, step: string): void {\r\n  if (isDevMode()) {\r\n    // only do it in dev mode\r\n    const timeAfter = new Date();\r\n    const parsingTime = (timeAfter.getTime() - beginTime.getTime()) / 1000;\r\n    console.log(`${step}, Parsing time: ${parsingTime} seconds`);\r\n  }\r\n}\r\n"]}
@@ -6,8 +6,7 @@ import * as i2$1 from '@angular/forms';
6
6
  import { FormsModule } from '@angular/forms';
7
7
  import * as i1$1 from '@danielmoncada/angular-datetime-picker';
8
8
  import { OwlDateTimeModule, OwlNativeDateTimeModule } from '@danielmoncada/angular-datetime-picker';
9
- import * as moment from 'moment-timezone';
10
- import moment__default from 'moment-timezone';
9
+ import * as moment$2 from 'moment-timezone';
11
10
  import * as i2 from 'ngx-dropdown-list';
12
11
  import { DropdownListModule } from 'ngx-dropdown-list';
13
12
  import { __awaiter } from 'tslib';
@@ -16,7 +15,7 @@ import * as chartjs from 'chart.js';
16
15
  import { Chart as Chart$2 } from 'chart.js';
17
16
  import { parse } from 'papaparse';
18
17
  import * as hammerjs from 'hammerjs';
19
- import moment$1 from 'moment';
18
+ import * as moment_module from 'moment';
20
19
  import * as i8 from 'ngx-selection-table';
21
20
  import { SelectionTableModule } from 'ngx-selection-table';
22
21
 
@@ -550,7 +549,7 @@ function _getTimeRange(time) {
550
549
  * get default local time zone
551
550
  */
552
551
  function getDefaultTimezone() {
553
- return moment__default.tz.guess();
552
+ return moment$2.tz.guess();
554
553
  }
555
554
  /**
556
555
  * Get time from provided timezone, using this only because chart.js doesn't support timezone.
@@ -563,8 +562,8 @@ function getTimeFromTimeZone(time, timezone) {
563
562
  timezone = getDefaultTimezone();
564
563
  console.warn(`getTimeFromTimeZone - Input timezone is null, returning the local (${timezone}) time. `);
565
564
  }
566
- const utcOffset = moment__default.tz.zone(timezone).utcOffset(time * 1000);
567
- const currentOffset = moment__default.tz.zone(getDefaultTimezone()).utcOffset(time * 1000);
565
+ const utcOffset = moment$2.tz.zone(timezone).utcOffset(time * 1000);
566
+ const currentOffset = moment$2.tz.zone(getDefaultTimezone()).utcOffset(time * 1000);
568
567
  // convert to utc and then to selected timezone
569
568
  return time + currentOffset * 60 - utcOffset * 60;
570
569
  }
@@ -572,7 +571,7 @@ function getTimeFromTimeZone(time, timezone) {
572
571
  * Get time formatted with the provided timezone
573
572
  */
574
573
  function getTimeString(time) {
575
- return moment__default(time).format('YYYY-MM-DD HH:mm:ss');
574
+ return moment$2(time).format('YYYY-MM-DD HH:mm:ss');
576
575
  }
577
576
  /**
578
577
  * Get the time range string by time array, eg: 2018-10-25 10:10:00 ~ 2018-10-25 12:12:00
@@ -774,7 +773,7 @@ class TimezoneSelectorService {
774
773
  */
775
774
  getZones() {
776
775
  const timezones = [];
777
- const zones = moment.tz.names();
776
+ const zones = moment$2.tz.names();
778
777
  zones.forEach(zone => {
779
778
  // get region
780
779
  let region;
@@ -831,7 +830,7 @@ class TimezoneSelectorComponent {
831
830
  return tz[tz.length - 1].replace('_', ' ');
832
831
  }
833
832
  _getOffset(zone) {
834
- let offset = moment__default.tz(zone).utcOffset();
833
+ let offset = moment$2.tz(zone).utcOffset();
835
834
  const neg = offset < 0;
836
835
  if (neg) {
837
836
  offset = -1 * offset;
@@ -1942,11 +1941,17 @@ class ChartService {
1942
1941
  * generate configuration for chart and create the chart object.
1943
1942
  */
1944
1943
  buildChart(time, data, yScale, header, headerKey, selection, tableSource, title, defaultItems, zoomCB) {
1945
- return new Promise((resolve) => {
1946
- const ctx = document.getElementById('chartNameServerHistory').getContext('2d');
1947
- const cfg = ChartService._generateChartConfig(time, data, yScale, header, headerKey, selection, tableSource, title, defaultItems, zoomCB);
1948
- this._chart = new Chart$2(ctx, cfg);
1949
- resolve();
1944
+ return new Promise((resolve, reject) => {
1945
+ var _a;
1946
+ const ctx = (_a = document.getElementById('chartNameServerHistory')) === null || _a === void 0 ? void 0 : _a.getContext('2d');
1947
+ if (ctx) {
1948
+ const cfg = ChartService._generateChartConfig(time, data, yScale, header, headerKey, selection, tableSource, title, defaultItems, zoomCB);
1949
+ this._chart = new Chart$2(ctx, cfg);
1950
+ resolve();
1951
+ }
1952
+ else {
1953
+ reject('Can not find the canvas.');
1954
+ }
1950
1955
  });
1951
1956
  }
1952
1957
  /**
@@ -2706,6 +2711,7 @@ class LTTBDataMipmap extends DataMipmap {
2706
2711
  }
2707
2712
  }
2708
2713
 
2714
+ const moment$1 = (window && window.moment) ? window.moment : moment_module;
2709
2715
  function getCompareValue(value) {
2710
2716
  if (typeof value === 'number') {
2711
2717
  return value;
@@ -2784,6 +2790,7 @@ function cullData(data, range) {
2784
2790
  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
2785
2791
  * SOFTWARE.
2786
2792
  */
2793
+ const moment = (window && window.moment) ? window.moment : moment_module;
2787
2794
  // Using dynamic flag to fix the issue of ng-packagr #696: Lambda not supported
2788
2795
  // @dynamic
2789
2796
  /**
@@ -2840,8 +2847,8 @@ class ResponsiveDownsamplePlugin {
2840
2847
  if (isNil(xScale)) {
2841
2848
  return null;
2842
2849
  }
2843
- const start = moment$1(xScale.getValueForPixel(xScale.left));
2844
- const end = moment$1(xScale.getValueForPixel(xScale.left + 1));
2850
+ const start = moment(xScale.getValueForPixel(xScale.left));
2851
+ const end = moment(xScale.getValueForPixel(xScale.left + 1));
2845
2852
  const targetResolution = end.diff(start);
2846
2853
  return targetResolution * options.desiredDataPointDistance;
2847
2854
  }
@@ -3526,19 +3533,6 @@ class NameServerHistoryComponent {
3526
3533
  this.stepShowChart = false;
3527
3534
  this.searchType = SearchType.searchAll;
3528
3535
  }
3529
- ngOnInit() {
3530
- // this.timezone = this.defaultTimezone;
3531
- this.onResize();
3532
- // init items' status
3533
- // reset chart button will be disable by default later, only be enabled after zoomed
3534
- this._toggleItems([
3535
- { id: HtmlElement.chartArea, status: false },
3536
- { id: HtmlElement.readFileProgress, status: false },
3537
- { id: HtmlElement.showChartButton, status: false },
3538
- { id: HtmlElement.loadPortsButton, status: true },
3539
- { id: HtmlElement.resetChartButton, status: false }
3540
- ]);
3541
- }
3542
3536
  ngOnChanges(changes) {
3543
3537
  return __awaiter(this, void 0, void 0, function* () {
3544
3538
  const fbc = changes.fileBuffer;
@@ -3548,16 +3542,27 @@ class NameServerHistoryComponent {
3548
3542
  yield this.fileSelected(simulatedEvent);
3549
3543
  this.port = undefined; // clear the port selection
3550
3544
  if (this.autoDisplay) {
3551
- this.onResize(); // update the size, otherwise there may have a scrollbar (because of the toast) if auto display is set to true
3552
3545
  this.showChart();
3553
3546
  }
3554
3547
  }
3555
3548
  });
3556
3549
  }
3550
+ ngAfterViewInit() {
3551
+ // init items' status
3552
+ // reset chart button will be disable by default later, only be enabled after zoomed
3553
+ this._toggleItems([
3554
+ { id: HtmlElement.chartArea, status: false },
3555
+ { id: HtmlElement.readFileProgress, status: false },
3556
+ { id: HtmlElement.showChartButton, status: false },
3557
+ { id: HtmlElement.loadPortsButton, status: true },
3558
+ { id: HtmlElement.resetChartButton, status: false }
3559
+ ]);
3560
+ this.onResize(); // update the size, otherwise there may have a scrollbar (because of the toast) if auto display is set to true
3561
+ }
3557
3562
  /**
3558
- * Reset Chart to initial status
3559
- * If legend is already selected/unselected from the list, it wouldn't be restored.
3560
- */
3563
+ * Reset Chart to initial status
3564
+ * If legend is already selected/unselected from the list, it wouldn't be restored.
3565
+ */
3561
3566
  resetChart() {
3562
3567
  this._toggleItems([{ id: HtmlElement.resetChartButton, status: false }]);
3563
3568
  if (this.tableSource && this._selection) {