EVOLUTION-MANAGER
Edit File: UserSyncInfo.tsx
import React, { PureComponent } from 'react'; import { dateTime } from '@grafana/data'; import { LdapUserSyncInfo } from 'app/types'; interface Props { disableSync: boolean; syncInfo: LdapUserSyncInfo; onSync?: () => void; } interface State { isSyncing: boolean; } const syncTimeFormat = 'dddd YYYY-MM-DD HH:mm zz'; export class UserSyncInfo extends PureComponent<Props, State> { state = { isSyncing: false, }; onSyncClick = async () => { const { onSync } = this.props; this.setState({ isSyncing: true }); try { if (onSync) { await onSync(); } } finally { this.setState({ isSyncing: false }); } }; render() { const { syncInfo, disableSync } = this.props; const { isSyncing } = this.state; const nextSyncTime = syncInfo.nextSync ? dateTime(syncInfo.nextSync).format(syncTimeFormat) : ''; const prevSyncSuccessful = syncInfo && syncInfo.prevSync; const prevSyncTime = prevSyncSuccessful ? dateTime(syncInfo.prevSync).format(syncTimeFormat) : ''; const isDisabled = isSyncing || disableSync; return ( <> <button className={`btn btn-secondary pull-right`} onClick={this.onSyncClick} disabled={isDisabled}> <span className="btn-title">Sync user</span> {isSyncing && <i className="fa fa-spinner fa-fw fa-spin run-icon" />} </button> <div className="clearfix" /> <h3 className="page-heading">LDAP</h3> <div className="gf-form-group"> <div className="gf-form"> <table className="filter-table form-inline"> <tbody> <tr> <td>Last synchronisation</td> <td>{prevSyncTime}</td> {prevSyncSuccessful && <td className="pull-right">Successful</td>} </tr> <tr> <td>Next scheduled synchronisation</td> <td colSpan={2}>{nextSyncTime}</td> </tr> </tbody> </table> </div> </div> </> ); } }