From 39aa963729624c3c1b9384dbd0ed4ff71ef3dcce Mon Sep 17 00:00:00 2001 From: Vihang Mehta Date: Wed, 5 Oct 2022 15:18:58 -0700 Subject: [PATCH] chore: Replace lodash with ES6 funcs Summary: lodash isn't heavily used in our codebase and ES6 should cover everthing we need anyway so this is just a step towards getting rid of lodash. Test Plan: Ran the dev UI. Checked charts, and their legends. Reviewers: nlanam, zasgar Reviewed By: zasgar Signed-off-by: Vihang Mehta Differential Revision: https://phab.corp.pixielabs.ai/D12351 GitOrigin-RevId: 9fb1a5879fffd677822a167aa850c65edddfb1e9 --- src/ui/src/containers/legend/legend-data.tsx | 34 +++++++++++--------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/ui/src/containers/legend/legend-data.tsx b/src/ui/src/containers/legend/legend-data.tsx index 86c0c3a22ea..9228d0c8932 100644 --- a/src/ui/src/containers/legend/legend-data.tsx +++ b/src/ui/src/containers/legend/legend-data.tsx @@ -16,7 +16,6 @@ * SPDX-License-Identifier: Apache-2.0 */ -import * as _ from 'lodash'; import { View } from 'vega-typings'; import { COLOR_SCALE } from 'app/containers/live/convert-to-vega-spec'; @@ -127,25 +126,28 @@ const keyAvgs = (hoverData: ValidHoverDatum[]): { [key: string]: number } => { keyedAvgState[key].n += 1; }); }); - return _.mapValues(keyedAvgState, (state: { sum: number; n: number }) => { - if (state.n === 0) { - return 0.0; - } - return state.sum / state.n; - }); + return Object.fromEntries( + Object.entries(keyedAvgState).map(([key, state]) => { + if (state.n === 0) { + return [key, 0.0]; + } + return [key, state.sum / state.n]; + }), + ); }; -const buildTimeHashMap = (hoverData: ValidHoverDatum[], sortBy: (key: string) => number): TimeHashMap => { +function buildTimeHashMap( + hoverData: ValidHoverDatum[], + sortBy: (a: UnformattedLegendEntry, b: UnformattedLegendEntry) => number, +): TimeHashMap { const timeHashMap: TimeHashMap = {}; - hoverData.forEach((datum) => { + for (const datum of hoverData) { const rest: UnformattedLegendEntry[] = Object.entries(datum).map((entry) => ({ key: entry[0], val: entry[1] })) - .filter((item) => item.key !== 'time' && item.key !== 'sum'); - // noinspection UnnecessaryLocalVariableJS - const sortedRest = _.sortBy(rest, (item) => sortBy(item.key)); - timeHashMap[datum.time] = sortedRest; - }); + .filter((item) => item.key !== 'time' && item.key !== 'sum').sort(sortBy); + timeHashMap[datum.time] = rest; + } return timeHashMap; -}; +} // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types export const buildHoverDataCache = (hoverData: any): HoverDataCache => { @@ -177,7 +179,7 @@ export const buildHoverDataCache = (hoverData: any): HoverDataCache => { const { minTime, maxTime } = minMaxTimes(validEntries); const keyedAvgs = keyAvgs(validEntries); - const timeHashMap: TimeHashMap = buildTimeHashMap(validEntries, (key) => -keyedAvgs[key]); + const timeHashMap: TimeHashMap = buildTimeHashMap(validEntries, (a, b) => keyedAvgs[b.key] - keyedAvgs[a.key]); return { timeHashMap,