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)}; `;