import YAML from 'yamljs'; import { CheckCircleOutlined, CloseCircleOutlined, LoadingOutlined } from '@ant-design/icons'; import { ANTD_GRAY, REDESIGN_COLORS } from '../../entity/shared/constants'; import { SOURCE_TEMPLATE_CONFIGS } from './conf/sources'; import { EntityType, FacetMetadata } from '../../../types.generated'; import { capitalizeFirstLetterOnly, pluralize } from '../../shared/textUtil'; import EntityRegistry from '../../entity/EntityRegistry'; export const sourceTypeToIconUrl = (type: string) => { return SOURCE_TEMPLATE_CONFIGS.find((config) => config.type === type)?.logoUrl; }; export const getSourceConfigs = (sourceType: string) => { const sourceConfigs = SOURCE_TEMPLATE_CONFIGS.find((configs) => configs.type === sourceType); if (!sourceConfigs) { throw new Error(`Failed to find source configs with source type ${sourceType}`); } return sourceConfigs; }; export const yamlToJson = (yaml: string): string => { const obj = YAML.parse(yaml); const jsonStr = JSON.stringify(obj); return jsonStr; }; export const jsonToYaml = (json: string): string => { const obj = JSON.parse(json); const yamlStr = YAML.stringify(obj, 6); return yamlStr; }; export const RUNNING = 'RUNNING'; export const SUCCESS = 'SUCCESS'; export const FAILURE = 'FAILURE'; export const CANCELLED = 'CANCELLED'; export const getExecutionRequestStatusIcon = (status: string) => { return ( (status === RUNNING && LoadingOutlined) || (status === SUCCESS && CheckCircleOutlined) || (status === FAILURE && CloseCircleOutlined) || (status === CANCELLED && CloseCircleOutlined) || undefined ); }; export const getExecutionRequestStatusDisplayText = (status: string) => { return ( (status === RUNNING && 'Running') || (status === SUCCESS && 'Succeeded') || (status === FAILURE && 'Failed') || (status === CANCELLED && 'Cancelled') || status ); }; export const getExecutionRequestSummaryText = (status: string) => { switch (status) { case RUNNING: return 'Ingestion is running'; case SUCCESS: return 'Ingestion successfully completed'; case FAILURE: return 'Ingestion completed with errors'; case CANCELLED: return 'Ingestion was cancelled'; default: return 'Ingestion status not recognized'; } }; export const getExecutionRequestStatusDisplayColor = (status: string) => { return ( (status === RUNNING && REDESIGN_COLORS.BLUE) || (status === SUCCESS && 'green') || (status === FAILURE && 'red') || (status === CANCELLED && ANTD_GRAY[9]) || ANTD_GRAY[7] ); }; const ENTITIES_WITH_SUBTYPES = new Set([ EntityType.Dataset.toLowerCase(), EntityType.Container.toLowerCase(), EntityType.Notebook.toLowerCase(), ]); type EntityTypeCount = { count: number; displayName: string; }; /** * Extract entity type counts to display in the ingestion summary. * * @param entityTypeFacets the filter facets for entity type. * @param subTypeFacets the filter facets for sub types. */ export const extractEntityTypeCountsFromFacets = ( entityRegistry: EntityRegistry, entityTypeFacets: FacetMetadata, subTypeFacets?: FacetMetadata | null, ): EntityTypeCount[] => { const finalCounts: EntityTypeCount[] = []; if (subTypeFacets) { subTypeFacets.aggregations .filter((agg) => agg.count > 0) .forEach((agg) => finalCounts.push({ count: agg.count, displayName: pluralize(agg.count, capitalizeFirstLetterOnly(agg.value) || ''), }), ); entityTypeFacets.aggregations .filter((agg) => agg.count > 0) .filter((agg) => !ENTITIES_WITH_SUBTYPES.has(agg.value.toLowerCase())) .forEach((agg) => finalCounts.push({ count: agg.count, displayName: entityRegistry.getCollectionName(agg.value as EntityType), }), ); } else { // Only use Entity Types- no subtypes. entityTypeFacets.aggregations .filter((agg) => agg.count > 0) .forEach((agg) => finalCounts.push({ count: agg.count, displayName: entityRegistry.getCollectionName(agg.value as EntityType), }), ); } return finalCounts; };