ngx-hana-nameserver-history-viewer 1.1.9-8.beta → 1.1.9-9.3.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.
- package/esm2020/src/nameserver-history-viewer/components/nameserver-history.component.mjs +9 -6
- package/esm2020/src/nameserver-history-viewer/components/port-selector/port-selector.component.mjs +3 -3
- package/esm2020/src/nameserver-history-viewer/components/timezone-selector/timezone-selector.component.mjs +2 -2
- package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/data_culling.mjs +2 -3
- package/esm2020/src/nameserver-history-viewer/utils/chartjs-downsample/responsive_downsample_plugin.mjs +2 -3
- package/esm2020/src/nameserver-history-viewer/utils/time-util.mjs +3 -12
- package/fesm2015/ngx-hana-nameserver-history-viewer.mjs +38 -40
- package/fesm2015/ngx-hana-nameserver-history-viewer.mjs.map +1 -1
- package/fesm2020/ngx-hana-nameserver-history-viewer.mjs +21 -28
- package/fesm2020/ngx-hana-nameserver-history-viewer.mjs.map +1 -1
- package/package.json +4 -4
- package/src/nameserver-history-viewer/components/nameserver-history.component.d.ts +7 -3
- package/src/nameserver-history-viewer/utils/chartjs-downsample/data_culling.d.ts +2 -2
|
@@ -22,8 +22,7 @@
|
|
|
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
|
|
26
|
-
const moment = (window && window.moment) ? window.moment : moment_module;
|
|
25
|
+
import moment from 'moment';
|
|
27
26
|
import * as utils from './utils';
|
|
28
27
|
import { DataMipmap } from './data_mipmap';
|
|
29
28
|
import { LTTBDataMipmap } from './lttb_data_mipmap';
|
|
@@ -165,4 +164,4 @@ export class ResponsiveDownsamplePlugin {
|
|
|
165
164
|
}
|
|
166
165
|
}
|
|
167
166
|
}
|
|
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, ChartData, 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"]}
|
|
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"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { isDevMode } from '@angular/core';
|
|
2
2
|
import { getIgnoredLineNumFromTail } from './ui-util';
|
|
3
|
-
import
|
|
3
|
+
import moment from 'moment-timezone';
|
|
4
4
|
/**
|
|
5
5
|
* get the time range for all ports
|
|
6
6
|
*/
|
|
@@ -60,16 +60,7 @@ export function getTimeFromTimeZone(time, timezone) {
|
|
|
60
60
|
* Get time formatted with the provided timezone
|
|
61
61
|
*/
|
|
62
62
|
export function getTimeString(time) {
|
|
63
|
-
|
|
64
|
-
const dateTime = new Date(time);
|
|
65
|
-
const year = dateTime.getFullYear();
|
|
66
|
-
const month = ('0' + (dateTime.getMonth() + 1)).slice(-2);
|
|
67
|
-
const date = ('0' + dateTime.getDate()).slice(-2);
|
|
68
|
-
const hour = ('0' + dateTime.getHours()).slice(-2);
|
|
69
|
-
const minute = ('0' + dateTime.getMinutes()).slice(-2);
|
|
70
|
-
const second = ('0' + dateTime.getSeconds()).slice(-2);
|
|
71
|
-
return `${year}-${month}-${date} ${hour}:${minute}:${second}}`;
|
|
72
|
-
// return moment(time).format('YYYY-MM-DD HH:mm:ss');
|
|
63
|
+
return moment(time).format('YYYY-MM-DD HH:mm:ss');
|
|
73
64
|
}
|
|
74
65
|
/**
|
|
75
66
|
* Get the time range string by time array, eg: 2018-10-25 10:10:00 ~ 2018-10-25 12:12:00
|
|
@@ -105,4 +96,4 @@ export function printProcessedTime(beginTime, step) {
|
|
|
105
96
|
console.log(`${step}, Parsing time: ${parsingTime} seconds`);
|
|
106
97
|
}
|
|
107
98
|
}
|
|
108
|
-
//# 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    console.log('3333312', time, '4444434', moment(time));\r\n\r\n    const dateTime = new Date(time);\r\n    const year = dateTime.getFullYear();\r\n    const month = ('0' + (dateTime.getMonth() + 1)).slice(-2);\r\n    const date = ('0' + dateTime.getDate()).slice(-2);\r\n    const hour = ('0' + dateTime.getHours()).slice(-2);\r\n    const minute = ('0' + dateTime.getMinutes()).slice(-2);\r\n    const second = ('0' + dateTime.getSeconds()).slice(-2);\r\n\r\n    return `${year}-${month}-${date} ${hour}:${minute}:${second}}`;\r\n\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 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,15 +6,17 @@ 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
|
|
9
|
+
import * as moment from 'moment-timezone';
|
|
10
|
+
import moment__default from 'moment-timezone';
|
|
10
11
|
import * as i2 from 'ngx-dropdown-list';
|
|
11
12
|
import { DropdownListModule } from 'ngx-dropdown-list';
|
|
13
|
+
import { __awaiter } from 'tslib';
|
|
12
14
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
13
15
|
import * as chartjs from 'chart.js';
|
|
14
16
|
import { Chart as Chart$2 } from 'chart.js';
|
|
15
17
|
import { parse } from 'papaparse';
|
|
16
18
|
import * as hammerjs from 'hammerjs';
|
|
17
|
-
import
|
|
19
|
+
import moment$1 from 'moment';
|
|
18
20
|
import * as i8 from 'ngx-selection-table';
|
|
19
21
|
import { SelectionTableModule } from 'ngx-selection-table';
|
|
20
22
|
|
|
@@ -548,7 +550,7 @@ function _getTimeRange(time) {
|
|
|
548
550
|
* get default local time zone
|
|
549
551
|
*/
|
|
550
552
|
function getDefaultTimezone() {
|
|
551
|
-
return
|
|
553
|
+
return moment__default.tz.guess();
|
|
552
554
|
}
|
|
553
555
|
/**
|
|
554
556
|
* Get time from provided timezone, using this only because chart.js doesn't support timezone.
|
|
@@ -561,8 +563,8 @@ function getTimeFromTimeZone(time, timezone) {
|
|
|
561
563
|
timezone = getDefaultTimezone();
|
|
562
564
|
console.warn(`getTimeFromTimeZone - Input timezone is null, returning the local (${timezone}) time. `);
|
|
563
565
|
}
|
|
564
|
-
const utcOffset =
|
|
565
|
-
const currentOffset =
|
|
566
|
+
const utcOffset = moment__default.tz.zone(timezone).utcOffset(time * 1000);
|
|
567
|
+
const currentOffset = moment__default.tz.zone(getDefaultTimezone()).utcOffset(time * 1000);
|
|
566
568
|
// convert to utc and then to selected timezone
|
|
567
569
|
return time + currentOffset * 60 - utcOffset * 60;
|
|
568
570
|
}
|
|
@@ -570,16 +572,7 @@ function getTimeFromTimeZone(time, timezone) {
|
|
|
570
572
|
* Get time formatted with the provided timezone
|
|
571
573
|
*/
|
|
572
574
|
function getTimeString(time) {
|
|
573
|
-
|
|
574
|
-
const dateTime = new Date(time);
|
|
575
|
-
const year = dateTime.getFullYear();
|
|
576
|
-
const month = ('0' + (dateTime.getMonth() + 1)).slice(-2);
|
|
577
|
-
const date = ('0' + dateTime.getDate()).slice(-2);
|
|
578
|
-
const hour = ('0' + dateTime.getHours()).slice(-2);
|
|
579
|
-
const minute = ('0' + dateTime.getMinutes()).slice(-2);
|
|
580
|
-
const second = ('0' + dateTime.getSeconds()).slice(-2);
|
|
581
|
-
return `${year}-${month}-${date} ${hour}:${minute}:${second}}`;
|
|
582
|
-
// return moment(time).format('YYYY-MM-DD HH:mm:ss');
|
|
575
|
+
return moment__default(time).format('YYYY-MM-DD HH:mm:ss');
|
|
583
576
|
}
|
|
584
577
|
/**
|
|
585
578
|
* Get the time range string by time array, eg: 2018-10-25 10:10:00 ~ 2018-10-25 12:12:00
|
|
@@ -781,7 +774,7 @@ class TimezoneSelectorService {
|
|
|
781
774
|
*/
|
|
782
775
|
getZones() {
|
|
783
776
|
const timezones = [];
|
|
784
|
-
const zones = moment
|
|
777
|
+
const zones = moment.tz.names();
|
|
785
778
|
zones.forEach(zone => {
|
|
786
779
|
// get region
|
|
787
780
|
let region;
|
|
@@ -838,7 +831,7 @@ class TimezoneSelectorComponent {
|
|
|
838
831
|
return tz[tz.length - 1].replace('_', ' ');
|
|
839
832
|
}
|
|
840
833
|
_getOffset(zone) {
|
|
841
|
-
let offset =
|
|
834
|
+
let offset = moment__default.tz(zone).utcOffset();
|
|
842
835
|
const neg = offset < 0;
|
|
843
836
|
if (neg) {
|
|
844
837
|
offset = -1 * offset;
|
|
@@ -957,7 +950,7 @@ class PortSelectorComponent {
|
|
|
957
950
|
}
|
|
958
951
|
PortSelectorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PortSelectorComponent, deps: [{ token: PortSelectorService }], target: i0.ɵɵFactoryTarget.Component });
|
|
959
952
|
PortSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PortSelectorComponent, selector: "port-selector", inputs: { disabled: "disabled", port: "port", ports: "ports" }, outputs: { portChange: "portChange" }, providers: [PortSelectorService], ngImport: i0, template: `
|
|
960
|
-
<label>
|
|
953
|
+
<label style="width: 100%">
|
|
961
954
|
<ngx-dropdown-list (selectionChange)="onChange($event)"
|
|
962
955
|
[items]="displayPorts"
|
|
963
956
|
[multiSelection]="false"
|
|
@@ -973,7 +966,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
973
966
|
args: [{
|
|
974
967
|
selector: 'port-selector',
|
|
975
968
|
template: `
|
|
976
|
-
<label>
|
|
969
|
+
<label style="width: 100%">
|
|
977
970
|
<ngx-dropdown-list (selectionChange)="onChange($event)"
|
|
978
971
|
[items]="displayPorts"
|
|
979
972
|
[multiSelection]="false"
|
|
@@ -2713,7 +2706,6 @@ class LTTBDataMipmap extends DataMipmap {
|
|
|
2713
2706
|
}
|
|
2714
2707
|
}
|
|
2715
2708
|
|
|
2716
|
-
const moment$1 = (window && window.moment) ? window.moment : moment_module;
|
|
2717
2709
|
function getCompareValue(value) {
|
|
2718
2710
|
if (typeof value === 'number') {
|
|
2719
2711
|
return value;
|
|
@@ -2792,7 +2784,6 @@ function cullData(data, range) {
|
|
|
2792
2784
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
2793
2785
|
* SOFTWARE.
|
|
2794
2786
|
*/
|
|
2795
|
-
const moment = (window && window.moment) ? window.moment : moment_module;
|
|
2796
2787
|
// Using dynamic flag to fix the issue of ng-packagr #696: Lambda not supported
|
|
2797
2788
|
// @dynamic
|
|
2798
2789
|
/**
|
|
@@ -2849,8 +2840,8 @@ class ResponsiveDownsamplePlugin {
|
|
|
2849
2840
|
if (isNil(xScale)) {
|
|
2850
2841
|
return null;
|
|
2851
2842
|
}
|
|
2852
|
-
const start = moment(xScale.getValueForPixel(xScale.left));
|
|
2853
|
-
const end = moment(xScale.getValueForPixel(xScale.left + 1));
|
|
2843
|
+
const start = moment$1(xScale.getValueForPixel(xScale.left));
|
|
2844
|
+
const end = moment$1(xScale.getValueForPixel(xScale.left + 1));
|
|
2854
2845
|
const targetResolution = end.diff(start);
|
|
2855
2846
|
return targetResolution * options.desiredDataPointDistance;
|
|
2856
2847
|
}
|
|
@@ -3549,12 +3540,15 @@ class NameServerHistoryComponent {
|
|
|
3549
3540
|
]);
|
|
3550
3541
|
}
|
|
3551
3542
|
ngOnChanges(changes) {
|
|
3552
|
-
|
|
3553
|
-
|
|
3554
|
-
|
|
3555
|
-
|
|
3556
|
-
|
|
3557
|
-
|
|
3543
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
3544
|
+
const fbc = changes.fileBuffer;
|
|
3545
|
+
if (fbc && fbc.currentValue && fbc.currentValue !== fbc.previousValue) {
|
|
3546
|
+
// simulate selecting file
|
|
3547
|
+
const simulatedEvent = { target: { files: [blobToFile(this.fileBuffer, this.streamModeFileName)] } };
|
|
3548
|
+
yield this.fileSelected(simulatedEvent);
|
|
3549
|
+
this.showChart();
|
|
3550
|
+
}
|
|
3551
|
+
});
|
|
3558
3552
|
}
|
|
3559
3553
|
/**
|
|
3560
3554
|
* Reset Chart to initial status
|
|
@@ -3611,17 +3605,19 @@ class NameServerHistoryComponent {
|
|
|
3611
3605
|
* select name server history file, currently only supports 1 file.
|
|
3612
3606
|
*/
|
|
3613
3607
|
fileSelected(event) {
|
|
3614
|
-
|
|
3615
|
-
|
|
3616
|
-
if (
|
|
3617
|
-
|
|
3618
|
-
|
|
3619
|
-
|
|
3620
|
-
|
|
3621
|
-
|
|
3622
|
-
|
|
3608
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
3609
|
+
const selectedFile = getFileFromInput(event.target);
|
|
3610
|
+
if (selectedFile) {
|
|
3611
|
+
if (!isSameFile(this.file, selectedFile)) {
|
|
3612
|
+
// init port selector
|
|
3613
|
+
yield this._initPortSelector().catch(e => this._showMessage(Alert.error, e));
|
|
3614
|
+
this.file = selectedFile;
|
|
3615
|
+
this.abbreviatedFileName = getAbbreviatedFileName(this.file.name);
|
|
3616
|
+
// after file has been selected, the show chart button needs to be enabled
|
|
3617
|
+
this._toggleItems([{ id: HtmlElement.showChartButton, status: true }]);
|
|
3618
|
+
}
|
|
3623
3619
|
}
|
|
3624
|
-
}
|
|
3620
|
+
});
|
|
3625
3621
|
}
|
|
3626
3622
|
/**
|
|
3627
3623
|
* drop name server history file, currently only supports 1 file.
|
|
@@ -3995,7 +3991,7 @@ class NameServerHistoryComponent {
|
|
|
3995
3991
|
}
|
|
3996
3992
|
}
|
|
3997
3993
|
NameServerHistoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NameServerHistoryComponent, deps: [{ token: FileService }, { token: ChartService }, { token: UIService }], target: i0.ɵɵFactoryTarget.Component });
|
|
3998
|
-
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: FileDropInputComponent, selector: "file-drop-input", inputs: ["dropAreaText", "inputAreaText"], outputs: ["fileDrop", "fileInput"] }, { type: ProgressBarComponent, selector: "progress-bar", inputs: ["progress"] }, { type: TimeRangeSelectorComponent, selector: "time-range-selector", inputs: ["disabled", "dateTimeRange"], outputs: ["dateTimeRangeChange"] }, { type: TimezoneSelectorComponent, selector: "timezone-selector", inputs: ["disabled", "timezone"], outputs: ["timezoneChange"] }, { type: PortSelectorComponent, selector: "port-selector", inputs: ["disabled", "port", "ports"], outputs: ["portChange"] }, { type: 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: AlertComponent, selector: "alert", inputs: ["alertMessage", "alertType", "alertTimeout"], outputs: ["alertMessageChange"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
3994
|
+
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", autoDisplay: "autoDisplay" }, 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: FileDropInputComponent, selector: "file-drop-input", inputs: ["dropAreaText", "inputAreaText"], outputs: ["fileDrop", "fileInput"] }, { type: ProgressBarComponent, selector: "progress-bar", inputs: ["progress"] }, { type: TimeRangeSelectorComponent, selector: "time-range-selector", inputs: ["disabled", "dateTimeRange"], outputs: ["dateTimeRangeChange"] }, { type: TimezoneSelectorComponent, selector: "timezone-selector", inputs: ["disabled", "timezone"], outputs: ["timezoneChange"] }, { type: PortSelectorComponent, selector: "port-selector", inputs: ["disabled", "port", "ports"], outputs: ["portChange"] }, { type: 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: AlertComponent, selector: "alert", inputs: ["alertMessage", "alertType", "alertTimeout"], outputs: ["alertMessageChange"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
3999
3995
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: NameServerHistoryComponent, decorators: [{
|
|
4000
3996
|
type: Component,
|
|
4001
3997
|
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"] }]
|
|
@@ -4019,6 +4015,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
4019
4015
|
type: Input
|
|
4020
4016
|
}], streamModeFileName: [{
|
|
4021
4017
|
type: Input
|
|
4018
|
+
}], autoDisplay: [{
|
|
4019
|
+
type: Input
|
|
4022
4020
|
}] } });
|
|
4023
4021
|
|
|
4024
4022
|
class NameserverHistoryModule {
|