UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

111 lines 16.2 kB
import dayjs from 'dayjs'; import { last, max } from 'lodash-es'; import { DATE_FORMAT } from '../core/constants/public-api'; import { UNITS } from '../core/utils/public-api'; export const BASE_UNITS = ['K', 'M', 'G', 'T', 'P', 'E']; export const MEMORY_UNITS = BASE_UNITS.map(unit => unit + 'i'); export var UnitType; (function (UnitType) { UnitType["MEMORY"] = "memory"; UnitType["CAPACITY"] = "capacity"; })(UnitType || (UnitType = {})); export const MATCH_UNIT_DEFAULT_BASE = 1024; export const UnitMap = { [UnitType.MEMORY]: MEMORY_UNITS, [UnitType.CAPACITY]: UNITS, }; const _matchUnit = (value, { base = MATCH_UNIT_DEFAULT_BASE, threshold = 800, unitType = UnitType.CAPACITY, groups, unitRange, baseUnit, } = {}) => { const units = unitRange || UnitMap[unitType]; if (!value) { return { unit: baseUnit || units[0], units }; } const cloneUnits = units.map(item => item); const index = units.indexOf(baseUnit || units[0]); const isPositive = value > threshold; const unitsList = isPositive ? cloneUnits.splice(index) : cloneUnits.splice(0, index + 1).reverse(); let unitBase = 1; for (const unit of unitsList) { const _base = groups?.find(g => g.range?.slice(0, -1)?.includes(unit))?.base || base; if (value <= threshold) { return { unit, base: unitBase, units: unitsList }; } isPositive ? (unitBase *= _base) : (unitBase /= _base); isPositive ? (value /= _base) : (value *= _base); } return { unit: last(unitsList), base: unitBase, units: unitsList }; }; export const matchUnit = (value, params) => { const { unit, units, base } = _matchUnit(value, params); return { unit, base, exponent: units.indexOf(unit), }; }; export const adaptUnit = (seriesOrMetrics, params) => matchUnit(max(seriesOrMetrics.flatMap(({ data, values = data }) => values.map(d => d.y))), params); export function getTimeValueOf(value) { return dayjs(value).valueOf() / 1000; } export const CHART_DATA_FORMAT = `${DATE_FORMAT} HH:mm`; export const getTimeRanges = (value, unit) => ({ start: () => dateTimeRounding(dayjs().subtract(value, unit)), end: () => dayjs().format(CHART_DATA_FORMAT), startTime: () => getTimeValueOf(dateTimeRounding(dayjs().subtract(value, unit))), endTime: () => getTimeValueOf(dayjs().format(CHART_DATA_FORMAT)), }); export function dateTimeRounding(value) { return dayjs(value).format(CHART_DATA_FORMAT); } export const PICKER_TIME_RANGES = [ { name: 'nearly_30_minute', ...getTimeRanges(30, 'm'), step: 30, zoomStep: 30, }, { name: 'nearly_1_hour', ...getTimeRanges(1, 'hour'), step: 60, zoomStep: 30, }, { name: 'nearly_3_hour', ...getTimeRanges(3, 'hour'), step: ((3 * 60) / 60) * 60, zoomStep: ((3 * 60) / 360) * 60, }, { name: 'nearly_6_hour', ...getTimeRanges(6, 'hour'), step: ((6 * 60) / 120) * 60, zoomStep: ((6 * 60) / 720) * 60, }, { name: 'nearly_12_hour', ...getTimeRanges(12, 'hour'), step: ((12 * 60) / 120) * 60, zoomStep: ((12 * 60) / 720) * 60, }, { name: 'nearly_1_day', ...getTimeRanges(1, 'day'), step: ((24 * 60) / 120) * 60, zoomStep: ((24 * 60) / 720) * 60, }, { name: 'nearly_3_day', ...getTimeRanges(3, 'day'), step: ((3 * 24 * 60) / 120) * 60, zoomStep: ((3 * 24 * 60) / 720) * 60, }, { name: 'nearly_7_day', ...getTimeRanges(7, 'day'), step: ((7 * 24 * 60) / 120) * 60, zoomStep: ((7 * 24 * 60) / 720) * 60, }, ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../../../libs/common/src/metric-chart/helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import dayjs, { Dayjs, ManipulateType } from 'dayjs';\nimport { last, max } from 'lodash-es';\n\nimport { DATE_FORMAT } from '../core/constants/public-api';\nimport { UNITS } from '../core/utils/public-api';\n\nimport { PickerTimeRanges } from './types';\n\nexport const BASE_UNITS = ['K', 'M', 'G', 'T', 'P', 'E'] as const;\nexport const MEMORY_UNITS = BASE_UNITS.map(unit => unit + 'i');\n\nexport enum UnitType {\n  MEMORY = 'memory',\n  CAPACITY = 'capacity',\n}\n\nexport interface MatchUnitParams {\n  base?: number;\n  threshold?: number;\n  unitType?: UnitType;\n  unitRange?: string[];\n  defaultPrefix?: boolean;\n  prefix?: string;\n  baseUnit?: string;\n  groups?: Array<{ base: number; range: string[] }>;\n}\n\nexport const MATCH_UNIT_DEFAULT_BASE = 1024;\n\nexport const UnitMap: { [key: string]: readonly string[] } = {\n  [UnitType.MEMORY]: MEMORY_UNITS,\n  [UnitType.CAPACITY]: UNITS,\n};\n\nconst _matchUnit = (\n  value: number,\n  {\n    base = MATCH_UNIT_DEFAULT_BASE,\n    threshold = 800,\n    unitType = UnitType.CAPACITY,\n    groups,\n    unitRange,\n    baseUnit,\n  }: MatchUnitParams = {},\n) => {\n  const units = unitRange || UnitMap[unitType];\n  if (!value) {\n    return { unit: baseUnit || units[0], units };\n  }\n  const cloneUnits = units.map(item => item);\n  const index = units.indexOf(baseUnit || units[0]);\n  const isPositive = value > threshold;\n  const unitsList = isPositive\n    ? cloneUnits.splice(index)\n    : cloneUnits.splice(0, index + 1).reverse();\n  let unitBase = 1;\n  for (const unit of unitsList) {\n    const _base: number =\n      groups?.find(g => g.range?.slice(0, -1)?.includes(unit))?.base || base;\n    if (value <= threshold) {\n      return { unit, base: unitBase, units: unitsList };\n    }\n    isPositive ? (unitBase *= _base) : (unitBase /= _base);\n    isPositive ? (value /= _base) : (value *= _base);\n  }\n  return { unit: last(unitsList), base: unitBase, units: unitsList };\n};\n\nexport const matchUnit = (value: number, params?: MatchUnitParams) => {\n  const { unit, units, base } = _matchUnit(value, params);\n  return {\n    unit,\n    base,\n    exponent: units.indexOf(unit),\n  };\n};\n\nexport const adaptUnit = (\n  seriesOrMetrics: Array<{\n    data?: Array<{ x: number; y: number }>;\n    values?: Array<{ x: number; y: number }>;\n  }>,\n  params?: MatchUnitParams,\n) =>\n  matchUnit(\n    max<number>(\n      seriesOrMetrics.flatMap(({ data, values = data }) =>\n        values.map(d => d.y),\n      ),\n    ),\n    params,\n  );\n\nexport function getTimeValueOf(value: string) {\n  return dayjs(value).valueOf() / 1000;\n}\n\nexport const CHART_DATA_FORMAT = `${DATE_FORMAT} HH:mm`;\n\nexport const getTimeRanges = (value: number, unit: ManipulateType) => ({\n  start: () => dateTimeRounding(dayjs().subtract(value, unit)),\n  end: () => dayjs().format(CHART_DATA_FORMAT),\n  startTime: () =>\n    getTimeValueOf(dateTimeRounding(dayjs().subtract(value, unit))),\n  endTime: () => getTimeValueOf(dayjs().format(CHART_DATA_FORMAT)),\n});\n\nexport function dateTimeRounding(value: number | Dayjs) {\n  return dayjs(value).format(CHART_DATA_FORMAT);\n}\n\nexport const PICKER_TIME_RANGES: PickerTimeRanges[] = [\n  {\n    name: 'nearly_30_minute',\n    ...getTimeRanges(30, 'm'),\n    step: 30,\n    zoomStep: 30,\n  },\n  {\n    name: 'nearly_1_hour',\n    ...getTimeRanges(1, 'hour'),\n    step: 60,\n    zoomStep: 30,\n  },\n  {\n    name: 'nearly_3_hour',\n    ...getTimeRanges(3, 'hour'),\n    step: ((3 * 60) / 60) * 60,\n    zoomStep: ((3 * 60) / 360) * 60,\n  },\n  {\n    name: 'nearly_6_hour',\n    ...getTimeRanges(6, 'hour'),\n    step: ((6 * 60) / 120) * 60,\n    zoomStep: ((6 * 60) / 720) * 60,\n  },\n  {\n    name: 'nearly_12_hour',\n    ...getTimeRanges(12, 'hour'),\n    step: ((12 * 60) / 120) * 60,\n    zoomStep: ((12 * 60) / 720) * 60,\n  },\n  {\n    name: 'nearly_1_day',\n    ...getTimeRanges(1, 'day'),\n    step: ((24 * 60) / 120) * 60,\n    zoomStep: ((24 * 60) / 720) * 60,\n  },\n  {\n    name: 'nearly_3_day',\n    ...getTimeRanges(3, 'day'),\n    step: ((3 * 24 * 60) / 120) * 60,\n    zoomStep: ((3 * 24 * 60) / 720) * 60,\n  },\n  {\n    name: 'nearly_7_day',\n    ...getTimeRanges(7, 'day'),\n    step: ((7 * 24 * 60) / 120) * 60,\n    zoomStep: ((7 * 24 * 60) / 720) * 60,\n  },\n];\n"]}