1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
import { createExternal,IExternalTableState } from '../../../../framework/src/components/material-table/utilities';
import { createSearchDataHandler } from '../../../../framework/src/utilities/elasticSearch';
import { ConnectionStatusLogType } from '../models/connectionStatusLog';
export interface IConnectionStatusLogState extends IExternalTableState<ConnectionStatusLogType> { }
// create eleactic search material data fetch handler
const connectionStatusLogSearchHandler = createSearchDataHandler<{ event: ConnectionStatusLogType }, ConnectionStatusLogType>('sdnevents_v1/eventlog', null,
(event) => ({
_id: event._id,
timeStamp: event._source.event.timeStamp,
objectId: event._source.event.objectId,
type: event._source.event.type,
elementStatus: event._source.event.type === 'ObjectCreationNotificationXml'
? 'connected'
: event._source.event.type === 'ObjectDeletionNotificationXml'
? 'disconnected'
: 'unknown'
}),
(name) => `event.${ name }`);
export const {
actionHandler: connectionStatusLogActionHandler,
createActions: createConnectionStatusLogActions,
createProperties: createConnectionStatusLogProperties,
reloadAction: connectionStatusLogReloadAction,
// set value action, to change a value
} = createExternal<ConnectionStatusLogType>(connectionStatusLogSearchHandler, appState => appState.connectApp.connectionStatusLog);
|