/*
* Routes Rendering Columns
*/
import _ from 'underscore'
import React from 'react'
import {connect} from 'react-redux'
import FilterReason
from 'components/routeservers/communities/filter-reason'
import NoexportReason
from 'components/routeservers/communities/noexport-reason'
import {ROUTES_RECEIVED,
ROUTES_FILTERED,
ROUTES_NOT_EXPORTED} from '../actions'
import {PrimaryIndicator,
BlackholeIndicator,
RpkiIndicator,
RejectCandidateIndicator} from './flags'
// Helper: Lookup value in route path
export const _lookup = (r, path) => {
return path.split(".").reduce((acc, elem) => acc[elem], r);
}
export const ColDefault = function(props) {
return (
{_lookup(props.route, props.column)}
|
);
}
// Include filter and noexport reason in this column.
export const ColNetwork = function(props) {
return (
{props.route.network}
|
);
}
// Special AS Path Widget
export const ColAsPath = function(props) {
const asns = _lookup(props.route, "bgp.as_path");
const baseUrl = "http://irrexplorer.nlnog.net/search/"
let asnLinks = asns.map((asn, i) => {
return ({asn} );
});
return (
{asnLinks}
|
);
}
export const ColFlags = function(props) {
return (
|
);
}
// Meta component, decides what to render based on on
// prop 'column'.
export default function(props) {
const widgets = {
"network": ColNetwork,
"flags": ColFlags,
"bgp.as_path": ColAsPath,
"ASPath": ColAsPath,
};
let Widget = widgets[props.column] || ColDefault;
return (
);
}