From d4b8c7edd52740498bc9ef730d79f76a7abf2cbd Mon Sep 17 00:00:00 2001 From: Ricardo M Date: Fri, 17 Nov 2023 15:14:54 +0100 Subject: [PATCH] feature(catalog): Allow consumers to update Camel Catalog URL Currently, there's no mechanism to update the Camel Catalog URL at build time. This commit introduces such possibility by adding a `catalogUrl` property to `SchemaLoaderProvider` and `CatalogLoaderProvider`. --- .../ui-tests/stories/ContextToolbar.stories.tsx | 5 +++-- packages/ui/src/App.tsx | 5 +++-- packages/ui/src/providers/catalog.provider.tsx | 14 +++++++------- packages/ui/src/providers/schemas.provider.tsx | 6 +++--- .../ui/src/utils/catalog-schema-loader.test.ts | 8 ++++---- packages/ui/src/utils/catalog-schema-loader.ts | 10 +++++----- 6 files changed, 25 insertions(+), 23 deletions(-) diff --git a/packages/ui-tests/stories/ContextToolbar.stories.tsx b/packages/ui-tests/stories/ContextToolbar.stories.tsx index a648828ae..4e897f20a 100644 --- a/packages/ui-tests/stories/ContextToolbar.stories.tsx +++ b/packages/ui-tests/stories/ContextToolbar.stories.tsx @@ -1,5 +1,6 @@ import { CatalogLoaderProvider, + CatalogSchemaLoader, CatalogTilesProvider, ContextToolbar, EntitiesContext, @@ -14,8 +15,8 @@ import camelRouteMock from '../cypress/fixtures/camelRouteMock.json'; const EntitiesContextDecorator = (Story: StoryFn) => ( {} }}> - - + + diff --git a/packages/ui/src/App.tsx b/packages/ui/src/App.tsx index b4541423f..87df740c5 100644 --- a/packages/ui/src/App.tsx +++ b/packages/ui/src/App.tsx @@ -5,14 +5,15 @@ import { CatalogLoaderProvider } from './providers/catalog.provider'; import { EntitiesProvider } from './providers/entities.provider'; import { SchemasLoaderProvider } from './providers/schemas.provider'; import { SourceCodeProvider } from './providers/source-code.provider'; +import { CatalogSchemaLoader } from './utils/catalog-schema-loader'; function App() { return ( - - + + diff --git a/packages/ui/src/providers/catalog.provider.tsx b/packages/ui/src/providers/catalog.provider.tsx index f92d74997..8061492bd 100644 --- a/packages/ui/src/providers/catalog.provider.tsx +++ b/packages/ui/src/providers/catalog.provider.tsx @@ -10,27 +10,27 @@ export const CatalogContext = createContext(CamelCat /** * Loader for the components catalog. */ -export const CatalogLoaderProvider: FunctionComponent = (props) => { +export const CatalogLoaderProvider: FunctionComponent> = (props) => { const [isLoading, setIsLoading] = useState(true); useEffect(() => { - fetch(`.${CatalogSchemaLoader.DEFAULT_CATALOG_PATH}/index.json`) + fetch(`${props.catalogUrl}/index.json`) .then((response) => response.json()) .then(async (catalogIndex: CamelCatalogIndex) => { const camelComponentsFiles = CatalogSchemaLoader.fetchFile( - catalogIndex.catalogs.components.file, + `${props.catalogUrl}/${catalogIndex.catalogs.components.file}`, ); const camelProcessorsFiles = CatalogSchemaLoader.fetchFile( - catalogIndex.catalogs.models.file, + `${props.catalogUrl}/${catalogIndex.catalogs.models.file}`, ); const camelLanguagesFiles = CatalogSchemaLoader.fetchFile( - catalogIndex.catalogs.languages.file, + `${props.catalogUrl}/${catalogIndex.catalogs.languages.file}`, ); const camelDataformatsFiles = CatalogSchemaLoader.fetchFile( - catalogIndex.catalogs.dataformats.file, + `${props.catalogUrl}/${catalogIndex.catalogs.dataformats.file}`, ); const kameletsFiles = CatalogSchemaLoader.fetchFile( - catalogIndex.catalogs.kamelets.file, + `${props.catalogUrl}/${catalogIndex.catalogs.kamelets.file}`, ); const [camelComponents, camelProcessors, camelLanguages, camelDataformats, kamelets] = await Promise.all([ diff --git a/packages/ui/src/providers/schemas.provider.tsx b/packages/ui/src/providers/schemas.provider.tsx index e21d2e9a9..d853078f9 100644 --- a/packages/ui/src/providers/schemas.provider.tsx +++ b/packages/ui/src/providers/schemas.provider.tsx @@ -11,16 +11,16 @@ export const SchemasContext = createContext>({}); /** * Loader for the components schemas. */ -export const SchemasLoaderProvider: FunctionComponent = (props) => { +export const SchemasLoaderProvider: FunctionComponent> = (props) => { const setSchema = useSchemasStore((state) => state.setSchema); const [isLoading, setIsLoading] = useState(true); const [schemas, setSchemas] = useState>({}); useEffect(() => { - fetch(`.${CatalogSchemaLoader.DEFAULT_CATALOG_PATH}/index.json`) + fetch(`${props.catalogUrl}/index.json`) .then((response) => response.json()) .then(async (catalogIndex: CamelCatalogIndex) => { - const schemaFilesPromise = CatalogSchemaLoader.getSchemasFiles(catalogIndex.schemas); + const schemaFilesPromise = CatalogSchemaLoader.getSchemasFiles(props.catalogUrl, catalogIndex.schemas); const loadedSchemas = await Promise.all(schemaFilesPromise); const combinedSchemas = loadedSchemas.reduce( diff --git a/packages/ui/src/utils/catalog-schema-loader.test.ts b/packages/ui/src/utils/catalog-schema-loader.test.ts index 9ca209feb..310711e97 100644 --- a/packages/ui/src/utils/catalog-schema-loader.test.ts +++ b/packages/ui/src/utils/catalog-schema-loader.test.ts @@ -19,10 +19,10 @@ describe('CatalogSchemaLoader', () => { }); describe('fetchFile', () => { - it('should use the file and the DEFAULT_CATALOG_PATH in the path', async () => { + it('should fetch the file', async () => { await CatalogSchemaLoader.fetchFile('file.json'); - expect(fetchMock).toHaveBeenCalledWith('./camel-catalog/file.json'); + expect(fetchMock).toHaveBeenCalledWith('file.json'); }); it('should return the body and the uri', async () => { @@ -32,7 +32,7 @@ describe('CatalogSchemaLoader', () => { body: { content: 'file-content', }, - uri: 'http://localhost/./camel-catalog/file.json', + uri: 'http://localhost/file.json', }); }); }); @@ -69,7 +69,7 @@ describe('CatalogSchemaLoader', () => { }); it('should return the schemas files', async () => { - const schemaPromises = CatalogSchemaLoader.getSchemasFiles(schemasEntries); + const schemaPromises = CatalogSchemaLoader.getSchemasFiles('http://localhost', schemasEntries); const result = await Promise.all(schemaPromises); diff --git a/packages/ui/src/utils/catalog-schema-loader.ts b/packages/ui/src/utils/catalog-schema-loader.ts index c70582a40..b1305dee9 100644 --- a/packages/ui/src/utils/catalog-schema-loader.ts +++ b/packages/ui/src/utils/catalog-schema-loader.ts @@ -1,20 +1,20 @@ import { Schema, SchemaEntry } from '../models'; export class CatalogSchemaLoader { - static readonly DEFAULT_CATALOG_PATH = '/camel-catalog'; + /** The `.` is required to support relative routes in GitHub pages */ + static readonly DEFAULT_CATALOG_PATH = './camel-catalog'; static readonly VISUAL_FLOWS = ['route', 'Integration', 'Kamelet', 'KameletBinding', 'Pipe']; static async fetchFile(file: string): Promise<{ body: T; uri: string }> { - /** The `.` is required to support relative routes in GitHub pages */ - const response = await fetch(`.${this.DEFAULT_CATALOG_PATH}/${file}`); + const response = await fetch(file); const body = await response.json(); return { body, uri: response.url }; } - static getSchemasFiles(schemaFiles: Record): Promise[] { + static getSchemasFiles(basePath: string, schemaFiles: Record): Promise[] { return Object.entries(schemaFiles).map(async ([name, schemaDef]) => { - const fetchedSchema = await this.fetchFile(schemaDef.file); + const fetchedSchema = await this.fetchFile(`${basePath}/${schemaDef.file}`); const tags = []; if (this.VISUAL_FLOWS.includes(name)) {