@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
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import React, { useEffect } from 'react';
|
|
2
|
-
import mermaid from 'mermaid';
|
|
3
|
-
import { Service, Event } from '@eventcatalog/types';
|
|
4
|
-
import { buildMermaidFlowChartForEvent, buildMermaidFlowChartForService } from '@/lib/graphs';
|
|
5
|
-
|
|
6
|
-
mermaid.initialize({
|
|
7
|
-
startOnLoad: true,
|
|
8
|
-
theme: 'forest',
|
|
9
|
-
securityLevel: 'loose',
|
|
10
|
-
flowchart: {
|
|
11
|
-
useMaxWidth: false,
|
|
12
|
-
},
|
|
13
|
-
themeCSS: `
|
|
14
|
-
.node {
|
|
15
|
-
filter: drop-shadow( 3px 3px 2px rgba(0, 0, 0, .2))
|
|
16
|
-
}
|
|
17
|
-
.mermaid svg {
|
|
18
|
-
width: 10000px
|
|
19
|
-
}
|
|
20
|
-
.node rect {
|
|
21
|
-
fill: white
|
|
22
|
-
}
|
|
23
|
-
`,
|
|
24
|
-
fontFamily: 'Fira Code',
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
interface MermaidProps {
|
|
28
|
-
data: Event | Service;
|
|
29
|
-
source: 'event' | 'service';
|
|
30
|
-
rootNodeColor?: string;
|
|
31
|
-
charts?: string[];
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
function Mermaid({ data, source = 'event', rootNodeColor, charts }: MermaidProps) {
|
|
35
|
-
useEffect(() => {
|
|
36
|
-
mermaid.contentLoaded();
|
|
37
|
-
}, []);
|
|
38
|
-
|
|
39
|
-
if (charts) {
|
|
40
|
-
return (
|
|
41
|
-
<>
|
|
42
|
-
{charts.map((content, index) => (
|
|
43
|
-
<div key={`chart-${index}`} className="mermaid">
|
|
44
|
-
{content}
|
|
45
|
-
</div>
|
|
46
|
-
))}
|
|
47
|
-
</>
|
|
48
|
-
);
|
|
49
|
-
}
|
|
50
|
-
const mermaidChart =
|
|
51
|
-
source === 'event'
|
|
52
|
-
? buildMermaidFlowChartForEvent(data as Event, rootNodeColor)
|
|
53
|
-
: buildMermaidFlowChartForService(data as Service, rootNodeColor);
|
|
54
|
-
|
|
55
|
-
return <div className="mermaid">{mermaidChart}</div>;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
export default Mermaid;
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { DocumentAddIcon } from '@heroicons/react/solid';
|
|
2
|
-
|
|
3
|
-
interface NotFoundProps {
|
|
4
|
-
type: 'service' | 'event' | 'domain';
|
|
5
|
-
name: string;
|
|
6
|
-
editUrl?: string;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export default function Example(props: NotFoundProps) {
|
|
10
|
-
const { type, name, editUrl } = props;
|
|
11
|
-
|
|
12
|
-
return (
|
|
13
|
-
<main className="min-h-full bg-cover bg-top sm:bg-top h-screen">
|
|
14
|
-
<div className="max-w-7xl mx-auto px-4 py-16 text-center sm:px-6 sm:py-24 lg:px-8 lg:py-48">
|
|
15
|
-
<p className="text-sm font-semibold text-gray-700 text-opacity-50 uppercase tracking-wide blur-xl">
|
|
16
|
-
Failed to find {type}
|
|
17
|
-
</p>
|
|
18
|
-
<h1 className="mt-2 text-4xl font-extrabold text-gray-900 tracking-tight sm:text-5xl">Missing Documentation</h1>
|
|
19
|
-
<p className="mt-2 text-lg font-medium text-gray-700 text-opacity-50 text-center ">
|
|
20
|
-
Documentation for {type} is missing!
|
|
21
|
-
<span className="block font-bold text-gray-800 underline break-all max-w-2xl mx-auto py-4">{name}</span>
|
|
22
|
-
</p>
|
|
23
|
-
<p className="mt-4 text-xs text-gray-400">Help the eco-system and add the documentation for others ❤️ </p>
|
|
24
|
-
{editUrl && (
|
|
25
|
-
<div className="mt-12">
|
|
26
|
-
<a
|
|
27
|
-
href={editUrl}
|
|
28
|
-
target="_blank"
|
|
29
|
-
className="inline-flex items-center px-4 py-2 border border-transparent text-sm font-medium rounded-md text-white bg-black bg-opacity-75 "
|
|
30
|
-
rel="noreferrer"
|
|
31
|
-
>
|
|
32
|
-
<DocumentAddIcon className="-ml-1 mr-2 h-5 w-5" aria-hidden="true" />
|
|
33
|
-
Add missing <span className="underline px-1">{type}</span> documentation
|
|
34
|
-
</a>
|
|
35
|
-
</div>
|
|
36
|
-
)}
|
|
37
|
-
</div>
|
|
38
|
-
</main>
|
|
39
|
-
);
|
|
40
|
-
}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import Link from 'next/link';
|
|
3
|
-
import type { Domain } from '@eventcatalog/types';
|
|
4
|
-
import { CubeIcon } from '@heroicons/react/outline';
|
|
5
|
-
import ExternalLinks from './components/ExternalLinks';
|
|
6
|
-
import Tags from './components/Tags';
|
|
7
|
-
import Owners from './components/Owners';
|
|
8
|
-
import ItemList from './components/ItemList';
|
|
9
|
-
|
|
10
|
-
interface DomainSideBarProps {
|
|
11
|
-
domain: Domain;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
function ServiceSidebar({ domain }: DomainSideBarProps) {
|
|
15
|
-
const { name, owners, services, events, tags = [], externalLinks } = domain;
|
|
16
|
-
|
|
17
|
-
return (
|
|
18
|
-
<aside className="hidden xl:block xl:pl-8 divide-y divide-gray-200">
|
|
19
|
-
<h2 className="sr-only">Details</h2>
|
|
20
|
-
|
|
21
|
-
{events.length > 0 && (
|
|
22
|
-
<ItemList
|
|
23
|
-
title={`Events (${events.length})`}
|
|
24
|
-
titleIcon={{ icon: CubeIcon, className: 'text-indigo-400' }}
|
|
25
|
-
items={events.map((event) => ({ label: event.name, href: `/domains/${name}/events/${event.name}`, bgColor: 'indigo' }))}
|
|
26
|
-
/>
|
|
27
|
-
)}
|
|
28
|
-
|
|
29
|
-
{services.length > 0 && (
|
|
30
|
-
<ItemList
|
|
31
|
-
title={`Services (${services.length})`}
|
|
32
|
-
titleIcon={{ icon: CubeIcon, className: 'text-green-400' }}
|
|
33
|
-
items={services.map((service) => ({
|
|
34
|
-
label: service.name,
|
|
35
|
-
href: `/domains/${name}/services/${service.name}`,
|
|
36
|
-
bgColor: 'green',
|
|
37
|
-
}))}
|
|
38
|
-
/>
|
|
39
|
-
)}
|
|
40
|
-
|
|
41
|
-
{owners.length > 0 && <Owners owners={owners} />}
|
|
42
|
-
|
|
43
|
-
<Link href={`/visualiser?type=domain&name=${domain.name}`}>
|
|
44
|
-
<a className="hidden w-full md:inline-flex h-10 justify-center px-4 py-2 border border-gray-300 shadow-sm text-sm font-medium rounded-md text-gray-800 hover:bg-gray-100 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-gray-200">
|
|
45
|
-
<span>View in Visualiser</span>
|
|
46
|
-
</a>
|
|
47
|
-
</Link>
|
|
48
|
-
|
|
49
|
-
{externalLinks.length > 0 && <ExternalLinks externalLinks={externalLinks} />}
|
|
50
|
-
{tags.length > 0 && <Tags tags={tags} />}
|
|
51
|
-
</aside>
|
|
52
|
-
);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
export default ServiceSidebar;
|
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import Link from 'next/link';
|
|
3
|
-
import getConfig from 'next/config';
|
|
4
|
-
import { CubeIcon, DownloadIcon, CollectionIcon } from '@heroicons/react/outline';
|
|
5
|
-
import type { Event } from '@eventcatalog/types';
|
|
6
|
-
|
|
7
|
-
import ExternalLinks from './components/ExternalLinks';
|
|
8
|
-
import Tags from './components/Tags';
|
|
9
|
-
import Owners from './components/Owners';
|
|
10
|
-
import ItemList from './components/ItemList';
|
|
11
|
-
|
|
12
|
-
interface EventSideBarProps {
|
|
13
|
-
event: Event;
|
|
14
|
-
urlPath: string;
|
|
15
|
-
loadedVersion?: string;
|
|
16
|
-
isOldVersion?: boolean;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
const getServiceLink = (serviceName: string, event: Event) => {
|
|
20
|
-
const allEventServices = [...event.consumers, ...event.producers];
|
|
21
|
-
const matchedService = allEventServices.find((service) => service.name === serviceName);
|
|
22
|
-
if (matchedService && matchedService.domain) return `/domains/${matchedService.domain}/services/${serviceName}`;
|
|
23
|
-
return `/services/${serviceName}`;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
const getEventLogsURL = (event: Event) =>
|
|
27
|
-
event.domain ? `/domains/${event.domain}/events/${event.name}/logs` : `/events/${event.name}/logs`;
|
|
28
|
-
|
|
29
|
-
function EventSideBar({ event, loadedVersion, isOldVersion, urlPath }: EventSideBarProps) {
|
|
30
|
-
const {
|
|
31
|
-
name: eventName,
|
|
32
|
-
owners,
|
|
33
|
-
producerNames: producers,
|
|
34
|
-
consumerNames: consumers,
|
|
35
|
-
tags,
|
|
36
|
-
historicVersions,
|
|
37
|
-
externalLinks,
|
|
38
|
-
schema,
|
|
39
|
-
domain,
|
|
40
|
-
} = event;
|
|
41
|
-
const { publicRuntimeConfig: { basePath = '' } = {} } = getConfig();
|
|
42
|
-
|
|
43
|
-
const getSchemaDownloadURL = () => {
|
|
44
|
-
if (!schema) return null;
|
|
45
|
-
return isOldVersion
|
|
46
|
-
? `${basePath}/schemas/${eventName}/${loadedVersion}/schema.${schema.extension}`
|
|
47
|
-
: `${basePath}/schemas/${eventName}/schema.${schema.extension}`;
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
return (
|
|
51
|
-
<aside className="hidden xl:block xl:pl-8 divide-y divide-gray-200">
|
|
52
|
-
<h2 className="sr-only">Details</h2>
|
|
53
|
-
|
|
54
|
-
{producers.length > 0 && (
|
|
55
|
-
<ItemList
|
|
56
|
-
title={`Producers (${producers.length})`}
|
|
57
|
-
titleIcon={{ icon: CubeIcon, className: 'text-green-400' }}
|
|
58
|
-
items={producers.map((producer) => ({ label: producer, href: getServiceLink(producer, event), bgColor: 'green' }))}
|
|
59
|
-
/>
|
|
60
|
-
)}
|
|
61
|
-
|
|
62
|
-
{consumers.length > 0 && (
|
|
63
|
-
<ItemList
|
|
64
|
-
title={`Consumers (${consumers.length})`}
|
|
65
|
-
titleIcon={{ icon: CubeIcon, className: 'text-indigo-400' }}
|
|
66
|
-
items={consumers.map((consumer) => ({ label: consumer, href: getServiceLink(consumer, event), bgColor: 'indigo' }))}
|
|
67
|
-
/>
|
|
68
|
-
)}
|
|
69
|
-
|
|
70
|
-
{domain && (
|
|
71
|
-
<div className="py-6 space-y-8">
|
|
72
|
-
<div>
|
|
73
|
-
<h2 className="text-sm font-medium text-gray-500">
|
|
74
|
-
<CollectionIcon className="h-5 w-5 text-yellow-400 inline-block mr-2" aria-hidden="true" />
|
|
75
|
-
Domain
|
|
76
|
-
</h2>
|
|
77
|
-
<ul className="mt-2 leading-8">
|
|
78
|
-
<li className="inline">
|
|
79
|
-
<Link href={`/domains/${domain}`}>
|
|
80
|
-
<a href="#" className="relative inline-flex items-center rounded-full border border-gray-300 px-3 py-0.5">
|
|
81
|
-
<div className="absolute flex-shrink-0 flex items-center justify-center">
|
|
82
|
-
<span className="h-1.5 w-1.5 rounded-full bg-yellow-500 animate animate-pulse" aria-hidden="true" />
|
|
83
|
-
</div>
|
|
84
|
-
<div className="ml-3.5 text-sm font-medium text-gray-900">{domain}</div>
|
|
85
|
-
</a>
|
|
86
|
-
</Link>
|
|
87
|
-
</li>
|
|
88
|
-
</ul>
|
|
89
|
-
</div>
|
|
90
|
-
</div>
|
|
91
|
-
)}
|
|
92
|
-
{historicVersions.length > 0 && (
|
|
93
|
-
<div className=" py-6">
|
|
94
|
-
<div>
|
|
95
|
-
<h2 className="text-sm font-medium text-gray-500">Event Versions</h2>
|
|
96
|
-
<ul className="mt-2 leading-8 text-left text-blue-500">
|
|
97
|
-
<li className="text-sm inline ">
|
|
98
|
-
<Link href={urlPath}>
|
|
99
|
-
<a>
|
|
100
|
-
<span
|
|
101
|
-
className={`inline-flex mr-2 items-center px-2.5 py-0.5 rounded-full text-xs font-medium -top-0.5 relative ${
|
|
102
|
-
loadedVersion === 'latest'
|
|
103
|
-
? 'bg-blue-400 text-white shadow-md font-bold underline'
|
|
104
|
-
: 'bg-blue-100 text-blue-800'
|
|
105
|
-
}`}
|
|
106
|
-
>
|
|
107
|
-
Latest
|
|
108
|
-
</span>
|
|
109
|
-
</a>
|
|
110
|
-
</Link>
|
|
111
|
-
</li>
|
|
112
|
-
|
|
113
|
-
{historicVersions.map((version) => {
|
|
114
|
-
const isLoadedVersion = loadedVersion === version;
|
|
115
|
-
const styles = isLoadedVersion
|
|
116
|
-
? 'bg-blue-400 text-white shadow-md font-bold underline'
|
|
117
|
-
: 'bg-blue-100 text-blue-800';
|
|
118
|
-
return (
|
|
119
|
-
<li className="text-sm inline" key={version}>
|
|
120
|
-
<Link href={`${urlPath}/v/${version}`}>
|
|
121
|
-
<a>
|
|
122
|
-
<span
|
|
123
|
-
className={`inline-flex mr-2 items-center px-2.5 py-0.5 rounded-full text-xs font-medium -top-0.5 relative ${styles}`}
|
|
124
|
-
>
|
|
125
|
-
v{version}
|
|
126
|
-
</span>
|
|
127
|
-
</a>
|
|
128
|
-
</Link>
|
|
129
|
-
</li>
|
|
130
|
-
);
|
|
131
|
-
})}
|
|
132
|
-
</ul>
|
|
133
|
-
</div>
|
|
134
|
-
</div>
|
|
135
|
-
)}
|
|
136
|
-
|
|
137
|
-
{owners.length > 0 && <Owners owners={owners} />}
|
|
138
|
-
|
|
139
|
-
<div className=" py-6 space-y-1">
|
|
140
|
-
{schema && (
|
|
141
|
-
<a
|
|
142
|
-
href={getSchemaDownloadURL()}
|
|
143
|
-
download={`${eventName}(${event.version}).${schema.extension}`}
|
|
144
|
-
className="hidden w-full md:inline-flex h-10 justify-center px-4 py-2 border border-gray-300 shadow-sm text-sm font-medium rounded-md text-gray-200 bg-gray-800 hover:bg-gray-600 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-gray-900"
|
|
145
|
-
>
|
|
146
|
-
<DownloadIcon className="-ml-1 mr-2 h-5 w-5 text-gray-200" aria-hidden="true" />
|
|
147
|
-
<span>Download Schema</span>
|
|
148
|
-
</a>
|
|
149
|
-
)}
|
|
150
|
-
|
|
151
|
-
{historicVersions.length > 0 && (
|
|
152
|
-
<Link href={getEventLogsURL(event)}>
|
|
153
|
-
<a className="hidden w-full md:inline-flex h-10 justify-center px-4 py-2 border border-gray-300 shadow-sm text-sm font-medium rounded-md text-gray-800 hover:bg-gray-100 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-gray-200">
|
|
154
|
-
<span>View Changes</span>
|
|
155
|
-
</a>
|
|
156
|
-
</Link>
|
|
157
|
-
)}
|
|
158
|
-
|
|
159
|
-
<Link href={`/visualiser?type=event&name=${eventName}`}>
|
|
160
|
-
<a className="hidden w-full md:inline-flex h-10 justify-center px-4 py-2 border border-gray-300 shadow-sm text-sm font-medium rounded-md text-gray-800 hover:bg-gray-100 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-gray-200">
|
|
161
|
-
<span>View in Visualiser</span>
|
|
162
|
-
</a>
|
|
163
|
-
</Link>
|
|
164
|
-
|
|
165
|
-
{externalLinks.length > 0 && <ExternalLinks externalLinks={externalLinks} />}
|
|
166
|
-
{tags.length > 0 && <Tags tags={tags} />}
|
|
167
|
-
</div>
|
|
168
|
-
</aside>
|
|
169
|
-
);
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
export default EventSideBar;
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import Link from 'next/link';
|
|
3
|
-
import type { Event, Service } from '@eventcatalog/types';
|
|
4
|
-
|
|
5
|
-
import { CubeIcon, CollectionIcon } from '@heroicons/react/outline';
|
|
6
|
-
import getBackgroundColor from '@/utils/random-bg';
|
|
7
|
-
|
|
8
|
-
import ExternalLinks from './components/ExternalLinks';
|
|
9
|
-
import Tags from './components/Tags';
|
|
10
|
-
import Owners from './components/Owners';
|
|
11
|
-
import ItemList from './components/ItemList';
|
|
12
|
-
|
|
13
|
-
const getURLForEvent = (event: Event): string =>
|
|
14
|
-
event.domain ? `/domains/${event.domain}/events/${event.name}` : `/events/${event.name}`;
|
|
15
|
-
|
|
16
|
-
interface ServiceSideBarProps {
|
|
17
|
-
service: Service;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
function ServiceSidebar({ service }: ServiceSideBarProps) {
|
|
21
|
-
const { owners, subscribes, publishes, repository, tags = [], externalLinks, domain } = service;
|
|
22
|
-
const { language, url: repositoryUrl } = repository;
|
|
23
|
-
|
|
24
|
-
let languages = [];
|
|
25
|
-
|
|
26
|
-
if (language) {
|
|
27
|
-
languages = Array.isArray(language) ? language : [language];
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
let trimmedUrl = '';
|
|
31
|
-
|
|
32
|
-
if (repositoryUrl) {
|
|
33
|
-
trimmedUrl = repositoryUrl.replace(/(^\w+:|^)\/\//, '');
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
return (
|
|
37
|
-
<aside className="hidden xl:block xl:pl-8 ">
|
|
38
|
-
<h2 className="sr-only">Details</h2>
|
|
39
|
-
|
|
40
|
-
{publishes.length > 0 && (
|
|
41
|
-
<ItemList
|
|
42
|
-
title={`Publishes Events (${publishes.length})`}
|
|
43
|
-
titleIcon={{ icon: CubeIcon, className: 'text-indigo-400' }}
|
|
44
|
-
items={publishes.map((event) => ({ label: event.name, href: getURLForEvent(event), bgColor: 'indigo' }))}
|
|
45
|
-
/>
|
|
46
|
-
)}
|
|
47
|
-
|
|
48
|
-
{subscribes.length > 0 && (
|
|
49
|
-
<ItemList
|
|
50
|
-
title={`Subscribes to Events (${subscribes.length})`}
|
|
51
|
-
titleIcon={{ icon: CubeIcon, className: 'text-green-400' }}
|
|
52
|
-
items={subscribes.map((event) => ({ label: event.name, href: getURLForEvent(event), bgColor: 'green' }))}
|
|
53
|
-
/>
|
|
54
|
-
)}
|
|
55
|
-
|
|
56
|
-
{domain && (
|
|
57
|
-
<div className="border-t border-gray-200 py-6 space-y-8">
|
|
58
|
-
<div>
|
|
59
|
-
<h2 className="text-sm font-medium text-gray-500">
|
|
60
|
-
<CollectionIcon className="h-5 w-5 text-yellow-400 inline-block mr-2" aria-hidden="true" />
|
|
61
|
-
Domain
|
|
62
|
-
</h2>
|
|
63
|
-
<ul className="mt-2 leading-8">
|
|
64
|
-
<li className="inline" key={domain}>
|
|
65
|
-
<Link href={`/domains/${domain}`}>
|
|
66
|
-
<a href="#" className="relative inline-flex items-center rounded-full border border-gray-300 px-3 py-0.5">
|
|
67
|
-
<div className="absolute flex-shrink-0 flex items-center justify-center">
|
|
68
|
-
<span className="h-1.5 w-1.5 rounded-full bg-yellow-500 animate animate-pulse" aria-hidden="true" />
|
|
69
|
-
</div>
|
|
70
|
-
<div className="ml-3.5 text-sm font-medium text-gray-900">{domain}</div>
|
|
71
|
-
</a>
|
|
72
|
-
</Link>
|
|
73
|
-
</li>
|
|
74
|
-
</ul>
|
|
75
|
-
</div>
|
|
76
|
-
</div>
|
|
77
|
-
)}
|
|
78
|
-
|
|
79
|
-
{owners.length > 0 && <Owners owners={owners} />}
|
|
80
|
-
|
|
81
|
-
{repository?.url && (
|
|
82
|
-
<div className="border-t border-gray-200 py-6 space-y-8">
|
|
83
|
-
<div className="space-y-3">
|
|
84
|
-
<h2 className="text-sm font-medium text-gray-500">Repository</h2>
|
|
85
|
-
<ul className=" leading-8 space-y-2">
|
|
86
|
-
<li className="flex justify-start">
|
|
87
|
-
<a
|
|
88
|
-
href={repository?.url}
|
|
89
|
-
target="_blank"
|
|
90
|
-
className="flex items-center space-x-3 text-blue-600 underline text-sm"
|
|
91
|
-
rel="noreferrer"
|
|
92
|
-
>
|
|
93
|
-
{trimmedUrl}
|
|
94
|
-
</a>
|
|
95
|
-
</li>
|
|
96
|
-
</ul>
|
|
97
|
-
</div>
|
|
98
|
-
</div>
|
|
99
|
-
)}
|
|
100
|
-
{languages.length > 0 && (
|
|
101
|
-
<div className="border-t border-gray-200 py-6 space-y-8">
|
|
102
|
-
<div className="space-y-3">
|
|
103
|
-
<h2 className="text-sm font-medium text-gray-500">Language</h2>
|
|
104
|
-
{languages.map((value) => (
|
|
105
|
-
<div className="relative flex items-center mt-2" key={value}>
|
|
106
|
-
<div className="absolute flex-shrink-0 flex items-center justify-center">
|
|
107
|
-
<span className="h-2 w-2 rounded-full" aria-hidden="true" style={{ background: getBackgroundColor(value) }} />
|
|
108
|
-
</div>
|
|
109
|
-
<div className="ml-3.5 text-sm font-medium text-gray-900">{value}</div>
|
|
110
|
-
</div>
|
|
111
|
-
))}
|
|
112
|
-
</div>
|
|
113
|
-
</div>
|
|
114
|
-
)}
|
|
115
|
-
|
|
116
|
-
<Link href={`/visualiser?type=service&name=${service.name}`}>
|
|
117
|
-
<a className="hidden w-full md:inline-flex h-10 justify-center px-4 py-2 border border-gray-300 shadow-sm text-sm font-medium rounded-md text-gray-800 hover:bg-gray-100 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-gray-200">
|
|
118
|
-
<span>View in Visualiser</span>
|
|
119
|
-
</a>
|
|
120
|
-
</Link>
|
|
121
|
-
|
|
122
|
-
{externalLinks.length > 0 && <ExternalLinks externalLinks={externalLinks} />}
|
|
123
|
-
{tags.length > 0 && <Tags tags={tags} />}
|
|
124
|
-
</aside>
|
|
125
|
-
);
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
export default ServiceSidebar;
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
|
|
3
|
-
import { ExternalLinkIcon } from '@heroicons/react/outline';
|
|
4
|
-
|
|
5
|
-
function ExternalLinks({ externalLinks }: { externalLinks: any[] }) {
|
|
6
|
-
if (externalLinks.length === 0) return null;
|
|
7
|
-
return (
|
|
8
|
-
<div className=" py-2 space-y-8">
|
|
9
|
-
<div className="space-y-3">
|
|
10
|
-
{externalLinks.map((tag) => (
|
|
11
|
-
<a
|
|
12
|
-
href={tag.url}
|
|
13
|
-
target="_blank"
|
|
14
|
-
type="button"
|
|
15
|
-
className="hidden w-full md:inline-flex h-10 justify-center px-4 py-2 border border-teal-300 shadow-sm text-sm font-medium rounded-md text-teal-800 hover:bg-teal-100 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-teal-200"
|
|
16
|
-
rel="noreferrer"
|
|
17
|
-
key={tag.url}
|
|
18
|
-
>
|
|
19
|
-
<ExternalLinkIcon className="-ml-1 mr-2 h-5 w-5 text-teal-200" aria-hidden="true" />
|
|
20
|
-
<span>{`${tag.label}`}</span>
|
|
21
|
-
</a>
|
|
22
|
-
))}
|
|
23
|
-
</div>
|
|
24
|
-
</div>
|
|
25
|
-
);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export default ExternalLinks;
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import Link from 'next/link';
|
|
3
|
-
import { CubeIcon } from '@heroicons/react/outline';
|
|
4
|
-
|
|
5
|
-
function ItemList({ title, titleIcon: { icon: Icon = CubeIcon, className: iconClassName }, items }: any) {
|
|
6
|
-
return (
|
|
7
|
-
<div className="pt-6 py-6 space-y-8">
|
|
8
|
-
<div>
|
|
9
|
-
<h2 className="text-sm font-medium text-gray-500">
|
|
10
|
-
<Icon className={`h-5 w-5 inline-block mr-2 ${iconClassName}`} aria-hidden="true" />
|
|
11
|
-
{title}
|
|
12
|
-
</h2>
|
|
13
|
-
<ul className="mt-2 leading-8">
|
|
14
|
-
{items.map((item) => (
|
|
15
|
-
<li className="inline mr-2" key={item.label}>
|
|
16
|
-
<Link href={item.href}>
|
|
17
|
-
<a className="relative inline-flex items-center rounded-full border border-gray-300 px-3 py-0.5">
|
|
18
|
-
<div className="absolute flex-shrink-0 flex items-center justify-center">
|
|
19
|
-
<span className={`h-1.5 w-1.5 rounded-full bg-${item.bgColor}-500`} aria-hidden="true" />
|
|
20
|
-
</div>
|
|
21
|
-
<div className="ml-3.5 text-sm font-medium text-gray-900 truncate max-w-xs">{item.label}</div>
|
|
22
|
-
</a>
|
|
23
|
-
</Link>
|
|
24
|
-
</li>
|
|
25
|
-
))}
|
|
26
|
-
</ul>
|
|
27
|
-
</div>
|
|
28
|
-
</div>
|
|
29
|
-
);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export default ItemList;
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import Link from 'next/link';
|
|
3
|
-
import type { Owner } from '@eventcatalog/types';
|
|
4
|
-
import { useUser } from '@/hooks/EventCatalog';
|
|
5
|
-
|
|
6
|
-
function Owners({ owners }: { owners: Owner[] | string[] }) {
|
|
7
|
-
const { getUserById } = useUser();
|
|
8
|
-
|
|
9
|
-
return (
|
|
10
|
-
<div className=" py-6 space-y-8">
|
|
11
|
-
<div>
|
|
12
|
-
<h2 className="text-sm font-medium text-gray-500">Domain Owners ({owners.length})</h2>
|
|
13
|
-
<ul className="mt-4 leading-8 space-y-2">
|
|
14
|
-
{owners.map((owner) => {
|
|
15
|
-
const user = getUserById(owner);
|
|
16
|
-
|
|
17
|
-
if (!user) return null;
|
|
18
|
-
|
|
19
|
-
return (
|
|
20
|
-
<li className="flex justify-start" key={user.id}>
|
|
21
|
-
<Link href={`/users/${user.id}`}>
|
|
22
|
-
<a className="flex items-center space-x-3">
|
|
23
|
-
<div className="flex-shrink-0">
|
|
24
|
-
<img className="h-5 w-5 rounded-full" src={user.avatarUrl} alt="" />
|
|
25
|
-
</div>
|
|
26
|
-
<div className="text-sm font-medium text-gray-900">{user.name}</div>
|
|
27
|
-
</a>
|
|
28
|
-
</Link>
|
|
29
|
-
</li>
|
|
30
|
-
);
|
|
31
|
-
})}
|
|
32
|
-
</ul>
|
|
33
|
-
</div>
|
|
34
|
-
</div>
|
|
35
|
-
);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
export default Owners;
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import type { Tag } from '@eventcatalog/types';
|
|
3
|
-
import { TagIcon } from '@heroicons/react/outline';
|
|
4
|
-
|
|
5
|
-
const tailwindBgs = ['purple', 'pink', 'green', 'yellow', 'blue', 'indigo'];
|
|
6
|
-
|
|
7
|
-
function Tags({ tags }: { tags: Tag[] }) {
|
|
8
|
-
return (
|
|
9
|
-
<div className=" py-6 space-y-8">
|
|
10
|
-
<div>
|
|
11
|
-
<h2 className="text-sm font-medium text-gray-500">
|
|
12
|
-
<TagIcon className="h-5 w-5 text-gray-400 inline-block mr-2" aria-hidden="true" />
|
|
13
|
-
Tags
|
|
14
|
-
</h2>
|
|
15
|
-
<div className="mt-3 space-y-2">
|
|
16
|
-
{tags.map(({ label, url }, index) => {
|
|
17
|
-
const color = tailwindBgs[index % tailwindBgs.length];
|
|
18
|
-
|
|
19
|
-
if (url) {
|
|
20
|
-
return (
|
|
21
|
-
<a href={url} className="inline-block underline" target="_blank" rel="noreferrer">
|
|
22
|
-
<span
|
|
23
|
-
className={`underline inline-block mr-2 items-center px-2.5 py-0.5 rounded-full text-xs font-medium -top-0.5 relative bg-${color}-100 text-${color}-800`}
|
|
24
|
-
>
|
|
25
|
-
{label}
|
|
26
|
-
</span>
|
|
27
|
-
</a>
|
|
28
|
-
);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
return (
|
|
32
|
-
<span
|
|
33
|
-
className={`inline-block mr-2 items-center px-2.5 py-0.5 rounded-full text-xs font-medium -top-0.5 relative bg-${color}-100 text-${color}-800`}
|
|
34
|
-
>
|
|
35
|
-
{label}
|
|
36
|
-
</span>
|
|
37
|
-
);
|
|
38
|
-
})}
|
|
39
|
-
</div>
|
|
40
|
-
</div>
|
|
41
|
-
</div>
|
|
42
|
-
);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export default Tags;
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import React, { useState } from 'react';
|
|
2
|
-
|
|
3
|
-
import codeStyle from 'react-syntax-highlighter/dist/cjs/styles/prism/dracula';
|
|
4
|
-
import { Prism as PrismSyntaxHighlighter } from 'react-syntax-highlighter';
|
|
5
|
-
import copy from 'copy-text-to-clipboard';
|
|
6
|
-
import { ClipboardCopyIcon } from '@heroicons/react/outline';
|
|
7
|
-
|
|
8
|
-
function SyntaxHighlighter({ language, name = '', ...props }: any) {
|
|
9
|
-
const [showCopied, setShowCopied] = useState(false);
|
|
10
|
-
|
|
11
|
-
const handleCopyCode = () => {
|
|
12
|
-
copy(props.children);
|
|
13
|
-
setShowCopied(true);
|
|
14
|
-
setTimeout(() => setShowCopied(false), 2000);
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
const regex = /\\n/g;
|
|
18
|
-
return (
|
|
19
|
-
<div className="h-96 relative">
|
|
20
|
-
{name && (
|
|
21
|
-
<div className={`flex -mb-3 pb-2 bg-gray-900 ${name ? 'justify-between' : 'justify-end'}`}>
|
|
22
|
-
{name && <span className="block text-xs py-2 px-2 font-bold text-gray-300">{name}</span>}
|
|
23
|
-
<button type="button" onClick={handleCopyCode} className="text-xs text-white rounded-md px-4">
|
|
24
|
-
{showCopied ? 'Copied' : <ClipboardCopyIcon className="h-4 w-4" />}
|
|
25
|
-
</button>
|
|
26
|
-
</div>
|
|
27
|
-
)}
|
|
28
|
-
|
|
29
|
-
{!name && (
|
|
30
|
-
<button type="button" onClick={handleCopyCode} className="text-xs absolute right-0 top-2 text-white rounded-md px-4">
|
|
31
|
-
{showCopied ? 'Copied' : <ClipboardCopyIcon className="h-4 w-4" />}
|
|
32
|
-
</button>
|
|
33
|
-
)}
|
|
34
|
-
|
|
35
|
-
<PrismSyntaxHighlighter style={codeStyle} language={language} {...props} wrapLines className="h-96 overflow-auto">
|
|
36
|
-
{props.children.replace(regex, '\n')}
|
|
37
|
-
</PrismSyntaxHighlighter>
|
|
38
|
-
</div>
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
export default SyntaxHighlighter;
|