2020-12-07 13:17:19 +03:00
|
|
|
import { FC, ReactNode } from 'react';
|
|
|
|
import { isEmpty } from 'ramda';
|
|
|
|
import classNames from 'classnames';
|
|
|
|
import { SelectedServer } from '../servers/data';
|
2021-03-06 11:58:29 +03:00
|
|
|
import { supportsShortUrlTitle } from '../utils/helpers/features';
|
2020-12-07 13:17:19 +03:00
|
|
|
import { ShortUrlsList as ShortUrlsListState } from './reducers/shortUrlsList';
|
|
|
|
import { ShortUrlsRowProps } from './helpers/ShortUrlsRow';
|
2021-12-24 15:47:27 +03:00
|
|
|
import { OrderableFields } from './data';
|
2020-12-07 13:17:19 +03:00
|
|
|
import './ShortUrlsTable.scss';
|
|
|
|
|
|
|
|
export interface ShortUrlsTableProps {
|
|
|
|
orderByColumn?: (column: OrderableFields) => () => void;
|
|
|
|
renderOrderIcon?: (column: OrderableFields) => ReactNode;
|
|
|
|
shortUrlsList: ShortUrlsListState;
|
|
|
|
selectedServer: SelectedServer;
|
2020-12-20 11:09:22 +03:00
|
|
|
onTagClick?: (tag: string) => void;
|
2020-12-07 13:17:19 +03:00
|
|
|
className?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const ShortUrlsTable = (ShortUrlsRow: FC<ShortUrlsRowProps>) => ({
|
|
|
|
orderByColumn,
|
|
|
|
renderOrderIcon,
|
|
|
|
shortUrlsList,
|
2020-12-20 11:09:22 +03:00
|
|
|
onTagClick,
|
2020-12-07 13:17:19 +03:00
|
|
|
selectedServer,
|
|
|
|
className,
|
|
|
|
}: ShortUrlsTableProps) => {
|
|
|
|
const { error, loading, shortUrls } = shortUrlsList;
|
2021-03-05 16:20:49 +03:00
|
|
|
const actionableFieldClasses = classNames({ 'short-urls-table__header-cell--with-action': !!orderByColumn });
|
|
|
|
const orderableColumnsClasses = classNames('short-urls-table__header-cell', actionableFieldClasses);
|
2020-12-12 12:56:10 +03:00
|
|
|
const tableClasses = classNames('table table-hover', className);
|
2021-03-06 11:58:29 +03:00
|
|
|
const supportsTitle = supportsShortUrlTitle(selectedServer);
|
2020-12-07 13:17:19 +03:00
|
|
|
|
|
|
|
const renderShortUrls = () => {
|
|
|
|
if (error) {
|
|
|
|
return (
|
|
|
|
<tr>
|
2021-11-09 01:41:17 +03:00
|
|
|
<td colSpan={6} className="text-center table-danger text-dark">
|
|
|
|
Something went wrong while loading short URLs :(
|
|
|
|
</td>
|
2020-12-07 13:17:19 +03:00
|
|
|
</tr>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (loading) {
|
|
|
|
return <tr><td colSpan={6} className="text-center">Loading...</td></tr>;
|
|
|
|
}
|
|
|
|
|
2020-12-15 01:35:31 +03:00
|
|
|
if (!loading && isEmpty(shortUrls?.data)) {
|
2020-12-07 13:17:19 +03:00
|
|
|
return <tr><td colSpan={6} className="text-center">No results found</td></tr>;
|
|
|
|
}
|
|
|
|
|
|
|
|
return shortUrls?.data.map((shortUrl) => (
|
|
|
|
<ShortUrlsRow
|
|
|
|
key={shortUrl.shortUrl}
|
|
|
|
shortUrl={shortUrl}
|
|
|
|
selectedServer={selectedServer}
|
2020-12-20 11:09:22 +03:00
|
|
|
onTagClick={onTagClick}
|
2020-12-07 13:17:19 +03:00
|
|
|
/>
|
|
|
|
));
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<table className={tableClasses}>
|
2021-08-22 11:46:47 +03:00
|
|
|
<thead className="responsive-table__header short-urls-table__header">
|
2020-12-07 13:17:19 +03:00
|
|
|
<tr>
|
|
|
|
<th className={orderableColumnsClasses} onClick={orderByColumn?.('dateCreated')}>
|
2021-11-01 15:41:16 +03:00
|
|
|
Created at {renderOrderIcon?.('dateCreated')}
|
2020-12-07 13:17:19 +03:00
|
|
|
</th>
|
|
|
|
<th className={orderableColumnsClasses} onClick={orderByColumn?.('shortCode')}>
|
2021-11-01 15:41:16 +03:00
|
|
|
Short URL {renderOrderIcon?.('shortCode')}
|
2020-12-07 13:17:19 +03:00
|
|
|
</th>
|
2021-03-05 16:20:49 +03:00
|
|
|
{!supportsTitle && (
|
|
|
|
<th className={orderableColumnsClasses} onClick={orderByColumn?.('longUrl')}>
|
2021-11-01 15:41:16 +03:00
|
|
|
Long URL {renderOrderIcon?.('longUrl')}
|
2021-03-05 16:20:49 +03:00
|
|
|
</th>
|
|
|
|
) || (
|
|
|
|
<th className="short-urls-table__header-cell">
|
|
|
|
<span className={actionableFieldClasses} onClick={orderByColumn?.('title')}>
|
2021-11-01 15:41:16 +03:00
|
|
|
Title {renderOrderIcon?.('title')}
|
2021-03-05 16:20:49 +03:00
|
|
|
</span>
|
|
|
|
/
|
|
|
|
<span className={actionableFieldClasses} onClick={orderByColumn?.('longUrl')}>
|
2021-11-01 15:41:16 +03:00
|
|
|
<span className="indivisible">Long URL</span> {renderOrderIcon?.('longUrl')}
|
2021-03-05 16:20:49 +03:00
|
|
|
</span>
|
|
|
|
</th>
|
|
|
|
)}
|
2020-12-07 13:17:19 +03:00
|
|
|
<th className="short-urls-table__header-cell">Tags</th>
|
|
|
|
<th className={orderableColumnsClasses} onClick={orderByColumn?.('visits')}>
|
2021-11-01 15:41:16 +03:00
|
|
|
<span className="indivisible">Visits {renderOrderIcon?.('visits')}</span>
|
2020-12-07 13:17:19 +03:00
|
|
|
</th>
|
|
|
|
<th className="short-urls-table__header-cell"> </th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{renderShortUrls()}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
);
|
|
|
|
};
|