@eventcatalog/core 0.0.6 → 0.0.10

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.
Files changed (155) hide show
  1. package/.next/BUILD_ID +1 -0
  2. package/.next/build-manifest.json +110 -0
  3. package/.next/cache/.tsbuildinfo +1 -0
  4. package/.next/cache/config.json +7 -0
  5. package/.next/cache/eslint/.cache_1bay4w0 +1 -0
  6. package/.next/cache/next-server.js.nft.json +1 -0
  7. package/.next/cache/webpack/client-production/0.pack +0 -0
  8. package/.next/cache/webpack/client-production/index.pack +0 -0
  9. package/.next/cache/webpack/server-production/0.pack +0 -0
  10. package/.next/cache/webpack/server-production/index.pack +0 -0
  11. package/.next/export-marker.json +1 -0
  12. package/.next/images-manifest.json +1 -0
  13. package/.next/next-server.js.nft.json +1 -0
  14. package/.next/prerender-manifest.json +1 -0
  15. package/.next/react-loadable-manifest.json +1717 -0
  16. package/.next/required-server-files.json +1 -0
  17. package/.next/routes-manifest.json +1 -0
  18. package/.next/server/chunks/237.js +116 -0
  19. package/.next/server/chunks/428.js +84 -0
  20. package/.next/server/chunks/47.js +51 -0
  21. package/.next/server/chunks/526.js +131 -0
  22. package/.next/server/chunks/565.js +121 -0
  23. package/.next/server/chunks/596.js +98 -0
  24. package/.next/server/chunks/730.js +324 -0
  25. package/.next/server/chunks/8.js +122 -0
  26. package/.next/server/chunks/938.js +109 -0
  27. package/.next/server/chunks/944.js +649 -0
  28. package/.next/server/chunks/959.js +286 -0
  29. package/.next/server/chunks/97.js +1837 -0
  30. package/.next/server/chunks/font-manifest.json +1 -0
  31. package/.next/server/font-manifest.json +1 -0
  32. package/.next/server/middleware-manifest.json +6 -0
  33. package/.next/server/pages/404.html +1 -0
  34. package/.next/server/pages/500.html +1 -0
  35. package/.next/server/pages/_app.js +370 -0
  36. package/.next/server/pages/_app.js.nft.json +1 -0
  37. package/.next/server/pages/_document.js +1004 -0
  38. package/.next/server/pages/_document.js.nft.json +1 -0
  39. package/.next/server/pages/_error.js +123 -0
  40. package/.next/server/pages/_error.js.nft.json +1 -0
  41. package/.next/server/pages/api/event/[name]/download.js +64 -0
  42. package/.next/server/pages/api/event/[name]/download.js.nft.json +1 -0
  43. package/.next/server/pages/events/AddedItemToCart.html +73 -0
  44. package/.next/server/pages/events/AddedItemToCart.json +1 -0
  45. package/.next/server/pages/events/OrderComplete.html +48 -0
  46. package/.next/server/pages/events/OrderComplete.json +1 -0
  47. package/.next/server/pages/events/OrderConfirmed.html +48 -0
  48. package/.next/server/pages/events/OrderConfirmed.json +1 -0
  49. package/.next/server/pages/events/OrderRequested.html +48 -0
  50. package/.next/server/pages/events/OrderRequested.json +1 -0
  51. package/.next/server/pages/events/PaymentProcessed.html +52 -0
  52. package/.next/server/pages/events/PaymentProcessed.json +1 -0
  53. package/.next/server/pages/events/RemovedItemFromCart.html +55 -0
  54. package/.next/server/pages/events/RemovedItemFromCart.json +1 -0
  55. package/.next/server/pages/events/ShipmentDelivered.html +53 -0
  56. package/.next/server/pages/events/ShipmentDelivered.json +1 -0
  57. package/.next/server/pages/events/ShipmentDispatched.html +52 -0
  58. package/.next/server/pages/events/ShipmentDispatched.json +1 -0
  59. package/.next/server/pages/events/ShipmentPrepared.html +52 -0
  60. package/.next/server/pages/events/ShipmentPrepared.json +1 -0
  61. package/.next/server/pages/events/[name]/logs.js +414 -0
  62. package/.next/server/pages/events/[name]/logs.js.nft.json +1 -0
  63. package/.next/server/pages/events/[name]/v/[version].js +274 -0
  64. package/.next/server/pages/events/[name]/v/[version].js.nft.json +1 -0
  65. package/.next/server/pages/events/[name].js +235 -0
  66. package/.next/server/pages/events/[name].js.nft.json +1 -0
  67. package/.next/server/pages/events.js +519 -0
  68. package/.next/server/pages/events.js.nft.json +1 -0
  69. package/.next/server/pages/index.html +1 -0
  70. package/.next/server/pages/index.js.nft.json +1 -0
  71. package/.next/server/pages/overview.js +240 -0
  72. package/.next/server/pages/overview.js.nft.json +1 -0
  73. package/.next/server/pages/services/Basket Service.html +11 -0
  74. package/.next/server/pages/services/Basket Service.json +1 -0
  75. package/.next/server/pages/services/Data Lake.html +12 -0
  76. package/.next/server/pages/services/Data Lake.json +1 -0
  77. package/.next/server/pages/services/Payment Service.html +10 -0
  78. package/.next/server/pages/services/Payment Service.json +1 -0
  79. package/.next/server/pages/services/Shipping Service.html +14 -0
  80. package/.next/server/pages/services/Shipping Service.json +1 -0
  81. package/.next/server/pages/services/[name].js +675 -0
  82. package/.next/server/pages/services/[name].js.nft.json +1 -0
  83. package/.next/server/pages/services.js +396 -0
  84. package/.next/server/pages/services.js.nft.json +1 -0
  85. package/.next/server/pages/users/[id].js +327 -0
  86. package/.next/server/pages/users/[id].js.nft.json +1 -0
  87. package/.next/server/pages-manifest.json +16 -0
  88. package/.next/server/webpack-api-runtime.js +160 -0
  89. package/.next/server/webpack-runtime.js +264 -0
  90. package/.next/static/chunks/020d8314.aea2d24215754e7b.js +1 -0
  91. package/.next/static/chunks/176cb4e4-8a0f6f010ef8accb.js +1 -0
  92. package/.next/static/chunks/236-0acd5083c102a9cb.js +1 -0
  93. package/.next/static/chunks/274-11c4d093341d7201.js +1 -0
  94. package/.next/static/chunks/336-5d9007a96aa8f2c7.js +1 -0
  95. package/.next/static/chunks/364-3cb3c8cf1d3c95de.js +1 -0
  96. package/.next/static/chunks/519-7f22292093abd7c3.js +1 -0
  97. package/.next/static/chunks/638.d570519ae49c92c8.js +1 -0
  98. package/.next/static/chunks/873-9d69271e4b2dd496.js +1 -0
  99. package/.next/static/chunks/962-d5070461f6d4a478.js +1 -0
  100. package/.next/static/chunks/framework-576ec6a1c1386453.js +1 -0
  101. package/.next/static/chunks/main-0289ecbd51cd4cb4.js +1 -0
  102. package/.next/static/chunks/pages/_app-c9d3172cc09cf069.js +1 -0
  103. package/.next/static/chunks/pages/_error-5a714c45c50a8db4.js +1 -0
  104. package/.next/static/chunks/pages/events/[name]/logs-d159d7b82f44847f.js +1 -0
  105. package/.next/static/chunks/pages/events/[name]/v/[version]-dc146dc9bfa7362d.js +1 -0
  106. package/.next/static/chunks/pages/events/[name]-fb77119f66a5793e.js +1 -0
  107. package/.next/static/chunks/pages/events-bcad8442f21d6b67.js +1 -0
  108. package/.next/static/chunks/pages/index-3eeab7e4014a02ea.js +1 -0
  109. package/.next/static/chunks/pages/overview-5ac749891cbe1922.js +1 -0
  110. package/.next/static/chunks/pages/services/[name]-69692188d11304b7.js +1 -0
  111. package/.next/static/chunks/pages/services-bcc61898062e1bf4.js +1 -0
  112. package/.next/static/chunks/pages/users/[id]-2da54ccb6319b207.js +1 -0
  113. package/.next/static/chunks/polyfills-5cd94c89d3acac5f.js +1 -0
  114. package/.next/static/chunks/webpack-afe52d4a9fcc5a75.js +1 -0
  115. package/.next/static/css/5eeed9cb243ce668.css +1 -0
  116. package/.next/static/css/b44e1178a88a93b4.css +3 -0
  117. package/.next/static/yc3MsaLWgBvovlJpHpfqc/_buildManifest.js +1 -0
  118. package/.next/static/yc3MsaLWgBvovlJpHpfqc/_middlewareManifest.js +1 -0
  119. package/.next/static/yc3MsaLWgBvovlJpHpfqc/_ssgManifest.js +1 -0
  120. package/.next/trace +37 -0
  121. package/CHANGELOG.md +30 -0
  122. package/bin/eventcatalog.js +4 -15
  123. package/components/ContentView.tsx +22 -29
  124. package/components/Grids/EventGrid.tsx +3 -13
  125. package/components/Grids/ServiceGrid.tsx +3 -11
  126. package/components/Header.tsx +1 -3
  127. package/components/Mdx/Examples.tsx +2 -9
  128. package/components/NotFound/index.tsx +2 -6
  129. package/components/Sidebars/EventSidebar.tsx +19 -14
  130. package/components/Sidebars/ServiceSidebar.tsx +26 -25
  131. package/eventcatalog.config.js +40 -0
  132. package/hooks/EventCatalog.tsx +1 -1
  133. package/lib/__tests__/assets/services/Basket Service/index.md +19 -0
  134. package/lib/__tests__/events.spec.ts +16 -27
  135. package/lib/__tests__/file-reader.spec.ts +3 -9
  136. package/lib/__tests__/services.spec.ts +27 -6
  137. package/lib/events.ts +5 -10
  138. package/lib/file-reader.ts +1 -3
  139. package/lib/graphs.ts +2 -4
  140. package/lib/services.ts +5 -11
  141. package/package.json +2 -2
  142. package/pages/_app.tsx +3 -12
  143. package/pages/events/[name]/logs.tsx +7 -18
  144. package/pages/events/[name].tsx +4 -13
  145. package/pages/events.tsx +5 -16
  146. package/pages/index.tsx +2 -9
  147. package/pages/overview.tsx +1 -4
  148. package/pages/services/[name].tsx +2 -2
  149. package/pages/services.tsx +2 -6
  150. package/pages/users/[id].tsx +4 -13
  151. package/scripts/__tests__/assets/eventcatalog.config.js +1 -2
  152. package/scripts/__tests__/generate.spec.ts +1 -4
  153. package/scripts/generate.js +1 -1
  154. package/tailwind.config.js +1 -5
  155. package/tsconfig.json +1 -7
@@ -0,0 +1 @@
1
+ {"version":1,"config":{"env":{},"webpack":null,"webpackDevMiddleware":null,"eslint":{"ignoreDuringBuilds":false},"typescript":{"ignoreBuildErrors":false,"tsconfigPath":"tsconfig.json"},"distDir":".next","cleanDistDir":true,"assetPrefix":"","configOrigin":"next.config.js","useFileSystemPublicRoutes":true,"generateEtags":true,"pageExtensions":["tsx","ts","jsx","js"],"target":"server","poweredByHeader":true,"compress":false,"analyticsId":"","images":{"deviceSizes":[640,750,828,1080,1200,1920,2048,3840],"imageSizes":[16,32,48,64,96,128,256,384],"path":"/_next/image","loader":"default","domains":[],"disableStaticImages":false,"minimumCacheTTL":60,"formats":["image/webp"]},"devIndicators":{"buildActivity":true,"buildActivityPosition":"bottom-right"},"onDemandEntries":{"maxInactiveAge":15000,"pagesBufferLength":2},"amp":{"canonicalBase":""},"basePath":"","sassOptions":{},"trailingSlash":false,"i18n":null,"productionBrowserSourceMaps":false,"optimizeFonts":true,"excludeDefaultMomentLocales":true,"serverRuntimeConfig":{},"publicRuntimeConfig":{},"reactStrictMode":true,"httpAgentOptions":{"keepAlive":true},"outputFileTracing":true,"staticPageGenerationTimeout":60,"swcMinify":false,"experimental":{"cpus":1,"sharedPool":true,"plugins":false,"profiling":false,"isrFlushToDisk":true,"workerThreads":false,"pageEnv":false,"optimizeImages":false,"optimizeCss":false,"scrollRestoration":false,"externalDir":false,"reactRoot":false,"disableOptimizedLoading":false,"gzipSize":true,"swcFileReading":true,"craCompat":false,"esmExternals":true,"isrMemoryCacheSize":52428800,"concurrentFeatures":false,"serverComponents":false,"fullySpecified":false,"outputFileTracingRoot":"","outputStandalone":false},"configFileName":"next.config.js"},"appDir":"/home/runner/work/eventcatalog/eventcatalog/packages/eventcatalog","files":[".next/routes-manifest.json",".next/server/pages-manifest.json",".next/build-manifest.json",".next/prerender-manifest.json",".next/server/middleware-manifest.json",".next/react-loadable-manifest.json",".next/server/font-manifest.json",".next/BUILD_ID"],"ignore":["../../node_modules/next/dist/compiled/@ampproject/toolbox-optimizer/**/*"]}
@@ -0,0 +1 @@
1
+ {"version":3,"pages404":true,"basePath":"","redirects":[{"source":"/:path+/","destination":"/:path+","internal":true,"statusCode":308,"regex":"^(?:/((?:[^/]+?)(?:/(?:[^/]+?))*))/$"}],"headers":[],"dynamicRoutes":[{"page":"/api/event/[name]/download","regex":"^/api/event/([^/]+?)/download(?:/)?$","routeKeys":{"name":"name"},"namedRegex":"^/api/event/(?<name>[^/]+?)/download(?:/)?$"},{"page":"/events/[name]","regex":"^/events/([^/]+?)(?:/)?$","routeKeys":{"name":"name"},"namedRegex":"^/events/(?<name>[^/]+?)(?:/)?$"},{"page":"/events/[name]/logs","regex":"^/events/([^/]+?)/logs(?:/)?$","routeKeys":{"name":"name"},"namedRegex":"^/events/(?<name>[^/]+?)/logs(?:/)?$"},{"page":"/events/[name]/v/[version]","regex":"^/events/([^/]+?)/v/([^/]+?)(?:/)?$","routeKeys":{"name":"name","version":"version"},"namedRegex":"^/events/(?<name>[^/]+?)/v/(?<version>[^/]+?)(?:/)?$"},{"page":"/services/[name]","regex":"^/services/([^/]+?)(?:/)?$","routeKeys":{"name":"name"},"namedRegex":"^/services/(?<name>[^/]+?)(?:/)?$"},{"page":"/users/[id]","regex":"^/users/([^/]+?)(?:/)?$","routeKeys":{"id":"id"},"namedRegex":"^/users/(?<id>[^/]+?)(?:/)?$"}],"staticRoutes":[{"page":"/","regex":"^/(?:/)?$","routeKeys":{},"namedRegex":"^/(?:/)?$"},{"page":"/events","regex":"^/events(?:/)?$","routeKeys":{},"namedRegex":"^/events(?:/)?$"},{"page":"/overview","regex":"^/overview(?:/)?$","routeKeys":{},"namedRegex":"^/overview(?:/)?$"},{"page":"/services","regex":"^/services(?:/)?$","routeKeys":{},"namedRegex":"^/services(?:/)?$"}],"dataRoutes":[{"page":"/events","dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events.json$"},{"page":"/events/[name]","routeKeys":{"name":"name"},"dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events/([^/]+?)\\.json$","namedDataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events/(?<name>[^/]+?)\\.json$"},{"page":"/events/[name]/logs","routeKeys":{"name":"name"},"dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events/([^/]+?)/logs\\.json$","namedDataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events/(?<name>[^/]+?)/logs\\.json$"},{"page":"/events/[name]/v/[version]","routeKeys":{"name":"name","version":"version"},"dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events/([^/]+?)/v/([^/]+?)\\.json$","namedDataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/events/(?<name>[^/]+?)/v/(?<version>[^/]+?)\\.json$"},{"page":"/overview","dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/overview.json$"},{"page":"/services","dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/services.json$"},{"page":"/services/[name]","routeKeys":{"name":"name"},"dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/services/([^/]+?)\\.json$","namedDataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/services/(?<name>[^/]+?)\\.json$"},{"page":"/users/[id]","routeKeys":{"id":"id"},"dataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/users/([^/]+?)\\.json$","namedDataRouteRegex":"^/_next/data/yc3MsaLWgBvovlJpHpfqc/users/(?<id>[^/]+?)\\.json$"}],"rewrites":[]}
@@ -0,0 +1,116 @@
1
+ exports.id = 237;
2
+ exports.ids = [237];
3
+ exports.modules = {
4
+
5
+ /***/ 5805:
6
+ /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
7
+
8
+ "use strict";
9
+ var __webpack_unused_export__;
10
+
11
+ __webpack_unused_export__ = ({
12
+ value: true
13
+ });
14
+ __webpack_unused_export__ = noSSR;
15
+ exports["default"] = dynamic;
16
+ var _react = _interopRequireDefault(__webpack_require__(6689));
17
+ var _loadable = _interopRequireDefault(__webpack_require__(5832));
18
+ function _interopRequireDefault(obj) {
19
+ return obj && obj.__esModule ? obj : {
20
+ default: obj
21
+ };
22
+ }
23
+ const isServerSide = "undefined" === 'undefined';
24
+ function noSSR(LoadableInitializer, loadableOptions) {
25
+ // Removing webpack and modules means react-loadable won't try preloading
26
+ delete loadableOptions.webpack;
27
+ delete loadableOptions.modules;
28
+ // This check is necessary to prevent react-loadable from initializing on the server
29
+ if (!isServerSide) {
30
+ return LoadableInitializer(loadableOptions);
31
+ }
32
+ const Loading = loadableOptions.loading;
33
+ // This will only be rendered on the server side
34
+ return ()=>/*#__PURE__*/ _react.default.createElement(Loading, {
35
+ error: null,
36
+ isLoading: true,
37
+ pastDelay: false,
38
+ timedOut: false
39
+ })
40
+ ;
41
+ }
42
+ function dynamic(dynamicOptions, options) {
43
+ let loadableFn = _loadable.default;
44
+ let loadableOptions = {
45
+ // A loading component is not required, so we default it
46
+ loading: ({ error , isLoading , pastDelay })=>{
47
+ if (!pastDelay) return null;
48
+ if (false) {}
49
+ return null;
50
+ }
51
+ };
52
+ // Support for direct import(), eg: dynamic(import('../hello-world'))
53
+ // Note that this is only kept for the edge case where someone is passing in a promise as first argument
54
+ // The react-loadable babel plugin will turn dynamic(import('../hello-world')) into dynamic(() => import('../hello-world'))
55
+ // To make sure we don't execute the import without rendering first
56
+ if (dynamicOptions instanceof Promise) {
57
+ loadableOptions.loader = ()=>dynamicOptions
58
+ ;
59
+ // Support for having import as a function, eg: dynamic(() => import('../hello-world'))
60
+ } else if (typeof dynamicOptions === 'function') {
61
+ loadableOptions.loader = dynamicOptions;
62
+ // Support for having first argument being options, eg: dynamic({loader: import('../hello-world')})
63
+ } else if (typeof dynamicOptions === 'object') {
64
+ loadableOptions = {
65
+ ...loadableOptions,
66
+ ...dynamicOptions
67
+ };
68
+ }
69
+ // Support for passing options, eg: dynamic(import('../hello-world'), {loading: () => <p>Loading something</p>})
70
+ loadableOptions = {
71
+ ...loadableOptions,
72
+ ...options
73
+ };
74
+ const suspenseOptions = loadableOptions;
75
+ if (true) {
76
+ // Error if react root is not enabled and `suspense` option is set to true
77
+ if ( true && suspenseOptions.suspense) {
78
+ // TODO: add error doc when this feature is stable
79
+ throw new Error(`Invalid suspense option usage in next/dynamic. Read more: https://nextjs.org/docs/messages/invalid-dynamic-suspense`);
80
+ }
81
+ }
82
+ if (suspenseOptions.suspense) {
83
+ return loadableFn(suspenseOptions);
84
+ }
85
+ // coming from build/babel/plugins/react-loadable-plugin.js
86
+ if (loadableOptions.loadableGenerated) {
87
+ loadableOptions = {
88
+ ...loadableOptions,
89
+ ...loadableOptions.loadableGenerated
90
+ };
91
+ delete loadableOptions.loadableGenerated;
92
+ }
93
+ // support for disabling server side rendering, eg: dynamic(import('../hello-world'), {ssr: false})
94
+ if (typeof loadableOptions.ssr === 'boolean') {
95
+ if (!loadableOptions.ssr) {
96
+ delete loadableOptions.ssr;
97
+ return noSSR(loadableFn, loadableOptions);
98
+ }
99
+ delete loadableOptions.ssr;
100
+ }
101
+ return loadableFn(loadableOptions);
102
+ } //# sourceMappingURL=dynamic.js.map
103
+
104
+
105
+ /***/ }),
106
+
107
+ /***/ 5237:
108
+ /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
109
+
110
+ module.exports = __webpack_require__(5805)
111
+
112
+
113
+ /***/ })
114
+
115
+ };
116
+ ;
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ exports.id = 428;
3
+ exports.ids = [428];
4
+ exports.modules = {
5
+
6
+ /***/ 2428:
7
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
8
+
9
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
10
+ /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
11
+ /* harmony export */ });
12
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(997);
13
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
14
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6689);
15
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);
16
+ /* harmony import */ var _heroicons_react_solid__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1143);
17
+ /* harmony import */ var _heroicons_react_solid__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_heroicons_react_solid__WEBPACK_IMPORTED_MODULE_2__);
18
+ /* harmony import */ var next_link__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9097);
19
+
20
+
21
+
22
+
23
+ function BreadCrumbs({ pages , homePath ='/events' }) {
24
+ return(/*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("nav", {
25
+ className: "flex",
26
+ "aria-label": "Breadcrumb",
27
+ children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("ol", {
28
+ className: "flex items-center space-x-4",
29
+ children: [
30
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("li", {
31
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(next_link__WEBPACK_IMPORTED_MODULE_3__["default"], {
32
+ href: homePath,
33
+ children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("a", {
34
+ className: "text-gray-400 hover:text-gray-500",
35
+ children: [
36
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_heroicons_react_solid__WEBPACK_IMPORTED_MODULE_2__.HomeIcon, {
37
+ className: "flex-shrink-0 h-5 w-5",
38
+ "aria-hidden": "true"
39
+ }),
40
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("span", {
41
+ className: "sr-only",
42
+ children: "Home"
43
+ })
44
+ ]
45
+ })
46
+ })
47
+ }),
48
+ pages.map((page)=>/*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("li", {
49
+ children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
50
+ className: "flex items-center",
51
+ children: [
52
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("svg", {
53
+ className: "flex-shrink-0 h-5 w-5 text-gray-300",
54
+ xmlns: "http://www.w3.org/2000/svg",
55
+ fill: "currentColor",
56
+ viewBox: "0 0 20 20",
57
+ "aria-hidden": "true",
58
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("path", {
59
+ d: "M5.555 17.776l8-16 .894.448-8 16-.894-.448z"
60
+ })
61
+ }),
62
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(next_link__WEBPACK_IMPORTED_MODULE_3__["default"], {
63
+ href: page.href,
64
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("a", {
65
+ className: "ml-4 text-sm font-medium text-gray-500 hover:text-gray-700",
66
+ "aria-current": page.current ? 'page' : undefined,
67
+ children: page.name
68
+ })
69
+ })
70
+ ]
71
+ })
72
+ }, page.name)
73
+ )
74
+ ]
75
+ })
76
+ }));
77
+ }
78
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (BreadCrumbs);
79
+
80
+
81
+ /***/ })
82
+
83
+ };
84
+ ;
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ exports.id = 47;
3
+ exports.ids = [47];
4
+ exports.modules = {
5
+
6
+ /***/ 9071:
7
+ /***/ ((__unused_webpack_module, exports) => {
8
+
9
+
10
+ Object.defineProperty(exports, "__esModule", ({
11
+ value: true
12
+ }));
13
+ exports.cancelIdleCallback = exports.requestIdleCallback = void 0;
14
+ const requestIdleCallback = typeof self !== 'undefined' && self.requestIdleCallback && self.requestIdleCallback.bind(window) || function(cb) {
15
+ let start = Date.now();
16
+ return setTimeout(function() {
17
+ cb({
18
+ didTimeout: false,
19
+ timeRemaining: function() {
20
+ return Math.max(0, 50 - (Date.now() - start));
21
+ }
22
+ });
23
+ }, 1);
24
+ };
25
+ exports.requestIdleCallback = requestIdleCallback;
26
+ const cancelIdleCallback = typeof self !== 'undefined' && self.cancelIdleCallback && self.cancelIdleCallback.bind(window) || function(id) {
27
+ return clearTimeout(id);
28
+ };
29
+ exports.cancelIdleCallback = cancelIdleCallback; //# sourceMappingURL=request-idle-callback.js.map
30
+
31
+
32
+ /***/ }),
33
+
34
+ /***/ 274:
35
+ /***/ ((__unused_webpack_module, exports) => {
36
+
37
+
38
+ Object.defineProperty(exports, "__esModule", ({
39
+ value: true
40
+ }));
41
+ exports["default"] = isError;
42
+ function isError(err) {
43
+ return typeof err === 'object' && err !== null && 'name' in err && 'message' in err;
44
+ }
45
+
46
+ //# sourceMappingURL=is-error.js.map
47
+
48
+ /***/ })
49
+
50
+ };
51
+ ;
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ exports.id = 526;
3
+ exports.ids = [526];
4
+ exports.modules = {
5
+
6
+ /***/ 526:
7
+ /***/ ((module, __webpack_exports__, __webpack_require__) => {
8
+
9
+ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__) => {
10
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
11
+ /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
12
+ /* harmony export */ });
13
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(997);
14
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
15
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6689);
16
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);
17
+ /* harmony import */ var next_link__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9097);
18
+ /* harmony import */ var _heroicons_react_outline__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(8768);
19
+ /* harmony import */ var _heroicons_react_outline__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_heroicons_react_outline__WEBPACK_IMPORTED_MODULE_3__);
20
+ /* harmony import */ var _utils_random_bg__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(6892);
21
+ /* harmony import */ var _components_Mermaid__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(788);
22
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_components_Mermaid__WEBPACK_IMPORTED_MODULE_4__]);
23
+ _components_Mermaid__WEBPACK_IMPORTED_MODULE_4__ = (__webpack_async_dependencies__.then ? await __webpack_async_dependencies__ : __webpack_async_dependencies__)[0];
24
+
25
+
26
+
27
+
28
+
29
+
30
+ function classNames(...classes) {
31
+ return classes.filter(Boolean).join(' ');
32
+ }
33
+ function EventGrid({ events =[] , showMermaidDiagrams =false }) {
34
+ return(/*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("ul", {
35
+ className: "mt-3 grid grid-cols-1 gap-5 md:grid-cols-2",
36
+ children: events.map((event)=>{
37
+ const { draft: isDraft } = event;
38
+ return(/*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("li", {
39
+ className: "flex",
40
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(next_link__WEBPACK_IMPORTED_MODULE_2__["default"], {
41
+ href: `/events/${event.name}`,
42
+ children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("a", {
43
+ className: "flex shadow-sm rounded-md w-full",
44
+ children: [
45
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
46
+ style: {
47
+ background: (0,_utils_random_bg__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z)(event.name)
48
+ },
49
+ className: classNames('bg-red-500', 'flex-shrink-0 flex items-center justify-center w-4 text-white text-sm font-medium rounded-l-md')
50
+ }),
51
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
52
+ className: "w-full border-t border-r border-b border-gray-200 bg-white rounded-r-md ",
53
+ children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
54
+ className: "p-4 text-sm space-y-2 flex flex-col justify-between h-full",
55
+ children: [
56
+ /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
57
+ className: "text-gray-900 font-bold hover:text-gray-600",
58
+ children: [
59
+ event.name,
60
+ /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("span", {
61
+ className: "ml-2 inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-yellow-100 text-yellow-800",
62
+ children: [
63
+ "v",
64
+ event.version
65
+ ]
66
+ }),
67
+ isDraft && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("span", {
68
+ className: "ml-2 inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-gray-500 text-gray-100",
69
+ children: "Draft"
70
+ }),
71
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
72
+ className: "text-gray-500 text-xs font-normal mt-2 ",
73
+ children: event.summary
74
+ })
75
+ ]
76
+ }),
77
+ showMermaidDiagrams && /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
78
+ className: "h-full items-center flex",
79
+ children: /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_components_Mermaid__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z, {
80
+ source: "event",
81
+ data: event,
82
+ rootNodeColor: (0,_utils_random_bg__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z)(event.name)
83
+ })
84
+ }),
85
+ /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
86
+ className: "flex space-x-4 text-xs pt-2 relative bottom-0 left-0",
87
+ children: [
88
+ /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
89
+ className: " font-medium text-gray-500",
90
+ children: [
91
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_heroicons_react_outline__WEBPACK_IMPORTED_MODULE_3__.CubeIcon, {
92
+ className: "h-4 w-4 text-green-400 inline-block mr-2",
93
+ "aria-hidden": "true"
94
+ }),
95
+ "Producers (",
96
+ event.producers.length,
97
+ ")"
98
+ ]
99
+ }),
100
+ /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)("div", {
101
+ className: " font-medium text-gray-500",
102
+ children: [
103
+ /*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx(_heroicons_react_outline__WEBPACK_IMPORTED_MODULE_3__.CubeIcon, {
104
+ className: "h-4 w-4 text-indigo-400 inline-block mr-2",
105
+ "aria-hidden": "true"
106
+ }),
107
+ "Subscribers (",
108
+ event.consumers.length,
109
+ ")"
110
+ ]
111
+ })
112
+ ]
113
+ })
114
+ ]
115
+ })
116
+ })
117
+ ]
118
+ })
119
+ })
120
+ }, event.name));
121
+ })
122
+ }));
123
+ }
124
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EventGrid);
125
+
126
+ });
127
+
128
+ /***/ })
129
+
130
+ };
131
+ ;
@@ -0,0 +1,121 @@
1
+ "use strict";
2
+ exports.id = 565;
3
+ exports.ids = [565];
4
+ exports.modules = {
5
+
6
+ /***/ 788:
7
+ /***/ ((module, __webpack_exports__, __webpack_require__) => {
8
+
9
+ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__) => {
10
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
11
+ /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
12
+ /* harmony export */ });
13
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(997);
14
+ /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__);
15
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6689);
16
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);
17
+ /* harmony import */ var mermaid__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1024);
18
+ /* harmony import */ var _lib_graphs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7360);
19
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([mermaid__WEBPACK_IMPORTED_MODULE_2__]);
20
+ mermaid__WEBPACK_IMPORTED_MODULE_2__ = (__webpack_async_dependencies__.then ? await __webpack_async_dependencies__ : __webpack_async_dependencies__)[0];
21
+
22
+
23
+
24
+
25
+ mermaid__WEBPACK_IMPORTED_MODULE_2__["default"].initialize({
26
+ startOnLoad: true,
27
+ theme: 'forest',
28
+ securityLevel: 'loose',
29
+ flowchart: {
30
+ useMaxWidth: false,
31
+ width: '1000px'
32
+ },
33
+ themeCSS: `
34
+ .node {
35
+ filter: drop-shadow( 3px 3px 2px rgba(0, 0, 0, .2))
36
+ }
37
+ .mermaid svg {
38
+ width: 10000px
39
+ }
40
+ .node rect {
41
+ fill: white
42
+ }
43
+ `,
44
+ fontFamily: 'Fira Code',
45
+ width: '100%'
46
+ });
47
+ function Mermaid({ data , source ='event' , rootNodeColor }) {
48
+ const mermaidChart = source === 'event' ? (0,_lib_graphs__WEBPACK_IMPORTED_MODULE_3__/* .buildMermaidFlowChartForEvent */ .B)(data, rootNodeColor) : (0,_lib_graphs__WEBPACK_IMPORTED_MODULE_3__/* .buildMermaidFlowChartForService */ .S)(data, rootNodeColor);
49
+ (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{
50
+ mermaid__WEBPACK_IMPORTED_MODULE_2__["default"].contentLoaded();
51
+ }, []);
52
+ return(/*#__PURE__*/ react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx("div", {
53
+ className: "mermaid",
54
+ children: mermaidChart
55
+ }));
56
+ }
57
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Mermaid);
58
+
59
+ });
60
+
61
+ /***/ }),
62
+
63
+ /***/ 7360:
64
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
65
+
66
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
67
+ /* harmony export */ "B": () => (/* binding */ buildMermaidFlowChartForEvent),
68
+ /* harmony export */ "S": () => (/* binding */ buildMermaidFlowChartForService)
69
+ /* harmony export */ });
70
+ const buildMermaid = (centerNode, leftNodes, rightNodes, rootNodeColor)=>{
71
+ // mermaid does not work with spaces in nodes
72
+ const removeSpacesInNames = (nodes)=>nodes.map((node)=>node.replace(/ /g, '_')
73
+ )
74
+ ;
75
+ const lNodes = removeSpacesInNames(leftNodes);
76
+ const rNodes = removeSpacesInNames(rightNodes);
77
+ const nodeValue = centerNode.replace(/ /g, '_');
78
+ return `flowchart LR
79
+ ${lNodes.map((node)=>`${node}:::producer-->${nodeValue}:::event\n`
80
+ ).join('')}
81
+ classDef event stroke:${rootNodeColor},stroke-width: 4px;
82
+ classDef producer stroke:#75d7b6,stroke-width: 2px;
83
+ classDef consumer stroke:#818cf8,stroke-width: 2px;
84
+ ${rNodes.map((node)=>`${nodeValue}:::event-->${node}:::consumer\n`
85
+ ).join('')}
86
+ `;
87
+ };
88
+ const buildMermaidFlowChartForEvent = ({ name: eventName , producers , consumers }, rootNodeColor = '#2563eb')=>buildMermaid(eventName, producers, consumers, rootNodeColor)
89
+ ;
90
+ const buildMermaidFlowChartForService = ({ publishes , subscribes , name: serviceName }, rootNodeColor = '#2563eb')=>buildMermaid(serviceName, subscribes.map((s)=>s.name
91
+ ), publishes.map((p)=>p.name
92
+ ), rootNodeColor)
93
+ ;
94
+
95
+
96
+ /***/ }),
97
+
98
+ /***/ 6892:
99
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
100
+
101
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
102
+ /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__)
103
+ /* harmony export */ });
104
+ /* eslint-disable */ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ((str)=>{
105
+ let hash = 0;
106
+ for(let i = 0; i < str.length; i++){
107
+ hash = str.charCodeAt(i) + ((hash << 5) - hash);
108
+ }
109
+ let colour = '#';
110
+ for(let i1 = 0; i1 < 3; i1++){
111
+ const value = hash >> i1 * 8 & 255;
112
+ colour += `00${value.toString(16)}`.substr(-2);
113
+ }
114
+ return colour;
115
+ });
116
+
117
+
118
+ /***/ })
119
+
120
+ };
121
+ ;
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+ exports.id = 596;
3
+ exports.ids = [596];
4
+ exports.modules = {
5
+
6
+ /***/ 9596:
7
+ /***/ ((module, __webpack_exports__, __webpack_require__) => {
8
+
9
+ __webpack_require__.a(module, async (__webpack_handle_async_dependencies__) => {
10
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
11
+ /* harmony export */ "UV": () => (/* binding */ getAllServices),
12
+ /* harmony export */ "vY": () => (/* binding */ getAllServicesByOwnerId),
13
+ /* harmony export */ "in": () => (/* binding */ getServiceByName)
14
+ /* harmony export */ });
15
+ /* harmony import */ var fs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7147);
16
+ /* harmony import */ var fs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(fs__WEBPACK_IMPORTED_MODULE_0__);
17
+ /* harmony import */ var path__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1017);
18
+ /* harmony import */ var path__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_1__);
19
+ /* harmony import */ var next_mdx_remote_serialize__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7112);
20
+ /* harmony import */ var next_mdx_remote_serialize__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_mdx_remote_serialize__WEBPACK_IMPORTED_MODULE_2__);
21
+ /* harmony import */ var _lib_file_reader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(2432);
22
+ /* harmony import */ var _lib_events__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(9959);
23
+ var __webpack_async_dependencies__ = __webpack_handle_async_dependencies__([_lib_events__WEBPACK_IMPORTED_MODULE_4__]);
24
+ _lib_events__WEBPACK_IMPORTED_MODULE_4__ = (__webpack_async_dependencies__.then ? await __webpack_async_dependencies__ : __webpack_async_dependencies__)[0];
25
+
26
+
27
+
28
+
29
+
30
+ const buildService = (eventFrontMatter)=>{
31
+ const { name , summary , owners =[] , repository ={
32
+ } , tags =[] , externalLinks =[] } = eventFrontMatter;
33
+ return {
34
+ name,
35
+ summary,
36
+ owners,
37
+ repository,
38
+ tags,
39
+ externalLinks
40
+ };
41
+ };
42
+ const getAllServices = ()=>{
43
+ const servicesDir = path__WEBPACK_IMPORTED_MODULE_1___default().join(process.env.PROJECT_DIR, 'services');
44
+ const folders = fs__WEBPACK_IMPORTED_MODULE_0___default().readdirSync(servicesDir);
45
+ const services = folders.map((folder)=>(0,_lib_file_reader__WEBPACK_IMPORTED_MODULE_3__/* .readMarkdownFile */ .ws)(path__WEBPACK_IMPORTED_MODULE_1___default().join(servicesDir, folder, 'index.md'))
46
+ );
47
+ const events = (0,_lib_events__WEBPACK_IMPORTED_MODULE_4__/* .getAllEvents */ .IP)();
48
+ const parsedServices = services.map((frontMatter)=>buildService(frontMatter.data)
49
+ );
50
+ // @ts-ignore
51
+ return parsedServices.map((service)=>({
52
+ ...service,
53
+ ...(0,_lib_events__WEBPACK_IMPORTED_MODULE_4__/* .getAllEventsThatHaveRelationshipWithService */ .X4)(service, events)
54
+ })
55
+ );
56
+ };
57
+ const getAllServicesByOwnerId = async (ownerId)=>{
58
+ const services = await getAllServices();
59
+ const servicesOwnedByUser = services.filter((service)=>service.owners.some((id)=>id === ownerId
60
+ )
61
+ );
62
+ return servicesOwnedByUser.map((service)=>({
63
+ ...service
64
+ })
65
+ );
66
+ };
67
+ const getServiceByName = async (serviceName)=>{
68
+ try {
69
+ const servicesDir = path__WEBPACK_IMPORTED_MODULE_1___default().join(process.env.PROJECT_DIR, 'services');
70
+ const serviceDirectory = path__WEBPACK_IMPORTED_MODULE_1___default().join(servicesDir, serviceName);
71
+ const { data , content } = (0,_lib_file_reader__WEBPACK_IMPORTED_MODULE_3__/* .readMarkdownFile */ .ws)(path__WEBPACK_IMPORTED_MODULE_1___default().join(serviceDirectory, `index.md`));
72
+ const service = buildService(data);
73
+ const events = (0,_lib_events__WEBPACK_IMPORTED_MODULE_4__/* .getAllEvents */ .IP)();
74
+ const mdxSource = await (0,next_mdx_remote_serialize__WEBPACK_IMPORTED_MODULE_2__.serialize)(content);
75
+ return {
76
+ // @ts-ignore
77
+ service: {
78
+ ...service,
79
+ ...(0,_lib_events__WEBPACK_IMPORTED_MODULE_4__/* .getAllEventsThatHaveRelationshipWithService */ .X4)(service, events)
80
+ },
81
+ markdown: {
82
+ content,
83
+ lastModifiedDate: (0,_lib_file_reader__WEBPACK_IMPORTED_MODULE_3__/* .getLastModifiedDateOfFile */ .cn)(path__WEBPACK_IMPORTED_MODULE_1___default().join(serviceDirectory, `index.md`)),
84
+ source: mdxSource
85
+ }
86
+ };
87
+ } catch (error) {
88
+ console.log('Failed to get service by name', serviceName);
89
+ return Promise.reject();
90
+ }
91
+ };
92
+
93
+ });
94
+
95
+ /***/ })
96
+
97
+ };
98
+ ;