From 68d9b53d7d7d437204f4f7a780f59d82c81c068d Mon Sep 17 00:00:00 2001 From: Xin Hao Zhang Date: Mon, 21 Mar 2022 15:25:11 -0400 Subject: [PATCH] ui: remove unnecessary uses of lodash in database pages Closes #68820 This commit removes the ue of functions from the lodash function where regular JS can be used. Release note: None --- .../databaseDetailsPage.stories.tsx | 62 +++++++++---------- .../databaseDetailsPage.tsx | 12 ++-- .../databaseTablePage.stories.tsx | 17 +++-- .../databaseTablePage/databaseTablePage.tsx | 3 +- .../databasesPage/databasesPage.stories.tsx | 2 +- .../src/databasesPage/databasesPage.tsx | 5 +- 6 files changed, 47 insertions(+), 54 deletions(-) diff --git a/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.stories.tsx b/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.stories.tsx index c00140b4b5f9..7804bed093b5 100644 --- a/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.stories.tsx +++ b/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.stories.tsx @@ -20,6 +20,7 @@ import { } from "src/storybook/fixtures"; import { DatabaseDetailsPage, + DatabaseDetailsPageDataTable, DatabaseDetailsPageProps, ViewMode, } from "./databaseDetailsPage"; @@ -86,41 +87,40 @@ const withoutData: DatabaseDetailsPageProps = { }, }; +function createTable(): DatabaseDetailsPageDataTable { + const roles = _.uniq(new Array(_.random(1, 3)).map(() => randomRole())); + const grants = _.uniq( + new Array(_.random(1, 5)).map(() => randomTablePrivilege()), + ); + + return { + name: randomName(), + details: { + loading: false, + loaded: true, + columnCount: _.random(5, 42), + indexCount: _.random(1, 6), + userCount: roles.length, + roles: roles, + grants: grants, + statsLastUpdated: moment("0001-01-01T00:00:00Z"), + }, + stats: { + loading: false, + loaded: true, + replicationSizeInBytes: _.random(1000.0) * 1024 ** _.random(1, 2), + rangeCount: _.random(50, 500), + nodesByRegionString: + "gcp-europe-west1(n8), gcp-us-east1(n1), gcp-us-west1(n6)", + }, + }; +} + const withData: DatabaseDetailsPageProps = { loading: false, loaded: true, name: randomName(), - tables: _.map(Array(42), _item => { - const roles = _.uniq( - _.map(new Array(_.random(1, 3)), _item => randomRole()), - ); - const grants = _.uniq( - _.map(new Array(_.random(1, 5)), _item => randomTablePrivilege()), - ); - - return { - name: randomName(), - details: { - loading: false, - loaded: true, - columnCount: _.random(5, 42), - indexCount: _.random(1, 6), - userCount: roles.length, - roles: roles, - grants: grants, - statsLastUpdated: moment("0001-01-01T00:00:00Z"), - }, - showNodeRegionsColumn: true, - stats: { - loading: false, - loaded: true, - replicationSizeInBytes: _.random(1000.0) * 1024 ** _.random(1, 2), - rangeCount: _.random(50, 500), - nodesByRegionString: - "gcp-europe-west1(n8), gcp-us-east1(n1), gcp-us-west1(n6)", - }, - }; - }), + tables: [createTable()], viewMode: ViewMode.Tables, sortSettingTables: { ascending: false, diff --git a/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.tsx b/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.tsx index 1ddde24a6c83..16bc3876ffe5 100644 --- a/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.tsx +++ b/pkg/ui/workspaces/cluster-ui/src/databaseDetailsPage/databaseDetailsPage.tsx @@ -12,8 +12,6 @@ import React from "react"; import { Link, RouteComponentProps } from "react-router-dom"; import { Tooltip } from "antd"; import classNames from "classnames/bind"; -import _ from "lodash"; - import { Breadcrumbs } from "src/breadcrumbs"; import { Dropdown, DropdownOption } from "src/dropdown"; import { CaretRight } from "src/icon/caretRight"; @@ -203,7 +201,7 @@ export class DatabaseDetailsPage extends React.Component< return this.props.refreshDatabaseDetails(this.props.name); } - _.forEach(this.props.tables, table => { + this.props.tables.forEach(table => { if (!table.details.loaded && !table.details.loading) { return this.props.refreshTableDetails(this.props.name, table.name); } @@ -417,8 +415,8 @@ export class DatabaseDetailsPage extends React.Component< Roles ), - cell: table => _.join(table.details.roles, ", "), - sort: table => _.join(table.details.roles, ", "), + cell: table => table.details.roles.join(", "), + sort: table => table.details.roles.join(", "), className: cx("database-table__col-roles"), name: "roles", }, @@ -428,8 +426,8 @@ export class DatabaseDetailsPage extends React.Component< Grants ), - cell: table => _.join(table.details.grants, ", "), - sort: table => _.join(table.details.grants, ", "), + cell: table => table.details.grants.join(", "), + sort: table => table.details.grants.join(", "), className: cx("database-table__col-grants"), name: "grants", }, diff --git a/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.stories.tsx b/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.stories.tsx index bb444ba90f9d..5922cb4fa92a 100644 --- a/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.stories.tsx +++ b/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.stories.tsx @@ -10,7 +10,6 @@ import React from "react"; import { storiesOf } from "@storybook/react"; -import _ from "lodash"; import { withBackground, withRouterProvider } from "src/storybook/decorators"; import { @@ -84,15 +83,13 @@ const withData: DatabaseTablePageProps = { ) `, replicaCount: 7, - indexNames: _.map(Array(3), randomName), - grants: _.uniq( - _.map(Array(12), () => { - return { - user: randomRole(), - privilege: randomTablePrivilege(), - }; - }), - ), + indexNames: Array(3).map(randomName), + grants: [ + { + user: randomRole(), + privilege: randomTablePrivilege(), + }, + ], statsLastUpdated: moment("0001-01-01T00:00:00Z"), }, showNodeRegionsSection: true, diff --git a/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.tsx b/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.tsx index 5c8cf2d89c23..37b703465815 100644 --- a/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.tsx +++ b/pkg/ui/workspaces/cluster-ui/src/databaseTablePage/databaseTablePage.tsx @@ -12,7 +12,6 @@ import React from "react"; import { Col, Row, Tabs } from "antd"; import { RouteComponentProps } from "react-router-dom"; import classNames from "classnames/bind"; -import _ from "lodash"; import { Tooltip } from "antd"; import { Heading } from "@cockroachlabs/ui-components"; @@ -421,7 +420,7 @@ export class DatabaseTablePage extends React.Component< /> diff --git a/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.stories.tsx b/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.stories.tsx index 5107bbb00052..a8d94beb51cd 100644 --- a/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.stories.tsx +++ b/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.stories.tsx @@ -76,7 +76,7 @@ const withData: DatabasesPageProps = { ascending: false, columnTitle: "name", }, - databases: _.map(Array(42), _item => { + databases: Array(42).map(() => { return { loading: false, loaded: true, diff --git a/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.tsx b/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.tsx index ba9ee87f54a0..9564f00ad541 100644 --- a/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.tsx +++ b/pkg/ui/workspaces/cluster-ui/src/databasesPage/databasesPage.tsx @@ -12,7 +12,6 @@ import React from "react"; import { Link, RouteComponentProps } from "react-router-dom"; import { Tooltip } from "antd"; import classNames from "classnames/bind"; -import _ from "lodash"; import { Anchor } from "src/anchor"; import { StackIcon } from "src/icon/stackIcon"; @@ -175,12 +174,12 @@ export class DatabasesPage extends React.Component< return this.props.refreshDatabases(); } - _.forEach(this.props.databases, database => { + this.props.databases.forEach(database => { if (!database.loaded && !database.loading) { return this.props.refreshDatabaseDetails(database.name); } - _.forEach(database.missingTables, table => { + database.missingTables.forEach(table => { if (!table.loading) { return this.props.refreshTableStats(database.name, table.name); }