diff --git a/nerdlets/observability-maps-nerdlet/components/node/edit/drilldown-dashboard.js b/nerdlets/observability-maps-nerdlet/components/node/edit/drilldown-dashboard.js index 4c25a05..f316876 100644 --- a/nerdlets/observability-maps-nerdlet/components/node/edit/drilldown-dashboard.js +++ b/nerdlets/observability-maps-nerdlet/components/node/edit/drilldown-dashboard.js @@ -3,10 +3,17 @@ no-console: 0 */ import React from 'react'; -import { Button, Form, Table, Radio, Input } from 'semantic-ui-react'; +import { Button, Form, Radio, Input } from 'semantic-ui-react'; import { DataConsumer } from '../../../context/data'; import { nerdGraphQuery, DashboardQuery } from '../../../lib/utils'; -import { Spinner } from 'nr1'; +import { + Spinner, + Table, + TableHeader, + TableHeaderCell, + TableRow, + TableRowCell +} from 'nr1'; export default class DrilldownDashboard extends React.PureComponent { constructor(props) { @@ -16,40 +23,39 @@ export default class DrilldownDashboard extends React.PureComponent { searchedDashboards: [], showSearchMsg: false, selectedDash: null, - searchText: '' + searchText: '', + fetchingDashboards: false }; } - fetchDashboards = async cursor => { - let { selectedAccount, searchedDashboards } = this.state; - // if no cursor its a new search so empty entities - if (!cursor) { - searchedDashboards = []; - } + fetchDashboards = async (init, cursor, incomingResults) => { + const { selectedAccount } = this.state; + + let results = init ? [] : incomingResults; const nerdGraphResult = await nerdGraphQuery( - DashboardQuery(selectedAccount) + DashboardQuery(selectedAccount, cursor) ); const dashboardSearchResults = (((nerdGraphResult || {}).actor || {}).entitySearch || {}).results || {}; // let foundGuids = ((entitySearchResults || {}).entities || []).map((result)=>result.guid) - searchedDashboards = [ - ...searchedDashboards, - ...dashboardSearchResults.entities - ]; - this.setState({ searchedDashboards }, () => { - if (dashboardSearchResults.nextCursor) { - console.log( - 'collecting next dashboardSearch batch guid:', - dashboardSearchResults.nextCursor - ); - this.fetchEntities(dashboardSearchResults.nextCursor); - } else { - // console.log("complete", this.state.searchedEntities.length) + results = [...results, ...dashboardSearchResults.entities]; + + if (dashboardSearchResults.nextCursor) { + console.log( + 'collecting next dashboardSearch batch guid:', + dashboardSearchResults.nextCursor + ); + this.fetchDashboards(false, dashboardSearchResults.nextCursor, results); + } else { + console.log('complete', results.length); + this.setState({ searchedDashboards: results, fetchingDashboards: false }); + + if (results.length === 0) { + this.setState({ showSearchMsg: true }); } - this.setState({ showSearchMsg: true }); - }); + } }; updateDashboard = async ( @@ -72,7 +78,8 @@ export default class DrilldownDashboard extends React.PureComponent { searchedDashboards, showSearchMsg, selectedDash, - searchText + searchText, + fetchingDashboards } = this.state; return ( @@ -87,6 +94,12 @@ export default class DrilldownDashboard extends React.PureComponent { const currentDash = mapConfig.nodeData[selectedNode].dashboard; const addDisabled = selectedAccount === null || selectedDash === null; + const filteredDashboards = searchedDashboards.filter(dash => + dash.name + ? dash.name.toLowerCase().includes(searchText.toLowerCase()) + : false + ); + if (accountOptions) { return ( <> @@ -102,12 +115,17 @@ export default class DrilldownDashboard extends React.PureComponent { } /> { - this.fetchDashboards(); + this.setState( + { fetchingDashboards: true, searchedDashboards: [] }, + () => { + this.fetchDashboards(true); + } + ); }} /> @@ -126,6 +144,15 @@ export default class DrilldownDashboard extends React.PureComponent { } /> +
+ +
No entities found with accountId = {selectedAccount}.
+ {}
- - - {searchedDashboards - .filter(dash => - dash.name - ? dash.name - .toLowerCase() - .includes(searchText.toLowerCase()) - : false - ) - .map((dash, i) => { - return ( - - {dash.name} - - - this.setState({ selectedDash: dash.guid }) - } - /> - - - ); - })} - +
+ + Name + Select + + {({ item }) => ( + + {item.name} + + + this.setState({ selectedDash: item.guid }) + } + /> + + + )}

diff --git a/nerdlets/observability-maps-nerdlet/lib/utils.js b/nerdlets/observability-maps-nerdlet/lib/utils.js index d3bdf80..1fe74de 100644 --- a/nerdlets/observability-maps-nerdlet/lib/utils.js +++ b/nerdlets/observability-maps-nerdlet/lib/utils.js @@ -119,9 +119,11 @@ export const entitySearchByAccountQuery = (domain, accountId, cursor) => { return ngql`{ actor { - entitySearch(query: "domain IN ('${domain}') ${subType ? `AND type = '${subType}'` : `` - } AND reporting = 'true' ${accountId ? `AND tags.accountId IN ('${accountId}')` : '' - }") { + entitySearch(query: "domain IN ('${domain}') ${ + subType ? `AND type = '${subType}'` : `` + } AND reporting = 'true' ${ + accountId ? `AND tags.accountId IN ('${accountId}')` : '' + }") { query results${cursor ? `(cursor: "${cursor}")` : ''} { nextCursor @@ -571,10 +573,11 @@ export const InfraEntityBatchQuery = guids => { }`; }; -export const DashboardQuery = accountId => `{ +export const DashboardQuery = (accountId, cursor) => `{ actor { entitySearch(query: "accountId=${accountId} and type='DASHBOARD'") { - results { + results${cursor ? `(cursor: "${cursor}")` : ''} { + nextCursor entities { accountId guid