@eventcatalog/core 1.2.7 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.changeset/config.json +11 -0
- package/.github/CODEOWNERS +3 -0
- package/.github/ISSUE_TEMPLATE.md +1 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +18 -0
- package/.github/funding.yml +1 -0
- package/.github/workflows/lint.yml +22 -0
- package/.github/workflows/release.yml +34 -0
- package/.github/workflows/verify-build.yml +27 -0
- package/.prettierignore +7 -0
- package/.prettierrc +10 -0
- package/CHANGELOG.md +10 -0
- package/LICENSE.md +21 -0
- package/README.md +206 -5
- package/astro.config.mjs +57 -0
- package/bin/dist/eventcatalog.cjs +3139 -0
- package/bin/dist/eventcatalog.d.cts +1 -0
- package/bin/dist/eventcatalog.d.ts +1 -0
- package/bin/dist/eventcatalog.js +3141 -0
- package/images/example.png +0 -0
- package/package.json +59 -52
- package/public/icons/github.svg +1 -0
- package/public/icons/x-twitter.svg +1 -0
- package/public/logo.png +0 -0
- package/public/slack-icon.svg +1 -0
- package/scripts/build-ci.js +22 -0
- package/scripts/catalog-to-astro-content-directory.js +188 -0
- package/scripts/default-files-for-collections/commands.md +8 -0
- package/scripts/default-files-for-collections/domains.md +8 -0
- package/scripts/default-files-for-collections/events.md +8 -0
- package/scripts/default-files-for-collections/services.md +8 -0
- package/scripts/default-files-for-collections/teams.md +11 -0
- package/scripts/default-files-for-collections/users.md +11 -0
- package/scripts/start-catalog-locally.js +23 -0
- package/scripts/watcher.js +53 -0
- package/src/components/DocsNavigation.astro +110 -0
- package/src/components/Header.astro +65 -0
- package/src/components/Lists/BasicList.tsx +59 -0
- package/src/components/Lists/OwnersList.tsx +101 -0
- package/src/components/Lists/PillList.tsx +67 -0
- package/src/components/Lists/VersionList.astro +29 -0
- package/src/components/MDX/Accordion/Accordion.astro +10 -0
- package/src/components/MDX/Accordion/Accordion.tsx +29 -0
- package/src/components/MDX/Accordion/AccordionGroup.astro +16 -0
- package/{components/Mdx → src/components/MDX}/Admonition.tsx +6 -5
- package/src/components/MDX/File.tsx +43 -0
- package/src/components/MDX/NodeGraph/DownloadButton.tsx +58 -0
- package/src/components/MDX/NodeGraph/NodeGraph.astro +82 -0
- package/src/components/MDX/NodeGraph/NodeGraph.tsx +135 -0
- package/src/components/MDX/NodeGraph/NodeGraphPortal.tsx +15 -0
- package/src/components/MDX/NodeGraph/Nodes/Command.tsx +74 -0
- package/src/components/MDX/NodeGraph/Nodes/Event.tsx +74 -0
- package/src/components/MDX/NodeGraph/Nodes/Service.tsx +83 -0
- package/src/components/MDX/OpenAPI/OpenAPI.tsx +35 -0
- package/src/components/MDX/Schema.tsx +45 -0
- package/src/components/MDX/components.tsx +24 -0
- package/src/components/Search.astro +108 -0
- package/src/components/Seo.astro +79 -0
- package/src/components/SideBars/DomainSideBar.astro +42 -0
- package/src/components/SideBars/MessageSideBar.astro +81 -0
- package/src/components/SideBars/ServiceSideBar.astro +93 -0
- package/src/components/Tables/DebouncedInput.tsx +32 -0
- package/src/components/Tables/Table.tsx +228 -0
- package/src/components/Tables/columns/DomainTableColumns.tsx +118 -0
- package/src/components/Tables/columns/MessageTableColumns.tsx +159 -0
- package/src/components/Tables/columns/ServiceTableColumns.tsx +162 -0
- package/src/components/Tables/columns/index.tsx +17 -0
- package/src/components/Tables/filters/custom-filters.ts +14 -0
- package/src/content/config.ts +119 -0
- package/src/env.d.ts +2 -0
- package/src/layouts/CustomDocsPageLayout.astro +100 -0
- package/src/layouts/DiscoverLayout.astro +120 -0
- package/src/layouts/DocsLayout.astro +59 -0
- package/src/layouts/PlainPage.astro +29 -0
- package/src/layouts/VisualiserLayout.astro +73 -0
- package/src/pages/discover/[type]/index.astro +36 -0
- package/src/pages/docs/[type]/[id]/[version]/index.astro +215 -0
- package/src/pages/docs/[type]/[id]/[version]/spec/index.astro +93 -0
- package/src/pages/docs/index.md +4 -0
- package/src/pages/docs/teams/[id]/index.astro +127 -0
- package/src/pages/docs/users/[id]/index.astro +132 -0
- package/src/pages/visualiser/[type]/[id]/[version]/index.astro +46 -0
- package/src/pages/visualiser/index.astro +25 -0
- package/src/remark-plugins/mermaid.ts +27 -0
- package/src/remark-plugins/remark-modified-time.mjs +9 -0
- package/src/types/index.ts +2 -0
- package/src/utils/collections/util.ts +22 -0
- package/src/utils/colors.ts +14 -0
- package/src/utils/commands/node-graph.ts +107 -0
- package/src/utils/commands.ts +60 -0
- package/src/utils/config/catalog.ts +2 -0
- package/src/utils/domains/domains.ts +50 -0
- package/src/utils/domains/node-graph.ts +60 -0
- package/src/utils/events/node-graph.ts +108 -0
- package/src/utils/events.ts +62 -0
- package/src/utils/example-remark-plugin.mjs +6 -0
- package/src/utils/messages.ts +7 -0
- package/src/utils/node-graph-utils/utils.ts +31 -0
- package/src/utils/services/node-graph.ts +133 -0
- package/src/utils/services/services.ts +88 -0
- package/src/utils/teams.ts +47 -0
- package/src/utils/users.ts +59 -0
- package/tailwind.config.mjs +24 -0
- package/tsconfig.json +11 -26
- package/.next/BUILD_ID +0 -1
- package/.next/build-manifest.json +0 -246
- package/.next/cache/.tsbuildinfo +0 -1
- package/.next/cache/config.json +0 -7
- package/.next/cache/eslint/.cache_1bay4w0 +0 -1
- package/.next/cache/next-server.js.nft.json +0 -1
- package/.next/cache/webpack/client-production/0.pack +0 -0
- package/.next/cache/webpack/client-production/index.pack +0 -0
- package/.next/cache/webpack/server-production/0.pack +0 -0
- package/.next/cache/webpack/server-production/index.pack +0 -0
- package/.next/export-detail.json +0 -1
- package/.next/export-marker.json +0 -1
- package/.next/images-manifest.json +0 -1
- package/.next/next-server.js.nft.json +0 -1
- package/.next/package.json +0 -1
- package/.next/prerender-manifest.json +0 -1
- package/.next/react-loadable-manifest.json +0 -2112
- package/.next/required-server-files.json +0 -1
- package/.next/routes-manifest.json +0 -1
- package/.next/server/chunks/109.js +0 -608
- package/.next/server/chunks/237.js +0 -109
- package/.next/server/chunks/267.js +0 -257
- package/.next/server/chunks/274.js +0 -32
- package/.next/server/chunks/29.js +0 -675
- package/.next/server/chunks/331.js +0 -750
- package/.next/server/chunks/362.js +0 -570
- package/.next/server/chunks/428.js +0 -84
- package/.next/server/chunks/50.js +0 -466
- package/.next/server/chunks/526.js +0 -159
- package/.next/server/chunks/537.js +0 -136
- package/.next/server/chunks/788.js +0 -162
- package/.next/server/chunks/797.js +0 -92
- package/.next/server/chunks/8.js +0 -173
- package/.next/server/chunks/854.js +0 -107
- package/.next/server/chunks/938.js +0 -140
- package/.next/server/chunks/944.js +0 -721
- package/.next/server/chunks/962.js +0 -13
- package/.next/server/chunks/97.js +0 -2829
- package/.next/server/chunks/992.js +0 -50
- package/.next/server/chunks/font-manifest.json +0 -1
- package/.next/server/font-manifest.json +0 -1
- package/.next/server/middleware-manifest.json +0 -6
- package/.next/server/pages/404.html +0 -12
- package/.next/server/pages/500.html +0 -12
- package/.next/server/pages/_app.js +0 -623
- package/.next/server/pages/_app.js.nft.json +0 -1
- package/.next/server/pages/_document.js +0 -120
- package/.next/server/pages/_document.js.nft.json +0 -1
- package/.next/server/pages/_error.js +0 -148
- package/.next/server/pages/_error.js.nft.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderComplete/logs.html +0 -1
- package/.next/server/pages/domains/Orders/events/OrderComplete/logs.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderComplete.html +0 -40
- package/.next/server/pages/domains/Orders/events/OrderComplete.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderConfirmed/logs.html +0 -1
- package/.next/server/pages/domains/Orders/events/OrderConfirmed/logs.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderConfirmed.html +0 -40
- package/.next/server/pages/domains/Orders/events/OrderConfirmed.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderCreated/logs.html +0 -1
- package/.next/server/pages/domains/Orders/events/OrderCreated/logs.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderCreated.html +0 -2
- package/.next/server/pages/domains/Orders/events/OrderCreated.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderRequested/logs.html +0 -1
- package/.next/server/pages/domains/Orders/events/OrderRequested/logs.json +0 -1
- package/.next/server/pages/domains/Orders/events/OrderRequested.html +0 -40
- package/.next/server/pages/domains/Orders/events/OrderRequested.json +0 -1
- package/.next/server/pages/domains/Orders/services/Orders Service.html +0 -2
- package/.next/server/pages/domains/Orders/services/Orders Service.json +0 -1
- package/.next/server/pages/domains/Orders.html +0 -2
- package/.next/server/pages/domains/Orders.json +0 -1
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart/logs.html +0 -1
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart/logs.json +0 -1
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart/v/0.0.1.html +0 -59
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart/v/0.0.1.json +0 -1
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart/v/0.0.2.html +0 -66
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart/v/0.0.2.json +0 -1
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart.html +0 -65
- package/.next/server/pages/domains/Shopping/events/AddedItemToCart.json +0 -1
- package/.next/server/pages/domains/Shopping/events/RemovedItemFromCart/logs.html +0 -1
- package/.next/server/pages/domains/Shopping/events/RemovedItemFromCart/logs.json +0 -1
- package/.next/server/pages/domains/Shopping/events/RemovedItemFromCart.html +0 -48
- package/.next/server/pages/domains/Shopping/events/RemovedItemFromCart.json +0 -1
- package/.next/server/pages/domains/Shopping.html +0 -2
- package/.next/server/pages/domains/Shopping.json +0 -1
- package/.next/server/pages/domains/[domain]/events/[name]/logs.js +0 -345
- package/.next/server/pages/domains/[domain]/events/[name]/logs.js.nft.json +0 -1
- package/.next/server/pages/domains/[domain]/events/[name]/v/[version].js +0 -435
- package/.next/server/pages/domains/[domain]/events/[name]/v/[version].js.nft.json +0 -1
- package/.next/server/pages/domains/[domain]/events/[name].js +0 -354
- package/.next/server/pages/domains/[domain]/events/[name].js.nft.json +0 -1
- package/.next/server/pages/domains/[domain]/services/[name].js +0 -402
- package/.next/server/pages/domains/[domain]/services/[name].js.nft.json +0 -1
- package/.next/server/pages/domains/[domain].js +0 -549
- package/.next/server/pages/domains/[domain].js.nft.json +0 -1
- package/.next/server/pages/domains.html +0 -3
- package/.next/server/pages/domains.js +0 -576
- package/.next/server/pages/domains.js.nft.json +0 -1
- package/.next/server/pages/domains.json +0 -1
- package/.next/server/pages/events/PaymentProcessed/logs.html +0 -1
- package/.next/server/pages/events/PaymentProcessed/logs.json +0 -1
- package/.next/server/pages/events/PaymentProcessed.html +0 -44
- package/.next/server/pages/events/PaymentProcessed.json +0 -1
- package/.next/server/pages/events/ShipmentDelivered/logs.html +0 -1
- package/.next/server/pages/events/ShipmentDelivered/logs.json +0 -1
- package/.next/server/pages/events/ShipmentDelivered.html +0 -44
- package/.next/server/pages/events/ShipmentDelivered.json +0 -1
- package/.next/server/pages/events/ShipmentDispatched/logs.html +0 -1
- package/.next/server/pages/events/ShipmentDispatched/logs.json +0 -1
- package/.next/server/pages/events/ShipmentDispatched.html +0 -44
- package/.next/server/pages/events/ShipmentDispatched.json +0 -1
- package/.next/server/pages/events/ShipmentPrepared/logs.html +0 -1
- package/.next/server/pages/events/ShipmentPrepared/logs.json +0 -1
- package/.next/server/pages/events/ShipmentPrepared.html +0 -2
- package/.next/server/pages/events/ShipmentPrepared.json +0 -1
- package/.next/server/pages/events/[name]/logs.js +0 -263
- package/.next/server/pages/events/[name]/logs.js.nft.json +0 -1
- package/.next/server/pages/events/[name]/v/[version].js +0 -431
- package/.next/server/pages/events/[name]/v/[version].js.nft.json +0 -1
- package/.next/server/pages/events/[name].js +0 -354
- package/.next/server/pages/events/[name].js.nft.json +0 -1
- package/.next/server/pages/events.html +0 -11
- package/.next/server/pages/events.js +0 -789
- package/.next/server/pages/events.js.nft.json +0 -1
- package/.next/server/pages/events.json +0 -1
- package/.next/server/pages/index.html +0 -1
- package/.next/server/pages/index.js.nft.json +0 -1
- package/.next/server/pages/overview.html +0 -1
- package/.next/server/pages/overview.js +0 -240
- package/.next/server/pages/overview.js.nft.json +0 -1
- package/.next/server/pages/overview.json +0 -1
- package/.next/server/pages/services/Orders Service.html +0 -1
- package/.next/server/pages/services/Orders Service.json +0 -1
- package/.next/server/pages/services/Payment Service.html +0 -2
- package/.next/server/pages/services/Payment Service.json +0 -1
- package/.next/server/pages/services/Shipping Service.html +0 -2
- package/.next/server/pages/services/Shipping Service.json +0 -1
- package/.next/server/pages/services/[name].js +0 -319
- package/.next/server/pages/services/[name].js.nft.json +0 -1
- package/.next/server/pages/services.html +0 -4
- package/.next/server/pages/services.js +0 -741
- package/.next/server/pages/services.js.nft.json +0 -1
- package/.next/server/pages/services.json +0 -1
- package/.next/server/pages/users/[id].js +0 -475
- package/.next/server/pages/users/[id].js.nft.json +0 -1
- package/.next/server/pages/users/dboyne.html +0 -16
- package/.next/server/pages/users/dboyne.json +0 -1
- package/.next/server/pages/users/mSmith.html +0 -13
- package/.next/server/pages/users/mSmith.json +0 -1
- package/.next/server/pages/users.html +0 -1
- package/.next/server/pages/users.js.nft.json +0 -1
- package/.next/server/pages/visualiser.html +0 -16
- package/.next/server/pages/visualiser.js +0 -739
- package/.next/server/pages/visualiser.js.nft.json +0 -1
- package/.next/server/pages/visualiser.json +0 -1
- package/.next/server/pages-manifest.json +0 -23
- package/.next/server/webpack-runtime.js +0 -259
- package/.next/static/chunks/020d8314.2bae2f29ef0060e4.js +0 -1
- package/.next/static/chunks/1093.67f04e0e6b50c9e5.js +0 -1
- package/.next/static/chunks/1178-c3c8c74ac08d7c77.js +0 -1
- package/.next/static/chunks/1254.a78e9444e102b061.js +0 -1
- package/.next/static/chunks/130.fa515915f80e17f9.js +0 -1
- package/.next/static/chunks/1318.a5349c1b3da2b184.js +0 -1
- package/.next/static/chunks/1415.55c7c89ef0a8aab1.js +0 -1
- package/.next/static/chunks/1455-8df9e334899797b2.js +0 -1
- package/.next/static/chunks/172-940ad0353b57ff98.js +0 -1
- package/.next/static/chunks/1733.1bead33faaa9eeb0.js +0 -1
- package/.next/static/chunks/1806.3ed762ab3ecedc9d.js +0 -1
- package/.next/static/chunks/2157.cd3aa9fee64d976e.js +0 -1
- package/.next/static/chunks/2566.4084969752c613a9.js +0 -1
- package/.next/static/chunks/2620-21775e17d8a6a407.js +0 -1
- package/.next/static/chunks/2edb282b-45c56c19221816df.js +0 -1
- package/.next/static/chunks/3116-446dd88b93c44018.js +0 -1
- package/.next/static/chunks/3193.f69abc67598575a9.js +0 -1
- package/.next/static/chunks/3260.00ac1405e82b8dd9.js +0 -1
- package/.next/static/chunks/3271.83723868c9b8e7c1.js +0 -1
- package/.next/static/chunks/3287.f50c49237cef9ae8.js +0 -1
- package/.next/static/chunks/39a9cf3f.8cc8ac3887be2999.js +0 -1
- package/.next/static/chunks/3ede58a6.44fda8e0e5284248.js +0 -1
- package/.next/static/chunks/40.16abe9d3c57256d6.js +0 -1
- package/.next/static/chunks/407.3078ab29e8d18c02.js +0 -1
- package/.next/static/chunks/438.dea6dada9bd4b683.js +0 -1
- package/.next/static/chunks/4384-8a28a71e7e3b8d8a.js +0 -1
- package/.next/static/chunks/4466.dc03dbcd026995cc.js +0 -1
- package/.next/static/chunks/4737.ae583b848d202a93.js +0 -1
- package/.next/static/chunks/5048.73fa7a6d734ba5ef.js +0 -1
- package/.next/static/chunks/5092.8ead508f86f4b11c.js +0 -1
- package/.next/static/chunks/5493-b00dc3d50ab46716.js +0 -1
- package/.next/static/chunks/5835.a9405ab0913544df.js +0 -1
- package/.next/static/chunks/6067.cc75c37618cf0147.js +0 -1
- package/.next/static/chunks/6121.758a43c0db92ca23.js +0 -1
- package/.next/static/chunks/6229.7a9f0c8b204b76dc.js +0 -1
- package/.next/static/chunks/6487.44c6e83c098ed47f.js +0 -1
- package/.next/static/chunks/6582.06af6897be0d24b3.js +0 -1
- package/.next/static/chunks/6724.ed1280c926906c76.js +0 -1
- package/.next/static/chunks/6772-fc6143a6584acf9b.js +0 -1
- package/.next/static/chunks/6790-f4527d80153a3e25.js +0 -1
- package/.next/static/chunks/7005-09e42f99859b8d03.js +0 -1
- package/.next/static/chunks/7109-c8d3fde4c3b6798e.js +0 -1
- package/.next/static/chunks/7374.a673e317f007d3b6.js +0 -1
- package/.next/static/chunks/74030e57.9636ad3c5c96940b.js +0 -1
- package/.next/static/chunks/7458.1de01a44cd67f6f0.js +0 -1
- package/.next/static/chunks/7469.d932a6b01168373b.js +0 -1
- package/.next/static/chunks/7636.9eaf88a09c2a88ed.js +0 -1
- package/.next/static/chunks/7f5d3f51-659399fe6f04b9eb.js +0 -1
- package/.next/static/chunks/8264-a1b0376ff4b3d4da.js +0 -1
- package/.next/static/chunks/828-1a4a120d2fbea802.js +0 -1
- package/.next/static/chunks/8341-b8d844d6f606aed5.js +0 -1
- package/.next/static/chunks/8470.c811187bd2982a8a.js +0 -1
- package/.next/static/chunks/9076.0a13d7d5aab7bfa1.js +0 -1
- package/.next/static/chunks/9097.1efc23284d82765c.js +0 -1
- package/.next/static/chunks/9270.a4c64e6be4a278a4.js +0 -1
- package/.next/static/chunks/9404.a44dfe8858add605.js +0 -1
- package/.next/static/chunks/9497.49670ee9a8bd76f7.js +0 -1
- package/.next/static/chunks/9930.28415573db2b7806.js +0 -7
- package/.next/static/chunks/b2f22a9c-0216e9400ac0ac1c.js +0 -1
- package/.next/static/chunks/b9e0c7b4-52b02c0d4f161186.js +0 -1
- package/.next/static/chunks/eb6e03f4.3dd8d555aebe18ff.js +0 -1
- package/.next/static/chunks/f4df0e03.56d1c15b5532ab26.js +0 -1
- package/.next/static/chunks/framework-6cc1bceeaaf75e91.js +0 -1
- package/.next/static/chunks/main-da37322a396d572a.js +0 -1
- package/.next/static/chunks/pages/_app-d40841fd52b70886.js +0 -1
- package/.next/static/chunks/pages/_error-c36fa6f7fd569cf6.js +0 -1
- package/.next/static/chunks/pages/domains/[domain]/events/[name]/logs-350f383eed1cf3f8.js +0 -1
- package/.next/static/chunks/pages/domains/[domain]/events/[name]/v/[version]-45b0d7bc42f6f81c.js +0 -1
- package/.next/static/chunks/pages/domains/[domain]/events/[name]-15bb0ef487953fa1.js +0 -1
- package/.next/static/chunks/pages/domains/[domain]/services/[name]-a4857d4d0aa4d04b.js +0 -1
- package/.next/static/chunks/pages/domains/[domain]-ea20e2daae1794fc.js +0 -1
- package/.next/static/chunks/pages/domains-71179cbdb719a0f8.js +0 -1
- package/.next/static/chunks/pages/events/[name]/logs-695c5b2cfd996539.js +0 -1
- package/.next/static/chunks/pages/events/[name]/v/[version]-b718302d7185dcb0.js +0 -1
- package/.next/static/chunks/pages/events/[name]-8cb0b3b469bd7845.js +0 -1
- package/.next/static/chunks/pages/events-83c9161a6e696533.js +0 -1
- package/.next/static/chunks/pages/index-68062a10328e7d10.js +0 -1
- package/.next/static/chunks/pages/overview-4251cc856f776fc2.js +0 -1
- package/.next/static/chunks/pages/services/[name]-7030da24d73a8ea3.js +0 -1
- package/.next/static/chunks/pages/services-7069c0a5295e53ae.js +0 -1
- package/.next/static/chunks/pages/users/[id]-00aeace648436383.js +0 -1
- package/.next/static/chunks/pages/users-412f257b1de51363.js +0 -1
- package/.next/static/chunks/pages/visualiser-8474d03175cf9d12.js +0 -1
- package/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +0 -1
- package/.next/static/chunks/webpack-1ea4cabfc6778694.js +0 -1
- package/.next/static/css/7e14b4dede1671ad.css +0 -1
- package/.next/static/css/94b9a747218712b2.css +0 -3
- package/.next/static/css/ae8abf3666c55019.css +0 -5
- package/.next/static/css/cc3c8fcadcf7a58b.css +0 -1
- package/.next/static/css/deb57cf90a65a90f.css +0 -1
- package/.next/static/css/ed97de5465a152bb.css +0 -1
- package/.next/static/wZIh57Hs672ULoPeUaYa1/_buildManifest.js +0 -1
- package/.next/static/wZIh57Hs672ULoPeUaYa1/_ssgManifest.js +0 -1
- package/.next/trace +0 -141
- package/bin/eventcatalog.js +0 -141
- package/components/BreadCrumbs.tsx +0 -50
- package/components/ContentView.tsx +0 -123
- package/components/Footer.tsx +0 -31
- package/components/Grids/DomainGrid.tsx +0 -61
- package/components/Grids/EventGrid.tsx +0 -102
- package/components/Grids/ServiceGrid.tsx +0 -84
- package/components/Grids/UserGrid.tsx +0 -55
- package/components/Header.tsx +0 -74
- package/components/Mdx/AsyncApiSpec.tsx +0 -25
- package/components/Mdx/Examples.tsx +0 -70
- package/components/Mdx/NodeGraph/GraphElements.tsx +0 -294
- package/components/Mdx/NodeGraph/GraphLayout.ts +0 -110
- package/components/Mdx/NodeGraph/Node.tsx +0 -15
- package/components/Mdx/NodeGraph/NodeGraph.tsx +0 -168
- package/components/Mdx/NodeGraph/__tests__/GraphElements.spec.ts +0 -102
- package/components/Mdx/NodeGraph/__tests__/GraphLayout.spec.ts +0 -115
- package/components/Mdx/NodeGraph/__tests__/__snapshots__/GraphElements.spec.ts.snap +0 -559
- package/components/Mdx/NodeGraph/__tests__/__snapshots__/GraphLayout.spec.ts.snap +0 -81
- package/components/Mdx/OpenApiSpec.tsx +0 -21
- package/components/Mdx/SchemaViewer/SchemaViewer.module.css +0 -5
- package/components/Mdx/SchemaViewer/SchemaViewer.tsx +0 -34
- package/components/Mermaid/index.tsx +0 -58
- package/components/NotFound/index.tsx +0 -40
- package/components/Sidebars/DomainSidebar.tsx +0 -55
- package/components/Sidebars/EventSidebar.tsx +0 -172
- package/components/Sidebars/ServiceSidebar.tsx +0 -128
- package/components/Sidebars/components/ExternalLinks.tsx +0 -28
- package/components/Sidebars/components/ItemList.tsx +0 -32
- package/components/Sidebars/components/Owners.tsx +0 -38
- package/components/Sidebars/components/Tags.tsx +0 -45
- package/components/SyntaxHighlighter.tsx +0 -42
- package/eventcatalog.config.js +0 -58
- package/eventcatalog.styles.css +0 -15
- package/hooks/EventCatalog.tsx +0 -54
- package/lib/__tests__/assets/domains/User/events/UserCreated/index.md +0 -20
- package/lib/__tests__/assets/domains/User/events/UserRemoved/examples/Basic.cs +0 -31
- package/lib/__tests__/assets/domains/User/events/UserRemoved/examples/Basic.js +0 -1
- package/lib/__tests__/assets/domains/User/events/UserRemoved/index.md +0 -16
- package/lib/__tests__/assets/domains/User/events/UserRemoved/schema.json +0 -4
- package/lib/__tests__/assets/domains/User/index.md +0 -16
- package/lib/__tests__/assets/domains/User/services/User Service/index.md +0 -19
- package/lib/__tests__/assets/events/AddedItemToCart/index.md +0 -25
- package/lib/__tests__/assets/events/EmailSent/index.md +0 -15
- package/lib/__tests__/assets/events/EventWithSchemaAndExamples/examples/Basic.cs +0 -31
- package/lib/__tests__/assets/events/EventWithSchemaAndExamples/examples/Basic.js +0 -1
- package/lib/__tests__/assets/events/EventWithSchemaAndExamples/index.md +0 -8
- package/lib/__tests__/assets/events/EventWithSchemaAndExamples/schema.json +0 -4
- package/lib/__tests__/assets/events/EventWithVersions/index.md +0 -10
- package/lib/__tests__/assets/events/EventWithVersions/versioned/0.0.1/index.md +0 -10
- package/lib/__tests__/assets/services/Basket Service/index.md +0 -26
- package/lib/__tests__/assets/services/Email Platform/index.md +0 -17
- package/lib/__tests__/assets/services/Payment Service/index.md +0 -7
- package/lib/__tests__/domains.spec.ts +0 -416
- package/lib/__tests__/events.spec.ts +0 -514
- package/lib/__tests__/file-reader.spec.ts +0 -69
- package/lib/__tests__/graphs.spec.ts +0 -88
- package/lib/__tests__/services.spec.ts +0 -268
- package/lib/analytics.ts +0 -30
- package/lib/domains.ts +0 -160
- package/lib/events.ts +0 -313
- package/lib/file-reader.ts +0 -76
- package/lib/graphs.ts +0 -92
- package/lib/services.ts +0 -126
- package/next-env.d.ts +0 -5
- package/next.config.js +0 -11
- package/out/404/index.html +0 -12
- package/out/404.html +0 -12
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderComplete/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderComplete.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderConfirmed/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderConfirmed.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderCreated/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderCreated.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderRequested/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/events/OrderRequested.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders/services/Orders Service.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Orders.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping/events/AddedItemToCart/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping/events/AddedItemToCart/v/0.0.1.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping/events/AddedItemToCart/v/0.0.2.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping/events/AddedItemToCart.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping/events/RemovedItemFromCart/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping/events/RemovedItemFromCart.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains/Shopping.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/domains.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/PaymentProcessed/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/PaymentProcessed.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/ShipmentDelivered/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/ShipmentDelivered.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/ShipmentDispatched/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/ShipmentDispatched.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/ShipmentPrepared/logs.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events/ShipmentPrepared.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/events.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/overview.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/services/Orders Service.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/services/Payment Service.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/services/Shipping Service.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/services.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/users/dboyne.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/users/mSmith.json +0 -1
- package/out/_next/data/wZIh57Hs672ULoPeUaYa1/visualiser.json +0 -1
- package/out/_next/static/chunks/020d8314.2bae2f29ef0060e4.js +0 -1
- package/out/_next/static/chunks/1093.67f04e0e6b50c9e5.js +0 -1
- package/out/_next/static/chunks/1178-c3c8c74ac08d7c77.js +0 -1
- package/out/_next/static/chunks/1254.a78e9444e102b061.js +0 -1
- package/out/_next/static/chunks/130.fa515915f80e17f9.js +0 -1
- package/out/_next/static/chunks/1318.a5349c1b3da2b184.js +0 -1
- package/out/_next/static/chunks/1415.55c7c89ef0a8aab1.js +0 -1
- package/out/_next/static/chunks/1455-8df9e334899797b2.js +0 -1
- package/out/_next/static/chunks/172-940ad0353b57ff98.js +0 -1
- package/out/_next/static/chunks/1733.1bead33faaa9eeb0.js +0 -1
- package/out/_next/static/chunks/1806.3ed762ab3ecedc9d.js +0 -1
- package/out/_next/static/chunks/2157.cd3aa9fee64d976e.js +0 -1
- package/out/_next/static/chunks/2566.4084969752c613a9.js +0 -1
- package/out/_next/static/chunks/2620-21775e17d8a6a407.js +0 -1
- package/out/_next/static/chunks/2edb282b-45c56c19221816df.js +0 -1
- package/out/_next/static/chunks/3116-446dd88b93c44018.js +0 -1
- package/out/_next/static/chunks/3193.f69abc67598575a9.js +0 -1
- package/out/_next/static/chunks/3260.00ac1405e82b8dd9.js +0 -1
- package/out/_next/static/chunks/3271.83723868c9b8e7c1.js +0 -1
- package/out/_next/static/chunks/3287.f50c49237cef9ae8.js +0 -1
- package/out/_next/static/chunks/39a9cf3f.8cc8ac3887be2999.js +0 -1
- package/out/_next/static/chunks/3ede58a6.44fda8e0e5284248.js +0 -1
- package/out/_next/static/chunks/40.16abe9d3c57256d6.js +0 -1
- package/out/_next/static/chunks/407.3078ab29e8d18c02.js +0 -1
- package/out/_next/static/chunks/438.dea6dada9bd4b683.js +0 -1
- package/out/_next/static/chunks/4384-8a28a71e7e3b8d8a.js +0 -1
- package/out/_next/static/chunks/4466.dc03dbcd026995cc.js +0 -1
- package/out/_next/static/chunks/4737.ae583b848d202a93.js +0 -1
- package/out/_next/static/chunks/5048.73fa7a6d734ba5ef.js +0 -1
- package/out/_next/static/chunks/5092.8ead508f86f4b11c.js +0 -1
- package/out/_next/static/chunks/5493-b00dc3d50ab46716.js +0 -1
- package/out/_next/static/chunks/5835.a9405ab0913544df.js +0 -1
- package/out/_next/static/chunks/6067.cc75c37618cf0147.js +0 -1
- package/out/_next/static/chunks/6121.758a43c0db92ca23.js +0 -1
- package/out/_next/static/chunks/6229.7a9f0c8b204b76dc.js +0 -1
- package/out/_next/static/chunks/6487.44c6e83c098ed47f.js +0 -1
- package/out/_next/static/chunks/6582.06af6897be0d24b3.js +0 -1
- package/out/_next/static/chunks/6724.ed1280c926906c76.js +0 -1
- package/out/_next/static/chunks/6772-fc6143a6584acf9b.js +0 -1
- package/out/_next/static/chunks/6790-f4527d80153a3e25.js +0 -1
- package/out/_next/static/chunks/7005-09e42f99859b8d03.js +0 -1
- package/out/_next/static/chunks/7109-c8d3fde4c3b6798e.js +0 -1
- package/out/_next/static/chunks/7374.a673e317f007d3b6.js +0 -1
- package/out/_next/static/chunks/74030e57.9636ad3c5c96940b.js +0 -1
- package/out/_next/static/chunks/7458.1de01a44cd67f6f0.js +0 -1
- package/out/_next/static/chunks/7469.d932a6b01168373b.js +0 -1
- package/out/_next/static/chunks/7636.9eaf88a09c2a88ed.js +0 -1
- package/out/_next/static/chunks/7f5d3f51-659399fe6f04b9eb.js +0 -1
- package/out/_next/static/chunks/8264-a1b0376ff4b3d4da.js +0 -1
- package/out/_next/static/chunks/828-1a4a120d2fbea802.js +0 -1
- package/out/_next/static/chunks/8341-b8d844d6f606aed5.js +0 -1
- package/out/_next/static/chunks/8470.c811187bd2982a8a.js +0 -1
- package/out/_next/static/chunks/9076.0a13d7d5aab7bfa1.js +0 -1
- package/out/_next/static/chunks/9097.1efc23284d82765c.js +0 -1
- package/out/_next/static/chunks/9270.a4c64e6be4a278a4.js +0 -1
- package/out/_next/static/chunks/9404.a44dfe8858add605.js +0 -1
- package/out/_next/static/chunks/9497.49670ee9a8bd76f7.js +0 -1
- package/out/_next/static/chunks/9930.28415573db2b7806.js +0 -7
- package/out/_next/static/chunks/b2f22a9c-0216e9400ac0ac1c.js +0 -1
- package/out/_next/static/chunks/b9e0c7b4-52b02c0d4f161186.js +0 -1
- package/out/_next/static/chunks/eb6e03f4.3dd8d555aebe18ff.js +0 -1
- package/out/_next/static/chunks/f4df0e03.56d1c15b5532ab26.js +0 -1
- package/out/_next/static/chunks/framework-6cc1bceeaaf75e91.js +0 -1
- package/out/_next/static/chunks/main-da37322a396d572a.js +0 -1
- package/out/_next/static/chunks/pages/_app-d40841fd52b70886.js +0 -1
- package/out/_next/static/chunks/pages/_error-c36fa6f7fd569cf6.js +0 -1
- package/out/_next/static/chunks/pages/domains/[domain]/events/[name]/logs-350f383eed1cf3f8.js +0 -1
- package/out/_next/static/chunks/pages/domains/[domain]/events/[name]/v/[version]-45b0d7bc42f6f81c.js +0 -1
- package/out/_next/static/chunks/pages/domains/[domain]/events/[name]-15bb0ef487953fa1.js +0 -1
- package/out/_next/static/chunks/pages/domains/[domain]/services/[name]-a4857d4d0aa4d04b.js +0 -1
- package/out/_next/static/chunks/pages/domains/[domain]-ea20e2daae1794fc.js +0 -1
- package/out/_next/static/chunks/pages/domains-71179cbdb719a0f8.js +0 -1
- package/out/_next/static/chunks/pages/events/[name]/logs-695c5b2cfd996539.js +0 -1
- package/out/_next/static/chunks/pages/events/[name]/v/[version]-b718302d7185dcb0.js +0 -1
- package/out/_next/static/chunks/pages/events/[name]-8cb0b3b469bd7845.js +0 -1
- package/out/_next/static/chunks/pages/events-83c9161a6e696533.js +0 -1
- package/out/_next/static/chunks/pages/index-68062a10328e7d10.js +0 -1
- package/out/_next/static/chunks/pages/overview-4251cc856f776fc2.js +0 -1
- package/out/_next/static/chunks/pages/services/[name]-7030da24d73a8ea3.js +0 -1
- package/out/_next/static/chunks/pages/services-7069c0a5295e53ae.js +0 -1
- package/out/_next/static/chunks/pages/users/[id]-00aeace648436383.js +0 -1
- package/out/_next/static/chunks/pages/users-412f257b1de51363.js +0 -1
- package/out/_next/static/chunks/pages/visualiser-8474d03175cf9d12.js +0 -1
- package/out/_next/static/chunks/polyfills-c67a75d1b6f99dc8.js +0 -1
- package/out/_next/static/chunks/webpack-1ea4cabfc6778694.js +0 -1
- package/out/_next/static/css/7e14b4dede1671ad.css +0 -1
- package/out/_next/static/css/94b9a747218712b2.css +0 -3
- package/out/_next/static/css/ae8abf3666c55019.css +0 -5
- package/out/_next/static/css/cc3c8fcadcf7a58b.css +0 -1
- package/out/_next/static/css/deb57cf90a65a90f.css +0 -1
- package/out/_next/static/css/ed97de5465a152bb.css +0 -1
- package/out/_next/static/wZIh57Hs672ULoPeUaYa1/_buildManifest.js +0 -1
- package/out/_next/static/wZIh57Hs672ULoPeUaYa1/_ssgManifest.js +0 -1
- package/out/domains/Orders/events/OrderComplete/index.html +0 -40
- package/out/domains/Orders/events/OrderComplete/logs/index.html +0 -1
- package/out/domains/Orders/events/OrderConfirmed/index.html +0 -40
- package/out/domains/Orders/events/OrderConfirmed/logs/index.html +0 -1
- package/out/domains/Orders/events/OrderCreated/index.html +0 -2
- package/out/domains/Orders/events/OrderCreated/logs/index.html +0 -1
- package/out/domains/Orders/events/OrderRequested/index.html +0 -40
- package/out/domains/Orders/events/OrderRequested/logs/index.html +0 -1
- package/out/domains/Orders/index.html +0 -2
- package/out/domains/Orders/services/Orders Service/index.html +0 -2
- package/out/domains/Shopping/events/AddedItemToCart/index.html +0 -65
- package/out/domains/Shopping/events/AddedItemToCart/logs/index.html +0 -1
- package/out/domains/Shopping/events/AddedItemToCart/v/0.0.1/index.html +0 -59
- package/out/domains/Shopping/events/AddedItemToCart/v/0.0.2/index.html +0 -66
- package/out/domains/Shopping/events/RemovedItemFromCart/index.html +0 -48
- package/out/domains/Shopping/events/RemovedItemFromCart/logs/index.html +0 -1
- package/out/domains/Shopping/index.html +0 -2
- package/out/domains/index.html +0 -3
- package/out/events/PaymentProcessed/index.html +0 -44
- package/out/events/PaymentProcessed/logs/index.html +0 -1
- package/out/events/ShipmentDelivered/index.html +0 -44
- package/out/events/ShipmentDelivered/logs/index.html +0 -1
- package/out/events/ShipmentDispatched/index.html +0 -44
- package/out/events/ShipmentDispatched/logs/index.html +0 -1
- package/out/events/ShipmentPrepared/index.html +0 -2
- package/out/events/ShipmentPrepared/logs/index.html +0 -1
- package/out/events/index.html +0 -11
- package/out/favicon.ico +0 -0
- package/out/index.html +0 -1
- package/out/logo-random.svg +0 -114
- package/out/logo.svg +0 -44
- package/out/opengraph.png +0 -0
- package/out/overview/index.html +0 -1
- package/out/services/Orders Service/index.html +0 -1
- package/out/services/Payment Service/index.html +0 -2
- package/out/services/Shipping Service/index.html +0 -2
- package/out/services/index.html +0 -4
- package/out/users/dboyne/index.html +0 -16
- package/out/users/index.html +0 -1
- package/out/users/mSmith/index.html +0 -13
- package/out/visualiser/index.html +0 -16
- package/pages/_app.tsx +0 -111
- package/pages/_document.tsx +0 -18
- package/pages/domains/[domain]/events/[name]/logs.tsx +0 -35
- package/pages/domains/[domain]/events/[name]/v/[version].tsx +0 -39
- package/pages/domains/[domain]/events/[name].tsx +0 -46
- package/pages/domains/[domain]/index.tsx +0 -137
- package/pages/domains/[domain]/services/[name].tsx +0 -42
- package/pages/domains.tsx +0 -210
- package/pages/events/[name]/logs.tsx +0 -177
- package/pages/events/[name]/v/[version].tsx +0 -38
- package/pages/events/[name].tsx +0 -223
- package/pages/events.tsx +0 -357
- package/pages/index.tsx +0 -56
- package/pages/overview.tsx +0 -89
- package/pages/services/[name].tsx +0 -164
- package/pages/services.tsx +0 -311
- package/pages/users/[id].tsx +0 -101
- package/pages/users.tsx +0 -43
- package/pages/visualiser.tsx +0 -322
- package/postcss.config.js +0 -6
- package/public/logo-random.svg +0 -114
- package/public/logo.svg +0 -44
- package/scripts/__tests__/assets/eventcatalog.config.js +0 -32
- package/scripts/__tests__/generate.spec.ts +0 -36
- package/scripts/generate.js +0 -28
- package/scripts/move-schemas-for-download.js +0 -80
- package/styles/Home.module.css +0 -116
- package/styles/globals.css +0 -85
- package/tailwind.config.js +0 -36
- package/types/index.ts +0 -7
- package/utils/random-bg.ts +0 -13
- /package/{lib/__tests__/assets/services/Payment Service/openapi.yaml → public/openapi.yml} +0 -0
package/components/Header.tsx
DELETED
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import Link from 'next/link';
|
|
2
|
-
import getConfig from 'next/config';
|
|
3
|
-
import { useRouter } from 'next/router';
|
|
4
|
-
import { useConfig } from '@/hooks/EventCatalog';
|
|
5
|
-
|
|
6
|
-
const defaultNavigation = [
|
|
7
|
-
{ label: 'Events', href: '/events' },
|
|
8
|
-
{ label: 'Services', href: '/services' },
|
|
9
|
-
{ label: 'Domains', href: '/domains' },
|
|
10
|
-
{ label: 'Users', href: '/users' },
|
|
11
|
-
{ label: 'Visualiser', href: '/visualiser' },
|
|
12
|
-
{ label: '3D Node Graph', href: '/overview' },
|
|
13
|
-
];
|
|
14
|
-
|
|
15
|
-
function classNames(...classes) {
|
|
16
|
-
return classes.filter(Boolean).join(' ');
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export default function Example() {
|
|
20
|
-
const { title, homepageLink, logo, headerLinks: configNavigation } = useConfig();
|
|
21
|
-
const router = useRouter();
|
|
22
|
-
|
|
23
|
-
const { publicRuntimeConfig: { basePath = '' } = {} } = getConfig();
|
|
24
|
-
const logoToLoad = logo || { alt: 'EventCatalog Logo', src: `logo.svg` };
|
|
25
|
-
|
|
26
|
-
const headerNavigation = configNavigation || defaultNavigation;
|
|
27
|
-
|
|
28
|
-
return (
|
|
29
|
-
<div className="bg-gray-800">
|
|
30
|
-
<div className="max-w-7xl mx-auto ">
|
|
31
|
-
<div className="relative flex items-center justify-between h-16">
|
|
32
|
-
<div className="flex-1 flex items-center justify-center sm:items-stretch sm:justify-start">
|
|
33
|
-
<div className="flex-shrink-0 flex items-center text-white font-bold">
|
|
34
|
-
{!homepageLink && (
|
|
35
|
-
<Link href="/">
|
|
36
|
-
<a className="flex items-center">
|
|
37
|
-
<img alt="logo" className="text-white w-8 inline-block mr-3" src={`${basePath}/${logoToLoad.src}`} />
|
|
38
|
-
<span className="text-xl">{title}</span>
|
|
39
|
-
</a>
|
|
40
|
-
</Link>
|
|
41
|
-
)}
|
|
42
|
-
{homepageLink && (
|
|
43
|
-
<a href={homepageLink} className="flex items-center">
|
|
44
|
-
<img alt="logo" className="text-white w-8 inline-block mr-3" src={`${basePath}/${logoToLoad.src}`} />
|
|
45
|
-
<span className="text-xl">{title}</span>
|
|
46
|
-
</a>
|
|
47
|
-
)}
|
|
48
|
-
</div>
|
|
49
|
-
</div>
|
|
50
|
-
<div className="hidden sm:block sm:ml-6">
|
|
51
|
-
<div className="flex space-x-4">
|
|
52
|
-
{headerNavigation.map((item) => {
|
|
53
|
-
const current = router.pathname === item.href;
|
|
54
|
-
return (
|
|
55
|
-
<Link key={item.label} href={item.href}>
|
|
56
|
-
<a
|
|
57
|
-
className={classNames(
|
|
58
|
-
current ? 'bg-gray-900 text-white' : 'text-gray-300 hover:bg-gray-700 hover:text-white',
|
|
59
|
-
'px-3 py-2 rounded-md text-sm font-medium'
|
|
60
|
-
)}
|
|
61
|
-
aria-current={current ? 'page' : undefined}
|
|
62
|
-
>
|
|
63
|
-
{item.label}
|
|
64
|
-
</a>
|
|
65
|
-
</Link>
|
|
66
|
-
);
|
|
67
|
-
})}
|
|
68
|
-
</div>
|
|
69
|
-
</div>
|
|
70
|
-
</div>
|
|
71
|
-
</div>
|
|
72
|
-
</div>
|
|
73
|
-
);
|
|
74
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import dynamic from 'next/dynamic';
|
|
2
|
-
import '@asyncapi/react-component/styles/default.min.css';
|
|
3
|
-
|
|
4
|
-
const AsyncApiComponent = dynamic(import('@asyncapi/react-component'), { ssr: false });
|
|
5
|
-
|
|
6
|
-
const config = {
|
|
7
|
-
show: {
|
|
8
|
-
errors: false,
|
|
9
|
-
},
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
interface AsyncApiSpecProps {
|
|
13
|
-
spec?: string;
|
|
14
|
-
url?: string;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export default function AsyncApiSpec({ spec, url }: AsyncApiSpecProps) {
|
|
18
|
-
const schema = !url ? spec : { url };
|
|
19
|
-
|
|
20
|
-
return (
|
|
21
|
-
<div className={`my-4 border border-gray-300 border-dashed px-5 `}>
|
|
22
|
-
<AsyncApiComponent schema={schema} config={config} />
|
|
23
|
-
</div>
|
|
24
|
-
);
|
|
25
|
-
}
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import React, { useState } from 'react';
|
|
2
|
-
import SyntaxHighlighter from '@/components/SyntaxHighlighter';
|
|
3
|
-
|
|
4
|
-
function classNames(...classes) {
|
|
5
|
-
return classes.filter(Boolean).join(' ');
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
interface ExampleProps {
|
|
9
|
-
title?: string;
|
|
10
|
-
description?: string;
|
|
11
|
-
examples: any;
|
|
12
|
-
showLineNumbers?: boolean;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
function Examples({ title = 'Examples', description, examples = [], showLineNumbers }: ExampleProps) {
|
|
16
|
-
const tabs = examples.map((example, index) => ({
|
|
17
|
-
name: example.name || `Example ${index + 1}`,
|
|
18
|
-
content: example.snippet,
|
|
19
|
-
description: example.description,
|
|
20
|
-
langugage: example.langugage,
|
|
21
|
-
}));
|
|
22
|
-
|
|
23
|
-
const [selectedTab, setSelectedTab] = useState(tabs[0]);
|
|
24
|
-
|
|
25
|
-
const handleTabSelection = (tab: string) => {
|
|
26
|
-
setSelectedTab(tab);
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
return (
|
|
30
|
-
<div className="my-5 examples">
|
|
31
|
-
<div className="">
|
|
32
|
-
<h2 className="text-lg font-medium text-gray-700 underline">{title}</h2>
|
|
33
|
-
{description && <p className="text-md font-medium text-gray-700">{description}</p>}
|
|
34
|
-
|
|
35
|
-
<div>
|
|
36
|
-
<div className="col-span-5">
|
|
37
|
-
<nav className="-mb-2 flex bg-gray-900 w-full overflow-hidden overflow-x-scroll" aria-label="Tabs">
|
|
38
|
-
{tabs.map((tab) => {
|
|
39
|
-
const isSelected = tab.name === selectedTab.name;
|
|
40
|
-
return (
|
|
41
|
-
<button
|
|
42
|
-
type="button"
|
|
43
|
-
key={tab.name}
|
|
44
|
-
onClick={() => handleTabSelection(tab)}
|
|
45
|
-
className={classNames(
|
|
46
|
-
isSelected
|
|
47
|
-
? 'border-yellow-300 text-yellow-300 selected bg-gray-700'
|
|
48
|
-
: 'border-transparent text-gray-500 hover:text-gray-400 bg-gray-800 ',
|
|
49
|
-
'whitespace-nowrap py-3 border-b-2 font-medium important:no-underline px-6 text-xs transition '
|
|
50
|
-
)}
|
|
51
|
-
aria-current={isSelected ? 'page' : undefined}
|
|
52
|
-
>
|
|
53
|
-
{tab.name}
|
|
54
|
-
</button>
|
|
55
|
-
);
|
|
56
|
-
})}
|
|
57
|
-
</nav>
|
|
58
|
-
<div>
|
|
59
|
-
<SyntaxHighlighter language={selectedTab.langugage} showLineNumbers={showLineNumbers}>
|
|
60
|
-
{selectedTab.content}
|
|
61
|
-
</SyntaxHighlighter>
|
|
62
|
-
</div>
|
|
63
|
-
</div>
|
|
64
|
-
</div>
|
|
65
|
-
</div>
|
|
66
|
-
</div>
|
|
67
|
-
);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export default Examples;
|
|
@@ -1,294 +0,0 @@
|
|
|
1
|
-
import { ArrowHeadType, XYPosition, Node, Edge } from 'react-flow-renderer';
|
|
2
|
-
import getConfig from 'next/config';
|
|
3
|
-
import type { Event, Service } from '@eventcatalog/types';
|
|
4
|
-
import CustomNode from './Node';
|
|
5
|
-
|
|
6
|
-
const { publicRuntimeConfig: { basePath = '' } = {} } = getConfig();
|
|
7
|
-
|
|
8
|
-
const MIN_NODE_WIDTH = 150;
|
|
9
|
-
type NODE_TYPES = 'service' | 'event';
|
|
10
|
-
|
|
11
|
-
const generateLink = (value, type, domain?) => `${basePath}/${domain ? `domains/${domain}/` : ''}${type}/${value}`;
|
|
12
|
-
const calcWidth = (value) => (value.length * 8 > MIN_NODE_WIDTH ? value.length * 8 : MIN_NODE_WIDTH);
|
|
13
|
-
|
|
14
|
-
const buildNodeEdge = ({ id, target, source, label, isAnimated = true }): Edge => ({
|
|
15
|
-
id,
|
|
16
|
-
target,
|
|
17
|
-
source,
|
|
18
|
-
type: 'smoothstep',
|
|
19
|
-
arrowHeadType: ArrowHeadType.ArrowClosed,
|
|
20
|
-
animated: isAnimated,
|
|
21
|
-
label,
|
|
22
|
-
labelBgPadding: [8, 4],
|
|
23
|
-
labelBgBorderRadius: 4,
|
|
24
|
-
labelStyle: { fontSize: '6px' },
|
|
25
|
-
labelBgStyle: { fill: 'white', color: '#fff', fillOpacity: 0.5 },
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
const buildNodeData = ({
|
|
29
|
-
name,
|
|
30
|
-
label,
|
|
31
|
-
type,
|
|
32
|
-
maxWidth,
|
|
33
|
-
renderInColumn,
|
|
34
|
-
domain,
|
|
35
|
-
}: {
|
|
36
|
-
name: string;
|
|
37
|
-
label: string;
|
|
38
|
-
type: NODE_TYPES;
|
|
39
|
-
maxWidth?: number;
|
|
40
|
-
renderInColumn?: number;
|
|
41
|
-
domain?: string;
|
|
42
|
-
}) => {
|
|
43
|
-
const width = calcWidth(label);
|
|
44
|
-
const linkType = type === 'service' ? 'services' : 'events';
|
|
45
|
-
|
|
46
|
-
const link = generateLink(name, linkType, domain);
|
|
47
|
-
return { label, link, width, maxWidth, renderInColumn };
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
const getNodeLabel = ({ type, label, includeIcon }: { type: NODE_TYPES; label: any; includeIcon: boolean }) => {
|
|
51
|
-
if (!includeIcon) return label;
|
|
52
|
-
return <CustomNode type={type} label={label} />;
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Builds a graph for a given event
|
|
57
|
-
* @param {Event} - event
|
|
58
|
-
* @param rootNodeColor - The color of the root node
|
|
59
|
-
* @param isAnimated - whether to animate the graph
|
|
60
|
-
*/
|
|
61
|
-
export const getEventElements = (
|
|
62
|
-
{ name: eventName, domain, consumers: eventConsumers = [], producers: eventProducers = [] }: Event,
|
|
63
|
-
rootNodeColor = '#2563eb',
|
|
64
|
-
isAnimated = true,
|
|
65
|
-
includeLabels = false,
|
|
66
|
-
includeNodeIcons = false
|
|
67
|
-
) => {
|
|
68
|
-
const position: XYPosition = { x: 0, y: 0 };
|
|
69
|
-
|
|
70
|
-
const consumerColor = '#818cf8';
|
|
71
|
-
const producerColor = '#75d7b6';
|
|
72
|
-
const nodeStyles = {
|
|
73
|
-
fontSize: includeNodeIcons ? '8px' : 'auto',
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
const producersNames = eventProducers.map((s) => calcWidth(s.name));
|
|
77
|
-
const maxProducersWidth = Math.max(...producersNames);
|
|
78
|
-
const consumersNames = eventConsumers.map((s) => calcWidth(s.name));
|
|
79
|
-
const maxConsumersWidth = Math.max(...consumersNames);
|
|
80
|
-
|
|
81
|
-
const eventNameAsNodeID = `ev-${eventName.replace(/ /g, '_')}`;
|
|
82
|
-
const eventNodeWidth = calcWidth(eventName);
|
|
83
|
-
|
|
84
|
-
const producers = eventProducers.map((node) => ({
|
|
85
|
-
label: node.name,
|
|
86
|
-
id: `pr-${node.name.replace(/ /g, '_')}`,
|
|
87
|
-
domain: node.domain,
|
|
88
|
-
}));
|
|
89
|
-
const consumers = eventConsumers.map((node) => ({
|
|
90
|
-
label: node.name,
|
|
91
|
-
id: `co-${node.name.replace(/ /g, '_')}`,
|
|
92
|
-
domain: node.domain,
|
|
93
|
-
}));
|
|
94
|
-
|
|
95
|
-
// Transforms services & event into a graph model
|
|
96
|
-
const producersNodes: Node[] = producers.map(({ label, id, domain: producerDomain }) => {
|
|
97
|
-
const nodeWidth = calcWidth(label);
|
|
98
|
-
const diff = maxProducersWidth - nodeWidth;
|
|
99
|
-
const nodeMaxWidth = diff !== 0 ? nodeWidth - diff : maxProducersWidth;
|
|
100
|
-
const labelToRender = getNodeLabel({ type: 'service', label, includeIcon: includeNodeIcons });
|
|
101
|
-
return {
|
|
102
|
-
id,
|
|
103
|
-
data: buildNodeData({
|
|
104
|
-
name: label,
|
|
105
|
-
label: labelToRender,
|
|
106
|
-
type: 'service',
|
|
107
|
-
maxWidth: nodeMaxWidth,
|
|
108
|
-
renderInColumn: 1,
|
|
109
|
-
domain: producerDomain,
|
|
110
|
-
}),
|
|
111
|
-
style: { border: `2px solid ${producerColor}`, width: nodeWidth, ...nodeStyles },
|
|
112
|
-
type: 'input',
|
|
113
|
-
position,
|
|
114
|
-
};
|
|
115
|
-
});
|
|
116
|
-
const consumersNodes: Node[] = consumers.map(({ id, label, domain: consumerDomain }) => {
|
|
117
|
-
const width = calcWidth(label);
|
|
118
|
-
const labelToRender = getNodeLabel({ type: 'service', label, includeIcon: includeNodeIcons });
|
|
119
|
-
return {
|
|
120
|
-
id,
|
|
121
|
-
data: buildNodeData({
|
|
122
|
-
name: label,
|
|
123
|
-
label: labelToRender,
|
|
124
|
-
type: 'service',
|
|
125
|
-
maxWidth: maxConsumersWidth,
|
|
126
|
-
renderInColumn: 3,
|
|
127
|
-
domain: consumerDomain,
|
|
128
|
-
}),
|
|
129
|
-
style: { border: `2px solid ${consumerColor}`, width, ...nodeStyles },
|
|
130
|
-
type: 'output',
|
|
131
|
-
position,
|
|
132
|
-
};
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
const eventNode: Node = {
|
|
136
|
-
id: eventNameAsNodeID,
|
|
137
|
-
data: buildNodeData({
|
|
138
|
-
name: eventName,
|
|
139
|
-
label: getNodeLabel({ type: 'event', label: eventName, includeIcon: includeNodeIcons }),
|
|
140
|
-
type: 'event',
|
|
141
|
-
maxWidth: eventNodeWidth,
|
|
142
|
-
renderInColumn: 2,
|
|
143
|
-
domain,
|
|
144
|
-
}),
|
|
145
|
-
style: {
|
|
146
|
-
border: `2px solid ${rootNodeColor}`,
|
|
147
|
-
width: eventNodeWidth,
|
|
148
|
-
...nodeStyles,
|
|
149
|
-
},
|
|
150
|
-
position,
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
// Build connections
|
|
154
|
-
const producersEdges: Edge[] = producers.map(({ id, label }) =>
|
|
155
|
-
buildNodeEdge({
|
|
156
|
-
id: `epe-${label.replace(/ /g, '_')}-${eventNameAsNodeID}`,
|
|
157
|
-
source: id,
|
|
158
|
-
target: eventNameAsNodeID,
|
|
159
|
-
isAnimated,
|
|
160
|
-
label: includeLabels ? 'publishes' : '',
|
|
161
|
-
})
|
|
162
|
-
);
|
|
163
|
-
const consumersEdges: Edge[] = consumers.map(({ id, label }) =>
|
|
164
|
-
buildNodeEdge({
|
|
165
|
-
id: `ece-${label.replace(/ /g, '_')}-${eventNameAsNodeID}`,
|
|
166
|
-
target: id,
|
|
167
|
-
source: eventNameAsNodeID,
|
|
168
|
-
isAnimated,
|
|
169
|
-
label: includeLabels ? 'subscribed by' : '',
|
|
170
|
-
})
|
|
171
|
-
);
|
|
172
|
-
|
|
173
|
-
// Merge nodes in order
|
|
174
|
-
const elements: (Node | Edge)[] = [...producersNodes, eventNode, ...consumersNodes, ...producersEdges, ...consumersEdges];
|
|
175
|
-
return elements;
|
|
176
|
-
};
|
|
177
|
-
|
|
178
|
-
/**
|
|
179
|
-
* Builds a graph for a given service
|
|
180
|
-
* @param {Service} service
|
|
181
|
-
* @param {string} rootNodeColor of the root node
|
|
182
|
-
* @param isAnimated whether the graph should be animated
|
|
183
|
-
* @returns {string} Mermaid Graph
|
|
184
|
-
*/
|
|
185
|
-
export const getServiceElements = (
|
|
186
|
-
{ publishes, subscribes, name: serviceName, domain }: Service,
|
|
187
|
-
rootNodeColor = '#2563eb',
|
|
188
|
-
isAnimated = true,
|
|
189
|
-
includeEdgeLabels = false,
|
|
190
|
-
includeNodeIcons = false
|
|
191
|
-
) => {
|
|
192
|
-
const position: XYPosition = { x: 0, y: 0 };
|
|
193
|
-
|
|
194
|
-
const publishColor = '#818cf8';
|
|
195
|
-
const subscribeColor = '#75d7b6';
|
|
196
|
-
const nodeStyles = {
|
|
197
|
-
fontSize: includeNodeIcons ? '8px' : 'auto',
|
|
198
|
-
};
|
|
199
|
-
|
|
200
|
-
const publishesNames = publishes.map((e) => calcWidth(e.name));
|
|
201
|
-
const maxPublishesWidth = Math.max(...publishesNames);
|
|
202
|
-
const subscribesNames = subscribes.map((e) => calcWidth(e.name));
|
|
203
|
-
const maxSubscribesWidth = Math.max(...subscribesNames);
|
|
204
|
-
|
|
205
|
-
const serviceNameAsNodeID = `ser-${serviceName.replace(/ /g, '_')}`;
|
|
206
|
-
|
|
207
|
-
// Transforms services & event into a graph model
|
|
208
|
-
const publishesNodes: Node[] = publishes.map((node) => {
|
|
209
|
-
const nodeWidth = calcWidth(node.name);
|
|
210
|
-
const labelToRender = getNodeLabel({ type: 'event', label: node.name, includeIcon: includeNodeIcons });
|
|
211
|
-
return {
|
|
212
|
-
id: `pub-${node.name.replace(/ /g, '_')}`,
|
|
213
|
-
data: buildNodeData({
|
|
214
|
-
name: node.name,
|
|
215
|
-
label: labelToRender,
|
|
216
|
-
type: 'event',
|
|
217
|
-
maxWidth: maxPublishesWidth,
|
|
218
|
-
renderInColumn: 3,
|
|
219
|
-
domain: node.domain,
|
|
220
|
-
}),
|
|
221
|
-
style: { border: `2px solid ${publishColor}`, width: nodeWidth, ...nodeStyles },
|
|
222
|
-
type: 'output',
|
|
223
|
-
position,
|
|
224
|
-
};
|
|
225
|
-
});
|
|
226
|
-
const subscribesNodes: Node[] = subscribes.map((node) => {
|
|
227
|
-
const nodeWidth = calcWidth(node.name);
|
|
228
|
-
const diff = maxSubscribesWidth - nodeWidth;
|
|
229
|
-
const nodeMaxWidth = diff !== 0 ? nodeWidth - diff : maxSubscribesWidth;
|
|
230
|
-
const labelToRender = getNodeLabel({ type: 'event', label: node.name, includeIcon: includeNodeIcons });
|
|
231
|
-
return {
|
|
232
|
-
id: `sub-${node.name.replace(/ /g, '_')}`,
|
|
233
|
-
data: buildNodeData({
|
|
234
|
-
name: node.name,
|
|
235
|
-
label: labelToRender,
|
|
236
|
-
type: 'event',
|
|
237
|
-
maxWidth: nodeMaxWidth,
|
|
238
|
-
...nodeStyles,
|
|
239
|
-
renderInColumn: 1,
|
|
240
|
-
domain: node.domain,
|
|
241
|
-
}),
|
|
242
|
-
style: {
|
|
243
|
-
border: `2px solid ${subscribeColor}`,
|
|
244
|
-
width: nodeWidth,
|
|
245
|
-
...nodeStyles,
|
|
246
|
-
},
|
|
247
|
-
type: 'input',
|
|
248
|
-
position,
|
|
249
|
-
};
|
|
250
|
-
});
|
|
251
|
-
|
|
252
|
-
const serviceNode: Node = {
|
|
253
|
-
id: serviceNameAsNodeID,
|
|
254
|
-
data: buildNodeData({
|
|
255
|
-
name: serviceName,
|
|
256
|
-
label: getNodeLabel({ type: 'service', label: serviceName, includeIcon: includeNodeIcons }),
|
|
257
|
-
type: 'service',
|
|
258
|
-
maxWidth: calcWidth(serviceName),
|
|
259
|
-
renderInColumn: 2,
|
|
260
|
-
domain,
|
|
261
|
-
}),
|
|
262
|
-
style: {
|
|
263
|
-
border: `2px solid ${rootNodeColor}`,
|
|
264
|
-
width: calcWidth(serviceName),
|
|
265
|
-
...nodeStyles,
|
|
266
|
-
},
|
|
267
|
-
position,
|
|
268
|
-
};
|
|
269
|
-
|
|
270
|
-
// Build connections
|
|
271
|
-
const publishesEdges: Edge[] = publishes.map((node) =>
|
|
272
|
-
buildNodeEdge({
|
|
273
|
-
id: `ecp-${node.name.replace(/ /g, '_')}`,
|
|
274
|
-
source: serviceNameAsNodeID,
|
|
275
|
-
target: `pub-${node.name.replace(/ /g, '_')}`,
|
|
276
|
-
isAnimated,
|
|
277
|
-
label: includeEdgeLabels ? 'publishes' : '',
|
|
278
|
-
})
|
|
279
|
-
);
|
|
280
|
-
|
|
281
|
-
const subscribesEdges: Edge[] = subscribes.map((node) =>
|
|
282
|
-
buildNodeEdge({
|
|
283
|
-
id: `esc-${node.name.replace(/ /g, '_')}`,
|
|
284
|
-
target: serviceNameAsNodeID,
|
|
285
|
-
source: `sub-${node.name.replace(/ /g, '_')}`,
|
|
286
|
-
isAnimated,
|
|
287
|
-
label: includeEdgeLabels ? 'subscribed by' : '',
|
|
288
|
-
})
|
|
289
|
-
);
|
|
290
|
-
|
|
291
|
-
// Merge nodes in order
|
|
292
|
-
const elements: (Node | Edge)[] = [...subscribesNodes, serviceNode, ...publishesNodes, ...publishesEdges, ...subscribesEdges];
|
|
293
|
-
return elements;
|
|
294
|
-
};
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { isNode, Elements, Position } from 'react-flow-renderer';
|
|
2
|
-
import dagre from 'dagre';
|
|
3
|
-
import { DataSource } from './NodeGraph';
|
|
4
|
-
|
|
5
|
-
const nodeDefaultWidth = 150;
|
|
6
|
-
const nodeDefaultHeight = 36;
|
|
7
|
-
const offset = 48;
|
|
8
|
-
const verticalOffset = offset / 1.5;
|
|
9
|
-
|
|
10
|
-
const getMaxWidthElementFromPreviousColumn = (elements, column) => {
|
|
11
|
-
const elementsInColumn = elements.filter((element) => element?.data?.renderInColumn === column);
|
|
12
|
-
|
|
13
|
-
if (elementsInColumn.length === 0) return {};
|
|
14
|
-
if (elementsInColumn.length === 1) return elementsInColumn[0];
|
|
15
|
-
|
|
16
|
-
const maxWidthElement = elementsInColumn.reduce((currentElement, element) => {
|
|
17
|
-
const currentElementWidth = currentElement?.data?.maxWidth || currentElement?.data?.width || nodeDefaultWidth;
|
|
18
|
-
const elementWidth = element?.data?.maxWidth || element?.data.width || nodeDefaultWidth;
|
|
19
|
-
return elementWidth > currentElementWidth ? element : currentElement;
|
|
20
|
-
}, elementsInColumn[0]);
|
|
21
|
-
|
|
22
|
-
return maxWidthElement;
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
const getXPositionFromElement = (elem) => {
|
|
26
|
-
const elementWidth = elem?.data?.maxWidth || elem.width || nodeDefaultWidth;
|
|
27
|
-
const currentXPositionOfElement = elem.position.x;
|
|
28
|
-
return currentXPositionOfElement + elementWidth;
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
export default function createGraphLayout(elements: Elements, isHorizontal: boolean): Elements {
|
|
32
|
-
const dagreGraph = new dagre.graphlib.Graph();
|
|
33
|
-
|
|
34
|
-
dagreGraph.setDefaultEdgeLabel(() => ({}));
|
|
35
|
-
dagreGraph.setGraph({ rankdir: 'LR', ranksep: offset * 2, nodesep: verticalOffset });
|
|
36
|
-
|
|
37
|
-
elements.forEach((element) => {
|
|
38
|
-
if (isNode(element)) {
|
|
39
|
-
// eslint-disable-next-line no-underscore-dangle
|
|
40
|
-
const nodeWidth = element.__rf?.width ? element.__rf?.width : element.data?.width;
|
|
41
|
-
dagreGraph.setNode(element.id, {
|
|
42
|
-
width: nodeWidth || nodeDefaultWidth,
|
|
43
|
-
// eslint-disable-next-line no-underscore-dangle
|
|
44
|
-
height: element.__rf?.height || nodeDefaultHeight,
|
|
45
|
-
});
|
|
46
|
-
} else {
|
|
47
|
-
dagreGraph.setEdge(element.source, element.target);
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
// Calculate the layout, to get the node positions with their widths and heights
|
|
52
|
-
dagre.layout(dagreGraph);
|
|
53
|
-
|
|
54
|
-
const allNodes = elements.filter((element) => element.data);
|
|
55
|
-
const allEdges = elements.filter((element) => !element.data);
|
|
56
|
-
|
|
57
|
-
const sortedNodesByColumn = allNodes.sort((nodeA, nodeB) =>
|
|
58
|
-
// eslint-disable-next-line no-nested-ternary
|
|
59
|
-
nodeA.data.renderInColumn > nodeB.data.renderInColumn ? 1 : nodeB.data.renderInColumn > nodeA.data.renderInColumn ? -1 : 0
|
|
60
|
-
);
|
|
61
|
-
const allData = [...sortedNodesByColumn, ...allEdges];
|
|
62
|
-
|
|
63
|
-
return allData.map((element) => {
|
|
64
|
-
if (isNode(element)) {
|
|
65
|
-
const node = dagreGraph.node(element.id);
|
|
66
|
-
element.targetPosition = isHorizontal ? Position.Left : Position.Top;
|
|
67
|
-
element.sourcePosition = isHorizontal ? Position.Right : Position.Bottom;
|
|
68
|
-
|
|
69
|
-
const paddingBetweenNodes = element.data.renderInColumn > 1 ? 75 : 0;
|
|
70
|
-
const currentColumnToRenderIn = element?.data?.renderInColumn;
|
|
71
|
-
const maxWidthElementFromPreviousColumn = getMaxWidthElementFromPreviousColumn(elements, currentColumnToRenderIn - 1);
|
|
72
|
-
|
|
73
|
-
const nodeX =
|
|
74
|
-
Object.keys(maxWidthElementFromPreviousColumn).length > 0
|
|
75
|
-
? getXPositionFromElement(maxWidthElementFromPreviousColumn)
|
|
76
|
-
: 0;
|
|
77
|
-
|
|
78
|
-
element.position = {
|
|
79
|
-
x: nodeX + paddingBetweenNodes,
|
|
80
|
-
y: node.y - node.height / 2,
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
// This is due to an issue with ReactFlow giving errors when we set the width in the styles.
|
|
84
|
-
if (element.style.width) {
|
|
85
|
-
if (Number(element.style.width) <= nodeDefaultWidth) {
|
|
86
|
-
element.style.width = undefined;
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
return element;
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
// Helper - ReactFlow canvas height calculator
|
|
96
|
-
export const calcCanvasHeight = ({ source, data }: DataSource): number => {
|
|
97
|
-
const minHeight = 300;
|
|
98
|
-
const nodeSpacing = nodeDefaultHeight + verticalOffset;
|
|
99
|
-
let nodesHeight = 0;
|
|
100
|
-
|
|
101
|
-
if (source === 'event') {
|
|
102
|
-
nodesHeight = Math.max(data.producerNames.length, data.consumerNames.length) * nodeSpacing;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
if (source === 'service') {
|
|
106
|
-
nodesHeight = Math.max(data.publishes.length, data.subscribes.length) * nodeSpacing;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
return Math.max(minHeight, nodesHeight);
|
|
110
|
-
};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { ServerIcon } from '@heroicons/react/outline/';
|
|
3
|
-
import { MailIcon } from '@heroicons/react/solid/';
|
|
4
|
-
|
|
5
|
-
function Node({ type, label }: any) {
|
|
6
|
-
const Icon = type === 'event' ? MailIcon : ServerIcon;
|
|
7
|
-
return (
|
|
8
|
-
<div>
|
|
9
|
-
<Icon className="h-3 w-3 text-gray-700 inline-block mr-1 -mt-0.5" />
|
|
10
|
-
<span className="text-gray-700">{label}</span>
|
|
11
|
-
</div>
|
|
12
|
-
);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export default Node;
|