import styled from '@emotion/styled';
import EmptyMessage from 'sentry/components/emptyMessage';
import Link from 'sentry/components/links/link';
import LoadingIndicator from 'sentry/components/loadingIndicator';
import Panel from 'sentry/components/panels/panel';
import {IconList} from 'sentry/icons';
import {space} from 'sentry/styles/space';
import type {Project} from 'sentry/types/project';
import type {DebugIdBundle} from 'sentry/types/sourceMaps';
import useOrganization from 'sentry/utils/useOrganization';
import {DebugIdBundleDeleteButton} from 'sentry/views/settings/projectSourceMaps/debugIdBundleDeleteButton';
import {DebugIdBundleDetails} from 'sentry/views/settings/projectSourceMaps/debugIdBundleDetails';
interface DebugIdBundleListProps {
emptyMessage: React.ReactNode;
isLoading: boolean;
onDelete: (bundleId: string) => void;
project: Project;
debugIdBundles?: DebugIdBundle[];
}
export function DebugIdBundleList({
isLoading,
debugIdBundles,
emptyMessage,
onDelete,
project,
}: DebugIdBundleListProps) {
const organization = useOrganization();
if (isLoading) {
return ;
}
if (!debugIdBundles || debugIdBundles.length === 0) {
return {emptyMessage};
}
return (
{debugIdBundles.map(debugIdBundle => (
-
{debugIdBundle.bundleId}
onDelete(debugIdBundle.bundleId)}
/>
))}
);
}
const List = styled('div')`
display: grid;
grid-template-columns: 1fr;
gap: ${space(2)};
`;
const Item = styled(Panel)`
margin: 0;
`;
const ItemHeader = styled('div')`
display: flex;
align-items: center;
justify-content: space-between;
font-size: ${p => p.theme.fontSizeMedium};
border-bottom: 1px solid ${p => p.theme.border};
line-height: 1;
padding: ${space(1)} ${space(2)};
`;
const ItemTitle = styled(Link)`
display: flex;
align-items: center;
gap: ${space(1)};
`;
const ItemContent = styled('div')`
padding: ${space(1)} ${space(2)};
`;