mirror of
https://github.com/portainer/portainer.git
synced 2025-07-23 15:29:42 +02:00
* port services from ee * fix external link * post review improvements * remove applications-ports-datatable * minor post review updates * add services help url * post review update * more post review updates * post review updates * rename index to component * fix external ip display and sorting * fix external apps tag * fix ingress screen time format * use uid for row id. Prevent blank link * fix some missing bits ported from EE * match ee * fix display of show system resources * remove icon next to service type
53 lines
1.2 KiB
TypeScript
53 lines
1.2 KiB
TypeScript
import { CellProps, Column } from 'react-table';
|
|
|
|
import { Service } from '../../types';
|
|
|
|
export const targetPorts: Column<Service> = {
|
|
Header: 'Target Ports',
|
|
id: 'targetPorts',
|
|
accessor: (row) => {
|
|
const ports = row.Ports;
|
|
if (!ports.length) {
|
|
return '-';
|
|
}
|
|
return ports.map((port) => `${port.TargetPort}`);
|
|
},
|
|
Cell: ({ row }: CellProps<Service>) => {
|
|
const ports = row.original.Ports;
|
|
if (!ports.length) {
|
|
return '-';
|
|
}
|
|
return ports.map((port, index) => <div key={index}>{port.TargetPort}</div>);
|
|
},
|
|
disableFilters: true,
|
|
canHide: true,
|
|
|
|
sortType: (rowA, rowB) => {
|
|
const a = rowA.original.Ports;
|
|
const b = rowB.original.Ports;
|
|
|
|
if (!a.length && !b.length) return 0;
|
|
if (!a.length) return 1;
|
|
if (!b.length) return -1;
|
|
|
|
const portA = a[0].TargetPort;
|
|
const portB = b[0].TargetPort;
|
|
|
|
if (portA === portB) {
|
|
if (a.length < b.length) return -1;
|
|
if (a.length > b.length) return 1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
// natural sort of the port
|
|
return portA.localeCompare(
|
|
portB,
|
|
navigator.languages[0] || navigator.language,
|
|
{
|
|
numeric: true,
|
|
ignorePunctuation: true,
|
|
}
|
|
);
|
|
},
|
|
};
|